{"version":3,"sources":["__prelude__","/../../node_modules/metro-runtime/src/polyfills/require.js","\u0000polyfill:external-require","\u0000polyfill:environment-variables","/../../node_modules/@react-native/js-polyfills/error-guard.js","/index.js","/../../node_modules/expo-router/entry.js","/../../node_modules/@expo/metro-runtime/build/index.js","/../../node_modules/@expo/metro-runtime/build/location/install.js","/../../node_modules/@expo/metro-runtime/build/effects.js","/../../node_modules/@expo/metro-runtime/build/async-require/index.js","/../../node_modules/@expo/metro-runtime/build/async-require/buildAsyncRequire.js","/../../node_modules/@expo/metro-runtime/build/async-require/loadBundle.js","/../../node_modules/@expo/metro-runtime/build/async-require/buildUrlForBundle.js","/../../node_modules/@expo/metro-runtime/build/async-require/fetchThenEval.web.js","/../../node_modules/expo-router/build/qualified-entry.js","/../../node_modules/react/jsx-runtime.js","/../../node_modules/react/cjs/react-jsx-runtime.production.min.js","/../../node_modules/react/index.js","/../../node_modules/react/cjs/react.production.min.js","/../../node_modules/expo-router/_ctx.web.js","/app?ctx=e5807cc4e93b7ea02120ad0165264d893ac772db","/app/_layout.js","/../../node_modules/@babel/runtime/helpers/interopRequireDefault.js","/../../node_modules/react-native-gesture-handler/lib/module/index.js","/../../node_modules/react-native-gesture-handler/lib/module/init.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/eventReceiver.js","/../../node_modules/react-native-web/dist/exports/DeviceEventEmitter/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/EventEmitter/RCTDeviceEventEmitter.js","/../../node_modules/react-native-web/dist/vendor/react-native/vendor/emitter/EventEmitter.js","/../../node_modules/react-native-gesture-handler/lib/module/State.js","/../../node_modules/react-native-gesture-handler/lib/module/TouchEventType.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/handlersRegistry.js","/../../node_modules/react-native-gesture-handler/lib/module/utils.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/gestureStateManager.web.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/NodeManager.js","/../../node_modules/react-native-gesture-handler/lib/module/RNGestureHandlerModule.web.js","/../../node_modules/react-native-gesture-handler/lib/module/EnableNewWebImplementation.js","/../../node_modules/react-native-web/dist/exports/Platform/index.js","/../../node_modules/react-native-gesture-handler/lib/module/web/Gestures.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/PanGestureHandler.js","/../../node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js","/../../node_modules/react-native-gesture-handler/lib/module/web/constants.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/GestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web/interfaces.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/GestureHandlerOrchestrator.js","/../../node_modules/react-native-gesture-handler/lib/module/PointerType.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/PointerTracker.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/VelocityTracker.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/CircularBuffer.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/LeastSquareSolver.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/InteractionManager.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestureHandlerCommon.js","/../../node_modules/react-native-web/dist/exports/findNodeHandle/index.js","/../../node_modules/react-dom/index.js","/../../node_modules/react-dom/cjs/react-dom.production.min.js","/../../node_modules/scheduler/index.js","/../../node_modules/scheduler/cjs/scheduler.production.min.js","/../../node_modules/react-native-gesture-handler/lib/module/ghQueueMicrotask.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/TapGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/LongPressGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/PinchGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web/detectors/ScaleGestureDetector.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/RotationGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web/detectors/RotationGestureDetector.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/FlingGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/Directions.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/Vector.js","/../../node_modules/react-native-gesture-handler/lib/module/web/utils.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/NativeViewGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/ManualGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web/handlers/HoverGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/NativeViewGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/DiscreteGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/GestureHandler.js","/../../node_modules/@egjs/hammerjs/dist/hammer.esm.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/constants.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/NodeManager.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/utils.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/PressGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/PanGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/DraggingGestureHandler.js","/../../node_modules/react-native-web/dist/exports/PixelRatio/index.js","/../../node_modules/react-native-web/dist/exports/Dimensions/index.js","/../../node_modules/fbjs/lib/invariant.js","/../../node_modules/react-native-web/dist/modules/canUseDom/index.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/TapGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/LongPressGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/PinchGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/IndiscreteGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/RotationGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/FlingGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/web_hammer/Errors.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/GestureHandlerWebDelegate.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/PointerEventManager.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/EventManager.js","/../../node_modules/react-native-gesture-handler/lib/module/web/tools/TouchEventManager.js","/../../node_modules/react-native-gesture-handler/lib/module/components/gestureHandlerRootHOC.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/index.js","/../../node_modules/@babel/runtime/helpers/objectSpread2.js","/../../node_modules/@babel/runtime/helpers/defineProperty.js","/../../node_modules/@babel/runtime/helpers/toPropertyKey.js","/../../node_modules/@babel/runtime/helpers/typeof.js","/../../node_modules/@babel/runtime/helpers/toPrimitive.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/compiler/index.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/compiler/createReactDOMStyle.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/compiler/normalizeValueWithProperty.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/compiler/unitlessNumbers.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/compiler/normalizeColor.js","/../../node_modules/react-native-web/dist/modules/isWebColor/index.js","/../../node_modules/react-native-web/dist/exports/processColor/index.js","/../../node_modules/@react-native/normalize-colors/index.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/compiler/hash.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/compiler/hyphenateStyleName.js","/../../node_modules/react-native-web/dist/modules/prefixStyles/index.js","/../../node_modules/inline-style-prefixer/lib/createPrefixer.js","/../../node_modules/inline-style-prefixer/lib/utils/prefixProperty.js","/../../node_modules/inline-style-prefixer/lib/utils/capitalizeString.js","/../../node_modules/inline-style-prefixer/lib/utils/prefixValue.js","/../../node_modules/inline-style-prefixer/lib/utils/addNewValuesOnly.js","/../../node_modules/inline-style-prefixer/lib/utils/isObject.js","/../../node_modules/react-native-web/dist/modules/prefixStyles/static.js","/../../node_modules/inline-style-prefixer/lib/plugins/backgroundClip.js","/../../node_modules/inline-style-prefixer/lib/plugins/crossFade.js","/../../node_modules/css-in-js-utils/es/index.js","/../../node_modules/css-in-js-utils/es/assignStyle.js","/../../node_modules/css-in-js-utils/es/camelCaseProperty.js","/../../node_modules/css-in-js-utils/es/cssifyDeclaration.js","/../../node_modules/css-in-js-utils/es/hyphenateProperty.js","/../../node_modules/hyphenate-style-name/index.js","/../../node_modules/css-in-js-utils/es/cssifyObject.js","/../../node_modules/css-in-js-utils/es/isPrefixedProperty.js","/../../node_modules/css-in-js-utils/es/isPrefixedValue.js","/../../node_modules/css-in-js-utils/es/isUnitlessProperty.js","/../../node_modules/css-in-js-utils/es/normalizeProperty.js","/../../node_modules/css-in-js-utils/es/unprefixProperty.js","/../../node_modules/css-in-js-utils/es/resolveArrayValue.js","/../../node_modules/css-in-js-utils/es/unprefixValue.js","/../../node_modules/inline-style-prefixer/lib/plugins/cursor.js","/../../node_modules/inline-style-prefixer/lib/plugins/filter.js","/../../node_modules/inline-style-prefixer/lib/plugins/imageSet.js","/../../node_modules/css-in-js-utils/lib/isPrefixedValue.js","/../../node_modules/inline-style-prefixer/lib/plugins/logical.js","/../../node_modules/inline-style-prefixer/lib/plugins/position.js","/../../node_modules/inline-style-prefixer/lib/plugins/sizing.js","/../../node_modules/inline-style-prefixer/lib/plugins/transition.js","/../../node_modules/css-in-js-utils/lib/hyphenateProperty.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/dom/index.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/dom/createCSSStyleSheet.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/dom/createOrderedCSSStyleSheet.js","/../../node_modules/styleq/transform-localize-style.js","/../../node_modules/styleq/dist/transform-localize-style.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/preprocess.js","/../../node_modules/react-native-web/dist/modules/warnOnce/index.js","/../../node_modules/styleq/dist/styleq.js","/../../node_modules/react-native-web/dist/exports/StyleSheet/validate.js","/../../node_modules/postcss-value-parser/lib/index.js","/../../node_modules/postcss-value-parser/lib/parse.js","/../../node_modules/postcss-value-parser/lib/walk.js","/../../node_modules/postcss-value-parser/lib/stringify.js","/../../node_modules/postcss-value-parser/lib/unit.js","/../../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","/../../node_modules/react-is/index.js","/../../node_modules/react-is/cjs/react-is.production.min.js","/../../node_modules/react-native-gesture-handler/lib/module/components/GestureHandlerRootView.web.js","/../../node_modules/react-native-web/dist/exports/View/index.js","/../../node_modules/react-native-web/dist/exports/createElement/index.js","/../../node_modules/react-native-web/dist/modules/AccessibilityUtil/index.js","/../../node_modules/react-native-web/dist/modules/AccessibilityUtil/isDisabled.js","/../../node_modules/react-native-web/dist/modules/AccessibilityUtil/propsToAccessibilityComponent.js","/../../node_modules/react-native-web/dist/modules/AccessibilityUtil/propsToAriaRole.js","/../../node_modules/react-native-web/dist/modules/createDOMProps/index.js","/../../node_modules/react-native-web/dist/modules/useLocale/index.js","/../../node_modules/react-native-web/dist/modules/useLocale/isLocaleRTL.js","/../../node_modules/react-native-web/dist/modules/forwardedProps/index.js","/../../node_modules/react-native-web/dist/modules/pick/index.js","/../../node_modules/react-native-web/dist/modules/useElementLayout/index.js","/../../node_modules/react-native-web/dist/modules/useLayoutEffect/index.js","/../../node_modules/react-native-web/dist/exports/UIManager/index.js","/../../node_modules/react-native-web/dist/modules/getBoundingClientRect/index.js","/../../node_modules/react-native-web/dist/modules/setValueForStyles/index.js","/../../node_modules/react-native-web/dist/modules/setValueForStyles/dangerousStyleValue.js","/../../node_modules/react-native-web/dist/modules/unitlessNumbers/index.js","/../../node_modules/react-native-web/dist/modules/useMergeRefs/index.js","/../../node_modules/react-native-web/dist/modules/mergeRefs/index.js","/../../node_modules/react-native-web/dist/modules/usePlatformMethods/index.js","/../../node_modules/react-native-web/dist/modules/useStable/index.js","/../../node_modules/react-native-web/dist/modules/useResponderEvents/index.js","/../../node_modules/react-native-web/dist/modules/useResponderEvents/ResponderSystem.js","/../../node_modules/react-native-web/dist/modules/useResponderEvents/createResponderEvent.js","/../../node_modules/react-native-web/dist/modules/useResponderEvents/ResponderEventTypes.js","/../../node_modules/react-native-web/dist/modules/useResponderEvents/utils.js","/../../node_modules/react-native-web/dist/modules/isSelectionValid/index.js","/../../node_modules/react-native-web/dist/modules/useResponderEvents/ResponderTouchHistoryStore.js","/../../node_modules/react-native-web/dist/exports/Text/TextAncestorContext.js","/../../node_modules/react-native-gesture-handler/lib/module/GestureHandlerRootViewContext.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/TapGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/createHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/customDirectEventTypes.web.js","/../../node_modules/lodash/isEqual.js","/../../node_modules/lodash/_baseIsEqual.js","/../../node_modules/lodash/_baseIsEqualDeep.js","/../../node_modules/lodash/_Stack.js","/../../node_modules/lodash/_ListCache.js","/../../node_modules/lodash/_listCacheClear.js","/../../node_modules/lodash/_listCacheDelete.js","/../../node_modules/lodash/_assocIndexOf.js","/../../node_modules/lodash/eq.js","/../../node_modules/lodash/_listCacheGet.js","/../../node_modules/lodash/_listCacheHas.js","/../../node_modules/lodash/_listCacheSet.js","/../../node_modules/lodash/_stackClear.js","/../../node_modules/lodash/_stackDelete.js","/../../node_modules/lodash/_stackGet.js","/../../node_modules/lodash/_stackHas.js","/../../node_modules/lodash/_stackSet.js","/../../node_modules/lodash/_Map.js","/../../node_modules/lodash/_getNative.js","/../../node_modules/lodash/_baseIsNative.js","/../../node_modules/lodash/isFunction.js","/../../node_modules/lodash/_baseGetTag.js","/../../node_modules/lodash/_Symbol.js","/../../node_modules/lodash/_root.js","/../../node_modules/lodash/_freeGlobal.js","/../../node_modules/lodash/_getRawTag.js","/../../node_modules/lodash/_objectToString.js","/../../node_modules/lodash/isObject.js","/../../node_modules/lodash/_isMasked.js","/../../node_modules/lodash/_coreJsData.js","/../../node_modules/lodash/_toSource.js","/../../node_modules/lodash/_getValue.js","/../../node_modules/lodash/_MapCache.js","/../../node_modules/lodash/_mapCacheClear.js","/../../node_modules/lodash/_Hash.js","/../../node_modules/lodash/_hashClear.js","/../../node_modules/lodash/_nativeCreate.js","/../../node_modules/lodash/_hashDelete.js","/../../node_modules/lodash/_hashGet.js","/../../node_modules/lodash/_hashHas.js","/../../node_modules/lodash/_hashSet.js","/../../node_modules/lodash/_mapCacheDelete.js","/../../node_modules/lodash/_getMapData.js","/../../node_modules/lodash/_isKeyable.js","/../../node_modules/lodash/_mapCacheGet.js","/../../node_modules/lodash/_mapCacheHas.js","/../../node_modules/lodash/_mapCacheSet.js","/../../node_modules/lodash/_equalArrays.js","/../../node_modules/lodash/_SetCache.js","/../../node_modules/lodash/_setCacheAdd.js","/../../node_modules/lodash/_setCacheHas.js","/../../node_modules/lodash/_arraySome.js","/../../node_modules/lodash/_cacheHas.js","/../../node_modules/lodash/_equalByTag.js","/../../node_modules/lodash/_Uint8Array.js","/../../node_modules/lodash/_mapToArray.js","/../../node_modules/lodash/_setToArray.js","/../../node_modules/lodash/_equalObjects.js","/../../node_modules/lodash/_getAllKeys.js","/../../node_modules/lodash/_baseGetAllKeys.js","/../../node_modules/lodash/_arrayPush.js","/../../node_modules/lodash/isArray.js","/../../node_modules/lodash/_getSymbols.js","/../../node_modules/lodash/_arrayFilter.js","/../../node_modules/lodash/stubArray.js","/../../node_modules/lodash/keys.js","/../../node_modules/lodash/_arrayLikeKeys.js","/../../node_modules/lodash/_baseTimes.js","/../../node_modules/lodash/isArguments.js","/../../node_modules/lodash/_baseIsArguments.js","/../../node_modules/lodash/isObjectLike.js","/../../node_modules/lodash/isBuffer.js","/../../node_modules/lodash/stubFalse.js","/../../node_modules/lodash/_isIndex.js","/../../node_modules/lodash/isTypedArray.js","/../../node_modules/lodash/_baseIsTypedArray.js","/../../node_modules/lodash/isLength.js","/../../node_modules/lodash/_baseUnary.js","/../../node_modules/lodash/_nodeUtil.js","/../../node_modules/lodash/_baseKeys.js","/../../node_modules/lodash/_isPrototype.js","/../../node_modules/lodash/_nativeKeys.js","/../../node_modules/lodash/_overArg.js","/../../node_modules/lodash/isArrayLike.js","/../../node_modules/lodash/_getTag.js","/../../node_modules/lodash/_DataView.js","/../../node_modules/lodash/_Promise.js","/../../node_modules/lodash/_Set.js","/../../node_modules/lodash/_WeakMap.js","/../../node_modules/react-native-gesture-handler/lib/module/ActionType.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/PressabilityDebugView.web.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/ForceTouchGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/PlatformConstants.web.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/LongPressGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/PanGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/PinchGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/RotationGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/FlingGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/createNativeWrapper.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/NativeViewGestureHandler.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/GestureDetector.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/gesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/reanimatedWrapper.js","/../../node_modules/react-native-reanimated/lib/module/index.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/publicGlobals.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/core.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/NativeReanimated/index.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/js-reanimated/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/js-reanimated/JSReanimated.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/PlatformChecker.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/commonTypes.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/mockedRequestAnimationFrame.js","/../../node_modules/react-native-reanimated/lib/module/propsAllowlists.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/shareables.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/errors.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platform-specific/jsVersion.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/shareableMappingCache.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/initializers.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/threads.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/SensorContainer.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/Sensor.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/mutables.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/valueSetter.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/mappers.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/isSharedValue.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/runtimes.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useAnimatedProps.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useAnimatedStyle.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/UpdateProps.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/Colors.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/util.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/transformationMatrix/matrixUtils.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/timing.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/Easing.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/Bezier.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/spring.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/springUtils.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/decay/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/decay/decay.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/decay/rubberBandDecay.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/decay/utils.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/decay/rigidDecay.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/clamp.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/delay.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/repeat.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/sequence.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/animation/styleAnimation.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useSharedValue.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/utils.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/ViewDescriptorsSet.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useWorkletCallback.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useReducedMotion.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useAnimatedGestureHandler.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useHandler.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useEvent.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/WorkletEventHandler.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useAnimatedReaction.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useAnimatedRef.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/fabricUtils.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useAnimatedScrollHandler.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useDerivedValue.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useAnimatedSensor.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useFrameCallback.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/frameCallback/FrameCallbackRegistryJS.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/frameCallback/FrameCallbackRegistryUI.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useAnimatedKeyboard.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/hook/useScrollViewOffset.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/interpolation.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/interpolateColor.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platformFunctions/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platformFunctions/dispatchCommand.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platformFunctions/measure.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platformFunctions/scrollTo.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platformFunctions/setGestureState.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platformFunctions/setNativeProps.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platformFunctions/getRelativeCoords.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/PropAdapters.js","/../../node_modules/react-native-reanimated/lib/module/ConfigHelper.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/animationsManager.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/animationBuilder/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/animationBuilder/BaseAnimationBuilder.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/animationBuilder/ComplexAnimationBuilder.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/animationBuilder/Keyframe.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/animationBuilder/commonTypes.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Flip.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Stretch.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Fade.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Slide.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Zoom.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Bounce.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Lightspeed.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Pinwheel.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Rotate.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultAnimations/Roll.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultTransitions/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultTransitions/LinearTransition.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultTransitions/FadingTransition.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultTransitions/SequencedTransition.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultTransitions/JumpingTransition.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultTransitions/CurvedTransition.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/defaultTransitions/EntryExitTransition.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/sharedTransitions/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/sharedTransitions/SharedTransition.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/sharedTransitions/ProgressTransitionManager.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/pluginUtils.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/jestUtils.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/component/LayoutAnimationConfig.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/component/PerformanceMonitor.js","/../../node_modules/react-native-web/dist/exports/TextInput/index.js","/../../node_modules/react-native-web/dist/modules/TextInputState/index.js","/../../node_modules/react-native-reanimated/lib/module/createAnimatedComponent/index.js","/../../node_modules/react-native-reanimated/lib/module/createAnimatedComponent/createAnimatedComponent.js","/../../node_modules/invariant/browser.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/platform-specific/RNRenderer.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/PropsRegistry.js","/../../node_modules/react-native-reanimated/lib/module/animationBuilder.js","/../../node_modules/react-native-reanimated/lib/module/createAnimatedComponent/JSPropsUpdater.web.js","/../../node_modules/react-native-reanimated/lib/module/createAnimatedComponent/utils.js","/../../node_modules/react-native-reanimated/lib/module/createAnimatedComponent/setAndForwardRef.js","/../../node_modules/react-native-reanimated/lib/module/createAnimatedComponent/InlinePropManager.js","/../../node_modules/react-native-reanimated/lib/module/createAnimatedComponent/PropsFilter.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animationsManager.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/config.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Bounce.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animationParser.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Fade.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Flip.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Lightspeed.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Pinwheel.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Roll.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Rotate.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Slide.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Stretch.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/animation/Zoom.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/createAnimation.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/transition/Linear.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/transition/Sequenced.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/transition/Fading.web.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/domUtils.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/componentStyle.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/layoutReanimation/web/componentUtils.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/UpdateLayoutAnimations.js","/../../node_modules/react-native-reanimated/lib/module/createAnimatedComponent/getViewInfo.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/screenTransition/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/screenTransition/animationManager.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/screenTransition/styleUpdater.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/screenTransition/swipeSimulator.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/screenTransition/RNScreensTurboModule.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/screenTransition/presets.js","/../../node_modules/react-native-reanimated/lib/module/Animated.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/component/Text.js","/../../node_modules/react-native-web/dist/exports/Text/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/component/View.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/component/ScrollView.js","/../../node_modules/react-native-web/dist/exports/ScrollView/index.js","/../../node_modules/@babel/runtime/helpers/extends.js","/../../node_modules/react-native-web/dist/modules/dismissKeyboard/index.js","/../../node_modules/react-native-web/dist/exports/ScrollView/ScrollViewBase.js","/../../node_modules/fbjs/lib/warning.js","/../../node_modules/fbjs/lib/emptyFunction.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/component/Image.js","/../../node_modules/react-native-web/dist/exports/Image/index.js","/../../node_modules/@react-native/assets-registry/registry.js","/../../node_modules/react-native-web/dist/modules/ImageLoader/index.js","/../../node_modules/react-native-reanimated/lib/module/reanimated2/component/FlatList.js","/../../node_modules/react-native-web/dist/exports/FlatList/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/FlatList/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/deepDiffer/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/VirtualizedList/index.js","/../../node_modules/@babel/runtime/helpers/createForOfIteratorHelperLoose.js","/../../node_modules/@babel/runtime/helpers/unsupportedIterableToArray.js","/../../node_modules/@babel/runtime/helpers/arrayLikeToArray.js","/../../node_modules/react-native-web/dist/exports/RefreshControl/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/Batchinator/index.js","/../../node_modules/react-native-web/dist/exports/InteractionManager/index.js","/../../node_modules/react-native-web/dist/exports/InteractionManager/TaskQueue.js","/../../node_modules/react-native-web/dist/modules/requestIdleCallback/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/Utilities/clamp.js","/../../node_modules/react-native-web/dist/vendor/react-native/infoLog/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/VirtualizedList/CellRenderMask.js","/../../node_modules/react-native-web/dist/vendor/react-native/VirtualizedList/ChildListCollection.js","/../../node_modules/react-native-web/dist/vendor/react-native/FillRateHelper/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/VirtualizedList/StateSafePureComponent.js","/../../node_modules/react-native-web/dist/vendor/react-native/ViewabilityHelper/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/VirtualizedList/VirtualizedListCellRenderer.js","/../../node_modules/react-native-web/dist/vendor/react-native/VirtualizedList/VirtualizedListContext.js","/../../node_modules/react-native-web/dist/vendor/react-native/VirtualizeUtils/index.js","/../../node_modules/nullthrows/nullthrows.js","/../../node_modules/react-native-web/node_modules/memoize-one/dist/memoize-one.esm.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/hoverGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/getReactNativeVersion.web.js","/../../node_modules/react-native-gesture-handler/lib/module/getShadowNodeFromRef.web.js","/../../node_modules/react-native-gesture-handler/lib/module/RNRenderer.web.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/gestureObjects.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/flingGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/forceTouchGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/gestureComposition.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/longPressGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/panGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/pinchGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/rotationGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/tapGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/nativeGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/handlers/gestures/manualGesture.js","/../../node_modules/react-native-gesture-handler/lib/module/components/GestureButtons.js","/../../node_modules/react-native-web/dist/exports/Animated/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/Animated.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/components/AnimatedFlatList.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/createAnimatedComponent.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/useAnimatedProps.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedProps.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/AnimatedEvent.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedValue.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedInterpolation.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedWithChildren.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedNode.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/NativeAnimatedHelper.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/NativeAnimatedModule.js","/../../node_modules/react-native-web/dist/vendor/react-native/TurboModule/TurboModuleRegistry.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/NativeAnimatedTurboModule.js","/../../node_modules/react-native-web/dist/vendor/react-native/EventEmitter/NativeEventEmitter.js","/../../node_modules/react-native-web/dist/vendor/react-native/Utilities/Platform.js","/../../node_modules/react-native-web/dist/vendor/react-native/ReactNative/ReactNativeFeatureFlags.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedStyle.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedTransform.js","/../../node_modules/react-native-web/dist/vendor/react-native/Utilities/useRefEffect.js","/../../node_modules/react-native-web/dist/vendor/react-native/Utilities/useMergeRefs.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/components/AnimatedImage.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/components/AnimatedScrollView.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/components/AnimatedSectionList.js","/../../node_modules/react-native-web/dist/exports/SectionList/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/SectionList/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/VirtualizedSectionList/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/components/AnimatedText.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/components/AnimatedView.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/AnimatedMock.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/AnimatedImplementation.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedAddition.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedDiffClamp.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedDivision.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedModulo.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedMultiplication.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedSubtraction.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedTracking.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedValueXY.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/animations/DecayAnimation.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/animations/Animation.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/animations/SpringAnimation.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/SpringConfig.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/nodes/AnimatedColor.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/animations/TimingAnimation.js","/../../node_modules/react-native-web/dist/exports/Easing/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/Easing.js","/../../node_modules/react-native-web/dist/vendor/react-native/Animated/bezier.js","/../../node_modules/react-native-gesture-handler/lib/module/components/GestureHandlerButton.web.js","/../../node_modules/react-native-gesture-handler/lib/module/components/touchables/index.js","/../../node_modules/react-native-gesture-handler/lib/module/components/touchables/TouchableNativeFeedback.js","/../../node_modules/react-native-web/dist/exports/TouchableNativeFeedback/index.js","/../../node_modules/react-native-web/dist/modules/UnimplementedView/index.js","/../../node_modules/react-native-gesture-handler/lib/module/components/touchables/TouchableWithoutFeedback.js","/../../node_modules/react-native-gesture-handler/lib/module/components/touchables/GenericTouchable.js","/../../node_modules/react-native-gesture-handler/lib/module/components/touchables/TouchableOpacity.js","/../../node_modules/react-native-gesture-handler/lib/module/components/touchables/TouchableHighlight.js","/../../node_modules/react-native-gesture-handler/lib/module/components/GestureComponents.web.js","/../../node_modules/react-native-web/dist/exports/Switch/index.js","/../../node_modules/react-native-web/dist/modules/multiplyStyleLengthValue/index.js","/../../node_modules/react-native-gesture-handler/lib/module/components/Swipeable.js","/../../node_modules/react-native-web/dist/exports/I18nManager/index.js","/../../node_modules/react-native-gesture-handler/lib/module/components/DrawerLayout.js","/../../node_modules/react-native-web/dist/exports/Keyboard/index.js","/../../node_modules/react-native-web/dist/exports/StatusBar/index.js","/../../node_modules/react-native-paper/lib/module/core/PaperProvider.js","/../../node_modules/react-native-web/dist/exports/AccessibilityInfo/index.js","/../../node_modules/react-native-web/dist/exports/Appearance/index.js","/../../node_modules/react-native-paper/lib/module/core/SafeAreaProviderCompat.js","/../../node_modules/react-native-safe-area-context/lib/module/index.js","/../../node_modules/react-native-safe-area-context/lib/module/SafeAreaContext.js","/../../node_modules/react-native-safe-area-context/lib/module/NativeSafeAreaProvider.web.js","/../../node_modules/react-native-safe-area-context/lib/module/SafeAreaView.web.js","/../../node_modules/react-native-safe-area-context/lib/module/InitialWindow.js","/../../node_modules/react-native-safe-area-context/lib/module/SafeArea.types.js","/../../node_modules/react-native-paper/lib/module/core/settings.js","/../../node_modules/react-native-paper/lib/module/components/MaterialCommunityIcon.js","/../../node_modules/react-native-paper/lib/module/styles/themes/v2/colors.js","/../../node_modules/@expo/vector-icons/MaterialCommunityIcons.js","/../../node_modules/@expo/vector-icons/build/MaterialCommunityIcons.js","/../../node_modules/@expo/vector-icons/build/createIconSet.js","/../../node_modules/expo-font/build/index.js","/../../node_modules/expo-font/build/Font.js","/../../node_modules/expo-modules-core/build/index.js","/../../node_modules/expo-modules-core/build/EventEmitter.js","/../../node_modules/react-native-web/dist/exports/NativeEventEmitter/index.js","/../../node_modules/expo-modules-core/build/NativeModule.js","/../../node_modules/expo-modules-core/build/ensureNativeModulesAreInstalled.js","/../../node_modules/react-native-web/dist/exports/NativeModules/index.js","/../../node_modules/expo-modules-core/build/web/index.web.js","/../../node_modules/expo-modules-core/build/web/CoreModule.js","/../../node_modules/expo-modules-core/build/uuid/index.js","/../../node_modules/expo-modules-core/build/uuid/uuid.web.js","/../../node_modules/expo-modules-core/build/uuid/lib/sha1.js","/../../node_modules/expo-modules-core/build/uuid/lib/v35.js","/../../node_modules/expo-modules-core/build/uuid/lib/bytesToUuid.js","/../../node_modules/expo-modules-core/build/uuid/uuid.types.js","/../../node_modules/metro-runtime/src/modules/empty-module.js","/../../node_modules/expo-modules-core/build/NativeModulesProxy.js","/../../node_modules/expo-modules-core/build/NativeViewManagerAdapter.js","/../../node_modules/expo-modules-core/build/errors/UnavailabilityError.js","/../../node_modules/expo-modules-core/build/errors/CodedError.js","/../../node_modules/expo-modules-core/build/Platform.js","/../../node_modules/expo-modules-core/build/environment/browser.web.js","/../../node_modules/expo-modules-core/build/SharedObject.js","/../../node_modules/expo-modules-core/build/sweet/setUpErrorManager.fx.web.js","/../../node_modules/expo-modules-core/build/requireNativeModule.web.js","/../../node_modules/expo-modules-core/build/createWebModule.web.js","/../../node_modules/expo-modules-core/build/TypedArrays.types.js","/../../node_modules/expo-modules-core/build/PermissionsInterface.js","/../../node_modules/expo-modules-core/build/PermissionsHook.js","/../../node_modules/expo-modules-core/build/Refs.js","/../../node_modules/expo-modules-core/build/hooks/useReleasingSharedObject.js","/../../node_modules/expo-modules-core/build/reload.js","/../../node_modules/expo-font/build/ExpoFontLoader.web.js","/../../node_modules/fontfaceobserver/fontfaceobserver.standalone.js","/../../node_modules/expo-font/build/Font.types.js","/../../node_modules/expo-font/build/FontLoader.web.js","/../../node_modules/expo-asset/build/index.js","/../../node_modules/expo-asset/build/Asset.fx.js","/../../node_modules/expo-asset/build/Asset.js","/../../node_modules/expo-asset/build/AssetSources.js","/../../node_modules/expo-asset/build/AssetSourceResolver.js","/../../node_modules/expo-asset/build/PlatformUtils.web.js","/../../node_modules/expo-asset/build/AssetUris.js","/../../node_modules/expo-asset/build/ExpoAsset.web.js","/../../node_modules/expo-asset/build/ImageAssets.js","/../../node_modules/expo-asset/build/LocalAssets.web.js","/../../node_modules/expo-asset/build/resolveAssetSource.js","/../../node_modules/expo-asset/build/AssetHooks.js","/../../node_modules/expo-font/build/memory.js","/../../node_modules/expo-font/build/server.js","/../../node_modules/expo-font/build/FontHooks.js","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/lib/create-icon-set.js","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/lib/ensure-native-module-available.js","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/lib/create-icon-source-cache.js","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/lib/icon-button.js","/../../node_modules/prop-types/index.js","/../../node_modules/prop-types/factoryWithThrowingShims.js","/../../node_modules/prop-types/lib/ReactPropTypesSecret.js","/../../node_modules/react-native-web/dist/exports/TouchableHighlight/index.js","/../../node_modules/react-native-web/dist/modules/usePressEvents/index.js","/../../node_modules/react-native-web/dist/modules/usePressEvents/PressResponder.js","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/lib/object-utils.js","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/Fonts/MaterialCommunityIcons.ttf","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/glyphmaps/MaterialCommunityIcons.json","/../../node_modules/react-native-paper/lib/module/core/theming.js","/../../node_modules/@callstack/react-theme-provider/lib/index.js","/../../node_modules/@callstack/react-theme-provider/lib/createTheming.js","/../../node_modules/@callstack/react-theme-provider/node_modules/deepmerge/dist/umd.js","/../../node_modules/@callstack/react-theme-provider/lib/createThemeProvider.js","/../../node_modules/@callstack/react-theme-provider/lib/createWithTheme.js","/../../node_modules/react-native-paper/node_modules/color/index.js","/../../node_modules/color-string/index.js","/../../node_modules/color-name/index.js","/../../node_modules/simple-swizzle/index.js","/../../node_modules/simple-swizzle/node_modules/is-arrayish/index.js","/../../node_modules/color-convert/index.js","/../../node_modules/color-convert/conversions.js","/../../node_modules/color-convert/node_modules/color-name/index.js","/../../node_modules/color-convert/route.js","/../../node_modules/react-native-paper/lib/module/styles/themes/index.js","/../../node_modules/react-native-paper/lib/module/styles/themes/v3/LightTheme.js","/../../node_modules/react-native-paper/lib/module/styles/themes/v3/tokens.js","/../../node_modules/react-native-paper/lib/module/styles/fonts.js","/../../node_modules/react-native-paper/lib/module/styles/themes/v3/DarkTheme.js","/../../node_modules/react-native-paper/lib/module/styles/themes/v2/LightTheme.js","/../../node_modules/react-native-paper/lib/module/styles/themes/v2/DarkTheme.js","/../../node_modules/react-native-paper/lib/module/components/Portal/PortalHost.js","/../../node_modules/react-native-paper/lib/module/components/Portal/PortalManager.js","/../../node_modules/react-native-paper/lib/module/utils/addEventListener.js","/../../node_modules/@react-navigation/native/lib/module/index.js","/../../node_modules/@react-navigation/native/lib/module/Link.js","/../../node_modules/@react-navigation/native/lib/module/useLinkProps.js","/../../node_modules/@react-navigation/core/lib/module/index.js","/../../node_modules/@react-navigation/core/lib/module/BaseNavigationContainer.js","/../../node_modules/@react-navigation/routers/lib/module/index.js","/../../node_modules/@react-navigation/routers/lib/module/CommonActions.js","/../../node_modules/@react-navigation/routers/lib/module/BaseRouter.js","/../../node_modules/nanoid/non-secure/index.js","/../../node_modules/@react-navigation/routers/lib/module/DrawerRouter.js","/../../node_modules/@react-navigation/routers/lib/module/TabRouter.js","/../../node_modules/@react-navigation/routers/lib/module/StackRouter.js","/../../node_modules/@react-navigation/routers/lib/module/types.js","/../../node_modules/@react-navigation/core/lib/module/checkDuplicateRouteNames.js","/../../node_modules/@react-navigation/core/lib/module/checkSerializable.js","/../../node_modules/@react-navigation/core/lib/module/createNavigationContainerRef.js","/../../node_modules/@react-navigation/core/lib/module/EnsureSingleNavigator.js","/../../node_modules/@react-navigation/core/lib/module/findFocusedRoute.js","/../../node_modules/@react-navigation/core/lib/module/NavigationBuilderContext.js","/../../node_modules/@react-navigation/core/lib/module/NavigationContainerRefContext.js","/../../node_modules/@react-navigation/core/lib/module/NavigationContext.js","/../../node_modules/@react-navigation/core/lib/module/NavigationRouteContext.js","/../../node_modules/@react-navigation/core/lib/module/NavigationStateContext.js","/../../node_modules/@react-navigation/core/lib/module/UnhandledActionContext.js","/../../node_modules/@react-navigation/core/lib/module/useChildListeners.js","/../../node_modules/@react-navigation/core/lib/module/useEventEmitter.js","/../../node_modules/@react-navigation/core/lib/module/useKeyedChildListeners.js","/../../node_modules/@react-navigation/core/lib/module/useOptionsGetters.js","/../../node_modules/@react-navigation/core/lib/module/useScheduleUpdate.js","/../../node_modules/@react-navigation/core/lib/module/useSyncState.js","/../../node_modules/@react-navigation/core/lib/module/createNavigatorFactory.js","/../../node_modules/@react-navigation/core/lib/module/Group.js","/../../node_modules/@react-navigation/core/lib/module/Screen.js","/../../node_modules/@react-navigation/core/lib/module/CurrentRenderContext.js","/../../node_modules/@react-navigation/core/lib/module/getActionFromState.js","/../../node_modules/@react-navigation/core/lib/module/getFocusedRouteNameFromRoute.js","/../../node_modules/@react-navigation/core/lib/module/useRouteCache.js","/../../node_modules/@react-navigation/core/lib/module/getPathFromState.js","/../../node_modules/query-string/index.js","/../../node_modules/strict-uri-encode/index.js","/../../node_modules/decode-uri-component/index.js","/../../node_modules/split-on-first/index.js","/../../node_modules/filter-obj/index.js","/../../node_modules/@react-navigation/core/lib/module/fromEntries.js","/../../node_modules/@react-navigation/core/lib/module/validatePathConfig.js","/../../node_modules/@react-navigation/core/lib/module/getStateFromPath.js","/../../node_modules/escape-string-regexp/index.js","/../../node_modules/@react-navigation/core/lib/module/NavigationHelpersContext.js","/../../node_modules/@react-navigation/core/lib/module/PreventRemoveContext.js","/../../node_modules/@react-navigation/core/lib/module/PreventRemoveProvider.js","/../../node_modules/use-latest-callback/lib/index.js","/../../node_modules/@react-navigation/core/lib/module/types.js","/../../node_modules/@react-navigation/core/lib/module/useFocusEffect.js","/../../node_modules/@react-navigation/core/lib/module/useNavigation.js","/../../node_modules/@react-navigation/core/lib/module/useIsFocused.js","/../../node_modules/@react-navigation/core/lib/module/useNavigationBuilder.js","/../../node_modules/@react-navigation/core/lib/module/isArrayEqual.js","/../../node_modules/@react-navigation/core/lib/module/isRecordEqual.js","/../../node_modules/@react-navigation/core/lib/module/useComponent.js","/../../node_modules/@react-navigation/core/lib/module/useCurrentRender.js","/../../node_modules/@react-navigation/core/lib/module/useDescriptors.js","/../../node_modules/@react-navigation/core/lib/module/SceneView.js","/../../node_modules/@react-navigation/core/lib/module/StaticContainer.js","/../../node_modules/@react-navigation/core/lib/module/useNavigationCache.js","/../../node_modules/@react-navigation/core/lib/module/useFocusedListenersChildrenAdapter.js","/../../node_modules/@react-navigation/core/lib/module/useFocusEvents.js","/../../node_modules/@react-navigation/core/lib/module/useNavigationHelpers.js","/../../node_modules/@react-navigation/core/lib/module/useOnAction.js","/../../node_modules/@react-navigation/core/lib/module/useOnPreventRemove.js","/../../node_modules/@react-navigation/core/lib/module/useOnGetState.js","/../../node_modules/@react-navigation/core/lib/module/useOnRouteFocus.js","/../../node_modules/@react-navigation/core/lib/module/useRegisterNavigator.js","/../../node_modules/@react-navigation/core/lib/module/useNavigationContainerRef.js","/../../node_modules/@react-navigation/core/lib/module/useNavigationState.js","/../../node_modules/@react-navigation/core/lib/module/usePreventRemove.js","/../../node_modules/@react-navigation/core/lib/module/usePreventRemoveContext.js","/../../node_modules/@react-navigation/core/lib/module/useRoute.js","/../../node_modules/@react-navigation/native/lib/module/LinkingContext.js","/../../node_modules/@react-navigation/native/lib/module/useLinkTo.js","/../../node_modules/@react-navigation/native/lib/module/NavigationContainer.js","/../../node_modules/@react-navigation/native/lib/module/theming/DefaultTheme.js","/../../node_modules/@react-navigation/native/lib/module/theming/ThemeProvider.js","/../../node_modules/@react-navigation/native/lib/module/theming/ThemeContext.js","/../../node_modules/@react-navigation/native/lib/module/useBackButton.js","/../../node_modules/@react-navigation/native/lib/module/useDocumentTitle.js","/../../node_modules/@react-navigation/native/lib/module/useLinking.js","/../../node_modules/fast-deep-equal/index.js","/../../node_modules/@react-navigation/native/lib/module/createMemoryHistory.js","/../../node_modules/@react-navigation/native/lib/module/ServerContext.js","/../../node_modules/@react-navigation/native/lib/module/useThenable.js","/../../node_modules/@react-navigation/native/lib/module/ServerContainer.js","/../../node_modules/@react-navigation/native/lib/module/theming/DarkTheme.js","/../../node_modules/@react-navigation/native/lib/module/theming/useTheme.js","/../../node_modules/@react-navigation/native/lib/module/types.js","/../../node_modules/@react-navigation/native/lib/module/useLinkBuilder.js","/../../node_modules/@react-navigation/native/lib/module/useScrollToTop.js","/src/common/theme/theme.js","/../../node_modules/react-native-paper/lib/module/index.js","/../../node_modules/react-native-paper/lib/module/styles/shadow.js","/../../node_modules/react-native-paper/lib/module/styles/overlay.js","/../../node_modules/react-native-paper/lib/module/components/Avatar/Avatar.js","/../../node_modules/react-native-paper/lib/module/components/Avatar/AvatarIcon.js","/../../node_modules/react-native-paper/lib/module/utils/getContrastingColor.js","/../../node_modules/react-native-paper/lib/module/components/Icon.js","/../../node_modules/react-native-paper/lib/module/components/Avatar/AvatarImage.js","/../../node_modules/react-native-paper/lib/module/components/Avatar/AvatarText.js","/../../node_modules/react-native-web/dist/exports/useWindowDimensions/index.js","/../../node_modules/react-native-paper/lib/module/components/Typography/Text.js","/../../node_modules/react-native-paper/lib/module/components/Typography/AnimatedText.js","/../../node_modules/react-native-paper/lib/module/components/Typography/v2/StyledText.js","/../../node_modules/react-native-paper/lib/module/components/Typography/v2/Text.js","/../../node_modules/react-native-paper/lib/module/utils/forwardRef.js","/../../node_modules/react-native-paper/lib/module/components/Drawer/Drawer.js","/../../node_modules/react-native-paper/lib/module/components/Drawer/DrawerItem.js","/../../node_modules/react-native-paper/lib/module/components/TouchableRipple/TouchableRipple.js","/../../node_modules/react-native-paper/lib/module/components/TouchableRipple/Pressable.js","/../../node_modules/react-native-web/dist/exports/Pressable/index.js","/../../node_modules/react-native-web/dist/modules/useHover/index.js","/../../node_modules/react-native-web/dist/modules/modality/index.js","/../../node_modules/react-native-web/dist/modules/addEventListener/index.js","/../../node_modules/react-native-web/dist/modules/useEvent/index.js","/../../node_modules/react-native-paper/lib/module/components/TouchableRipple/utils.js","/../../node_modules/react-native-paper/lib/module/utils/hasTouchHandler.js","/../../node_modules/react-native-paper/lib/module/components/Drawer/DrawerCollapsedItem.js","/../../node_modules/react-native-paper/lib/module/components/Badge.js","/../../node_modules/react-native-paper/lib/module/components/Drawer/DrawerSection.js","/../../node_modules/react-native-paper/lib/module/components/Divider.js","/../../node_modules/react-native-paper/lib/module/components/List/List.js","/../../node_modules/react-native-paper/lib/module/components/List/ListAccordion.js","/../../node_modules/react-native-paper/lib/module/components/List/ListAccordionGroup.js","/../../node_modules/react-native-paper/lib/module/components/List/utils.js","/../../node_modules/react-native-paper/lib/module/components/List/ListIcon.js","/../../node_modules/react-native-paper/lib/module/components/List/ListItem.js","/../../node_modules/react-native-paper/lib/module/components/List/ListSection.js","/../../node_modules/react-native-paper/lib/module/components/List/ListSubheader.js","/../../node_modules/react-native-paper/lib/module/components/List/ListImage.js","/../../node_modules/react-native-paper/lib/module/components/FAB/AnimatedFAB.js","/../../node_modules/react-native-paper/lib/module/components/FAB/utils.js","/../../node_modules/react-native-paper/lib/module/components/Surface.js","/../../node_modules/react-native-paper/lib/module/utils/splitStyles.js","/../../node_modules/react-native-paper/lib/module/components/ActivityIndicator.js","/../../node_modules/react-native-paper/lib/module/components/Banner.js","/../../node_modules/react-native-paper/lib/module/components/Button/Button.js","/../../node_modules/react-native-paper/lib/module/components/Button/utils.js","/../../node_modules/react-native-paper/lib/module/components/BottomNavigation/BottomNavigation.js","/../../node_modules/react-native-paper/lib/module/components/BottomNavigation/BottomNavigationBar.js","/../../node_modules/react-native-paper/lib/module/components/BottomNavigation/utils.js","/../../node_modules/react-native-paper/lib/module/utils/useAnimatedValue.js","/../../node_modules/react-native-paper/lib/module/utils/useLazyRef.js","/../../node_modules/react-native-paper/lib/module/utils/useAnimatedValueArray.js","/../../node_modules/react-native-paper/lib/module/utils/useIsKeyboardShown.js","/../../node_modules/react-native-paper/lib/module/utils/useLayout.js","/../../node_modules/react-native-paper/lib/module/components/BottomNavigation/BottomNavigationRouteScreen.js","/../../node_modules/react-native-paper/lib/module/components/Card/Card.js","/../../node_modules/react-native-paper/lib/module/components/Card/CardActions.js","/../../node_modules/react-native-paper/lib/module/components/Card/CardContent.js","/../../node_modules/react-native-paper/lib/module/components/Card/CardCover.js","/../../node_modules/react-native-paper/lib/module/components/Card/utils.js","/../../node_modules/react-native-paper/lib/module/components/Card/CardTitle.js","/../../node_modules/react-native-paper/lib/module/components/Typography/v2/Caption.js","/../../node_modules/react-native-paper/lib/module/components/Typography/v2/Title.js","/../../node_modules/react-native-paper/lib/module/components/Checkbox/index.js","/../../node_modules/react-native-paper/lib/module/components/Checkbox/Checkbox.js","/../../node_modules/react-native-paper/lib/module/components/Checkbox/CheckboxAndroid.js","/../../node_modules/react-native-paper/lib/module/components/Checkbox/utils.js","/../../node_modules/react-native-paper/lib/module/components/Checkbox/CheckboxIOS.js","/../../node_modules/react-native-paper/lib/module/components/Checkbox/CheckboxItem.js","/../../node_modules/react-native-paper/lib/module/components/Chip/Chip.js","/../../node_modules/react-native-paper/lib/module/components/Chip/helpers.js","/../../node_modules/react-native-paper/lib/module/components/DataTable/DataTable.js","/../../node_modules/react-native-paper/lib/module/components/DataTable/DataTableCell.js","/../../node_modules/react-native-paper/lib/module/components/DataTable/DataTableHeader.js","/../../node_modules/react-native-paper/lib/module/components/DataTable/DataTablePagination.js","/../../node_modules/react-native-paper/lib/module/components/IconButton/IconButton.js","/../../node_modules/react-native-paper/lib/module/components/IconButton/utils.js","/../../node_modules/react-native-paper/lib/module/components/CrossFadeIcon.js","/../../node_modules/react-native-paper/lib/module/components/Menu/Menu.js","/../../node_modules/react-native-paper/lib/module/components/Menu/MenuItem.js","/../../node_modules/react-native-paper/lib/module/components/Menu/utils.js","/../../node_modules/react-native-paper/lib/module/constants.js","/../../node_modules/react-native-paper/lib/module/types.js","/../../node_modules/react-native-paper/lib/module/utils/BackHandler/BackHandler.js","/../../node_modules/react-native-paper/lib/module/components/Portal/Portal.js","/../../node_modules/react-native-paper/lib/module/components/Portal/PortalConsumer.js","/../../node_modules/react-native-paper/lib/module/components/DataTable/DataTableRow.js","/../../node_modules/react-native-paper/lib/module/components/DataTable/DataTableTitle.js","/../../node_modules/react-native-paper/lib/module/components/Dialog/Dialog.js","/../../node_modules/react-native-paper/lib/module/components/Dialog/DialogActions.js","/../../node_modules/react-native-paper/lib/module/components/Dialog/DialogContent.js","/../../node_modules/react-native-paper/lib/module/components/Dialog/DialogIcon.js","/../../node_modules/react-native-paper/lib/module/components/Dialog/DialogScrollArea.js","/../../node_modules/react-native-paper/lib/module/components/Dialog/DialogTitle.js","/../../node_modules/react-native-paper/lib/module/components/Modal.js","/../../node_modules/react-native-paper/lib/module/components/FAB/index.js","/../../node_modules/react-native-paper/lib/module/components/FAB/FAB.js","/../../node_modules/react-native-paper/lib/module/components/FAB/FABGroup.js","/../../node_modules/react-native-paper/lib/module/components/HelperText/HelperText.js","/../../node_modules/react-native-paper/lib/module/components/HelperText/utils.js","/../../node_modules/react-native-paper/lib/module/components/ProgressBar.js","/../../node_modules/react-native-paper/lib/module/components/RadioButton/index.js","/../../node_modules/react-native-paper/lib/module/components/RadioButton/RadioButton.js","/../../node_modules/react-native-paper/lib/module/components/RadioButton/RadioButtonAndroid.js","/../../node_modules/react-native-paper/lib/module/components/RadioButton/RadioButtonGroup.js","/../../node_modules/react-native-paper/lib/module/components/RadioButton/utils.js","/../../node_modules/react-native-paper/lib/module/components/RadioButton/RadioButtonIOS.js","/../../node_modules/react-native-paper/lib/module/components/RadioButton/RadioButtonItem.js","/../../node_modules/react-native-paper/lib/module/components/Searchbar.js","/../../node_modules/react-native-paper/lib/module/components/Snackbar.js","/../../node_modules/react-native-paper/lib/module/components/Switch/Switch.js","/../../node_modules/react-native-paper/lib/module/components/Switch/utils.js","/../../node_modules/react-native-paper/lib/module/components/Appbar/index.js","/../../node_modules/react-native-paper/lib/module/components/Appbar/Appbar.js","/../../node_modules/react-native-paper/lib/module/components/Appbar/AppbarContent.js","/../../node_modules/react-native-paper/lib/module/components/Appbar/utils.js","/../../node_modules/react-native-paper/lib/module/components/Appbar/AppbarAction.js","/../../node_modules/react-native-paper/lib/module/components/Appbar/AppbarBackAction.js","/../../node_modules/react-native-paper/lib/module/components/Appbar/AppbarBackIcon.js","/../../node_modules/react-native-paper/lib/module/components/Appbar/AppbarHeader.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/TextInput.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Adornment/TextInputAffix.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Adornment/enums.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Adornment/utils.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/helpers.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/constants.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Adornment/TextInputIcon.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/TextInputFlat.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Addons/Underline.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Adornment/TextInputAdornment.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Label/InputLabel.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/TextInputOutlined.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Addons/Outline.js","/../../node_modules/react-native-paper/lib/module/components/TextInput/Label/LabelBackground.js","/../../node_modules/react-native-paper/lib/module/utils/roundLayoutSize.js","/../../node_modules/react-native-paper/lib/module/components/ToggleButton/index.js","/../../node_modules/react-native-paper/lib/module/components/ToggleButton/ToggleButton.js","/../../node_modules/react-native-paper/lib/module/components/ToggleButton/ToggleButtonGroup.js","/../../node_modules/react-native-paper/lib/module/components/ToggleButton/utils.js","/../../node_modules/react-native-paper/lib/module/components/ToggleButton/ToggleButtonRow.js","/../../node_modules/react-native-paper/lib/module/components/SegmentedButtons/SegmentedButtons.js","/../../node_modules/react-native-paper/lib/module/components/SegmentedButtons/SegmentedButtonItem.js","/../../node_modules/react-native-paper/lib/module/components/SegmentedButtons/utils.js","/../../node_modules/react-native-paper/lib/module/components/Tooltip/Tooltip.js","/../../node_modules/react-native-paper/lib/module/components/Tooltip/utils.js","/../../node_modules/react-native-paper/lib/module/components/Typography/v2/index.js","/../../node_modules/react-native-paper/lib/module/components/Typography/v2/Headline.js","/../../node_modules/react-native-paper/lib/module/components/Typography/v2/Paragraph.js","/../../node_modules/react-native-paper/lib/module/components/Typography/v2/Subheading.js","/../../node_modules/axios/index.js","/../../node_modules/axios/lib/axios.js","/../../node_modules/axios/lib/utils.js","/../../node_modules/axios/lib/helpers/bind.js","/../../node_modules/axios/lib/core/Axios.js","/../../node_modules/axios/lib/helpers/buildURL.js","/../../node_modules/axios/lib/core/InterceptorManager.js","/../../node_modules/axios/lib/core/dispatchRequest.js","/../../node_modules/axios/lib/core/transformData.js","/../../node_modules/axios/lib/defaults.js","/../../node_modules/axios/lib/helpers/normalizeHeaderName.js","/../../node_modules/axios/lib/core/enhanceError.js","/../../node_modules/axios/lib/adapters/xhr.js","/../../node_modules/axios/lib/core/settle.js","/../../node_modules/axios/lib/core/createError.js","/../../node_modules/axios/lib/helpers/cookies.js","/../../node_modules/axios/lib/core/buildFullPath.js","/../../node_modules/axios/lib/helpers/isAbsoluteURL.js","/../../node_modules/axios/lib/helpers/combineURLs.js","/../../node_modules/axios/lib/helpers/parseHeaders.js","/../../node_modules/axios/lib/helpers/isURLSameOrigin.js","/../../node_modules/axios/lib/cancel/isCancel.js","/../../node_modules/axios/lib/core/mergeConfig.js","/../../node_modules/axios/lib/helpers/validator.js","/../../node_modules/axios/package.json","/../../node_modules/axios/lib/cancel/Cancel.js","/../../node_modules/axios/lib/cancel/CancelToken.js","/../../node_modules/axios/lib/helpers/spread.js","/../../node_modules/axios/lib/helpers/isAxiosError.js","/../../node_modules/react-redux/es/index.js","/../../node_modules/react-redux/es/exports.js","/../../node_modules/react-redux/es/components/Provider.js","/../../node_modules/react-redux/es/components/Context.js","/../../node_modules/react-redux/es/utils/Subscription.js","/../../node_modules/react-redux/es/utils/batch.js","/../../node_modules/react-redux/es/utils/useIsomorphicLayoutEffect.js","/../../node_modules/react-redux/es/components/connectAdvanced.js","/../../node_modules/@babel/runtime/helpers/esm/extends.js","/../../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","/../../node_modules/react-redux/node_modules/react-is/index.js","/../../node_modules/react-redux/node_modules/react-is/cjs/react-is.production.min.js","/../../node_modules/react-redux/es/connect/connect.js","/../../node_modules/react-redux/es/utils/shallowEqual.js","/../../node_modules/react-redux/es/connect/mapDispatchToProps.js","/../../node_modules/react-redux/es/utils/bindActionCreators.js","/../../node_modules/react-redux/es/connect/wrapMapToProps.js","/../../node_modules/react-redux/es/utils/verifyPlainObject.js","/../../node_modules/react-redux/es/utils/isPlainObject.js","/../../node_modules/react-redux/es/utils/warning.js","/../../node_modules/react-redux/es/connect/mapStateToProps.js","/../../node_modules/react-redux/es/connect/mergeProps.js","/../../node_modules/react-redux/es/connect/selectorFactory.js","/../../node_modules/react-redux/es/connect/verifySubselectors.js","/../../node_modules/react-redux/es/hooks/useDispatch.js","/../../node_modules/react-redux/es/hooks/useStore.js","/../../node_modules/react-redux/es/hooks/useReduxContext.js","/../../node_modules/react-redux/es/hooks/useSelector.js","/../../node_modules/react-redux/es/utils/reactBatchedUpdates.js","/src/data/redux/storeConfig/store.js","/../../node_modules/redux-thunk/es/index.js","/../../node_modules/redux-debounced/lib/index.js","/src/data/redux/reducers/rootReducer.js","/../../node_modules/redux/es/redux.js","/../../node_modules/symbol-observable/es/index.js","/../../node_modules/symbol-observable/es/ponyfill.js","/src/data/redux/reducers/alert/index.js","/src/data/constants/alertConstants.js","/src/data/redux/reducers/data/index.js","/src/data/redux/reducers/data/chapters.js","/src/data/constants/apiConstants/index.js","/../../node_modules/expo-constants/build/Constants.js","/../../node_modules/expo-constants/build/Constants.types.js","/../../node_modules/expo-constants/build/ExponentConstants.web.js","/src/common/utils/mobileUtils.js","/../../node_modules/react-native-device-info/lib/module/index.js","/../../node_modules/react-native-device-info/lib/module/internal/asyncHookWrappers.js","/../../node_modules/react-native-device-info/lib/module/internal/devicesWithDynamicIsland.js","/../../node_modules/react-native-device-info/lib/module/internal/devicesWithNotch.js","/../../node_modules/react-native-device-info/lib/module/internal/nativeInterface.js","/../../node_modules/react-native-device-info/lib/module/web/index.js","/../../node_modules/react-native-device-info/lib/module/internal/supported-platform-info.js","/src/data/services/chaptersService.js","/src/data/redux/reducers/data/interviewReports.js","/src/data/services/interviewReportService.js","/src/data/services/gradesService.js","/src/data/redux/reducers/data/liveReports.js","/src/data/services/liveReportService.js","/src/data/redux/reducers/data/liveSessions.js","/src/data/services/referralService.js","/src/data/services/roomService.js","/src/data/services/liveService.js","/src/data/services/attendanceFlagsService.js","/src/data/redux/reducers/data/materials.js","/src/data/services/activitiesService.js","/src/data/redux/reducers/data/referrals.js","/src/data/redux/reducers/data/schools.js","/src/data/services/schoolsService.js","/src/data/redux/reducers/data/studyPrograms.js","/src/data/services/studyProgramsService.js","/src/data/redux/reducers/data/backOffice.js","/src/data/services/backOfficeService.js","/src/data/services/trialSessionsService.js","/src/data/redux/reducers/data/currentUser.js","/src/data/services/authService.js","/src/data/services/tutorsService.js","/src/data/services/studentsService.js","/src/data/services/interviewsService.js","/src/data/utility/Utils.js","/src/data/constants/formConstants.js","/../../node_modules/moment/moment.js","/../../node_modules/moment/locale/fr.js","/src/data/constants/activitiesConstants.js","/src/data/constants/authConstants.js","/src/data/services/challengesService.js","/src/data/services/achievementsService.js","/src/data/services/schoolSubjectsService.js","/src/data/services/shopService.js","/src/data/services/subscriptionService.js","/src/data/constants/messengerConstants.js","/src/data/services/messengerService.js","/src/data/services/skillSetsService.js","/src/data/constants/liveModeConstants.js","/src/data/services/substitutionProposalsService.js","/src/data/services/liveServiceV2.js","/src/data/redux/reducers/data/formData.js","/src/data/constants/formDataConstants.js","/src/data/redux/reducers/data/reviewer.js","/src/data/services/scoringService.js","/src/data/redux/reducers/data/schoolCardReport.js","/src/data/services/schoolCardReportService.js","/src/data/redux/reducers/data/session.js","/src/data/redux/reducers/data/staticData.js","/src/data/services/staticDataService.js","/src/data/redux/reducers/data/suggestions.js","/src/data/constants/suggestionsConstants.js","/src/data/redux/reducers/data/tutors.js","/src/data/redux/reducers/data/users.js","/src/data/redux/reducers/data/videoCall.js","/src/data/constants/videoCallConstants.js","/src/data/redux/reducers/offlineMode/index.js","/src/data/constants/offlineModeConstants.js","/src/data/redux/reducers/liveMode/index.js","/src/data/redux/reducers/camera/index.js","/src/data/constants/cameraConstants.js","/src/data/redux/reducers/api/index.js","/src/data/services/index.js","/src/data/services/quizzservice.js","/src/data/services/vaporService.js","/src/data/redux/reducers/notifications/index.js","/src/data/constants/notificationConstants.js","/src/data/redux/reducers/activity/index.js","/src/data/redux/reducers/navigation/index.js","/src/data/constants/navigationConstants.js","/src/data/redux/reducers/liveKitRoom/index.js","/../../node_modules/redux-persist/es/index.js","/../../node_modules/redux-persist/es/persistReducer.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/persistCombineReducers.js","/../../node_modules/redux-persist/es/stateReconciler/autoMergeLevel2.js","/../../node_modules/redux-persist/es/persistStore.js","/../../node_modules/redux-persist/es/createMigrate.js","/../../node_modules/redux-persist/es/createTransform.js","/../../node_modules/@react-native-async-storage/async-storage/lib/module/index.js","/../../node_modules/@react-native-async-storage/async-storage/lib/module/AsyncStorage.js","/../../node_modules/merge-options/index.js","/../../node_modules/is-plain-obj/index.js","/../../node_modules/@react-native-async-storage/async-storage/lib/module/hooks.js","/../../node_modules/redux-persist/lib/stateReconciler/autoMergeLevel2.js","/../../node_modules/redux-persist/lib/integration/react.js","/src/common/navigation/RootNavigator.js","/src/common/utils/DeepLinking.js","/src/data/redux/actions/api/index.js","/../../node_modules/@react-native-community/netinfo/lib/module/index.js","/../../node_modules/@react-native-community/netinfo/lib/module/internal/defaultConfiguration.web.js","/../../node_modules/@react-native-community/netinfo/lib/module/internal/nativeInterface.web.js","/../../node_modules/@react-native-community/netinfo/lib/module/internal/nativeModule.web.js","/../../node_modules/@react-native-community/netinfo/lib/module/internal/privateTypes.js","/../../node_modules/@react-native-community/netinfo/lib/module/internal/types.js","/../../node_modules/@react-native-community/netinfo/lib/module/internal/state.js","/../../node_modules/@react-native-community/netinfo/lib/module/internal/internetReachability.js","/src/common/components/alert/dialog/Dialog.js","/src/common/components/alert/dialog/useDialog.js","/src/common/components/alert/snackbar/useSnackBar.js","/src/student/champions/ChampionImageM.js","/src/common/components/icons/IconsM.js","/assets/icons/generic/lightning.png","/assets/icons/generic/gift.png","/assets/icons/generic/feather.png","/assets/icons/generic/petal_new.png","/assets/icons/generic/checked.png","/assets/icons/generic/remove.png","/assets/icons/generic/broken-image.png","/assets/icons/generic/remove-grey.png","/assets/icons/generic/planning-plus.png","/assets/icons/generic/premium-plus.png","/assets/icons/generic/premium-coach.png","/../../node_modules/@expo/vector-icons/FontAwesome5.js","/../../node_modules/@expo/vector-icons/build/FontAwesome5.js","/../../node_modules/@expo/vector-icons/build/createIconSetFromFontAwesome5.js","/../../node_modules/@expo/vector-icons/build/createMultiStyleIconSet.js","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/glyphmaps/FontAwesome5Free.json","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/glyphmaps/FontAwesome5Free_meta.json","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/Fonts/FontAwesome5_Regular.ttf","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/Fonts/FontAwesome5_Solid.ttf","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/Fonts/FontAwesome5_Brands.ttf","/assets/champions/zoe_main.png","/assets/champions/zoe_happy.png","/assets/champions/zoe_unhappy.png","/assets/champions/abou_main.png","/assets/champions/abou_happy.png","/assets/champions/abou_unhappy.png","/assets/champions/sam_main.png","/assets/champions/sam_happy.png","/assets/champions/sam_unhappy.png","/assets/champions/tina_main.png","/assets/champions/tina_happy.png","/assets/champions/tina_unhappy.png","/../../node_modules/@amplitude/analytics-react-native/lib/module/index.js","/../../node_modules/@amplitude/analytics-react-native/lib/module/react-native-client.js","/../../node_modules/react-native-web/dist/exports/AppState/index.js","/../../node_modules/@amplitude/analytics-core/lib/esm/index.js","/../../node_modules/@amplitude/analytics-core/lib/esm/core-client.js","/../../node_modules/tslib/tslib.es6.js","/../../node_modules/@amplitude/analytics-core/lib/esm/utils/event-builder.js","/../../node_modules/@amplitude/analytics-types/lib/esm/index.js","/../../node_modules/@amplitude/analytics-types/lib/esm/event.js","/../../node_modules/@amplitude/analytics-types/lib/esm/logger.js","/../../node_modules/@amplitude/analytics-types/lib/esm/plugin.js","/../../node_modules/@amplitude/analytics-types/lib/esm/server-zone.js","/../../node_modules/@amplitude/analytics-types/lib/esm/status.js","/../../node_modules/@amplitude/analytics-types/lib/esm/transport.js","/../../node_modules/@amplitude/analytics-core/lib/esm/identify.js","/../../node_modules/@amplitude/analytics-core/lib/esm/constants.js","/../../node_modules/@amplitude/analytics-core/lib/esm/utils/valid-properties.js","/../../node_modules/@amplitude/analytics-core/lib/esm/timeline.js","/../../node_modules/@amplitude/analytics-core/lib/esm/utils/result-builder.js","/../../node_modules/@amplitude/analytics-core/lib/esm/messages.js","/../../node_modules/@amplitude/analytics-core/lib/esm/utils/return-wrapper.js","/../../node_modules/@amplitude/analytics-core/lib/esm/revenue.js","/../../node_modules/@amplitude/analytics-core/lib/esm/plugins/destination.js","/../../node_modules/@amplitude/analytics-core/lib/esm/utils/chunk.js","/../../node_modules/@amplitude/analytics-core/lib/esm/config.js","/../../node_modules/@amplitude/analytics-core/lib/esm/logger.js","/../../node_modules/@amplitude/analytics-core/lib/esm/utils/debug.js","/../../node_modules/@amplitude/analytics-core/lib/esm/utils/uuid.js","/../../node_modules/@amplitude/analytics-core/lib/esm/storage/memory.js","/../../node_modules/@amplitude/analytics-core/lib/esm/transports/base.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/index.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/analytics-connector.js","/../../node_modules/@amplitude/analytics-connector/dist/analytics-connector.esm.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/attribution/campaign-parser.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/query-params.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/global-scope.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/attribution/constants.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/attribution/campaign-tracker.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/cookie-name.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/default-tracking.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/language.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/plugins/identity.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/storage/cookie.js","/../../node_modules/@amplitude/analytics-client-common/lib/esm/transports/fetch.js","/../../node_modules/@amplitude/analytics-react-native/lib/module/plugins/context.js","/../../node_modules/@amplitude/ua-parser-js/src/ua-parser.js","/../../node_modules/@amplitude/analytics-react-native/lib/module/version.js","/../../node_modules/@amplitude/analytics-react-native/lib/module/config.js","/../../node_modules/@amplitude/analytics-react-native/lib/module/storage/local-storage.js","/../../node_modules/@amplitude/analytics-react-native/node_modules/@react-native-async-storage/async-storage/lib/module/index.js","/../../node_modules/@amplitude/analytics-react-native/node_modules/@react-native-async-storage/async-storage/lib/module/AsyncStorage.js","/../../node_modules/@amplitude/analytics-react-native/node_modules/@react-native-async-storage/async-storage/lib/module/hooks.js","/../../node_modules/@amplitude/analytics-react-native/lib/module/migration/remnant-data-migration.js","/../../node_modules/@amplitude/analytics-react-native/lib/module/cookie-migration/index.js","/../../node_modules/@amplitude/analytics-react-native/lib/module/utils/platform.js","/../../node_modules/slugify/slugify.js","/src/common/utils/initBugsnag.web.js","/../../node_modules/@bugsnag/js/browser/notifier.js","/../../node_modules/@bugsnag/browser/dist/bugsnag.js","/../../node_modules/@bugsnag/plugin-react/dist/bugsnag-react.js","/../../node_modules/expo-linking/build/Linking.js","/../../node_modules/expo-linking/build/ExpoLinking.web.js","/../../node_modules/expo-linking/build/createURL.web.js","/../../node_modules/expo-linking/build/validateURL.js","/../../node_modules/expo-linking/build/Linking.types.js","/../../node_modules/expo-linking/build/Schemes.web.js","/src/common/navigation/navigationScreens.js","/src/common/account/ChangeEmailStepper.js","/src/common/components/stepper/FormStepper.js","/src/common/components/stepper/ProgressStepper.js","/src/common/components/button/FilledButtonM.js","/src/common/utils/withPreventDoubleClick.js","/src/common/components/text/TextM.js","/../../node_modules/react-native-circular-progress-indicator/src/circularProgress/index.tsx","/../../node_modules/react-native-svg/lib/module/index.js","/../../node_modules/react-native-svg/lib/module/ReactNativeSVG.web.js","/../../node_modules/react-native-svg/lib/module/lib/SvgTouchableMixin.js","/../../node_modules/react-native-web/dist/exports/Touchable/index.js","/../../node_modules/react-native-web/dist/exports/Touchable/BoundingDimensions.js","/../../node_modules/react-native-web/dist/vendor/react-native/PooledClass/index.js","/../../node_modules/react-native-web/dist/exports/Touchable/Position.js","/../../node_modules/react-native-svg/lib/module/lib/resolve.js","/../../node_modules/react-native-svg/lib/module/lib/extract/extractTransform.js","/../../node_modules/react-native-svg/lib/module/lib/Matrix2D.js","/../../node_modules/react-native-svg/lib/module/lib/extract/transform.js","/src/student/champions/ChampionBubble.js","/src/common/components/speech-bubble/SpeechBubbleM.js","/src/common/components/speech-bubble/index.js","/../../node_modules/react-native-web/dist/exports/TouchableOpacity/index.js","/src/common/components/speech-bubble/TypeWriter.js","/src/common/components/speech-bubble/assets/ic_touch_app.png","/src/common/components/speech-bubble/assets/ic_replay.png","/src/common/components/stepper/ProgressStepperHeader.js","\u0000shim:react-native-web/dist/exports/BackHandler/index.js","/../../node_modules/react-hook-form/dist/index.esm.mjs","/src/common/components/stepper/FormStep.js","/../../node_modules/react-native-web/dist/exports/KeyboardAvoidingView/index.js","/src/common/components/list/ListGroupM.js","/src/common/components/list/ListItemM.js","/../../node_modules/expo-clipboard/build/Clipboard.js","/../../node_modules/expo-clipboard/build/ClipboardPasteButton.js","/../../node_modules/expo-clipboard/build/ExpoClipboardPasteButton.js","/../../node_modules/expo-clipboard/build/ExpoClipboard.web.js","/../../node_modules/expo-clipboard/build/web/ClipboardModule.js","/../../node_modules/expo-clipboard/build/web/Exceptions.js","/../../node_modules/expo-clipboard/build/web/Utils.js","/../../node_modules/expo-clipboard/build/Clipboard.types.js","/src/common/components/avatar/AvatarM.js","/src/data/constants/studentsConstants.js","/src/data/utility/ability.js","/src/data/utility/initialAbility.js","/assets/icons/bow-tie/bow-tie-0.png","/assets/icons/bow-tie/bow-tie-1.png","/assets/icons/bow-tie/bow-tie-2.png","/assets/icons/bow-tie/bow-tie-3.png","/assets/icons/bow-tie/bow-tie-4.png","/assets/icons/menus-new/prof-gris.png","/src/common/components/text/TitleM.js","/src/common/components/input/TextInputM.js","/src/common/components/text/ErrorTextM.js","/src/common/components/button/TextButtonM.js","/src/common/screens/PaginatedFlatList.js","/src/common/screens/PaginatedFlatListContent.js","/src/admin/DateTimePicker.js","/../../node_modules/react-native-paper-dates/lib/module/index.js","/../../node_modules/react-native-paper-dates/lib/module/Date/Calendar.js","/../../node_modules/react-native-paper-dates/lib/module/Date/Swiper.js","/../../node_modules/react-native-paper-dates/lib/module/Date/Month.js","/../../node_modules/react-native-paper-dates/lib/module/Date/Day.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DayRange.js","/../../node_modules/react-native-paper-dates/lib/module/Date/dateUtils.js","/../../node_modules/react-native-paper-dates/lib/module/shared/utils.js","/../../node_modules/color/index.js","/../../node_modules/color/node_modules/color-convert/index.js","/../../node_modules/color/node_modules/color-convert/conversions.js","/../../node_modules/color/node_modules/color-convert/route.js","/../../node_modules/react-native-paper-dates/lib/module/shared/styles.js","/../../node_modules/react-native-paper-dates/lib/module/Date/CalendarHeader.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DayNames.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DayName.js","/../../node_modules/react-native-paper-dates/lib/module/translations/utils.js","/../../node_modules/react-native-paper-dates/lib/module/Date/SwiperUtils.js","/../../node_modules/react-native-paper-dates/lib/module/Date/AutoSizer.js","/../../node_modules/react-native-paper-dates/lib/module/Date/YearPicker.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DatePickerModal.js","/../../node_modules/react-native-web/dist/exports/Modal/index.js","/../../node_modules/react-native-web/dist/exports/Modal/ModalPortal.js","/../../node_modules/react-native-web/dist/exports/Modal/ModalAnimation.js","/../../node_modules/react-native-web/dist/exports/Modal/ModalContent.js","/../../node_modules/react-native-web/dist/exports/Modal/ModalFocusTrap.js","/../../node_modules/react-native-web/dist/exports/TouchableWithoutFeedback/index.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DatePickerModalContent.js","/../../node_modules/react-native-paper-dates/lib/module/Date/AnimatedCrossView.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DatePickerModalHeader.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DatePickerModalContentHeader.js","/../../node_modules/react-native-paper-dates/lib/module/Date/CalendarEdit.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DatePickerInputWithoutModal.js","/../../node_modules/react-native-paper-dates/lib/module/TextInputMask.js","/../../node_modules/react-native-paper-dates/lib/module/Date/inputUtils.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DatePickerModalHeaderBackground.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DatePickerModalStatusBar.js","/../../node_modules/react-native-paper-dates/lib/module/Time/TimePickerModal.js","/../../node_modules/react-native-paper-dates/lib/module/Time/TimePicker.js","/../../node_modules/react-native-paper-dates/lib/module/Time/timeUtils.js","/../../node_modules/react-native-paper-dates/lib/module/Time/AnalogClock.js","/../../node_modules/react-native-web/dist/exports/PanResponder/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/PanResponder/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/TouchHistoryMath/index.js","/../../node_modules/react-native-paper-dates/lib/module/Time/AnalogClockHours.js","/../../node_modules/react-native-paper-dates/lib/module/Time/AnimatedClockSwitcher.js","/../../node_modules/react-native-paper-dates/lib/module/Time/AnalogClockMinutes.js","/../../node_modules/react-native-paper-dates/lib/module/contexts/DisplayModeContext.js","/../../node_modules/react-native-paper-dates/lib/module/Time/TimeInputs.js","/../../node_modules/react-native-paper-dates/lib/module/Time/TimeInput.js","/../../node_modules/react-native-paper-dates/lib/module/Time/AmPmSwitcher.js","/../../node_modules/react-native-paper-dates/lib/module/Date/DatePickerInput.js","/../../node_modules/react-native-paper-dates/lib/module/translations/ar.js","/../../node_modules/react-native-paper-dates/lib/module/translations/ca.js","/../../node_modules/react-native-paper-dates/lib/module/translations/de.js","/../../node_modules/react-native-paper-dates/lib/module/translations/en.js","/../../node_modules/react-native-paper-dates/lib/module/translations/enGB.js","/../../node_modules/react-native-paper-dates/lib/module/translations/es.js","/../../node_modules/react-native-paper-dates/lib/module/translations/fr.js","/../../node_modules/react-native-paper-dates/lib/module/translations/he.js","/../../node_modules/react-native-paper-dates/lib/module/translations/hi.js","/../../node_modules/react-native-paper-dates/lib/module/translations/it.js","/../../node_modules/react-native-paper-dates/lib/module/translations/ko.js","/../../node_modules/react-native-paper-dates/lib/module/translations/nl.js","/../../node_modules/react-native-paper-dates/lib/module/translations/pl.js","/../../node_modules/react-native-paper-dates/lib/module/translations/pt.js","/../../node_modules/react-native-paper-dates/lib/module/translations/tr.js","/../../node_modules/react-native-paper-dates/lib/module/translations/zh.js","/../../node_modules/react-native-paper-dates/lib/module/translations/zhTW.js","/../../node_modules/react-native-paper-dates/lib/module/translations/cs.js","/../../node_modules/react-native-paper-dates/lib/module/translations/el.js","/../../node_modules/react-native-paper-dates/lib/module/translations/ru.js","/../../node_modules/react-native-paper-dates/lib/module/translations/ro.js","/../../node_modules/react-native-paper-dates/lib/module/translations/id.js","/../../node_modules/react-native-paper-dates/lib/module/translations/ja.js","/../../node_modules/react-native-paper-dates/lib/module/translations/th.js","/../../node_modules/react-native-paper-dates/lib/module/translations/ukUA.js","/../../node_modules/react-native-paper-dates/lib/module/translations/noNO.js","/src/admin/live/rooms/SelectDayModal.js","/src/common/components/modal/ModalM.js","/src/common/camera/CameraImagesM.js","/../../node_modules/expo-image-picker/build/ImagePicker.js","/../../node_modules/expo-image-picker/build/ExponentImagePicker.web.js","/../../node_modules/expo-image-picker/build/ImagePicker.types.js","/../../node_modules/react-native-web/dist/exports/Vibration/index.js","/src/common/camera/PhotoElement.js","/src/common/components/button/IconButtonM.js","/../../node_modules/@babel/runtime/helpers/objectDestructuringEmpty.js","/src/common/hooks/useCamera.web.js","/src/data/redux/actions/activity/index.js","/src/data/redux/actions/camera/index.js","/src/common/components/image/ImageViewer.js","/src/common/components/image/PinchableBox.js","/src/common/components/zoom/index.ts","/src/common/components/zoom/zoom.tsx","/src/common/components/zoom/zoom-list-context.ts","/src/common/components/zoom/createZoomListComponent.tsx","/src/common/components/icons/IconTextM.js","/src/admin/ServerSearch.js","/src/common/hooks/useApiStatus.js","/src/data/redux/actions/formData/index.js","/src/common/components/alert/snackbar/SnackBar.js","/src/data/utility/validation.js","/../../node_modules/yup/es/index.js","/../../node_modules/yup/es/mixed.js","/../../node_modules/yup/es/schema.js","/../../node_modules/nanoclone/src/index.js","/../../node_modules/yup/es/locale.js","/../../node_modules/yup/es/util/printValue.js","/../../node_modules/yup/es/Condition.js","/../../node_modules/lodash/has.js","/../../node_modules/lodash/_baseHas.js","/../../node_modules/lodash/_hasPath.js","/../../node_modules/lodash/_castPath.js","/../../node_modules/lodash/_isKey.js","/../../node_modules/lodash/isSymbol.js","/../../node_modules/lodash/_stringToPath.js","/../../node_modules/lodash/_memoizeCapped.js","/../../node_modules/lodash/memoize.js","/../../node_modules/lodash/toString.js","/../../node_modules/lodash/_baseToString.js","/../../node_modules/lodash/_arrayMap.js","/../../node_modules/lodash/_toKey.js","/../../node_modules/yup/es/util/isSchema.js","/../../node_modules/yup/es/util/runTests.js","/../../node_modules/yup/es/ValidationError.js","/../../node_modules/yup/es/util/toArray.js","/../../node_modules/yup/es/util/createValidation.js","/../../node_modules/lodash/mapValues.js","/../../node_modules/lodash/_baseAssignValue.js","/../../node_modules/lodash/_defineProperty.js","/../../node_modules/lodash/_baseForOwn.js","/../../node_modules/lodash/_baseFor.js","/../../node_modules/lodash/_createBaseFor.js","/../../node_modules/lodash/_baseIteratee.js","/../../node_modules/lodash/_baseMatches.js","/../../node_modules/lodash/_baseIsMatch.js","/../../node_modules/lodash/_getMatchData.js","/../../node_modules/lodash/_isStrictComparable.js","/../../node_modules/lodash/_matchesStrictComparable.js","/../../node_modules/lodash/_baseMatchesProperty.js","/../../node_modules/lodash/get.js","/../../node_modules/lodash/_baseGet.js","/../../node_modules/lodash/hasIn.js","/../../node_modules/lodash/_baseHasIn.js","/../../node_modules/lodash/identity.js","/../../node_modules/lodash/property.js","/../../node_modules/lodash/_baseProperty.js","/../../node_modules/lodash/_basePropertyDeep.js","/../../node_modules/yup/es/Reference.js","/../../node_modules/property-expr/index.js","/../../node_modules/yup/es/util/reach.js","/../../node_modules/yup/es/util/ReferenceSet.js","/../../node_modules/yup/es/boolean.js","/../../node_modules/yup/es/util/isAbsent.js","/../../node_modules/yup/es/string.js","/../../node_modules/yup/es/number.js","/../../node_modules/yup/es/date.js","/../../node_modules/yup/es/util/isodate.js","/../../node_modules/yup/es/object.js","/../../node_modules/lodash/snakeCase.js","/../../node_modules/lodash/_createCompounder.js","/../../node_modules/lodash/_arrayReduce.js","/../../node_modules/lodash/deburr.js","/../../node_modules/lodash/_deburrLetter.js","/../../node_modules/lodash/_basePropertyOf.js","/../../node_modules/lodash/words.js","/../../node_modules/lodash/_asciiWords.js","/../../node_modules/lodash/_hasUnicodeWord.js","/../../node_modules/lodash/_unicodeWords.js","/../../node_modules/lodash/camelCase.js","/../../node_modules/lodash/capitalize.js","/../../node_modules/lodash/upperFirst.js","/../../node_modules/lodash/_createCaseFirst.js","/../../node_modules/lodash/_castSlice.js","/../../node_modules/lodash/_baseSlice.js","/../../node_modules/lodash/_hasUnicode.js","/../../node_modules/lodash/_stringToArray.js","/../../node_modules/lodash/_asciiToArray.js","/../../node_modules/lodash/_unicodeToArray.js","/../../node_modules/lodash/mapKeys.js","/../../node_modules/yup/es/util/sortFields.js","/../../node_modules/toposort/index.js","/../../node_modules/yup/es/util/sortByKeyOrder.js","/../../node_modules/yup/es/array.js","/../../node_modules/yup/es/Lazy.js","/../../node_modules/yup/es/setLocale.js","/src/common/account/SubscribtionContinuity.js","/src/common/account/SuspensionRecap.js","/src/common/components/text/LinkTextM.js","/../../node_modules/expo-web-browser/build/WebBrowser.js","/../../node_modules/react-native-web/dist/exports/Linking/index.js","/../../node_modules/expo-web-browser/build/ExpoWebBrowser.web.js","/../../node_modules/expo-web-browser/build/WebBrowser.types.js","/src/auth/PricingColumnM.js","/assets/offers/initial.png","/assets/offers/essential.png","/assets/offers/integral.png","/assets/offers/holidays.png","/src/common/components/badge/BadgeM.js","/src/common/utils/base64.js","/src/common/account/SubscriptionContinuityInformation.js","/assets/icons/generic/live.png","/assets/icons/generic/rituals.png","/assets/icons/generic/books.png","/src/student/account/onboarding/TrialOnboardingScreen.js","/assets/icons/menus/children.png","/assets/icons/generic/reportf.png","/src/data/utility/dataUtils.js","/src/student/account/onboarding/LiveRoomCard.js","/../../node_modules/react-native-url-polyfill/index.js","/../../node_modules/react-native-url-polyfill/js/ios10Fix.js","/../../node_modules/react-native-url-polyfill/package.json","/../../node_modules/react-native-url-polyfill/js/URL.js","/../../node_modules/whatwg-url-without-unicode/index.js","/../../node_modules/whatwg-url-without-unicode/webidl2js-wrapper.js","/../../node_modules/whatwg-url-without-unicode/lib/URL.js","/../../node_modules/whatwg-url-without-unicode/node_modules/webidl-conversions/lib/index.js","/../../node_modules/whatwg-url-without-unicode/lib/utils.js","/../../node_modules/whatwg-url-without-unicode/lib/URL-impl.js","/../../node_modules/whatwg-url-without-unicode/lib/url-state-machine.js","/../../node_modules/buffer/index.js","/../../node_modules/base64-js/index.js","/../../node_modules/ieee754/index.js","/../../node_modules/punycode/punycode.js","/../../node_modules/whatwg-url-without-unicode/lib/infra.js","/../../node_modules/whatwg-url-without-unicode/lib/urlencoded.js","/../../node_modules/whatwg-url-without-unicode/lib/URLSearchParams.js","/../../node_modules/whatwg-url-without-unicode/lib/URLSearchParams-impl.js","/../../node_modules/react-native-url-polyfill/js/URLSearchParams.js","/assets/icons/menus-new/prof.png","/src/auth/SubscribeScreen.js","/../../node_modules/expo-status-bar/build/StatusBar.web.js","/assets/logo-blue.png","/src/auth/PricingTableM.js","/src/student/account/subscription/MySubscriptionInfos.js","/src/data/utility/Can.js","/../../node_modules/@casl/react/dist/es5m/index.js","/../../node_modules/react-native-web/dist/exports/ActivityIndicator/index.js","/src/student/account/SubscriptionPrivilegeChip.js","/src/student/account/subscription/MySubscriptionScreen.js","/src/student/account/subscription/BecomePremiumCard.js","/src/student/account/subscription/SubscriptionStateCard.js","/src/common/components/button/TouchableRippleM.js","/src/student/account/ProfileSection.js","/../../node_modules/expo-linear-gradient/build/LinearGradient.js","/../../node_modules/expo-linear-gradient/build/NativeLinearGradient.web.js","/../../node_modules/expo-linear-gradient/build/normalizeColor.js","/src/tutor/students/ProfilDetails.js","/src/admin/AvailabilitySlotsM.js","/src/student/account/subscription/ChangePaymentCollectionDayModal.js","/../../node_modules/@hookform/resolvers/yup/dist/yup.module.js","/../../node_modules/@hookform/resolvers/dist/resolvers.module.js","/src/common/components/button/ToggleButtonM.js","/src/student/activity/todo/NextLiveSessionBanner.js","/src/data/redux/actions/data/index.js","/src/data/redux/actions/liveMode/index.js","/src/student/tutoring/RescheduleTrialLiveSessionModal.js","/src/common/components/stepper/FormStepperModal.js","/src/student/tutoring/StudentLiveSessionsListModal.js","/src/student/tutoring/StudentLiveSessionsList.js","/src/student/tutoring/StudentLiveCardComponent.js","/src/student/tutoring/SendTutorMessageModal.js","/src/common/hooks/useRequestsBatch.js","/src/common/utils/useInterval.js","/src/common/components/input/UncontrolledTextInputM.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheet/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheet/BottomSheet.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useBottomSheet.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/contexts/external.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useBottomSheetInternal.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/contexts/internal.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useBottomSheetModal.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/contexts/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/contexts/gesture.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/contexts/modal/external.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/contexts/modal/internal.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useBottomSheetModalInternal.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useScrollable.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/getRefNativeTag.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/constants.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useScrollableSetter.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useScrollHandler.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useScrollEventsHandlersDefault.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/normalizeSnapPoint.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/animate.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/getKeyboardAnimationConfigs.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/logger.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/noop.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useGestureHandler.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useGestureEventsHandlersDefault.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/clamp.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/snapPoint.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useKeyboard.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useStableCallback.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/usePropsValidator.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheet/constants.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useNormalizedSnapPoints.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useReactiveSharedValue.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useBottomSheetDynamicSnapPoints.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useBottomSheetGestureHandlers.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetContainer/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetContainer/BottomSheetContainer.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetContainer/styles.web.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetGestureHandlersProvider/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetGestureHandlersProvider/BottomSheetGestureHandlersProvider.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackdropContainer/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackdropContainer/BottomSheetBackdropContainer.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackdropContainer/styles.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetHandleContainer/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetHandleContainer/BottomSheetHandleContainer.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetHandle/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetHandle/BottomSheetHandle.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetHandle/styles.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackgroundContainer/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackgroundContainer/BottomSheetBackgroundContainer.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackground/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackground/BottomSheetBackground.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackground/styles.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackgroundContainer/styles.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetFooterContainer/BottomSheetFooterContainer.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetDraggableView/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetDraggableView/BottomSheetDraggableView.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheet/styles.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetModal/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetModal/BottomSheetModal.js","/../../node_modules/@gorhom/portal/lib/module/index.js","/../../node_modules/@gorhom/portal/lib/module/components/portal/Portal.js","/../../node_modules/@gorhom/portal/lib/module/hooks/usePortal.js","/../../node_modules/@gorhom/portal/lib/module/state/constants.js","/../../node_modules/@gorhom/portal/lib/module/contexts/portal.js","/../../node_modules/@gorhom/portal/lib/module/components/portalHost/PortalHost.js","/../../node_modules/@gorhom/portal/lib/module/hooks/usePortalState.js","/../../node_modules/@gorhom/portal/lib/module/components/portalProvider/PortalProvider.js","/../../node_modules/@gorhom/portal/lib/module/state/reducer.js","/../../node_modules/@gorhom/portal/lib/module/utilities/logger.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetModal/constants.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/utilities/id.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetModalProvider/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetModalProvider/BottomSheetModalProvider.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useBottomSheetSpringConfigs.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/hooks/useBottomSheetTimingConfigs.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetScrollable/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetScrollable/createBottomSheetScrollableComponent.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetRefreshControl/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetRefreshControl/BottomSheetRefreshControl.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetScrollable/styles.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetScrollable/BottomSheetSectionList.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetScrollable/BottomSheetFlatList.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetScrollable/BottomSheetScrollView.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetScrollable/BottomSheetVirtualizedList.js","/../../node_modules/react-native-web/dist/exports/VirtualizedList/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetView/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetView/BottomSheetView.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetTextInput/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetTextInput/BottomSheetTextInput.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackdrop/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackdrop/BottomSheetBackdrop.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackdrop/constants.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetBackdrop/styles.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetFooter/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetFooter/BottomSheetFooter.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/bottomSheetFooter/styles.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/touchables/index.js","/../../node_modules/@gorhom/bottom-sheet/lib/module/components/touchables/Touchables.js","/src/common/components/FAQ/FAQComponent.js","/src/common/account/ReferralActionCard.js","/src/common/chapters/feeling-quiz/ChapterFeelingQuiz.js","/src/common/chapters/feeling-quiz/FeelingQuiz.js","/src/common/chapters/feeling-quiz/FeelingQuizItem.js","/src/common/hooks/useLaunchActivity.js","/src/common/liveMode/CallStudentsStepper.js","/src/tutor/students/LiveAvatarM.js","/assets/icons/generic/forbidden.png","/assets/icons/activity-steps/photo.png","/src/common/liveMode/EndSessionScreen.js","/../../node_modules/react-native-callkeep/index.js","/../../node_modules/react-native-web/dist/exports/Alert/index.js","/../../node_modules/react-native-callkeep/actions.js","/src/common/liveMode/live-report/LiveReportComponent.js","/assets/icons/generic/video.png","/assets/icons/generic/chronometer.png","/src/common/chapters/ChapterItemComponent.js","/src/common/components/progress/ProgressBarM.js","/src/common/animations/SuccessAnimation.js","/src/common/components/playSound/PlaySoundM.js","/src/common/components/playSound/usePlaySound.js","/src/common/sound/PlaySound.js","/../../node_modules/expo-av/build/index.js","/../../node_modules/expo-av/build/Audio.js","/../../node_modules/expo-av/build/Audio.types.js","/../../node_modules/expo-av/build/ExponentAV.web.js","/../../node_modules/expo-av/build/Audio/RecordingConstants.js","/../../node_modules/expo-av/build/Audio/Recording.js","/../../node_modules/expo-av/build/Audio/AudioAvailability.js","/../../node_modules/expo-av/build/Audio/Sound.js","/../../node_modules/expo-av/build/AV.js","/../../node_modules/expo-av/build/AV.types.js","/../../node_modules/expo-av/build/Audio/Recording.types.js","/../../node_modules/expo-av/build/Video.js","/../../node_modules/expo-av/build/ExpoVideoManager.web.js","/../../node_modules/expo-av/build/FullscreenUtils.web.js","/../../node_modules/expo-av/build/ExponentVideo.web.js","/../../node_modules/expo-av/build/Video.types.js","/assets/sounds/progress.mp3","/src/common/chapters/ActivityLevelBadge.js","/assets/icons/intensity-level/intensity_level_1.png","/assets/icons/intensity-level/intensity_level_2.png","/assets/icons/intensity-level/intensity_level_3.png","/src/common/liveMode/SatisfactionComponent.js","/../../node_modules/react-native-ratings/src/index.tsx","/../../node_modules/react-native-ratings/src/SwipeRating.tsx","/../../node_modules/lodash/times.js","/../../node_modules/lodash/_castFunction.js","/../../node_modules/lodash/toInteger.js","/../../node_modules/lodash/toFinite.js","/../../node_modules/lodash/toNumber.js","/../../node_modules/lodash/_baseTrim.js","/../../node_modules/lodash/_trimmedEndIndex.js","/../../node_modules/react-native-ratings/src/images/star.png","/../../node_modules/react-native-ratings/src/images/heart.png","/../../node_modules/react-native-ratings/src/images/rocket.png","/../../node_modules/react-native-ratings/src/images/bell.png","/../../node_modules/react-native-ratings/src/TapRating.tsx","/../../node_modules/lodash/lodash.js","/../../node_modules/react-native-ratings/src/components/Star.tsx","/../../node_modules/react-native-ratings/src/images/airbnb-star.png","/../../node_modules/react-native-ratings/src/images/airbnb-star-selected.png","/src/common/liveMode/EndSessionStudentComment.js","/src/common/components/menu/MenuM.js","/../../node_modules/react-native-popup-menu/build/rnpm.js","/../../node_modules/react-native-web/dist/index.js","/../../node_modules/react-native-web/dist/exports/render/index.js","/../../node_modules/react-dom/client.js","/../../node_modules/react-native-web/dist/exports/unmountComponentAtNode/index.js","/../../node_modules/react-native-web/dist/exports/AppRegistry/index.js","/../../node_modules/react-native-web/dist/exports/AppRegistry/renderApplication.js","\u0000shim:react-native-web/dist/exports/AppRegistry/AppContainer.js","/../../node_modules/react-native-web/dist/exports/Clipboard/index.js","/../../node_modules/react-native-web/dist/exports/LayoutAnimation/index.js","/../../node_modules/react-native-web/dist/vendor/react-native/LayoutAnimation/index.js","/../../node_modules/react-native-web/dist/exports/Share/index.js","/../../node_modules/react-native-web/dist/exports/Button/index.js","/../../node_modules/react-native-web/dist/exports/CheckBox/index.js","/../../node_modules/react-native-web/dist/exports/ImageBackground/index.js","/../../node_modules/react-native-web/dist/exports/Picker/index.js","/../../node_modules/react-native-web/dist/exports/Picker/PickerItem.js","/../../node_modules/react-native-web/dist/exports/ProgressBar/index.js","/../../node_modules/react-native-web/dist/exports/SafeAreaView/index.js","/../../node_modules/react-native-web/dist/exports/YellowBox/index.js","/../../node_modules/react-native-web/dist/exports/LogBox/index.js","/../../node_modules/react-native-web/dist/exports/useColorScheme/index.js","/../../node_modules/react-native-web/dist/exports/useLocaleContext/index.js","/src/student/activity/execute/AudioRecordingContainer.js","/../../node_modules/@react-native-community/slider/dist/Slider.js","/../../node_modules/@babel/runtime/helpers/slicedToArray.js","/../../node_modules/@babel/runtime/helpers/arrayWithHoles.js","/../../node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","/../../node_modules/@babel/runtime/helpers/nonIterableRest.js","/../../node_modules/@babel/runtime/helpers/objectWithoutProperties.js","/../../node_modules/@react-native-community/slider/dist/index.js","/../../node_modules/@react-native-community/slider/dist/RNCSliderNativeComponent.web.js","/../../node_modules/@babel/runtime/helpers/toConsumableArray.js","/../../node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","/../../node_modules/@babel/runtime/helpers/iterableToArray.js","/../../node_modules/@babel/runtime/helpers/nonIterableSpread.js","/../../node_modules/@react-native-community/slider/dist/components/StepsIndicator.js","/../../node_modules/@react-native-community/slider/dist/components/StepNumber.js","/../../node_modules/@react-native-community/slider/dist/utils/styles.js","/../../node_modules/@react-native-community/slider/dist/components/TrackMark.js","/../../node_modules/@react-native-community/slider/dist/utils/constants.js","/../../node_modules/expo-keep-awake/build/index.js","/../../node_modules/expo-keep-awake/build/ExpoKeepAwake.web.js","/../../node_modules/expo-keep-awake/build/KeepAwake.types.js","/src/common/components/input/TextInputAutoSaveM.js","/src/common/liveMode/EndSessionScreenStudent.js","/src/common/header/LiveSessionDialogComponent.js","/src/common/liveMode/LaunchLiveScreen.js","/src/common/screens/CongratsScreen.js","/src/student/organize/challenges/ChallengeLaunchCongrats.js","/src/student/organize/challenges/ChallengeHeaderNew.js","/src/student/organize/challenges/ChallengeProgressBarNew.js","/src/student/activity/execute/ActivityFinalizedCongrats.js","/src/student/activity/read/ActivityXpKeyValueItem.js","/src/common/components/card/KeyValueItem.js","/src/common/hooks/livekit/useLiveKitEventSender.js","/src/common/hooks/livekit/useLiveKitEventListener.js","/src/data/redux/actions/broadcast/index.js","/src/common/hooks/livekit/useLiveKitEventHandler.web.js","/../../node_modules/livekit-client/dist/livekit-client.esm.mjs","/../../node_modules/@livekit/components-react/dist/index.mjs","/../../node_modules/@livekit/components-react/dist/hooks-JwdUfgCD.mjs","/../../node_modules/@livekit/components-react/dist/contexts-B7YgC7ji.mjs","/../../node_modules/@livekit/components-react/dist/room-BBI9Ul2f.mjs","/../../node_modules/@livekit/components-react/dist/prefabs.mjs","/../../node_modules/@livekit/components-react/dist/components-DZxz2YwG.mjs","/assets/sounds/toggle_001.mp3","/assets/sounds/finished.mp3","/src/student/progress/successes/NewAchievementCongrats.js","/src/student/progress/successes/SuccessBadge.js","/src/common/components/statistics/Counters.js","/src/student/organize/challenges/ChallengeProgressCongrats.js","/src/student/shop/ShopProductPurchasedCongrats.js","/src/student/activity/read/ActivityReviewedCongrats.js","/src/student/activity/read/ActivityScoringKeyValueItem.js","/src/student/activity/read/ScoringDetails.js","/src/common/components/rating/RatingM.js","/assets/icons/stars/sparkle_b.png","/src/student/account/profile/ProfileCompletedCongrats.js","/src/student/tutoring/OfferChosenCongrats.js","/src/student/account/onboarding/StartTrialNewScreen.js","/assets/icon-2.png","/src/student/account/onboarding/SelectInputM.js","/src/student/account/onboarding/CertificateIconM.js","/src/student/account/CustomizableAvatar.js","/src/student/account/ImagePickerCropModal.js","/../../node_modules/react-avatar-image-cropper/src/index.js","/src/data/utility/asyncStorageUtils.js","/src/common/screens/GenericCongrats.js","/src/data/constants/championsConstants.js","/src/student/league/LeagueCongrats.js","/src/student/progress/my progress/MyProgressCongrats.js","/src/student/progress/my progress/SkillItem.js","/src/common/components/skill/SkillBadge.js","/src/student/account/SkillSetTitleButton.js","/src/student/progress/my progress/NewTitleCongrats.js","/assets/sounds/new-title.mp3","/src/student/progress/my progress/PetalsGainedCongrats.js","/assets/sounds/petals-gained-2.mp3","/../../node_modules/lottie-react-native/lib/module/index.js","/../../node_modules/lottie-react-native/lib/module/LottieView/index.web.js","/../../node_modules/lottie-react-native/lib/module/LottieView/utils.js","/../../node_modules/@dotlottie/react-player/dist/index.js","/../../node_modules/@dotlottie/react-player/dist/chunk-O2M23KUL.js","/../../node_modules/@dotlottie/react-player/dist/chunk-XVC7DH25.js","/../../node_modules/@dotlottie/common/dist/index.js","/../../node_modules/@dotlottie/common/dist/chunk-NZJZ4CCL.js","/../../node_modules/@dotlottie/common/dist/chunk-74T7T5LL.js","/../../node_modules/@dotlottie/common/dist/chunk-DCAKKOYV.js","/../../node_modules/@dotlottie/common/dist/chunk-GSRQSB3U.js","/../../node_modules/metro-runtime/src/modules/asyncRequire.js","/../../node_modules/@dotlottie/common/dist/chunk-BHJSY5WG.js","/../../node_modules/@dotlottie/common/dist/chunk-B7OIQIGJ.js","/../../node_modules/@dotlottie/react-player/dist/chunk-ZAFYX2AB.js","/../../node_modules/@lottiefiles/react-lottie-player/dist/lottie-react.esm.js","/../../node_modules/lottie-react-native/lib/module/types.js","/src/student/social/ShareStatsCongrats.js","/assets/icons/generic/tree.png","/assets/icons/generic/lunch-bag.png","/src/student/activity/todo/NewTodoCongrats.js","/src/student/organize/list/RealizationsListItem.js","/src/student/organize/list/RealizationsListItemContent.js","/src/student/activity/read/DoneChip.js","/src/student/organize/list/TodoActivityBadges.js","/src/student/activity/execute/TimerContainer.js","/assets/sounds/question_002.mp3","/assets/sounds/error_003.mp3","/src/data/redux/actions/navigation/index.js","/src/quiz/QuizzInitializedCongrats.js","/src/quiz/QuizzConfirmedCongrats.js","/assets/icons/generic/plant_tree.png","/assets/social/linkedin.png","/assets/social/facebook.png","/assets/social/instagram.png","/src/tutor/application/ApplicationStepCongrats.js","/src/tutor/application/motivation/ApplicationFinishedCongrats.js","/src/student/tutoring/DownloadAppCongrats.js","/assets/icons/generic/fire.png","/assets/app-store-b.png","/assets/google-play-b.png","/../../node_modules/expo-store-review/build/StoreReview.js","/../../node_modules/expo-store-review/build/ExpoStoreReview.js","/src/student/tutoring/DownloadAppButton.js","/src/common/chapters/ChapterProgressCongrats.js","/assets/animations/62717-confetti.json","/src/common/liveMode/live-report/LiveReportScreen.js","/src/common/header/HeaderContainerM.js","/src/common/liveMode/LiveMainLayout.js","/src/data/redux/actions/videoCall/index.js","/src/common/liveMode/liveV3/LiveContainerV3.js","/src/common/notifications/NotificationSubscriptionHandler.js","/../../node_modules/expo-device/build/Device.js","/../../node_modules/expo-device/build/Device.types.js","/../../node_modules/expo-device/build/ExpoDevice.web.js","/../../node_modules/ua-parser-js/src/ua-parser.js","/../../node_modules/expo-notifications/build/index.js","/../../node_modules/expo-notifications/build/getDevicePushTokenAsync.web.js","/../../node_modules/expo-notifications/build/unregisterForNotificationsAsync.js","/../../node_modules/expo-notifications/build/PushTokenManager.js","/../../node_modules/expo-notifications/build/getExpoPushTokenAsync.js","/../../node_modules/expo-application/build/Application.js","/../../node_modules/expo-application/build/Application.types.js","/../../node_modules/expo-application/build/ExpoApplication.web.js","/../../node_modules/expo-notifications/build/DevicePushTokenAutoRegistration.fx.js","/../../node_modules/abort-controller/polyfill.mjs","/../../node_modules/abort-controller/dist/abort-controller.mjs","/../../node_modules/event-target-shim/dist/event-target-shim.mjs","/../../node_modules/expo-notifications/build/ServerRegistrationModule.web.js","/../../node_modules/expo-notifications/build/TokenEmitter.js","/../../node_modules/expo-notifications/build/utils/updateDevicePushTokenAsync.js","/../../node_modules/@ide/backoff/build/backoff.js","/../../node_modules/assert/build/assert.js","/../../node_modules/assert/build/internal/errors.js","/../../node_modules/util/util.js","/../../node_modules/util/support/types.js","/../../node_modules/is-arguments/index.js","/../../node_modules/has-tostringtag/shams.js","/../../node_modules/has-symbols/shams.js","/../../node_modules/call-bind/callBound.js","/../../node_modules/get-intrinsic/index.js","/../../node_modules/has-symbols/index.js","/../../node_modules/has-proto/index.js","/../../node_modules/function-bind/index.js","/../../node_modules/function-bind/implementation.js","/../../node_modules/has/src/index.js","/../../node_modules/call-bind/index.js","/../../node_modules/is-generator-function/index.js","/../../node_modules/which-typed-array/index.js","/../../node_modules/for-each/index.js","/../../node_modules/is-callable/index.js","/../../node_modules/available-typed-arrays/index.js","/../../node_modules/gopd/index.js","/../../node_modules/is-typed-array/index.js","/../../node_modules/util/support/isBufferBrowser.js","/../../node_modules/inherits/inherits_browser.js","/../../node_modules/assert/build/internal/assert/assertion_error.js","/../../node_modules/object.assign/polyfill.js","/../../node_modules/object.assign/implementation.js","/../../node_modules/object-keys/index.js","/../../node_modules/object-keys/isArguments.js","/../../node_modules/object-keys/implementation.js","/../../node_modules/object-is/polyfill.js","/../../node_modules/object-is/implementation.js","/../../node_modules/assert/build/internal/util/comparisons.js","/../../node_modules/object-is/index.js","/../../node_modules/define-properties/index.js","/../../node_modules/define-data-property/index.js","/../../node_modules/has-property-descriptors/index.js","/../../node_modules/object-is/shim.js","/../../node_modules/is-nan/index.js","/../../node_modules/is-nan/implementation.js","/../../node_modules/is-nan/polyfill.js","/../../node_modules/is-nan/shim.js","/../../node_modules/expo-notifications/build/getPresentedNotificationsAsync.js","/../../node_modules/expo-notifications/build/NotificationPresenterModule.js","/../../node_modules/expo-notifications/build/utils/mapNotificationResponse.js","/../../node_modules/expo-notifications/build/presentNotificationAsync.js","/../../node_modules/expo-notifications/build/dismissNotificationAsync.js","/../../node_modules/expo-notifications/build/dismissAllNotificationsAsync.js","/../../node_modules/expo-notifications/build/getNotificationChannelsAsync.js","/../../node_modules/expo-notifications/build/getNotificationChannelAsync.js","/../../node_modules/expo-notifications/build/setNotificationChannelAsync.js","/../../node_modules/expo-notifications/build/deleteNotificationChannelAsync.js","/../../node_modules/expo-notifications/build/getNotificationChannelGroupsAsync.js","/../../node_modules/expo-notifications/build/getNotificationChannelGroupAsync.js","/../../node_modules/expo-notifications/build/setNotificationChannelGroupAsync.js","/../../node_modules/expo-notifications/build/deleteNotificationChannelGroupAsync.js","/../../node_modules/expo-notifications/build/getBadgeCountAsync.js","/../../node_modules/expo-notifications/build/BadgeModule.web.js","/../../node_modules/badgin/build/index.es.js","/../../node_modules/expo-notifications/build/setBadgeCountAsync.js","/../../node_modules/expo-notifications/build/getAllScheduledNotificationsAsync.js","/../../node_modules/expo-notifications/build/NotificationScheduler.js","/../../node_modules/expo-notifications/build/scheduleNotificationAsync.js","/../../node_modules/expo-notifications/build/cancelScheduledNotificationAsync.js","/../../node_modules/expo-notifications/build/cancelAllScheduledNotificationsAsync.js","/../../node_modules/expo-notifications/build/getNotificationCategoriesAsync.js","/../../node_modules/expo-notifications/build/NotificationCategoriesModule.js","/../../node_modules/expo-notifications/build/setNotificationCategoryAsync.js","/../../node_modules/expo-notifications/build/deleteNotificationCategoryAsync.js","/../../node_modules/expo-notifications/build/getNextTriggerDateAsync.js","/../../node_modules/expo-notifications/build/useLastNotificationResponse.js","/../../node_modules/expo-notifications/build/NotificationsEmitter.js","/../../node_modules/expo-notifications/build/NotificationsEmitterModule.js","/../../node_modules/expo-notifications/build/registerTaskAsync.js","/../../node_modules/expo-notifications/build/BackgroundNotificationTasksModule.js","/../../node_modules/expo-notifications/build/unregisterTaskAsync.js","/../../node_modules/expo-notifications/build/NotificationsHandler.js","/../../node_modules/expo-notifications/build/NotificationsHandlerModule.js","/../../node_modules/expo-notifications/build/NotificationPermissions.js","/../../node_modules/expo-notifications/build/NotificationPermissionsModule.js","/../../node_modules/expo-notifications/build/NotificationChannelGroupManager.types.js","/../../node_modules/expo-notifications/build/NotificationChannelManager.types.js","/../../node_modules/expo-notifications/build/NotificationPermissions.types.js","/../../node_modules/expo-notifications/build/Notifications.types.js","/../../node_modules/expo-notifications/build/Tokens.types.js","/src/data/redux/actions/notifications/index.js","/src/common/main-menu/LivesBottomTabsNavigator.js","/src/common/liveMode/liveStudentTabScreens.js","/src/student/organize/list/RealizationsTabScreen.js","/src/student/activity/read/ReadReviewRequestHandler.js","/src/common/notifications/notifications.js","/src/common/components/alert/alertPolyfill.js","/assets/icons/menus-new/accueil.png","/assets/icons/menus-new/accueil-gris.png","/assets/icons/menus-new/travaux-faits.png","/assets/icons/menus-new/travaux-faits-gris.png","/src/student/activity/todo/TodoListScreen.js","/../../node_modules/react-native-draggable-flatlist/lib/module/index.js","/../../node_modules/react-native-draggable-flatlist/lib/module/components/DraggableFlatList.js","/../../node_modules/react-native-draggable-flatlist/lib/module/components/CellRendererComponent.js","/../../node_modules/react-native-draggable-flatlist/lib/module/context/draggableFlatListContext.js","/../../node_modules/react-native-draggable-flatlist/lib/module/constants.js","/../../node_modules/react-native-draggable-flatlist/lib/module/hooks/useCellTranslate.js","/../../node_modules/react-native-draggable-flatlist/lib/module/context/animatedValueContext.js","/../../node_modules/react-native-draggable-flatlist/lib/module/context/propsContext.js","/../../node_modules/react-native-draggable-flatlist/lib/module/context/refContext.js","/../../node_modules/react-native-draggable-flatlist/lib/module/utils.js","/../../node_modules/react-native-draggable-flatlist/lib/module/context/cellContext.js","/../../node_modules/react-native-draggable-flatlist/lib/module/hooks/useStableCallback.js","/../../node_modules/react-native-draggable-flatlist/lib/module/components/PlaceholderItem.js","/../../node_modules/react-native-draggable-flatlist/lib/module/components/RowItem.js","/../../node_modules/react-native-draggable-flatlist/lib/module/hooks/useAutoScroll.js","/../../node_modules/react-native-draggable-flatlist/lib/module/components/ScrollOffsetListener.js","/../../node_modules/react-native-draggable-flatlist/lib/module/components/CellDecorators.js","/../../node_modules/react-native-draggable-flatlist/lib/module/hooks/useOnCellActiveAnimation.js","/../../node_modules/react-native-draggable-flatlist/lib/module/components/NestableDraggableFlatList.js","/../../node_modules/react-native-draggable-flatlist/lib/module/context/nestableScrollContainerContext.js","/../../node_modules/react-native-draggable-flatlist/lib/module/hooks/useNestedAutoScroll.js","/../../node_modules/react-native-draggable-flatlist/lib/module/components/NestableScrollContainer.js","/../../node_modules/react-native-draggable-flatlist/lib/module/types.js","/src/student/activity/todo/TodoModal.js","/src/student/activity/execute/MaterialDisplayModal.js","/src/common/components/menu/Menu3Point.js","/src/data/redux/actions/offlineMode/index.js","/../../node_modules/react-native-webview/index.js","/../../node_modules/react-native-webview/lib/WebView.js","/../../node_modules/react-native-webview/lib/WebView.styles.js","/src/common/components/pdf/PdfViewer.web.js","/src/student/activity/todo/ActivityPicker.js","/src/common/components/button/TouchableTile.js","/src/student/activity/execute/YoutubePlayer.js","/../../node_modules/react-player/youtube.js","/../../node_modules/react-player/lib/ReactPlayer.js","/../../node_modules/deepmerge/dist/cjs.js","/../../node_modules/memoize-one/dist/memoize-one.esm.js","/../../node_modules/react-fast-compare/index.js","/../../node_modules/react-player/lib/props.js","/../../node_modules/react-player/lib/utils.js","/../../node_modules/load-script/index.js","/../../node_modules/react-player/lib/Player.js","/../../node_modules/react-player/lib/players/YouTube.js","/../../node_modules/react-player/lib/patterns.js","/src/common/components/pdf/pdfHelpers.js","/src/tutor/students/IconTouchableRipple.js","/src/student/activity/read/StepLogs.js","/src/student/activity/ActivityIcon.js","/assets/icons/activity-steps/play.png","/assets/icons/activity-steps/form.png","/assets/icons/activity-steps/text.png","/assets/icons/activity-steps/audio.png","/assets/icons/activity-steps/chrono.png","/src/common/components/card/KeyComponentItem.js","/../../node_modules/react-native-hyperlink/dist/module/index.js","/../../node_modules/react-native-hyperlink/dist/module/Hyperlink.js","/../../node_modules/mdurl/index.js","/../../node_modules/mdurl/encode.js","/../../node_modules/mdurl/decode.js","/../../node_modules/mdurl/format.js","/../../node_modules/mdurl/parse.js","/../../node_modules/linkify-it/index.js","/../../node_modules/linkify-it/lib/re.js","/../../node_modules/uc.micro/properties/Any/regex.js","/../../node_modules/uc.micro/categories/Cc/regex.js","/../../node_modules/uc.micro/categories/Z/regex.js","/../../node_modules/uc.micro/categories/P/regex.js","/src/student/organize/challenges/StudentSuggestions.js","/src/student/champions/ChampionBottomSheetModal.js","/src/common/components/modal/BottomSheetM.js","/src/data/redux/actions/suggestions/index.js","/src/tutor/students/StudentsListItem.js","/src/reviewer/BoxedCardBorderStyle.js","/src/student/activity/todo/ChaptersList.js","/src/common/components/card/BannerCard.js","/src/common/liveMode/liveTutorTabScreens.js","/assets/icons/menus/children-g.png","/assets/icons/menus/loupe.png","/assets/icons/menus/loupe-g.png","/src/common/liveMode/StudentsList.js","/src/tutor/students/NewStudentsListItem.js","/src/common/components/icons/DualIconButton.js","/src/reviewer/ReviewActivitiesTabScreen.js","/src/common/components/menu/MenuFilter.js","/src/common/components/select/selectSingle-Multiple.js","/src/tutor/home/tutorResources/TutorResources.js","/assets/icons/menus/write.png","/assets/icons/menus/write-g.png","/../../node_modules/@react-navigation/bottom-tabs/lib/module/index.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/navigators/createBottomTabNavigator.js","/../../node_modules/warn-once/index.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/views/BottomTabView.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/index.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Background.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/getDefaultHeaderHeight.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/getHeaderTitle.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/Header.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/HeaderBackground.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/HeaderShownContext.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/getNamedContext.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/HeaderTitle.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/HeaderBackButton.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/MaskedView.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/PlatformPressable.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/assets/back-icon.png","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/assets/back-icon-mask.png","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/HeaderBackContext.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/HeaderHeightContext.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Header/useHeaderHeight.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/MissingIcon.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/ResourceSavingView.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/SafeAreaProviderCompat.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/Screen.js","/../../node_modules/@react-navigation/bottom-tabs/node_modules/@react-navigation/elements/lib/module/types.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/utils/BottomTabBarHeightCallbackContext.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/utils/BottomTabBarHeightContext.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/views/BottomTabBar.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/utils/useIsKeyboardShown.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/views/BottomTabItem.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/views/TabBarIcon.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/views/Badge.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/views/ScreenFallback.js","/../../node_modules/react-native-screens/lib/module/index.js","/../../node_modules/react-native-screens/lib/module/types.js","/../../node_modules/react-native-screens/lib/module/core.js","/../../node_modules/react-native-screens/lib/module/components/Screen.web.js","/../../node_modules/react-native-screens/lib/module/components/ScreenContainer.web.js","/../../node_modules/react-native-screens/lib/module/components/ScreenStack.web.js","/../../node_modules/react-native-screens/lib/module/components/ScreenStackHeaderConfig.web.js","/../../node_modules/react-native-screens/lib/module/components/SearchBar.web.js","/../../node_modules/react-native-screens/lib/module/components/FullWindowOverlay.web.js","/../../node_modules/react-native-screens/lib/module/fabric/NativeScreensModule.web.js","/../../node_modules/react-native-screens/lib/module/native-stack/contexts/GHContext.js","/../../node_modules/react-native-screens/lib/module/utils.js","/../../node_modules/react-native-screens/lib/module/useTransitionProgress.js","/../../node_modules/react-native-screens/lib/module/TransitionProgressContext.js","/../../node_modules/@react-navigation/bottom-tabs/lib/module/utils/useBottomTabBarHeight.js","/src/common/header/LiveModeParticipantsIcon.js","/src/common/livekit/LKVideoCallPortal.web.js","/src/common/video-call/DraggableView.js","/src/common/video-call/MiniModeM.web.js","/src/common/video-call/ConnectingView.js","/src/common/header/LiveModeHeader.js","/src/common/liveMode/LiveChat.js","/src/common/messenger/CommonChat.js","/../../node_modules/dayjs/locale/fr.js","/../../node_modules/dayjs/dayjs.min.js","/../../node_modules/react-native-gifted-chat/lib/index.js","/../../node_modules/react-native-get-random-values/index.web.js","/../../node_modules/react-native-gifted-chat/lib/GiftedChat.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/index.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/ActionSheetProvider.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/ActionSheet/index.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/ActionSheet/CustomActionSheet.js","/../../node_modules/@babel/runtime/helpers/classCallCheck.js","/../../node_modules/@babel/runtime/helpers/createClass.js","/../../node_modules/@babel/runtime/helpers/assertThisInitialized.js","/../../node_modules/@babel/runtime/helpers/inherits.js","/../../node_modules/@babel/runtime/helpers/setPrototypeOf.js","/../../node_modules/@babel/runtime/helpers/possibleConstructorReturn.js","/../../node_modules/@babel/runtime/helpers/getPrototypeOf.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/ActionSheet/ActionGroup.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/ActionSheet/TouchableNativeFeedbackSafe.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/context.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/connectActionSheet.js","/../../node_modules/@expo/react-native-action-sheet/lib/module/types.js","/../../node_modules/react-native-gifted-chat/node_modules/dayjs/dayjs.min.js","/../../node_modules/react-native-gifted-chat/node_modules/dayjs/plugin/localizedFormat.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/index.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/max.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/nil.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/parse.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/validate.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/regex.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/stringify.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v1.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/rng.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v1ToV6.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v3.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v35.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/md5.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v4.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/native.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v5.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/sha1.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v6.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v6ToV1.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/v7.js","/../../node_modules/react-native-gifted-chat/node_modules/uuid/dist/esm-browser/version.js","/../../node_modules/react-native-gifted-chat/lib/Actions.js","/../../node_modules/react-native-gifted-chat/lib/Color.js","/../../node_modules/react-native-gifted-chat/lib/utils.js","/../../node_modules/react-native-gifted-chat/lib/GiftedChatContext.js","/../../node_modules/react-native-gifted-chat/lib/Avatar.js","/../../node_modules/react-native-gifted-chat/lib/GiftedAvatar.js","/../../node_modules/react-native-gifted-chat/lib/Bubble.js","/../../node_modules/react-native-gifted-chat/lib/QuickReplies.js","/../../node_modules/react-native-gifted-chat/lib/logging.js","/../../node_modules/react-native-gifted-chat/lib/MessageText.js","/../../node_modules/react-native-parsed-text/src/ParsedText.js","/../../node_modules/react-native-parsed-text/src/lib/TextExtraction.js","/../../node_modules/react-native-gifted-chat/lib/MessageImage.js","/../../node_modules/react-native-lightbox-v2/dist/Lightbox.js","/../../node_modules/react-native-lightbox-v2/dist/LightboxOverlay.js","/../../node_modules/react-native-lightbox-v2/dist/hooks/index.js","/../../node_modules/react-native-lightbox-v2/dist/hooks/use-gesture.js","/../../node_modules/react-native-lightbox-v2/dist/hooks/use-next-tick.js","/../../node_modules/react-native-gifted-chat/lib/MessageVideo.js","/../../node_modules/react-native-gifted-chat/lib/MessageAudio.js","/../../node_modules/react-native-gifted-chat/lib/Time.js","/../../node_modules/react-native-gifted-chat/lib/Constant.js","/../../node_modules/react-native-gifted-chat/lib/Composer.js","/../../node_modules/react-native-gifted-chat/lib/Day.js","/../../node_modules/react-native-gifted-chat/lib/InputToolbar.js","/../../node_modules/react-native-gifted-chat/lib/Send.js","/../../node_modules/react-native-gifted-chat/lib/LoadEarlier.js","/../../node_modules/react-native-gifted-chat/lib/Message.js","/../../node_modules/lodash.isequal/index.js","/../../node_modules/react-native-gifted-chat/lib/SystemMessage.js","/../../node_modules/react-native-gifted-chat/lib/MessageContainer.js","/../../node_modules/react-native-gifted-chat/lib/TypingIndicator.js","/../../node_modules/react-native-gifted-chat/lib/Models.js","/../../node_modules/emoji-toolkit/lib/js/joypixels.js","/../../node_modules/html-entities/lib/index.js","/../../node_modules/html-entities/lib/named-references.js","/../../node_modules/html-entities/lib/numeric-unicode-map.js","/../../node_modules/html-entities/lib/surrogate-pairs.js","/src/common/messenger/AudioRecordingModal.js","/src/common/messenger/activity/CreateActivityFromChatImageScreen.js","/src/common/messenger/SendImageComponent.js","/../../node_modules/react-native-paper/src/utils/getContrastingColor.tsx","/src/common/livekit/components/PermissionBanner.js","/../../node_modules/expo-camera/build/index.js","/../../node_modules/expo-camera/build/ExpoCameraManager.web.js","/../../node_modules/expo-camera/build/legacy/Camera.types.js","/../../node_modules/expo-camera/build/web/WebUserMediaManager.js","/../../node_modules/expo-camera/build/CameraView.js","/../../node_modules/expo-camera/build/ExpoCamera.web.js","/../../node_modules/expo-camera/build/web/WebCameraUtils.js","/../../node_modules/expo-camera/build/web/WebCapabilityUtils.js","/../../node_modules/expo-camera/build/web/WebConstants.js","/../../node_modules/expo-camera/build/web/useWebCameraStream.js","/../../node_modules/expo-camera/build/web/useWebQRScanner.js","/../../node_modules/expo-camera/build/utils/props.js","/../../node_modules/expo-camera/build/Camera.types.js","/src/common/video-call/PermissionsManager.js","/../../node_modules/livekit-client/src/room/Room.ts","/../../node_modules/@livekit/mutex/dist/index.mjs","/../../node_modules/@livekit/protocol/dist/index.mjs","/../../node_modules/@bufbuild/protobuf/dist/cjs/index.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/proto3.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/proto-runtime.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/enum.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/assert.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/message-type.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/message.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/extensions.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/scalars.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/proto-int64.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/varint.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/scalar.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/json-format.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/proto-base64.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/extension-accessor.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/reflect.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/field-wrapper.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/is-message.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/binary-format.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/binary-encoding.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/util-common.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/field-list.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/field-normalize.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/field.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/names.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/proto2.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/proto-double.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/proto-delimited.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/codegen-info.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/reify-wkt.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/service-type.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/create-descriptor-set.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/descriptor_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/text-format.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/private/feature-set.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/create-registry.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/create-registry-from-desc.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/timestamp_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/duration_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/any_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/empty_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/field_mask_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/struct_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/wrappers_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/to-plain-message.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/compiler/plugin_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/api_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/type_pb.js","/../../node_modules/@bufbuild/protobuf/dist/cjs/google/protobuf/source_context_pb.js","/../../node_modules/events/events.js","/../../node_modules/webrtc-adapter/src/js/adapter_core.js","/../../node_modules/webrtc-adapter/src/js/adapter_factory.js","/../../node_modules/webrtc-adapter/src/js/utils.js","/../../node_modules/webrtc-adapter/src/js/chrome/chrome_shim.js","/../../node_modules/webrtc-adapter/src/js/chrome/getusermedia.js","/../../node_modules/webrtc-adapter/src/js/firefox/firefox_shim.js","/../../node_modules/webrtc-adapter/src/js/firefox/getusermedia.js","/../../node_modules/webrtc-adapter/src/js/firefox/getdisplaymedia.js","/../../node_modules/webrtc-adapter/src/js/safari/safari_shim.js","/../../node_modules/webrtc-adapter/src/js/common_shim.js","/../../node_modules/sdp/sdp.js","/../../node_modules/livekit-client/src/e2ee/index.ts","/../../node_modules/livekit-client/src/e2ee/KeyProvider.ts","/../../node_modules/livekit-client/src/logger.ts","/../../node_modules/loglevel/lib/loglevel.js","/../../node_modules/livekit-client/src/e2ee/constants.ts","/../../node_modules/livekit-client/src/e2ee/events.ts","/../../node_modules/livekit-client/src/e2ee/utils.ts","/../../node_modules/livekit-client/src/e2ee/types.ts","/../../node_modules/livekit-client/src/e2ee/errors.ts","/../../node_modules/livekit-client/src/room/errors.ts","/../../node_modules/livekit-client/src/e2ee/E2eeManager.ts","/../../node_modules/livekit-client/src/room/events.ts","/../../node_modules/livekit-client/src/room/track/utils.ts","/../../node_modules/livekit-client/src/utils/cloneDeep.ts","/../../node_modules/livekit-client/src/room/utils.ts","/../../node_modules/livekit-client/src/utils/browserParser.ts","/../../node_modules/livekit-client/src/version.ts","/../../node_modules/livekit-client/package.json","/../../node_modules/livekit-client/src/room/timers.ts","/../../node_modules/livekit-client/src/room/track/Track.ts","/../../node_modules/livekit-client/src/room/track/options.ts","/../../node_modules/livekit-client/src/room/DeviceManager.ts","/../../node_modules/livekit-client/src/room/RTCEngine.ts","/../../node_modules/livekit-client/src/api/SignalClient.ts","/../../node_modules/livekit-client/src/utils/AsyncQueue.ts","/../../node_modules/livekit-client/src/room/PCTransport.ts","/../../node_modules/sdp-transform/lib/index.js","/../../node_modules/sdp-transform/lib/parser.js","/../../node_modules/sdp-transform/lib/grammar.js","/../../node_modules/sdp-transform/lib/writer.js","/../../node_modules/ts-debounce/dist/src/index.esm.js","/../../node_modules/livekit-client/src/room/PCTransportManager.ts","/../../node_modules/livekit-client/src/room/defaults.ts","/../../node_modules/livekit-client/src/room/DefaultReconnectPolicy.ts","/../../node_modules/livekit-client/src/room/RegionUrlProvider.ts","/../../node_modules/livekit-client/src/room/StreamReader.ts","/../../node_modules/livekit-client/src/room/participant/LocalParticipant.ts","/../../node_modules/livekit-client/src/room/StreamWriter.ts","/../../node_modules/livekit-client/src/room/rpc.ts","/../../node_modules/livekit-client/src/room/track/LocalAudioTrack.ts","/../../node_modules/livekit-client/src/room/stats.ts","/../../node_modules/livekit-client/src/room/track/LocalTrack.ts","/../../node_modules/livekit-client/src/room/track/LocalTrackPublication.ts","/../../node_modules/livekit-client/src/room/track/TrackPublication.ts","/../../node_modules/livekit-client/src/room/track/LocalVideoTrack.ts","/../../node_modules/livekit-client/src/room/participant/publishUtils.ts","/../../node_modules/livekit-client/src/room/participant/Participant.ts","/../../node_modules/livekit-client/src/room/participant/ParticipantTrackPermission.ts","/../../node_modules/livekit-client/src/room/participant/RemoteParticipant.ts","/../../node_modules/livekit-client/src/room/track/RemoteAudioTrack.ts","/../../node_modules/livekit-client/src/room/track/RemoteTrack.ts","/../../node_modules/livekit-client/src/room/track/RemoteTrackPublication.ts","/../../node_modules/livekit-client/src/room/track/RemoteVideoTrack.ts","/src/common/livekit/components/useDisconnecting.js","/src/common/livekit/components-web/ControlBarM.tsx","/../../node_modules/@livekit/components-core/dist/index.mjs","/../../node_modules/@floating-ui/dom/dist/floating-ui.dom.esm.js","/../../node_modules/@floating-ui/core/dist/floating-ui.core.esm.js","/../../node_modules/@floating-ui/utils/dist/floating-ui.utils.esm.js","/../../node_modules/@floating-ui/utils/dom/floating-ui.utils.dom.esm.js","/../../node_modules/@livekit/components-core/node_modules/loglevel/lib/loglevel.js","/../../node_modules/rxjs/dist/esm5/index.js","/../../node_modules/rxjs/dist/esm5/internal/Observable.js","/../../node_modules/rxjs/dist/esm5/internal/Subscriber.js","/../../node_modules/rxjs/dist/esm5/internal/util/isFunction.js","/../../node_modules/rxjs/dist/esm5/internal/Subscription.js","/../../node_modules/rxjs/dist/esm5/internal/util/UnsubscriptionError.js","/../../node_modules/rxjs/dist/esm5/internal/util/createErrorClass.js","/../../node_modules/rxjs/dist/esm5/internal/util/arrRemove.js","/../../node_modules/rxjs/dist/esm5/internal/config.js","/../../node_modules/rxjs/dist/esm5/internal/util/reportUnhandledError.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/timeoutProvider.js","/../../node_modules/rxjs/dist/esm5/internal/util/noop.js","/../../node_modules/rxjs/dist/esm5/internal/NotificationFactories.js","/../../node_modules/rxjs/dist/esm5/internal/util/errorContext.js","/../../node_modules/rxjs/dist/esm5/internal/symbol/observable.js","/../../node_modules/rxjs/dist/esm5/internal/util/pipe.js","/../../node_modules/rxjs/dist/esm5/internal/util/identity.js","/../../node_modules/rxjs/dist/esm5/internal/observable/ConnectableObservable.js","/../../node_modules/rxjs/dist/esm5/internal/operators/refCount.js","/../../node_modules/rxjs/dist/esm5/internal/util/lift.js","/../../node_modules/rxjs/dist/esm5/internal/operators/OperatorSubscriber.js","/../../node_modules/rxjs/dist/esm5/internal/observable/dom/animationFrames.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/performanceTimestampProvider.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/animationFrameProvider.js","/../../node_modules/rxjs/dist/esm5/internal/Subject.js","/../../node_modules/rxjs/dist/esm5/internal/util/ObjectUnsubscribedError.js","/../../node_modules/rxjs/dist/esm5/internal/BehaviorSubject.js","/../../node_modules/rxjs/dist/esm5/internal/ReplaySubject.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/dateTimestampProvider.js","/../../node_modules/rxjs/dist/esm5/internal/AsyncSubject.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/asap.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/AsapAction.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/AsyncAction.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/Action.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/intervalProvider.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/immediateProvider.js","/../../node_modules/rxjs/dist/esm5/internal/util/Immediate.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/AsapScheduler.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/AsyncScheduler.js","/../../node_modules/rxjs/dist/esm5/internal/Scheduler.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/async.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/queue.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/QueueAction.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/QueueScheduler.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/animationFrame.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/AnimationFrameAction.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/AnimationFrameScheduler.js","/../../node_modules/rxjs/dist/esm5/internal/scheduler/VirtualTimeScheduler.js","/../../node_modules/rxjs/dist/esm5/internal/Notification.js","/../../node_modules/rxjs/dist/esm5/internal/observable/empty.js","/../../node_modules/rxjs/dist/esm5/internal/observable/of.js","/../../node_modules/rxjs/dist/esm5/internal/util/args.js","/../../node_modules/rxjs/dist/esm5/internal/util/isScheduler.js","/../../node_modules/rxjs/dist/esm5/internal/observable/from.js","/../../node_modules/rxjs/dist/esm5/internal/scheduled/scheduled.js","/../../node_modules/rxjs/dist/esm5/internal/scheduled/scheduleObservable.js","/../../node_modules/rxjs/dist/esm5/internal/observable/innerFrom.js","/../../node_modules/rxjs/dist/esm5/internal/util/isArrayLike.js","/../../node_modules/rxjs/dist/esm5/internal/util/isPromise.js","/../../node_modules/rxjs/dist/esm5/internal/util/isInteropObservable.js","/../../node_modules/rxjs/dist/esm5/internal/util/isAsyncIterable.js","/../../node_modules/rxjs/dist/esm5/internal/util/throwUnobservableError.js","/../../node_modules/rxjs/dist/esm5/internal/util/isIterable.js","/../../node_modules/rxjs/dist/esm5/internal/symbol/iterator.js","/../../node_modules/rxjs/dist/esm5/internal/util/isReadableStreamLike.js","/../../node_modules/rxjs/dist/esm5/internal/operators/observeOn.js","/../../node_modules/rxjs/dist/esm5/internal/util/executeSchedule.js","/../../node_modules/rxjs/dist/esm5/internal/operators/subscribeOn.js","/../../node_modules/rxjs/dist/esm5/internal/scheduled/schedulePromise.js","/../../node_modules/rxjs/dist/esm5/internal/scheduled/scheduleArray.js","/../../node_modules/rxjs/dist/esm5/internal/scheduled/scheduleIterable.js","/../../node_modules/rxjs/dist/esm5/internal/scheduled/scheduleAsyncIterable.js","/../../node_modules/rxjs/dist/esm5/internal/scheduled/scheduleReadableStreamLike.js","/../../node_modules/rxjs/dist/esm5/internal/observable/throwError.js","/../../node_modules/rxjs/dist/esm5/internal/util/isObservable.js","/../../node_modules/rxjs/dist/esm5/internal/lastValueFrom.js","/../../node_modules/rxjs/dist/esm5/internal/util/EmptyError.js","/../../node_modules/rxjs/dist/esm5/internal/firstValueFrom.js","/../../node_modules/rxjs/dist/esm5/internal/util/ArgumentOutOfRangeError.js","/../../node_modules/rxjs/dist/esm5/internal/util/NotFoundError.js","/../../node_modules/rxjs/dist/esm5/internal/util/SequenceError.js","/../../node_modules/rxjs/dist/esm5/internal/operators/timeout.js","/../../node_modules/rxjs/dist/esm5/internal/util/isDate.js","/../../node_modules/rxjs/dist/esm5/internal/observable/bindCallback.js","/../../node_modules/rxjs/dist/esm5/internal/observable/bindCallbackInternals.js","/../../node_modules/rxjs/dist/esm5/internal/util/mapOneOrManyArgs.js","/../../node_modules/rxjs/dist/esm5/internal/operators/map.js","/../../node_modules/rxjs/dist/esm5/internal/observable/bindNodeCallback.js","/../../node_modules/rxjs/dist/esm5/internal/observable/combineLatest.js","/../../node_modules/rxjs/dist/esm5/internal/util/argsArgArrayOrObject.js","/../../node_modules/rxjs/dist/esm5/internal/util/createObject.js","/../../node_modules/rxjs/dist/esm5/internal/observable/concat.js","/../../node_modules/rxjs/dist/esm5/internal/operators/concatAll.js","/../../node_modules/rxjs/dist/esm5/internal/operators/mergeAll.js","/../../node_modules/rxjs/dist/esm5/internal/operators/mergeMap.js","/../../node_modules/rxjs/dist/esm5/internal/operators/mergeInternals.js","/../../node_modules/rxjs/dist/esm5/internal/observable/connectable.js","/../../node_modules/rxjs/dist/esm5/internal/observable/defer.js","/../../node_modules/rxjs/dist/esm5/internal/observable/forkJoin.js","/../../node_modules/rxjs/dist/esm5/internal/observable/fromEvent.js","/../../node_modules/rxjs/dist/esm5/internal/observable/fromEventPattern.js","/../../node_modules/rxjs/dist/esm5/internal/observable/generate.js","/../../node_modules/rxjs/dist/esm5/internal/observable/iif.js","/../../node_modules/rxjs/dist/esm5/internal/observable/interval.js","/../../node_modules/rxjs/dist/esm5/internal/observable/timer.js","/../../node_modules/rxjs/dist/esm5/internal/observable/merge.js","/../../node_modules/rxjs/dist/esm5/internal/observable/never.js","/../../node_modules/rxjs/dist/esm5/internal/observable/onErrorResumeNext.js","/../../node_modules/rxjs/dist/esm5/internal/util/argsOrArgArray.js","/../../node_modules/rxjs/dist/esm5/internal/observable/pairs.js","/../../node_modules/rxjs/dist/esm5/internal/observable/partition.js","/../../node_modules/rxjs/dist/esm5/internal/util/not.js","/../../node_modules/rxjs/dist/esm5/internal/operators/filter.js","/../../node_modules/rxjs/dist/esm5/internal/observable/race.js","/../../node_modules/rxjs/dist/esm5/internal/observable/range.js","/../../node_modules/rxjs/dist/esm5/internal/observable/using.js","/../../node_modules/rxjs/dist/esm5/internal/observable/zip.js","/../../node_modules/rxjs/dist/esm5/internal/types.js","/../../node_modules/rxjs/dist/esm5/internal/operators/audit.js","/../../node_modules/rxjs/dist/esm5/internal/operators/auditTime.js","/../../node_modules/rxjs/dist/esm5/internal/operators/buffer.js","/../../node_modules/rxjs/dist/esm5/internal/operators/bufferCount.js","/../../node_modules/rxjs/dist/esm5/internal/operators/bufferTime.js","/../../node_modules/rxjs/dist/esm5/internal/operators/bufferToggle.js","/../../node_modules/rxjs/dist/esm5/internal/operators/bufferWhen.js","/../../node_modules/rxjs/dist/esm5/internal/operators/catchError.js","/../../node_modules/rxjs/dist/esm5/internal/operators/combineAll.js","/../../node_modules/rxjs/dist/esm5/internal/operators/combineLatestAll.js","/../../node_modules/rxjs/dist/esm5/internal/operators/joinAllInternals.js","/../../node_modules/rxjs/dist/esm5/internal/operators/toArray.js","/../../node_modules/rxjs/dist/esm5/internal/operators/reduce.js","/../../node_modules/rxjs/dist/esm5/internal/operators/scanInternals.js","/../../node_modules/rxjs/dist/esm5/internal/operators/combineLatestWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/combineLatest.js","/../../node_modules/rxjs/dist/esm5/internal/operators/concatMap.js","/../../node_modules/rxjs/dist/esm5/internal/operators/concatMapTo.js","/../../node_modules/rxjs/dist/esm5/internal/operators/concatWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/concat.js","/../../node_modules/rxjs/dist/esm5/internal/operators/connect.js","/../../node_modules/rxjs/dist/esm5/internal/observable/fromSubscribable.js","/../../node_modules/rxjs/dist/esm5/internal/operators/count.js","/../../node_modules/rxjs/dist/esm5/internal/operators/debounce.js","/../../node_modules/rxjs/dist/esm5/internal/operators/debounceTime.js","/../../node_modules/rxjs/dist/esm5/internal/operators/defaultIfEmpty.js","/../../node_modules/rxjs/dist/esm5/internal/operators/delay.js","/../../node_modules/rxjs/dist/esm5/internal/operators/delayWhen.js","/../../node_modules/rxjs/dist/esm5/internal/operators/take.js","/../../node_modules/rxjs/dist/esm5/internal/operators/ignoreElements.js","/../../node_modules/rxjs/dist/esm5/internal/operators/mapTo.js","/../../node_modules/rxjs/dist/esm5/internal/operators/dematerialize.js","/../../node_modules/rxjs/dist/esm5/internal/operators/distinct.js","/../../node_modules/rxjs/dist/esm5/internal/operators/distinctUntilChanged.js","/../../node_modules/rxjs/dist/esm5/internal/operators/distinctUntilKeyChanged.js","/../../node_modules/rxjs/dist/esm5/internal/operators/elementAt.js","/../../node_modules/rxjs/dist/esm5/internal/operators/throwIfEmpty.js","/../../node_modules/rxjs/dist/esm5/internal/operators/endWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/every.js","/../../node_modules/rxjs/dist/esm5/internal/operators/exhaust.js","/../../node_modules/rxjs/dist/esm5/internal/operators/exhaustAll.js","/../../node_modules/rxjs/dist/esm5/internal/operators/exhaustMap.js","/../../node_modules/rxjs/dist/esm5/internal/operators/expand.js","/../../node_modules/rxjs/dist/esm5/internal/operators/finalize.js","/../../node_modules/rxjs/dist/esm5/internal/operators/find.js","/../../node_modules/rxjs/dist/esm5/internal/operators/findIndex.js","/../../node_modules/rxjs/dist/esm5/internal/operators/first.js","/../../node_modules/rxjs/dist/esm5/internal/operators/groupBy.js","/../../node_modules/rxjs/dist/esm5/internal/operators/isEmpty.js","/../../node_modules/rxjs/dist/esm5/internal/operators/last.js","/../../node_modules/rxjs/dist/esm5/internal/operators/takeLast.js","/../../node_modules/rxjs/dist/esm5/internal/operators/materialize.js","/../../node_modules/rxjs/dist/esm5/internal/operators/max.js","/../../node_modules/rxjs/dist/esm5/internal/operators/flatMap.js","/../../node_modules/rxjs/dist/esm5/internal/operators/mergeMapTo.js","/../../node_modules/rxjs/dist/esm5/internal/operators/mergeScan.js","/../../node_modules/rxjs/dist/esm5/internal/operators/mergeWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/merge.js","/../../node_modules/rxjs/dist/esm5/internal/operators/min.js","/../../node_modules/rxjs/dist/esm5/internal/operators/multicast.js","/../../node_modules/rxjs/dist/esm5/internal/operators/onErrorResumeNextWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/pairwise.js","/../../node_modules/rxjs/dist/esm5/internal/operators/pluck.js","/../../node_modules/rxjs/dist/esm5/internal/operators/publish.js","/../../node_modules/rxjs/dist/esm5/internal/operators/publishBehavior.js","/../../node_modules/rxjs/dist/esm5/internal/operators/publishLast.js","/../../node_modules/rxjs/dist/esm5/internal/operators/publishReplay.js","/../../node_modules/rxjs/dist/esm5/internal/operators/raceWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/repeat.js","/../../node_modules/rxjs/dist/esm5/internal/operators/repeatWhen.js","/../../node_modules/rxjs/dist/esm5/internal/operators/retry.js","/../../node_modules/rxjs/dist/esm5/internal/operators/retryWhen.js","/../../node_modules/rxjs/dist/esm5/internal/operators/sample.js","/../../node_modules/rxjs/dist/esm5/internal/operators/sampleTime.js","/../../node_modules/rxjs/dist/esm5/internal/operators/scan.js","/../../node_modules/rxjs/dist/esm5/internal/operators/sequenceEqual.js","/../../node_modules/rxjs/dist/esm5/internal/operators/share.js","/../../node_modules/rxjs/dist/esm5/internal/operators/shareReplay.js","/../../node_modules/rxjs/dist/esm5/internal/operators/single.js","/../../node_modules/rxjs/dist/esm5/internal/operators/skip.js","/../../node_modules/rxjs/dist/esm5/internal/operators/skipLast.js","/../../node_modules/rxjs/dist/esm5/internal/operators/skipUntil.js","/../../node_modules/rxjs/dist/esm5/internal/operators/skipWhile.js","/../../node_modules/rxjs/dist/esm5/internal/operators/startWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/switchAll.js","/../../node_modules/rxjs/dist/esm5/internal/operators/switchMap.js","/../../node_modules/rxjs/dist/esm5/internal/operators/switchMapTo.js","/../../node_modules/rxjs/dist/esm5/internal/operators/switchScan.js","/../../node_modules/rxjs/dist/esm5/internal/operators/takeUntil.js","/../../node_modules/rxjs/dist/esm5/internal/operators/takeWhile.js","/../../node_modules/rxjs/dist/esm5/internal/operators/tap.js","/../../node_modules/rxjs/dist/esm5/internal/operators/throttle.js","/../../node_modules/rxjs/dist/esm5/internal/operators/throttleTime.js","/../../node_modules/rxjs/dist/esm5/internal/operators/timeInterval.js","/../../node_modules/rxjs/dist/esm5/internal/operators/timeoutWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/timestamp.js","/../../node_modules/rxjs/dist/esm5/internal/operators/window.js","/../../node_modules/rxjs/dist/esm5/internal/operators/windowCount.js","/../../node_modules/rxjs/dist/esm5/internal/operators/windowTime.js","/../../node_modules/rxjs/dist/esm5/internal/operators/windowToggle.js","/../../node_modules/rxjs/dist/esm5/internal/operators/windowWhen.js","/../../node_modules/rxjs/dist/esm5/internal/operators/withLatestFrom.js","/../../node_modules/rxjs/dist/esm5/internal/operators/zipAll.js","/../../node_modules/rxjs/dist/esm5/internal/operators/zipWith.js","/../../node_modules/rxjs/dist/esm5/internal/operators/zip.js","/../../node_modules/@livekit/components-react/src/components/controls/SettingsMenuToggle.tsx","/../../node_modules/@livekit/components-react/src/hooks/useSettingsToggle.ts","/../../node_modules/@livekit/components-react/src/context/index.ts","/../../node_modules/@livekit/components-react/src/context/chat-context.ts","/../../node_modules/@livekit/components-react/src/context/layout-context.ts","/../../node_modules/@livekit/components-react/src/context/pin-context.ts","/../../node_modules/@livekit/components-react/src/context/participant-context.ts","/../../node_modules/@livekit/components-react/src/context/track-reference-context.ts","/../../node_modules/@livekit/components-react/src/context/room-context.ts","/../../node_modules/@livekit/components-react/src/context/feature-context.ts","/../../node_modules/@livekit/components-react/src/mergeProps.ts","/../../node_modules/clsx/dist/clsx.mjs","/../../node_modules/@livekit/components-react/src/hooks/internal/index.ts","/../../node_modules/@livekit/components-react/src/hooks/internal/useResizeObserver.ts","/../../node_modules/@livekit/components-react/src/hooks/internal/useObservableState.ts","/../../node_modules/@livekit/components-react/src/hooks/internal/useMediaQuery.ts","/src/common/livekit/components-web/TrackToggleM.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/util.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/index.ts","/../../node_modules/@livekit/components-react/src/assets/icons/CameraDisabledIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/CameraIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/ChatCloseIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/ChatIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/Chevron.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/FocusToggleIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/GearIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/LeaveIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/LockLockedIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/MicDisabledIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/MicIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/QualityExcellentIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/QualityGoodIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/QualityPoorIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/QualityUnknownIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/ScreenShareIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/ScreenShareStopIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/SpinnerIcon.tsx","/../../node_modules/@livekit/components-react/src/assets/icons/UnfocusToggleIcon.tsx","/src/common/livekit/components/LayoutToggleM.tsx","/src/common/livekit/components-web/MuteCurrentUser.tsx","/src/common/livekit/components/InformationBarComponent.js","/src/common/livekit/RoomView.web.js","/src/common/livekit/liveKitUtils.js","/src/common/livekit/components-web/FocusLayoutM.tsx","/src/common/livekit/components-web/ParticipantTileM.tsx","/src/common/video-call/UsernameComponent.js","/src/common/livekit/components-web/FocusLayoutComponent.tsx","/src/common/livekit/components-web/GridLayoutM.tsx","/../../node_modules/@livekit/components-react/src/utils.ts","/src/common/liveMode/liveV3/CallKeepManagerM.web.js","/src/data/redux/actions/liveKitRoom/index.js","/src/common/video-call/CallKeepSetup.web.js","/src/common/liveMode/PreCallScreen.js","/src/common/liveMode/DownloadAppCard.js","/src/tutor/lives/MoveSessionReasonComponent.js","/assets/sounds/maximize_001_low.mp3","/src/common/liveMode/SatisfactionScreen.js","/src/common/liveMode/TodoCheck.js","/src/admin/Analytics.js","/src/admin/SubscriptionSection.js","/src/admin/AnalyticsCard.js","/src/admin/AnalyticsChart.js","/../../node_modules/victory-native/src/index.js","/../../node_modules/victory-core/es/index.js","/../../node_modules/victory-core/es/types/callbacks.js","/../../node_modules/victory-core/es/types/prop-types.js","/../../node_modules/victory-core/es/victory-accessible-group/victory-accessible-group.js","/../../node_modules/victory-core/es/victory-animation/victory-animation.js","/../../node_modules/victory-vendor/d3-ease.js","/../../node_modules/victory-vendor/lib/d3-ease.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/linear.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/quad.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/cubic.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/poly.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/sin.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/exp.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/math.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/circle.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/bounce.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/back.js","/../../node_modules/victory-vendor/lib-vendor/d3-ease/src/elastic.js","/../../node_modules/victory-core/es/victory-animation/util.js","/../../node_modules/lodash/orderBy.js","/../../node_modules/lodash/_baseOrderBy.js","/../../node_modules/lodash/_baseMap.js","/../../node_modules/lodash/_baseEach.js","/../../node_modules/lodash/_createBaseEach.js","/../../node_modules/lodash/_baseSortBy.js","/../../node_modules/lodash/_compareMultiple.js","/../../node_modules/lodash/_compareAscending.js","/../../node_modules/lodash/isPlainObject.js","/../../node_modules/lodash/_getPrototype.js","/../../node_modules/victory-vendor/d3-interpolate.js","/../../node_modules/victory-vendor/lib/d3-interpolate.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/value.js","/../../node_modules/victory-vendor/lib-vendor/d3-color/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-color/src/color.js","/../../node_modules/victory-vendor/lib-vendor/d3-color/src/define.js","/../../node_modules/victory-vendor/lib-vendor/d3-color/src/lab.js","/../../node_modules/victory-vendor/lib-vendor/d3-color/src/math.js","/../../node_modules/victory-vendor/lib-vendor/d3-color/src/cubehelix.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/rgb.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/basis.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/basisClosed.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/color.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/constant.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/array.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/numberArray.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/date.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/number.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/object.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/string.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/discrete.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/hue.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/round.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/transform/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/transform/parse.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/transform/decompose.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/zoom.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/hsl.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/lab.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/hcl.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/cubehelix.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/piecewise.js","/../../node_modules/victory-vendor/lib-vendor/d3-interpolate/src/quantize.js","/../../node_modules/victory-core/es/victory-util/timer-context.js","/../../node_modules/victory-core/es/victory-util/timer.js","/../../node_modules/victory-vendor/d3-timer.js","/../../node_modules/victory-vendor/lib/d3-timer.js","/../../node_modules/victory-vendor/lib-vendor/d3-timer/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-timer/src/timer.js","/../../node_modules/victory-vendor/lib-vendor/d3-timer/src/timeout.js","/../../node_modules/victory-vendor/lib-vendor/d3-timer/src/interval.js","/../../node_modules/victory-core/es/victory-container/victory-container.js","/../../node_modules/lodash/uniqueId.js","/../../node_modules/lodash/defaults.js","/../../node_modules/lodash/_baseRest.js","/../../node_modules/lodash/_overRest.js","/../../node_modules/lodash/_apply.js","/../../node_modules/lodash/_setToString.js","/../../node_modules/lodash/_baseSetToString.js","/../../node_modules/lodash/constant.js","/../../node_modules/lodash/_shortOut.js","/../../node_modules/lodash/_isIterateeCall.js","/../../node_modules/lodash/keysIn.js","/../../node_modules/lodash/_baseKeysIn.js","/../../node_modules/lodash/_nativeKeysIn.js","/../../node_modules/lodash/assign.js","/../../node_modules/lodash/_assignValue.js","/../../node_modules/lodash/_copyObject.js","/../../node_modules/lodash/_createAssigner.js","/../../node_modules/victory-core/es/victory-util/prop-types.js","/../../node_modules/lodash/isRegExp.js","/../../node_modules/lodash/_baseIsRegExp.js","/../../node_modules/lodash/find.js","/../../node_modules/lodash/_createFind.js","/../../node_modules/lodash/findIndex.js","/../../node_modules/lodash/_baseFindIndex.js","/../../node_modules/victory-core/es/victory-util/log.js","/../../node_modules/victory-core/es/victory-util/scale.js","/../../node_modules/lodash/includes.js","/../../node_modules/lodash/_baseIndexOf.js","/../../node_modules/lodash/_baseIsNaN.js","/../../node_modules/lodash/_strictIndexOf.js","/../../node_modules/lodash/isString.js","/../../node_modules/lodash/values.js","/../../node_modules/lodash/_baseValues.js","/../../node_modules/victory-core/es/victory-util/helpers.js","/../../node_modules/lodash/pick.js","/../../node_modules/lodash/_basePick.js","/../../node_modules/lodash/_basePickBy.js","/../../node_modules/lodash/_baseSet.js","/../../node_modules/lodash/_flatRest.js","/../../node_modules/lodash/flatten.js","/../../node_modules/lodash/_baseFlatten.js","/../../node_modules/lodash/_isFlattenable.js","/../../node_modules/victory-core/es/victory-util/collection.js","/../../node_modules/victory-vendor/d3-scale.js","/../../node_modules/victory-vendor/lib/d3-scale.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/band.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/bisect.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/ascending.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/bisector.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/descending.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/number.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/count.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/cross.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/cumsum.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/deviation.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/variance.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/extent.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/fsum.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/group.js","/../../node_modules/victory-vendor/lib-vendor/internmap/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/identity.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/groupSort.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/sort.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/permute.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/bin.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/array.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/constant.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/nice.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/ticks.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/threshold/sturges.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/threshold/freedmanDiaconis.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/quantile.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/max.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/min.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/quickselect.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/threshold/scott.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/maxIndex.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/mean.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/median.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/merge.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/minIndex.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/mode.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/pairs.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/range.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/rank.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/least.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/leastIndex.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/greatest.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/greatestIndex.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/scan.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/shuffle.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/sum.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/transpose.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/zip.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/every.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/some.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/filter.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/map.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/reduce.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/reverse.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/difference.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/disjoint.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/intersection.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/subset.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/superset.js","/../../node_modules/victory-vendor/lib-vendor/d3-array/src/union.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/init.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/ordinal.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/identity.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/linear.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/continuous.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/constant.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/number.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/tickFormat.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/defaultLocale.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/locale.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/exponent.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/formatDecimal.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/formatGroup.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/formatNumerals.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/formatSpecifier.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/formatTrim.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/formatTypes.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/formatPrefixAuto.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/formatRounded.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/identity.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/precisionFixed.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/precisionPrefix.js","/../../node_modules/victory-vendor/lib-vendor/d3-format/src/precisionRound.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/log.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/nice.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/symlog.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/pow.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/radial.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/quantile.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/quantize.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/threshold.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/time.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/interval.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/millisecond.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/second.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/duration.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/minute.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/hour.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/day.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/week.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/month.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/year.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/utcMinute.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/utcHour.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/utcDay.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/utcWeek.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/utcMonth.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/utcYear.js","/../../node_modules/victory-vendor/lib-vendor/d3-time/src/ticks.js","/../../node_modules/victory-vendor/lib-vendor/d3-time-format/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-time-format/src/defaultLocale.js","/../../node_modules/victory-vendor/lib-vendor/d3-time-format/src/locale.js","/../../node_modules/victory-vendor/lib-vendor/d3-time-format/src/isoFormat.js","/../../node_modules/victory-vendor/lib-vendor/d3-time-format/src/isoParse.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/utcTime.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/sequential.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/sequentialQuantile.js","/../../node_modules/victory-vendor/lib-vendor/d3-scale/src/diverging.js","/../../node_modules/victory-core/es/victory-portal/portal.js","/../../node_modules/victory-core/es/victory-portal/portal-context.js","/../../node_modules/victory-core/es/victory-util/user-props.js","/../../node_modules/victory-core/es/victory-label/victory-label.js","/../../node_modules/lodash/isEmpty.js","/../../node_modules/victory-core/es/victory-portal/victory-portal.js","/../../node_modules/victory-core/es/victory-primitives/rect.js","/../../node_modules/victory-core/es/victory-primitives/text.js","/../../node_modules/victory-core/es/victory-primitives/tspan.js","/../../node_modules/victory-core/es/victory-util/label-helpers.js","/../../node_modules/victory-core/es/victory-util/style.js","/../../node_modules/victory-core/es/victory-util/textsize.js","/../../node_modules/victory-core/es/victory-transition/victory-transition.js","/../../node_modules/victory-core/es/victory-util/transitions.js","/../../node_modules/victory-core/es/victory-clip-container/victory-clip-container.js","/../../node_modules/victory-core/es/victory-primitives/clip-path.js","/../../node_modules/victory-core/es/victory-primitives/circle.js","/../../node_modules/victory-core/es/victory-theme/types.js","/../../node_modules/victory-core/es/victory-theme/victory-theme.js","/../../node_modules/victory-core/es/victory-theme/grayscale.js","/../../node_modules/victory-core/es/victory-theme/material.js","/../../node_modules/victory-core/es/victory-primitives/index.js","/../../node_modules/victory-core/es/victory-primitives/arc.js","/../../node_modules/victory-core/es/victory-util/common-props.js","/../../node_modules/victory-core/es/victory-primitives/path.js","/../../node_modules/victory-core/es/victory-primitives/background.js","/../../node_modules/victory-core/es/victory-primitives/border.js","/../../node_modules/victory-core/es/victory-primitives/line.js","/../../node_modules/victory-core/es/victory-primitives/line-segment.js","/../../node_modules/victory-core/es/victory-primitives/point.js","/../../node_modules/victory-core/es/victory-util/point-path-helpers.js","/../../node_modules/lodash/range.js","/../../node_modules/lodash/_createRange.js","/../../node_modules/lodash/_baseRange.js","/../../node_modules/victory-core/es/victory-primitives/types.js","/../../node_modules/victory-core/es/victory-primitives/whisker.js","/../../node_modules/victory-core/es/victory-util/index.js","/../../node_modules/victory-core/es/victory-util/add-events.js","/../../node_modules/lodash/without.js","/../../node_modules/lodash/_baseDifference.js","/../../node_modules/lodash/_arrayIncludes.js","/../../node_modules/lodash/_arrayIncludesWith.js","/../../node_modules/lodash/isArrayLikeObject.js","/../../node_modules/lodash/isNil.js","/../../node_modules/lodash/difference.js","/../../node_modules/victory-core/es/victory-util/events.js","/../../node_modules/lodash/uniq.js","/../../node_modules/lodash/_baseUniq.js","/../../node_modules/lodash/_createSet.js","/../../node_modules/lodash/noop.js","/../../node_modules/lodash/omitBy.js","/../../node_modules/lodash/negate.js","/../../node_modules/lodash/pickBy.js","/../../node_modules/lodash/_getAllKeysIn.js","/../../node_modules/lodash/_getSymbolsIn.js","/../../node_modules/victory-core/es/victory-util/axis.js","/../../node_modules/lodash/invert.js","/../../node_modules/lodash/_createInverter.js","/../../node_modules/lodash/_baseInverter.js","/../../node_modules/victory-core/es/victory-util/domain.js","/../../node_modules/lodash/isDate.js","/../../node_modules/lodash/_baseIsDate.js","/../../node_modules/lodash/sortedUniq.js","/../../node_modules/lodash/_baseSortedUniq.js","/../../node_modules/victory-core/es/victory-util/data.js","/../../node_modules/lodash/isUndefined.js","/../../node_modules/lodash/last.js","/../../node_modules/victory-core/es/victory-util/immutable.js","/../../node_modules/victory-core/es/victory-util/default-transitions.js","/../../node_modules/victory-core/es/victory-util/hooks/index.js","/../../node_modules/victory-core/es/victory-util/hooks/use-previous-props.js","/../../node_modules/victory-core/es/victory-util/hooks/use-animation-state.js","/../../node_modules/lodash/some.js","/../../node_modules/lodash/_baseSome.js","/../../node_modules/victory-core/es/victory-util/line-helpers.js","/../../node_modules/victory-vendor/d3-shape.js","/../../node_modules/victory-vendor/lib/d3-shape.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/arc.js","/../../node_modules/victory-vendor/lib-vendor/d3-path/src/index.js","/../../node_modules/victory-vendor/lib-vendor/d3-path/src/path.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/constant.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/math.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/area.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/array.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/linear.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/line.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/point.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/pie.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/descending.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/identity.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/areaRadial.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/radial.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/lineRadial.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/pointRadial.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/link.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/bump.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/asterisk.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/circle.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/cross.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/diamond.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/diamond2.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/plus.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/square.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/square2.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/star.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/triangle.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/triangle2.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/wye.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/symbol/x.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/basisClosed.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/noop.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/basis.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/basisOpen.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/bundle.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/cardinalClosed.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/cardinal.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/cardinalOpen.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/catmullRomClosed.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/catmullRom.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/catmullRomOpen.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/linearClosed.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/monotone.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/natural.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/curve/step.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/stack.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/offset/none.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/order/none.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/offset/expand.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/offset/diverging.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/offset/silhouette.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/offset/wiggle.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/order/appearance.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/order/ascending.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/order/descending.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/order/insideOut.js","/../../node_modules/victory-vendor/lib-vendor/d3-shape/src/order/reverse.js","/../../node_modules/victory-core/es/victory-util/selection.js","/../../node_modules/victory-core/es/victory-util/wrapper.js","/../../node_modules/lodash/uniqBy.js","/../../node_modules/lodash/groupBy.js","/../../node_modules/lodash/_createAggregator.js","/../../node_modules/lodash/_arrayAggregator.js","/../../node_modules/lodash/_baseAggregator.js","/../../node_modules/victory-shared-events/es/index.js","/../../node_modules/victory-shared-events/es/victory-shared-events.js","/../../node_modules/lodash/fromPairs.js","/../../node_modules/json-stringify-safe/stringify.js","/../../node_modules/victory-native/src/components/victory-primitives/circle.js","/../../node_modules/victory-native/src/helpers/native-helpers.js","/../../node_modules/victory-native/src/components/victory-primitives/line.js","/../../node_modules/victory-native/src/components/victory-primitives/path.js","/../../node_modules/victory-native/src/components/victory-primitives/rect.js","/../../node_modules/victory-native/src/components/victory-primitives/text.js","/../../node_modules/victory-native/src/components/victory-primitives/tspan.js","/../../node_modules/victory-native/src/components/victory-primitives/arc.js","/../../node_modules/victory-native/src/components/victory-primitives/area.js","/../../node_modules/victory-area/es/index.js","/../../node_modules/victory-area/es/victory-area.js","/../../node_modules/victory-area/es/helper-methods.js","/../../node_modules/victory-area/es/area.js","/../../node_modules/victory-native/src/components/victory-primitives/background.js","/../../node_modules/victory-native/src/components/victory-primitives/bar.js","/../../node_modules/victory-bar/es/index.js","/../../node_modules/victory-bar/es/victory-bar.js","/../../node_modules/victory-bar/es/helper-methods.js","/../../node_modules/victory-bar/es/bar.js","/../../node_modules/victory-bar/es/bar-helper-methods.js","/../../node_modules/victory-bar/es/path-helper-methods.js","/../../node_modules/victory-bar/es/geometry-helper-methods.js","/../../node_modules/victory-native/src/components/victory-primitives/border.js","/../../node_modules/victory-native/src/components/victory-primitives/candle.js","/../../node_modules/victory-candlestick/es/index.js","/../../node_modules/victory-candlestick/es/victory-candlestick.js","/../../node_modules/victory-candlestick/es/candle.js","/../../node_modules/victory-candlestick/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-primitives/clip-path.js","/../../node_modules/victory-native/src/components/victory-primitives/curve.js","/../../node_modules/victory-line/es/index.js","/../../node_modules/victory-line/es/victory-line.js","/../../node_modules/victory-line/es/helper-methods.js","/../../node_modules/victory-line/es/curve.js","/../../node_modules/victory-native/src/components/victory-primitives/error-bar.js","/../../node_modules/victory-errorbar/es/index.js","/../../node_modules/victory-errorbar/es/victory-errorbar.js","/../../node_modules/victory-errorbar/es/error-bar.js","/../../node_modules/victory-errorbar/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-primitives/line-segment.js","/../../node_modules/victory-native/src/components/victory-primitives/point.js","/../../node_modules/victory-native/src/components/victory-primitives/slice.js","/../../node_modules/victory-pie/es/index.js","/../../node_modules/victory-pie/es/victory-pie.js","/../../node_modules/victory-pie/es/slice.js","/../../node_modules/victory-pie/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-primitives/voronoi.js","/../../node_modules/victory-voronoi/es/index.js","/../../node_modules/victory-voronoi/es/victory-voronoi.js","/../../node_modules/victory-voronoi/es/voronoi.js","/../../node_modules/victory-voronoi/es/helper-methods.js","/../../node_modules/d3-voronoi/src/index.js","/../../node_modules/d3-voronoi/src/voronoi.js","/../../node_modules/d3-voronoi/src/constant.js","/../../node_modules/d3-voronoi/src/point.js","/../../node_modules/d3-voronoi/src/Diagram.js","/../../node_modules/d3-voronoi/src/Beach.js","/../../node_modules/d3-voronoi/src/RedBlackTree.js","/../../node_modules/d3-voronoi/src/Cell.js","/../../node_modules/d3-voronoi/src/Edge.js","/../../node_modules/d3-voronoi/src/Circle.js","/../../node_modules/victory-native/src/components/victory-primitives/flyout.js","/../../node_modules/victory-tooltip/es/index.js","/../../node_modules/victory-tooltip/es/victory-tooltip.js","/../../node_modules/victory-tooltip/es/flyout.js","/../../node_modules/victory-native/src/components/victory-primitives/whisker.js","/../../node_modules/victory-native/src/components/victory-tooltip.js","/../../node_modules/victory-native/src/components/victory-label.js","/../../node_modules/victory-native/src/components/victory-portal/victory-portal.js","/../../node_modules/victory-native/src/components/victory-portal/portal.js","/../../node_modules/victory-native/src/components/victory-area.js","/../../node_modules/victory-native/src/components/victory-container.js","/../../node_modules/victory-native/src/components/victory-clip-container.js","/../../node_modules/victory-native/src/helpers/wrap-core-component.js","/../../node_modules/victory-native/src/components/victory-axis.js","/../../node_modules/victory-axis/es/index.js","/../../node_modules/victory-axis/es/victory-axis.js","/../../node_modules/victory-axis/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-polar-axis.js","/../../node_modules/victory-polar-axis/es/index.js","/../../node_modules/victory-polar-axis/es/victory-polar-axis.js","/../../node_modules/victory-polar-axis/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-bar.js","/../../node_modules/victory-native/src/components/victory-brush-line.js","/../../node_modules/victory-brush-line/es/index.js","/../../node_modules/victory-brush-line/es/victory-brush-line.js","/../../node_modules/victory-native/src/components/victory-boxplot.js","/../../node_modules/victory-box-plot/es/index.js","/../../node_modules/victory-box-plot/es/victory-box-plot.js","/../../node_modules/victory-box-plot/es/helper-methods.js","/../../node_modules/lodash/isNaN.js","/../../node_modules/lodash/isNumber.js","/../../node_modules/victory-vendor/d3-array.js","/../../node_modules/victory-vendor/lib/d3-array.js","/../../node_modules/victory-native/src/components/victory-group.js","/../../node_modules/victory-group/es/index.js","/../../node_modules/victory-group/es/victory-group.js","/../../node_modules/victory-group/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-line.js","/../../node_modules/victory-native/src/components/victory-histogram.js","/../../node_modules/victory-histogram/es/index.js","/../../node_modules/victory-histogram/es/victory-histogram.js","/../../node_modules/victory-histogram/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-scatter.js","/../../node_modules/victory-scatter/es/index.js","/../../node_modules/victory-scatter/es/victory-scatter.js","/../../node_modules/victory-scatter/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-stack.js","/../../node_modules/victory-stack/es/index.js","/../../node_modules/victory-stack/es/victory-stack.js","/../../node_modules/victory-stack/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-chart.js","/../../node_modules/victory-chart/es/index.js","/../../node_modules/victory-chart/es/victory-chart.js","/../../node_modules/victory-chart/es/helper-methods.js","/../../node_modules/victory-native/src/components/victory-errorbar.js","/../../node_modules/victory-native/src/components/victory-candlestick.js","/../../node_modules/victory-native/src/components/victory-voronoi.js","/../../node_modules/victory-native/src/components/victory-pie.js","/../../node_modules/victory-native/src/components/victory-legend.js","/../../node_modules/victory-legend/es/index.js","/../../node_modules/victory-legend/es/victory-legend.js","/../../node_modules/victory-legend/es/helper-methods.js","/../../node_modules/lodash/sum.js","/../../node_modules/lodash/_baseSum.js","/../../node_modules/victory-native/src/helpers/native-zoom-helpers.js","/../../node_modules/victory-zoom-container/es/index.js","/../../node_modules/victory-zoom-container/es/victory-zoom-container.js","/../../node_modules/victory-zoom-container/es/zoom-helpers.js","/../../node_modules/lodash/delay.js","/../../node_modules/lodash/_baseDelay.js","/../../node_modules/lodash/throttle.js","/../../node_modules/lodash/debounce.js","/../../node_modules/lodash/now.js","/../../node_modules/victory-native/src/components/victory-zoom-container.js","/../../node_modules/victory-native/src/components/victory-voronoi-container.js","/../../node_modules/victory-voronoi-container/es/index.js","/../../node_modules/victory-voronoi-container/es/victory-voronoi-container.js","/../../node_modules/victory-voronoi-container/es/voronoi-helpers.js","/../../node_modules/delaunay-find/lib/index.js","/../../node_modules/delaunator/delaunator.js","/../../node_modules/victory-native/src/components/victory-selection-container.js","/../../node_modules/victory-selection-container/es/index.js","/../../node_modules/victory-selection-container/es/victory-selection-container.js","/../../node_modules/victory-selection-container/es/selection-helpers.js","/../../node_modules/victory-native/src/components/victory-cursor-container.js","/../../node_modules/victory-cursor-container/es/index.js","/../../node_modules/victory-cursor-container/es/cursor-helpers.js","/../../node_modules/victory-cursor-container/es/victory-cursor-container.js","/../../node_modules/victory-native/src/components/victory-brush-container.js","/../../node_modules/victory-brush-container/es/index.js","/../../node_modules/victory-brush-container/es/victory-brush-container.js","/../../node_modules/victory-brush-container/es/brush-helpers.js","/../../node_modules/victory-native/src/helpers/create-container.js","/../../node_modules/victory-create-container/es/index.js","/../../node_modules/victory-create-container/es/create-container.js","/../../node_modules/lodash/flow.js","/../../node_modules/lodash/_createFlow.js","/../../node_modules/lodash/_LodashWrapper.js","/../../node_modules/lodash/_baseCreate.js","/../../node_modules/lodash/_baseLodash.js","/../../node_modules/lodash/_getData.js","/../../node_modules/lodash/_metaMap.js","/../../node_modules/lodash/_getFuncName.js","/../../node_modules/lodash/_realNames.js","/../../node_modules/lodash/_isLaziable.js","/../../node_modules/lodash/_LazyWrapper.js","/../../node_modules/lodash/wrapperLodash.js","/../../node_modules/lodash/_wrapperClone.js","/../../node_modules/lodash/_copyArray.js","/../../node_modules/lodash/forOwn.js","/../../node_modules/lodash/toPairs.js","/../../node_modules/lodash/_createToPairs.js","/../../node_modules/lodash/_baseToPairs.js","/../../node_modules/lodash/_setToPairs.js","/src/admin/ActivitiesSection.js","/src/admin/GlobalStatsSection.js","/src/tutor/home/interview/InterviewStatisticsCard.js","/assets/icons/generic/calendar-days.png","/assets/icons/stars/sparkle_filled.png","/assets/icons/menus/target.png","/src/tutor/home/dashboard/ActivityDaysSinceLastWeek.js","/src/tutor/home/dashboard/BarChartWeekSinceTwoWeeksAgo.js","/src/admin/applications/TutorApplicationDetailsScreen.js","/src/admin/applications/EvaluationScreen.js","/src/admin/applications/RemunerationModal.js","/src/admin/applications/AssignTutorModal.js","/src/admin/applications/ApplicationScreen.js","/src/student/social/ProfileInfo.js","/src/admin/applications/TutorsApplicationsTabNavigator.js","/../../node_modules/react-native-paper-tabs/lib/module/index.js","/../../node_modules/react-native-paper-tabs/lib/module/Tabs.js","/../../node_modules/react-native-paper-tabs/lib/module/Swiper.js","/../../node_modules/react-native-paper-tabs/lib/module/context.js","/../../node_modules/react-native-paper-tabs/lib/module/TabsHeader.js","/../../node_modules/react-native-paper-tabs/lib/module/internal.js","/../../node_modules/react-native-paper-tabs/lib/module/TabsHeaderItem.js","/../../node_modules/react-native-paper-tabs/lib/module/MaterialCommunityIcon.js","/../../node_modules/react-native-paper-tabs/lib/module/TabScreen.js","/../../node_modules/react-native-paper-tabs/lib/module/TabsProvider.js","/src/admin/applications/TutorsApplicationsScreen.js","/src/admin/UsersTable.js","/src/admin/AssignTutorAndLives.js","/src/student/social/RankingScreen.js","/src/admin/PaginatedTableM.js","/src/common/components/dataTable/DataTableTitleM.js","/../../node_modules/react-native-paper/src/core/theming.tsx","/../../node_modules/react-native-paper/src/styles/themes/index.ts","/../../node_modules/react-native-paper/src/styles/themes/v3/LightTheme.tsx","/../../node_modules/react-native-paper/src/styles/themes/v3/tokens.tsx","/../../node_modules/react-native-paper/src/styles/fonts.tsx","/../../node_modules/react-native-paper/src/styles/themes/v3/DarkTheme.tsx","/../../node_modules/react-native-paper/src/styles/themes/v2/LightTheme.tsx","/../../node_modules/react-native-paper/src/styles/themes/v2/colors.tsx","/../../node_modules/react-native-paper/src/styles/themes/v2/DarkTheme.tsx","/../../node_modules/react-native-paper/src/components/Icon.tsx","/../../node_modules/react-native-paper/src/components/MaterialCommunityIcon.tsx","/../../node_modules/react-native-paper/src/core/settings.tsx","/src/common/components/dataTable/DataTableCellM.js","/src/admin/live/LiveReportsScreen.js","/src/common/components/statistics/StatisticsItem.js","/src/admin/CancelSubscriptionModal.js","/src/admin/AssignTutor.js","/src/admin/ChangePrivileges.js","/src/admin/interviewReports/NewInterviewReportScreen.js","/src/data/constants/slotTutorConstants.js","/src/admin/interviewReports/SchoolResultsStep.js","/src/admin/interviewReports/AddResultsComponent.js","/src/common/components/modal/DatePickerModalM.js","/src/admin/interviewReports/StatisticsStep.js","/assets/icons/generic/refresh.png","/src/admin/live/AcceptSubstitution.js","/src/admin/live/AddUsersToLiveStepper.js","/src/admin/live/AddUserToLive.js","/src/admin/live/SelectTemporaryOrPermenant.js","/src/admin/live/live-history/LivesHistoryScreen.js","/src/admin/live/live-history/EditBillingModal.js","/src/common/components/livesHistory/LivesHistory.js","/src/common/components/livesHistory/ChangeStatusModal.js","/src/common/components/livesHistory/EditBillingModal.js","/src/admin/live/LiveShow.js","/src/admin/live/NextOccurencesScreen.js","/src/admin/live/StudentsListStringForOccurrence.js","/src/admin/live/TutorsListStringForOccurrence.js","/src/admin/live/LivesScreen.js","/src/tutor/home/interview/TutorInterviewCard.js","/src/admin/live/LiveStepper.js","/src/admin/live/RescheduleLive.js","/src/admin/live/rooms/AddUsersToSessions.js","/src/admin/live/rooms/CreateEditRoom.js","/src/admin/live/rooms/NewSessions.js","/src/admin/live/rooms/SelectSlotsStep.js","/src/admin/live/rooms/RoomsScreen.js","/src/admin/trials/TrialStudentsListScreen.js","/src/admin/live/rooms/RoomSessionsModal.js","/src/admin/metrics/MetricsTabNavigator.js","/src/admin/metrics/MetricsFilter.js","/src/admin/metrics/GrowthTabScreen.js","/src/admin/metrics/StatsCardItem.js","/src/admin/metrics/TutorsStatsTabScreen.js","/src/admin/metrics/TutorsStatsCardItem.js","/src/admin/metrics/EngagementTabScreen.js","/src/admin/metrics/QualityTabScreen.js","/src/admin/NewSubscriptionScreen.js","/src/student/account/onboarding/RegisterTrialSessionScreen.js","/../../node_modules/@sesamsolutions/phone-input/dist/index.js","/../../node_modules/@sesamsolutions/phone-input/dist/PhoneInput.js","/../../node_modules/@sesamsolutions/phone-input/dist/CountryFlag.js","/../../node_modules/@sesamsolutions/phone-input/dist/CountryPicker.js","/../../node_modules/@sesamsolutions/phone-input/dist/assets/dialCodes.ts","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/US.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/RU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/EG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ZA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NL.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/FR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ES.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/HU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/IT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/RO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GB.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/JE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/IM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/DK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PL.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/DE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MX.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CL.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/VE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ID.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/JP.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/VN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/IN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AF.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/IR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/DZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ML.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BF.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BJ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SL.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TD.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CF.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CV.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ST.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GQ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CD.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SC.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SD.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/RW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ET.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/DJ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/UG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ZM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/RE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/YT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TF.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ZW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ER.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/FO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GL.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/IE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/IS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AL.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/FI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LV.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/EE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MD.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AD.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MC.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/VA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/UA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/RS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/ME.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/XK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/HR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/FK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SV.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/HN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/HT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GP.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/EC.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GF.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MQ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/UY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TL.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NF.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AQ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NR.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SB.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/VU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/FJ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/WF.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/CK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/WS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NC.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TV.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PF.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/FM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/EH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KP.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/HK.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BD.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MV.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LB.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/JO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/IQ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KW.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/SA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/YE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/OM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/IL.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BH.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/QA.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/NP.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TJ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GE.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/UZ.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BB.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/VG.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/VI.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KY.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/BM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GD.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TC.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/MP.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/GU.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/AS.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/LC.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/DM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/VC.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/DO.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/TT.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/KN.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/JM.png","/../../node_modules/@sesamsolutions/phone-input/dist/assets/flags/PR.png","/../../node_modules/@sesamsolutions/phone-input/dist/utils/index.js","/../../node_modules/google-libphonenumber/dist/libphonenumber.js","/src/common/messenger/RegisterTrialPopup.js","/src/common/messenger/ReminderDialogComponent.js","/assets/avatar/default/student.png","/assets/avatar/default/parent.png","/src/tutor/home/TutorSlotsPicker.js","/src/tutor/application/personalInfos/ApplicationPersonalInfos.js","/src/admin/components/SubscriptionEmailPreview.js","/src/admin/NewWeeklyReportScreen.js","/src/admin/ReferralCodeScreen.js","/src/admin/ReferralCodeItemsContainer.js","/src/common/components/statistics/StatisticsItemCol.js","/assets/icons/generic/click.png","/assets/icons/generic/edit.png","/assets/icons/generic/money.png","/src/admin/referrals/CreateEditReferralCode.js","/src/admin/SendWeeklyReportScreen.js","/src/common/components/toggleIconButton/index.js","/src/admin/studyPrograms/CreateEditStudyProgram.js","/src/common/studyPrograms/StudyProgramItemsStep.js","/src/common/studyPrograms/StudyProgramItemsList.js","/src/common/studyPrograms/SelectChapterComponent.js","/src/common/chapters/SelectChapterScreen.js","/src/common/chapters/NewChapterModal.js","/assets/icons/menus/graduate.png","/src/common/chapters/ChapterItemArchive.js","/src/common/chapters/StudyProgramsFilterList.js","/src/common/studyPrograms/StudyProgramItemComponent.js","/src/common/screens/PaginatedFlatListNoNavigation.js","/src/admin/trials/AssignStudentTrial.js","/src/admin/trials/StudentsTrialTabScreen.js","/src/admin/trials/TrialSlotsScreen.js","/src/admin/tutors/AssignAdmin.js","/src/admin/tutors/FixSalaryScreen.js","/src/admin/tutors/TutorsScreen.js","/src/admin/tutors/UpdateMaxStudentsPerLive.js","/src/admin/UsersTabScreen.js","/src/admin/AdminActionsScreen.js","/src/student/tutoring/MyCoachTabScreen.js","/src/admin/ExportModal.js","/src/auth/AccountTypeScreen.js","/assets/avatar/default/tutor.png","/src/auth/AuthNavigator.js","/assets/screens/app_screen.png","/assets/screens/live_screen_.png","/assets/screens/cycle_screen.png","/assets/screens/quests_screen.png","/src/student/account/IntroScreen.js","/../../node_modules/react-native-onboarding-swiper/src/index.js","/../../node_modules/tinycolor2/cjs/tinycolor.js","/../../node_modules/react-native-onboarding-swiper/src/Page.js","/../../node_modules/react-native-onboarding-swiper/src/Pagination.js","/../../node_modules/react-native-onboarding-swiper/src/Dots.js","/../../node_modules/react-native-onboarding-swiper/src/Dot.js","/../../node_modules/react-native-onboarding-swiper/src/buttons/SkipButton.js","/../../node_modules/react-native-onboarding-swiper/src/buttons/TextButton.js","/../../node_modules/react-native-onboarding-swiper/src/buttons/util.js","/../../node_modules/react-native-onboarding-swiper/src/buttons/NextButton.js","/../../node_modules/react-native-onboarding-swiper/src/buttons/DoneButton.js","/../../node_modules/react-native-onboarding-swiper/src/buttons/SymbolButton.js","/assets/screens/chrono_screen.png","/assets/screens/coach_screen.png","/assets/screens/gestures_screen.png","/assets/screens/scoring_screen.png","/src/common/animations/ExpandingDot.tsx","/src/auth/AvailabilitySlotsScreen.js","/src/auth/EmailVerifyScreen.js","/src/auth/ForgotPassword.js","/src/auth/LoginScreen.js","/src/auth/PrioritizedSchoolSubjectsScreen.js","/src/auth/RegisterNewScreen.js","/src/auth/RegisterReturnScreen.js","/src/common/account/LogoutButton.js","/src/auth/RegisterScreen.js","/assets/icons/reasons/graduate.png","/assets/icons/reasons/star.png","/assets/icons/reasons/method.png","/assets/icons/reasons/study.png","/assets/icons/reasons/move_ahead.png","/assets/icons/reasons/offline_mode.png","/assets/icons/reasons/organize.png","/assets/icons/reasons/other.png","/assets/icons/reasons/grade.png","/src/common/account/SponsorshipConfirmation.js","/src/auth/ResetPasswordScreen.js","/src/auth/SubscribeRedirectScreen.js","/src/auth/SubscribeReturnScreen.js","/src/auth/TutorRegisterScreen.js","/src/quiz/ConfirmQuizzScreen.js","/src/quiz/NewQuizzScreen.js","/src/quiz/QuizzStepSuccessBottomSheet.js","/assets/sounds/next-step.wav","/assets/sounds/error_004.mp3","/src/reviewer/ActivityReviewScreen.js","/src/student/activity/read/ActivityTemplateHeader.js","/src/student/activity/read/ActivityGem.js","/src/reviewer/ActivityReviewSection.js","/src/reviewer/RejectActivity.js","/src/reviewer/SamAppreciationGenerator.js","/src/reviewer/ValidateActivity.js","/src/reviewer/ScoringCriterion.js","/src/reviewer/ActivityJsonDetails.web.js","/../../node_modules/react-json-formatter/dist/index.js","/src/reviewer/NewScoringCommentScreen.js","/src/reviewer/NewScoringRuleScreen.js","/src/school-card-report/scan/ScanLoadingScreen.js","/src/school-card-report/scan/ScanScreen.js","/../../node_modules/expo-document-picker/build/index.js","/../../node_modules/expo-document-picker/build/ExpoDocumentPicker.web.js","/../../node_modules/expo-document-picker/build/types.js","/src/student/account/onboarding/CGUText.js","/src/school/Schools.js","/src/school/SchoolCard.js","/src/school/SchoolScreen.js","/assets/icons/generic/star-rating.png","/src/student/absence/AbsenceFormComponent.js","/src/student/absence/RecoverLiveSessionComponent.js","/src/student/absence/CancelAbsenceFormComponent.js","/src/student/absence/RecoverFormComponent.js","/src/student/account/classroom/JoinClassroomScreen.js","/src/student/account/classroom/JoinSchoolScreen.js","/src/student/account/classroom/UpdateClassScreen.js","/src/student/account/CreateAvatarScreen.js","/src/common/avatar/index.js","/src/common/avatar/personas-avatar.tsx","/src/common/avatar/components/body.tsx","/assets/avatar/avatarParts/peau/peau1.png","/assets/avatar/avatarParts/peau/peau2.png","/assets/avatar/avatarParts/peau/peau3.png","/assets/avatar/avatarParts/peau/peau4.png","/assets/avatar/avatarParts/peau/peau5.png","/src/common/avatar/components/eyes.tsx","/assets/avatar/avatarParts/yeaux/yeaux1bleu.png","/assets/avatar/avatarParts/yeaux/yeaux1marron.png","/assets/avatar/avatarParts/yeaux/yeaux1rose.png","/assets/avatar/avatarParts/yeaux/yeaux1vert.png","/assets/avatar/avatarParts/yeaux/yeaux1violet.png","/assets/avatar/avatarParts/yeaux/yeaux2bleu.png","/assets/avatar/avatarParts/yeaux/yeaux2marron.png","/assets/avatar/avatarParts/yeaux/yeaux2rose.png","/assets/avatar/avatarParts/yeaux/yeaux2vert.png","/assets/avatar/avatarParts/yeaux/yeaux2violet.png","/assets/avatar/avatarParts/yeaux/yeaux3bleu.png","/assets/avatar/avatarParts/yeaux/yeaux3marron.png","/assets/avatar/avatarParts/yeaux/yeaux3rose.png","/assets/avatar/avatarParts/yeaux/yeaux3vert.png","/assets/avatar/avatarParts/yeaux/yeaux3violet.png","/assets/avatar/avatarParts/yeaux/yeaux4bleu.png","/assets/avatar/avatarParts/yeaux/yeaux4marron.png","/assets/avatar/avatarParts/yeaux/yeaux4rose.png","/assets/avatar/avatarParts/yeaux/yeaux4vert.png","/assets/avatar/avatarParts/yeaux/yeaux4violet.png","/assets/avatar/avatarParts/yeaux/sharingan.png","/assets/avatar/avatarParts/yeaux/sharinganRennengan.png","/assets/avatar/avatarParts/yeaux/rennengan.png","/src/common/avatar/components/hair.tsx","/assets/avatar/avatarParts/cheveux/chev1blanc.png","/assets/avatar/avatarParts/cheveux/chev1blond.png","/assets/avatar/avatarParts/cheveux/chev1marron.png","/assets/avatar/avatarParts/cheveux/chev1roux.png","/assets/avatar/avatarParts/cheveux/chev2blanc.png","/assets/avatar/avatarParts/cheveux/chev2blond.png","/assets/avatar/avatarParts/cheveux/chev2marron.png","/assets/avatar/avatarParts/cheveux/chev2roux.png","/assets/avatar/avatarParts/cheveux/chev3blanc.png","/assets/avatar/avatarParts/cheveux/chev3blond.png","/assets/avatar/avatarParts/cheveux/chev3marron.png","/assets/avatar/avatarParts/cheveux/chev3roux.png","/assets/avatar/avatarParts/cheveux/chev4blanc.png","/assets/avatar/avatarParts/cheveux/chev5blanc.png","/assets/avatar/avatarParts/cheveux/chev6blanc.png","/assets/avatar/avatarParts/cheveux/chev7blanc.png","/assets/avatar/avatarParts/cheveux/chev8blanc.png","/assets/avatar/avatarParts/cheveux/chev5blond.png","/assets/avatar/avatarParts/cheveux/chev6blond.png","/assets/avatar/avatarParts/cheveux/chev7blond.png","/assets/avatar/avatarParts/cheveux/chev8blond.png","/assets/avatar/avatarParts/cheveux/chev4blond.png","/assets/avatar/avatarParts/cheveux/chev4marron.png","/assets/avatar/avatarParts/cheveux/chev5marron.png","/assets/avatar/avatarParts/cheveux/chev6marron.png","/assets/avatar/avatarParts/cheveux/chev7marron.png","/assets/avatar/avatarParts/cheveux/chev8marron.png","/assets/avatar/avatarParts/cheveux/chev4roux.png","/assets/avatar/avatarParts/cheveux/chev5roux.png","/assets/avatar/avatarParts/cheveux/chev6roux.png","/assets/avatar/avatarParts/cheveux/chev7roux.png","/assets/avatar/avatarParts/cheveux/chev8roux.png","/assets/avatar/avatarParts/cheveux/chev1noir.png","/assets/avatar/avatarParts/cheveux/chev2noir.png","/assets/avatar/avatarParts/cheveux/chev3noir.png","/assets/avatar/avatarParts/cheveux/chev4noir.png","/assets/avatar/avatarParts/cheveux/chev5noir.png","/assets/avatar/avatarParts/cheveux/chev6noir.png","/assets/avatar/avatarParts/cheveux/chev7noir.png","/assets/avatar/avatarParts/cheveux/chev8noir.png","/src/common/avatar/components/shirt.tsx","/assets/avatar/avatarParts/tshirt/tshirt1.png","/assets/avatar/avatarParts/tshirt/tshirt-beige.png","/assets/avatar/avatarParts/tshirt/tshirt-blanc.png","/assets/avatar/avatarParts/tshirt/tshirt-cyan.png","/assets/avatar/avatarParts/tshirt/tshirt-gris.png","/assets/avatar/avatarParts/tshirt/tshirt-jaune.png","/assets/avatar/avatarParts/tshirt/tshirt-noir.png","/assets/avatar/avatarParts/tshirt/tshirt-violet.png","/assets/avatar/avatarParts/tshirt/Tshirt2.png","/assets/avatar/avatarParts/tshirt/tshirt3.png","/assets/avatar/avatarParts/tshirt/tshirtBleu.png","/assets/avatar/avatarParts/tshirt/tshirtRose.png","/assets/avatar/avatarParts/tshirt/tshirtVert.png","/assets/avatar/avatarParts/chemise/chemiseFilleBlanche.png","/assets/avatar/avatarParts/chemise/chemiseFilleBleu.png","/assets/avatar/avatarParts/chemise/chemiseFilleRose.png","/assets/avatar/avatarParts/pull/pullFilleBeige.png","/assets/avatar/avatarParts/pull/pullFilleBlanc.png","/assets/avatar/avatarParts/pull/pullFilleGris.png","/assets/avatar/avatarParts/robe/robeBlanche.png","/assets/avatar/avatarParts/robe/robeNoire.png","/assets/avatar/avatarParts/robe/robeRouge.png","/src/common/avatar/constants/background.ts","/src/common/avatar/constants/facial-hair.ts","/src/common/avatar/constants/hair.ts","/src/common/avatar/constants/body.ts","/src/common/avatar/constants/skin.ts","/src/common/avatar/utils.ts","/src/common/avatar/constants/eyes.ts","/src/common/avatar/constants/tshirt.ts","/src/common/avatar/constants/nose.ts","/src/common/avatar/components/jacket.tsx","/assets/avatar/avatarParts/veste/veste1.png","/assets/avatar/avatarParts/veste/veste2.png","/assets/avatar/avatarParts/veste/vesteTeddy1.png","/assets/avatar/avatarParts/veste/vesteTeddy2.png","/assets/avatar/avatarParts/veste/vesteTeddy3.png","/src/common/avatar/constants/jacket.ts","/../../node_modules/react-native-view-shot/src/index.js","/../../node_modules/react-native-view-shot/src/RNViewShot.web.js","/../../node_modules/html2canvas/dist/html2canvas.js","/src/common/components/button/CustomButton.js","/src/common/avatar/CustomizationComponents/CustomizeColors.js","/src/common/avatar/CustomizationComponents/CustomizeShapes.js","/src/common/avatar/components/facial-hair.tsx","/src/common/avatar/components/nose.tsx","/assets/icons/generic/jacket.png","/assets/icons/generic/hair.png","/src/student/account/DeleteAccountScreen.js","/src/student/account/MyAccountScreen.js","/src/student/account/profile/CompleteProfileCard.js","/src/student/progress/ActivitiesStatistics.js","/src/common/components/statistics/StatisticsList.js","/assets/icons/menus/ranking.png","/assets/icons/generic/xp_square.png","/src/student/account/ChooseTitleModal.js","/src/common/account/ValidateEmailActionCard.js","/src/student/account/StripeExpressDashboardButton.js","/src/student/account/onboarding/preparation-form/TrialSessionPreparationForm.js","/src/student/account/onboarding/preparation-form/HomeWorkAssistance.js","/src/student/organize/school-subjects/SchoolSubjectModal.js","/src/student/account/onboarding/preparation-form/SubjectSupport.js","/src/student/account/onboarding/preparation-form/StartingFormHeader.js","/src/student/account/onboarding/RegisterSpecialScreen.js","/src/student/account/onboarding/RegisterTrialScreen.js","/src/student/account/onboarding/RegisterWorkshopScreen.js","/src/student/account/onboarding/SchoolSubjectForm.js","/src/common/components/select/SchoolSubjectSelect.js","/src/student/account/onboarding/StudentEvaluationForm.js","/src/student/account/SettingsTabNavigator.js","/src/student/account/SettingsGeneralScreen.js","/src/student/account/SettingsProfileScreen.js","/src/student/account/SettingsConfigurationScreen.js","/../../node_modules/react-native-modal-datetime-picker/src/index.js","/../../node_modules/react-native-modal-datetime-picker/src/DateTimePickerModal.js","/src/common/account/NotificationSettingsItem.js","/src/student/account/SponsorshipScreen.js","/src/student/account/UpdatePasswordScreen.js","/src/student/activity/AllActivities.js","/src/student/organize/list/ActivityButton.js","/src/student/organize/list/ActivityButtonContent.js","/src/student/activity/execute/ActivityScreen.js","/src/student/activity/execute/TimerActivityStep.js","/../../node_modules/expo-network/build/Network.js","/../../node_modules/expo-network/build/ExpoNetwork.web.js","/../../node_modules/expo-network/build/Network.types.js","/src/student/activity/one-step/OneStepActivityHeader.js","/assets/sounds/game-start-cut.mp3","/assets/animations/Countdown.json","/src/student/activity/one-step/MyWorkModal.js","/src/student/activity/execute/AudioVideoActivityStep.js","/src/student/activity/read/ActivityPresentationScreen.js","/src/student/activity/execute/StepNumAndIcon.js","/src/student/activity/read/ActivityResultScreen.js","/src/student/activity/read/SingleActivityResult.js","/src/student/activity/todo/NewTodoScreen.js","/src/student/material/MaterialPicker.js","/../../node_modules/@flyerhq/react-native-link-preview/lib/index.js","/../../node_modules/@flyerhq/react-native-link-preview/lib/LinkPreview.js","/../../node_modules/@flyerhq/react-native-link-preview/lib/utils.js","/../../node_modules/@flyerhq/react-native-link-preview/lib/types.js","/src/common/components/pdf/documentPicker.js","/src/student/material/MaterialImage.js","/src/student/material/MaterialItemComponent.js","/src/student/material/MaterialPdf.js","/src/student/activity/todo/TodoListByChapterScreen.js","/src/student/champions/ChampionIntroScreen.js","/src/student/champions/ZoeIntroScreen.js","/src/student/league/LeagueHistoryScreen.js","/assets/leagues/silver.png","/assets/leagues/bronze.png","/src/student/league/LeagueProgressScreen.js","/src/student/material/ManageMaterialScreen.js","/src/student/material/MaterialDetails.js","/src/student/organize/challenges/ChallengeHistoryScreen.js","/src/student/organize/challenges/ChallengesListItem.js","/src/student/organize/challenges/ChallengePlanningScroll.js","/src/student/organize/challenges/ChallengeTimeline.js","/src/student/organize/list/ActivityPlannedButton.js","/src/student/organize/list/ActivityPlannedButtonContent.js","/src/student/organize/challenges/NewChallengeScreen.js","/src/student/organize/StudentTabsNavigator.js","/src/common/header/StudentMainMenuHeader.js","/../../node_modules/rn-tourguide/lib/index.js","/../../node_modules/rn-tourguide/lib/components/TourGuideZone.js","/../../node_modules/rn-tourguide/lib/components/Step.js","/../../node_modules/rn-tourguide/lib/components/ConnectedStep.js","/../../node_modules/rn-tourguide/lib/components/TourGuideContext.js","/../../node_modules/rn-tourguide/lib/components/Wrapper.js","/../../node_modules/rn-tourguide/lib/components/TourGuideProvider.js","/../../node_modules/mitt/dist/mitt.es.js","/../../node_modules/rn-tourguide/lib/hooks/useIsMounted.js","/../../node_modules/rn-tourguide/lib/utilities.js","/../../node_modules/flubber/build/flubber.min.js","/../../node_modules/lodash.clamp/index.js","/../../node_modules/rn-tourguide/node_modules/memoize-one/dist/memoize-one.esm.js","/../../node_modules/rn-tourguide/lib/components/Modal.js","/../../node_modules/rn-tourguide/lib/components/style.js","/../../node_modules/rn-tourguide/lib/components/SvgMask.js","/../../node_modules/rn-tourguide/lib/components/AnimatedPath.web.js","/../../node_modules/rn-tourguide/lib/components/Tooltip.js","/../../node_modules/rn-tourguide/lib/components/Button.js","/../../node_modules/rn-tourguide/lib/components/TourGuideZoneByPosition.js","/../../node_modules/rn-tourguide/lib/hooks/useTourGuideController.js","/../../node_modules/rn-tourguide/lib/types.js","/src/student/progress/my progress/MyProgressScreen.js","/src/student/progress/my progress/SkillSetHeader.js","/src/student/shop/MyPetalsTabScreen.js","/src/student/shop/ShopProductListItem.js","/src/student/shop/ShopProductItemDetails.js","/src/student/social/ProfilFriendScreen.js","/src/student/account/MesStatistiques.js","/src/student/social/ShareStatsScreen.web.js","/src/teacher/classrooms/ClassroomNewChallenge.js","/src/teacher/classrooms/Classrooms.js","/src/teacher/classrooms/ClassroomCard.js","/src/teacher/classrooms/ClassroomScreen.js","/src/tutor/home/InterviewHeader.js","/src/teacher/classrooms/ClassroomChallengesTab.js","/src/teacher/classrooms/ClassroomSettingsTab.js","/src/teacher/classrooms/ClassroomStudentsTab.js","/src/teacher/classrooms/ClassroomInviteModal.js","/src/teacher/classrooms/NewClassroomStepper.js","/src/tutor/application/motivation/InterviewScreen.js","/src/tutor/application/motivation/InterviewQuestion.js","/src/tutor/application/motivation/TechnicalQuestionsScreen.js","/src/tutor/application/motivation/VideoRecordingScreen.js","/src/tutor/application/motivation/VideoRecordingComponent.web.js","/../../node_modules/react-webcam/dist/react-webcam.js","/src/tutor/application/TutorApplicationScreen.js","/src/tutor/application/FileStep.js","/src/tutor/application/ApplicationFinishedScreen.js","/assets/icons/generic/candidat.png","/src/tutor/home/CompleteTutorProfileStepper.js","/src/tutor/home/components/TutorProfilePersonalizer.js","/src/tutor/home/interview/Interview.js","/src/tutor/home/interview/interview steps/InterviewStepX1.js","/src/tutor/home/interview/InterviewHeader.js","/src/tutor/home/interview/interview steps/InterviewStepFinal.js","/src/tutor/home/interview/interview steps/InterviewChallengesStep.js","/src/student/organize/challenges/ChallengesTabScreen.js","/src/student/organize/school-subjects/SchoolSubjectBottomSheetModal.js","/src/tutor/home/interview/InterviewSummary.js","/src/tutor/home/InterviewHistory.js","/src/tutor/SlotModal.js","/src/tutor/home/substitution/SubstitutionProposalScreen.js","/src/tutor/home/tutorResources/BrowseActivites.js","/src/tutor/home/tutorResources/BrowseByChallenge.js","/src/tutor/home/tutorResources/TutorVideos.js","/src/tutor/invoices/TutoringInvoicesScreen.js","/src/tutor/lives/live-history/TutorLivesHistoryScreen.js","/src/tutor/lives/ManageRDVScreen.js","/src/tutor/lives/TutorLiveCardComponent.js","/src/tutor/lives/SelectDelayComponent.js","/src/tutor/lives/SelectSituationComponent.js","/src/tutor/lives/TutorNextLivesListScreen.js","/src/tutor/notes/NewNoteScreen.js","/src/tutor/notes/StudentNotesScreen.js","/src/tutor/notes/NoteCard.js","/src/tutor/SlotUpdateScreen.js","/src/tutor/students/StudentProfil.js","/src/student/account/trial-information/ParentEvaluationScores.js","/src/tutor/TutorSlotsScreen.js","/src/common/account/ValidateEmailScreen.js","/src/common/account/ValidateEmailCard.js","/src/common/camera/CameraScreen.js","/src/common/camera/CameraComponent.web.js","/../../node_modules/@expo/vector-icons/FontAwesome6.js","/../../node_modules/@expo/vector-icons/build/FontAwesome6.js","/../../node_modules/@expo/vector-icons/build/createIconSetFromFontAwesome6.js","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/glyphmaps/FontAwesome6Free.json","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/glyphmaps/FontAwesome6Free_meta.json","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/Fonts/FontAwesome6_Regular.ttf","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/Fonts/FontAwesome6_Solid.ttf","/../../node_modules/@expo/vector-icons/build/vendor/react-native-vector-icons/Fonts/FontAwesome6_Brands.ttf","/src/common/interviewReports/InterviewReportScreen.js","/src/common/interviewReports/interviewReportComponent.js","/assets/icons/menus/rise.png","/src/common/interviewReports/InterviewReportsScreen.js","/src/common/liveMode/LiveParticipants.js","/src/common/main-menu/BottomTabsNavigator.js","/src/tutor/tutorTabScreens.js","/src/tutor/home/TutorHomeTabScreen.js","/src/tutor/home/dashboard/CoachStats.js","/assets/icons/menus/live-chat.png","/src/tutor/home/components/SlotCompletion.js","/src/tutor/lives/TutorNextLivesCard.js","/src/tutor/home/interview/TutorNextEventsCard.js","/src/tutor/home/interview/TutorNextEventsModal.js","/src/tutor/lives/MissingLiveReportsCard.js","/src/tutor/home/components/StripeConnectOnboardingCard.js","/src/tutor/home/substitution/SubstitutionProposalsCard.js","/assets/icons/menus/home1.png","/assets/icons/menus/home1-g.png","/src/tutor/students/MyStudentsTabScreen.js","/assets/icons/menus/referral.png","/assets/icons/menus/referral-g.png","/assets/icons/menus/cogwheel.png","/assets/icons/menus/cogwheel-g.png","/assets/icons/menus/school.png","/assets/icons/menus/school-g.png","/assets/icons/menus/graduate-g.png","/src/admin/referrals/ReferralsBackofficeScreen.js","/src/student/studentTabScreens.js","/src/student/social/RankingTabScreen.js","/assets/icons/menus-new/classement.png","/assets/icons/menus-new/classement-gris.png","/assets/icons/menus-new/quete.png","/assets/icons/menus-new/quete-gris.png","/src/student/progress/my progress/MySkillSetsTabScreen.js","/src/common/components/modal/VersionUpdateModal.js","/src/common/messenger/ChatScreen.js","/src/common/messenger/ChatScreenHeader.js","/src/common/studyPrograms/studyProgramScreen.js","/src/common/studyPrograms/StudyProgramsScreen.js","/src/school-card-report/cta/CTAScreen.js","/assets/diagnostic/cta/balise-de-remise.png","/src/common/components/navigation/DiagnosticNavigationM.js","/src/school-card-report/diagnostic/DiagnosticHelpers.js","/assets/diagnostic/performance/finish-flag.png","/assets/diagnostic/motivation/beach-umbrella.png","/assets/diagnostic/motivation/plane.png","/assets/diagnostic/motivation/compass.png","/assets/diagnostic/motivation/shuttle.png","/assets/diagnostic/organisation/windstorm.png","/assets/diagnostic/organisation/hourglass.png","/assets/diagnostic/organisation/book.png","/assets/diagnostic/organisation/trophy.png","/assets/diagnostic/style/balance.png","/assets/diagnostic/style/flask.png","/assets/diagnostic/style/open-book.png","/assets/diagnostic/style/parchment.png","/assets/diagnostic/style/sunbathing.png","/assets/diagnostic/priority/warning.png","/assets/diagnostic/objectif/target.png","/assets/diagnostic/organisation/heure-de-grande-ecoute.png","/assets/diagnostic/priority/puzzle.png","/assets/diagnostic/objectif/task.png","/assets/diagnostic/priority/subjects/maths.png","/assets/diagnostic/priority/subjects/french.png","/assets/diagnostic/priority/subjects/english.png","/src/school-card-report/diagnostic/DiagnosticScreen.js","/src/school-card-report/EnterEmailModal.js","/src/school-card-report/diagnostic/see-more/MotivationSeeMoreScreen.js","/../../node_modules/react-native-animatable/index.js","/../../node_modules/react-native-animatable/createAnimatableComponent.js","/../../node_modules/react-native-animatable/wrapStyleTransforms.js","/../../node_modules/react-native-animatable/getStyleValues.js","/../../node_modules/react-native-animatable/flattenStyle.js","/../../node_modules/react-native-animatable/getDefaultStyleValue.js","/../../node_modules/react-native-animatable/createAnimation.js","/../../node_modules/react-native-animatable/registry.js","/../../node_modules/react-native-animatable/easing.js","/../../node_modules/react-native-animatable/definitions/index.js","/../../node_modules/react-native-animatable/definitions/attention-seekers.js","/../../node_modules/react-native-animatable/definitions/bouncing-entrances.js","/../../node_modules/react-native-animatable/definitions/bouncing-exits.js","/../../node_modules/react-native-animatable/definitions/fading-entrances.js","/../../node_modules/react-native-animatable/definitions/fading-exits.js","/../../node_modules/react-native-animatable/definitions/flippers.js","/../../node_modules/react-native-animatable/definitions/lightspeed.js","/../../node_modules/react-native-animatable/definitions/sliding-entrances.js","/../../node_modules/react-native-animatable/definitions/sliding-exits.js","/../../node_modules/react-native-animatable/definitions/zooming-entrances.js","/../../node_modules/react-native-animatable/definitions/zooming-exits.js","/src/school-card-report/diagnostic/see-more/PerformanceRankingScreen.js","/src/school-card-report/diagnostic/see-more/StyleSeeMoreScreen.js","/src/school-card-report/diagnostic/see-more/BulletPointsSeeMoreScreen.js","/../../node_modules/@react-navigation/stack/lib/module/index.js","/../../node_modules/@react-navigation/stack/lib/module/TransitionConfigs/CardStyleInterpolators.js","/../../node_modules/@react-navigation/stack/lib/module/utils/conditional.js","/../../node_modules/@react-navigation/stack/lib/module/TransitionConfigs/HeaderStyleInterpolators.js","/../../node_modules/@react-navigation/stack/lib/module/TransitionConfigs/TransitionPresets.js","/../../node_modules/@react-navigation/stack/lib/module/TransitionConfigs/TransitionSpecs.js","/../../node_modules/@react-navigation/stack/lib/module/navigators/createStackNavigator.js","/../../node_modules/@react-navigation/stack/lib/module/views/Stack/StackView.js","/../../node_modules/@react-navigation/elements/lib/module/index.js","/../../node_modules/@react-navigation/elements/lib/module/Background.js","/../../node_modules/@react-navigation/elements/lib/module/Header/getDefaultHeaderHeight.js","/../../node_modules/@react-navigation/elements/lib/module/Header/getHeaderTitle.js","/../../node_modules/@react-navigation/elements/lib/module/Header/Header.js","/../../node_modules/@react-navigation/elements/lib/module/Header/HeaderBackground.js","/../../node_modules/@react-navigation/elements/lib/module/Header/HeaderShownContext.js","/../../node_modules/@react-navigation/elements/lib/module/getNamedContext.js","/../../node_modules/@react-navigation/elements/lib/module/Header/HeaderTitle.js","/../../node_modules/@react-navigation/elements/lib/module/Header/HeaderBackButton.js","/../../node_modules/@react-navigation/elements/lib/module/MaskedView.js","/../../node_modules/@react-navigation/elements/lib/module/PlatformPressable.js","/../../node_modules/@react-navigation/elements/lib/module/assets/back-icon.png","/../../node_modules/@react-navigation/elements/lib/module/assets/back-icon-mask.png","/../../node_modules/@react-navigation/elements/lib/module/Header/HeaderBackContext.js","/../../node_modules/@react-navigation/elements/lib/module/Header/HeaderHeightContext.js","/../../node_modules/@react-navigation/elements/lib/module/Header/useHeaderHeight.js","/../../node_modules/@react-navigation/elements/lib/module/MissingIcon.js","/../../node_modules/@react-navigation/elements/lib/module/ResourceSavingView.js","/../../node_modules/@react-navigation/elements/lib/module/SafeAreaProviderCompat.js","/../../node_modules/@react-navigation/elements/lib/module/Screen.js","/../../node_modules/@react-navigation/elements/lib/module/types.js","/../../node_modules/@react-navigation/stack/lib/module/utils/ModalPresentationContext.js","/../../node_modules/@react-navigation/stack/lib/module/views/GestureHandler.js","/../../node_modules/@react-navigation/stack/lib/module/views/Header/HeaderContainer.js","/../../node_modules/@react-navigation/stack/lib/module/views/Header/Header.js","/../../node_modules/@react-navigation/stack/lib/module/utils/debounce.js","/../../node_modules/@react-navigation/stack/lib/module/views/Header/HeaderSegment.js","/../../node_modules/@react-navigation/stack/lib/module/utils/memoize.js","/../../node_modules/@react-navigation/stack/lib/module/views/Stack/CardStack.js","/../../node_modules/@react-navigation/stack/lib/module/utils/findLastIndex.js","/../../node_modules/@react-navigation/stack/lib/module/utils/getDistanceForDirection.js","/../../node_modules/@react-navigation/stack/lib/module/utils/getInvertedMultiplier.js","/../../node_modules/@react-navigation/stack/lib/module/views/Screens.js","/../../node_modules/@react-navigation/stack/lib/module/views/Stack/Card.js","/../../node_modules/@react-navigation/stack/lib/module/utils/CardAnimationContext.js","/../../node_modules/@react-navigation/stack/lib/module/views/ModalStatusBarManager.js","/../../node_modules/@react-navigation/stack/lib/module/views/Stack/CardSheet.js","/../../node_modules/@react-navigation/stack/lib/module/views/Stack/CardContainer.js","/../../node_modules/@react-navigation/stack/lib/module/utils/useKeyboardManager.js","/../../node_modules/@react-navigation/stack/lib/module/utils/GestureHandlerRefContext.js","/../../node_modules/@react-navigation/stack/lib/module/utils/useCardAnimation.js","/../../node_modules/@react-navigation/stack/lib/module/utils/useGestureHandlerRef.js","/src/auth/NotFound.js","/src/auth/Unauthorized.js","/src/common/header/Header.js","/src/common/header/TutorMainMenuHeader.js","/../../node_modules/@casl/ability/dist/es5m/index.js","/../../node_modules/@ucast/mongo2js/dist/es5m/index.js","/../../node_modules/@ucast/core/dist/es5m/index.js","/../../node_modules/@ucast/mongo/dist/es5m/index.js","/../../node_modules/@ucast/js/dist/es5m/index.js","/src/common/screens/ErrorBoundaryFallbackView.js","/assets/icons/emojis/dead.png","/src/student/champions/ChampionTooltipM.js","/../../node_modules/expo-dev-client/build/DevClient.js","/../../node_modules/expo-dev-launcher/build/DevLauncher.js","/../../node_modules/expo-dev-launcher/build/setUpErrorHandler.fx.web.js","/../../node_modules/expo-dev-launcher/build/DevLauncherErrorManager.web.js","/../../node_modules/expo-dev-launcher/build/WebUnsupportedError.js","/../../node_modules/expo-dev-menu/build/DevMenu.js","/../../node_modules/expo-dev-menu/build/ExpoDevMenu.web.js","/../../node_modules/expo-dev-menu/build/WebUnsupportedError.js","/src/common/hooks/useGTMWeb.js","/../../node_modules/@react-navigation/devtools/lib/module/index.js","/src/common/livekit/LiveKitRoomM.web.js","/../../node_modules/@livekit/components-styles/dist/general/index.css","/src/common/livekit/LiveKitRoom.tsx","/src/common/livekit/components-web/LKEvents.tsx","/assets/sounds/glass_006.mp3","/assets/sounds/minimize_001_low.mp3","/assets/fonts/Owl-Cute.ttf","/assets/fonts/Montserrat-Black.ttf","/assets/fonts/Montserrat-BlackItalic.ttf","/assets/fonts/Montserrat-Bold.ttf","/assets/fonts/Montserrat-BoldItalic.ttf","/assets/fonts/Montserrat-ExtraBold.ttf","/assets/fonts/Montserrat-ExtraBoldItalic.ttf","/assets/fonts/Montserrat-ExtraLight.ttf","/assets/fonts/Montserrat-ExtraLightItalic.ttf","/assets/fonts/Montserrat-Italic.ttf","/assets/fonts/Montserrat-Light.ttf","/assets/fonts/Montserrat-LightItalic.ttf","/assets/fonts/Montserrat-Medium.ttf","/assets/fonts/Montserrat-MediumItalic.ttf","/assets/fonts/Montserrat-Regular.ttf","/assets/fonts/Montserrat-SemiBold.ttf","/assets/fonts/Montserrat-SemiBoldItalic.ttf","/assets/fonts/Montserrat-Thin.ttf","/assets/fonts/Montserrat-ThinItalic.ttf","/../../node_modules/react-native-vector-icons/Fonts/Ionicons.ttf","/../../node_modules/react-native-vector-icons/Fonts/FontAwesome.ttf","/../../node_modules/react-native-vector-icons/Fonts/FontAwesome5_Brands.ttf","/../../node_modules/react-native-vector-icons/Fonts/FontAwesome5_Regular.ttf","/../../node_modules/react-native-vector-icons/Fonts/FontAwesome5_Solid.ttf","/../../node_modules/react-native-vector-icons/Fonts/FontAwesome6_Brands.ttf","/../../node_modules/react-native-vector-icons/Fonts/FontAwesome6_Regular.ttf","/../../node_modules/react-native-vector-icons/Fonts/FontAwesome6_Solid.ttf","/../../node_modules/react-native-vector-icons/Fonts/MaterialIcons.ttf","/../../node_modules/react-native-vector-icons/Fonts/Feather.ttf","/../../node_modules/react-native-vector-icons/Fonts/MaterialCommunityIcons.ttf","/../../node_modules/expo-router/build/ExpoRoot.js","/../../node_modules/expo-router/build/fork/NavigationContainer.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/index.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/BaseNavigationContainer.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/checkDuplicateRouteNames.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/checkSerializable.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/createNavigationContainerRef.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/EnsureSingleNavigator.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/findFocusedRoute.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/NavigationBuilderContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/NavigationContainerRefContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/NavigationContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/NavigationRouteContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/NavigationStateContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/UnhandledActionContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useChildListeners.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useEventEmitter.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useKeyedChildListeners.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useOptionsGetters.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useScheduleUpdate.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useSyncState.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/createNavigatorFactory.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/Group.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/Screen.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/CurrentRenderContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/getActionFromState.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/getFocusedRouteNameFromRoute.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useRouteCache.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/getPathFromState.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/fromEntries.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/validatePathConfig.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/getStateFromPath.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/NavigationHelpersContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/PreventRemoveContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/PreventRemoveProvider.js","/../../node_modules/expo-router/node_modules/use-latest-callback/lib/src/index.js","/../../node_modules/expo-router/node_modules/use-latest-callback/lib/src/useIsomorphicLayoutEffect.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/types.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useFocusEffect.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useNavigation.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useIsFocused.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useNavigationBuilder.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/isArrayEqual.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/isRecordEqual.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useComponent.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useCurrentRender.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useDescriptors.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/SceneView.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/StaticContainer.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useNavigationCache.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useFocusedListenersChildrenAdapter.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useFocusEvents.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useNavigationHelpers.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useOnAction.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useOnPreventRemove.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useOnGetState.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useOnRouteFocus.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useRegisterNavigator.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useNavigationContainerRef.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useNavigationState.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/usePreventRemove.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/usePreventRemoveContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/core/lib/module/useRoute.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/index.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/Link.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/useLinkProps.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/LinkingContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/useLinkTo.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/NavigationContainer.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/theming/DefaultTheme.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/theming/ThemeProvider.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/theming/ThemeContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/useBackButton.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/useDocumentTitle.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/useLinking.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/createMemoryHistory.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/ServerContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/useThenable.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/ServerContainer.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/theming/DarkTheme.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/theming/useTheme.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/types.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/useLinkBuilder.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/lib/module/useScrollToTop.js","/../../node_modules/expo-router/node_modules/@react-navigation/native/src/useBackButton.tsx","/../../node_modules/expo-router/node_modules/@react-navigation/native/src/useDocumentTitle.tsx","/../../node_modules/expo-router/node_modules/@react-navigation/native/src/useThenable.tsx","/../../node_modules/expo-router/build/fork/useLinking.js","/../../node_modules/expo-router/build/fork/createMemoryHistory.js","/../../node_modules/expo-router/build/global-state/serverContext.js","/../../node_modules/expo-router/build/fork/getPathFromState.js","/../../node_modules/expo-router/build/matchers.js","/../../node_modules/expo-router/build/global-state/router-store.js","/../../node_modules/expo-splash-screen/build/index.js","/../../node_modules/expo-router/build/global-state/routing.js","/../../node_modules/expo-router/build/link/href.js","/../../node_modules/expo-router/build/link/path.js","/../../node_modules/expo-router/build/utils/url.js","/../../node_modules/expo-router/build/global-state/sort-routes.js","/../../node_modules/expo-router/build/Route.js","/../../node_modules/expo-router/build/sortRoutes.js","/../../node_modules/expo-router/build/LocationProvider.js","/../../node_modules/expo-router/build/fork/getStateFromPath.js","/../../node_modules/expo-router/build/fork/findFocusedRoute.js","/../../node_modules/expo-router/build/fork/validatePathConfig.js","/../../node_modules/expo-router/build/getLinkingConfig.js","/../../node_modules/expo-router/build/getReactNavigationConfig.js","/../../node_modules/expo-router/build/link/linking.js","/../../node_modules/expo-router/build/fork/extractPathFromURL.js","/../../node_modules/expo-router/build/getRoutes.js","/../../node_modules/expo-router/build/getRoutesCore.js","/../../node_modules/expo-router/build/views/Navigator.js","/../../node_modules/expo-router/build/views/Screen.js","/../../node_modules/expo-router/build/useNavigation.js","/../../node_modules/expo-router/build/layouts/withLayoutContext.js","/../../node_modules/expo-router/build/useScreens.js","/../../node_modules/expo-router/build/import-mode/index.js","/../../node_modules/expo-router/build/primitives.js","/../../node_modules/expo-router/build/views/EmptyRoute.js","/../../node_modules/expo-router/build/views/Toast.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/index.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/navigators/createBottomTabNavigator.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/views/BottomTabView.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/index.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Background.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/getDefaultHeaderHeight.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/getHeaderTitle.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/Header.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/HeaderBackground.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/HeaderShownContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/getNamedContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/HeaderTitle.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/HeaderBackButton.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/MaskedView.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/PlatformPressable.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/assets/back-icon.png","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/assets/back-icon-mask.png","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/HeaderBackContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/HeaderHeightContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Header/useHeaderHeight.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/MissingIcon.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/ResourceSavingView.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/SafeAreaProviderCompat.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/Screen.js","/../../node_modules/expo-router/node_modules/@react-navigation/elements/lib/module/types.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/utils/BottomTabBarHeightCallbackContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/utils/BottomTabBarHeightContext.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/views/BottomTabBar.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/utils/useIsKeyboardShown.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/views/BottomTabItem.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/views/TabBarIcon.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/views/Badge.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/views/ScreenFallback.js","/../../node_modules/expo-router/node_modules/@react-navigation/bottom-tabs/lib/module/utils/useBottomTabBarHeight.js","/../../node_modules/expo-router/assets/error.png","/../../node_modules/expo-router/build/views/SuspenseFallback.js","/../../node_modules/expo-router/build/views/Try.js","/../../node_modules/expo-router/build/views/Splash.js","/../../node_modules/expo-router/build/views/Sitemap.js","/../../node_modules/expo-router/build/views/Pressable.js","/../../node_modules/expo-router/build/imperative-api.js","/../../node_modules/expo-router/build/link/Link.js","/../../node_modules/@radix-ui/react-slot/dist/index.module.js","/../../node_modules/@radix-ui/react-slot/node_modules/@babel/runtime/helpers/interopRequireDefault.js","/../../node_modules/@radix-ui/react-slot/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js","/../../node_modules/@radix-ui/react-slot/node_modules/@babel/runtime/helpers/esm/extends.js","/../../node_modules/@radix-ui/react-compose-refs/dist/index.module.js","/../../node_modules/expo-router/build/link/useLinkToPathProps.js","/../../node_modules/expo-router/build/hooks.js","/../../node_modules/expo-router/build/useFocusEffect.js","/../../node_modules/expo-router/build/link/useLoadedNavigation.js","/../../node_modules/expo-router/build/utils/statusbar.js","/../../node_modules/expo-router/assets/file.png","/../../node_modules/expo-router/assets/pkg.png","/../../node_modules/expo-router/assets/forward.png","/../../node_modules/expo-router/build/views/Unmatched.js","/../../node_modules/expo-router/build/head/index.js","/../../node_modules/expo-router/build/head/ExpoHead.js","/../../node_modules/react-native-helmet-async/lib/index.esm.js","/../../node_modules/shallowequal/index.js","/../../node_modules/expo-router/build/renderRootComponent.js","/../../node_modules/expo/build/Expo.js","/../../node_modules/expo/build/Expo.fx.web.js","/../../node_modules/expo/build/errors/ExpoErrorManager.js","/../../node_modules/expo/build/launch/registerRootComponent.js","/../../node_modules/expo/build/environment/ExpoGo.web.js"],"sourcesContent":["var __BUNDLE_START_TIME__=this.nativePerformanceNow?nativePerformanceNow():Date.now(),__DEV__=false,process=this.process||{},__METRO_GLOBAL_PREFIX__='';process.env=process.env||{};process.env.NODE_ENV=process.env.NODE_ENV||\"production\";","\"use strict\";\n\nglobal.__r = metroRequire;\nglobal[`${__METRO_GLOBAL_PREFIX__}__d`] = define;\nglobal.__c = clear;\nglobal.__registerSegment = registerSegment;\nvar modules = clear();\nconst EMPTY = {};\nconst CYCLE_DETECTED = {};\nconst { hasOwnProperty } = {};\nif (__DEV__) {\n global.$RefreshReg$ = () => {};\n global.$RefreshSig$ = () => (type) => type;\n}\nfunction clear() {\n modules = new Map();\n return modules;\n}\nif (__DEV__) {\n var verboseNamesToModuleIds = new Map();\n var getModuleIdForVerboseName = (verboseName) => {\n const moduleId = verboseNamesToModuleIds.get(verboseName);\n if (moduleId == null) {\n throw new Error(`Unknown named module: \"${verboseName}\"`);\n }\n return moduleId;\n };\n var initializingModuleIds = [];\n}\nfunction define(factory, moduleId, dependencyMap) {\n if (modules.has(moduleId)) {\n if (__DEV__) {\n const inverseDependencies = arguments[4];\n if (inverseDependencies) {\n global.__accept(moduleId, factory, dependencyMap, inverseDependencies);\n }\n }\n return;\n }\n const mod = {\n dependencyMap,\n factory,\n hasError: false,\n importedAll: EMPTY,\n importedDefault: EMPTY,\n isInitialized: false,\n publicModule: {\n exports: {},\n },\n };\n modules.set(moduleId, mod);\n if (__DEV__) {\n mod.hot = createHotReloadingObject();\n const verboseName = arguments[3];\n if (verboseName) {\n mod.verboseName = verboseName;\n verboseNamesToModuleIds.set(verboseName, moduleId);\n }\n }\n}\nfunction metroRequire(moduleId) {\n if (__DEV__ && typeof moduleId === \"string\") {\n const verboseName = moduleId;\n moduleId = getModuleIdForVerboseName(verboseName);\n console.warn(\n `Requiring module \"${verboseName}\" by name is only supported for ` +\n \"debugging purposes and will BREAK IN PRODUCTION!\"\n );\n }\n const moduleIdReallyIsNumber = moduleId;\n if (__DEV__) {\n const initializingIndex = initializingModuleIds.indexOf(\n moduleIdReallyIsNumber\n );\n if (initializingIndex !== -1) {\n const cycle = initializingModuleIds\n .slice(initializingIndex)\n .map((id) => modules.get(id)?.verboseName ?? \"[unknown]\");\n if (shouldPrintRequireCycle(cycle)) {\n cycle.push(cycle[0]);\n console.warn(\n `Require cycle: ${cycle.join(\" -> \")}\\n\\n` +\n \"Require cycles are allowed, but can result in uninitialized values. \" +\n \"Consider refactoring to remove the need for a cycle.\"\n );\n }\n }\n }\n const module = modules.get(moduleIdReallyIsNumber);\n return module && module.isInitialized\n ? module.publicModule.exports\n : guardedLoadModule(moduleIdReallyIsNumber, module);\n}\nfunction shouldPrintRequireCycle(modules) {\n const regExps =\n global[__METRO_GLOBAL_PREFIX__ + \"__requireCycleIgnorePatterns\"];\n if (!Array.isArray(regExps)) {\n return true;\n }\n const isIgnored = (module) =>\n module != null && regExps.some((regExp) => regExp.test(module));\n return modules.every((module) => !isIgnored(module));\n}\nfunction metroImportDefault(moduleId) {\n if (__DEV__ && typeof moduleId === \"string\") {\n const verboseName = moduleId;\n moduleId = getModuleIdForVerboseName(verboseName);\n }\n const moduleIdReallyIsNumber = moduleId;\n const maybeInitializedModule = modules.get(moduleIdReallyIsNumber);\n if (\n maybeInitializedModule &&\n maybeInitializedModule.importedDefault !== EMPTY\n ) {\n return maybeInitializedModule.importedDefault;\n }\n const exports = metroRequire(moduleIdReallyIsNumber);\n const importedDefault =\n exports && exports.__esModule ? exports.default : exports;\n const initializedModule = modules.get(moduleIdReallyIsNumber);\n return (initializedModule.importedDefault = importedDefault);\n}\nmetroRequire.importDefault = metroImportDefault;\nfunction metroImportAll(moduleId) {\n if (__DEV__ && typeof moduleId === \"string\") {\n const verboseName = moduleId;\n moduleId = getModuleIdForVerboseName(verboseName);\n }\n const moduleIdReallyIsNumber = moduleId;\n const maybeInitializedModule = modules.get(moduleIdReallyIsNumber);\n if (maybeInitializedModule && maybeInitializedModule.importedAll !== EMPTY) {\n return maybeInitializedModule.importedAll;\n }\n const exports = metroRequire(moduleIdReallyIsNumber);\n let importedAll;\n if (exports && exports.__esModule) {\n importedAll = exports;\n } else {\n importedAll = {};\n if (exports) {\n for (const key in exports) {\n if (hasOwnProperty.call(exports, key)) {\n importedAll[key] = exports[key];\n }\n }\n }\n importedAll.default = exports;\n }\n const initializedModule = modules.get(moduleIdReallyIsNumber);\n return (initializedModule.importedAll = importedAll);\n}\nmetroRequire.importAll = metroImportAll;\nmetroRequire.context = function fallbackRequireContext() {\n if (__DEV__) {\n throw new Error(\n \"The experimental Metro feature `require.context` is not enabled in your project.\\nThis can be enabled by setting the `transformer.unstable_allowRequireContext` property to `true` in your Metro configuration.\"\n );\n }\n throw new Error(\n \"The experimental Metro feature `require.context` is not enabled in your project.\"\n );\n};\nmetroRequire.resolveWeak = function fallbackRequireResolveWeak() {\n if (__DEV__) {\n throw new Error(\n \"require.resolveWeak cannot be called dynamically. Ensure you are using the same version of `metro` and `metro-runtime`.\"\n );\n }\n throw new Error(\"require.resolveWeak cannot be called dynamically.\");\n};\nlet inGuard = false;\nfunction guardedLoadModule(moduleId, module) {\n if (!inGuard && global.ErrorUtils) {\n inGuard = true;\n let returnValue;\n try {\n returnValue = loadModuleImplementation(moduleId, module);\n } catch (e) {\n global.ErrorUtils.reportFatalError(e);\n }\n inGuard = false;\n return returnValue;\n } else {\n return loadModuleImplementation(moduleId, module);\n }\n}\nconst ID_MASK_SHIFT = 16;\nconst LOCAL_ID_MASK = ~0 >>> ID_MASK_SHIFT;\nfunction unpackModuleId(moduleId) {\n const segmentId = moduleId >>> ID_MASK_SHIFT;\n const localId = moduleId & LOCAL_ID_MASK;\n return {\n segmentId,\n localId,\n };\n}\nmetroRequire.unpackModuleId = unpackModuleId;\nfunction packModuleId(value) {\n return (value.segmentId << ID_MASK_SHIFT) + value.localId;\n}\nmetroRequire.packModuleId = packModuleId;\nconst moduleDefinersBySegmentID = [];\nconst definingSegmentByModuleID = new Map();\nfunction registerSegment(segmentId, moduleDefiner, moduleIds) {\n moduleDefinersBySegmentID[segmentId] = moduleDefiner;\n if (__DEV__) {\n if (segmentId === 0 && moduleIds) {\n throw new Error(\n \"registerSegment: Expected moduleIds to be null for main segment\"\n );\n }\n if (segmentId !== 0 && !moduleIds) {\n throw new Error(\n \"registerSegment: Expected moduleIds to be passed for segment #\" +\n segmentId\n );\n }\n }\n if (moduleIds) {\n moduleIds.forEach((moduleId) => {\n if (!modules.has(moduleId) && !definingSegmentByModuleID.has(moduleId)) {\n definingSegmentByModuleID.set(moduleId, segmentId);\n }\n });\n }\n}\nfunction loadModuleImplementation(moduleId, module) {\n if (!module && moduleDefinersBySegmentID.length > 0) {\n const segmentId = definingSegmentByModuleID.get(moduleId) ?? 0;\n const definer = moduleDefinersBySegmentID[segmentId];\n if (definer != null) {\n definer(moduleId);\n module = modules.get(moduleId);\n definingSegmentByModuleID.delete(moduleId);\n }\n }\n const nativeRequire = global.nativeRequire;\n if (!module && nativeRequire) {\n const { segmentId, localId } = unpackModuleId(moduleId);\n nativeRequire(localId, segmentId);\n module = modules.get(moduleId);\n }\n if (!module) {\n throw unknownModuleError(moduleId);\n }\n if (module.hasError) {\n throw module.error;\n }\n if (__DEV__) {\n var Systrace = requireSystrace();\n var Refresh = requireRefresh();\n }\n module.isInitialized = true;\n const { factory, dependencyMap } = module;\n if (__DEV__) {\n initializingModuleIds.push(moduleId);\n }\n try {\n if (__DEV__) {\n Systrace.beginEvent(\"JS_require_\" + (module.verboseName || moduleId));\n }\n const moduleObject = module.publicModule;\n if (__DEV__) {\n moduleObject.hot = module.hot;\n var prevRefreshReg = global.$RefreshReg$;\n var prevRefreshSig = global.$RefreshSig$;\n if (Refresh != null) {\n const RefreshRuntime = Refresh;\n global.$RefreshReg$ = (type, id) => {\n RefreshRuntime.register(type, moduleId + \" \" + id);\n };\n global.$RefreshSig$ =\n RefreshRuntime.createSignatureFunctionForTransform;\n }\n }\n moduleObject.id = moduleId;\n factory(\n global,\n metroRequire,\n metroImportDefault,\n metroImportAll,\n moduleObject,\n moduleObject.exports,\n dependencyMap\n );\n if (!__DEV__) {\n module.factory = undefined;\n module.dependencyMap = undefined;\n }\n if (__DEV__) {\n Systrace.endEvent();\n if (Refresh != null) {\n registerExportsForReactRefresh(Refresh, moduleObject.exports, moduleId);\n }\n }\n return moduleObject.exports;\n } catch (e) {\n module.hasError = true;\n module.error = e;\n module.isInitialized = false;\n module.publicModule.exports = undefined;\n throw e;\n } finally {\n if (__DEV__) {\n if (initializingModuleIds.pop() !== moduleId) {\n throw new Error(\n \"initializingModuleIds is corrupt; something is terribly wrong\"\n );\n }\n global.$RefreshReg$ = prevRefreshReg;\n global.$RefreshSig$ = prevRefreshSig;\n }\n }\n}\nfunction unknownModuleError(id) {\n let message = 'Requiring unknown module \"' + id + '\".';\n if (__DEV__) {\n message +=\n \" If you are sure the module exists, try restarting Metro. \" +\n \"You may also want to run `yarn` or `npm install`.\";\n }\n return Error(message);\n}\nif (__DEV__) {\n metroRequire.Systrace = {\n beginEvent: () => {},\n endEvent: () => {},\n };\n metroRequire.getModules = () => {\n return modules;\n };\n var createHotReloadingObject = function () {\n const hot = {\n _acceptCallback: null,\n _disposeCallback: null,\n _didAccept: false,\n accept: (callback) => {\n hot._didAccept = true;\n hot._acceptCallback = callback;\n },\n dispose: (callback) => {\n hot._disposeCallback = callback;\n },\n };\n return hot;\n };\n let reactRefreshTimeout = null;\n const metroHotUpdateModule = function (\n id,\n factory,\n dependencyMap,\n inverseDependencies\n ) {\n const mod = modules.get(id);\n if (!mod) {\n if (factory) {\n return;\n }\n throw unknownModuleError(id);\n }\n if (!mod.hasError && !mod.isInitialized) {\n mod.factory = factory;\n mod.dependencyMap = dependencyMap;\n return;\n }\n const Refresh = requireRefresh();\n const refreshBoundaryIDs = new Set();\n let didBailOut = false;\n let updatedModuleIDs;\n try {\n updatedModuleIDs = topologicalSort(\n [id],\n (pendingID) => {\n const pendingModule = modules.get(pendingID);\n if (pendingModule == null) {\n return [];\n }\n const pendingHot = pendingModule.hot;\n if (pendingHot == null) {\n throw new Error(\n \"[Refresh] Expected module.hot to always exist in DEV.\"\n );\n }\n let canAccept = pendingHot._didAccept;\n if (!canAccept && Refresh != null) {\n const isBoundary = isReactRefreshBoundary(\n Refresh,\n pendingModule.publicModule.exports\n );\n if (isBoundary) {\n canAccept = true;\n refreshBoundaryIDs.add(pendingID);\n }\n }\n if (canAccept) {\n return [];\n }\n const parentIDs = inverseDependencies[pendingID];\n if (parentIDs.length === 0) {\n performFullRefresh(\"No root boundary\", {\n source: mod,\n failed: pendingModule,\n });\n didBailOut = true;\n return [];\n }\n return parentIDs;\n },\n () => didBailOut\n ).reverse();\n } catch (e) {\n if (e === CYCLE_DETECTED) {\n performFullRefresh(\"Dependency cycle\", {\n source: mod,\n });\n return;\n }\n throw e;\n }\n if (didBailOut) {\n return;\n }\n const seenModuleIDs = new Set();\n for (let i = 0; i < updatedModuleIDs.length; i++) {\n const updatedID = updatedModuleIDs[i];\n if (seenModuleIDs.has(updatedID)) {\n continue;\n }\n seenModuleIDs.add(updatedID);\n const updatedMod = modules.get(updatedID);\n if (updatedMod == null) {\n throw new Error(\"[Refresh] Expected to find the updated module.\");\n }\n const prevExports = updatedMod.publicModule.exports;\n const didError = runUpdatedModule(\n updatedID,\n updatedID === id ? factory : undefined,\n updatedID === id ? dependencyMap : undefined\n );\n const nextExports = updatedMod.publicModule.exports;\n if (didError) {\n return;\n }\n if (refreshBoundaryIDs.has(updatedID)) {\n const isNoLongerABoundary = !isReactRefreshBoundary(\n Refresh,\n nextExports\n );\n const didInvalidate = shouldInvalidateReactRefreshBoundary(\n Refresh,\n prevExports,\n nextExports\n );\n if (isNoLongerABoundary || didInvalidate) {\n const parentIDs = inverseDependencies[updatedID];\n if (parentIDs.length === 0) {\n performFullRefresh(\n isNoLongerABoundary\n ? \"No longer a boundary\"\n : \"Invalidated boundary\",\n {\n source: mod,\n failed: updatedMod,\n }\n );\n return;\n }\n for (let j = 0; j < parentIDs.length; j++) {\n const parentID = parentIDs[j];\n const parentMod = modules.get(parentID);\n if (parentMod == null) {\n throw new Error(\"[Refresh] Expected to find parent module.\");\n }\n const canAcceptParent = isReactRefreshBoundary(\n Refresh,\n parentMod.publicModule.exports\n );\n if (canAcceptParent) {\n refreshBoundaryIDs.add(parentID);\n updatedModuleIDs.push(parentID);\n } else {\n performFullRefresh(\"Invalidated boundary\", {\n source: mod,\n failed: parentMod,\n });\n return;\n }\n }\n }\n }\n }\n if (Refresh != null) {\n if (reactRefreshTimeout == null) {\n reactRefreshTimeout = setTimeout(() => {\n reactRefreshTimeout = null;\n Refresh.performReactRefresh();\n }, 30);\n }\n }\n };\n const topologicalSort = function (roots, getEdges, earlyStop) {\n const result = [];\n const visited = new Set();\n const stack = new Set();\n function traverseDependentNodes(node) {\n if (stack.has(node)) {\n throw CYCLE_DETECTED;\n }\n if (visited.has(node)) {\n return;\n }\n visited.add(node);\n stack.add(node);\n const dependentNodes = getEdges(node);\n if (earlyStop(node)) {\n stack.delete(node);\n return;\n }\n dependentNodes.forEach((dependent) => {\n traverseDependentNodes(dependent);\n });\n stack.delete(node);\n result.push(node);\n }\n roots.forEach((root) => {\n traverseDependentNodes(root);\n });\n return result;\n };\n const runUpdatedModule = function (id, factory, dependencyMap) {\n const mod = modules.get(id);\n if (mod == null) {\n throw new Error(\"[Refresh] Expected to find the module.\");\n }\n const { hot } = mod;\n if (!hot) {\n throw new Error(\"[Refresh] Expected module.hot to always exist in DEV.\");\n }\n if (hot._disposeCallback) {\n try {\n hot._disposeCallback();\n } catch (error) {\n console.error(\n `Error while calling dispose handler for module ${id}: `,\n error\n );\n }\n }\n if (factory) {\n mod.factory = factory;\n }\n if (dependencyMap) {\n mod.dependencyMap = dependencyMap;\n }\n mod.hasError = false;\n mod.error = undefined;\n mod.importedAll = EMPTY;\n mod.importedDefault = EMPTY;\n mod.isInitialized = false;\n const prevExports = mod.publicModule.exports;\n mod.publicModule.exports = {};\n hot._didAccept = false;\n hot._acceptCallback = null;\n hot._disposeCallback = null;\n metroRequire(id);\n if (mod.hasError) {\n mod.hasError = false;\n mod.isInitialized = true;\n mod.error = null;\n mod.publicModule.exports = prevExports;\n return true;\n }\n if (hot._acceptCallback) {\n try {\n hot._acceptCallback();\n } catch (error) {\n console.error(\n `Error while calling accept handler for module ${id}: `,\n error\n );\n }\n }\n return false;\n };\n const performFullRefresh = (reason, modules) => {\n if (\n typeof window !== \"undefined\" &&\n window.location != null &&\n typeof window.location.reload === \"function\"\n ) {\n window.location.reload();\n } else {\n const Refresh = requireRefresh();\n if (Refresh != null) {\n const sourceName = modules.source?.verboseName ?? \"unknown\";\n const failedName = modules.failed?.verboseName ?? \"unknown\";\n Refresh.performFullRefresh(\n `Fast Refresh - ${reason} <${sourceName}> <${failedName}>`\n );\n } else {\n console.warn(\"Could not reload the application after an edit.\");\n }\n }\n };\n var isReactRefreshBoundary = function (Refresh, moduleExports) {\n if (Refresh.isLikelyComponentType(moduleExports)) {\n return true;\n }\n if (moduleExports == null || typeof moduleExports !== \"object\") {\n return false;\n }\n let hasExports = false;\n let areAllExportsComponents = true;\n for (const key in moduleExports) {\n hasExports = true;\n if (key === \"__esModule\") {\n continue;\n }\n const desc = Object.getOwnPropertyDescriptor(moduleExports, key);\n if (desc && desc.get) {\n return false;\n }\n const exportValue = moduleExports[key];\n if (!Refresh.isLikelyComponentType(exportValue)) {\n areAllExportsComponents = false;\n }\n }\n return hasExports && areAllExportsComponents;\n };\n var shouldInvalidateReactRefreshBoundary = (\n Refresh,\n prevExports,\n nextExports\n ) => {\n const prevSignature = getRefreshBoundarySignature(Refresh, prevExports);\n const nextSignature = getRefreshBoundarySignature(Refresh, nextExports);\n if (prevSignature.length !== nextSignature.length) {\n return true;\n }\n for (let i = 0; i < nextSignature.length; i++) {\n if (prevSignature[i] !== nextSignature[i]) {\n return true;\n }\n }\n return false;\n };\n var getRefreshBoundarySignature = (Refresh, moduleExports) => {\n const signature = [];\n signature.push(Refresh.getFamilyByType(moduleExports));\n if (moduleExports == null || typeof moduleExports !== \"object\") {\n return signature;\n }\n for (const key in moduleExports) {\n if (key === \"__esModule\") {\n continue;\n }\n const desc = Object.getOwnPropertyDescriptor(moduleExports, key);\n if (desc && desc.get) {\n continue;\n }\n const exportValue = moduleExports[key];\n signature.push(key);\n signature.push(Refresh.getFamilyByType(exportValue));\n }\n return signature;\n };\n var registerExportsForReactRefresh = (Refresh, moduleExports, moduleID) => {\n Refresh.register(moduleExports, moduleID + \" %exports%\");\n if (moduleExports == null || typeof moduleExports !== \"object\") {\n return;\n }\n for (const key in moduleExports) {\n const desc = Object.getOwnPropertyDescriptor(moduleExports, key);\n if (desc && desc.get) {\n continue;\n }\n const exportValue = moduleExports[key];\n const typeID = moduleID + \" %exports% \" + key;\n Refresh.register(exportValue, typeID);\n }\n };\n global.__accept = metroHotUpdateModule;\n}\nif (__DEV__) {\n var requireSystrace = function requireSystrace() {\n return (\n global[__METRO_GLOBAL_PREFIX__ + \"__SYSTRACE\"] || metroRequire.Systrace\n );\n };\n var requireRefresh = function requireRefresh() {\n return (\n global[__METRO_GLOBAL_PREFIX__ + \"__ReactRefresh\"] || metroRequire.Refresh\n );\n };\n}\n","global.$$require_external = typeof window === \"undefined\" ? require : () => null;","//","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * @flow strict\n * @polyfill\n */\n\nlet _inGuard = 0;\n\ntype ErrorHandler = (error: mixed, isFatal: boolean) => void;\ntype Fn = (...Args) => Return;\n\n/**\n * This is the error handler that is called when we encounter an exception\n * when loading a module. This will report any errors encountered before\n * ExceptionsManager is configured.\n */\nlet _globalHandler: ErrorHandler = function onError(\n e: mixed,\n isFatal: boolean,\n) {\n throw e;\n};\n\n/**\n * The particular require runtime that we are using looks for a global\n * `ErrorUtils` object and if it exists, then it requires modules with the\n * error handler specified via ErrorUtils.setGlobalHandler by calling the\n * require function with applyWithGuard. Since the require module is loaded\n * before any of the modules, this ErrorUtils must be defined (and the handler\n * set) globally before requiring anything.\n */\nconst ErrorUtils = {\n setGlobalHandler(fun: ErrorHandler): void {\n _globalHandler = fun;\n },\n getGlobalHandler(): ErrorHandler {\n return _globalHandler;\n },\n reportError(error: mixed): void {\n _globalHandler && _globalHandler(error, false);\n },\n reportFatalError(error: mixed): void {\n // NOTE: This has an untyped call site in Metro.\n _globalHandler && _globalHandler(error, true);\n },\n applyWithGuard, TOut>(\n fun: Fn,\n context?: ?mixed,\n args?: ?TArgs,\n // Unused, but some code synced from www sets it to null.\n unused_onError?: null,\n // Some callers pass a name here, which we ignore.\n unused_name?: ?string,\n ): ?TOut {\n try {\n _inGuard++;\n /* $FlowFixMe[incompatible-call] : TODO T48204745 (1) apply(context,\n * null) is fine. (2) array -> rest array should work */\n /* $FlowFixMe[incompatible-type] : TODO T48204745 (1) apply(context,\n * null) is fine. (2) array -> rest array should work */\n return fun.apply(context, args);\n } catch (e) {\n ErrorUtils.reportError(e);\n } finally {\n _inGuard--;\n }\n return null;\n },\n applyWithGuardIfNeeded, TOut>(\n fun: Fn,\n context?: ?mixed,\n args?: ?TArgs,\n ): ?TOut {\n if (ErrorUtils.inGuard()) {\n /* $FlowFixMe[incompatible-call] : TODO T48204745 (1) apply(context,\n * null) is fine. (2) array -> rest array should work */\n /* $FlowFixMe[incompatible-type] : TODO T48204745 (1) apply(context,\n * null) is fine. (2) array -> rest array should work */\n return fun.apply(context, args);\n } else {\n ErrorUtils.applyWithGuard(fun, context, args);\n }\n return null;\n },\n inGuard(): boolean {\n return !!_inGuard;\n },\n guard, TOut>(\n fun: Fn,\n name?: ?string,\n context?: ?mixed,\n ): ?(...TArgs) => ?TOut {\n // TODO: (moti) T48204753 Make sure this warning is never hit and remove it - types\n // should be sufficient.\n if (typeof fun !== 'function') {\n console.warn('A function must be passed to ErrorUtils.guard, got ', fun);\n return null;\n }\n const guardName = name ?? fun.name ?? '';\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n function guarded(...args: TArgs): ?TOut {\n return ErrorUtils.applyWithGuard(\n fun,\n context ?? this,\n args,\n null,\n guardName,\n );\n }\n\n return guarded;\n },\n};\n\nglobal.ErrorUtils = ErrorUtils;\n\nexport type ErrorUtilsT = typeof ErrorUtils;\n","import 'expo-router/entry';\n","// `@expo/metro-runtime` MUST be the first import to ensure Fast Refresh works\n// on web.\nimport '@expo/metro-runtime';\n\nimport { App } from 'expo-router/build/qualified-entry';\nimport { renderRootComponent } from 'expo-router/build/renderRootComponent';\n\n// This file should only import and register the root. No components or exports\n// should be added here.\nrenderRootComponent(App);\n","\"use strict\";\n/**\n * Copyright © 2023 650 Industries.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nrequire(\"./location/install\");\n// IMPORT POSITION MATTERS FOR FAST REFRESH ON WEB\nrequire(\"./effects\");\n// vvv EVERYTHING ELSE vvv\nrequire(\"./async-require\");\n//# sourceMappingURL=index.js.map","//# sourceMappingURL=install.js.map","// Only during development.\nif (process.env.NODE_ENV !== 'production') {\n if (\n // Disable for SSR\n typeof window !== 'undefined') {\n require('./setupFastRefresh');\n require('./setupHMR');\n require('./messageSocket');\n }\n}\n//# sourceMappingURL=effects.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n/**\n * Copyright © 2022 650 Industries.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nconst buildAsyncRequire_1 = require(\"./buildAsyncRequire\");\n// @ts-ignore\nglobal[`${global.__METRO_GLOBAL_PREFIX__ ?? ''}__loadBundleAsync`] = (0, buildAsyncRequire_1.buildAsyncRequire)();\n//# sourceMappingURL=index.js.map","\"use strict\";\n/**\n * Copyright © 2022 650 Industries.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.buildAsyncRequire = void 0;\nconst loadBundle_1 = require(\"./loadBundle\");\n/** Create an `loadBundleAsync` function in the expected shape for Metro bundler. */\nfunction buildAsyncRequire() {\n const cache = new Map();\n return async function universal_loadBundleAsync(path) {\n if (cache.has(path)) {\n return cache.get(path);\n }\n const promise = (0, loadBundle_1.loadBundleAsync)(path).catch((error) => {\n cache.delete(path);\n throw error;\n });\n cache.set(path, promise);\n return promise;\n };\n}\nexports.buildAsyncRequire = buildAsyncRequire;\n//# sourceMappingURL=buildAsyncRequire.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.loadBundleAsync = void 0;\n/**\n * Copyright © 2022 650 Industries.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nconst buildUrlForBundle_1 = require(\"./buildUrlForBundle\");\nconst fetchThenEval_1 = require(\"./fetchThenEval\");\nlet pendingRequests = 0;\n/**\n * Load a bundle for a URL using fetch + eval on native and script tag injection on web.\n *\n * @param bundlePath Given a statement like `import('./Bacon')` `bundlePath` would be `Bacon.bundle?params=from-metro`.\n */\nasync function loadBundleAsync(bundlePath) {\n const requestUrl = (0, buildUrlForBundle_1.buildUrlForBundle)(bundlePath);\n if (process.env.NODE_ENV === 'production') {\n return (0, fetchThenEval_1.fetchThenEvalAsync)(requestUrl);\n }\n else {\n const LoadingView = require('../LoadingView')\n .default;\n if (process.env.EXPO_OS !== 'web') {\n // Send a signal to the `expo` package to show the loading indicator.\n LoadingView.showMessage('Downloading...', 'load');\n }\n pendingRequests++;\n return (0, fetchThenEval_1.fetchThenEvalAsync)(requestUrl)\n .then(() => {\n const HMRClient = require('../HMRClient').default;\n HMRClient.registerBundle(requestUrl);\n })\n .finally(() => {\n if (!--pendingRequests && process.env.EXPO_OS !== 'web') {\n LoadingView.hide();\n }\n });\n }\n}\nexports.loadBundleAsync = loadBundleAsync;\n//# sourceMappingURL=loadBundle.js.map","\"use strict\";\n/**\n * Copyright © 2022 650 Industries.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.buildUrlForBundle = void 0;\n/**\n * Given a path and some optional additional query parameters, create the dev server bundle URL.\n * @param bundlePath like `/foobar`\n * @param params like `{ platform: \"web\" }`\n * @returns a URL like \"/foobar.bundle?platform=android&modulesOnly=true&runModule=false&runtimeBytecodeVersion=null\"\n */\nfunction buildUrlForBundle(bundlePath) {\n if (bundlePath.match(/^https?:\\/\\//)) {\n return bundlePath;\n }\n // NOTE(EvanBacon): This must come from the window origin (at least in dev mode).\n // Otherwise Metro will crash from attempting to load a bundle that doesn't exist.\n return '/' + bundlePath.replace(/^\\/+/, '');\n}\nexports.buildUrlForBundle = buildUrlForBundle;\n//# sourceMappingURL=buildUrlForBundle.js.map","\"use strict\";\n/**\n * Copyright © 2022 650 Industries.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.fetchThenEvalAsync = void 0;\nconst currentSrc = typeof document !== 'undefined' && document.currentScript\n ? ('src' in document.currentScript && document.currentScript.src) || null\n : null;\n// Basically `__webpack_require__.l`.\nfunction fetchThenEvalAsync(url, { scriptType, nonce, crossOrigin, } = {}) {\n if (typeof window === 'undefined') {\n return require('./fetchThenEvalJs').fetchThenEvalAsync(url);\n }\n return new Promise((resolve, reject) => {\n const script = document.createElement('script');\n if (scriptType)\n script.type = scriptType;\n if (nonce)\n script.setAttribute('nonce', nonce);\n // script.setAttribute('data-expo-metro', ...);\n script.src = url;\n if (crossOrigin && script.src.indexOf(window.location.origin + '/') !== 0) {\n script.crossOrigin = crossOrigin;\n }\n script.onload = () => {\n script.parentNode && script.parentNode.removeChild(script);\n resolve();\n };\n // Create a new error object to preserve the original stack trace.\n const error = new AsyncRequireError();\n // Server error or network error.\n script.onerror = (ev) => {\n let event;\n if (typeof ev === 'string') {\n event = {\n type: 'error',\n target: {\n // @ts-expect-error\n src: event,\n },\n };\n }\n else {\n event = ev;\n }\n const errorType = event && (event.type === 'load' ? 'missing' : event.type);\n // @ts-expect-error\n const realSrc = event?.target?.src;\n error.message = 'Loading module ' + url + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n error.type = errorType;\n error.request = realSrc;\n script.parentNode && script.parentNode.removeChild(script);\n reject(error);\n };\n if (script.src === currentSrc) {\n // NOTE(kitten): We always prevent `fetchThenEval` from loading the \"current script\".\n // This points at our entrypoint bundle, and we should never reload and reevaluate the\n // entrypoint bundle\n resolve();\n }\n else {\n document.head.appendChild(script);\n }\n });\n}\nexports.fetchThenEvalAsync = fetchThenEvalAsync;\nclass AsyncRequireError extends Error {\n name = 'AsyncRequireError';\n type;\n request;\n}\n//# sourceMappingURL=fetchThenEval.web.js.map","\"use strict\";\n// The entry component (one that uses context modules) cannot be in the same file as the\n// entry side-effects, otherwise they'll be updated when files are added/removed from the\n// app directory. This will cause a lot of unfortunate errors regarding HMR and Fast Refresh.\n// This is because Fast Refresh is sending the entire file containing an updated component.\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.App = void 0;\n// This has to be the string \"expo-router/_ctx\" as we resolve the exact string to\n// a different file in a custom resolver for bundle splitting in Node.js.\nconst _ctx_1 = require(\"expo-router/_ctx\");\nconst react_1 = __importDefault(require(\"react\"));\nconst ExpoRoot_1 = require(\"./ExpoRoot\");\nconst head_1 = require(\"./head\");\n// Must be exported or Fast Refresh won't update the context\nfunction App() {\n return (\n \n );\n}\nexports.App = App;\n//# sourceMappingURL=qualified-entry.js.map","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.min.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\n","/**\n * @license React\n * react-jsx-runtime.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var f=require(\"react\"),k=Symbol.for(\"react.element\"),l=Symbol.for(\"react.fragment\"),m=Object.prototype.hasOwnProperty,n=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};\nfunction q(c,a,g){var b,d={},e=null,h=null;void 0!==g&&(e=\"\"+g);void 0!==a.key&&(e=\"\"+a.key);void 0!==a.ref&&(h=a.ref);for(b in a)m.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)void 0===d[b]&&(d[b]=a[b]);return{$$typeof:k,type:c,key:e,ref:h,props:d,_owner:n.current}}exports.Fragment=l;exports.jsx=q;exports.jsxs=q;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","/**\n * @license React\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var l=Symbol.for(\"react.element\"),n=Symbol.for(\"react.portal\"),p=Symbol.for(\"react.fragment\"),q=Symbol.for(\"react.strict_mode\"),r=Symbol.for(\"react.profiler\"),t=Symbol.for(\"react.provider\"),u=Symbol.for(\"react.context\"),v=Symbol.for(\"react.forward_ref\"),w=Symbol.for(\"react.suspense\"),x=Symbol.for(\"react.memo\"),y=Symbol.for(\"react.lazy\"),z=Symbol.iterator;function A(a){if(null===a||\"object\"!==typeof a)return null;a=z&&a[z]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nvar B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};\nE.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;\nH.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1 ({\n shouldShowAlert: true,\n shouldPlaySound: true,\n shouldSetBadge: true\n })\n });\n\nconst window = Dimensions.get(\"window\");\nconst screen = Dimensions.get(\"screen\");\n\nfunction App() {\n\n useGTMWeb() // google tag manager\n usePreventTranslation() // prevent translation\n\n\n const [dimensions, setDimensions] = useState({window, screen});\n const navigationRef = useNavigationContainerRef();\n const routeNameRef = useRef(\"\");\n\n if (__DEV__)\n useReduxDevToolsExtension(navigationRef);\n\n useEffect(() => {\n const subscription = Dimensions.addEventListener(\n \"change\",\n ({window, screen}) => {\n setDimensions({window, screen});\n }\n );\n return () => subscription?.remove();\n }, []);\n\n const [loaded] = useFonts({\n \"Owl-Cute\": require('@assets/fonts/Owl-Cute.ttf'),\n \"Montserrat-Black\": require('@assets/fonts/Montserrat-Black.ttf'),\n \"Montserrat-BlackItalic\": require('@assets/fonts/Montserrat-BlackItalic.ttf'),\n \"Montserrat-Bold\": require('@assets/fonts/Montserrat-Bold.ttf'),\n \"Montserrat-BoldItalic\": require('@assets/fonts/Montserrat-BoldItalic.ttf'),\n \"Montserrat-ExtraBold\": require('@assets/fonts/Montserrat-ExtraBold.ttf'),\n \"Montserrat-ExtraBoldItalic\": require('@assets/fonts/Montserrat-ExtraBoldItalic.ttf'),\n \"Montserrat-ExtraLight\": require('@assets/fonts/Montserrat-ExtraLight.ttf'),\n \"Montserrat-ExtraLightItalic\": require('@assets/fonts/Montserrat-ExtraLightItalic.ttf'),\n \"Montserrat-Italic\": require('@assets/fonts/Montserrat-Italic.ttf'),\n \"Montserrat-Light\": require('@assets/fonts/Montserrat-Light.ttf'),\n \"Montserrat-LightItalic\": require('@assets/fonts/Montserrat-LightItalic.ttf'),\n \"Montserrat-Medium\": require('@assets/fonts/Montserrat-Medium.ttf'),\n \"Montserrat-MediumItalic\": require('@assets/fonts/Montserrat-MediumItalic.ttf'),\n \"Montserrat-Regular\": require('@assets/fonts/Montserrat-Regular.ttf'),\n \"Montserrat-SemiBold\": require('@assets/fonts/Montserrat-SemiBold.ttf'),\n \"Montserrat-SemiBoldItalic\": require('@assets/fonts/Montserrat-SemiBoldItalic.ttf'),\n \"Montserrat-Thin\": require('@assets/fonts/Montserrat-Thin.ttf'),\n \"Montserrat-ThinItalic\": require('@assets/fonts/Montserrat-ThinItalic.ttf'),\n ...(IS_WEB ? {\n \"Ionicons\": require('react-native-vector-icons/Fonts/Ionicons.ttf'),\n \"FontAwesome\": require('react-native-vector-icons/Fonts/FontAwesome.ttf'),\n \"FontAwesome5_Brands\": require('react-native-vector-icons/Fonts/FontAwesome5_Brands.ttf'),\n \"FontAwesome5_Regular\": require('react-native-vector-icons/Fonts/FontAwesome5_Regular.ttf'),\n \"FontAwesome5_Solid\": require('react-native-vector-icons/Fonts/FontAwesome5_Solid.ttf'),\n \"FontAwesome6_Brands\": require('react-native-vector-icons/Fonts/FontAwesome6_Brands.ttf'),\n \"FontAwesome6_Regular\": require('react-native-vector-icons/Fonts/FontAwesome6_Regular.ttf'),\n \"FontAwesome6_Solid\": require('react-native-vector-icons/Fonts/FontAwesome6_Solid.ttf'),\n \"MaterialIcons\": require('react-native-vector-icons/Fonts/MaterialIcons.ttf'),\n \"Feather\": require('react-native-vector-icons/Fonts/Feather.ttf'),\n \"MaterialCommunityIcons\": require('react-native-vector-icons/Fonts/MaterialCommunityIcons.ttf')\n } : {})\n });\n\n if (!loaded && !IS_WEB) {\n return null;\n }\n\n const token = store.getState()?.data?.session?.object?.token\n\n // ** Configure axios to make requests\n axios.defaults.baseURL = API_URL\n if (token) axios.defaults.headers.common['Authorization'] = \"Bearer \" + token;\n\n if (IS_WEB) axios.defaults.withCredentials = true\n\n // ** Axios verbose\n const axiosVerbose = false\n if (axiosVerbose) {\n axios.interceptors.request.use(request => {\n console.log('Starting Request', JSON.stringify(request, null, 2))\n return request\n })\n\n axios.interceptors.response.use(response => {\n console.log('Response:', JSON.stringify(response, null, 2))\n return response\n }, error => {\n console.log('Error:', JSON.stringify(error, null, 2))\n return Promise.reject(error);\n })\n }\n\n // ** init abilities\n const userData = store.getState()?.data?.currentUser?.object\n const currentRoles = userData ? userData.roles : null\n const ability = new Ability(abilitiesForRoles(currentRoles) || initialAbility)\n\n // update abilities when role changes\n store.subscribe(() => {\n const prevRoles = currentRoles\n const userData = store.getState()?.data?.currentUser?.object\n const newRoles = userData ? userData.roles : null\n\n if (prevRoles !== newRoles) {\n ability.update(abilitiesForRoles(newRoles))\n }\n });\n\n const defaultRoutes = Object.values(navigationScreens)\n ?.reduce((pValue, cValue) => {\n return [...pValue, ...cValue]\n }, [])\n ?.reduce((pValue, cValue) => {\n return {...pValue, ...{[cValue?.name]: cValue?.name}}\n }, {})\n\n //Linking and routes on web\n const config = {\n initialRouteName: 'menu',\n screens: {\n ...defaultRoutes,\n menu: {\n screens: {\n \"dashboard\": 'menu/dashboard',\n \"schools\": 'menu/schools',\n \"tutor-resources\": 'menu/tutor-resources',\n \"students\": 'menu/students',\n \"activities-review\": 'menu/activities-review',\n \"admin-actions\": 'menu/admin-actions',\n \"referrals-backoffice\": 'menu/referrals-backoffice',\n \"live\": 'menu/live',\n \"finished-activities-live\": 'menu/finished-activities-live',\n \"live-students\": 'menu/live-students',\n \"live-activities-review\": 'menu/live-activities-review',\n \"live-tutor-resources\": 'menu/live-tutor-resources',\n \"home\": 'menu/home',\n \"finished-activities\": 'menu/finished-activities',\n \"skill-sets\": 'menu/skill-sets',\n \"rankings\": 'menu/rankings',\n \"tutor\": 'menu/tutor'\n }\n },\n \"not-found\": \"*\"\n }\n\n // screens: routes,\n // screens: {},\n };\n\n const linking = {\n prefixes: [prefix, \"https://app.masteur.com/\"],\n config\n };\n\n const width = Platform.OS !== 'web' ? dimensions?.window?.width : Dimensions.get('window').width > 800 ? dimensions?.window?.width * 2 / 3 : dimensions?.window?.width\n const height = Dimensions.get('window').height\n\n return (\n\n \n \n \n \n \n \n \n \n }}>\n \n `${options?.headerTitle ?? route?.name} - Masteur` + (Constants.expoConfig.extra.releaseStage === \"production\" ? \"\" : \" (\" + Constants.expoConfig.extra.releaseStage + \")\")\n }}\n ref={navigationRef}\n onReady={() => {\n routeNameRef.current = navigationRef.getCurrentRoute().name;\n }}\n onStateChange={async () => {\n const previousRouteName = routeNameRef.current;\n const currentRouteName = navigationRef.getCurrentRoute().name;\n const trackScreenView = (currentRouteName) => {\n // Your implementation of analytics goes here!\n if (userData) {\n const identifyObj = new amplitude.Identify();\n identifyObj.set('roles', userData?.roles);\n identifyObj.set('subscription_state', userData?.subscription_state?.status);\n amplitude.identify(identifyObj)\n amplitude.setUserId(userData?.email)\n setBugsnagUser(userData)\n }\n\n amplitude.track(\"screen.viewed.\" + currentRouteName)\n };\n\n if (previousRouteName !== currentRouteName) {\n // Save the current route name for later comparison\n routeNameRef.current = currentRouteName;\n\n // Replace the line below to add the tracker from a mobile analytics SDK\n trackScreenView(currentRouteName);\n }\n }}\n theme={theme}>\n \n {!IS_WEB ?\n \n \n \n \n \n \n \n \n \n \n : \n \n \n \n \n \n }\n \n \n \n \n \n \n \n \n \n\n );\n}\n\n// ** Error Boundary with Bugsnag\nexport default () => (!__DEV__) ? \n \n : ","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","import { initialize } from './init';\nexport { Directions } from './Directions';\nexport { State } from './State';\nexport { PointerType } from './PointerType';\nexport { default as gestureHandlerRootHOC } from './components/gestureHandlerRootHOC';\nexport { default as GestureHandlerRootView } from './components/GestureHandlerRootView';\nexport { MouseButton } from './handlers/gestureHandlerCommon';\nexport { TapGestureHandler } from './handlers/TapGestureHandler';\nexport { ForceTouchGestureHandler } from './handlers/ForceTouchGestureHandler';\nexport { LongPressGestureHandler } from './handlers/LongPressGestureHandler';\nexport { PanGestureHandler } from './handlers/PanGestureHandler';\nexport { PinchGestureHandler } from './handlers/PinchGestureHandler';\nexport { RotationGestureHandler } from './handlers/RotationGestureHandler';\nexport { FlingGestureHandler } from './handlers/FlingGestureHandler';\nexport { default as createNativeWrapper } from './handlers/createNativeWrapper';\nexport { GestureDetector } from './handlers/gestures/GestureDetector';\nexport { GestureObjects as Gesture } from './handlers/gestures/gestureObjects';\nexport { NativeViewGestureHandler } from './handlers/NativeViewGestureHandler';\nexport { RawButton, BaseButton, RectButton, BorderlessButton, PureNativeButton } from './components/GestureButtons';\nexport { TouchableHighlight, TouchableNativeFeedback, TouchableOpacity, TouchableWithoutFeedback } from './components/touchables';\nexport { ScrollView, Switch, TextInput, DrawerLayoutAndroid, FlatList, RefreshControl } from './components/GestureComponents';\nexport { HoverEffect } from './handlers/gestures/hoverGesture';\nexport { default as Swipeable } from './components/Swipeable';\nexport { default as DrawerLayout } from './components/DrawerLayout';\nexport { enableExperimentalWebImplementation, enableLegacyWebImplementation } from './EnableNewWebImplementation';\ninitialize();\n//# sourceMappingURL=index.js.map","import { startListening } from './handlers/gestures/eventReceiver';\nimport RNGestureHandlerModule from './RNGestureHandlerModule';\nimport { isFabric } from './utils';\nlet fabricInitialized = false;\nexport function initialize() {\n startListening();\n} // since isFabric() may give wrong results before the first render, we call this\n// method during render of GestureHandlerRootView\n\nexport function maybeInitializeFabric() {\n if (isFabric() && !fabricInitialized) {\n RNGestureHandlerModule.install();\n fabricInitialized = true;\n }\n}\n//# sourceMappingURL=init.js.map","import { DeviceEventEmitter } from 'react-native';\nimport { State } from '../../State';\nimport { TouchEventType } from '../../TouchEventType';\nimport { findHandler, findOldGestureHandler } from '../handlersRegistry';\nimport { GestureStateManager } from './gestureStateManager';\nlet gestureHandlerEventSubscription = null;\nlet gestureHandlerStateChangeEventSubscription = null;\nconst gestureStateManagers = new Map();\nconst lastUpdateEvent = [];\n\nfunction isStateChangeEvent(event) {\n // @ts-ignore oldState doesn't exist on GestureTouchEvent and that's the point\n return event.oldState != null;\n}\n\nfunction isTouchEvent(event) {\n return event.eventType != null;\n}\n\nexport function onGestureHandlerEvent(event) {\n var _handler$handlers7, _handler$handlers7$on, _handler$handlers8, _handler$handlers8$on, _handler$handlers9, _handler$handlers9$on, _handler$handlers10, _handler$handlers10$o;\n\n const handler = findHandler(event.handlerTag);\n\n if (handler) {\n if (isStateChangeEvent(event)) {\n if (event.oldState === State.UNDETERMINED && event.state === State.BEGAN) {\n var _handler$handlers$onB, _handler$handlers;\n\n (_handler$handlers$onB = (_handler$handlers = handler.handlers).onBegin) === null || _handler$handlers$onB === void 0 ? void 0 : _handler$handlers$onB.call(_handler$handlers, event);\n } else if ((event.oldState === State.BEGAN || event.oldState === State.UNDETERMINED) && event.state === State.ACTIVE) {\n var _handler$handlers$onS, _handler$handlers2;\n\n (_handler$handlers$onS = (_handler$handlers2 = handler.handlers).onStart) === null || _handler$handlers$onS === void 0 ? void 0 : _handler$handlers$onS.call(_handler$handlers2, event);\n lastUpdateEvent[handler.handlers.handlerTag] = event;\n } else if (event.oldState !== event.state && event.state === State.END) {\n var _handler$handlers$onF, _handler$handlers4;\n\n if (event.oldState === State.ACTIVE) {\n var _handler$handlers$onE, _handler$handlers3;\n\n (_handler$handlers$onE = (_handler$handlers3 = handler.handlers).onEnd) === null || _handler$handlers$onE === void 0 ? void 0 : _handler$handlers$onE.call(_handler$handlers3, event, true);\n }\n\n (_handler$handlers$onF = (_handler$handlers4 = handler.handlers).onFinalize) === null || _handler$handlers$onF === void 0 ? void 0 : _handler$handlers$onF.call(_handler$handlers4, event, true);\n lastUpdateEvent[handler.handlers.handlerTag] = undefined;\n } else if ((event.state === State.FAILED || event.state === State.CANCELLED) && event.oldState !== event.state) {\n var _handler$handlers$onF2, _handler$handlers6;\n\n if (event.oldState === State.ACTIVE) {\n var _handler$handlers$onE2, _handler$handlers5;\n\n (_handler$handlers$onE2 = (_handler$handlers5 = handler.handlers).onEnd) === null || _handler$handlers$onE2 === void 0 ? void 0 : _handler$handlers$onE2.call(_handler$handlers5, event, false);\n }\n\n (_handler$handlers$onF2 = (_handler$handlers6 = handler.handlers).onFinalize) === null || _handler$handlers$onF2 === void 0 ? void 0 : _handler$handlers$onF2.call(_handler$handlers6, event, false);\n gestureStateManagers.delete(event.handlerTag);\n lastUpdateEvent[handler.handlers.handlerTag] = undefined;\n }\n } else if (isTouchEvent(event)) {\n if (!gestureStateManagers.has(event.handlerTag)) {\n gestureStateManagers.set(event.handlerTag, GestureStateManager.create(event.handlerTag));\n } // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n\n\n const manager = gestureStateManagers.get(event.handlerTag);\n\n switch (event.eventType) {\n case TouchEventType.TOUCHES_DOWN:\n (_handler$handlers7 = handler.handlers) === null || _handler$handlers7 === void 0 ? void 0 : (_handler$handlers7$on = _handler$handlers7.onTouchesDown) === null || _handler$handlers7$on === void 0 ? void 0 : _handler$handlers7$on.call(_handler$handlers7, event, manager);\n break;\n\n case TouchEventType.TOUCHES_MOVE:\n (_handler$handlers8 = handler.handlers) === null || _handler$handlers8 === void 0 ? void 0 : (_handler$handlers8$on = _handler$handlers8.onTouchesMove) === null || _handler$handlers8$on === void 0 ? void 0 : _handler$handlers8$on.call(_handler$handlers8, event, manager);\n break;\n\n case TouchEventType.TOUCHES_UP:\n (_handler$handlers9 = handler.handlers) === null || _handler$handlers9 === void 0 ? void 0 : (_handler$handlers9$on = _handler$handlers9.onTouchesUp) === null || _handler$handlers9$on === void 0 ? void 0 : _handler$handlers9$on.call(_handler$handlers9, event, manager);\n break;\n\n case TouchEventType.TOUCHES_CANCELLED:\n (_handler$handlers10 = handler.handlers) === null || _handler$handlers10 === void 0 ? void 0 : (_handler$handlers10$o = _handler$handlers10.onTouchesCancelled) === null || _handler$handlers10$o === void 0 ? void 0 : _handler$handlers10$o.call(_handler$handlers10, event, manager);\n break;\n }\n } else {\n var _handler$handlers$onU, _handler$handlers11;\n\n (_handler$handlers$onU = (_handler$handlers11 = handler.handlers).onUpdate) === null || _handler$handlers$onU === void 0 ? void 0 : _handler$handlers$onU.call(_handler$handlers11, event);\n\n if (handler.handlers.onChange && handler.handlers.changeEventCalculator) {\n var _handler$handlers$onC, _handler$handlers12, _handler$handlers$cha, _handler$handlers13;\n\n (_handler$handlers$onC = (_handler$handlers12 = handler.handlers).onChange) === null || _handler$handlers$onC === void 0 ? void 0 : _handler$handlers$onC.call(_handler$handlers12, (_handler$handlers$cha = (_handler$handlers13 = handler.handlers).changeEventCalculator) === null || _handler$handlers$cha === void 0 ? void 0 : _handler$handlers$cha.call(_handler$handlers13, event, lastUpdateEvent[handler.handlers.handlerTag]));\n lastUpdateEvent[handler.handlers.handlerTag] = event;\n }\n }\n } else {\n const oldHandler = findOldGestureHandler(event.handlerTag);\n\n if (oldHandler) {\n const nativeEvent = {\n nativeEvent: event\n };\n\n if (isStateChangeEvent(event)) {\n oldHandler.onGestureStateChange(nativeEvent);\n } else {\n oldHandler.onGestureEvent(nativeEvent);\n }\n\n return;\n }\n }\n}\nexport function startListening() {\n stopListening();\n gestureHandlerEventSubscription = DeviceEventEmitter.addListener('onGestureHandlerEvent', onGestureHandlerEvent);\n gestureHandlerStateChangeEventSubscription = DeviceEventEmitter.addListener('onGestureHandlerStateChange', onGestureHandlerEvent);\n}\nexport function stopListening() {\n if (gestureHandlerEventSubscription) {\n gestureHandlerEventSubscription.remove();\n gestureHandlerEventSubscription = null;\n }\n\n if (gestureHandlerStateChangeEventSubscription) {\n gestureHandlerStateChangeEventSubscription.remove();\n gestureHandlerStateChangeEventSubscription = null;\n }\n}\n//# sourceMappingURL=eventReceiver.js.map","import RCTDeviceEventEmitter from '../../vendor/react-native/EventEmitter/RCTDeviceEventEmitter';\nexport default RCTDeviceEventEmitter;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport EventEmitter from '../vendor/emitter/EventEmitter';\n\n// FIXME: use typed events\n\n/**\n * Global EventEmitter used by the native platform to emit events to JavaScript.\n * Events are identified by globally unique event names.\n *\n * NativeModules that emit events should instead subclass `NativeEventEmitter`.\n */\nexport default new EventEmitter();","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n/**\n * EventEmitter manages listeners and publishes events to them.\n *\n * EventEmitter accepts a single type parameter that defines the valid events\n * and associated listener argument(s).\n *\n * @example\n *\n * const emitter = new EventEmitter<{\n * success: [number, string],\n * error: [Error],\n * }>();\n *\n * emitter.on('success', (statusCode, responseText) => {...});\n * emitter.emit('success', 200, '...');\n *\n * emitter.on('error', error => {...});\n * emitter.emit('error', new Error('Resource not found'));\n *\n */\nexport default class EventEmitter {\n constructor() {\n this._registry = {};\n }\n /**\n * Registers a listener that is called when the supplied event is emitted.\n * Returns a subscription that has a `remove` method to undo registration.\n */\n addListener(eventType, listener, context) {\n var registrations = allocate(this._registry, eventType);\n var registration = {\n context,\n listener,\n remove() {\n registrations.delete(registration);\n }\n };\n registrations.add(registration);\n return registration;\n }\n\n /**\n * Emits the supplied event. Additional arguments supplied to `emit` will be\n * passed through to each of the registered listeners.\n *\n * If a listener modifies the listeners registered for the same event, those\n * changes will not be reflected in the current invocation of `emit`.\n */\n emit(eventType) {\n var registrations = this._registry[eventType];\n if (registrations != null) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n for (var _i = 0, _arr = [...registrations]; _i < _arr.length; _i++) {\n var registration = _arr[_i];\n registration.listener.apply(registration.context, args);\n }\n }\n }\n\n /**\n * Removes all registered listeners.\n */\n removeAllListeners(eventType) {\n if (eventType == null) {\n this._registry = {};\n } else {\n delete this._registry[eventType];\n }\n }\n\n /**\n * Returns the number of registered listeners for the supplied event.\n */\n listenerCount(eventType) {\n var registrations = this._registry[eventType];\n return registrations == null ? 0 : registrations.size;\n }\n}\nfunction allocate(registry, eventType) {\n var registrations = registry[eventType];\n if (registrations == null) {\n registrations = new Set();\n registry[eventType] = registrations;\n }\n return registrations;\n}","// TODO use State from RNModule\nexport const State = {\n UNDETERMINED: 0,\n FAILED: 1,\n BEGAN: 2,\n CANCELLED: 3,\n ACTIVE: 4,\n END: 5\n}; // eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; it can be used as a type and as a value\n//# sourceMappingURL=State.js.map","export const TouchEventType = {\n UNDETERMINED: 0,\n TOUCHES_DOWN: 1,\n TOUCHES_MOVE: 2,\n TOUCHES_UP: 3,\n TOUCHES_CANCELLED: 4\n}; // eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; it can be used as a type and as a value\n//# sourceMappingURL=TouchEventType.js.map","import { isJestEnv } from '../utils';\nexport const handlerIDToTag = {};\nconst gestures = new Map();\nconst oldHandlers = new Map();\nconst testIDs = new Map();\nlet handlerTag = 1;\nexport function getNextHandlerTag() {\n return handlerTag++;\n}\nexport function registerHandler(handlerTag, handler, testID) {\n gestures.set(handlerTag, handler);\n\n if (isJestEnv() && testID) {\n testIDs.set(testID, handlerTag);\n }\n}\nexport function registerOldGestureHandler(handlerTag, handler) {\n oldHandlers.set(handlerTag, handler);\n}\nexport function unregisterHandler(handlerTag, testID) {\n gestures.delete(handlerTag);\n\n if (isJestEnv() && testID) {\n testIDs.delete(testID);\n }\n}\nexport function findHandler(handlerTag) {\n return gestures.get(handlerTag);\n}\nexport function findOldGestureHandler(handlerTag) {\n return oldHandlers.get(handlerTag);\n}\nexport function findHandlerByTestID(testID) {\n const handlerTag = testIDs.get(testID);\n\n if (handlerTag !== undefined) {\n var _findHandler;\n\n return (_findHandler = findHandler(handlerTag)) !== null && _findHandler !== void 0 ? _findHandler : null;\n }\n\n return null;\n}\n//# sourceMappingURL=handlersRegistry.js.map","export function toArray(object) {\n if (!Array.isArray(object)) {\n return [object];\n }\n\n return object;\n}\nexport function withPrevAndCurrent(array, mapFn) {\n const previousArr = [null];\n const currentArr = [...array];\n const transformedArr = [];\n currentArr.forEach((current, i) => {\n // This type cast is fine and solves problem mentioned in https://github.com/software-mansion/react-native-gesture-handler/pull/2867 (namely that `previous` can be undefined).\n // Unfortunately, linter on our CI does not allow this type of casting as it is unnecessary. To bypass that we use eslint-disable.\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion\n const previous = previousArr[i];\n const transformed = mapFn(previous, current);\n previousArr.push(transformed);\n transformedArr.push(transformed);\n });\n return transformedArr;\n} // eslint-disable-next-line @typescript-eslint/ban-types\n\nexport function hasProperty(object, key) {\n return Object.prototype.hasOwnProperty.call(object, key);\n}\nexport function isJestEnv() {\n // @ts-ignore Do not use `@types/node` because it will prioritise Node types over RN types which breaks the types (ex. setTimeout) in React Native projects.\n return hasProperty(global, 'process') && !!process.env.JEST_WORKER_ID;\n}\nexport function tagMessage(msg) {\n return `[react-native-gesture-handler] ${msg}`;\n} // helper method to check whether Fabric is enabled, however global.nativeFabricUIManager\n// may not be initialized before the first render\n\nexport function isFabric() {\n var _global;\n\n // @ts-expect-error nativeFabricUIManager is not yet included in the RN types\n return !!((_global = global) !== null && _global !== void 0 && _global.nativeFabricUIManager);\n}\nexport function isRemoteDebuggingEnabled() {\n // react-native-reanimated checks if in remote debugging in the same way\n // @ts-ignore global is available but node types are not included\n const localGlobal = global;\n return (!localGlobal.nativeCallSyncHook || !!localGlobal.__REMOTEDEV__) && !localGlobal.RN$Bridgeless;\n}\n//# sourceMappingURL=utils.js.map","import NodeManager from '../../web/tools/NodeManager';\nexport const GestureStateManager = {\n create(handlerTag) {\n return {\n begin: () => {\n NodeManager.getHandler(handlerTag).begin();\n },\n activate: () => {\n NodeManager.getHandler(handlerTag).activate(true);\n },\n fail: () => {\n NodeManager.getHandler(handlerTag).fail();\n },\n end: () => {\n NodeManager.getHandler(handlerTag).end();\n }\n };\n }\n\n};\n//# sourceMappingURL=gestureStateManager.web.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// eslint-disable-next-line @typescript-eslint/no-extraneous-class\nexport default class NodeManager {\n static getHandler(tag) {\n if (tag in this.gestures) {\n return this.gestures[tag];\n }\n\n throw new Error(`No handler for tag ${tag}`);\n }\n\n static createGestureHandler(handlerTag, handler) {\n if (handlerTag in this.gestures) {\n throw new Error(`Handler with tag ${handlerTag} already exists. Please ensure that no Gesture instance is used across multiple GestureDetectors.`);\n }\n\n this.gestures[handlerTag] = handler;\n this.gestures[handlerTag].setTag(handlerTag);\n }\n\n static dropGestureHandler(handlerTag) {\n if (!(handlerTag in this.gestures)) {\n return;\n }\n\n this.gestures[handlerTag].onDestroy(); // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n\n delete this.gestures[handlerTag];\n }\n\n static getNodes() {\n return { ...this.gestures\n };\n }\n\n}\n\n_defineProperty(NodeManager, \"gestures\", {});\n//# sourceMappingURL=NodeManager.js.map","import React from 'react';\nimport { isNewWebImplementationEnabled } from './EnableNewWebImplementation';\nimport { Gestures, HammerGestures } from './web/Gestures';\nimport InteractionManager from './web/tools/InteractionManager';\nimport NodeManager from './web/tools/NodeManager';\nimport * as HammerNodeManager from './web_hammer/NodeManager';\nimport { GestureHandlerWebDelegate } from './web/tools/GestureHandlerWebDelegate';\nexport default {\n handleSetJSResponder(tag, blockNativeResponder) {\n console.warn('handleSetJSResponder: ', tag, blockNativeResponder);\n },\n\n handleClearJSResponder() {\n console.warn('handleClearJSResponder: ');\n },\n\n createGestureHandler(handlerName, handlerTag, config) {\n if (isNewWebImplementationEnabled()) {\n if (!(handlerName in Gestures)) {\n throw new Error(`react-native-gesture-handler: ${handlerName} is not supported on web.`);\n }\n\n const GestureClass = Gestures[handlerName];\n NodeManager.createGestureHandler(handlerTag, new GestureClass(new GestureHandlerWebDelegate()));\n InteractionManager.getInstance().configureInteractions(NodeManager.getHandler(handlerTag), config);\n } else {\n if (!(handlerName in HammerGestures)) {\n throw new Error(`react-native-gesture-handler: ${handlerName} is not supported on web.`);\n } // @ts-ignore If it doesn't exist, the error is thrown\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\n\n const GestureClass = HammerGestures[handlerName]; // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n\n HammerNodeManager.createGestureHandler(handlerTag, new GestureClass());\n }\n\n this.updateGestureHandler(handlerTag, config);\n },\n\n attachGestureHandler(handlerTag, // eslint-disable-next-line @typescript-eslint/no-explicit-any\n newView, _actionType, propsRef) {\n if (!(newView instanceof HTMLElement || newView instanceof React.Component)) {\n return;\n }\n\n if (isNewWebImplementationEnabled()) {\n //@ts-ignore Types should be HTMLElement or React.Component\n NodeManager.getHandler(handlerTag).init(newView, propsRef);\n } else {\n //@ts-ignore Types should be HTMLElement or React.Component\n HammerNodeManager.getHandler(handlerTag).setView(newView, propsRef);\n }\n },\n\n updateGestureHandler(handlerTag, newConfig) {\n if (isNewWebImplementationEnabled()) {\n NodeManager.getHandler(handlerTag).updateGestureConfig(newConfig);\n InteractionManager.getInstance().configureInteractions(NodeManager.getHandler(handlerTag), newConfig);\n } else {\n HammerNodeManager.getHandler(handlerTag).updateGestureConfig(newConfig);\n }\n },\n\n getGestureHandlerNode(handlerTag) {\n if (isNewWebImplementationEnabled()) {\n return NodeManager.getHandler(handlerTag);\n } else {\n return HammerNodeManager.getHandler(handlerTag);\n }\n },\n\n dropGestureHandler(handlerTag) {\n if (isNewWebImplementationEnabled()) {\n NodeManager.dropGestureHandler(handlerTag);\n } else {\n HammerNodeManager.dropGestureHandler(handlerTag);\n }\n },\n\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n flushOperations() {}\n\n};\n//# sourceMappingURL=RNGestureHandlerModule.web.js.map","import { Platform } from 'react-native';\nlet useNewWebImplementation = true;\nlet getWasCalled = false;\nexport function enableExperimentalWebImplementation(_shouldEnable = true) {// NO-OP since the new implementation is now the default\n}\nexport function enableLegacyWebImplementation(shouldUseLegacyImplementation = true) {\n if (Platform.OS !== 'web' || useNewWebImplementation === !shouldUseLegacyImplementation) {\n return;\n }\n\n if (getWasCalled) {\n console.error('Some parts of this application have already started using the new gesture handler implementation. No changes will be applied. You can try enabling legacy implementation earlier.');\n return;\n }\n\n useNewWebImplementation = !shouldUseLegacyImplementation;\n}\nexport function isNewWebImplementationEnabled() {\n getWasCalled = true;\n return useNewWebImplementation;\n}\n//# sourceMappingURL=EnableNewWebImplementation.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar Platform = {\n OS: 'web',\n select: obj => 'web' in obj ? obj.web : obj.default,\n get isTesting() {\n if (process.env.NODE_ENV === 'test') {\n return true;\n }\n return false;\n }\n};\nexport default Platform;","// Gesture Handlers\nimport PanGestureHandler from './handlers/PanGestureHandler';\nimport TapGestureHandler from './handlers/TapGestureHandler';\nimport LongPressGestureHandler from './handlers/LongPressGestureHandler';\nimport PinchGestureHandler from './handlers/PinchGestureHandler';\nimport RotationGestureHandler from './handlers/RotationGestureHandler';\nimport FlingGestureHandler from './handlers/FlingGestureHandler';\nimport NativeViewGestureHandler from './handlers/NativeViewGestureHandler';\nimport ManualGestureHandler from './handlers/ManualGestureHandler';\nimport HoverGestureHandler from './handlers/HoverGestureHandler'; //Hammer Handlers\n\nimport HammerNativeViewGestureHandler from '../web_hammer/NativeViewGestureHandler';\nimport HammerPanGestureHandler from '../web_hammer/PanGestureHandler';\nimport HammerTapGestureHandler from '../web_hammer/TapGestureHandler';\nimport HammerLongPressGestureHandler from '../web_hammer/LongPressGestureHandler';\nimport HammerPinchGestureHandler from '../web_hammer/PinchGestureHandler';\nimport HammerRotationGestureHandler from '../web_hammer/RotationGestureHandler';\nimport HammerFlingGestureHandler from '../web_hammer/FlingGestureHandler';\nexport const Gestures = {\n NativeViewGestureHandler,\n PanGestureHandler,\n TapGestureHandler,\n LongPressGestureHandler,\n PinchGestureHandler,\n RotationGestureHandler,\n FlingGestureHandler,\n ManualGestureHandler,\n HoverGestureHandler\n};\nexport const HammerGestures = {\n NativeViewGestureHandler: HammerNativeViewGestureHandler,\n PanGestureHandler: HammerPanGestureHandler,\n TapGestureHandler: HammerTapGestureHandler,\n LongPressGestureHandler: HammerLongPressGestureHandler,\n PinchGestureHandler: HammerPinchGestureHandler,\n RotationGestureHandler: HammerRotationGestureHandler,\n FlingGestureHandler: HammerFlingGestureHandler\n};\n//# sourceMappingURL=Gestures.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { State } from '../../State';\nimport { DEFAULT_TOUCH_SLOP } from '../constants';\nimport GestureHandler from './GestureHandler';\nconst DEFAULT_MIN_POINTERS = 1;\nconst DEFAULT_MAX_POINTERS = 10;\nconst DEFAULT_MIN_DIST_SQ = DEFAULT_TOUCH_SLOP * DEFAULT_TOUCH_SLOP;\nexport default class PanGestureHandler extends GestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"customActivationProperties\", ['activeOffsetXStart', 'activeOffsetXEnd', 'failOffsetXStart', 'failOffsetXEnd', 'activeOffsetYStart', 'activeOffsetYEnd', 'failOffsetYStart', 'failOffsetYEnd', 'minVelocityX', 'minVelocityY', 'minVelocity']);\n\n _defineProperty(this, \"velocityX\", 0);\n\n _defineProperty(this, \"velocityY\", 0);\n\n _defineProperty(this, \"minDistSq\", DEFAULT_MIN_DIST_SQ);\n\n _defineProperty(this, \"activeOffsetXStart\", -Number.MAX_SAFE_INTEGER);\n\n _defineProperty(this, \"activeOffsetXEnd\", Number.MIN_SAFE_INTEGER);\n\n _defineProperty(this, \"failOffsetXStart\", Number.MIN_SAFE_INTEGER);\n\n _defineProperty(this, \"failOffsetXEnd\", Number.MAX_SAFE_INTEGER);\n\n _defineProperty(this, \"activeOffsetYStart\", Number.MAX_SAFE_INTEGER);\n\n _defineProperty(this, \"activeOffsetYEnd\", Number.MIN_SAFE_INTEGER);\n\n _defineProperty(this, \"failOffsetYStart\", Number.MIN_SAFE_INTEGER);\n\n _defineProperty(this, \"failOffsetYEnd\", Number.MAX_SAFE_INTEGER);\n\n _defineProperty(this, \"minVelocityX\", Number.MAX_SAFE_INTEGER);\n\n _defineProperty(this, \"minVelocityY\", Number.MAX_SAFE_INTEGER);\n\n _defineProperty(this, \"minVelocitySq\", Number.MAX_SAFE_INTEGER);\n\n _defineProperty(this, \"minPointers\", DEFAULT_MIN_POINTERS);\n\n _defineProperty(this, \"maxPointers\", DEFAULT_MAX_POINTERS);\n\n _defineProperty(this, \"startX\", 0);\n\n _defineProperty(this, \"startY\", 0);\n\n _defineProperty(this, \"offsetX\", 0);\n\n _defineProperty(this, \"offsetY\", 0);\n\n _defineProperty(this, \"lastX\", 0);\n\n _defineProperty(this, \"lastY\", 0);\n\n _defineProperty(this, \"activateAfterLongPress\", 0);\n\n _defineProperty(this, \"activationTimeout\", 0);\n }\n\n init(ref, propsRef) {\n super.init(ref, propsRef);\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n this.resetConfig();\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n this.checkCustomActivationCriteria(this.customActivationProperties);\n\n if (this.config.minDist !== undefined) {\n this.minDistSq = this.config.minDist * this.config.minDist;\n } else if (this.hasCustomActivationCriteria) {\n this.minDistSq = Number.MAX_SAFE_INTEGER;\n }\n\n if (this.config.minPointers !== undefined) {\n this.minPointers = this.config.minPointers;\n }\n\n if (this.config.maxPointers !== undefined) {\n this.maxPointers = this.config.maxPointers;\n }\n\n if (this.config.minVelocity !== undefined) {\n this.minVelocityX = this.config.minVelocity;\n this.minVelocityY = this.config.minVelocity;\n }\n\n if (this.config.minVelocityX !== undefined) {\n this.minVelocityX = this.config.minVelocityX;\n }\n\n if (this.config.minVelocityY !== undefined) {\n this.minVelocityY = this.config.minVelocityY;\n }\n\n if (this.config.activateAfterLongPress !== undefined) {\n this.activateAfterLongPress = this.config.activateAfterLongPress;\n }\n\n if (this.config.activeOffsetXStart !== undefined) {\n this.activeOffsetXStart = this.config.activeOffsetXStart;\n\n if (this.config.activeOffsetXEnd === undefined) {\n this.activeOffsetXEnd = Number.MAX_SAFE_INTEGER;\n }\n }\n\n if (this.config.activeOffsetXEnd !== undefined) {\n this.activeOffsetXEnd = this.config.activeOffsetXEnd;\n\n if (this.config.activeOffsetXStart === undefined) {\n this.activeOffsetXStart = Number.MIN_SAFE_INTEGER;\n }\n }\n\n if (this.config.failOffsetXStart !== undefined) {\n this.failOffsetXStart = this.config.failOffsetXStart;\n\n if (this.config.failOffsetXEnd === undefined) {\n this.failOffsetXEnd = Number.MAX_SAFE_INTEGER;\n }\n }\n\n if (this.config.failOffsetXEnd !== undefined) {\n this.failOffsetXEnd = this.config.failOffsetXEnd;\n\n if (this.config.failOffsetXStart === undefined) {\n this.failOffsetXStart = Number.MIN_SAFE_INTEGER;\n }\n }\n\n if (this.config.activeOffsetYStart !== undefined) {\n this.activeOffsetYStart = this.config.activeOffsetYStart;\n\n if (this.config.activeOffsetYEnd === undefined) {\n this.activeOffsetYEnd = Number.MAX_SAFE_INTEGER;\n }\n }\n\n if (this.config.activeOffsetYEnd !== undefined) {\n this.activeOffsetYEnd = this.config.activeOffsetYEnd;\n\n if (this.config.activeOffsetYStart === undefined) {\n this.activeOffsetYStart = Number.MIN_SAFE_INTEGER;\n }\n }\n\n if (this.config.failOffsetYStart !== undefined) {\n this.failOffsetYStart = this.config.failOffsetYStart;\n\n if (this.config.failOffsetYEnd === undefined) {\n this.failOffsetYEnd = Number.MAX_SAFE_INTEGER;\n }\n }\n\n if (this.config.failOffsetYEnd !== undefined) {\n this.failOffsetYEnd = this.config.failOffsetYEnd;\n\n if (this.config.failOffsetYStart === undefined) {\n this.failOffsetYStart = Number.MIN_SAFE_INTEGER;\n }\n }\n }\n\n resetConfig() {\n super.resetConfig();\n this.activeOffsetXStart = -Number.MAX_SAFE_INTEGER;\n this.activeOffsetXEnd = Number.MIN_SAFE_INTEGER;\n this.failOffsetXStart = Number.MIN_SAFE_INTEGER;\n this.failOffsetXEnd = Number.MAX_SAFE_INTEGER;\n this.activeOffsetYStart = Number.MAX_SAFE_INTEGER;\n this.activeOffsetYEnd = Number.MIN_SAFE_INTEGER;\n this.failOffsetYStart = Number.MIN_SAFE_INTEGER;\n this.failOffsetYEnd = Number.MAX_SAFE_INTEGER;\n this.minVelocityX = Number.MAX_SAFE_INTEGER;\n this.minVelocityY = Number.MAX_SAFE_INTEGER;\n this.minVelocitySq = Number.MAX_SAFE_INTEGER;\n this.minDistSq = DEFAULT_MIN_DIST_SQ;\n this.minPointers = DEFAULT_MIN_POINTERS;\n this.maxPointers = DEFAULT_MAX_POINTERS;\n this.activateAfterLongPress = 0;\n }\n\n transformNativeEvent() {\n const translationX = this.getTranslationX();\n const translationY = this.getTranslationY();\n return { ...super.transformNativeEvent(),\n translationX: isNaN(translationX) ? 0 : translationX,\n translationY: isNaN(translationY) ? 0 : translationY,\n velocityX: this.velocityX,\n velocityY: this.velocityY\n };\n }\n\n getTranslationX() {\n return this.lastX - this.startX + this.offsetX;\n }\n\n getTranslationY() {\n return this.lastY - this.startY + this.offsetY;\n }\n\n clearActivationTimeout() {\n clearTimeout(this.activationTimeout);\n } //EventsHandling\n\n\n onPointerDown(event) {\n if (!this.isButtonInConfig(event.button)) {\n return;\n }\n\n this.tracker.addToTracker(event);\n super.onPointerDown(event);\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.startX = this.lastX;\n this.startY = this.lastY;\n this.tryBegin(event);\n this.checkBegan();\n }\n\n onPointerAdd(event) {\n this.tracker.addToTracker(event);\n super.onPointerAdd(event);\n this.tryBegin(event);\n this.offsetX += this.lastX - this.startX;\n this.offsetY += this.lastY - this.startY;\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.startX = this.lastX;\n this.startY = this.lastY;\n\n if (this.tracker.getTrackedPointersCount() > this.maxPointers) {\n if (this.currentState === State.ACTIVE) {\n this.cancel();\n } else {\n this.fail();\n }\n } else {\n this.checkBegan();\n }\n }\n\n onPointerUp(event) {\n super.onPointerUp(event);\n\n if (this.currentState === State.ACTIVE) {\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n }\n\n this.tracker.removeFromTracker(event.pointerId);\n\n if (this.currentState === State.ACTIVE) {\n this.end();\n } else {\n this.resetProgress();\n this.fail();\n }\n }\n\n onPointerRemove(event) {\n super.onPointerRemove(event);\n this.tracker.removeFromTracker(event.pointerId);\n this.offsetX += this.lastX - this.startX;\n this.offsetY += this.lastY - this.startY;\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.startX = this.lastX;\n this.startY = this.lastY;\n\n if (!(this.currentState === State.ACTIVE && this.tracker.getTrackedPointersCount() < this.minPointers)) {\n this.checkBegan();\n }\n }\n\n onPointerMove(event) {\n this.tracker.track(event);\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.velocityX = this.tracker.getVelocityX(event.pointerId);\n this.velocityY = this.tracker.getVelocityY(event.pointerId);\n this.checkBegan();\n super.onPointerMove(event);\n }\n\n onPointerOutOfBounds(event) {\n if (this.getShouldCancelWhenOutside()) {\n return;\n }\n\n this.tracker.track(event);\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.velocityX = this.tracker.getVelocityX(event.pointerId);\n this.velocityY = this.tracker.getVelocityY(event.pointerId);\n this.checkBegan();\n\n if (this.currentState === State.ACTIVE) {\n super.onPointerOutOfBounds(event);\n }\n }\n\n shouldActivate() {\n const dx = this.getTranslationX();\n\n if (this.activeOffsetXStart !== Number.MAX_SAFE_INTEGER && dx < this.activeOffsetXStart) {\n return true;\n }\n\n if (this.activeOffsetXEnd !== Number.MIN_SAFE_INTEGER && dx > this.activeOffsetXEnd) {\n return true;\n }\n\n const dy = this.getTranslationY();\n\n if (this.activeOffsetYStart !== Number.MAX_SAFE_INTEGER && dy < this.activeOffsetYStart) {\n return true;\n }\n\n if (this.activeOffsetYEnd !== Number.MIN_SAFE_INTEGER && dy > this.activeOffsetYEnd) {\n return true;\n }\n\n const distanceSq = dx * dx + dy * dy;\n\n if (this.minDistSq !== Number.MAX_SAFE_INTEGER && distanceSq >= this.minDistSq) {\n return true;\n }\n\n const vx = this.velocityX;\n\n if (this.minVelocityX !== Number.MAX_SAFE_INTEGER && (this.minVelocityX < 0 && vx <= this.minVelocityX || this.minVelocityX >= 0 && this.minVelocityX <= vx)) {\n return true;\n }\n\n const vy = this.velocityY;\n\n if (this.minVelocityY !== Number.MAX_SAFE_INTEGER && (this.minVelocityY < 0 && vy <= this.minVelocityY || this.minVelocityY >= 0 && this.minVelocityY <= vy)) {\n return true;\n }\n\n const velocitySq = vx * vx + vy * vy;\n return this.minVelocitySq !== Number.MAX_SAFE_INTEGER && velocitySq >= this.minVelocitySq;\n }\n\n shouldFail() {\n const dx = this.getTranslationX();\n const dy = this.getTranslationY();\n const distanceSq = dx * dx + dy * dy;\n\n if (this.activateAfterLongPress > 0 && distanceSq > DEFAULT_MIN_DIST_SQ) {\n this.clearActivationTimeout();\n return true;\n }\n\n if (this.failOffsetXStart !== Number.MIN_SAFE_INTEGER && dx < this.failOffsetXStart) {\n return true;\n }\n\n if (this.failOffsetXEnd !== Number.MAX_SAFE_INTEGER && dx > this.failOffsetXEnd) {\n return true;\n }\n\n if (this.failOffsetYStart !== Number.MIN_SAFE_INTEGER && dy < this.failOffsetYStart) {\n return true;\n }\n\n return this.failOffsetYEnd !== Number.MAX_SAFE_INTEGER && dy > this.failOffsetYEnd;\n }\n\n tryBegin(event) {\n if (this.currentState === State.UNDETERMINED && this.tracker.getTrackedPointersCount() >= this.minPointers) {\n this.resetProgress();\n this.offsetX = 0;\n this.offsetY = 0;\n this.velocityX = 0;\n this.velocityY = 0;\n this.begin();\n\n if (this.activateAfterLongPress > 0) {\n this.activationTimeout = setTimeout(() => {\n this.activate();\n }, this.activateAfterLongPress);\n }\n } else {\n this.velocityX = this.tracker.getVelocityX(event.pointerId);\n this.velocityY = this.tracker.getVelocityY(event.pointerId);\n }\n }\n\n checkBegan() {\n if (this.currentState === State.BEGAN) {\n if (this.shouldFail()) {\n this.fail();\n } else if (this.shouldActivate()) {\n this.activate();\n }\n }\n }\n\n activate(force = false) {\n if (this.currentState !== State.ACTIVE) {\n this.resetProgress();\n }\n\n super.activate(force);\n }\n\n onCancel() {\n this.clearActivationTimeout();\n }\n\n onReset() {\n this.clearActivationTimeout();\n }\n\n resetProgress() {\n if (this.currentState === State.ACTIVE) {\n return;\n }\n\n this.startX = this.lastX;\n this.startY = this.lastY;\n }\n\n}\n//# sourceMappingURL=PanGestureHandler.js.map","function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nmodule.exports = _objectWithoutPropertiesLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","export const DEFAULT_TOUCH_SLOP = 15;\nexport const MINIMAL_FLING_VELOCITY = 0.1;\n//# sourceMappingURL=constants.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/* eslint-disable @typescript-eslint/no-empty-function */\nimport { State } from '../../State';\nimport { TouchEventType, EventTypes } from '../interfaces';\nimport GestureHandlerOrchestrator from '../tools/GestureHandlerOrchestrator';\nimport InteractionManager from '../tools/InteractionManager';\nimport PointerTracker from '../tools/PointerTracker';\nimport { MouseButton } from '../../handlers/gestureHandlerCommon';\nimport { PointerType } from '../../PointerType';\nexport default class GestureHandler {\n // Orchestrator properties\n constructor(delegate) {\n _defineProperty(this, \"lastSentState\", null);\n\n _defineProperty(this, \"currentState\", State.UNDETERMINED);\n\n _defineProperty(this, \"shouldCancelWhenOutside\", false);\n\n _defineProperty(this, \"hasCustomActivationCriteria\", false);\n\n _defineProperty(this, \"enabled\", false);\n\n _defineProperty(this, \"viewRef\", void 0);\n\n _defineProperty(this, \"propsRef\", void 0);\n\n _defineProperty(this, \"handlerTag\", void 0);\n\n _defineProperty(this, \"config\", {\n enabled: false\n });\n\n _defineProperty(this, \"tracker\", new PointerTracker());\n\n _defineProperty(this, \"activationIndex\", 0);\n\n _defineProperty(this, \"awaiting\", false);\n\n _defineProperty(this, \"active\", false);\n\n _defineProperty(this, \"shouldResetProgress\", false);\n\n _defineProperty(this, \"pointerType\", PointerType.MOUSE);\n\n _defineProperty(this, \"delegate\", void 0);\n\n _defineProperty(this, \"sendEvent\", (newState, oldState) => {\n const {\n onGestureHandlerEvent,\n onGestureHandlerStateChange\n } = this.propsRef.current;\n const resultEvent = this.transformEventData(newState, oldState); // In the new API oldState field has to be undefined, unless we send event state changed\n // Here the order is flipped to avoid workarounds such as making backup of the state and setting it to undefined first, then changing it back\n // Flipping order with setting oldState to undefined solves issue, when events were being sent twice instead of once\n // However, this may cause trouble in the future (but for now we don't know that)\n\n if (this.lastSentState !== newState) {\n this.lastSentState = newState;\n invokeNullableMethod(onGestureHandlerStateChange, resultEvent);\n }\n\n if (this.currentState === State.ACTIVE) {\n resultEvent.nativeEvent.oldState = undefined;\n invokeNullableMethod(onGestureHandlerEvent, resultEvent);\n }\n });\n\n this.delegate = delegate;\n } //\n // Initializing handler\n //\n\n\n init(viewRef, propsRef) {\n this.propsRef = propsRef;\n this.viewRef = viewRef;\n this.currentState = State.UNDETERMINED;\n this.delegate.init(viewRef, this);\n }\n\n attachEventManager(manager) {\n manager.setOnPointerDown(this.onPointerDown.bind(this));\n manager.setOnPointerAdd(this.onPointerAdd.bind(this));\n manager.setOnPointerUp(this.onPointerUp.bind(this));\n manager.setOnPointerRemove(this.onPointerRemove.bind(this));\n manager.setOnPointerMove(this.onPointerMove.bind(this));\n manager.setOnPointerEnter(this.onPointerEnter.bind(this));\n manager.setOnPointerLeave(this.onPointerLeave.bind(this));\n manager.setOnPointerCancel(this.onPointerCancel.bind(this));\n manager.setOnPointerOutOfBounds(this.onPointerOutOfBounds.bind(this));\n manager.setOnPointerMoveOver(this.onPointerMoveOver.bind(this));\n manager.setOnPointerMoveOut(this.onPointerMoveOut.bind(this));\n manager.registerListeners();\n } //\n // Resetting handler\n //\n\n\n onCancel() {}\n\n onReset() {}\n\n resetProgress() {}\n\n reset() {\n this.tracker.resetTracker();\n this.onReset();\n this.resetProgress();\n this.delegate.reset();\n this.currentState = State.UNDETERMINED;\n } //\n // State logic\n //\n\n\n moveToState(newState, sendIfDisabled) {\n if (this.currentState === newState) {\n return;\n }\n\n const oldState = this.currentState;\n this.currentState = newState;\n\n if (this.tracker.getTrackedPointersCount() > 0 && this.config.needsPointerData && this.isFinished()) {\n this.cancelTouches();\n }\n\n GestureHandlerOrchestrator.getInstance().onHandlerStateChange(this, newState, oldState, sendIfDisabled);\n this.onStateChange(newState, oldState);\n\n if (!this.enabled && this.isFinished()) {\n this.currentState = State.UNDETERMINED;\n }\n }\n\n onStateChange(_newState, _oldState) {}\n\n begin() {\n if (!this.checkHitSlop()) {\n return;\n }\n\n if (this.currentState === State.UNDETERMINED) {\n this.moveToState(State.BEGAN);\n }\n }\n /**\n * @param {boolean} sendIfDisabled - Used when handler becomes disabled. With this flag orchestrator will be forced to send fail event\n */\n\n\n fail(sendIfDisabled) {\n if (this.currentState === State.ACTIVE || this.currentState === State.BEGAN) {\n // Here the order of calling the delegate and moveToState is important.\n // At this point we can use currentState as previuos state, because immediately after changing cursor we call moveToState method.\n this.delegate.onFail();\n this.moveToState(State.FAILED, sendIfDisabled);\n }\n\n this.resetProgress();\n }\n /**\n * @param {boolean} sendIfDisabled - Used when handler becomes disabled. With this flag orchestrator will be forced to send cancel event\n */\n\n\n cancel(sendIfDisabled) {\n if (this.currentState === State.ACTIVE || this.currentState === State.UNDETERMINED || this.currentState === State.BEGAN) {\n this.onCancel(); // Same as above - order matters\n\n this.delegate.onCancel();\n this.moveToState(State.CANCELLED, sendIfDisabled);\n }\n }\n\n activate(force = false) {\n if ((this.config.manualActivation !== true || force) && (this.currentState === State.UNDETERMINED || this.currentState === State.BEGAN)) {\n this.delegate.onActivate();\n this.moveToState(State.ACTIVE);\n }\n }\n\n end() {\n if (this.currentState === State.BEGAN || this.currentState === State.ACTIVE) {\n // Same as above - order matters\n this.delegate.onEnd();\n this.moveToState(State.END);\n }\n\n this.resetProgress();\n } //\n // Methods for orchestrator\n //\n\n\n isAwaiting() {\n return this.awaiting;\n }\n\n setAwaiting(value) {\n this.awaiting = value;\n }\n\n isActive() {\n return this.active;\n }\n\n setActive(value) {\n this.active = value;\n }\n\n getShouldResetProgress() {\n return this.shouldResetProgress;\n }\n\n setShouldResetProgress(value) {\n this.shouldResetProgress = value;\n }\n\n getActivationIndex() {\n return this.activationIndex;\n }\n\n setActivationIndex(value) {\n this.activationIndex = value;\n }\n\n shouldWaitForHandlerFailure(handler) {\n if (handler === this) {\n return false;\n }\n\n return InteractionManager.getInstance().shouldWaitForHandlerFailure(this, handler);\n }\n\n shouldRequireToWaitForFailure(handler) {\n if (handler === this) {\n return false;\n }\n\n return InteractionManager.getInstance().shouldRequireHandlerToWaitForFailure(this, handler);\n }\n\n shouldRecognizeSimultaneously(handler) {\n if (handler === this) {\n return true;\n }\n\n return InteractionManager.getInstance().shouldRecognizeSimultaneously(this, handler);\n }\n\n shouldBeCancelledByOther(handler) {\n if (handler === this) {\n return false;\n }\n\n return InteractionManager.getInstance().shouldHandlerBeCancelledBy(this, handler);\n } //\n // Event actions\n //\n\n\n onPointerDown(event) {\n GestureHandlerOrchestrator.getInstance().recordHandlerIfNotPresent(this);\n this.pointerType = event.pointerType;\n\n if (this.pointerType === PointerType.TOUCH) {\n GestureHandlerOrchestrator.getInstance().cancelMouseAndPenGestures(this);\n }\n\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n } // Adding another pointer to existing ones\n\n\n onPointerAdd(event) {\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n }\n\n onPointerUp(event) {\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n } // Removing pointer, when there is more than one pointers\n\n\n onPointerRemove(event) {\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n }\n\n onPointerMove(event) {\n this.tryToSendMoveEvent(false);\n\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n }\n\n onPointerLeave(event) {\n if (this.shouldCancelWhenOutside) {\n switch (this.currentState) {\n case State.ACTIVE:\n this.cancel();\n break;\n\n case State.BEGAN:\n this.fail();\n break;\n }\n\n return;\n }\n\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n }\n\n onPointerEnter(event) {\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n }\n\n onPointerCancel(event) {\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n\n this.cancel();\n this.reset();\n }\n\n onPointerOutOfBounds(event) {\n this.tryToSendMoveEvent(true);\n\n if (this.config.needsPointerData) {\n this.sendTouchEvent(event);\n }\n }\n\n onPointerMoveOver(_event) {// used only by hover gesture handler atm\n }\n\n onPointerMoveOut(_event) {// used only by hover gesture handler atm\n }\n\n tryToSendMoveEvent(out) {\n if (this.enabled && this.active && (!out || out && !this.shouldCancelWhenOutside)) {\n this.sendEvent(this.currentState, this.currentState);\n }\n }\n\n sendTouchEvent(event) {\n if (!this.enabled) {\n return;\n }\n\n const {\n onGestureHandlerEvent\n } = this.propsRef.current;\n const touchEvent = this.transformTouchEvent(event);\n\n if (touchEvent) {\n invokeNullableMethod(onGestureHandlerEvent, touchEvent);\n }\n } //\n // Events Sending\n //\n\n\n transformEventData(newState, oldState) {\n return {\n nativeEvent: {\n numberOfPointers: this.tracker.getTrackedPointersCount(),\n state: newState,\n pointerInside: this.delegate.isPointerInBounds({\n x: this.tracker.getLastAvgX(),\n y: this.tracker.getLastAvgY()\n }),\n ...this.transformNativeEvent(),\n handlerTag: this.handlerTag,\n target: this.viewRef,\n oldState: newState !== oldState ? oldState : undefined,\n pointerType: this.pointerType\n },\n timeStamp: Date.now()\n };\n }\n\n transformTouchEvent(event) {\n var _event$touchEventType;\n\n const rect = this.delegate.measureView();\n const all = [];\n const changed = [];\n const trackerData = this.tracker.getData(); // This if handles edge case where all pointers have been cancelled\n // When pointercancel is triggered, reset method is called. This means that tracker will be reset after first pointer being cancelled\n // The problem is, that handler will receive another pointercancel event from the rest of the pointers\n // To avoid crashing, we don't send event if tracker tracks no pointers, i.e. has been reset\n\n if (trackerData.size === 0 || !trackerData.has(event.pointerId)) {\n return;\n }\n\n trackerData.forEach((element, key) => {\n const id = this.tracker.getMappedTouchEventId(key);\n all.push({\n id: id,\n x: element.lastX - rect.pageX,\n y: element.lastY - rect.pageY,\n absoluteX: element.lastX,\n absoluteY: element.lastY\n });\n }); // Each pointer sends its own event, so we want changed touches to contain only the pointer that has changed.\n // However, if the event is cancel, we want to cancel all pointers to avoid crashes\n\n if (event.eventType !== EventTypes.CANCEL) {\n changed.push({\n id: this.tracker.getMappedTouchEventId(event.pointerId),\n x: event.x - rect.pageX,\n y: event.y - rect.pageY,\n absoluteX: event.x,\n absoluteY: event.y\n });\n } else {\n trackerData.forEach((element, key) => {\n const id = this.tracker.getMappedTouchEventId(key);\n changed.push({\n id: id,\n x: element.lastX - rect.pageX,\n y: element.lastY - rect.pageY,\n absoluteX: element.lastX,\n absoluteY: element.lastY\n });\n });\n }\n\n let eventType = TouchEventType.UNDETERMINED;\n\n switch (event.eventType) {\n case EventTypes.DOWN:\n case EventTypes.ADDITIONAL_POINTER_DOWN:\n eventType = TouchEventType.DOWN;\n break;\n\n case EventTypes.UP:\n case EventTypes.ADDITIONAL_POINTER_UP:\n eventType = TouchEventType.UP;\n break;\n\n case EventTypes.MOVE:\n eventType = TouchEventType.MOVE;\n break;\n\n case EventTypes.CANCEL:\n eventType = TouchEventType.CANCELLED;\n break;\n } // Here, when we receive up event, we want to decrease number of touches\n // That's because we want handler to send information that there's one pointer less\n // However, we still want this pointer to be present in allTouches array, so that its data can be accessed\n\n\n let numberOfTouches = all.length;\n\n if (event.eventType === EventTypes.UP || event.eventType === EventTypes.ADDITIONAL_POINTER_UP) {\n --numberOfTouches;\n }\n\n return {\n nativeEvent: {\n handlerTag: this.handlerTag,\n state: this.currentState,\n eventType: (_event$touchEventType = event.touchEventType) !== null && _event$touchEventType !== void 0 ? _event$touchEventType : eventType,\n changedTouches: changed,\n allTouches: all,\n numberOfTouches: numberOfTouches\n },\n timeStamp: Date.now()\n };\n }\n\n cancelTouches() {\n const rect = this.delegate.measureView();\n const all = [];\n const changed = [];\n const trackerData = this.tracker.getData();\n\n if (trackerData.size === 0) {\n return;\n }\n\n trackerData.forEach((element, key) => {\n const id = this.tracker.getMappedTouchEventId(key);\n all.push({\n id: id,\n x: element.lastX - rect.pageX,\n y: element.lastY - rect.pageY,\n absoluteX: element.lastX,\n absoluteY: element.lastY\n });\n changed.push({\n id: id,\n x: element.lastX - rect.pageX,\n y: element.lastY - rect.pageY,\n absoluteX: element.lastX,\n absoluteY: element.lastY\n });\n });\n const cancelEvent = {\n nativeEvent: {\n handlerTag: this.handlerTag,\n state: this.currentState,\n eventType: TouchEventType.CANCELLED,\n changedTouches: changed,\n allTouches: all,\n numberOfTouches: all.length\n },\n timeStamp: Date.now()\n };\n const {\n onGestureHandlerEvent\n } = this.propsRef.current;\n invokeNullableMethod(onGestureHandlerEvent, cancelEvent);\n }\n\n transformNativeEvent() {\n // those properties are shared by most handlers and if not this method will be overriden\n const rect = this.delegate.measureView();\n return {\n x: this.tracker.getLastAvgX() - rect.pageX,\n y: this.tracker.getLastAvgY() - rect.pageY,\n absoluteX: this.tracker.getLastAvgX(),\n absoluteY: this.tracker.getLastAvgY()\n };\n } //\n // Handling config\n //\n\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n this.config = {\n enabled: enabled,\n ...props\n };\n this.enabled = enabled;\n\n if (this.config.shouldCancelWhenOutside !== undefined) {\n this.setShouldCancelWhenOutside(this.config.shouldCancelWhenOutside);\n }\n\n this.validateHitSlops();\n\n if (this.enabled) {\n return;\n }\n\n switch (this.currentState) {\n case State.ACTIVE:\n this.fail(true);\n break;\n\n case State.UNDETERMINED:\n GestureHandlerOrchestrator.getInstance().removeHandlerFromOrchestrator(this);\n break;\n\n default:\n this.cancel(true);\n break;\n }\n }\n\n checkCustomActivationCriteria(criterias) {\n for (const key in this.config) {\n if (criterias.indexOf(key) >= 0) {\n this.hasCustomActivationCriteria = true;\n }\n }\n }\n\n validateHitSlops() {\n if (!this.config.hitSlop) {\n return;\n }\n\n if (this.config.hitSlop.left !== undefined && this.config.hitSlop.right !== undefined && this.config.hitSlop.width !== undefined) {\n throw new Error('HitSlop Error: Cannot define left, right and width at the same time');\n }\n\n if (this.config.hitSlop.width !== undefined && this.config.hitSlop.left === undefined && this.config.hitSlop.right === undefined) {\n throw new Error('HitSlop Error: When width is defined, either left or right has to be defined');\n }\n\n if (this.config.hitSlop.height !== undefined && this.config.hitSlop.top !== undefined && this.config.hitSlop.bottom !== undefined) {\n throw new Error('HitSlop Error: Cannot define top, bottom and height at the same time');\n }\n\n if (this.config.hitSlop.height !== undefined && this.config.hitSlop.top === undefined && this.config.hitSlop.bottom === undefined) {\n throw new Error('HitSlop Error: When height is defined, either top or bottom has to be defined');\n }\n }\n\n checkHitSlop() {\n if (!this.config.hitSlop) {\n return true;\n }\n\n const {\n width,\n height\n } = this.delegate.measureView();\n let left = 0;\n let top = 0;\n let right = width;\n let bottom = height;\n\n if (this.config.hitSlop.horizontal !== undefined) {\n left -= this.config.hitSlop.horizontal;\n right += this.config.hitSlop.horizontal;\n }\n\n if (this.config.hitSlop.vertical !== undefined) {\n top -= this.config.hitSlop.vertical;\n bottom += this.config.hitSlop.vertical;\n }\n\n if (this.config.hitSlop.left !== undefined) {\n left = -this.config.hitSlop.left;\n }\n\n if (this.config.hitSlop.right !== undefined) {\n right = width + this.config.hitSlop.right;\n }\n\n if (this.config.hitSlop.top !== undefined) {\n top = -this.config.hitSlop.top;\n }\n\n if (this.config.hitSlop.bottom !== undefined) {\n bottom = width + this.config.hitSlop.bottom;\n }\n\n if (this.config.hitSlop.width !== undefined) {\n if (this.config.hitSlop.left !== undefined) {\n right = left + this.config.hitSlop.width;\n } else if (this.config.hitSlop.right !== undefined) {\n left = right - this.config.hitSlop.width;\n }\n }\n\n if (this.config.hitSlop.height !== undefined) {\n if (this.config.hitSlop.top !== undefined) {\n bottom = top + this.config.hitSlop.height;\n } else if (this.config.hitSlop.bottom !== undefined) {\n top = bottom - this.config.hitSlop.height;\n }\n }\n\n const rect = this.delegate.measureView();\n const offsetX = this.tracker.getLastX() - rect.pageX;\n const offsetY = this.tracker.getLastY() - rect.pageY;\n\n if (offsetX >= left && offsetX <= right && offsetY >= top && offsetY <= bottom) {\n return true;\n }\n\n return false;\n }\n\n isButtonInConfig(mouseButton) {\n return !mouseButton || !this.config.mouseButton && mouseButton === MouseButton.LEFT || this.config.mouseButton && mouseButton & this.config.mouseButton;\n }\n\n resetConfig() {}\n\n onDestroy() {\n this.delegate.destroy(this.config);\n } //\n // Getters and setters\n //\n\n\n getTag() {\n return this.handlerTag;\n }\n\n setTag(tag) {\n this.handlerTag = tag;\n }\n\n getConfig() {\n return this.config;\n }\n\n getDelegate() {\n return this.delegate;\n }\n\n getTracker() {\n return this.tracker;\n }\n\n getTrackedPointersID() {\n return this.tracker.getTrackedPointersID();\n }\n\n getState() {\n return this.currentState;\n }\n\n isEnabled() {\n return this.enabled;\n }\n\n isFinished() {\n return this.currentState === State.END || this.currentState === State.FAILED || this.currentState === State.CANCELLED;\n }\n\n setShouldCancelWhenOutside(shouldCancel) {\n this.shouldCancelWhenOutside = shouldCancel;\n }\n\n getShouldCancelWhenOutside() {\n return this.shouldCancelWhenOutside;\n }\n\n getPointerType() {\n return this.pointerType;\n }\n\n}\n\nfunction invokeNullableMethod(method, event) {\n if (!method) {\n return;\n }\n\n if (typeof method === 'function') {\n method(event);\n return;\n }\n\n if ('__getHandler' in method && typeof method.__getHandler === 'function') {\n const handler = method.__getHandler();\n\n invokeNullableMethod(handler, event);\n return;\n }\n\n if (!('__nodeConfig' in method)) {\n return;\n }\n\n const {\n argMapping\n } = method.__nodeConfig;\n\n if (!Array.isArray(argMapping)) {\n return;\n }\n\n for (const [index, [key, value]] of argMapping.entries()) {\n if (!(key in event.nativeEvent)) {\n continue;\n } // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\n\n const nativeValue = event.nativeEvent[key]; // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\n if (value !== null && value !== void 0 && value.setValue) {\n //Reanimated API\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call\n value.setValue(nativeValue);\n } else {\n //RN Animated API\n method.__nodeConfig.argMapping[index] = [key, nativeValue];\n }\n }\n\n return;\n}\n//# sourceMappingURL=GestureHandler.js.map","export let EventTypes;\n\n(function (EventTypes) {\n EventTypes[EventTypes[\"DOWN\"] = 0] = \"DOWN\";\n EventTypes[EventTypes[\"ADDITIONAL_POINTER_DOWN\"] = 1] = \"ADDITIONAL_POINTER_DOWN\";\n EventTypes[EventTypes[\"UP\"] = 2] = \"UP\";\n EventTypes[EventTypes[\"ADDITIONAL_POINTER_UP\"] = 3] = \"ADDITIONAL_POINTER_UP\";\n EventTypes[EventTypes[\"MOVE\"] = 4] = \"MOVE\";\n EventTypes[EventTypes[\"ENTER\"] = 5] = \"ENTER\";\n EventTypes[EventTypes[\"LEAVE\"] = 6] = \"LEAVE\";\n EventTypes[EventTypes[\"CANCEL\"] = 7] = \"CANCEL\";\n})(EventTypes || (EventTypes = {}));\n\nexport let TouchEventType;\n\n(function (TouchEventType) {\n TouchEventType[TouchEventType[\"UNDETERMINED\"] = 0] = \"UNDETERMINED\";\n TouchEventType[TouchEventType[\"DOWN\"] = 1] = \"DOWN\";\n TouchEventType[TouchEventType[\"MOVE\"] = 2] = \"MOVE\";\n TouchEventType[TouchEventType[\"UP\"] = 3] = \"UP\";\n TouchEventType[TouchEventType[\"CANCELLED\"] = 4] = \"CANCELLED\";\n})(TouchEventType || (TouchEventType = {}));\n//# sourceMappingURL=interfaces.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { PointerType } from '../../PointerType';\nimport { State } from '../../State';\nimport PointerTracker from './PointerTracker';\nexport default class GestureHandlerOrchestrator {\n // Private beacuse of Singleton\n // eslint-disable-next-line no-useless-constructor, @typescript-eslint/no-empty-function\n constructor() {\n _defineProperty(this, \"gestureHandlers\", []);\n\n _defineProperty(this, \"awaitingHandlers\", []);\n\n _defineProperty(this, \"awaitingHandlersTags\", new Set());\n\n _defineProperty(this, \"handlingChangeSemaphore\", 0);\n\n _defineProperty(this, \"activationIndex\", 0);\n }\n\n scheduleFinishedHandlersCleanup() {\n if (this.handlingChangeSemaphore === 0) {\n this.cleanupFinishedHandlers();\n }\n }\n\n cleanHandler(handler) {\n handler.reset();\n handler.setActive(false);\n handler.setAwaiting(false);\n handler.setActivationIndex(Number.MAX_VALUE);\n }\n\n removeHandlerFromOrchestrator(handler) {\n const indexInGestureHandlers = this.gestureHandlers.indexOf(handler);\n const indexInAwaitingHandlers = this.awaitingHandlers.indexOf(handler);\n\n if (indexInGestureHandlers >= 0) {\n this.gestureHandlers.splice(indexInGestureHandlers, 1);\n }\n\n if (indexInAwaitingHandlers >= 0) {\n this.awaitingHandlers.splice(indexInAwaitingHandlers, 1);\n this.awaitingHandlersTags.delete(handler.getTag());\n }\n }\n\n cleanupFinishedHandlers() {\n const handlersToRemove = new Set();\n\n for (let i = this.gestureHandlers.length - 1; i >= 0; --i) {\n const handler = this.gestureHandlers[i];\n\n if (this.isFinished(handler.getState()) && !handler.isAwaiting()) {\n this.cleanHandler(handler);\n handlersToRemove.add(handler);\n }\n }\n\n this.gestureHandlers = this.gestureHandlers.filter(handler => !handlersToRemove.has(handler));\n }\n\n hasOtherHandlerToWaitFor(handler) {\n const hasToWaitFor = otherHandler => {\n return !this.isFinished(otherHandler.getState()) && this.shouldHandlerWaitForOther(handler, otherHandler);\n };\n\n return this.gestureHandlers.some(hasToWaitFor);\n }\n\n shouldBeCancelledByFinishedHandler(handler) {\n const shouldBeCancelled = otherHandler => {\n return this.shouldHandlerWaitForOther(handler, otherHandler) && otherHandler.getState() === State.END;\n };\n\n return this.gestureHandlers.some(shouldBeCancelled);\n }\n\n tryActivate(handler) {\n if (this.shouldBeCancelledByFinishedHandler(handler)) {\n handler.cancel();\n return;\n }\n\n if (this.hasOtherHandlerToWaitFor(handler)) {\n this.addAwaitingHandler(handler);\n return;\n }\n\n const handlerState = handler.getState();\n\n if (handlerState === State.CANCELLED || handlerState === State.FAILED) {\n return;\n }\n\n if (this.shouldActivate(handler)) {\n this.makeActive(handler);\n return;\n }\n\n if (handlerState === State.ACTIVE) {\n handler.fail();\n return;\n }\n\n if (handlerState === State.BEGAN) {\n handler.cancel();\n }\n }\n\n shouldActivate(handler) {\n const shouldBeCancelledBy = otherHandler => {\n return this.shouldHandlerBeCancelledBy(handler, otherHandler);\n };\n\n return !this.gestureHandlers.some(shouldBeCancelledBy);\n }\n\n cleanupAwaitingHandlers(handler) {\n const shouldWait = otherHandler => {\n return !otherHandler.isAwaiting() && this.shouldHandlerWaitForOther(otherHandler, handler);\n };\n\n for (const otherHandler of this.awaitingHandlers) {\n if (shouldWait(otherHandler)) {\n this.cleanHandler(otherHandler);\n this.awaitingHandlersTags.delete(otherHandler.getTag());\n }\n }\n\n this.awaitingHandlers = this.awaitingHandlers.filter(otherHandler => this.awaitingHandlersTags.has(otherHandler.getTag()));\n }\n\n onHandlerStateChange(handler, newState, oldState, sendIfDisabled) {\n if (!handler.isEnabled() && !sendIfDisabled) {\n return;\n }\n\n this.handlingChangeSemaphore += 1;\n\n if (this.isFinished(newState)) {\n for (const otherHandler of this.awaitingHandlers) {\n if (!this.shouldHandlerWaitForOther(otherHandler, handler) || !this.awaitingHandlersTags.has(otherHandler.getTag())) {\n continue;\n }\n\n if (newState !== State.END) {\n this.tryActivate(otherHandler);\n continue;\n }\n\n otherHandler.cancel();\n\n if (otherHandler.getState() === State.END) {\n // Handle edge case, where discrete gestures end immediately after activation thus\n // their state is set to END and when the gesture they are waiting for activates they\n // should be cancelled, however `cancel` was never sent as gestures were already in the END state.\n // Send synthetic BEGAN -> CANCELLED to properly handle JS logic\n otherHandler.sendEvent(State.CANCELLED, State.BEGAN);\n }\n\n otherHandler.setAwaiting(false);\n }\n }\n\n if (newState === State.ACTIVE) {\n this.tryActivate(handler);\n } else if (oldState === State.ACTIVE || oldState === State.END) {\n if (handler.isActive()) {\n handler.sendEvent(newState, oldState);\n } else if (oldState === State.ACTIVE && (newState === State.CANCELLED || newState === State.FAILED)) {\n handler.sendEvent(newState, State.BEGAN);\n }\n } else if (oldState !== State.UNDETERMINED || newState !== State.CANCELLED) {\n handler.sendEvent(newState, oldState);\n }\n\n this.handlingChangeSemaphore -= 1;\n this.scheduleFinishedHandlersCleanup();\n\n if (!this.awaitingHandlers.includes(handler)) {\n this.cleanupAwaitingHandlers(handler);\n }\n }\n\n makeActive(handler) {\n const currentState = handler.getState();\n handler.setActive(true);\n handler.setShouldResetProgress(true);\n handler.setActivationIndex(this.activationIndex++);\n\n for (let i = this.gestureHandlers.length - 1; i >= 0; --i) {\n if (this.shouldHandlerBeCancelledBy(this.gestureHandlers[i], handler)) {\n this.gestureHandlers[i].cancel();\n }\n }\n\n for (const otherHandler of this.awaitingHandlers) {\n if (this.shouldHandlerBeCancelledBy(otherHandler, handler)) {\n otherHandler.setAwaiting(false);\n }\n }\n\n handler.sendEvent(State.ACTIVE, State.BEGAN);\n\n if (currentState !== State.ACTIVE) {\n handler.sendEvent(State.END, State.ACTIVE);\n\n if (currentState !== State.END) {\n handler.sendEvent(State.UNDETERMINED, State.END);\n }\n }\n\n if (!handler.isAwaiting()) {\n return;\n }\n\n handler.setAwaiting(false);\n this.awaitingHandlers = this.awaitingHandlers.filter(otherHandler => otherHandler !== handler);\n }\n\n addAwaitingHandler(handler) {\n if (this.awaitingHandlers.includes(handler)) {\n return;\n }\n\n this.awaitingHandlers.push(handler);\n this.awaitingHandlersTags.add(handler.getTag());\n handler.setAwaiting(true);\n handler.setActivationIndex(this.activationIndex++);\n }\n\n recordHandlerIfNotPresent(handler) {\n if (this.gestureHandlers.includes(handler)) {\n return;\n }\n\n this.gestureHandlers.push(handler);\n handler.setActive(false);\n handler.setAwaiting(false);\n handler.setActivationIndex(Number.MAX_SAFE_INTEGER);\n }\n\n shouldHandlerWaitForOther(handler, otherHandler) {\n return handler !== otherHandler && (handler.shouldWaitForHandlerFailure(otherHandler) || otherHandler.shouldRequireToWaitForFailure(handler));\n }\n\n canRunSimultaneously(gh1, gh2) {\n return gh1 === gh2 || gh1.shouldRecognizeSimultaneously(gh2) || gh2.shouldRecognizeSimultaneously(gh1);\n }\n\n shouldHandlerBeCancelledBy(handler, otherHandler) {\n if (this.canRunSimultaneously(handler, otherHandler)) {\n return false;\n }\n\n if (handler.isAwaiting() || handler.getState() === State.ACTIVE) {\n // For now it always returns false\n return handler.shouldBeCancelledByOther(otherHandler);\n }\n\n const handlerPointers = handler.getTrackedPointersID();\n const otherPointers = otherHandler.getTrackedPointersID();\n\n if (!PointerTracker.shareCommonPointers(handlerPointers, otherPointers) && handler.getDelegate().getView() !== otherHandler.getDelegate().getView()) {\n return this.checkOverlap(handler, otherHandler);\n }\n\n return true;\n }\n\n checkOverlap(handler, otherHandler) {\n // If handlers don't have common pointers, default return value is false.\n // However, if at least on pointer overlaps with both handlers, we return true\n // This solves issue in overlapping parents example\n // TODO: Find better way to handle that issue, for example by activation order and handler cancelling\n const isPointerWithinBothBounds = pointer => {\n const handlerX = handler.getTracker().getLastX(pointer);\n const handlerY = handler.getTracker().getLastY(pointer);\n const point = {\n x: handlerX,\n y: handlerY\n };\n return handler.getDelegate().isPointerInBounds(point) && otherHandler.getDelegate().isPointerInBounds(point);\n };\n\n const handlerPointers = handler.getTrackedPointersID();\n const otherPointers = otherHandler.getTrackedPointersID();\n return handlerPointers.some(isPointerWithinBothBounds) || otherPointers.some(isPointerWithinBothBounds);\n }\n\n isFinished(state) {\n return state === State.END || state === State.FAILED || state === State.CANCELLED;\n } // This function is called when handler receives touchdown event\n // If handler is using mouse or pen as a pointer and any handler receives touch event,\n // mouse/pen event dissappears - it doesn't send onPointerCancel nor onPointerUp (and others)\n // This became a problem because handler was left at active state without any signal to end or fail\n // To handle this, when new touch event is received, we loop through active handlers and check which type of\n // pointer they're using. If there are any handler with mouse/pen as a pointer, we cancel them\n\n\n cancelMouseAndPenGestures(currentHandler) {\n this.gestureHandlers.forEach(handler => {\n if (handler.getPointerType() !== PointerType.MOUSE && handler.getPointerType() !== PointerType.STYLUS) {\n return;\n }\n\n if (handler !== currentHandler) {\n handler.cancel();\n } else {\n // Handler that received touch event should have its pointer tracker reset\n // This allows handler to smoothly change from mouse/pen to touch\n // The drawback is, that when we try to use mouse/pen one more time, it doesn't send onPointerDown at the first time\n // so it is required to click two times to get handler to work\n //\n // However, handler will receive manually created onPointerEnter that is triggered in EventManager in onPointerMove method.\n // There may be possibility to use that fact to make handler respond properly to first mouse click\n handler.getTracker().resetTracker();\n }\n });\n }\n\n static getInstance() {\n if (!GestureHandlerOrchestrator.instance) {\n GestureHandlerOrchestrator.instance = new GestureHandlerOrchestrator();\n }\n\n return GestureHandlerOrchestrator.instance;\n }\n\n}\n\n_defineProperty(GestureHandlerOrchestrator, \"instance\", void 0);\n//# sourceMappingURL=GestureHandlerOrchestrator.js.map","export let PointerType;\n\n(function (PointerType) {\n PointerType[PointerType[\"TOUCH\"] = 0] = \"TOUCH\";\n PointerType[PointerType[\"STYLUS\"] = 1] = \"STYLUS\";\n PointerType[PointerType[\"MOUSE\"] = 2] = \"MOUSE\";\n PointerType[PointerType[\"OTHER\"] = 3] = \"OTHER\";\n})(PointerType || (PointerType = {}));\n//# sourceMappingURL=PointerType.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport VelocityTracker from './VelocityTracker';\nconst MAX_POINTERS = 20;\nexport default class PointerTracker {\n constructor() {\n _defineProperty(this, \"velocityTracker\", new VelocityTracker());\n\n _defineProperty(this, \"trackedPointers\", new Map());\n\n _defineProperty(this, \"touchEventsIds\", new Map());\n\n _defineProperty(this, \"lastMovedPointerId\", void 0);\n\n _defineProperty(this, \"cachedAverages\", {\n x: 0,\n y: 0\n });\n\n this.lastMovedPointerId = NaN;\n\n for (let i = 0; i < MAX_POINTERS; ++i) {\n this.touchEventsIds.set(i, NaN);\n }\n }\n\n addToTracker(event) {\n if (this.trackedPointers.has(event.pointerId)) {\n return;\n }\n\n this.lastMovedPointerId = event.pointerId;\n const newElement = {\n lastX: event.x,\n lastY: event.y,\n timeStamp: event.time,\n velocityX: 0,\n velocityY: 0\n };\n this.trackedPointers.set(event.pointerId, newElement);\n this.mapTouchEventId(event.pointerId);\n this.cachedAverages = {\n x: this.getLastAvgX(),\n y: this.getLastAvgY()\n };\n }\n\n removeFromTracker(pointerId) {\n this.trackedPointers.delete(pointerId);\n this.removeMappedTouchId(pointerId);\n }\n\n track(event) {\n const element = this.trackedPointers.get(event.pointerId);\n\n if (!element) {\n return;\n }\n\n this.lastMovedPointerId = event.pointerId;\n this.velocityTracker.add(event);\n const [velocityX, velocityY] = this.velocityTracker.getVelocity();\n element.velocityX = velocityX;\n element.velocityY = velocityY;\n element.lastX = event.x;\n element.lastY = event.y;\n this.trackedPointers.set(event.pointerId, element);\n const avgX = this.getLastAvgX();\n const avgY = this.getLastAvgY();\n this.cachedAverages = {\n x: avgX,\n y: avgY\n };\n } //Mapping TouchEvents ID\n\n\n mapTouchEventId(id) {\n for (const [mappedId, touchId] of this.touchEventsIds) {\n if (isNaN(touchId)) {\n this.touchEventsIds.set(mappedId, id);\n break;\n }\n }\n }\n\n removeMappedTouchId(id) {\n const mappedId = this.getMappedTouchEventId(id);\n\n if (!isNaN(mappedId)) {\n this.touchEventsIds.set(mappedId, NaN);\n }\n }\n\n getMappedTouchEventId(touchEventId) {\n for (const [key, value] of this.touchEventsIds.entries()) {\n if (value === touchEventId) {\n return key;\n }\n }\n\n return NaN;\n }\n\n getVelocityX(pointerId) {\n var _this$trackedPointers;\n\n return (_this$trackedPointers = this.trackedPointers.get(pointerId)) === null || _this$trackedPointers === void 0 ? void 0 : _this$trackedPointers.velocityX;\n }\n\n getVelocityY(pointerId) {\n var _this$trackedPointers2;\n\n return (_this$trackedPointers2 = this.trackedPointers.get(pointerId)) === null || _this$trackedPointers2 === void 0 ? void 0 : _this$trackedPointers2.velocityY;\n }\n /**\n * Returns X coordinate of last moved pointer\n */\n\n\n getLastX(pointerId) {\n if (pointerId !== undefined) {\n var _this$trackedPointers3;\n\n return (_this$trackedPointers3 = this.trackedPointers.get(pointerId)) === null || _this$trackedPointers3 === void 0 ? void 0 : _this$trackedPointers3.lastX;\n } else {\n var _this$trackedPointers4;\n\n return (_this$trackedPointers4 = this.trackedPointers.get(this.lastMovedPointerId)) === null || _this$trackedPointers4 === void 0 ? void 0 : _this$trackedPointers4.lastX;\n }\n }\n /**\n * Returns Y coordinate of last moved pointer\n */\n\n\n getLastY(pointerId) {\n if (pointerId !== undefined) {\n var _this$trackedPointers5;\n\n return (_this$trackedPointers5 = this.trackedPointers.get(pointerId)) === null || _this$trackedPointers5 === void 0 ? void 0 : _this$trackedPointers5.lastY;\n } else {\n var _this$trackedPointers6;\n\n return (_this$trackedPointers6 = this.trackedPointers.get(this.lastMovedPointerId)) === null || _this$trackedPointers6 === void 0 ? void 0 : _this$trackedPointers6.lastY;\n }\n } // Some handlers use these methods to send average values in native event.\n // This may happen when pointers have already been removed from tracker (i.e. pointerup event).\n // In situation when NaN would be sent as a response, we return cached value.\n // That prevents handlers from crashing\n\n\n getLastAvgX() {\n const avgX = this.getSumX() / this.trackedPointers.size;\n return isNaN(avgX) ? this.cachedAverages.x : avgX;\n }\n\n getLastAvgY() {\n const avgY = this.getSumY() / this.trackedPointers.size;\n return isNaN(avgY) ? this.cachedAverages.y : avgY;\n }\n\n getSumX(ignoredPointer) {\n let sumX = 0;\n this.trackedPointers.forEach((value, key) => {\n if (key !== ignoredPointer) {\n sumX += value.lastX;\n }\n });\n return sumX;\n }\n\n getSumY(ignoredPointer) {\n let sumY = 0;\n this.trackedPointers.forEach((value, key) => {\n if (key !== ignoredPointer) {\n sumY += value.lastY;\n }\n });\n return sumY;\n }\n\n getTrackedPointersCount() {\n return this.trackedPointers.size;\n }\n\n getTrackedPointersID() {\n const keys = [];\n this.trackedPointers.forEach((_value, key) => {\n keys.push(key);\n });\n return keys;\n }\n\n getData() {\n return this.trackedPointers;\n }\n\n resetTracker() {\n this.velocityTracker.reset();\n this.trackedPointers.clear();\n this.lastMovedPointerId = NaN;\n\n for (let i = 0; i < MAX_POINTERS; ++i) {\n this.touchEventsIds.set(i, NaN);\n }\n }\n\n static shareCommonPointers(stPointers, ndPointers) {\n return stPointers.some(pointerId => ndPointers.includes(pointerId));\n }\n\n}\n//# sourceMappingURL=PointerTracker.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport CircularBuffer from './CircularBuffer';\nimport LeastSquareSolver from './LeastSquareSolver';\nexport default class VelocityTracker {\n constructor() {\n _defineProperty(this, \"assumePointerMoveStoppedMilliseconds\", 40);\n\n _defineProperty(this, \"historySize\", 20);\n\n _defineProperty(this, \"horizonMilliseconds\", 300);\n\n _defineProperty(this, \"minSampleSize\", 3);\n\n _defineProperty(this, \"samples\", void 0);\n\n this.samples = new CircularBuffer(this.historySize);\n }\n\n add(event) {\n this.samples.push(event);\n } /// Returns an estimate of the velocity of the object being tracked by the\n /// tracker given the current information available to the tracker.\n ///\n /// Information is added using [addPosition].\n ///\n /// Returns null if there is no data on which to base an estimate.\n\n\n getVelocityEstimate() {\n const x = [];\n const y = [];\n const w = [];\n const time = [];\n let sampleCount = 0;\n let index = this.samples.size - 1;\n const newestSample = this.samples.get(index);\n\n if (!newestSample) {\n return null;\n }\n\n let previousSample = newestSample; // Starting with the most recent PointAtTime sample, iterate backwards while\n // the samples represent continuous motion.\n\n while (sampleCount < this.samples.size) {\n const sample = this.samples.get(index);\n const age = newestSample.time - sample.time;\n const delta = Math.abs(sample.time - previousSample.time);\n previousSample = sample;\n\n if (age > this.horizonMilliseconds || delta > this.assumePointerMoveStoppedMilliseconds) {\n break;\n }\n\n x.push(sample.x);\n y.push(sample.y);\n w.push(1);\n time.push(-age);\n sampleCount++;\n index--;\n }\n\n if (sampleCount >= this.minSampleSize) {\n const xSolver = new LeastSquareSolver(time, x, w);\n const xFit = xSolver.solve(2);\n\n if (xFit !== null) {\n const ySolver = new LeastSquareSolver(time, y, w);\n const yFit = ySolver.solve(2);\n\n if (yFit !== null) {\n const xVelocity = xFit.coefficients[1] * 1000;\n const yVelocity = yFit.coefficients[1] * 1000;\n return [xVelocity, yVelocity];\n }\n }\n }\n\n return null;\n }\n\n getVelocity() {\n const estimate = this.getVelocityEstimate();\n\n if (estimate !== null) {\n return estimate;\n }\n\n return [0, 0];\n }\n\n reset() {\n this.samples.clear();\n }\n\n}\n//# sourceMappingURL=VelocityTracker.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nexport default class CircularBuffer {\n constructor(size) {\n _defineProperty(this, \"bufferSize\", void 0);\n\n _defineProperty(this, \"buffer\", void 0);\n\n _defineProperty(this, \"index\", void 0);\n\n _defineProperty(this, \"actualSize\", void 0);\n\n this.bufferSize = size;\n this.buffer = new Array(size);\n this.index = 0;\n this.actualSize = 0;\n }\n\n get size() {\n return this.actualSize;\n }\n\n push(element) {\n this.buffer[this.index] = element;\n this.index = (this.index + 1) % this.bufferSize;\n this.actualSize = Math.min(this.actualSize + 1, this.bufferSize);\n }\n\n get(at) {\n if (this.actualSize === this.bufferSize) {\n let index = (this.index + at) % this.bufferSize;\n\n if (index < 0) {\n index += this.bufferSize;\n }\n\n return this.buffer[index];\n } else {\n return this.buffer[at];\n }\n }\n\n clear() {\n this.buffer = new Array(this.bufferSize);\n this.index = 0;\n this.actualSize = 0;\n }\n\n}\n//# sourceMappingURL=CircularBuffer.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// Implementation taken from Flutter's LeastSquareSolver\n// https://github.com/flutter/flutter/blob/master/packages/flutter/lib/src/gestures/lsq_solver.dart\nclass Vector {\n constructor(length) {\n _defineProperty(this, \"offset\", void 0);\n\n _defineProperty(this, \"length\", void 0);\n\n _defineProperty(this, \"elements\", void 0);\n\n this.offset = 0;\n this.length = length;\n this.elements = new Array(length);\n }\n\n static fromVOL(values, offset, length) {\n const result = new Vector(0);\n result.offset = offset;\n result.length = length;\n result.elements = values;\n return result;\n }\n\n get(index) {\n return this.elements[this.offset + index];\n }\n\n set(index, value) {\n this.elements[this.offset + index] = value;\n }\n\n dot(other) {\n let result = 0;\n\n for (let i = 0; i < this.length; i++) {\n result += this.get(i) * other.get(i);\n }\n\n return result;\n }\n\n norm() {\n return Math.sqrt(this.dot(this));\n }\n\n}\n\nclass Matrix {\n constructor(rows, columns) {\n _defineProperty(this, \"columns\", void 0);\n\n _defineProperty(this, \"elements\", void 0);\n\n this.columns = columns;\n this.elements = new Array(rows * columns);\n }\n\n get(row, column) {\n return this.elements[row * this.columns + column];\n }\n\n set(row, column, value) {\n this.elements[row * this.columns + column] = value;\n }\n\n getRow(row) {\n return Vector.fromVOL(this.elements, row * this.columns, this.columns);\n }\n\n} /// An nth degree polynomial fit to a dataset.\n\n\nclass PolynomialFit {\n /// The polynomial coefficients of the fit.\n ///\n /// For each `i`, the element `coefficients[i]` is the coefficient of\n /// the `i`-th power of the variable.\n /// Creates a polynomial fit of the given degree.\n ///\n /// There are n + 1 coefficients in a fit of degree n.\n constructor(degree) {\n _defineProperty(this, \"coefficients\", void 0);\n\n this.coefficients = new Array(degree + 1);\n }\n\n}\n\nconst precisionErrorTolerance = 1e-10; /// Uses the least-squares algorithm to fit a polynomial to a set of data.\n\nexport default class LeastSquareSolver {\n /// The x-coordinates of each data point.\n /// The y-coordinates of each data point.\n /// The weight to use for each data point.\n /// Creates a least-squares solver.\n ///\n /// The [x], [y], and [w] arguments must not be null.\n constructor(x, y, w) {\n _defineProperty(this, \"x\", void 0);\n\n _defineProperty(this, \"y\", void 0);\n\n _defineProperty(this, \"w\", void 0);\n\n this.x = x;\n this.y = y;\n this.w = w;\n } /// Fits a polynomial of the given degree to the data points.\n ///\n /// When there is not enough data to fit a curve null is returned.\n\n\n solve(degree) {\n if (degree > this.x.length) {\n // Not enough data to fit a curve.\n return null;\n }\n\n const result = new PolynomialFit(degree); // Shorthands for the purpose of notation equivalence to original C++ code.\n\n const m = this.x.length;\n const n = degree + 1; // Expand the X vector to a matrix A, pre-multiplied by the weights.\n\n const a = new Matrix(n, m);\n\n for (let h = 0; h < m; h++) {\n a.set(0, h, this.w[h]);\n\n for (let i = 1; i < n; i++) {\n a.set(i, h, a.get(i - 1, h) * this.x[h]);\n }\n } // Apply the Gram-Schmidt process to A to obtain its QR decomposition.\n // Orthonormal basis, column-major ordVectorer.\n\n\n const q = new Matrix(n, m); // Upper triangular matrix, row-major order.\n\n const r = new Matrix(n, m);\n\n for (let j = 0; j < n; j += 1) {\n for (let h = 0; h < m; h += 1) {\n q.set(j, h, a.get(j, h));\n }\n\n for (let i = 0; i < j; i += 1) {\n const dot = q.getRow(j).dot(q.getRow(i));\n\n for (let h = 0; h < m; h += 1) {\n q.set(j, h, q.get(j, h) - dot * q.get(i, h));\n }\n }\n\n const norm = q.getRow(j).norm();\n\n if (norm < precisionErrorTolerance) {\n // Vectors are linearly dependent or zero so no solution.\n return null;\n }\n\n const inverseNorm = 1.0 / norm;\n\n for (let h = 0; h < m; h += 1) {\n q.set(j, h, q.get(j, h) * inverseNorm);\n }\n\n for (let i = 0; i < n; i += 1) {\n r.set(j, i, i < j ? 0.0 : q.getRow(j).dot(a.getRow(i)));\n }\n } // Solve R B = Qt W Y to find B. This is easy because R is upper triangular.\n // We just work from bottom-right to top-left calculating B's coefficients.\n\n\n const wy = new Vector(m);\n\n for (let h = 0; h < m; h += 1) {\n wy.set(h, this.y[h] * this.w[h]);\n }\n\n for (let i = n - 1; i >= 0; i -= 1) {\n result.coefficients[i] = q.getRow(i).dot(wy);\n\n for (let j = n - 1; j > i; j -= 1) {\n result.coefficients[i] -= r.get(i, j) * result.coefficients[j];\n }\n\n result.coefficients[i] /= r.get(i, i);\n }\n\n return result;\n }\n\n}\n//# sourceMappingURL=LeastSquareSolver.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { State } from '../../State';\nexport default class InteractionManager {\n // Private becaues of singleton\n // eslint-disable-next-line no-useless-constructor, @typescript-eslint/no-empty-function\n constructor() {\n _defineProperty(this, \"waitForRelations\", new Map());\n\n _defineProperty(this, \"simultaneousRelations\", new Map());\n\n _defineProperty(this, \"blocksHandlersRelations\", new Map());\n }\n\n configureInteractions(handler, config) {\n this.dropRelationsForHandlerWithTag(handler.getTag());\n\n if (config.waitFor) {\n const waitFor = [];\n config.waitFor.forEach(otherHandler => {\n // New API reference\n if (typeof otherHandler === 'number') {\n waitFor.push(otherHandler);\n } else {\n // Old API reference\n waitFor.push(otherHandler.handlerTag);\n }\n });\n this.waitForRelations.set(handler.getTag(), waitFor);\n }\n\n if (config.simultaneousHandlers) {\n const simultaneousHandlers = [];\n config.simultaneousHandlers.forEach(otherHandler => {\n if (typeof otherHandler === 'number') {\n simultaneousHandlers.push(otherHandler);\n } else {\n simultaneousHandlers.push(otherHandler.handlerTag);\n }\n });\n this.simultaneousRelations.set(handler.getTag(), simultaneousHandlers);\n }\n\n if (config.blocksHandlers) {\n const blocksHandlers = [];\n config.blocksHandlers.forEach(otherHandler => {\n if (typeof otherHandler === 'number') {\n blocksHandlers.push(otherHandler);\n } else {\n blocksHandlers.push(otherHandler.handlerTag);\n }\n });\n this.blocksHandlersRelations.set(handler.getTag(), blocksHandlers);\n }\n }\n\n shouldWaitForHandlerFailure(handler, otherHandler) {\n const waitFor = this.waitForRelations.get(handler.getTag());\n return (waitFor === null || waitFor === void 0 ? void 0 : waitFor.find(tag => {\n return tag === otherHandler.getTag();\n })) !== undefined;\n }\n\n shouldRecognizeSimultaneously(handler, otherHandler) {\n const simultaneousHandlers = this.simultaneousRelations.get(handler.getTag());\n return (simultaneousHandlers === null || simultaneousHandlers === void 0 ? void 0 : simultaneousHandlers.find(tag => {\n return tag === otherHandler.getTag();\n })) !== undefined;\n }\n\n shouldRequireHandlerToWaitForFailure(handler, otherHandler) {\n const waitFor = this.blocksHandlersRelations.get(handler.getTag());\n return (waitFor === null || waitFor === void 0 ? void 0 : waitFor.find(tag => {\n return tag === otherHandler.getTag();\n })) !== undefined;\n }\n\n shouldHandlerBeCancelledBy(_handler, otherHandler) {\n var _otherHandler$isButto;\n\n // We check constructor name instead of using `instanceof` in order do avoid circular dependencies\n const isNativeHandler = otherHandler.constructor.name === 'NativeViewGestureHandler';\n const isActive = otherHandler.getState() === State.ACTIVE;\n const isButton = ((_otherHandler$isButto = otherHandler.isButton) === null || _otherHandler$isButto === void 0 ? void 0 : _otherHandler$isButto.call(otherHandler)) === true;\n return isNativeHandler && isActive && !isButton;\n }\n\n dropRelationsForHandlerWithTag(handlerTag) {\n this.waitForRelations.delete(handlerTag);\n this.simultaneousRelations.delete(handlerTag);\n this.blocksHandlersRelations.delete(handlerTag);\n }\n\n reset() {\n this.waitForRelations.clear();\n this.simultaneousRelations.clear();\n this.blocksHandlersRelations.clear();\n }\n\n static getInstance() {\n if (!this.instance) {\n this.instance = new InteractionManager();\n }\n\n return this.instance;\n }\n\n}\n\n_defineProperty(InteractionManager, \"instance\", void 0);\n//# sourceMappingURL=InteractionManager.js.map","// Previous types exported gesture handlers as classes which creates an interface and variable, both named the same as class.\n// Without those types, we'd introduce breaking change, forcing users to prefix every handler type specification with typeof\n// e.g. React.createRef -> React.createRef.\n// See https://www.typescriptlang.org/docs/handbook/classes.html#constructor-functions for reference.\nimport { Platform, findNodeHandle as findNodeHandleRN } from 'react-native';\nimport { handlerIDToTag } from './handlersRegistry';\nimport { toArray } from '../utils';\nimport RNGestureHandlerModule from '../RNGestureHandlerModule';\nimport { ghQueueMicrotask } from '../ghQueueMicrotask';\nconst commonProps = ['id', 'enabled', 'shouldCancelWhenOutside', 'hitSlop', 'cancelsTouchesInView', 'userSelect', 'activeCursor', 'mouseButton', 'enableContextMenu', 'touchAction'];\nconst componentInteractionProps = ['waitFor', 'simultaneousHandlers', 'blocksHandlers'];\nexport const baseGestureHandlerProps = [...commonProps, ...componentInteractionProps, 'onBegan', 'onFailed', 'onCancelled', 'onActivated', 'onEnded', 'onGestureEvent', 'onHandlerStateChange'];\nexport const baseGestureHandlerWithMonitorProps = [...commonProps, 'needsPointerData', 'manualActivation'];\nexport let MouseButton;\n\n(function (MouseButton) {\n MouseButton[MouseButton[\"LEFT\"] = 1] = \"LEFT\";\n MouseButton[MouseButton[\"RIGHT\"] = 2] = \"RIGHT\";\n MouseButton[MouseButton[\"MIDDLE\"] = 4] = \"MIDDLE\";\n MouseButton[MouseButton[\"BUTTON_4\"] = 8] = \"BUTTON_4\";\n MouseButton[MouseButton[\"BUTTON_5\"] = 16] = \"BUTTON_5\";\n MouseButton[MouseButton[\"ALL\"] = 31] = \"ALL\";\n})(MouseButton || (MouseButton = {}));\n\nfunction isConfigParam(param, name) {\n // param !== Object(param) returns false if `param` is a function\n // or an object and returns true if `param` is null\n return param !== undefined && (param !== Object(param) || !('__isNative' in param)) && name !== 'onHandlerStateChange' && name !== 'onGestureEvent';\n}\n\nexport function filterConfig(props, validProps, defaults = {}) {\n const filteredConfig = { ...defaults\n };\n\n for (const key of validProps) {\n let value = props[key];\n\n if (isConfigParam(value, key)) {\n if (key === 'simultaneousHandlers' || key === 'waitFor') {\n value = transformIntoHandlerTags(props[key]);\n } else if (key === 'hitSlop' && typeof value !== 'object') {\n value = {\n top: value,\n left: value,\n bottom: value,\n right: value\n };\n }\n\n filteredConfig[key] = value;\n }\n }\n\n return filteredConfig;\n}\n\nfunction transformIntoHandlerTags(handlerIDs) {\n handlerIDs = toArray(handlerIDs);\n\n if (Platform.OS === 'web') {\n return handlerIDs.map(({\n current\n }) => current).filter(handle => handle);\n } // converts handler string IDs into their numeric tags\n\n\n return handlerIDs.map(handlerID => {\n var _handlerID$current;\n\n return handlerIDToTag[handlerID] || ((_handlerID$current = handlerID.current) === null || _handlerID$current === void 0 ? void 0 : _handlerID$current.handlerTag) || -1;\n }).filter(handlerTag => handlerTag > 0);\n}\n\nexport function findNodeHandle(node) {\n if (Platform.OS === 'web') {\n return node;\n }\n\n return findNodeHandleRN(node);\n}\nlet flushOperationsScheduled = false;\nexport function scheduleFlushOperations() {\n if (!flushOperationsScheduled) {\n flushOperationsScheduled = true;\n ghQueueMicrotask(() => {\n RNGestureHandlerModule.flushOperations();\n flushOperationsScheduled = false;\n });\n }\n}\n//# sourceMappingURL=gestureHandlerCommon.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport { findDOMNode } from 'react-dom';\n\n/**\n * @deprecated imperatively finding the DOM element of a react component has been deprecated in React 18.\n * You should use ref properties on the component instead.\n */\nvar findNodeHandle = component => {\n var node;\n try {\n node = findDOMNode(component);\n } catch (e) {}\n return node;\n};\nexport default findNodeHandle;","'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.min.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n","/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;cb}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"\")&&(k=k.replace(\"\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e\"+b.valueOf().toString()+\"\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a>=g;e-=g;rg=1<<32-oc(b)+e|c<w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;ww?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;ac?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;eHj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;de&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;kB()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3>>1,e=a[d];if(0>>1;dg(C,c))ng(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","// `queueMicrotask` was introduced to react-native in version 0.66 (https://github.com/react-native-community/releases/blob/master/CHANGELOG.md#v0660)\n// Because Gesture Handler supports versions 0.64+, we have to handle situations where someone uses older version of react native.\n// That's why if `queueMicrotask` doesn't exist, we use `setImmediate` instead, since it was used before we switched to `queueMicrotask` in version 2.11.0\nexport const ghQueueMicrotask = typeof queueMicrotask === 'function' ? queueMicrotask : setImmediate;\n//# sourceMappingURL=ghQueueMicrotask.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { State } from '../../State';\nimport { EventTypes } from '../interfaces';\nimport GestureHandler from './GestureHandler';\nconst DEFAULT_MAX_DURATION_MS = 500;\nconst DEFAULT_MAX_DELAY_MS = 500;\nconst DEFAULT_NUMBER_OF_TAPS = 1;\nconst DEFAULT_MIN_NUMBER_OF_POINTERS = 1;\nexport default class TapGestureHandler extends GestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"maxDeltaX\", Number.MIN_SAFE_INTEGER);\n\n _defineProperty(this, \"maxDeltaY\", Number.MIN_SAFE_INTEGER);\n\n _defineProperty(this, \"maxDistSq\", Number.MIN_SAFE_INTEGER);\n\n _defineProperty(this, \"maxDurationMs\", DEFAULT_MAX_DURATION_MS);\n\n _defineProperty(this, \"maxDelayMs\", DEFAULT_MAX_DELAY_MS);\n\n _defineProperty(this, \"numberOfTaps\", DEFAULT_NUMBER_OF_TAPS);\n\n _defineProperty(this, \"minNumberOfPointers\", DEFAULT_MIN_NUMBER_OF_POINTERS);\n\n _defineProperty(this, \"currentMaxNumberOfPointers\", 1);\n\n _defineProperty(this, \"startX\", 0);\n\n _defineProperty(this, \"startY\", 0);\n\n _defineProperty(this, \"offsetX\", 0);\n\n _defineProperty(this, \"offsetY\", 0);\n\n _defineProperty(this, \"lastX\", 0);\n\n _defineProperty(this, \"lastY\", 0);\n\n _defineProperty(this, \"waitTimeout\", void 0);\n\n _defineProperty(this, \"delayTimeout\", void 0);\n\n _defineProperty(this, \"tapsSoFar\", 0);\n }\n\n init(ref, propsRef) {\n super.init(ref, propsRef);\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n\n if (this.config.numberOfTaps !== undefined) {\n this.numberOfTaps = this.config.numberOfTaps;\n }\n\n if (this.config.maxDurationMs !== undefined) {\n this.maxDurationMs = this.config.maxDurationMs;\n }\n\n if (this.config.maxDelayMs !== undefined) {\n this.maxDelayMs = this.config.maxDelayMs;\n }\n\n if (this.config.maxDeltaX !== undefined) {\n this.maxDeltaX = this.config.maxDeltaX;\n }\n\n if (this.config.maxDeltaY !== undefined) {\n this.maxDeltaY = this.config.maxDeltaY;\n }\n\n if (this.config.maxDist !== undefined) {\n this.maxDistSq = this.config.maxDist * this.config.maxDist;\n }\n\n if (this.config.minPointers !== undefined) {\n this.minNumberOfPointers = this.config.minPointers;\n }\n }\n\n resetConfig() {\n super.resetConfig();\n this.maxDeltaX = Number.MIN_SAFE_INTEGER;\n this.maxDeltaY = Number.MIN_SAFE_INTEGER;\n this.maxDistSq = Number.MIN_SAFE_INTEGER;\n this.maxDurationMs = DEFAULT_MAX_DURATION_MS;\n this.maxDelayMs = DEFAULT_MAX_DELAY_MS;\n this.numberOfTaps = DEFAULT_NUMBER_OF_TAPS;\n this.minNumberOfPointers = DEFAULT_MIN_NUMBER_OF_POINTERS;\n }\n\n clearTimeouts() {\n clearTimeout(this.waitTimeout);\n clearTimeout(this.delayTimeout);\n }\n\n startTap() {\n this.clearTimeouts();\n this.waitTimeout = setTimeout(() => this.fail(), this.maxDurationMs);\n }\n\n endTap() {\n this.clearTimeouts();\n\n if (++this.tapsSoFar === this.numberOfTaps && this.currentMaxNumberOfPointers >= this.minNumberOfPointers) {\n this.activate();\n } else {\n this.delayTimeout = setTimeout(() => this.fail(), this.maxDelayMs);\n }\n } //Handling Events\n\n\n onPointerDown(event) {\n if (!this.isButtonInConfig(event.button)) {\n return;\n }\n\n this.tracker.addToTracker(event);\n super.onPointerDown(event);\n this.trySettingPosition(event);\n this.startX = event.x;\n this.startY = event.y;\n this.lastX = event.x;\n this.lastY = event.y;\n this.updateState(event);\n }\n\n onPointerAdd(event) {\n super.onPointerAdd(event);\n this.tracker.addToTracker(event);\n this.trySettingPosition(event);\n this.offsetX += this.lastX - this.startX;\n this.offsetY += this.lastY - this.startY;\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.startX = this.tracker.getLastAvgX();\n this.startY = this.tracker.getLastAvgY();\n this.updateState(event);\n }\n\n onPointerUp(event) {\n super.onPointerUp(event);\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.tracker.removeFromTracker(event.pointerId);\n this.updateState(event);\n }\n\n onPointerRemove(event) {\n super.onPointerRemove(event);\n this.tracker.removeFromTracker(event.pointerId);\n this.offsetX += this.lastX - this.startX;\n this.offsetY += this.lastY = this.startY;\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.startX = this.lastX;\n this.startY = this.lastY;\n this.updateState(event);\n }\n\n onPointerMove(event) {\n this.trySettingPosition(event);\n this.tracker.track(event);\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.updateState(event);\n super.onPointerMove(event);\n }\n\n onPointerOutOfBounds(event) {\n this.trySettingPosition(event);\n this.tracker.track(event);\n this.lastX = this.tracker.getLastAvgX();\n this.lastY = this.tracker.getLastAvgY();\n this.updateState(event);\n super.onPointerOutOfBounds(event);\n }\n\n updateState(event) {\n if (this.currentMaxNumberOfPointers < this.tracker.getTrackedPointersCount()) {\n this.currentMaxNumberOfPointers = this.tracker.getTrackedPointersCount();\n }\n\n if (this.shouldFail()) {\n this.fail();\n return;\n }\n\n switch (this.currentState) {\n case State.UNDETERMINED:\n if (event.eventType === EventTypes.DOWN) {\n this.begin();\n }\n\n this.startTap();\n break;\n\n case State.BEGAN:\n if (event.eventType === EventTypes.UP) {\n this.endTap();\n }\n\n if (event.eventType === EventTypes.DOWN) {\n this.startTap();\n }\n\n break;\n\n default:\n break;\n }\n }\n\n trySettingPosition(event) {\n if (this.currentState !== State.UNDETERMINED) {\n return;\n }\n\n this.offsetX = 0;\n this.offsetY = 0;\n this.startX = event.x;\n this.startY = event.y;\n }\n\n shouldFail() {\n const dx = this.lastX - this.startX + this.offsetX;\n\n if (this.maxDeltaX !== Number.MIN_SAFE_INTEGER && Math.abs(dx) > this.maxDeltaX) {\n return true;\n }\n\n const dy = this.lastY - this.startY + this.offsetY;\n\n if (this.maxDeltaY !== Number.MIN_SAFE_INTEGER && Math.abs(dy) > this.maxDeltaY) {\n return true;\n }\n\n const distSq = dy * dy + dx * dx;\n return this.maxDistSq !== Number.MIN_SAFE_INTEGER && distSq > this.maxDistSq;\n }\n\n activate() {\n super.activate();\n this.end();\n }\n\n onCancel() {\n this.resetProgress();\n this.clearTimeouts();\n }\n\n resetProgress() {\n this.clearTimeouts();\n this.tapsSoFar = 0;\n this.currentMaxNumberOfPointers = 0;\n }\n\n}\n//# sourceMappingURL=TapGestureHandler.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { State } from '../../State';\nimport GestureHandler from './GestureHandler';\nconst DEFAULT_MIN_DURATION_MS = 500;\nconst DEFAULT_MAX_DIST_DP = 10;\nconst SCALING_FACTOR = 10;\nexport default class LongPressGestureHandler extends GestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"minDurationMs\", DEFAULT_MIN_DURATION_MS);\n\n _defineProperty(this, \"defaultMaxDistSq\", DEFAULT_MAX_DIST_DP * SCALING_FACTOR);\n\n _defineProperty(this, \"maxDistSq\", this.defaultMaxDistSq);\n\n _defineProperty(this, \"startX\", 0);\n\n _defineProperty(this, \"startY\", 0);\n\n _defineProperty(this, \"startTime\", 0);\n\n _defineProperty(this, \"previousTime\", 0);\n\n _defineProperty(this, \"activationTimeout\", void 0);\n }\n\n init(ref, propsRef) {\n if (this.config.enableContextMenu === undefined) {\n this.config.enableContextMenu = false;\n }\n\n super.init(ref, propsRef);\n }\n\n transformNativeEvent() {\n return { ...super.transformNativeEvent(),\n duration: Date.now() - this.startTime\n };\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n\n if (this.config.minDurationMs !== undefined) {\n this.minDurationMs = this.config.minDurationMs;\n }\n\n if (this.config.maxDist !== undefined) {\n this.maxDistSq = this.config.maxDist * this.config.maxDist;\n }\n }\n\n resetConfig() {\n super.resetConfig();\n this.minDurationMs = DEFAULT_MIN_DURATION_MS;\n this.maxDistSq = this.defaultMaxDistSq;\n }\n\n onStateChange(_newState, _oldState) {\n clearTimeout(this.activationTimeout);\n }\n\n onPointerDown(event) {\n if (!this.isButtonInConfig(event.button)) {\n return;\n }\n\n this.tracker.addToTracker(event);\n super.onPointerDown(event);\n this.tryBegin(event);\n this.tryActivate();\n this.checkDistanceFail(event);\n }\n\n onPointerMove(event) {\n super.onPointerMove(event);\n this.tracker.track(event);\n this.checkDistanceFail(event);\n }\n\n onPointerUp(event) {\n super.onPointerUp(event);\n this.tracker.removeFromTracker(event.pointerId);\n\n if (this.currentState === State.ACTIVE) {\n this.end();\n } else {\n this.fail();\n }\n }\n\n tryBegin(event) {\n if (this.currentState !== State.UNDETERMINED) {\n return;\n }\n\n this.previousTime = Date.now();\n this.startTime = this.previousTime;\n this.begin();\n this.startX = event.x;\n this.startY = event.y;\n }\n\n tryActivate() {\n if (this.minDurationMs > 0) {\n this.activationTimeout = setTimeout(() => {\n this.activate();\n }, this.minDurationMs);\n } else if (this.minDurationMs === 0) {\n this.activate();\n }\n }\n\n checkDistanceFail(event) {\n const dx = event.x - this.startX;\n const dy = event.y - this.startY;\n const distSq = dx * dx + dy * dy;\n\n if (distSq <= this.maxDistSq) {\n return;\n }\n\n if (this.currentState === State.ACTIVE) {\n this.cancel();\n } else {\n this.fail();\n }\n }\n\n}\n//# sourceMappingURL=LongPressGestureHandler.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { State } from '../../State';\nimport { DEFAULT_TOUCH_SLOP } from '../constants';\nimport GestureHandler from './GestureHandler';\nimport ScaleGestureDetector from '../detectors/ScaleGestureDetector';\nexport default class PinchGestureHandler extends GestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"scale\", 1);\n\n _defineProperty(this, \"velocity\", 0);\n\n _defineProperty(this, \"startingSpan\", 0);\n\n _defineProperty(this, \"spanSlop\", DEFAULT_TOUCH_SLOP);\n\n _defineProperty(this, \"scaleDetectorListener\", {\n onScaleBegin: detector => {\n this.startingSpan = detector.getCurrentSpan();\n return true;\n },\n onScale: detector => {\n const prevScaleFactor = this.scale;\n this.scale *= detector.getScaleFactor(this.tracker.getTrackedPointersCount());\n const delta = detector.getTimeDelta();\n\n if (delta > 0) {\n this.velocity = (this.scale - prevScaleFactor) / delta;\n }\n\n if (Math.abs(this.startingSpan - detector.getCurrentSpan()) >= this.spanSlop && this.currentState === State.BEGAN) {\n this.activate();\n }\n\n return true;\n },\n onScaleEnd: _detector => {}\n });\n\n _defineProperty(this, \"scaleGestureDetector\", new ScaleGestureDetector(this.scaleDetectorListener));\n }\n\n init(ref, propsRef) {\n super.init(ref, propsRef);\n this.setShouldCancelWhenOutside(false);\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n }\n\n transformNativeEvent() {\n return {\n focalX: this.scaleGestureDetector.getFocusX(),\n focalY: this.scaleGestureDetector.getFocusY(),\n velocity: this.velocity,\n scale: this.scale\n };\n }\n\n onPointerDown(event) {\n this.tracker.addToTracker(event);\n super.onPointerDown(event);\n }\n\n onPointerAdd(event) {\n this.tracker.addToTracker(event);\n super.onPointerAdd(event);\n this.tryBegin();\n this.scaleGestureDetector.onTouchEvent(event, this.tracker);\n }\n\n onPointerUp(event) {\n super.onPointerUp(event);\n this.tracker.removeFromTracker(event.pointerId);\n\n if (this.currentState !== State.ACTIVE) {\n return;\n }\n\n this.scaleGestureDetector.onTouchEvent(event, this.tracker);\n\n if (this.currentState === State.ACTIVE) {\n this.end();\n } else {\n this.fail();\n }\n }\n\n onPointerRemove(event) {\n super.onPointerRemove(event);\n this.scaleGestureDetector.onTouchEvent(event, this.tracker);\n this.tracker.removeFromTracker(event.pointerId);\n\n if (this.currentState === State.ACTIVE && this.tracker.getTrackedPointersCount() < 2) {\n this.end();\n }\n }\n\n onPointerMove(event) {\n if (this.tracker.getTrackedPointersCount() < 2) {\n return;\n }\n\n this.tracker.track(event);\n this.scaleGestureDetector.onTouchEvent(event, this.tracker);\n super.onPointerMove(event);\n }\n\n onPointerOutOfBounds(event) {\n if (this.tracker.getTrackedPointersCount() < 2) {\n return;\n }\n\n this.tracker.track(event);\n this.scaleGestureDetector.onTouchEvent(event, this.tracker);\n super.onPointerOutOfBounds(event);\n }\n\n tryBegin() {\n if (this.currentState !== State.UNDETERMINED) {\n return;\n }\n\n this.resetProgress();\n this.begin();\n }\n\n activate(force) {\n if (this.currentState !== State.ACTIVE) {\n this.resetProgress();\n }\n\n super.activate(force);\n }\n\n onReset() {\n this.resetProgress();\n }\n\n resetProgress() {\n if (this.currentState === State.ACTIVE) {\n return;\n }\n\n this.velocity = 0;\n this.scale = 1;\n }\n\n}\n//# sourceMappingURL=PinchGestureHandler.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { DEFAULT_TOUCH_SLOP } from '../constants';\nimport { EventTypes } from '../interfaces';\nexport default class ScaleGestureDetector {\n constructor(callbacks) {\n _defineProperty(this, \"onScaleBegin\", void 0);\n\n _defineProperty(this, \"onScale\", void 0);\n\n _defineProperty(this, \"onScaleEnd\", void 0);\n\n _defineProperty(this, \"focusX\", void 0);\n\n _defineProperty(this, \"focusY\", void 0);\n\n _defineProperty(this, \"currentSpan\", void 0);\n\n _defineProperty(this, \"prevSpan\", void 0);\n\n _defineProperty(this, \"initialSpan\", void 0);\n\n _defineProperty(this, \"currentTime\", void 0);\n\n _defineProperty(this, \"prevTime\", void 0);\n\n _defineProperty(this, \"inProgress\", false);\n\n _defineProperty(this, \"spanSlop\", void 0);\n\n _defineProperty(this, \"minSpan\", void 0);\n\n this.onScaleBegin = callbacks.onScaleBegin;\n this.onScale = callbacks.onScale;\n this.onScaleEnd = callbacks.onScaleEnd;\n this.spanSlop = DEFAULT_TOUCH_SLOP * 2;\n this.minSpan = 0;\n }\n\n onTouchEvent(event, tracker) {\n this.currentTime = event.time;\n const action = event.eventType;\n const numOfPointers = tracker.getTrackedPointersCount();\n const streamComplete = action === EventTypes.UP || action === EventTypes.ADDITIONAL_POINTER_UP || action === EventTypes.CANCEL;\n\n if (action === EventTypes.DOWN || streamComplete) {\n if (this.inProgress) {\n this.onScaleEnd(this);\n this.inProgress = false;\n this.initialSpan = 0;\n }\n\n if (streamComplete) {\n return true;\n }\n }\n\n const configChanged = action === EventTypes.DOWN || action === EventTypes.ADDITIONAL_POINTER_UP || action === EventTypes.ADDITIONAL_POINTER_DOWN;\n const pointerUp = action === EventTypes.ADDITIONAL_POINTER_UP;\n const ignoredPointer = pointerUp ? event.pointerId : undefined; //Determine focal point\n\n const div = pointerUp ? numOfPointers - 1 : numOfPointers;\n const sumX = tracker.getSumX(ignoredPointer);\n const sumY = tracker.getSumY(ignoredPointer);\n const focusX = sumX / div;\n const focusY = sumY / div; //Determine average deviation from focal point\n\n let devSumX = 0;\n let devSumY = 0;\n tracker.getData().forEach((value, key) => {\n if (key === ignoredPointer) {\n return;\n }\n\n devSumX += Math.abs(value.lastX - focusX);\n devSumY += Math.abs(value.lastY - focusY);\n });\n const devX = devSumX / div;\n const devY = devSumY / div;\n const spanX = devX * 2;\n const spanY = devY * 2;\n const span = Math.hypot(spanX, spanY); //Begin/end events\n\n const wasInProgress = this.inProgress;\n this.focusX = focusX;\n this.focusY = focusY;\n\n if (this.inProgress && (span < this.minSpan || configChanged)) {\n this.onScaleEnd(this);\n this.inProgress = false;\n this.initialSpan = span;\n }\n\n if (configChanged) {\n this.initialSpan = this.prevSpan = this.currentSpan = span;\n }\n\n if (!this.inProgress && span >= this.minSpan && (wasInProgress || Math.abs(span - this.initialSpan) > this.spanSlop)) {\n this.prevSpan = this.currentSpan = span;\n this.prevTime = this.currentTime;\n this.inProgress = this.onScaleBegin(this);\n } //Handle motion\n\n\n if (action !== EventTypes.MOVE) {\n return true;\n }\n\n this.currentSpan = span;\n\n if (this.inProgress && !this.onScale(this)) {\n return true;\n }\n\n this.prevSpan = this.currentSpan;\n this.prevTime = this.currentTime;\n return true;\n }\n\n getCurrentSpan() {\n return this.currentSpan;\n }\n\n getFocusX() {\n return this.focusX;\n }\n\n getFocusY() {\n return this.focusY;\n }\n\n getTimeDelta() {\n return this.currentTime - this.prevTime;\n }\n\n getScaleFactor(numOfPointers) {\n if (numOfPointers < 2) {\n return 1;\n }\n\n return this.prevSpan > 0 ? this.currentSpan / this.prevSpan : 1;\n }\n\n}\n//# sourceMappingURL=ScaleGestureDetector.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { State } from '../../State';\nimport GestureHandler from './GestureHandler';\nimport RotationGestureDetector from '../detectors/RotationGestureDetector';\nconst ROTATION_RECOGNITION_THRESHOLD = Math.PI / 36;\nexport default class RotationGestureHandler extends GestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"rotation\", 0);\n\n _defineProperty(this, \"velocity\", 0);\n\n _defineProperty(this, \"cachedAnchorX\", 0);\n\n _defineProperty(this, \"cachedAnchorY\", 0);\n\n _defineProperty(this, \"rotationGestureListener\", {\n onRotationBegin: _detector => true,\n onRotation: detector => {\n const previousRotation = this.rotation;\n this.rotation += detector.getRotation();\n const delta = detector.getTimeDelta();\n\n if (delta > 0) {\n this.velocity = (this.rotation - previousRotation) / delta;\n }\n\n if (Math.abs(this.rotation) >= ROTATION_RECOGNITION_THRESHOLD && this.currentState === State.BEGAN) {\n this.activate();\n }\n\n return true;\n },\n onRotationEnd: _detector => {\n this.end();\n }\n });\n\n _defineProperty(this, \"rotationGestureDetector\", new RotationGestureDetector(this.rotationGestureListener));\n }\n\n init(ref, propsRef) {\n super.init(ref, propsRef);\n this.setShouldCancelWhenOutside(false);\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n }\n\n transformNativeEvent() {\n return {\n rotation: this.rotation ? this.rotation : 0,\n anchorX: this.getAnchorX(),\n anchorY: this.getAnchorY(),\n velocity: this.velocity ? this.velocity : 0\n };\n }\n\n getAnchorX() {\n const anchorX = this.rotationGestureDetector.getAnchorX();\n return anchorX ? anchorX : this.cachedAnchorX;\n }\n\n getAnchorY() {\n const anchorY = this.rotationGestureDetector.getAnchorY();\n return anchorY ? anchorY : this.cachedAnchorY;\n }\n\n onPointerDown(event) {\n this.tracker.addToTracker(event);\n super.onPointerDown(event);\n }\n\n onPointerAdd(event) {\n this.tracker.addToTracker(event);\n super.onPointerAdd(event);\n this.tryBegin();\n this.rotationGestureDetector.onTouchEvent(event, this.tracker);\n }\n\n onPointerMove(event) {\n if (this.tracker.getTrackedPointersCount() < 2) {\n return;\n }\n\n if (this.getAnchorX()) {\n this.cachedAnchorX = this.getAnchorX();\n }\n\n if (this.getAnchorY()) {\n this.cachedAnchorY = this.getAnchorY();\n }\n\n this.tracker.track(event);\n this.rotationGestureDetector.onTouchEvent(event, this.tracker);\n super.onPointerMove(event);\n }\n\n onPointerOutOfBounds(event) {\n if (this.tracker.getTrackedPointersCount() < 2) {\n return;\n }\n\n if (this.getAnchorX()) {\n this.cachedAnchorX = this.getAnchorX();\n }\n\n if (this.getAnchorY()) {\n this.cachedAnchorY = this.getAnchorY();\n }\n\n this.tracker.track(event);\n this.rotationGestureDetector.onTouchEvent(event, this.tracker);\n super.onPointerOutOfBounds(event);\n }\n\n onPointerUp(event) {\n super.onPointerUp(event);\n this.tracker.removeFromTracker(event.pointerId);\n this.rotationGestureDetector.onTouchEvent(event, this.tracker);\n\n if (this.currentState !== State.ACTIVE) {\n return;\n }\n\n if (this.currentState === State.ACTIVE) {\n this.end();\n } else {\n this.fail();\n }\n }\n\n onPointerRemove(event) {\n super.onPointerRemove(event);\n this.rotationGestureDetector.onTouchEvent(event, this.tracker);\n this.tracker.removeFromTracker(event.pointerId);\n }\n\n tryBegin() {\n if (this.currentState !== State.UNDETERMINED) {\n return;\n }\n\n this.begin();\n }\n\n activate(_force) {\n super.activate();\n }\n\n onReset() {\n if (this.currentState === State.ACTIVE) {\n return;\n }\n\n this.rotation = 0;\n this.velocity = 0;\n this.rotationGestureDetector.reset();\n }\n\n}\n//# sourceMappingURL=RotationGestureHandler.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { EventTypes } from '../interfaces';\nexport default class RotationGestureDetector {\n constructor(callbacks) {\n _defineProperty(this, \"onRotationBegin\", void 0);\n\n _defineProperty(this, \"onRotation\", void 0);\n\n _defineProperty(this, \"onRotationEnd\", void 0);\n\n _defineProperty(this, \"currentTime\", 0);\n\n _defineProperty(this, \"previousTime\", 0);\n\n _defineProperty(this, \"previousAngle\", 0);\n\n _defineProperty(this, \"rotation\", 0);\n\n _defineProperty(this, \"anchorX\", 0);\n\n _defineProperty(this, \"anchorY\", 0);\n\n _defineProperty(this, \"isInProgress\", false);\n\n _defineProperty(this, \"keyPointers\", [NaN, NaN]);\n\n this.onRotationBegin = callbacks.onRotationBegin;\n this.onRotation = callbacks.onRotation;\n this.onRotationEnd = callbacks.onRotationEnd;\n }\n\n updateCurrent(event, tracker) {\n this.previousTime = this.currentTime;\n this.currentTime = event.time;\n const [firstPointerID, secondPointerID] = this.keyPointers;\n const firstPointerX = tracker.getLastX(firstPointerID);\n const firstPointerY = tracker.getLastY(firstPointerID);\n const secondPointerX = tracker.getLastX(secondPointerID);\n const secondPointerY = tracker.getLastY(secondPointerID);\n const vectorX = secondPointerX - firstPointerX;\n const vectorY = secondPointerY - firstPointerY;\n this.anchorX = (firstPointerX + secondPointerX) / 2;\n this.anchorY = (firstPointerY + secondPointerY) / 2; //Angle diff should be positive when rotating in clockwise direction\n\n const angle = -Math.atan2(vectorY, vectorX);\n this.rotation = Number.isNaN(this.previousAngle) ? 0 : this.previousAngle - angle;\n this.previousAngle = angle;\n\n if (this.rotation > Math.PI) {\n this.rotation -= Math.PI;\n } else if (this.rotation < -Math.PI) {\n this.rotation += Math.PI;\n }\n\n if (this.rotation > Math.PI / 2) {\n this.rotation -= Math.PI;\n } else if (this.rotation < -Math.PI / 2) {\n this.rotation += Math.PI;\n }\n }\n\n finish() {\n if (!this.isInProgress) {\n return;\n }\n\n this.isInProgress = false;\n this.keyPointers = [NaN, NaN];\n this.onRotationEnd(this);\n }\n\n setKeyPointers(tracker) {\n if (this.keyPointers[0] && this.keyPointers[1]) {\n return;\n }\n\n const pointerIDs = tracker.getData().keys();\n this.keyPointers[0] = pointerIDs.next().value;\n this.keyPointers[1] = pointerIDs.next().value;\n }\n\n onTouchEvent(event, tracker) {\n switch (event.eventType) {\n case EventTypes.DOWN:\n this.isInProgress = false;\n break;\n\n case EventTypes.ADDITIONAL_POINTER_DOWN:\n if (this.isInProgress) {\n break;\n }\n\n this.isInProgress = true;\n this.previousTime = event.time;\n this.previousAngle = NaN;\n this.setKeyPointers(tracker);\n this.updateCurrent(event, tracker);\n this.onRotationBegin(this);\n break;\n\n case EventTypes.MOVE:\n if (!this.isInProgress) {\n break;\n }\n\n this.updateCurrent(event, tracker);\n this.onRotation(this);\n break;\n\n case EventTypes.ADDITIONAL_POINTER_UP:\n if (!this.isInProgress) {\n break;\n }\n\n if (this.keyPointers.indexOf(event.pointerId) >= 0) {\n this.finish();\n }\n\n break;\n\n case EventTypes.UP:\n if (this.isInProgress) {\n this.finish();\n }\n\n break;\n }\n\n return true;\n }\n\n getTimeDelta() {\n return this.currentTime + this.previousTime;\n }\n\n getAnchorX() {\n return this.anchorX;\n }\n\n getAnchorY() {\n return this.anchorY;\n }\n\n getRotation() {\n return this.rotation;\n }\n\n reset() {\n this.keyPointers = [NaN, NaN];\n this.isInProgress = false;\n }\n\n}\n//# sourceMappingURL=RotationGestureDetector.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { State } from '../../State';\nimport { DiagonalDirections, Directions } from '../../Directions';\nimport GestureHandler from './GestureHandler';\nimport Vector from '../tools/Vector';\nimport { coneToDeviation } from '../utils';\nconst DEFAULT_MAX_DURATION_MS = 800;\nconst DEFAULT_MIN_VELOCITY = 700;\nconst DEFAULT_ALIGNMENT_CONE = 30;\nconst DEFAULT_DIRECTION = Directions.RIGHT;\nconst DEFAULT_NUMBER_OF_TOUCHES_REQUIRED = 1;\nconst AXIAL_DEVIATION_COSINE = coneToDeviation(DEFAULT_ALIGNMENT_CONE);\nconst DIAGONAL_DEVIATION_COSINE = coneToDeviation(90 - DEFAULT_ALIGNMENT_CONE);\nexport default class FlingGestureHandler extends GestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"numberOfPointersRequired\", DEFAULT_NUMBER_OF_TOUCHES_REQUIRED);\n\n _defineProperty(this, \"direction\", DEFAULT_DIRECTION);\n\n _defineProperty(this, \"maxDurationMs\", DEFAULT_MAX_DURATION_MS);\n\n _defineProperty(this, \"minVelocity\", DEFAULT_MIN_VELOCITY);\n\n _defineProperty(this, \"delayTimeout\", void 0);\n\n _defineProperty(this, \"maxNumberOfPointersSimultaneously\", 0);\n\n _defineProperty(this, \"keyPointer\", NaN);\n }\n\n init(ref, propsRef) {\n super.init(ref, propsRef);\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n\n if (this.config.direction) {\n this.direction = this.config.direction;\n }\n\n if (this.config.numberOfPointers) {\n this.numberOfPointersRequired = this.config.numberOfPointers;\n }\n }\n\n startFling() {\n this.begin();\n this.maxNumberOfPointersSimultaneously = 1;\n this.delayTimeout = setTimeout(() => this.fail(), this.maxDurationMs);\n }\n\n tryEndFling() {\n const velocityVector = Vector.fromVelocity(this.tracker, this.keyPointer);\n\n const getAlignment = (direction, minimalAlignmentCosine) => {\n return (direction & this.direction) === direction && velocityVector.isSimilar(Vector.fromDirection(direction), minimalAlignmentCosine);\n };\n\n const axialDirectionsList = Object.values(Directions);\n const diagonalDirectionsList = Object.values(DiagonalDirections); // list of alignments to all activated directions\n\n const axialAlignmentList = axialDirectionsList.map(direction => getAlignment(direction, AXIAL_DEVIATION_COSINE));\n const diagonalAlignmentList = diagonalDirectionsList.map(direction => getAlignment(direction, DIAGONAL_DEVIATION_COSINE));\n const isAligned = axialAlignmentList.some(Boolean) || diagonalAlignmentList.some(Boolean);\n const isFast = velocityVector.magnitude > this.minVelocity;\n\n if (this.maxNumberOfPointersSimultaneously === this.numberOfPointersRequired && isAligned && isFast) {\n clearTimeout(this.delayTimeout);\n this.activate();\n return true;\n }\n\n return false;\n }\n\n endFling() {\n if (!this.tryEndFling()) {\n this.fail();\n }\n }\n\n onPointerDown(event) {\n if (!this.isButtonInConfig(event.button)) {\n return;\n }\n\n this.tracker.addToTracker(event);\n this.keyPointer = event.pointerId;\n super.onPointerDown(event);\n this.newPointerAction();\n }\n\n onPointerAdd(event) {\n this.tracker.addToTracker(event);\n super.onPointerAdd(event);\n this.newPointerAction();\n }\n\n newPointerAction() {\n if (this.currentState === State.UNDETERMINED) {\n this.startFling();\n }\n\n if (this.currentState !== State.BEGAN) {\n return;\n }\n\n this.tryEndFling();\n\n if (this.tracker.getTrackedPointersCount() > this.maxNumberOfPointersSimultaneously) {\n this.maxNumberOfPointersSimultaneously = this.tracker.getTrackedPointersCount();\n }\n }\n\n pointerMoveAction(event) {\n this.tracker.track(event);\n\n if (this.currentState !== State.BEGAN) {\n return;\n }\n\n this.tryEndFling();\n }\n\n onPointerMove(event) {\n this.pointerMoveAction(event);\n super.onPointerMove(event);\n }\n\n onPointerOutOfBounds(event) {\n this.pointerMoveAction(event);\n super.onPointerOutOfBounds(event);\n }\n\n onPointerUp(event) {\n super.onPointerUp(event);\n this.onUp(event);\n this.keyPointer = NaN;\n }\n\n onPointerRemove(event) {\n super.onPointerRemove(event);\n this.onUp(event);\n }\n\n onUp(event) {\n if (this.currentState === State.BEGAN) {\n this.endFling();\n }\n\n this.tracker.removeFromTracker(event.pointerId);\n }\n\n activate(force) {\n super.activate(force);\n this.end();\n }\n\n resetConfig() {\n super.resetConfig();\n this.numberOfPointersRequired = DEFAULT_NUMBER_OF_TOUCHES_REQUIRED;\n this.direction = DEFAULT_DIRECTION;\n }\n\n}\n//# sourceMappingURL=FlingGestureHandler.js.map","const RIGHT = 1;\nconst LEFT = 2;\nconst UP = 4;\nconst DOWN = 8; // public interface\n\nexport const Directions = {\n RIGHT: RIGHT,\n LEFT: LEFT,\n UP: UP,\n DOWN: DOWN\n}; // internal interface\n\nexport const DiagonalDirections = {\n UP_RIGHT: UP | RIGHT,\n DOWN_RIGHT: DOWN | RIGHT,\n UP_LEFT: UP | LEFT,\n DOWN_LEFT: DOWN | LEFT\n}; // eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; it can be used as a type and as a value\n//# sourceMappingURL=Directions.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { DiagonalDirections, Directions } from '../../Directions';\nimport { MINIMAL_FLING_VELOCITY } from '../constants';\nexport default class Vector {\n constructor(x, y) {\n _defineProperty(this, \"x\", void 0);\n\n _defineProperty(this, \"y\", void 0);\n\n _defineProperty(this, \"unitX\", void 0);\n\n _defineProperty(this, \"unitY\", void 0);\n\n _defineProperty(this, \"_magnitude\", void 0);\n\n this.x = x;\n this.y = y;\n this._magnitude = Math.hypot(this.x, this.y);\n const isMagnitudeSufficient = this._magnitude > MINIMAL_FLING_VELOCITY;\n this.unitX = isMagnitudeSufficient ? this.x / this._magnitude : 0;\n this.unitY = isMagnitudeSufficient ? this.y / this._magnitude : 0;\n }\n\n static fromDirection(direction) {\n return DirectionToVectorMappings.get(direction);\n }\n\n static fromVelocity(tracker, pointerId) {\n return new Vector(tracker.getVelocityX(pointerId), tracker.getVelocityY(pointerId));\n }\n\n get magnitude() {\n return this._magnitude;\n }\n\n computeSimilarity(vector) {\n return this.unitX * vector.unitX + this.unitY * vector.unitY;\n }\n\n isSimilar(vector, threshold) {\n return this.computeSimilarity(vector) > threshold;\n }\n\n}\nconst DirectionToVectorMappings = new Map([[Directions.LEFT, new Vector(-1, 0)], [Directions.RIGHT, new Vector(1, 0)], [Directions.UP, new Vector(0, -1)], [Directions.DOWN, new Vector(0, 1)], [DiagonalDirections.UP_RIGHT, new Vector(1, -1)], [DiagonalDirections.DOWN_RIGHT, new Vector(1, 1)], [DiagonalDirections.UP_LEFT, new Vector(-1, -1)], [DiagonalDirections.DOWN_LEFT, new Vector(-1, 1)]]);\n//# sourceMappingURL=Vector.js.map","import { PointerType } from '../PointerType';\nexport function isPointerInBounds(view, {\n x,\n y\n}) {\n const rect = view.getBoundingClientRect();\n return x >= rect.left && x <= rect.right && y >= rect.top && y <= rect.bottom;\n}\nexport const PointerTypeMapping = new Map([['mouse', PointerType.MOUSE], ['touch', PointerType.TOUCH], ['pen', PointerType.STYLUS], ['none', PointerType.OTHER]]);\nexport const degToRad = degrees => degrees * Math.PI / 180;\nexport const coneToDeviation = degrees => Math.cos(degToRad(degrees / 2));\n//# sourceMappingURL=utils.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Platform } from 'react-native';\nimport { State } from '../../State';\nimport { DEFAULT_TOUCH_SLOP } from '../constants';\nimport GestureHandler from './GestureHandler';\nexport default class NativeViewGestureHandler extends GestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"buttonRole\", void 0);\n\n _defineProperty(this, \"shouldActivateOnStart\", false);\n\n _defineProperty(this, \"disallowInterruption\", false);\n\n _defineProperty(this, \"startX\", 0);\n\n _defineProperty(this, \"startY\", 0);\n\n _defineProperty(this, \"minDistSq\", DEFAULT_TOUCH_SLOP * DEFAULT_TOUCH_SLOP);\n }\n\n init(ref, propsRef) {\n super.init(ref, propsRef);\n this.setShouldCancelWhenOutside(true);\n\n if (Platform.OS !== 'web') {\n return;\n }\n\n const view = this.delegate.getView();\n view.style['touchAction'] = 'auto'; //@ts-ignore Turns on defualt touch behavior on Safari\n\n view.style['WebkitTouchCallout'] = 'auto';\n this.buttonRole = view.getAttribute('role') === 'button';\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n\n if (this.config.shouldActivateOnStart !== undefined) {\n this.shouldActivateOnStart = this.config.shouldActivateOnStart;\n }\n\n if (this.config.disallowInterruption !== undefined) {\n this.disallowInterruption = this.config.disallowInterruption;\n }\n }\n\n resetConfig() {\n super.resetConfig();\n }\n\n onPointerDown(event) {\n this.tracker.addToTracker(event);\n super.onPointerDown(event);\n this.newPointerAction();\n }\n\n onPointerAdd(event) {\n this.tracker.addToTracker(event);\n super.onPointerAdd(event);\n this.newPointerAction();\n }\n\n newPointerAction() {\n this.startX = this.tracker.getLastAvgX();\n this.startY = this.tracker.getLastAvgY();\n\n if (this.currentState !== State.UNDETERMINED) {\n return;\n }\n\n this.begin();\n\n if (this.buttonRole) {\n this.activate();\n }\n }\n\n onPointerMove(event) {\n this.tracker.track(event);\n const dx = this.startX - this.tracker.getLastAvgX();\n const dy = this.startY - this.tracker.getLastAvgY();\n const distSq = dx * dx + dy * dy;\n\n if (distSq >= this.minDistSq) {\n if (this.buttonRole && this.currentState === State.ACTIVE) {\n this.cancel();\n } else if (!this.buttonRole && this.currentState === State.BEGAN) {\n this.activate();\n }\n }\n }\n\n onPointerLeave() {\n if (this.currentState === State.BEGAN || this.currentState === State.ACTIVE) {\n this.cancel();\n }\n }\n\n onPointerUp(event) {\n super.onPointerUp(event);\n this.onUp(event);\n }\n\n onPointerRemove(event) {\n super.onPointerRemove(event);\n this.onUp(event);\n }\n\n onUp(event) {\n this.tracker.removeFromTracker(event.pointerId);\n\n if (this.tracker.getTrackedPointersCount() === 0) {\n if (this.currentState === State.ACTIVE) {\n this.end();\n } else {\n this.fail();\n }\n }\n }\n\n shouldRecognizeSimultaneously(handler) {\n if (super.shouldRecognizeSimultaneously(handler)) {\n return true;\n }\n\n if (handler instanceof NativeViewGestureHandler && handler.getState() === State.ACTIVE && handler.disallowsInterruption()) {\n return false;\n }\n\n const canBeInterrupted = !this.disallowInterruption;\n\n if (this.currentState === State.ACTIVE && handler.getState() === State.ACTIVE && canBeInterrupted) {\n return false;\n }\n\n return this.currentState === State.ACTIVE && canBeInterrupted && handler.getTag() > 0;\n }\n\n shouldBeCancelledByOther(_handler) {\n return !this.disallowInterruption;\n }\n\n disallowsInterruption() {\n return this.disallowInterruption;\n }\n\n isButton() {\n return this.buttonRole;\n }\n\n}\n//# sourceMappingURL=NativeViewGestureHandler.js.map","import GestureHandler from './GestureHandler';\nexport default class ManualGestureHandler extends GestureHandler {\n init(ref, propsRef) {\n super.init(ref, propsRef);\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n }\n\n onPointerDown(event) {\n this.tracker.addToTracker(event);\n super.onPointerDown(event);\n this.begin();\n }\n\n onPointerAdd(event) {\n this.tracker.addToTracker(event);\n super.onPointerAdd(event);\n }\n\n onPointerMove(event) {\n this.tracker.track(event);\n super.onPointerMove(event);\n }\n\n onPointerOutOfBounds(event) {\n this.tracker.track(event);\n super.onPointerOutOfBounds(event);\n }\n\n onPointerUp(event) {\n super.onPointerUp(event);\n this.tracker.removeFromTracker(event.pointerId);\n }\n\n onPointerRemove(event) {\n super.onPointerRemove(event);\n this.tracker.removeFromTracker(event.pointerId);\n }\n\n}\n//# sourceMappingURL=ManualGestureHandler.js.map","import { State } from '../../State';\nimport GestureHandlerOrchestrator from '../tools/GestureHandlerOrchestrator';\nimport GestureHandler from './GestureHandler';\nexport default class HoverGestureHandler extends GestureHandler {\n init(ref, propsRef) {\n super.init(ref, propsRef);\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n super.updateGestureConfig({\n enabled: enabled,\n ...props\n });\n }\n\n onPointerMoveOver(event) {\n GestureHandlerOrchestrator.getInstance().recordHandlerIfNotPresent(this);\n this.tracker.addToTracker(event);\n super.onPointerMoveOver(event);\n\n if (this.getState() === State.UNDETERMINED) {\n this.begin();\n this.activate();\n }\n }\n\n onPointerMoveOut(event) {\n this.tracker.addToTracker(event);\n super.onPointerMoveOut(event);\n this.end();\n }\n\n onPointerMove(event) {\n this.tracker.track(event);\n super.onPointerMove(event);\n }\n\n onPointerCancel(event) {\n super.onPointerCancel(event);\n this.reset();\n }\n\n}\n//# sourceMappingURL=HoverGestureHandler.js.map","import DiscreteGestureHandler from './DiscreteGestureHandler';\nimport * as NodeManager from './NodeManager';\nimport PressGestureHandler from './PressGestureHandler';\nimport { TEST_MIN_IF_NOT_NAN, VEC_LEN_SQ } from './utils';\n\nclass NativeViewGestureHandler extends PressGestureHandler {\n get isNative() {\n return true;\n }\n\n onRawEvent(ev) {\n super.onRawEvent(ev);\n\n if (!ev.isFinal) {\n // if (this.ref instanceof ScrollView) {\n if (TEST_MIN_IF_NOT_NAN(VEC_LEN_SQ({\n x: ev.deltaX,\n y: ev.deltaY\n }), 10)) {\n // @ts-ignore FIXME(TS) config type\n if (this.config.disallowInterruption) {\n const gestures = Object.values(NodeManager.getNodes()).filter(gesture => {\n const {\n handlerTag,\n view,\n isGestureRunning\n } = gesture;\n return (// Check if this gesture isn't self\n handlerTag !== this.handlerTag && // Ensure the gesture needs to be cancelled\n isGestureRunning && // ScrollView can cancel discrete gestures like taps and presses\n gesture instanceof DiscreteGestureHandler && // Ensure a view exists and is a child of the current view\n view && // @ts-ignore FIXME(TS) view type\n this.view.contains(view)\n );\n }); // Cancel all of the gestures that passed the filter\n\n for (const gesture of gestures) {\n // TODO: Bacon: Send some cached event.\n gesture.forceInvalidate(ev);\n }\n }\n }\n }\n }\n\n}\n\nexport default NativeViewGestureHandler;\n//# sourceMappingURL=NativeViewGestureHandler.js.map","/* eslint-disable eslint-comments/no-unlimited-disable */\n\n/* eslint-disable */\nimport GestureHandler from './GestureHandler';\nimport { TEST_MAX_IF_NOT_NAN } from './utils';\n\nclass DiscreteGestureHandler extends GestureHandler {\n get isDiscrete() {\n return true;\n }\n\n get shouldEnableGestureOnSetup() {\n return true;\n }\n\n shouldFailUnderCustomCriteria({\n x,\n y,\n deltaX,\n deltaY\n }, {\n maxDeltaX,\n maxDeltaY,\n maxDistSq,\n shouldCancelWhenOutside\n }) {\n if (shouldCancelWhenOutside) {\n if (!this.isPointInView({\n x,\n y\n })) {\n return true;\n }\n }\n\n return TEST_MAX_IF_NOT_NAN(Math.abs(deltaX), maxDeltaX) || TEST_MAX_IF_NOT_NAN(Math.abs(deltaY), maxDeltaY) || TEST_MAX_IF_NOT_NAN(Math.abs(deltaY * deltaY + deltaX * deltaX), maxDistSq);\n }\n\n transformNativeEvent({\n center: {\n x,\n y\n }\n }) {\n // @ts-ignore FIXME(TS)\n const rect = this.view.getBoundingClientRect();\n return {\n absoluteX: x,\n absoluteY: y,\n x: x - rect.left,\n y: y - rect.top\n };\n }\n\n isGestureEnabledForEvent({\n minPointers,\n maxPointers,\n maxDeltaX,\n maxDeltaY,\n maxDistSq,\n shouldCancelWhenOutside\n }, _recognizer, {\n maxPointers: pointerLength,\n center,\n deltaX,\n deltaY\n }) {\n const validPointerCount = pointerLength >= minPointers && pointerLength <= maxPointers;\n\n if (this.shouldFailUnderCustomCriteria({ ...center,\n deltaX,\n deltaY\n }, {\n maxDeltaX,\n maxDeltaY,\n maxDistSq,\n shouldCancelWhenOutside\n }) || // A user probably won't land a multi-pointer tap on the first tick (so we cannot just cancel each time)\n // but if the gesture is running and the user adds or subtracts another pointer then it should fail.\n !validPointerCount && this.isGestureRunning) {\n return {\n failed: true\n };\n }\n\n return {\n success: validPointerCount\n };\n }\n\n}\n\nexport default DiscreteGestureHandler;\n//# sourceMappingURL=DiscreteGestureHandler.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/* eslint-disable eslint-comments/no-unlimited-disable */\n\n/* eslint-disable */\nimport Hammer from '@egjs/hammerjs';\nimport { findNodeHandle } from 'react-native';\nimport { State } from '../State';\nimport { EventMap } from './constants';\nimport * as NodeManager from './NodeManager';\nimport { ghQueueMicrotask } from '../ghQueueMicrotask'; // TODO(TS) Replace with HammerInput if https://github.com/DefinitelyTyped/DefinitelyTyped/pull/50438/files is merged\n\nlet gestureInstances = 0;\n\nclass GestureHandler {\n get id() {\n return `${this.name}${this.gestureInstance}`;\n } // a simple way to check if GestureHandler is NativeViewGestureHandler, since importing it\n // here to use instanceof would cause import cycle\n\n\n get isNative() {\n return false;\n }\n\n get isDiscrete() {\n return false;\n }\n\n get shouldEnableGestureOnSetup() {\n throw new Error('Must override GestureHandler.shouldEnableGestureOnSetup');\n }\n\n constructor() {\n _defineProperty(this, \"handlerTag\", void 0);\n\n _defineProperty(this, \"isGestureRunning\", false);\n\n _defineProperty(this, \"view\", null);\n\n _defineProperty(this, \"hasCustomActivationCriteria\", void 0);\n\n _defineProperty(this, \"hasGestureFailed\", false);\n\n _defineProperty(this, \"hammer\", null);\n\n _defineProperty(this, \"initialRotation\", null);\n\n _defineProperty(this, \"__initialX\", void 0);\n\n _defineProperty(this, \"__initialY\", void 0);\n\n _defineProperty(this, \"config\", {});\n\n _defineProperty(this, \"previousState\", State.UNDETERMINED);\n\n _defineProperty(this, \"pendingGestures\", {});\n\n _defineProperty(this, \"oldState\", State.UNDETERMINED);\n\n _defineProperty(this, \"lastSentState\", null);\n\n _defineProperty(this, \"gestureInstance\", void 0);\n\n _defineProperty(this, \"_stillWaiting\", void 0);\n\n _defineProperty(this, \"propsRef\", void 0);\n\n _defineProperty(this, \"ref\", void 0);\n\n _defineProperty(this, \"clearSelfAsPending\", () => {\n if (Array.isArray(this.config.waitFor)) {\n for (const gesture of this.config.waitFor) {\n gesture.removePendingGesture(this.id);\n }\n }\n });\n\n _defineProperty(this, \"destroy\", () => {\n this.clearSelfAsPending();\n\n if (this.hammer) {\n this.hammer.stop(false);\n this.hammer.destroy();\n }\n\n this.hammer = null;\n });\n\n _defineProperty(this, \"isPointInView\", ({\n x,\n y\n }) => {\n // @ts-ignore FIXME(TS)\n const rect = this.view.getBoundingClientRect();\n const pointerInside = x >= rect.left && x <= rect.right && y >= rect.top && y <= rect.bottom;\n return pointerInside;\n });\n\n _defineProperty(this, \"sendEvent\", nativeEvent => {\n const {\n onGestureHandlerEvent,\n onGestureHandlerStateChange\n } = this.propsRef.current;\n const event = this.transformEventData(nativeEvent);\n invokeNullableMethod(onGestureHandlerEvent, event);\n\n if (this.lastSentState !== event.nativeEvent.state) {\n this.lastSentState = event.nativeEvent.state;\n invokeNullableMethod(onGestureHandlerStateChange, event);\n }\n });\n\n _defineProperty(this, \"sync\", () => {\n const gesture = this.hammer.get(this.name);\n if (!gesture) return;\n\n const enable = (recognizer, inputData) => {\n if (!this.config.enabled) {\n this.isGestureRunning = false;\n this.hasGestureFailed = false;\n return false;\n } // Prevent events before the system is ready.\n\n\n if (!inputData || !recognizer.options || typeof inputData.maxPointers === 'undefined') {\n return this.shouldEnableGestureOnSetup;\n }\n\n if (this.hasGestureFailed) {\n return false;\n }\n\n if (!this.isDiscrete) {\n if (this.isGestureRunning) {\n return true;\n } // The built-in hammer.js \"waitFor\" doesn't work across multiple views.\n // Only process if there are views to wait for.\n\n\n this._stillWaiting = this._getPendingGestures(); // This gesture should continue waiting.\n\n if (this._stillWaiting.length) {\n // Check to see if one of the gestures you're waiting for has started.\n // If it has then the gesture should fail.\n for (const gesture of this._stillWaiting) {\n // When the target gesture has started, this gesture must force fail.\n if (!gesture.isDiscrete && gesture.isGestureRunning) {\n this.hasGestureFailed = true;\n this.isGestureRunning = false;\n return false;\n }\n } // This gesture shouldn't start until the others have finished.\n\n\n return false;\n }\n } // Use default behaviour\n\n\n if (!this.hasCustomActivationCriteria) {\n return true;\n }\n\n const deltaRotation = this.initialRotation == null ? 0 : inputData.rotation - this.initialRotation; // @ts-ignore FIXME(TS)\n\n const {\n success,\n failed\n } = this.isGestureEnabledForEvent(this.getConfig(), recognizer, { ...inputData,\n deltaRotation\n });\n\n if (failed) {\n this.simulateCancelEvent(inputData);\n this.hasGestureFailed = true;\n }\n\n return success;\n };\n\n const params = this.getHammerConfig(); // @ts-ignore FIXME(TS)\n\n gesture.set({ ...params,\n enable\n });\n });\n\n this.gestureInstance = gestureInstances++;\n this.hasCustomActivationCriteria = false;\n }\n\n getConfig() {\n return this.config;\n }\n\n onWaitingEnded(_gesture) {}\n\n removePendingGesture(id) {\n delete this.pendingGestures[id];\n }\n\n addPendingGesture(gesture) {\n this.pendingGestures[gesture.id] = gesture;\n }\n\n isGestureEnabledForEvent(_config, _recognizer, _event) {\n return {\n success: true\n };\n }\n\n get NativeGestureClass() {\n throw new Error('Must override GestureHandler.NativeGestureClass');\n }\n\n updateHasCustomActivationCriteria(_config) {\n return true;\n }\n\n updateGestureConfig({\n enabled = true,\n ...props\n }) {\n this.clearSelfAsPending();\n this.config = this.ensureConfig({\n enabled,\n ...props\n });\n this.hasCustomActivationCriteria = this.updateHasCustomActivationCriteria(this.config);\n\n if (Array.isArray(this.config.waitFor)) {\n for (const gesture of this.config.waitFor) {\n gesture.addPendingGesture(this);\n }\n }\n\n if (this.hammer) {\n this.sync();\n }\n\n return this.config;\n }\n\n getState(type) {\n // @ts-ignore TODO(TS) check if this is needed\n if (type == 0) {\n return 0;\n }\n\n return EventMap[type];\n }\n\n transformEventData(event) {\n const {\n eventType,\n maxPointers: numberOfPointers\n } = event; // const direction = DirectionMap[ev.direction];\n\n const changedTouch = event.changedPointers[0];\n const pointerInside = this.isPointInView({\n x: changedTouch.clientX,\n y: changedTouch.clientY\n }); // TODO(TS) Remove cast after https://github.com/DefinitelyTyped/DefinitelyTyped/pull/50966 is merged.\n\n const state = this.getState(eventType);\n\n if (state !== this.previousState) {\n this.oldState = this.previousState;\n this.previousState = state;\n }\n\n return {\n nativeEvent: {\n numberOfPointers,\n state,\n pointerInside,\n ...this.transformNativeEvent(event),\n // onHandlerStateChange only\n handlerTag: this.handlerTag,\n target: this.ref,\n // send oldState only when the state was changed, or is different than ACTIVE\n // GestureDetector relies on the presence of `oldState` to differentiate between\n // update events and state change events\n oldState: state !== this.previousState || state != 4 ? this.oldState : undefined\n },\n timeStamp: Date.now()\n };\n }\n\n transformNativeEvent(_event) {\n return {};\n }\n\n cancelPendingGestures(event) {\n for (const gesture of Object.values(this.pendingGestures)) {\n if (gesture && gesture.isGestureRunning) {\n gesture.hasGestureFailed = true;\n gesture.cancelEvent(event);\n }\n }\n }\n\n notifyPendingGestures() {\n for (const gesture of Object.values(this.pendingGestures)) {\n if (gesture) {\n gesture.onWaitingEnded(this);\n }\n }\n } // FIXME event is undefined in runtime when firstly invoked (see Draggable example), check other functions taking event as input\n\n\n onGestureEnded(event) {\n this.isGestureRunning = false;\n this.cancelPendingGestures(event);\n }\n\n forceInvalidate(event) {\n if (this.isGestureRunning) {\n this.hasGestureFailed = true;\n this.cancelEvent(event);\n }\n }\n\n cancelEvent(event) {\n this.notifyPendingGestures();\n this.sendEvent({ ...event,\n eventType: Hammer.INPUT_CANCEL,\n isFinal: true\n });\n this.onGestureEnded(event);\n }\n\n onRawEvent({\n isFirst\n }) {\n if (isFirst) {\n this.hasGestureFailed = false;\n }\n }\n\n shouldUseTouchEvents(config) {\n var _config$simultaneousH, _config$simultaneousH2;\n\n return (_config$simultaneousH = (_config$simultaneousH2 = config.simultaneousHandlers) === null || _config$simultaneousH2 === void 0 ? void 0 : _config$simultaneousH2.some(handler => handler.isNative)) !== null && _config$simultaneousH !== void 0 ? _config$simultaneousH : false;\n }\n\n setView(ref, propsRef) {\n if (ref == null) {\n this.destroy();\n this.view = null;\n return;\n } // @ts-ignore window doesn't exist on global type as we don't want to use Node types\n\n\n const SUPPORTS_TOUCH = ('ontouchstart' in window);\n this.propsRef = propsRef;\n this.ref = ref;\n this.view = findNodeHandle(ref); // When the browser starts handling the gesture (e.g. scrolling), it sends a pointercancel event and stops\n // sending additional pointer events. This is not the case with touch events, so if the gesture is simultaneous\n // with a NativeGestureHandler, we need to check if touch events are supported and use them if possible.\n\n this.hammer = SUPPORTS_TOUCH && this.shouldUseTouchEvents(this.config) ? new Hammer.Manager(this.view, {\n inputClass: Hammer.TouchInput\n }) : new Hammer.Manager(this.view);\n this.oldState = State.UNDETERMINED;\n this.previousState = State.UNDETERMINED;\n this.lastSentState = null;\n const {\n NativeGestureClass\n } = this; // @ts-ignore TODO(TS)\n\n const gesture = new NativeGestureClass(this.getHammerConfig());\n this.hammer.add(gesture);\n this.hammer.on('hammer.input', ev => {\n if (!this.config.enabled) {\n this.hasGestureFailed = false;\n this.isGestureRunning = false;\n return;\n }\n\n this.onRawEvent(ev); // TODO: Bacon: Check against something other than null\n // The isFirst value is not called when the first rotation is calculated.\n\n if (this.initialRotation === null && ev.rotation !== 0) {\n this.initialRotation = ev.rotation;\n }\n\n if (ev.isFinal) {\n // in favor of a willFail otherwise the last frame of the gesture will be captured.\n setTimeout(() => {\n this.initialRotation = null;\n this.hasGestureFailed = false;\n });\n }\n });\n this.setupEvents();\n this.sync();\n }\n\n setupEvents() {\n // TODO(TS) Hammer types aren't exactly that what we get in runtime\n if (!this.isDiscrete) {\n this.hammer.on(`${this.name}start`, event => this.onStart(event));\n this.hammer.on(`${this.name}end ${this.name}cancel`, event => {\n this.onGestureEnded(event);\n });\n }\n\n this.hammer.on(this.name, ev => this.onGestureActivated(ev)); // TODO(TS) remove cast after https://github.com/DefinitelyTyped/DefinitelyTyped/pull/50438 is merged\n }\n\n onStart({\n deltaX,\n deltaY,\n rotation\n }) {\n // Reset the state for the next gesture\n this.oldState = State.UNDETERMINED;\n this.previousState = State.UNDETERMINED;\n this.lastSentState = null;\n this.isGestureRunning = true;\n this.__initialX = deltaX;\n this.__initialY = deltaY;\n this.initialRotation = rotation;\n }\n\n onGestureActivated(ev) {\n this.sendEvent(ev);\n }\n\n onSuccess() {}\n\n _getPendingGestures() {\n if (Array.isArray(this.config.waitFor) && this.config.waitFor.length) {\n // Get the list of gestures that this gesture is still waiting for.\n // Use `=== false` in case a ref that isn't a gesture handler is used.\n const stillWaiting = this.config.waitFor.filter(({\n hasGestureFailed\n }) => hasGestureFailed === false);\n return stillWaiting;\n }\n\n return [];\n }\n\n getHammerConfig() {\n const pointers = this.config.minPointers === this.config.maxPointers ? this.config.minPointers : 0;\n return {\n pointers\n };\n }\n\n simulateCancelEvent(_inputData) {} // Validate the props\n\n\n ensureConfig(config) {\n const props = { ...config\n }; // TODO(TS) We use ! to assert that if property is present then value is not empty (null, undefined)\n\n if ('minDist' in config) {\n props.minDist = config.minDist;\n props.minDistSq = props.minDist * props.minDist;\n }\n\n if ('minVelocity' in config) {\n props.minVelocity = config.minVelocity;\n props.minVelocitySq = props.minVelocity * props.minVelocity;\n }\n\n if ('maxDist' in config) {\n props.maxDist = config.maxDist;\n props.maxDistSq = config.maxDist * config.maxDist;\n }\n\n if ('waitFor' in config) {\n props.waitFor = asArray(config.waitFor).map(({\n handlerTag\n }) => NodeManager.getHandler(handlerTag)).filter(v => v);\n } else {\n props.waitFor = null;\n }\n\n if ('simultaneousHandlers' in config) {\n const shouldUseTouchEvents = this.shouldUseTouchEvents(this.config);\n props.simultaneousHandlers = asArray(config.simultaneousHandlers).map(handler => {\n if (typeof handler === 'number') {\n return NodeManager.getHandler(handler);\n } else {\n return NodeManager.getHandler(handler.handlerTag);\n }\n }).filter(v => v);\n\n if (shouldUseTouchEvents !== this.shouldUseTouchEvents(props)) {\n ghQueueMicrotask(() => {\n // if the undelying event API needs to be changed, we need to unmount and mount\n // the hammer instance again.\n this.destroy();\n this.setView(this.ref, this.propsRef);\n });\n }\n } else {\n props.simultaneousHandlers = null;\n }\n\n const configProps = ['minPointers', 'maxPointers', 'minDist', 'maxDist', 'maxDistSq', 'minVelocitySq', 'minDistSq', 'minVelocity', 'failOffsetXStart', 'failOffsetYStart', 'failOffsetXEnd', 'failOffsetYEnd', 'activeOffsetXStart', 'activeOffsetXEnd', 'activeOffsetYStart', 'activeOffsetYEnd'];\n configProps.forEach(prop => {\n if (typeof props[prop] === 'undefined') {\n props[prop] = Number.NaN;\n }\n });\n return props; // TODO(TS) how to convince TS that props are filled?\n }\n\n} // TODO(TS) investigate this method\n// Used for sending data to a callback or AnimatedEvent\n\n\nfunction invokeNullableMethod(method, event) {\n if (method) {\n if (typeof method === 'function') {\n method(event);\n } else {\n // For use with reanimated's AnimatedEvent\n if ('__getHandler' in method && typeof method.__getHandler === 'function') {\n const handler = method.__getHandler();\n\n invokeNullableMethod(handler, event);\n } else {\n if ('__nodeConfig' in method) {\n const {\n argMapping\n } = method.__nodeConfig;\n\n if (Array.isArray(argMapping)) {\n for (const [index, [key, value]] of argMapping.entries()) {\n if (key in event.nativeEvent) {\n // @ts-ignore fix method type\n const nativeValue = event.nativeEvent[key];\n\n if (value && value.setValue) {\n // Reanimated API\n value.setValue(nativeValue);\n } else {\n // RN Animated API\n method.__nodeConfig.argMapping[index] = [key, nativeValue];\n }\n }\n }\n }\n }\n }\n }\n }\n}\n\nfunction asArray(value) {\n // TODO(TS) use config.waitFor type\n return value == null ? [] : Array.isArray(value) ? value : [value];\n}\n\nexport default GestureHandler;\n//# sourceMappingURL=GestureHandler.js.map","/*! Hammer.JS - v2.0.17-rc - 2019-12-16\n * http://naver.github.io/egjs\n *\n * Forked By Naver egjs\n * Copyright (c) hammerjs\n * Licensed under the MIT license */\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\n/**\n * @private\n * extend object.\n * means that properties in dest will be overwritten by the ones in src.\n * @param {Object} target\n * @param {...Object} objects_to_assign\n * @returns {Object} target\n */\nvar assign;\n\nif (typeof Object.assign !== 'function') {\n assign = function assign(target) {\n if (target === undefined || target === null) {\n throw new TypeError('Cannot convert undefined or null to object');\n }\n\n var output = Object(target);\n\n for (var index = 1; index < arguments.length; index++) {\n var source = arguments[index];\n\n if (source !== undefined && source !== null) {\n for (var nextKey in source) {\n if (source.hasOwnProperty(nextKey)) {\n output[nextKey] = source[nextKey];\n }\n }\n }\n }\n\n return output;\n };\n} else {\n assign = Object.assign;\n}\n\nvar assign$1 = assign;\n\nvar VENDOR_PREFIXES = ['', 'webkit', 'Moz', 'MS', 'ms', 'o'];\nvar TEST_ELEMENT = typeof document === \"undefined\" ? {\n style: {}\n} : document.createElement('div');\nvar TYPE_FUNCTION = 'function';\nvar round = Math.round,\n abs = Math.abs;\nvar now = Date.now;\n\n/**\n * @private\n * get the prefixed property\n * @param {Object} obj\n * @param {String} property\n * @returns {String|Undefined} prefixed\n */\n\nfunction prefixed(obj, property) {\n var prefix;\n var prop;\n var camelProp = property[0].toUpperCase() + property.slice(1);\n var i = 0;\n\n while (i < VENDOR_PREFIXES.length) {\n prefix = VENDOR_PREFIXES[i];\n prop = prefix ? prefix + camelProp : property;\n\n if (prop in obj) {\n return prop;\n }\n\n i++;\n }\n\n return undefined;\n}\n\n/* eslint-disable no-new-func, no-nested-ternary */\nvar win;\n\nif (typeof window === \"undefined\") {\n // window is undefined in node.js\n win = {};\n} else {\n win = window;\n}\n\nvar PREFIXED_TOUCH_ACTION = prefixed(TEST_ELEMENT.style, 'touchAction');\nvar NATIVE_TOUCH_ACTION = PREFIXED_TOUCH_ACTION !== undefined;\nfunction getTouchActionProps() {\n if (!NATIVE_TOUCH_ACTION) {\n return false;\n }\n\n var touchMap = {};\n var cssSupports = win.CSS && win.CSS.supports;\n ['auto', 'manipulation', 'pan-y', 'pan-x', 'pan-x pan-y', 'none'].forEach(function (val) {\n // If css.supports is not supported but there is native touch-action assume it supports\n // all values. This is the case for IE 10 and 11.\n return touchMap[val] = cssSupports ? win.CSS.supports('touch-action', val) : true;\n });\n return touchMap;\n}\n\nvar TOUCH_ACTION_COMPUTE = 'compute';\nvar TOUCH_ACTION_AUTO = 'auto';\nvar TOUCH_ACTION_MANIPULATION = 'manipulation'; // not implemented\n\nvar TOUCH_ACTION_NONE = 'none';\nvar TOUCH_ACTION_PAN_X = 'pan-x';\nvar TOUCH_ACTION_PAN_Y = 'pan-y';\nvar TOUCH_ACTION_MAP = getTouchActionProps();\n\nvar MOBILE_REGEX = /mobile|tablet|ip(ad|hone|od)|android/i;\nvar SUPPORT_TOUCH = 'ontouchstart' in win;\nvar SUPPORT_POINTER_EVENTS = prefixed(win, 'PointerEvent') !== undefined;\nvar SUPPORT_ONLY_TOUCH = SUPPORT_TOUCH && MOBILE_REGEX.test(navigator.userAgent);\nvar INPUT_TYPE_TOUCH = 'touch';\nvar INPUT_TYPE_PEN = 'pen';\nvar INPUT_TYPE_MOUSE = 'mouse';\nvar INPUT_TYPE_KINECT = 'kinect';\nvar COMPUTE_INTERVAL = 25;\nvar INPUT_START = 1;\nvar INPUT_MOVE = 2;\nvar INPUT_END = 4;\nvar INPUT_CANCEL = 8;\nvar DIRECTION_NONE = 1;\nvar DIRECTION_LEFT = 2;\nvar DIRECTION_RIGHT = 4;\nvar DIRECTION_UP = 8;\nvar DIRECTION_DOWN = 16;\nvar DIRECTION_HORIZONTAL = DIRECTION_LEFT | DIRECTION_RIGHT;\nvar DIRECTION_VERTICAL = DIRECTION_UP | DIRECTION_DOWN;\nvar DIRECTION_ALL = DIRECTION_HORIZONTAL | DIRECTION_VERTICAL;\nvar PROPS_XY = ['x', 'y'];\nvar PROPS_CLIENT_XY = ['clientX', 'clientY'];\n\n/**\n * @private\n * walk objects and arrays\n * @param {Object} obj\n * @param {Function} iterator\n * @param {Object} context\n */\nfunction each(obj, iterator, context) {\n var i;\n\n if (!obj) {\n return;\n }\n\n if (obj.forEach) {\n obj.forEach(iterator, context);\n } else if (obj.length !== undefined) {\n i = 0;\n\n while (i < obj.length) {\n iterator.call(context, obj[i], i, obj);\n i++;\n }\n } else {\n for (i in obj) {\n obj.hasOwnProperty(i) && iterator.call(context, obj[i], i, obj);\n }\n }\n}\n\n/**\n * @private\n * let a boolean value also be a function that must return a boolean\n * this first item in args will be used as the context\n * @param {Boolean|Function} val\n * @param {Array} [args]\n * @returns {Boolean}\n */\n\nfunction boolOrFn(val, args) {\n if (typeof val === TYPE_FUNCTION) {\n return val.apply(args ? args[0] || undefined : undefined, args);\n }\n\n return val;\n}\n\n/**\n * @private\n * small indexOf wrapper\n * @param {String} str\n * @param {String} find\n * @returns {Boolean} found\n */\nfunction inStr(str, find) {\n return str.indexOf(find) > -1;\n}\n\n/**\n * @private\n * when the touchActions are collected they are not a valid value, so we need to clean things up. *\n * @param {String} actions\n * @returns {*}\n */\n\nfunction cleanTouchActions(actions) {\n // none\n if (inStr(actions, TOUCH_ACTION_NONE)) {\n return TOUCH_ACTION_NONE;\n }\n\n var hasPanX = inStr(actions, TOUCH_ACTION_PAN_X);\n var hasPanY = inStr(actions, TOUCH_ACTION_PAN_Y); // if both pan-x and pan-y are set (different recognizers\n // for different directions, e.g. horizontal pan but vertical swipe?)\n // we need none (as otherwise with pan-x pan-y combined none of these\n // recognizers will work, since the browser would handle all panning\n\n if (hasPanX && hasPanY) {\n return TOUCH_ACTION_NONE;\n } // pan-x OR pan-y\n\n\n if (hasPanX || hasPanY) {\n return hasPanX ? TOUCH_ACTION_PAN_X : TOUCH_ACTION_PAN_Y;\n } // manipulation\n\n\n if (inStr(actions, TOUCH_ACTION_MANIPULATION)) {\n return TOUCH_ACTION_MANIPULATION;\n }\n\n return TOUCH_ACTION_AUTO;\n}\n\n/**\n * @private\n * Touch Action\n * sets the touchAction property or uses the js alternative\n * @param {Manager} manager\n * @param {String} value\n * @constructor\n */\n\nvar TouchAction =\n/*#__PURE__*/\nfunction () {\n function TouchAction(manager, value) {\n this.manager = manager;\n this.set(value);\n }\n /**\n * @private\n * set the touchAction value on the element or enable the polyfill\n * @param {String} value\n */\n\n\n var _proto = TouchAction.prototype;\n\n _proto.set = function set(value) {\n // find out the touch-action by the event handlers\n if (value === TOUCH_ACTION_COMPUTE) {\n value = this.compute();\n }\n\n if (NATIVE_TOUCH_ACTION && this.manager.element.style && TOUCH_ACTION_MAP[value]) {\n this.manager.element.style[PREFIXED_TOUCH_ACTION] = value;\n }\n\n this.actions = value.toLowerCase().trim();\n };\n /**\n * @private\n * just re-set the touchAction value\n */\n\n\n _proto.update = function update() {\n this.set(this.manager.options.touchAction);\n };\n /**\n * @private\n * compute the value for the touchAction property based on the recognizer's settings\n * @returns {String} value\n */\n\n\n _proto.compute = function compute() {\n var actions = [];\n each(this.manager.recognizers, function (recognizer) {\n if (boolOrFn(recognizer.options.enable, [recognizer])) {\n actions = actions.concat(recognizer.getTouchAction());\n }\n });\n return cleanTouchActions(actions.join(' '));\n };\n /**\n * @private\n * this method is called on each input cycle and provides the preventing of the browser behavior\n * @param {Object} input\n */\n\n\n _proto.preventDefaults = function preventDefaults(input) {\n var srcEvent = input.srcEvent;\n var direction = input.offsetDirection; // if the touch action did prevented once this session\n\n if (this.manager.session.prevented) {\n srcEvent.preventDefault();\n return;\n }\n\n var actions = this.actions;\n var hasNone = inStr(actions, TOUCH_ACTION_NONE) && !TOUCH_ACTION_MAP[TOUCH_ACTION_NONE];\n var hasPanY = inStr(actions, TOUCH_ACTION_PAN_Y) && !TOUCH_ACTION_MAP[TOUCH_ACTION_PAN_Y];\n var hasPanX = inStr(actions, TOUCH_ACTION_PAN_X) && !TOUCH_ACTION_MAP[TOUCH_ACTION_PAN_X];\n\n if (hasNone) {\n // do not prevent defaults if this is a tap gesture\n var isTapPointer = input.pointers.length === 1;\n var isTapMovement = input.distance < 2;\n var isTapTouchTime = input.deltaTime < 250;\n\n if (isTapPointer && isTapMovement && isTapTouchTime) {\n return;\n }\n }\n\n if (hasPanX && hasPanY) {\n // `pan-x pan-y` means browser handles all scrolling/panning, do not prevent\n return;\n }\n\n if (hasNone || hasPanY && direction & DIRECTION_HORIZONTAL || hasPanX && direction & DIRECTION_VERTICAL) {\n return this.preventSrc(srcEvent);\n }\n };\n /**\n * @private\n * call preventDefault to prevent the browser's default behavior (scrolling in most cases)\n * @param {Object} srcEvent\n */\n\n\n _proto.preventSrc = function preventSrc(srcEvent) {\n this.manager.session.prevented = true;\n srcEvent.preventDefault();\n };\n\n return TouchAction;\n}();\n\n/**\n * @private\n * find if a node is in the given parent\n * @method hasParent\n * @param {HTMLElement} node\n * @param {HTMLElement} parent\n * @return {Boolean} found\n */\nfunction hasParent(node, parent) {\n while (node) {\n if (node === parent) {\n return true;\n }\n\n node = node.parentNode;\n }\n\n return false;\n}\n\n/**\n * @private\n * get the center of all the pointers\n * @param {Array} pointers\n * @return {Object} center contains `x` and `y` properties\n */\n\nfunction getCenter(pointers) {\n var pointersLength = pointers.length; // no need to loop when only one touch\n\n if (pointersLength === 1) {\n return {\n x: round(pointers[0].clientX),\n y: round(pointers[0].clientY)\n };\n }\n\n var x = 0;\n var y = 0;\n var i = 0;\n\n while (i < pointersLength) {\n x += pointers[i].clientX;\n y += pointers[i].clientY;\n i++;\n }\n\n return {\n x: round(x / pointersLength),\n y: round(y / pointersLength)\n };\n}\n\n/**\n * @private\n * create a simple clone from the input used for storage of firstInput and firstMultiple\n * @param {Object} input\n * @returns {Object} clonedInputData\n */\n\nfunction simpleCloneInputData(input) {\n // make a simple copy of the pointers because we will get a reference if we don't\n // we only need clientXY for the calculations\n var pointers = [];\n var i = 0;\n\n while (i < input.pointers.length) {\n pointers[i] = {\n clientX: round(input.pointers[i].clientX),\n clientY: round(input.pointers[i].clientY)\n };\n i++;\n }\n\n return {\n timeStamp: now(),\n pointers: pointers,\n center: getCenter(pointers),\n deltaX: input.deltaX,\n deltaY: input.deltaY\n };\n}\n\n/**\n * @private\n * calculate the absolute distance between two points\n * @param {Object} p1 {x, y}\n * @param {Object} p2 {x, y}\n * @param {Array} [props] containing x and y keys\n * @return {Number} distance\n */\n\nfunction getDistance(p1, p2, props) {\n if (!props) {\n props = PROPS_XY;\n }\n\n var x = p2[props[0]] - p1[props[0]];\n var y = p2[props[1]] - p1[props[1]];\n return Math.sqrt(x * x + y * y);\n}\n\n/**\n * @private\n * calculate the angle between two coordinates\n * @param {Object} p1\n * @param {Object} p2\n * @param {Array} [props] containing x and y keys\n * @return {Number} angle\n */\n\nfunction getAngle(p1, p2, props) {\n if (!props) {\n props = PROPS_XY;\n }\n\n var x = p2[props[0]] - p1[props[0]];\n var y = p2[props[1]] - p1[props[1]];\n return Math.atan2(y, x) * 180 / Math.PI;\n}\n\n/**\n * @private\n * get the direction between two points\n * @param {Number} x\n * @param {Number} y\n * @return {Number} direction\n */\n\nfunction getDirection(x, y) {\n if (x === y) {\n return DIRECTION_NONE;\n }\n\n if (abs(x) >= abs(y)) {\n return x < 0 ? DIRECTION_LEFT : DIRECTION_RIGHT;\n }\n\n return y < 0 ? DIRECTION_UP : DIRECTION_DOWN;\n}\n\nfunction computeDeltaXY(session, input) {\n var center = input.center; // let { offsetDelta:offset = {}, prevDelta = {}, prevInput = {} } = session;\n // jscs throwing error on defalut destructured values and without defaults tests fail\n\n var offset = session.offsetDelta || {};\n var prevDelta = session.prevDelta || {};\n var prevInput = session.prevInput || {};\n\n if (input.eventType === INPUT_START || prevInput.eventType === INPUT_END) {\n prevDelta = session.prevDelta = {\n x: prevInput.deltaX || 0,\n y: prevInput.deltaY || 0\n };\n offset = session.offsetDelta = {\n x: center.x,\n y: center.y\n };\n }\n\n input.deltaX = prevDelta.x + (center.x - offset.x);\n input.deltaY = prevDelta.y + (center.y - offset.y);\n}\n\n/**\n * @private\n * calculate the velocity between two points. unit is in px per ms.\n * @param {Number} deltaTime\n * @param {Number} x\n * @param {Number} y\n * @return {Object} velocity `x` and `y`\n */\nfunction getVelocity(deltaTime, x, y) {\n return {\n x: x / deltaTime || 0,\n y: y / deltaTime || 0\n };\n}\n\n/**\n * @private\n * calculate the scale factor between two pointersets\n * no scale is 1, and goes down to 0 when pinched together, and bigger when pinched out\n * @param {Array} start array of pointers\n * @param {Array} end array of pointers\n * @return {Number} scale\n */\n\nfunction getScale(start, end) {\n return getDistance(end[0], end[1], PROPS_CLIENT_XY) / getDistance(start[0], start[1], PROPS_CLIENT_XY);\n}\n\n/**\n * @private\n * calculate the rotation degrees between two pointersets\n * @param {Array} start array of pointers\n * @param {Array} end array of pointers\n * @return {Number} rotation\n */\n\nfunction getRotation(start, end) {\n return getAngle(end[1], end[0], PROPS_CLIENT_XY) + getAngle(start[1], start[0], PROPS_CLIENT_XY);\n}\n\n/**\n * @private\n * velocity is calculated every x ms\n * @param {Object} session\n * @param {Object} input\n */\n\nfunction computeIntervalInputData(session, input) {\n var last = session.lastInterval || input;\n var deltaTime = input.timeStamp - last.timeStamp;\n var velocity;\n var velocityX;\n var velocityY;\n var direction;\n\n if (input.eventType !== INPUT_CANCEL && (deltaTime > COMPUTE_INTERVAL || last.velocity === undefined)) {\n var deltaX = input.deltaX - last.deltaX;\n var deltaY = input.deltaY - last.deltaY;\n var v = getVelocity(deltaTime, deltaX, deltaY);\n velocityX = v.x;\n velocityY = v.y;\n velocity = abs(v.x) > abs(v.y) ? v.x : v.y;\n direction = getDirection(deltaX, deltaY);\n session.lastInterval = input;\n } else {\n // use latest velocity info if it doesn't overtake a minimum period\n velocity = last.velocity;\n velocityX = last.velocityX;\n velocityY = last.velocityY;\n direction = last.direction;\n }\n\n input.velocity = velocity;\n input.velocityX = velocityX;\n input.velocityY = velocityY;\n input.direction = direction;\n}\n\n/**\n* @private\n * extend the data with some usable properties like scale, rotate, velocity etc\n * @param {Object} manager\n * @param {Object} input\n */\n\nfunction computeInputData(manager, input) {\n var session = manager.session;\n var pointers = input.pointers;\n var pointersLength = pointers.length; // store the first input to calculate the distance and direction\n\n if (!session.firstInput) {\n session.firstInput = simpleCloneInputData(input);\n } // to compute scale and rotation we need to store the multiple touches\n\n\n if (pointersLength > 1 && !session.firstMultiple) {\n session.firstMultiple = simpleCloneInputData(input);\n } else if (pointersLength === 1) {\n session.firstMultiple = false;\n }\n\n var firstInput = session.firstInput,\n firstMultiple = session.firstMultiple;\n var offsetCenter = firstMultiple ? firstMultiple.center : firstInput.center;\n var center = input.center = getCenter(pointers);\n input.timeStamp = now();\n input.deltaTime = input.timeStamp - firstInput.timeStamp;\n input.angle = getAngle(offsetCenter, center);\n input.distance = getDistance(offsetCenter, center);\n computeDeltaXY(session, input);\n input.offsetDirection = getDirection(input.deltaX, input.deltaY);\n var overallVelocity = getVelocity(input.deltaTime, input.deltaX, input.deltaY);\n input.overallVelocityX = overallVelocity.x;\n input.overallVelocityY = overallVelocity.y;\n input.overallVelocity = abs(overallVelocity.x) > abs(overallVelocity.y) ? overallVelocity.x : overallVelocity.y;\n input.scale = firstMultiple ? getScale(firstMultiple.pointers, pointers) : 1;\n input.rotation = firstMultiple ? getRotation(firstMultiple.pointers, pointers) : 0;\n input.maxPointers = !session.prevInput ? input.pointers.length : input.pointers.length > session.prevInput.maxPointers ? input.pointers.length : session.prevInput.maxPointers;\n computeIntervalInputData(session, input); // find the correct target\n\n var target = manager.element;\n var srcEvent = input.srcEvent;\n var srcEventTarget;\n\n if (srcEvent.composedPath) {\n srcEventTarget = srcEvent.composedPath()[0];\n } else if (srcEvent.path) {\n srcEventTarget = srcEvent.path[0];\n } else {\n srcEventTarget = srcEvent.target;\n }\n\n if (hasParent(srcEventTarget, target)) {\n target = srcEventTarget;\n }\n\n input.target = target;\n}\n\n/**\n * @private\n * handle input events\n * @param {Manager} manager\n * @param {String} eventType\n * @param {Object} input\n */\n\nfunction inputHandler(manager, eventType, input) {\n var pointersLen = input.pointers.length;\n var changedPointersLen = input.changedPointers.length;\n var isFirst = eventType & INPUT_START && pointersLen - changedPointersLen === 0;\n var isFinal = eventType & (INPUT_END | INPUT_CANCEL) && pointersLen - changedPointersLen === 0;\n input.isFirst = !!isFirst;\n input.isFinal = !!isFinal;\n\n if (isFirst) {\n manager.session = {};\n } // source event is the normalized value of the domEvents\n // like 'touchstart, mouseup, pointerdown'\n\n\n input.eventType = eventType; // compute scale, rotation etc\n\n computeInputData(manager, input); // emit secret event\n\n manager.emit('hammer.input', input);\n manager.recognize(input);\n manager.session.prevInput = input;\n}\n\n/**\n * @private\n * split string on whitespace\n * @param {String} str\n * @returns {Array} words\n */\nfunction splitStr(str) {\n return str.trim().split(/\\s+/g);\n}\n\n/**\n * @private\n * addEventListener with multiple events at once\n * @param {EventTarget} target\n * @param {String} types\n * @param {Function} handler\n */\n\nfunction addEventListeners(target, types, handler) {\n each(splitStr(types), function (type) {\n target.addEventListener(type, handler, false);\n });\n}\n\n/**\n * @private\n * removeEventListener with multiple events at once\n * @param {EventTarget} target\n * @param {String} types\n * @param {Function} handler\n */\n\nfunction removeEventListeners(target, types, handler) {\n each(splitStr(types), function (type) {\n target.removeEventListener(type, handler, false);\n });\n}\n\n/**\n * @private\n * get the window object of an element\n * @param {HTMLElement} element\n * @returns {DocumentView|Window}\n */\nfunction getWindowForElement(element) {\n var doc = element.ownerDocument || element;\n return doc.defaultView || doc.parentWindow || window;\n}\n\n/**\n * @private\n * create new input type manager\n * @param {Manager} manager\n * @param {Function} callback\n * @returns {Input}\n * @constructor\n */\n\nvar Input =\n/*#__PURE__*/\nfunction () {\n function Input(manager, callback) {\n var self = this;\n this.manager = manager;\n this.callback = callback;\n this.element = manager.element;\n this.target = manager.options.inputTarget; // smaller wrapper around the handler, for the scope and the enabled state of the manager,\n // so when disabled the input events are completely bypassed.\n\n this.domHandler = function (ev) {\n if (boolOrFn(manager.options.enable, [manager])) {\n self.handler(ev);\n }\n };\n\n this.init();\n }\n /**\n * @private\n * should handle the inputEvent data and trigger the callback\n * @virtual\n */\n\n\n var _proto = Input.prototype;\n\n _proto.handler = function handler() {};\n /**\n * @private\n * bind the events\n */\n\n\n _proto.init = function init() {\n this.evEl && addEventListeners(this.element, this.evEl, this.domHandler);\n this.evTarget && addEventListeners(this.target, this.evTarget, this.domHandler);\n this.evWin && addEventListeners(getWindowForElement(this.element), this.evWin, this.domHandler);\n };\n /**\n * @private\n * unbind the events\n */\n\n\n _proto.destroy = function destroy() {\n this.evEl && removeEventListeners(this.element, this.evEl, this.domHandler);\n this.evTarget && removeEventListeners(this.target, this.evTarget, this.domHandler);\n this.evWin && removeEventListeners(getWindowForElement(this.element), this.evWin, this.domHandler);\n };\n\n return Input;\n}();\n\n/**\n * @private\n * find if a array contains the object using indexOf or a simple polyFill\n * @param {Array} src\n * @param {String} find\n * @param {String} [findByKey]\n * @return {Boolean|Number} false when not found, or the index\n */\nfunction inArray(src, find, findByKey) {\n if (src.indexOf && !findByKey) {\n return src.indexOf(find);\n } else {\n var i = 0;\n\n while (i < src.length) {\n if (findByKey && src[i][findByKey] == find || !findByKey && src[i] === find) {\n // do not use === here, test fails\n return i;\n }\n\n i++;\n }\n\n return -1;\n }\n}\n\nvar POINTER_INPUT_MAP = {\n pointerdown: INPUT_START,\n pointermove: INPUT_MOVE,\n pointerup: INPUT_END,\n pointercancel: INPUT_CANCEL,\n pointerout: INPUT_CANCEL\n}; // in IE10 the pointer types is defined as an enum\n\nvar IE10_POINTER_TYPE_ENUM = {\n 2: INPUT_TYPE_TOUCH,\n 3: INPUT_TYPE_PEN,\n 4: INPUT_TYPE_MOUSE,\n 5: INPUT_TYPE_KINECT // see https://twitter.com/jacobrossi/status/480596438489890816\n\n};\nvar POINTER_ELEMENT_EVENTS = 'pointerdown';\nvar POINTER_WINDOW_EVENTS = 'pointermove pointerup pointercancel'; // IE10 has prefixed support, and case-sensitive\n\nif (win.MSPointerEvent && !win.PointerEvent) {\n POINTER_ELEMENT_EVENTS = 'MSPointerDown';\n POINTER_WINDOW_EVENTS = 'MSPointerMove MSPointerUp MSPointerCancel';\n}\n/**\n * @private\n * Pointer events input\n * @constructor\n * @extends Input\n */\n\n\nvar PointerEventInput =\n/*#__PURE__*/\nfunction (_Input) {\n _inheritsLoose(PointerEventInput, _Input);\n\n function PointerEventInput() {\n var _this;\n\n var proto = PointerEventInput.prototype;\n proto.evEl = POINTER_ELEMENT_EVENTS;\n proto.evWin = POINTER_WINDOW_EVENTS;\n _this = _Input.apply(this, arguments) || this;\n _this.store = _this.manager.session.pointerEvents = [];\n return _this;\n }\n /**\n * @private\n * handle mouse events\n * @param {Object} ev\n */\n\n\n var _proto = PointerEventInput.prototype;\n\n _proto.handler = function handler(ev) {\n var store = this.store;\n var removePointer = false;\n var eventTypeNormalized = ev.type.toLowerCase().replace('ms', '');\n var eventType = POINTER_INPUT_MAP[eventTypeNormalized];\n var pointerType = IE10_POINTER_TYPE_ENUM[ev.pointerType] || ev.pointerType;\n var isTouch = pointerType === INPUT_TYPE_TOUCH; // get index of the event in the store\n\n var storeIndex = inArray(store, ev.pointerId, 'pointerId'); // start and mouse must be down\n\n if (eventType & INPUT_START && (ev.button === 0 || isTouch)) {\n if (storeIndex < 0) {\n store.push(ev);\n storeIndex = store.length - 1;\n }\n } else if (eventType & (INPUT_END | INPUT_CANCEL)) {\n removePointer = true;\n } // it not found, so the pointer hasn't been down (so it's probably a hover)\n\n\n if (storeIndex < 0) {\n return;\n } // update the event in the store\n\n\n store[storeIndex] = ev;\n this.callback(this.manager, eventType, {\n pointers: store,\n changedPointers: [ev],\n pointerType: pointerType,\n srcEvent: ev\n });\n\n if (removePointer) {\n // remove from the store\n store.splice(storeIndex, 1);\n }\n };\n\n return PointerEventInput;\n}(Input);\n\n/**\n * @private\n * convert array-like objects to real arrays\n * @param {Object} obj\n * @returns {Array}\n */\nfunction toArray(obj) {\n return Array.prototype.slice.call(obj, 0);\n}\n\n/**\n * @private\n * unique array with objects based on a key (like 'id') or just by the array's value\n * @param {Array} src [{id:1},{id:2},{id:1}]\n * @param {String} [key]\n * @param {Boolean} [sort=False]\n * @returns {Array} [{id:1},{id:2}]\n */\n\nfunction uniqueArray(src, key, sort) {\n var results = [];\n var values = [];\n var i = 0;\n\n while (i < src.length) {\n var val = key ? src[i][key] : src[i];\n\n if (inArray(values, val) < 0) {\n results.push(src[i]);\n }\n\n values[i] = val;\n i++;\n }\n\n if (sort) {\n if (!key) {\n results = results.sort();\n } else {\n results = results.sort(function (a, b) {\n return a[key] > b[key];\n });\n }\n }\n\n return results;\n}\n\nvar TOUCH_INPUT_MAP = {\n touchstart: INPUT_START,\n touchmove: INPUT_MOVE,\n touchend: INPUT_END,\n touchcancel: INPUT_CANCEL\n};\nvar TOUCH_TARGET_EVENTS = 'touchstart touchmove touchend touchcancel';\n/**\n * @private\n * Multi-user touch events input\n * @constructor\n * @extends Input\n */\n\nvar TouchInput =\n/*#__PURE__*/\nfunction (_Input) {\n _inheritsLoose(TouchInput, _Input);\n\n function TouchInput() {\n var _this;\n\n TouchInput.prototype.evTarget = TOUCH_TARGET_EVENTS;\n _this = _Input.apply(this, arguments) || this;\n _this.targetIds = {}; // this.evTarget = TOUCH_TARGET_EVENTS;\n\n return _this;\n }\n\n var _proto = TouchInput.prototype;\n\n _proto.handler = function handler(ev) {\n var type = TOUCH_INPUT_MAP[ev.type];\n var touches = getTouches.call(this, ev, type);\n\n if (!touches) {\n return;\n }\n\n this.callback(this.manager, type, {\n pointers: touches[0],\n changedPointers: touches[1],\n pointerType: INPUT_TYPE_TOUCH,\n srcEvent: ev\n });\n };\n\n return TouchInput;\n}(Input);\n\nfunction getTouches(ev, type) {\n var allTouches = toArray(ev.touches);\n var targetIds = this.targetIds; // when there is only one touch, the process can be simplified\n\n if (type & (INPUT_START | INPUT_MOVE) && allTouches.length === 1) {\n targetIds[allTouches[0].identifier] = true;\n return [allTouches, allTouches];\n }\n\n var i;\n var targetTouches;\n var changedTouches = toArray(ev.changedTouches);\n var changedTargetTouches = [];\n var target = this.target; // get target touches from touches\n\n targetTouches = allTouches.filter(function (touch) {\n return hasParent(touch.target, target);\n }); // collect touches\n\n if (type === INPUT_START) {\n i = 0;\n\n while (i < targetTouches.length) {\n targetIds[targetTouches[i].identifier] = true;\n i++;\n }\n } // filter changed touches to only contain touches that exist in the collected target ids\n\n\n i = 0;\n\n while (i < changedTouches.length) {\n if (targetIds[changedTouches[i].identifier]) {\n changedTargetTouches.push(changedTouches[i]);\n } // cleanup removed touches\n\n\n if (type & (INPUT_END | INPUT_CANCEL)) {\n delete targetIds[changedTouches[i].identifier];\n }\n\n i++;\n }\n\n if (!changedTargetTouches.length) {\n return;\n }\n\n return [// merge targetTouches with changedTargetTouches so it contains ALL touches, including 'end' and 'cancel'\n uniqueArray(targetTouches.concat(changedTargetTouches), 'identifier', true), changedTargetTouches];\n}\n\nvar MOUSE_INPUT_MAP = {\n mousedown: INPUT_START,\n mousemove: INPUT_MOVE,\n mouseup: INPUT_END\n};\nvar MOUSE_ELEMENT_EVENTS = 'mousedown';\nvar MOUSE_WINDOW_EVENTS = 'mousemove mouseup';\n/**\n * @private\n * Mouse events input\n * @constructor\n * @extends Input\n */\n\nvar MouseInput =\n/*#__PURE__*/\nfunction (_Input) {\n _inheritsLoose(MouseInput, _Input);\n\n function MouseInput() {\n var _this;\n\n var proto = MouseInput.prototype;\n proto.evEl = MOUSE_ELEMENT_EVENTS;\n proto.evWin = MOUSE_WINDOW_EVENTS;\n _this = _Input.apply(this, arguments) || this;\n _this.pressed = false; // mousedown state\n\n return _this;\n }\n /**\n * @private\n * handle mouse events\n * @param {Object} ev\n */\n\n\n var _proto = MouseInput.prototype;\n\n _proto.handler = function handler(ev) {\n var eventType = MOUSE_INPUT_MAP[ev.type]; // on start we want to have the left mouse button down\n\n if (eventType & INPUT_START && ev.button === 0) {\n this.pressed = true;\n }\n\n if (eventType & INPUT_MOVE && ev.which !== 1) {\n eventType = INPUT_END;\n } // mouse must be down\n\n\n if (!this.pressed) {\n return;\n }\n\n if (eventType & INPUT_END) {\n this.pressed = false;\n }\n\n this.callback(this.manager, eventType, {\n pointers: [ev],\n changedPointers: [ev],\n pointerType: INPUT_TYPE_MOUSE,\n srcEvent: ev\n });\n };\n\n return MouseInput;\n}(Input);\n\n/**\n * @private\n * Combined touch and mouse input\n *\n * Touch has a higher priority then mouse, and while touching no mouse events are allowed.\n * This because touch devices also emit mouse events while doing a touch.\n *\n * @constructor\n * @extends Input\n */\n\nvar DEDUP_TIMEOUT = 2500;\nvar DEDUP_DISTANCE = 25;\n\nfunction setLastTouch(eventData) {\n var _eventData$changedPoi = eventData.changedPointers,\n touch = _eventData$changedPoi[0];\n\n if (touch.identifier === this.primaryTouch) {\n var lastTouch = {\n x: touch.clientX,\n y: touch.clientY\n };\n var lts = this.lastTouches;\n this.lastTouches.push(lastTouch);\n\n var removeLastTouch = function removeLastTouch() {\n var i = lts.indexOf(lastTouch);\n\n if (i > -1) {\n lts.splice(i, 1);\n }\n };\n\n setTimeout(removeLastTouch, DEDUP_TIMEOUT);\n }\n}\n\nfunction recordTouches(eventType, eventData) {\n if (eventType & INPUT_START) {\n this.primaryTouch = eventData.changedPointers[0].identifier;\n setLastTouch.call(this, eventData);\n } else if (eventType & (INPUT_END | INPUT_CANCEL)) {\n setLastTouch.call(this, eventData);\n }\n}\n\nfunction isSyntheticEvent(eventData) {\n var x = eventData.srcEvent.clientX;\n var y = eventData.srcEvent.clientY;\n\n for (var i = 0; i < this.lastTouches.length; i++) {\n var t = this.lastTouches[i];\n var dx = Math.abs(x - t.x);\n var dy = Math.abs(y - t.y);\n\n if (dx <= DEDUP_DISTANCE && dy <= DEDUP_DISTANCE) {\n return true;\n }\n }\n\n return false;\n}\n\nvar TouchMouseInput =\n/*#__PURE__*/\nfunction () {\n var TouchMouseInput =\n /*#__PURE__*/\n function (_Input) {\n _inheritsLoose(TouchMouseInput, _Input);\n\n function TouchMouseInput(_manager, callback) {\n var _this;\n\n _this = _Input.call(this, _manager, callback) || this;\n\n _this.handler = function (manager, inputEvent, inputData) {\n var isTouch = inputData.pointerType === INPUT_TYPE_TOUCH;\n var isMouse = inputData.pointerType === INPUT_TYPE_MOUSE;\n\n if (isMouse && inputData.sourceCapabilities && inputData.sourceCapabilities.firesTouchEvents) {\n return;\n } // when we're in a touch event, record touches to de-dupe synthetic mouse event\n\n\n if (isTouch) {\n recordTouches.call(_assertThisInitialized(_assertThisInitialized(_this)), inputEvent, inputData);\n } else if (isMouse && isSyntheticEvent.call(_assertThisInitialized(_assertThisInitialized(_this)), inputData)) {\n return;\n }\n\n _this.callback(manager, inputEvent, inputData);\n };\n\n _this.touch = new TouchInput(_this.manager, _this.handler);\n _this.mouse = new MouseInput(_this.manager, _this.handler);\n _this.primaryTouch = null;\n _this.lastTouches = [];\n return _this;\n }\n /**\n * @private\n * handle mouse and touch events\n * @param {Hammer} manager\n * @param {String} inputEvent\n * @param {Object} inputData\n */\n\n\n var _proto = TouchMouseInput.prototype;\n\n /**\n * @private\n * remove the event listeners\n */\n _proto.destroy = function destroy() {\n this.touch.destroy();\n this.mouse.destroy();\n };\n\n return TouchMouseInput;\n }(Input);\n\n return TouchMouseInput;\n}();\n\n/**\n * @private\n * create new input type manager\n * called by the Manager constructor\n * @param {Hammer} manager\n * @returns {Input}\n */\n\nfunction createInputInstance(manager) {\n var Type; // let inputClass = manager.options.inputClass;\n\n var inputClass = manager.options.inputClass;\n\n if (inputClass) {\n Type = inputClass;\n } else if (SUPPORT_POINTER_EVENTS) {\n Type = PointerEventInput;\n } else if (SUPPORT_ONLY_TOUCH) {\n Type = TouchInput;\n } else if (!SUPPORT_TOUCH) {\n Type = MouseInput;\n } else {\n Type = TouchMouseInput;\n }\n\n return new Type(manager, inputHandler);\n}\n\n/**\n * @private\n * if the argument is an array, we want to execute the fn on each entry\n * if it aint an array we don't want to do a thing.\n * this is used by all the methods that accept a single and array argument.\n * @param {*|Array} arg\n * @param {String} fn\n * @param {Object} [context]\n * @returns {Boolean}\n */\n\nfunction invokeArrayArg(arg, fn, context) {\n if (Array.isArray(arg)) {\n each(arg, context[fn], context);\n return true;\n }\n\n return false;\n}\n\nvar STATE_POSSIBLE = 1;\nvar STATE_BEGAN = 2;\nvar STATE_CHANGED = 4;\nvar STATE_ENDED = 8;\nvar STATE_RECOGNIZED = STATE_ENDED;\nvar STATE_CANCELLED = 16;\nvar STATE_FAILED = 32;\n\n/**\n * @private\n * get a unique id\n * @returns {number} uniqueId\n */\nvar _uniqueId = 1;\nfunction uniqueId() {\n return _uniqueId++;\n}\n\n/**\n * @private\n * get a recognizer by name if it is bound to a manager\n * @param {Recognizer|String} otherRecognizer\n * @param {Recognizer} recognizer\n * @returns {Recognizer}\n */\nfunction getRecognizerByNameIfManager(otherRecognizer, recognizer) {\n var manager = recognizer.manager;\n\n if (manager) {\n return manager.get(otherRecognizer);\n }\n\n return otherRecognizer;\n}\n\n/**\n * @private\n * get a usable string, used as event postfix\n * @param {constant} state\n * @returns {String} state\n */\n\nfunction stateStr(state) {\n if (state & STATE_CANCELLED) {\n return 'cancel';\n } else if (state & STATE_ENDED) {\n return 'end';\n } else if (state & STATE_CHANGED) {\n return 'move';\n } else if (state & STATE_BEGAN) {\n return 'start';\n }\n\n return '';\n}\n\n/**\n * @private\n * Recognizer flow explained; *\n * All recognizers have the initial state of POSSIBLE when a input session starts.\n * The definition of a input session is from the first input until the last input, with all it's movement in it. *\n * Example session for mouse-input: mousedown -> mousemove -> mouseup\n *\n * On each recognizing cycle (see Manager.recognize) the .recognize() method is executed\n * which determines with state it should be.\n *\n * If the recognizer has the state FAILED, CANCELLED or RECOGNIZED (equals ENDED), it is reset to\n * POSSIBLE to give it another change on the next cycle.\n *\n * Possible\n * |\n * +-----+---------------+\n * | |\n * +-----+-----+ |\n * | | |\n * Failed Cancelled |\n * +-------+------+\n * | |\n * Recognized Began\n * |\n * Changed\n * |\n * Ended/Recognized\n */\n\n/**\n * @private\n * Recognizer\n * Every recognizer needs to extend from this class.\n * @constructor\n * @param {Object} options\n */\n\nvar Recognizer =\n/*#__PURE__*/\nfunction () {\n function Recognizer(options) {\n if (options === void 0) {\n options = {};\n }\n\n this.options = _extends({\n enable: true\n }, options);\n this.id = uniqueId();\n this.manager = null; // default is enable true\n\n this.state = STATE_POSSIBLE;\n this.simultaneous = {};\n this.requireFail = [];\n }\n /**\n * @private\n * set options\n * @param {Object} options\n * @return {Recognizer}\n */\n\n\n var _proto = Recognizer.prototype;\n\n _proto.set = function set(options) {\n assign$1(this.options, options); // also update the touchAction, in case something changed about the directions/enabled state\n\n this.manager && this.manager.touchAction.update();\n return this;\n };\n /**\n * @private\n * recognize simultaneous with an other recognizer.\n * @param {Recognizer} otherRecognizer\n * @returns {Recognizer} this\n */\n\n\n _proto.recognizeWith = function recognizeWith(otherRecognizer) {\n if (invokeArrayArg(otherRecognizer, 'recognizeWith', this)) {\n return this;\n }\n\n var simultaneous = this.simultaneous;\n otherRecognizer = getRecognizerByNameIfManager(otherRecognizer, this);\n\n if (!simultaneous[otherRecognizer.id]) {\n simultaneous[otherRecognizer.id] = otherRecognizer;\n otherRecognizer.recognizeWith(this);\n }\n\n return this;\n };\n /**\n * @private\n * drop the simultaneous link. it doesnt remove the link on the other recognizer.\n * @param {Recognizer} otherRecognizer\n * @returns {Recognizer} this\n */\n\n\n _proto.dropRecognizeWith = function dropRecognizeWith(otherRecognizer) {\n if (invokeArrayArg(otherRecognizer, 'dropRecognizeWith', this)) {\n return this;\n }\n\n otherRecognizer = getRecognizerByNameIfManager(otherRecognizer, this);\n delete this.simultaneous[otherRecognizer.id];\n return this;\n };\n /**\n * @private\n * recognizer can only run when an other is failing\n * @param {Recognizer} otherRecognizer\n * @returns {Recognizer} this\n */\n\n\n _proto.requireFailure = function requireFailure(otherRecognizer) {\n if (invokeArrayArg(otherRecognizer, 'requireFailure', this)) {\n return this;\n }\n\n var requireFail = this.requireFail;\n otherRecognizer = getRecognizerByNameIfManager(otherRecognizer, this);\n\n if (inArray(requireFail, otherRecognizer) === -1) {\n requireFail.push(otherRecognizer);\n otherRecognizer.requireFailure(this);\n }\n\n return this;\n };\n /**\n * @private\n * drop the requireFailure link. it does not remove the link on the other recognizer.\n * @param {Recognizer} otherRecognizer\n * @returns {Recognizer} this\n */\n\n\n _proto.dropRequireFailure = function dropRequireFailure(otherRecognizer) {\n if (invokeArrayArg(otherRecognizer, 'dropRequireFailure', this)) {\n return this;\n }\n\n otherRecognizer = getRecognizerByNameIfManager(otherRecognizer, this);\n var index = inArray(this.requireFail, otherRecognizer);\n\n if (index > -1) {\n this.requireFail.splice(index, 1);\n }\n\n return this;\n };\n /**\n * @private\n * has require failures boolean\n * @returns {boolean}\n */\n\n\n _proto.hasRequireFailures = function hasRequireFailures() {\n return this.requireFail.length > 0;\n };\n /**\n * @private\n * if the recognizer can recognize simultaneous with an other recognizer\n * @param {Recognizer} otherRecognizer\n * @returns {Boolean}\n */\n\n\n _proto.canRecognizeWith = function canRecognizeWith(otherRecognizer) {\n return !!this.simultaneous[otherRecognizer.id];\n };\n /**\n * @private\n * You should use `tryEmit` instead of `emit` directly to check\n * that all the needed recognizers has failed before emitting.\n * @param {Object} input\n */\n\n\n _proto.emit = function emit(input) {\n var self = this;\n var state = this.state;\n\n function emit(event) {\n self.manager.emit(event, input);\n } // 'panstart' and 'panmove'\n\n\n if (state < STATE_ENDED) {\n emit(self.options.event + stateStr(state));\n }\n\n emit(self.options.event); // simple 'eventName' events\n\n if (input.additionalEvent) {\n // additional event(panleft, panright, pinchin, pinchout...)\n emit(input.additionalEvent);\n } // panend and pancancel\n\n\n if (state >= STATE_ENDED) {\n emit(self.options.event + stateStr(state));\n }\n };\n /**\n * @private\n * Check that all the require failure recognizers has failed,\n * if true, it emits a gesture event,\n * otherwise, setup the state to FAILED.\n * @param {Object} input\n */\n\n\n _proto.tryEmit = function tryEmit(input) {\n if (this.canEmit()) {\n return this.emit(input);\n } // it's failing anyway\n\n\n this.state = STATE_FAILED;\n };\n /**\n * @private\n * can we emit?\n * @returns {boolean}\n */\n\n\n _proto.canEmit = function canEmit() {\n var i = 0;\n\n while (i < this.requireFail.length) {\n if (!(this.requireFail[i].state & (STATE_FAILED | STATE_POSSIBLE))) {\n return false;\n }\n\n i++;\n }\n\n return true;\n };\n /**\n * @private\n * update the recognizer\n * @param {Object} inputData\n */\n\n\n _proto.recognize = function recognize(inputData) {\n // make a new copy of the inputData\n // so we can change the inputData without messing up the other recognizers\n var inputDataClone = assign$1({}, inputData); // is is enabled and allow recognizing?\n\n if (!boolOrFn(this.options.enable, [this, inputDataClone])) {\n this.reset();\n this.state = STATE_FAILED;\n return;\n } // reset when we've reached the end\n\n\n if (this.state & (STATE_RECOGNIZED | STATE_CANCELLED | STATE_FAILED)) {\n this.state = STATE_POSSIBLE;\n }\n\n this.state = this.process(inputDataClone); // the recognizer has recognized a gesture\n // so trigger an event\n\n if (this.state & (STATE_BEGAN | STATE_CHANGED | STATE_ENDED | STATE_CANCELLED)) {\n this.tryEmit(inputDataClone);\n }\n };\n /**\n * @private\n * return the state of the recognizer\n * the actual recognizing happens in this method\n * @virtual\n * @param {Object} inputData\n * @returns {constant} STATE\n */\n\n /* jshint ignore:start */\n\n\n _proto.process = function process(inputData) {};\n /* jshint ignore:end */\n\n /**\n * @private\n * return the preferred touch-action\n * @virtual\n * @returns {Array}\n */\n\n\n _proto.getTouchAction = function getTouchAction() {};\n /**\n * @private\n * called when the gesture isn't allowed to recognize\n * like when another is being recognized or it is disabled\n * @virtual\n */\n\n\n _proto.reset = function reset() {};\n\n return Recognizer;\n}();\n\n/**\n * @private\n * A tap is recognized when the pointer is doing a small tap/click. Multiple taps are recognized if they occur\n * between the given interval and position. The delay option can be used to recognize multi-taps without firing\n * a single tap.\n *\n * The eventData from the emitted event contains the property `tapCount`, which contains the amount of\n * multi-taps being recognized.\n * @constructor\n * @extends Recognizer\n */\n\nvar TapRecognizer =\n/*#__PURE__*/\nfunction (_Recognizer) {\n _inheritsLoose(TapRecognizer, _Recognizer);\n\n function TapRecognizer(options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n _this = _Recognizer.call(this, _extends({\n event: 'tap',\n pointers: 1,\n taps: 1,\n interval: 300,\n // max time between the multi-tap taps\n time: 250,\n // max time of the pointer to be down (like finger on the screen)\n threshold: 9,\n // a minimal movement is ok, but keep it low\n posThreshold: 10\n }, options)) || this; // previous time and center,\n // used for tap counting\n\n _this.pTime = false;\n _this.pCenter = false;\n _this._timer = null;\n _this._input = null;\n _this.count = 0;\n return _this;\n }\n\n var _proto = TapRecognizer.prototype;\n\n _proto.getTouchAction = function getTouchAction() {\n return [TOUCH_ACTION_MANIPULATION];\n };\n\n _proto.process = function process(input) {\n var _this2 = this;\n\n var options = this.options;\n var validPointers = input.pointers.length === options.pointers;\n var validMovement = input.distance < options.threshold;\n var validTouchTime = input.deltaTime < options.time;\n this.reset();\n\n if (input.eventType & INPUT_START && this.count === 0) {\n return this.failTimeout();\n } // we only allow little movement\n // and we've reached an end event, so a tap is possible\n\n\n if (validMovement && validTouchTime && validPointers) {\n if (input.eventType !== INPUT_END) {\n return this.failTimeout();\n }\n\n var validInterval = this.pTime ? input.timeStamp - this.pTime < options.interval : true;\n var validMultiTap = !this.pCenter || getDistance(this.pCenter, input.center) < options.posThreshold;\n this.pTime = input.timeStamp;\n this.pCenter = input.center;\n\n if (!validMultiTap || !validInterval) {\n this.count = 1;\n } else {\n this.count += 1;\n }\n\n this._input = input; // if tap count matches we have recognized it,\n // else it has began recognizing...\n\n var tapCount = this.count % options.taps;\n\n if (tapCount === 0) {\n // no failing requirements, immediately trigger the tap event\n // or wait as long as the multitap interval to trigger\n if (!this.hasRequireFailures()) {\n return STATE_RECOGNIZED;\n } else {\n this._timer = setTimeout(function () {\n _this2.state = STATE_RECOGNIZED;\n\n _this2.tryEmit();\n }, options.interval);\n return STATE_BEGAN;\n }\n }\n }\n\n return STATE_FAILED;\n };\n\n _proto.failTimeout = function failTimeout() {\n var _this3 = this;\n\n this._timer = setTimeout(function () {\n _this3.state = STATE_FAILED;\n }, this.options.interval);\n return STATE_FAILED;\n };\n\n _proto.reset = function reset() {\n clearTimeout(this._timer);\n };\n\n _proto.emit = function emit() {\n if (this.state === STATE_RECOGNIZED) {\n this._input.tapCount = this.count;\n this.manager.emit(this.options.event, this._input);\n }\n };\n\n return TapRecognizer;\n}(Recognizer);\n\n/**\n * @private\n * This recognizer is just used as a base for the simple attribute recognizers.\n * @constructor\n * @extends Recognizer\n */\n\nvar AttrRecognizer =\n/*#__PURE__*/\nfunction (_Recognizer) {\n _inheritsLoose(AttrRecognizer, _Recognizer);\n\n function AttrRecognizer(options) {\n if (options === void 0) {\n options = {};\n }\n\n return _Recognizer.call(this, _extends({\n pointers: 1\n }, options)) || this;\n }\n /**\n * @private\n * Used to check if it the recognizer receives valid input, like input.distance > 10.\n * @memberof AttrRecognizer\n * @param {Object} input\n * @returns {Boolean} recognized\n */\n\n\n var _proto = AttrRecognizer.prototype;\n\n _proto.attrTest = function attrTest(input) {\n var optionPointers = this.options.pointers;\n return optionPointers === 0 || input.pointers.length === optionPointers;\n };\n /**\n * @private\n * Process the input and return the state for the recognizer\n * @memberof AttrRecognizer\n * @param {Object} input\n * @returns {*} State\n */\n\n\n _proto.process = function process(input) {\n var state = this.state;\n var eventType = input.eventType;\n var isRecognized = state & (STATE_BEGAN | STATE_CHANGED);\n var isValid = this.attrTest(input); // on cancel input and we've recognized before, return STATE_CANCELLED\n\n if (isRecognized && (eventType & INPUT_CANCEL || !isValid)) {\n return state | STATE_CANCELLED;\n } else if (isRecognized || isValid) {\n if (eventType & INPUT_END) {\n return state | STATE_ENDED;\n } else if (!(state & STATE_BEGAN)) {\n return STATE_BEGAN;\n }\n\n return state | STATE_CHANGED;\n }\n\n return STATE_FAILED;\n };\n\n return AttrRecognizer;\n}(Recognizer);\n\n/**\n * @private\n * direction cons to string\n * @param {constant} direction\n * @returns {String}\n */\n\nfunction directionStr(direction) {\n if (direction === DIRECTION_DOWN) {\n return 'down';\n } else if (direction === DIRECTION_UP) {\n return 'up';\n } else if (direction === DIRECTION_LEFT) {\n return 'left';\n } else if (direction === DIRECTION_RIGHT) {\n return 'right';\n }\n\n return '';\n}\n\n/**\n * @private\n * Pan\n * Recognized when the pointer is down and moved in the allowed direction.\n * @constructor\n * @extends AttrRecognizer\n */\n\nvar PanRecognizer =\n/*#__PURE__*/\nfunction (_AttrRecognizer) {\n _inheritsLoose(PanRecognizer, _AttrRecognizer);\n\n function PanRecognizer(options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n _this = _AttrRecognizer.call(this, _extends({\n event: 'pan',\n threshold: 10,\n pointers: 1,\n direction: DIRECTION_ALL\n }, options)) || this;\n _this.pX = null;\n _this.pY = null;\n return _this;\n }\n\n var _proto = PanRecognizer.prototype;\n\n _proto.getTouchAction = function getTouchAction() {\n var direction = this.options.direction;\n var actions = [];\n\n if (direction & DIRECTION_HORIZONTAL) {\n actions.push(TOUCH_ACTION_PAN_Y);\n }\n\n if (direction & DIRECTION_VERTICAL) {\n actions.push(TOUCH_ACTION_PAN_X);\n }\n\n return actions;\n };\n\n _proto.directionTest = function directionTest(input) {\n var options = this.options;\n var hasMoved = true;\n var distance = input.distance;\n var direction = input.direction;\n var x = input.deltaX;\n var y = input.deltaY; // lock to axis?\n\n if (!(direction & options.direction)) {\n if (options.direction & DIRECTION_HORIZONTAL) {\n direction = x === 0 ? DIRECTION_NONE : x < 0 ? DIRECTION_LEFT : DIRECTION_RIGHT;\n hasMoved = x !== this.pX;\n distance = Math.abs(input.deltaX);\n } else {\n direction = y === 0 ? DIRECTION_NONE : y < 0 ? DIRECTION_UP : DIRECTION_DOWN;\n hasMoved = y !== this.pY;\n distance = Math.abs(input.deltaY);\n }\n }\n\n input.direction = direction;\n return hasMoved && distance > options.threshold && direction & options.direction;\n };\n\n _proto.attrTest = function attrTest(input) {\n return AttrRecognizer.prototype.attrTest.call(this, input) && ( // replace with a super call\n this.state & STATE_BEGAN || !(this.state & STATE_BEGAN) && this.directionTest(input));\n };\n\n _proto.emit = function emit(input) {\n this.pX = input.deltaX;\n this.pY = input.deltaY;\n var direction = directionStr(input.direction);\n\n if (direction) {\n input.additionalEvent = this.options.event + direction;\n }\n\n _AttrRecognizer.prototype.emit.call(this, input);\n };\n\n return PanRecognizer;\n}(AttrRecognizer);\n\n/**\n * @private\n * Swipe\n * Recognized when the pointer is moving fast (velocity), with enough distance in the allowed direction.\n * @constructor\n * @extends AttrRecognizer\n */\n\nvar SwipeRecognizer =\n/*#__PURE__*/\nfunction (_AttrRecognizer) {\n _inheritsLoose(SwipeRecognizer, _AttrRecognizer);\n\n function SwipeRecognizer(options) {\n if (options === void 0) {\n options = {};\n }\n\n return _AttrRecognizer.call(this, _extends({\n event: 'swipe',\n threshold: 10,\n velocity: 0.3,\n direction: DIRECTION_HORIZONTAL | DIRECTION_VERTICAL,\n pointers: 1\n }, options)) || this;\n }\n\n var _proto = SwipeRecognizer.prototype;\n\n _proto.getTouchAction = function getTouchAction() {\n return PanRecognizer.prototype.getTouchAction.call(this);\n };\n\n _proto.attrTest = function attrTest(input) {\n var direction = this.options.direction;\n var velocity;\n\n if (direction & (DIRECTION_HORIZONTAL | DIRECTION_VERTICAL)) {\n velocity = input.overallVelocity;\n } else if (direction & DIRECTION_HORIZONTAL) {\n velocity = input.overallVelocityX;\n } else if (direction & DIRECTION_VERTICAL) {\n velocity = input.overallVelocityY;\n }\n\n return _AttrRecognizer.prototype.attrTest.call(this, input) && direction & input.offsetDirection && input.distance > this.options.threshold && input.maxPointers === this.options.pointers && abs(velocity) > this.options.velocity && input.eventType & INPUT_END;\n };\n\n _proto.emit = function emit(input) {\n var direction = directionStr(input.offsetDirection);\n\n if (direction) {\n this.manager.emit(this.options.event + direction, input);\n }\n\n this.manager.emit(this.options.event, input);\n };\n\n return SwipeRecognizer;\n}(AttrRecognizer);\n\n/**\n * @private\n * Pinch\n * Recognized when two or more pointers are moving toward (zoom-in) or away from each other (zoom-out).\n * @constructor\n * @extends AttrRecognizer\n */\n\nvar PinchRecognizer =\n/*#__PURE__*/\nfunction (_AttrRecognizer) {\n _inheritsLoose(PinchRecognizer, _AttrRecognizer);\n\n function PinchRecognizer(options) {\n if (options === void 0) {\n options = {};\n }\n\n return _AttrRecognizer.call(this, _extends({\n event: 'pinch',\n threshold: 0,\n pointers: 2\n }, options)) || this;\n }\n\n var _proto = PinchRecognizer.prototype;\n\n _proto.getTouchAction = function getTouchAction() {\n return [TOUCH_ACTION_NONE];\n };\n\n _proto.attrTest = function attrTest(input) {\n return _AttrRecognizer.prototype.attrTest.call(this, input) && (Math.abs(input.scale - 1) > this.options.threshold || this.state & STATE_BEGAN);\n };\n\n _proto.emit = function emit(input) {\n if (input.scale !== 1) {\n var inOut = input.scale < 1 ? 'in' : 'out';\n input.additionalEvent = this.options.event + inOut;\n }\n\n _AttrRecognizer.prototype.emit.call(this, input);\n };\n\n return PinchRecognizer;\n}(AttrRecognizer);\n\n/**\n * @private\n * Rotate\n * Recognized when two or more pointer are moving in a circular motion.\n * @constructor\n * @extends AttrRecognizer\n */\n\nvar RotateRecognizer =\n/*#__PURE__*/\nfunction (_AttrRecognizer) {\n _inheritsLoose(RotateRecognizer, _AttrRecognizer);\n\n function RotateRecognizer(options) {\n if (options === void 0) {\n options = {};\n }\n\n return _AttrRecognizer.call(this, _extends({\n event: 'rotate',\n threshold: 0,\n pointers: 2\n }, options)) || this;\n }\n\n var _proto = RotateRecognizer.prototype;\n\n _proto.getTouchAction = function getTouchAction() {\n return [TOUCH_ACTION_NONE];\n };\n\n _proto.attrTest = function attrTest(input) {\n return _AttrRecognizer.prototype.attrTest.call(this, input) && (Math.abs(input.rotation) > this.options.threshold || this.state & STATE_BEGAN);\n };\n\n return RotateRecognizer;\n}(AttrRecognizer);\n\n/**\n * @private\n * Press\n * Recognized when the pointer is down for x ms without any movement.\n * @constructor\n * @extends Recognizer\n */\n\nvar PressRecognizer =\n/*#__PURE__*/\nfunction (_Recognizer) {\n _inheritsLoose(PressRecognizer, _Recognizer);\n\n function PressRecognizer(options) {\n var _this;\n\n if (options === void 0) {\n options = {};\n }\n\n _this = _Recognizer.call(this, _extends({\n event: 'press',\n pointers: 1,\n time: 251,\n // minimal time of the pointer to be pressed\n threshold: 9\n }, options)) || this;\n _this._timer = null;\n _this._input = null;\n return _this;\n }\n\n var _proto = PressRecognizer.prototype;\n\n _proto.getTouchAction = function getTouchAction() {\n return [TOUCH_ACTION_AUTO];\n };\n\n _proto.process = function process(input) {\n var _this2 = this;\n\n var options = this.options;\n var validPointers = input.pointers.length === options.pointers;\n var validMovement = input.distance < options.threshold;\n var validTime = input.deltaTime > options.time;\n this._input = input; // we only allow little movement\n // and we've reached an end event, so a tap is possible\n\n if (!validMovement || !validPointers || input.eventType & (INPUT_END | INPUT_CANCEL) && !validTime) {\n this.reset();\n } else if (input.eventType & INPUT_START) {\n this.reset();\n this._timer = setTimeout(function () {\n _this2.state = STATE_RECOGNIZED;\n\n _this2.tryEmit();\n }, options.time);\n } else if (input.eventType & INPUT_END) {\n return STATE_RECOGNIZED;\n }\n\n return STATE_FAILED;\n };\n\n _proto.reset = function reset() {\n clearTimeout(this._timer);\n };\n\n _proto.emit = function emit(input) {\n if (this.state !== STATE_RECOGNIZED) {\n return;\n }\n\n if (input && input.eventType & INPUT_END) {\n this.manager.emit(this.options.event + \"up\", input);\n } else {\n this._input.timeStamp = now();\n this.manager.emit(this.options.event, this._input);\n }\n };\n\n return PressRecognizer;\n}(Recognizer);\n\nvar defaults = {\n /**\n * @private\n * set if DOM events are being triggered.\n * But this is slower and unused by simple implementations, so disabled by default.\n * @type {Boolean}\n * @default false\n */\n domEvents: false,\n\n /**\n * @private\n * The value for the touchAction property/fallback.\n * When set to `compute` it will magically set the correct value based on the added recognizers.\n * @type {String}\n * @default compute\n */\n touchAction: TOUCH_ACTION_COMPUTE,\n\n /**\n * @private\n * @type {Boolean}\n * @default true\n */\n enable: true,\n\n /**\n * @private\n * EXPERIMENTAL FEATURE -- can be removed/changed\n * Change the parent input target element.\n * If Null, then it is being set the to main element.\n * @type {Null|EventTarget}\n * @default null\n */\n inputTarget: null,\n\n /**\n * @private\n * force an input class\n * @type {Null|Function}\n * @default null\n */\n inputClass: null,\n\n /**\n * @private\n * Some CSS properties can be used to improve the working of Hammer.\n * Add them to this method and they will be set when creating a new Manager.\n * @namespace\n */\n cssProps: {\n /**\n * @private\n * Disables text selection to improve the dragging gesture. Mainly for desktop browsers.\n * @type {String}\n * @default 'none'\n */\n userSelect: \"none\",\n\n /**\n * @private\n * Disable the Windows Phone grippers when pressing an element.\n * @type {String}\n * @default 'none'\n */\n touchSelect: \"none\",\n\n /**\n * @private\n * Disables the default callout shown when you touch and hold a touch target.\n * On iOS, when you touch and hold a touch target such as a link, Safari displays\n * a callout containing information about the link. This property allows you to disable that callout.\n * @type {String}\n * @default 'none'\n */\n touchCallout: \"none\",\n\n /**\n * @private\n * Specifies whether zooming is enabled. Used by IE10>\n * @type {String}\n * @default 'none'\n */\n contentZooming: \"none\",\n\n /**\n * @private\n * Specifies that an entire element should be draggable instead of its contents. Mainly for desktop browsers.\n * @type {String}\n * @default 'none'\n */\n userDrag: \"none\",\n\n /**\n * @private\n * Overrides the highlight color shown when the user taps a link or a JavaScript\n * clickable element in iOS. This property obeys the alpha value, if specified.\n * @type {String}\n * @default 'rgba(0,0,0,0)'\n */\n tapHighlightColor: \"rgba(0,0,0,0)\"\n }\n};\n/**\n * @private\n * Default recognizer setup when calling `Hammer()`\n * When creating a new Manager these will be skipped.\n * This is separated with other defaults because of tree-shaking.\n * @type {Array}\n */\n\nvar preset = [[RotateRecognizer, {\n enable: false\n}], [PinchRecognizer, {\n enable: false\n}, ['rotate']], [SwipeRecognizer, {\n direction: DIRECTION_HORIZONTAL\n}], [PanRecognizer, {\n direction: DIRECTION_HORIZONTAL\n}, ['swipe']], [TapRecognizer], [TapRecognizer, {\n event: 'doubletap',\n taps: 2\n}, ['tap']], [PressRecognizer]];\n\nvar STOP = 1;\nvar FORCED_STOP = 2;\n/**\n * @private\n * add/remove the css properties as defined in manager.options.cssProps\n * @param {Manager} manager\n * @param {Boolean} add\n */\n\nfunction toggleCssProps(manager, add) {\n var element = manager.element;\n\n if (!element.style) {\n return;\n }\n\n var prop;\n each(manager.options.cssProps, function (value, name) {\n prop = prefixed(element.style, name);\n\n if (add) {\n manager.oldCssProps[prop] = element.style[prop];\n element.style[prop] = value;\n } else {\n element.style[prop] = manager.oldCssProps[prop] || \"\";\n }\n });\n\n if (!add) {\n manager.oldCssProps = {};\n }\n}\n/**\n * @private\n * trigger dom event\n * @param {String} event\n * @param {Object} data\n */\n\n\nfunction triggerDomEvent(event, data) {\n var gestureEvent = document.createEvent(\"Event\");\n gestureEvent.initEvent(event, true, true);\n gestureEvent.gesture = data;\n data.target.dispatchEvent(gestureEvent);\n}\n/**\n* @private\n * Manager\n * @param {HTMLElement} element\n * @param {Object} [options]\n * @constructor\n */\n\n\nvar Manager =\n/*#__PURE__*/\nfunction () {\n function Manager(element, options) {\n var _this = this;\n\n this.options = assign$1({}, defaults, options || {});\n this.options.inputTarget = this.options.inputTarget || element;\n this.handlers = {};\n this.session = {};\n this.recognizers = [];\n this.oldCssProps = {};\n this.element = element;\n this.input = createInputInstance(this);\n this.touchAction = new TouchAction(this, this.options.touchAction);\n toggleCssProps(this, true);\n each(this.options.recognizers, function (item) {\n var recognizer = _this.add(new item[0](item[1]));\n\n item[2] && recognizer.recognizeWith(item[2]);\n item[3] && recognizer.requireFailure(item[3]);\n }, this);\n }\n /**\n * @private\n * set options\n * @param {Object} options\n * @returns {Manager}\n */\n\n\n var _proto = Manager.prototype;\n\n _proto.set = function set(options) {\n assign$1(this.options, options); // Options that need a little more setup\n\n if (options.touchAction) {\n this.touchAction.update();\n }\n\n if (options.inputTarget) {\n // Clean up existing event listeners and reinitialize\n this.input.destroy();\n this.input.target = options.inputTarget;\n this.input.init();\n }\n\n return this;\n };\n /**\n * @private\n * stop recognizing for this session.\n * This session will be discarded, when a new [input]start event is fired.\n * When forced, the recognizer cycle is stopped immediately.\n * @param {Boolean} [force]\n */\n\n\n _proto.stop = function stop(force) {\n this.session.stopped = force ? FORCED_STOP : STOP;\n };\n /**\n * @private\n * run the recognizers!\n * called by the inputHandler function on every movement of the pointers (touches)\n * it walks through all the recognizers and tries to detect the gesture that is being made\n * @param {Object} inputData\n */\n\n\n _proto.recognize = function recognize(inputData) {\n var session = this.session;\n\n if (session.stopped) {\n return;\n } // run the touch-action polyfill\n\n\n this.touchAction.preventDefaults(inputData);\n var recognizer;\n var recognizers = this.recognizers; // this holds the recognizer that is being recognized.\n // so the recognizer's state needs to be BEGAN, CHANGED, ENDED or RECOGNIZED\n // if no recognizer is detecting a thing, it is set to `null`\n\n var curRecognizer = session.curRecognizer; // reset when the last recognizer is recognized\n // or when we're in a new session\n\n if (!curRecognizer || curRecognizer && curRecognizer.state & STATE_RECOGNIZED) {\n session.curRecognizer = null;\n curRecognizer = null;\n }\n\n var i = 0;\n\n while (i < recognizers.length) {\n recognizer = recognizers[i]; // find out if we are allowed try to recognize the input for this one.\n // 1. allow if the session is NOT forced stopped (see the .stop() method)\n // 2. allow if we still haven't recognized a gesture in this session, or the this recognizer is the one\n // that is being recognized.\n // 3. allow if the recognizer is allowed to run simultaneous with the current recognized recognizer.\n // this can be setup with the `recognizeWith()` method on the recognizer.\n\n if (session.stopped !== FORCED_STOP && ( // 1\n !curRecognizer || recognizer === curRecognizer || // 2\n recognizer.canRecognizeWith(curRecognizer))) {\n // 3\n recognizer.recognize(inputData);\n } else {\n recognizer.reset();\n } // if the recognizer has been recognizing the input as a valid gesture, we want to store this one as the\n // current active recognizer. but only if we don't already have an active recognizer\n\n\n if (!curRecognizer && recognizer.state & (STATE_BEGAN | STATE_CHANGED | STATE_ENDED)) {\n session.curRecognizer = recognizer;\n curRecognizer = recognizer;\n }\n\n i++;\n }\n };\n /**\n * @private\n * get a recognizer by its event name.\n * @param {Recognizer|String} recognizer\n * @returns {Recognizer|Null}\n */\n\n\n _proto.get = function get(recognizer) {\n if (recognizer instanceof Recognizer) {\n return recognizer;\n }\n\n var recognizers = this.recognizers;\n\n for (var i = 0; i < recognizers.length; i++) {\n if (recognizers[i].options.event === recognizer) {\n return recognizers[i];\n }\n }\n\n return null;\n };\n /**\n * @private add a recognizer to the manager\n * existing recognizers with the same event name will be removed\n * @param {Recognizer} recognizer\n * @returns {Recognizer|Manager}\n */\n\n\n _proto.add = function add(recognizer) {\n if (invokeArrayArg(recognizer, \"add\", this)) {\n return this;\n } // remove existing\n\n\n var existing = this.get(recognizer.options.event);\n\n if (existing) {\n this.remove(existing);\n }\n\n this.recognizers.push(recognizer);\n recognizer.manager = this;\n this.touchAction.update();\n return recognizer;\n };\n /**\n * @private\n * remove a recognizer by name or instance\n * @param {Recognizer|String} recognizer\n * @returns {Manager}\n */\n\n\n _proto.remove = function remove(recognizer) {\n if (invokeArrayArg(recognizer, \"remove\", this)) {\n return this;\n }\n\n var targetRecognizer = this.get(recognizer); // let's make sure this recognizer exists\n\n if (recognizer) {\n var recognizers = this.recognizers;\n var index = inArray(recognizers, targetRecognizer);\n\n if (index !== -1) {\n recognizers.splice(index, 1);\n this.touchAction.update();\n }\n }\n\n return this;\n };\n /**\n * @private\n * bind event\n * @param {String} events\n * @param {Function} handler\n * @returns {EventEmitter} this\n */\n\n\n _proto.on = function on(events, handler) {\n if (events === undefined || handler === undefined) {\n return this;\n }\n\n var handlers = this.handlers;\n each(splitStr(events), function (event) {\n handlers[event] = handlers[event] || [];\n handlers[event].push(handler);\n });\n return this;\n };\n /**\n * @private unbind event, leave emit blank to remove all handlers\n * @param {String} events\n * @param {Function} [handler]\n * @returns {EventEmitter} this\n */\n\n\n _proto.off = function off(events, handler) {\n if (events === undefined) {\n return this;\n }\n\n var handlers = this.handlers;\n each(splitStr(events), function (event) {\n if (!handler) {\n delete handlers[event];\n } else {\n handlers[event] && handlers[event].splice(inArray(handlers[event], handler), 1);\n }\n });\n return this;\n };\n /**\n * @private emit event to the listeners\n * @param {String} event\n * @param {Object} data\n */\n\n\n _proto.emit = function emit(event, data) {\n // we also want to trigger dom events\n if (this.options.domEvents) {\n triggerDomEvent(event, data);\n } // no handlers, so skip it all\n\n\n var handlers = this.handlers[event] && this.handlers[event].slice();\n\n if (!handlers || !handlers.length) {\n return;\n }\n\n data.type = event;\n\n data.preventDefault = function () {\n data.srcEvent.preventDefault();\n };\n\n var i = 0;\n\n while (i < handlers.length) {\n handlers[i](data);\n i++;\n }\n };\n /**\n * @private\n * destroy the manager and unbinds all events\n * it doesn't unbind dom events, that is the user own responsibility\n */\n\n\n _proto.destroy = function destroy() {\n this.element && toggleCssProps(this, false);\n this.handlers = {};\n this.session = {};\n this.input.destroy();\n this.element = null;\n };\n\n return Manager;\n}();\n\nvar SINGLE_TOUCH_INPUT_MAP = {\n touchstart: INPUT_START,\n touchmove: INPUT_MOVE,\n touchend: INPUT_END,\n touchcancel: INPUT_CANCEL\n};\nvar SINGLE_TOUCH_TARGET_EVENTS = 'touchstart';\nvar SINGLE_TOUCH_WINDOW_EVENTS = 'touchstart touchmove touchend touchcancel';\n/**\n * @private\n * Touch events input\n * @constructor\n * @extends Input\n */\n\nvar SingleTouchInput =\n/*#__PURE__*/\nfunction (_Input) {\n _inheritsLoose(SingleTouchInput, _Input);\n\n function SingleTouchInput() {\n var _this;\n\n var proto = SingleTouchInput.prototype;\n proto.evTarget = SINGLE_TOUCH_TARGET_EVENTS;\n proto.evWin = SINGLE_TOUCH_WINDOW_EVENTS;\n _this = _Input.apply(this, arguments) || this;\n _this.started = false;\n return _this;\n }\n\n var _proto = SingleTouchInput.prototype;\n\n _proto.handler = function handler(ev) {\n var type = SINGLE_TOUCH_INPUT_MAP[ev.type]; // should we handle the touch events?\n\n if (type === INPUT_START) {\n this.started = true;\n }\n\n if (!this.started) {\n return;\n }\n\n var touches = normalizeSingleTouches.call(this, ev, type); // when done, reset the started state\n\n if (type & (INPUT_END | INPUT_CANCEL) && touches[0].length - touches[1].length === 0) {\n this.started = false;\n }\n\n this.callback(this.manager, type, {\n pointers: touches[0],\n changedPointers: touches[1],\n pointerType: INPUT_TYPE_TOUCH,\n srcEvent: ev\n });\n };\n\n return SingleTouchInput;\n}(Input);\n\nfunction normalizeSingleTouches(ev, type) {\n var all = toArray(ev.touches);\n var changed = toArray(ev.changedTouches);\n\n if (type & (INPUT_END | INPUT_CANCEL)) {\n all = uniqueArray(all.concat(changed), 'identifier', true);\n }\n\n return [all, changed];\n}\n\n/**\n * @private\n * wrap a method with a deprecation warning and stack trace\n * @param {Function} method\n * @param {String} name\n * @param {String} message\n * @returns {Function} A new function wrapping the supplied method.\n */\nfunction deprecate(method, name, message) {\n var deprecationMessage = \"DEPRECATED METHOD: \" + name + \"\\n\" + message + \" AT \\n\";\n return function () {\n var e = new Error('get-stack-trace');\n var stack = e && e.stack ? e.stack.replace(/^[^\\(]+?[\\n$]/gm, '').replace(/^\\s+at\\s+/gm, '').replace(/^Object.\\s*\\(/gm, '{anonymous}()@') : 'Unknown Stack Trace';\n var log = window.console && (window.console.warn || window.console.log);\n\n if (log) {\n log.call(window.console, deprecationMessage, stack);\n }\n\n return method.apply(this, arguments);\n };\n}\n\n/**\n * @private\n * extend object.\n * means that properties in dest will be overwritten by the ones in src.\n * @param {Object} dest\n * @param {Object} src\n * @param {Boolean} [merge=false]\n * @returns {Object} dest\n */\n\nvar extend = deprecate(function (dest, src, merge) {\n var keys = Object.keys(src);\n var i = 0;\n\n while (i < keys.length) {\n if (!merge || merge && dest[keys[i]] === undefined) {\n dest[keys[i]] = src[keys[i]];\n }\n\n i++;\n }\n\n return dest;\n}, 'extend', 'Use `assign`.');\n\n/**\n * @private\n * merge the values from src in the dest.\n * means that properties that exist in dest will not be overwritten by src\n * @param {Object} dest\n * @param {Object} src\n * @returns {Object} dest\n */\n\nvar merge = deprecate(function (dest, src) {\n return extend(dest, src, true);\n}, 'merge', 'Use `assign`.');\n\n/**\n * @private\n * simple class inheritance\n * @param {Function} child\n * @param {Function} base\n * @param {Object} [properties]\n */\n\nfunction inherit(child, base, properties) {\n var baseP = base.prototype;\n var childP;\n childP = child.prototype = Object.create(baseP);\n childP.constructor = child;\n childP._super = baseP;\n\n if (properties) {\n assign$1(childP, properties);\n }\n}\n\n/**\n * @private\n * simple function bind\n * @param {Function} fn\n * @param {Object} context\n * @returns {Function}\n */\nfunction bindFn(fn, context) {\n return function boundFn() {\n return fn.apply(context, arguments);\n };\n}\n\n/**\n * @private\n * Simple way to create a manager with a default set of recognizers.\n * @param {HTMLElement} element\n * @param {Object} [options]\n * @constructor\n */\n\nvar Hammer =\n/*#__PURE__*/\nfunction () {\n var Hammer =\n /**\n * @private\n * @const {string}\n */\n function Hammer(element, options) {\n if (options === void 0) {\n options = {};\n }\n\n return new Manager(element, _extends({\n recognizers: preset.concat()\n }, options));\n };\n\n Hammer.VERSION = \"2.0.17-rc\";\n Hammer.DIRECTION_ALL = DIRECTION_ALL;\n Hammer.DIRECTION_DOWN = DIRECTION_DOWN;\n Hammer.DIRECTION_LEFT = DIRECTION_LEFT;\n Hammer.DIRECTION_RIGHT = DIRECTION_RIGHT;\n Hammer.DIRECTION_UP = DIRECTION_UP;\n Hammer.DIRECTION_HORIZONTAL = DIRECTION_HORIZONTAL;\n Hammer.DIRECTION_VERTICAL = DIRECTION_VERTICAL;\n Hammer.DIRECTION_NONE = DIRECTION_NONE;\n Hammer.DIRECTION_DOWN = DIRECTION_DOWN;\n Hammer.INPUT_START = INPUT_START;\n Hammer.INPUT_MOVE = INPUT_MOVE;\n Hammer.INPUT_END = INPUT_END;\n Hammer.INPUT_CANCEL = INPUT_CANCEL;\n Hammer.STATE_POSSIBLE = STATE_POSSIBLE;\n Hammer.STATE_BEGAN = STATE_BEGAN;\n Hammer.STATE_CHANGED = STATE_CHANGED;\n Hammer.STATE_ENDED = STATE_ENDED;\n Hammer.STATE_RECOGNIZED = STATE_RECOGNIZED;\n Hammer.STATE_CANCELLED = STATE_CANCELLED;\n Hammer.STATE_FAILED = STATE_FAILED;\n Hammer.Manager = Manager;\n Hammer.Input = Input;\n Hammer.TouchAction = TouchAction;\n Hammer.TouchInput = TouchInput;\n Hammer.MouseInput = MouseInput;\n Hammer.PointerEventInput = PointerEventInput;\n Hammer.TouchMouseInput = TouchMouseInput;\n Hammer.SingleTouchInput = SingleTouchInput;\n Hammer.Recognizer = Recognizer;\n Hammer.AttrRecognizer = AttrRecognizer;\n Hammer.Tap = TapRecognizer;\n Hammer.Pan = PanRecognizer;\n Hammer.Swipe = SwipeRecognizer;\n Hammer.Pinch = PinchRecognizer;\n Hammer.Rotate = RotateRecognizer;\n Hammer.Press = PressRecognizer;\n Hammer.on = addEventListeners;\n Hammer.off = removeEventListeners;\n Hammer.each = each;\n Hammer.merge = merge;\n Hammer.extend = extend;\n Hammer.bindFn = bindFn;\n Hammer.assign = assign$1;\n Hammer.inherit = inherit;\n Hammer.bindFn = bindFn;\n Hammer.prefixed = prefixed;\n Hammer.toArray = toArray;\n Hammer.inArray = inArray;\n Hammer.uniqueArray = uniqueArray;\n Hammer.splitStr = splitStr;\n Hammer.boolOrFn = boolOrFn;\n Hammer.hasParent = hasParent;\n Hammer.addEventListeners = addEventListeners;\n Hammer.removeEventListeners = removeEventListeners;\n Hammer.defaults = assign$1({}, defaults, {\n preset: preset\n });\n return Hammer;\n}();\n\n// style loader but by script tag, not by the loader.\n\nvar defaults$1 = Hammer.defaults;\n\nexport default Hammer;\nexport { INPUT_START, INPUT_MOVE, INPUT_END, INPUT_CANCEL, STATE_POSSIBLE, STATE_BEGAN, STATE_CHANGED, STATE_ENDED, STATE_RECOGNIZED, STATE_CANCELLED, STATE_FAILED, DIRECTION_NONE, DIRECTION_LEFT, DIRECTION_RIGHT, DIRECTION_UP, DIRECTION_DOWN, DIRECTION_HORIZONTAL, DIRECTION_VERTICAL, DIRECTION_ALL, Manager, Input, TouchAction, TouchInput, MouseInput, PointerEventInput, TouchMouseInput, SingleTouchInput, Recognizer, AttrRecognizer, TapRecognizer as Tap, PanRecognizer as Pan, SwipeRecognizer as Swipe, PinchRecognizer as Pinch, RotateRecognizer as Rotate, PressRecognizer as Press, addEventListeners as on, removeEventListeners as off, each, merge, extend, assign$1 as assign, inherit, bindFn, prefixed, toArray, inArray, uniqueArray, splitStr, boolOrFn, hasParent, addEventListeners, removeEventListeners, defaults$1 as defaults };\n//# sourceMappingURL=hammer.esm.js.map\n","import Hammer from '@egjs/hammerjs';\nimport { State } from '../State';\nexport const CONTENT_TOUCHES_DELAY = 240;\nexport const CONTENT_TOUCHES_QUICK_TAP_END_DELAY = 50;\nexport const MULTI_FINGER_PAN_MAX_PINCH_THRESHOLD = 0.1;\nexport const MULTI_FINGER_PAN_MAX_ROTATION_THRESHOLD = 7;\nexport const DEG_RAD = Math.PI / 180; // Map Hammer values to RNGH\n\nexport const EventMap = {\n [Hammer.INPUT_START]: State.BEGAN,\n [Hammer.INPUT_MOVE]: State.ACTIVE,\n [Hammer.INPUT_END]: State.END,\n [Hammer.INPUT_CANCEL]: State.FAILED\n};\nexport const Direction = {\n RIGHT: 1,\n LEFT: 2,\n UP: 4,\n DOWN: 8\n};\nexport const DirectionMap = {\n [Hammer.DIRECTION_RIGHT]: Direction.RIGHT,\n [Hammer.DIRECTION_LEFT]: Direction.LEFT,\n [Hammer.DIRECTION_UP]: Direction.UP,\n [Hammer.DIRECTION_DOWN]: Direction.DOWN\n};\nexport const HammerInputNames = {\n [Hammer.INPUT_START]: 'START',\n [Hammer.INPUT_MOVE]: 'MOVE',\n [Hammer.INPUT_END]: 'END',\n [Hammer.INPUT_CANCEL]: 'CANCEL'\n};\nexport const HammerDirectionNames = {\n [Hammer.DIRECTION_HORIZONTAL]: 'HORIZONTAL',\n [Hammer.DIRECTION_UP]: 'UP',\n [Hammer.DIRECTION_DOWN]: 'DOWN',\n [Hammer.DIRECTION_VERTICAL]: 'VERTICAL',\n [Hammer.DIRECTION_NONE]: 'NONE',\n [Hammer.DIRECTION_ALL]: 'ALL',\n [Hammer.DIRECTION_RIGHT]: 'RIGHT',\n [Hammer.DIRECTION_LEFT]: 'LEFT'\n};\n//# sourceMappingURL=constants.js.map","const gestures = {};\nexport function getHandler(tag) {\n if (tag in gestures) {\n return gestures[tag];\n }\n\n throw new Error(`No handler for tag ${tag}`);\n}\nexport function createGestureHandler(handlerTag, handler) {\n if (handlerTag in gestures) {\n throw new Error(`Handler with tag ${handlerTag} already exists`);\n }\n\n gestures[handlerTag] = handler; // @ts-ignore no types for web handlers yet\n\n gestures[handlerTag].handlerTag = handlerTag;\n}\nexport function dropGestureHandler(handlerTag) {\n // Since React 18, there are cases where componentWillUnmount gets called twice in a row\n // so skip this if the tag was already removed.\n if (!(handlerTag in gestures)) {\n return;\n }\n\n getHandler(handlerTag).destroy(); // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n\n delete gestures[handlerTag];\n}\nexport function getNodes() {\n return { ...gestures\n };\n}\n//# sourceMappingURL=NodeManager.js.map","// TODO(TS) remove if not necessary after rewrite\nexport const isnan = v => Number.isNaN(v); // TODO(TS) remove if not necessary after rewrite\n\nexport const isValidNumber = v => typeof v === 'number' && !Number.isNaN(v);\nexport const TEST_MIN_IF_NOT_NAN = (value, limit) => !isnan(limit) && (limit < 0 && value <= limit || limit >= 0 && value >= limit);\nexport const VEC_LEN_SQ = ({\n x = 0,\n y = 0\n} = {}) => x * x + y * y;\nexport const TEST_MAX_IF_NOT_NAN = (value, max) => !isnan(max) && (max < 0 && value < max || max >= 0 && value > max);\nexport function fireAfterInterval(method, interval) {\n if (!interval) {\n method();\n return null;\n }\n\n return setTimeout(() => method(), interval);\n}\n//# sourceMappingURL=utils.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport Hammer from '@egjs/hammerjs';\nimport { State } from '../State';\nimport { CONTENT_TOUCHES_DELAY, CONTENT_TOUCHES_QUICK_TAP_END_DELAY } from './constants';\nimport DiscreteGestureHandler from './DiscreteGestureHandler';\nimport { fireAfterInterval, isValidNumber, isnan } from './utils';\n\nclass PressGestureHandler extends DiscreteGestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"visualFeedbackTimer\", void 0);\n\n _defineProperty(this, \"initialEvent\", null);\n\n _defineProperty(this, \"shouldDelayTouches\", true);\n }\n\n get name() {\n return 'press';\n }\n\n get minDurationMs() {\n // @ts-ignore FIXME(TS)\n return isnan(this.config.minDurationMs) ? 5 : this.config.minDurationMs;\n }\n\n get maxDist() {\n return isnan(this.config.maxDist) ? 9 : this.config.maxDist;\n }\n\n get NativeGestureClass() {\n return Hammer.Press;\n }\n\n simulateCancelEvent(inputData) {\n // Long press never starts so we can't rely on the running event boolean.\n this.hasGestureFailed = true;\n this.cancelEvent(inputData);\n }\n\n updateHasCustomActivationCriteria({\n shouldCancelWhenOutside,\n maxDistSq\n }) {\n return shouldCancelWhenOutside || !isValidNumber(maxDistSq);\n }\n\n getState(type) {\n return {\n [Hammer.INPUT_START]: State.BEGAN,\n [Hammer.INPUT_MOVE]: State.ACTIVE,\n [Hammer.INPUT_END]: State.END,\n [Hammer.INPUT_CANCEL]: State.CANCELLED\n }[type];\n }\n\n getConfig() {\n if (!this.hasCustomActivationCriteria) {\n // Default config\n // If no params have been defined then this config should emulate the native gesture as closely as possible.\n return {\n shouldCancelWhenOutside: true,\n maxDistSq: 10\n };\n }\n\n return this.config;\n }\n\n getHammerConfig() {\n return { ...super.getHammerConfig(),\n // threshold: this.maxDist,\n time: this.minDurationMs\n };\n }\n\n onGestureActivated(ev) {\n this.onGestureStart(ev);\n }\n\n shouldDelayTouchForEvent({\n pointerType\n }) {\n // Don't disable event for mouse input\n return this.shouldDelayTouches && pointerType === 'touch';\n }\n\n onGestureStart(ev) {\n this.isGestureRunning = true;\n clearTimeout(this.visualFeedbackTimer);\n this.initialEvent = ev;\n this.visualFeedbackTimer = fireAfterInterval(() => {\n this.sendGestureStartedEvent(this.initialEvent);\n this.initialEvent = null;\n }, this.shouldDelayTouchForEvent(ev) && CONTENT_TOUCHES_DELAY);\n }\n\n sendGestureStartedEvent(ev) {\n clearTimeout(this.visualFeedbackTimer);\n this.visualFeedbackTimer = null;\n this.sendEvent({ ...ev,\n eventType: Hammer.INPUT_MOVE,\n isFirst: true\n });\n }\n\n forceInvalidate(event) {\n super.forceInvalidate(event);\n clearTimeout(this.visualFeedbackTimer);\n this.visualFeedbackTimer = null;\n this.initialEvent = null;\n }\n\n onRawEvent(ev) {\n super.onRawEvent(ev);\n\n if (this.isGestureRunning) {\n if (ev.isFinal) {\n let timeout;\n\n if (this.visualFeedbackTimer) {\n // Aesthetic timing for a quick tap.\n // We haven't activated the tap right away to emulate iOS `delaysContentTouches`\n // Now we must send the initial activation event and wait a set amount of time before firing the end event.\n timeout = CONTENT_TOUCHES_QUICK_TAP_END_DELAY;\n this.sendGestureStartedEvent(this.initialEvent);\n this.initialEvent = null;\n }\n\n fireAfterInterval(() => {\n this.sendEvent({ ...ev,\n eventType: Hammer.INPUT_END,\n isFinal: true\n }); // @ts-ignore -- this should explicitly support undefined\n\n this.onGestureEnded();\n }, timeout);\n } else {\n this.sendEvent({ ...ev,\n eventType: Hammer.INPUT_MOVE,\n isFinal: false\n });\n }\n }\n }\n\n updateGestureConfig({\n shouldActivateOnStart = false,\n disallowInterruption = false,\n shouldCancelWhenOutside = true,\n minDurationMs = Number.NaN,\n maxDist = Number.NaN,\n minPointers = 1,\n maxPointers = 1,\n ...props\n }) {\n return super.updateGestureConfig({\n shouldActivateOnStart,\n disallowInterruption,\n shouldCancelWhenOutside,\n minDurationMs,\n maxDist,\n minPointers,\n maxPointers,\n ...props\n });\n }\n\n}\n\nexport default PressGestureHandler;\n//# sourceMappingURL=PressGestureHandler.js.map","import Hammer from '@egjs/hammerjs';\nimport { MULTI_FINGER_PAN_MAX_PINCH_THRESHOLD, MULTI_FINGER_PAN_MAX_ROTATION_THRESHOLD } from './constants';\nimport DraggingGestureHandler from './DraggingGestureHandler';\nimport { isValidNumber, isnan, TEST_MIN_IF_NOT_NAN, VEC_LEN_SQ } from './utils';\nimport { State } from '../State';\n\nclass PanGestureHandler extends DraggingGestureHandler {\n get name() {\n return 'pan';\n }\n\n get NativeGestureClass() {\n return Hammer.Pan;\n }\n\n getHammerConfig() {\n return { ...super.getHammerConfig(),\n direction: this.getDirection()\n };\n }\n\n getState(type) {\n const nextState = super.getState(type); // Ensure that the first state sent is `BEGAN` and not `ACTIVE`\n\n if (this.previousState === State.UNDETERMINED && nextState === State.ACTIVE) {\n return State.BEGAN;\n }\n\n return nextState;\n }\n\n getDirection() {\n const config = this.getConfig();\n const {\n activeOffsetXStart,\n activeOffsetXEnd,\n activeOffsetYStart,\n activeOffsetYEnd,\n minDist\n } = config;\n let directions = [];\n let horizontalDirections = [];\n\n if (!isnan(minDist)) {\n return Hammer.DIRECTION_ALL;\n }\n\n if (!isnan(activeOffsetXStart)) {\n horizontalDirections.push(Hammer.DIRECTION_LEFT);\n }\n\n if (!isnan(activeOffsetXEnd)) {\n horizontalDirections.push(Hammer.DIRECTION_RIGHT);\n }\n\n if (horizontalDirections.length === 2) {\n horizontalDirections = [Hammer.DIRECTION_HORIZONTAL];\n }\n\n directions = directions.concat(horizontalDirections);\n let verticalDirections = [];\n\n if (!isnan(activeOffsetYStart)) {\n verticalDirections.push(Hammer.DIRECTION_UP);\n }\n\n if (!isnan(activeOffsetYEnd)) {\n verticalDirections.push(Hammer.DIRECTION_DOWN);\n }\n\n if (verticalDirections.length === 2) {\n verticalDirections = [Hammer.DIRECTION_VERTICAL];\n }\n\n directions = directions.concat(verticalDirections);\n\n if (!directions.length) {\n return Hammer.DIRECTION_NONE;\n }\n\n if (directions[0] === Hammer.DIRECTION_HORIZONTAL && directions[1] === Hammer.DIRECTION_VERTICAL) {\n return Hammer.DIRECTION_ALL;\n }\n\n if (horizontalDirections.length && verticalDirections.length) {\n return Hammer.DIRECTION_ALL;\n }\n\n return directions[0];\n }\n\n getConfig() {\n if (!this.hasCustomActivationCriteria) {\n // Default config\n // If no params have been defined then this config should emulate the native gesture as closely as possible.\n return {\n minDistSq: 10\n };\n }\n\n return this.config;\n }\n\n shouldFailUnderCustomCriteria({\n deltaX,\n deltaY\n }, criteria) {\n return !isnan(criteria.failOffsetXStart) && deltaX < criteria.failOffsetXStart || !isnan(criteria.failOffsetXEnd) && deltaX > criteria.failOffsetXEnd || !isnan(criteria.failOffsetYStart) && deltaY < criteria.failOffsetYStart || !isnan(criteria.failOffsetYEnd) && deltaY > criteria.failOffsetYEnd;\n }\n\n shouldActivateUnderCustomCriteria({\n deltaX,\n deltaY,\n velocity\n }, criteria) {\n return !isnan(criteria.activeOffsetXStart) && deltaX < criteria.activeOffsetXStart || !isnan(criteria.activeOffsetXEnd) && deltaX > criteria.activeOffsetXEnd || !isnan(criteria.activeOffsetYStart) && deltaY < criteria.activeOffsetYStart || !isnan(criteria.activeOffsetYEnd) && deltaY > criteria.activeOffsetYEnd || TEST_MIN_IF_NOT_NAN(VEC_LEN_SQ({\n x: deltaX,\n y: deltaY\n }), criteria.minDistSq) || TEST_MIN_IF_NOT_NAN(velocity.x, criteria.minVelocityX) || TEST_MIN_IF_NOT_NAN(velocity.y, criteria.minVelocityY) || TEST_MIN_IF_NOT_NAN(VEC_LEN_SQ(velocity), criteria.minVelocitySq);\n }\n\n shouldMultiFingerPanFail({\n pointerLength,\n scale,\n deltaRotation\n }) {\n if (pointerLength <= 1) {\n return false;\n } // Test if the pan had too much pinching or rotating.\n\n\n const deltaScale = Math.abs(scale - 1);\n const absDeltaRotation = Math.abs(deltaRotation);\n\n if (deltaScale > MULTI_FINGER_PAN_MAX_PINCH_THRESHOLD) {\n // > If the threshold doesn't seem right.\n // You can log the value which it failed at here:\n return true;\n }\n\n if (absDeltaRotation > MULTI_FINGER_PAN_MAX_ROTATION_THRESHOLD) {\n // > If the threshold doesn't seem right.\n // You can log the value which it failed at here:\n return true;\n }\n\n return false;\n }\n\n updateHasCustomActivationCriteria(criteria) {\n return isValidNumber(criteria.minDistSq) || isValidNumber(criteria.minVelocityX) || isValidNumber(criteria.minVelocityY) || isValidNumber(criteria.minVelocitySq) || isValidNumber(criteria.activeOffsetXStart) || isValidNumber(criteria.activeOffsetXEnd) || isValidNumber(criteria.activeOffsetYStart) || isValidNumber(criteria.activeOffsetYEnd);\n }\n\n isGestureEnabledForEvent(props, _recognizer, inputData) {\n if (this.shouldFailUnderCustomCriteria(inputData, props)) {\n return {\n failed: true\n };\n }\n\n const velocity = {\n x: inputData.velocityX,\n y: inputData.velocityY\n };\n\n if (this.hasCustomActivationCriteria && this.shouldActivateUnderCustomCriteria({\n deltaX: inputData.deltaX,\n deltaY: inputData.deltaY,\n velocity\n }, props)) {\n if (this.shouldMultiFingerPanFail({\n pointerLength: inputData.maxPointers,\n scale: inputData.scale,\n deltaRotation: inputData.deltaRotation\n })) {\n return {\n failed: true\n };\n }\n\n return {\n success: true\n };\n }\n\n return {\n success: false\n };\n }\n\n}\n\nexport default PanGestureHandler;\n//# sourceMappingURL=PanGestureHandler.js.map","/* eslint-disable eslint-comments/no-unlimited-disable */\n\n/* eslint-disable */\nimport GestureHandler from './GestureHandler';\nimport { PixelRatio } from 'react-native';\n\nclass DraggingGestureHandler extends GestureHandler {\n get shouldEnableGestureOnSetup() {\n return true;\n }\n\n transformNativeEvent({\n deltaX,\n deltaY,\n velocityX,\n velocityY,\n center: {\n x,\n y\n }\n }) {\n // @ts-ignore FIXME(TS)\n const rect = this.view.getBoundingClientRect();\n const ratio = PixelRatio.get();\n return {\n translationX: deltaX - (this.__initialX || 0),\n translationY: deltaY - (this.__initialY || 0),\n absoluteX: x,\n absoluteY: y,\n velocityX: velocityX * ratio,\n velocityY: velocityY * ratio,\n x: x - rect.left,\n y: y - rect.top\n };\n }\n\n}\n\nexport default DraggingGestureHandler;\n//# sourceMappingURL=DraggingGestureHandler.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport Dimensions from '../Dimensions';\n\n/**\n * PixelRatio gives access to the device pixel density.\n */\nexport default class PixelRatio {\n /**\n * Returns the device pixel density.\n */\n static get() {\n return Dimensions.get('window').scale;\n }\n\n /**\n * No equivalent for Web\n */\n static getFontScale() {\n return Dimensions.get('window').fontScale || PixelRatio.get();\n }\n\n /**\n * Converts a layout size (dp) to pixel size (px).\n * Guaranteed to return an integer number.\n */\n static getPixelSizeForLayoutSize(layoutSize) {\n return Math.round(layoutSize * PixelRatio.get());\n }\n\n /**\n * Rounds a layout size (dp) to the nearest layout size that corresponds to\n * an integer number of pixels. For example, on a device with a PixelRatio\n * of 3, `PixelRatio.roundToNearestPixel(8.4) = 8.33`, which corresponds to\n * exactly (8.33 * 3) = 25 pixels.\n */\n static roundToNearestPixel(layoutSize) {\n var ratio = PixelRatio.get();\n return Math.round(layoutSize * ratio) / ratio;\n }\n}","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport invariant from 'fbjs/lib/invariant';\nimport canUseDOM from '../../modules/canUseDom';\nvar dimensions = {\n window: {\n fontScale: 1,\n height: 0,\n scale: 1,\n width: 0\n },\n screen: {\n fontScale: 1,\n height: 0,\n scale: 1,\n width: 0\n }\n};\nvar listeners = {};\nvar shouldInit = canUseDOM;\nfunction update() {\n if (!canUseDOM) {\n return;\n }\n var win = window;\n var height;\n var width;\n\n /**\n * iOS does not update viewport dimensions on keyboard open/close.\n * window.visualViewport(https://developer.mozilla.org/en-US/docs/Web/API/VisualViewport)\n * is used instead of document.documentElement.clientHeight (which remains as a fallback)\n */\n if (win.visualViewport) {\n var visualViewport = win.visualViewport;\n /**\n * We are multiplying by scale because height and width from visual viewport\n * also react to pinch zoom, and become smaller when zoomed. But it is not desired\n * behaviour, since originally documentElement client height and width were used,\n * and they do not react to pinch zoom.\n */\n height = Math.round(visualViewport.height * visualViewport.scale);\n width = Math.round(visualViewport.width * visualViewport.scale);\n } else {\n var docEl = win.document.documentElement;\n height = docEl.clientHeight;\n width = docEl.clientWidth;\n }\n dimensions.window = {\n fontScale: 1,\n height,\n scale: win.devicePixelRatio || 1,\n width\n };\n dimensions.screen = {\n fontScale: 1,\n height: win.screen.height,\n scale: win.devicePixelRatio || 1,\n width: win.screen.width\n };\n}\nfunction handleResize() {\n update();\n if (Array.isArray(listeners['change'])) {\n listeners['change'].forEach(handler => handler(dimensions));\n }\n}\nexport default class Dimensions {\n static get(dimension) {\n if (shouldInit) {\n shouldInit = false;\n update();\n }\n invariant(dimensions[dimension], \"No dimension set for key \" + dimension);\n return dimensions[dimension];\n }\n static set(initialDimensions) {\n if (initialDimensions) {\n if (canUseDOM) {\n invariant(false, 'Dimensions cannot be set in the browser');\n } else {\n if (initialDimensions.screen != null) {\n dimensions.screen = initialDimensions.screen;\n }\n if (initialDimensions.window != null) {\n dimensions.window = initialDimensions.window;\n }\n }\n }\n }\n static addEventListener(type, handler) {\n listeners[type] = listeners[type] || [];\n listeners[type].push(handler);\n return {\n remove: () => {\n this.removeEventListener(type, handler);\n }\n };\n }\n static removeEventListener(type, handler) {\n if (Array.isArray(listeners[type])) {\n listeners[type] = listeners[type].filter(_handler => _handler !== handler);\n }\n }\n}\nif (canUseDOM) {\n if (window.visualViewport) {\n window.visualViewport.addEventListener('resize', handleResize, false);\n } else {\n window.addEventListener('resize', handleResize, false);\n }\n}","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n'use strict';\n\nvar validateFormat = process.env.NODE_ENV !== \"production\" ? function (format) {\n if (format === undefined) {\n throw new Error('invariant(...): Second argument must be a string.');\n }\n} : function (format) {};\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments to provide\n * information about what broke and what you were expecting.\n *\n * The invariant message will be stripped in production, but the invariant will\n * remain to ensure logic does not differ in production.\n */\n\nfunction invariant(condition, format) {\n for (var _len = arguments.length, args = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {\n args[_key - 2] = arguments[_key];\n }\n\n validateFormat(format);\n\n if (!condition) {\n var error;\n\n if (format === undefined) {\n error = new Error('Minified exception occurred; use the non-minified dev environment ' + 'for the full error message and additional helpful warnings.');\n } else {\n var argIndex = 0;\n error = new Error(format.replace(/%s/g, function () {\n return String(args[argIndex++]);\n }));\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // Skip invariant's own stack frame.\n\n throw error;\n }\n}\n\nmodule.exports = invariant;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nexport default canUseDOM;","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport Hammer from '@egjs/hammerjs';\nimport DiscreteGestureHandler from './DiscreteGestureHandler';\nimport { isnan } from './utils';\n\nclass TapGestureHandler extends DiscreteGestureHandler {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"_shouldFireEndEvent\", null);\n\n _defineProperty(this, \"_timer\", void 0);\n\n _defineProperty(this, \"_multiTapTimer\", void 0);\n\n _defineProperty(this, \"onSuccessfulTap\", ev => {\n if (this._getPendingGestures().length) {\n this._shouldFireEndEvent = ev;\n return;\n }\n\n if (ev.eventType === Hammer.INPUT_END) {\n this.sendEvent({ ...ev,\n eventType: Hammer.INPUT_MOVE\n });\n } // When handler gets activated it will turn into State.END immediately.\n\n\n this.sendEvent({ ...ev,\n isFinal: true\n });\n this.onGestureEnded(ev);\n });\n }\n\n // TODO unused?\n get name() {\n return 'tap';\n }\n\n get NativeGestureClass() {\n return Hammer.Tap;\n }\n\n get maxDelayMs() {\n // @ts-ignore TODO(TS) trace down config\n return isnan(this.config.maxDelayMs) ? 300 : this.config.maxDelayMs;\n }\n\n simulateCancelEvent(inputData) {\n if (this.isGestureRunning) {\n this.cancelEvent(inputData);\n }\n }\n\n onGestureActivated(ev) {\n if (this.isGestureRunning) {\n this.onSuccessfulTap(ev);\n }\n }\n\n onRawEvent(ev) {\n super.onRawEvent(ev); // Attempt to create a touch-down event by checking if a valid tap hasn't started yet, then validating the input.\n\n if (!this.hasGestureFailed && !this.isGestureRunning && // Prevent multi-pointer events from misfiring.\n !ev.isFinal) {\n // Tap Gesture start event\n const gesture = this.hammer.get(this.name); // @ts-ignore TODO(TS) trace down config\n\n if (gesture.options.enable(gesture, ev)) {\n clearTimeout(this._multiTapTimer);\n this.onStart(ev);\n this.sendEvent(ev);\n }\n }\n\n if (ev.isFinal && ev.maxPointers > 1) {\n setTimeout(() => {\n // Handle case where one finger presses slightly\n // after the first finger on a multi-tap event\n if (this.isGestureRunning) {\n this.cancelEvent(ev);\n }\n });\n }\n\n if (this.hasGestureFailed) {\n return;\n } // Hammer doesn't send a `cancel` event for taps.\n // Manually fail the event.\n\n\n if (ev.isFinal) {\n // Handle case where one finger presses slightly\n // after the first finger on a multi-tap event\n if (ev.maxPointers > 1) {\n setTimeout(() => {\n if (this.isGestureRunning) {\n this.cancelEvent(ev);\n }\n });\n } // Clear last timer\n\n\n clearTimeout(this._timer); // Create time out for multi-taps.\n\n this._timer = setTimeout(() => {\n this.hasGestureFailed = true;\n this.cancelEvent(ev);\n }, this.maxDelayMs);\n } else if (!this.hasGestureFailed && !this.isGestureRunning) {\n // Tap Gesture start event\n const gesture = this.hammer.get(this.name); // @ts-ignore TODO(TS) trace down config\n\n if (gesture.options.enable(gesture, ev)) {\n clearTimeout(this._multiTapTimer);\n this.onStart(ev);\n this.sendEvent(ev);\n }\n }\n }\n\n getHammerConfig() {\n return { ...super.getHammerConfig(),\n event: this.name,\n // @ts-ignore TODO(TS) trace down config\n taps: isnan(this.config.numberOfTaps) ? 1 : this.config.numberOfTaps,\n interval: this.maxDelayMs,\n time: // @ts-ignore TODO(TS) trace down config\n isnan(this.config.maxDurationMs) || this.config.maxDurationMs == null ? 250 : // @ts-ignore TODO(TS) trace down config\n this.config.maxDurationMs\n };\n }\n\n updateGestureConfig({\n shouldCancelWhenOutside = true,\n maxDeltaX = Number.NaN,\n maxDeltaY = Number.NaN,\n numberOfTaps = 1,\n minDurationMs = 525,\n maxDelayMs = Number.NaN,\n // eslint-disable-next-line @typescript-eslint/no-unused-vars -- TODO possibly forgotten to use in updateGestureConfig?\n maxDurationMs = Number.NaN,\n maxDist = 2,\n minPointers = 1,\n maxPointers = 1,\n ...props\n }) {\n return super.updateGestureConfig({\n shouldCancelWhenOutside,\n numberOfTaps,\n maxDeltaX,\n maxDeltaY,\n minDurationMs,\n maxDelayMs,\n maxDist,\n minPointers,\n maxPointers,\n ...props\n });\n }\n\n onGestureEnded(...props) {\n clearTimeout(this._timer); // @ts-ignore TODO(TS) check how onGestureEnded works\n\n super.onGestureEnded(...props);\n }\n\n onWaitingEnded(_gesture) {\n if (this._shouldFireEndEvent) {\n this.onSuccessfulTap(this._shouldFireEndEvent);\n this._shouldFireEndEvent = null;\n }\n }\n\n}\n\nexport default TapGestureHandler;\n//# sourceMappingURL=TapGestureHandler.js.map","/* eslint-disable eslint-comments/no-unlimited-disable */\n\n/* eslint-disable */\nimport Hammer from '@egjs/hammerjs';\nimport { State } from '../State';\nimport PressGestureHandler from './PressGestureHandler';\nimport { isnan, isValidNumber } from './utils';\n\nclass LongPressGestureHandler extends PressGestureHandler {\n get minDurationMs() {\n // @ts-ignore FIXNE(TS)\n return isnan(this.config.minDurationMs) ? 251 : this.config.minDurationMs;\n }\n\n get maxDist() {\n // @ts-ignore FIXNE(TS)\n return isnan(this.config.maxDist) ? 9 : this.config.maxDist;\n }\n\n updateHasCustomActivationCriteria({\n maxDistSq\n }) {\n return !isValidNumber(maxDistSq);\n }\n\n getConfig() {\n if (!this.hasCustomActivationCriteria) {\n // Default config\n // If no params have been defined then this config should emulate the native gesture as closely as possible.\n return {\n shouldCancelWhenOutside: true,\n maxDistSq: 10\n };\n }\n\n return this.config;\n }\n\n getHammerConfig() {\n return { ...super.getHammerConfig(),\n // threshold: this.maxDist,\n time: this.minDurationMs\n };\n }\n\n getState(type) {\n return {\n [Hammer.INPUT_START]: State.ACTIVE,\n [Hammer.INPUT_MOVE]: State.ACTIVE,\n [Hammer.INPUT_END]: State.END,\n [Hammer.INPUT_CANCEL]: State.FAILED\n }[type];\n }\n\n}\n\nexport default LongPressGestureHandler;\n//# sourceMappingURL=LongPressGestureHandler.js.map","import Hammer from '@egjs/hammerjs';\nimport IndiscreteGestureHandler from './IndiscreteGestureHandler';\n\nclass PinchGestureHandler extends IndiscreteGestureHandler {\n get name() {\n return 'pinch';\n }\n\n get NativeGestureClass() {\n return Hammer.Pinch;\n }\n\n transformNativeEvent({\n scale,\n velocity,\n center\n }) {\n return {\n focalX: center.x,\n focalY: center.y,\n velocity,\n scale\n };\n }\n\n}\n\nexport default PinchGestureHandler;\n//# sourceMappingURL=PinchGestureHandler.js.map","import GestureHandler from './GestureHandler';\n/**\n * The base class for **Rotation** and **Pinch** gesture handlers.\n */\n\nclass IndiscreteGestureHandler extends GestureHandler {\n get shouldEnableGestureOnSetup() {\n return false;\n }\n\n updateGestureConfig({\n minPointers = 2,\n maxPointers = 2,\n ...props\n }) {\n return super.updateGestureConfig({\n minPointers,\n maxPointers,\n ...props\n });\n }\n\n isGestureEnabledForEvent({\n minPointers,\n maxPointers\n }, _recognizer, {\n maxPointers: pointerLength\n }) {\n if (pointerLength > maxPointers) {\n return {\n failed: true\n };\n }\n\n const validPointerCount = pointerLength >= minPointers;\n return {\n success: validPointerCount\n };\n }\n\n}\n\nexport default IndiscreteGestureHandler;\n//# sourceMappingURL=IndiscreteGestureHandler.js.map","import Hammer from '@egjs/hammerjs';\nimport { DEG_RAD } from './constants';\nimport IndiscreteGestureHandler from './IndiscreteGestureHandler';\n\nclass RotationGestureHandler extends IndiscreteGestureHandler {\n get name() {\n return 'rotate';\n }\n\n get NativeGestureClass() {\n return Hammer.Rotate;\n }\n\n transformNativeEvent({\n rotation,\n velocity,\n center\n }) {\n var _this$initialRotation;\n\n return {\n rotation: (rotation - ((_this$initialRotation = this.initialRotation) !== null && _this$initialRotation !== void 0 ? _this$initialRotation : 0)) * DEG_RAD,\n anchorX: center.x,\n anchorY: center.y,\n velocity\n };\n }\n\n}\n\nexport default RotationGestureHandler;\n//# sourceMappingURL=RotationGestureHandler.js.map","/* eslint-disable eslint-comments/no-unlimited-disable */\n\n/* eslint-disable */\nimport Hammer from '@egjs/hammerjs';\nimport { Direction } from './constants';\nimport { GesturePropError } from './Errors';\nimport DraggingGestureHandler from './DraggingGestureHandler';\nimport { isnan } from './utils';\n\nclass FlingGestureHandler extends DraggingGestureHandler {\n get name() {\n return 'swipe';\n }\n\n get NativeGestureClass() {\n return Hammer.Swipe;\n }\n\n onGestureActivated(event) {\n this.sendEvent({ ...event,\n eventType: Hammer.INPUT_MOVE,\n isFinal: false,\n isFirst: true\n });\n this.isGestureRunning = false;\n this.hasGestureFailed = false;\n this.sendEvent({ ...event,\n eventType: Hammer.INPUT_END,\n isFinal: true\n });\n }\n\n onRawEvent(ev) {\n super.onRawEvent(ev);\n\n if (this.hasGestureFailed) {\n return;\n } // Hammer doesn't send a `cancel` event for taps.\n // Manually fail the event.\n\n\n if (ev.isFinal) {\n setTimeout(() => {\n if (this.isGestureRunning) {\n this.cancelEvent(ev);\n }\n });\n } else if (!this.hasGestureFailed && !this.isGestureRunning) {\n // Tap Gesture start event\n const gesture = this.hammer.get(this.name); // @ts-ignore FIXME(TS)\n\n if (gesture.options.enable(gesture, ev)) {\n this.onStart(ev);\n this.sendEvent(ev);\n }\n }\n }\n\n getHammerConfig() {\n return {\n // @ts-ignore FIXME(TS)\n pointers: this.config.numberOfPointers,\n direction: this.getDirection()\n };\n }\n\n getTargetDirections(direction) {\n const directions = [];\n\n if (direction & Direction.RIGHT) {\n directions.push(Hammer.DIRECTION_RIGHT);\n }\n\n if (direction & Direction.LEFT) {\n directions.push(Hammer.DIRECTION_LEFT);\n }\n\n if (direction & Direction.UP) {\n directions.push(Hammer.DIRECTION_UP);\n }\n\n if (direction & Direction.DOWN) {\n directions.push(Hammer.DIRECTION_DOWN);\n } // const hammerDirection = directions.reduce((a, b) => a | b, 0);\n\n\n return directions;\n }\n\n getDirection() {\n // @ts-ignore FIXME(TS)\n const {\n direction\n } = this.getConfig();\n let directions = [];\n\n if (direction & Direction.RIGHT) {\n directions.push(Hammer.DIRECTION_HORIZONTAL);\n }\n\n if (direction & Direction.LEFT) {\n directions.push(Hammer.DIRECTION_HORIZONTAL);\n }\n\n if (direction & Direction.UP) {\n directions.push(Hammer.DIRECTION_VERTICAL);\n }\n\n if (direction & Direction.DOWN) {\n directions.push(Hammer.DIRECTION_VERTICAL);\n }\n\n directions = [...new Set(directions)];\n if (directions.length === 0) return Hammer.DIRECTION_NONE;\n if (directions.length === 1) return directions[0];\n return Hammer.DIRECTION_ALL;\n }\n\n isGestureEnabledForEvent({\n numberOfPointers\n }, _recognizer, {\n maxPointers: pointerLength\n }) {\n const validPointerCount = pointerLength === numberOfPointers;\n\n if (!validPointerCount && this.isGestureRunning) {\n return {\n failed: true\n };\n }\n\n return {\n success: validPointerCount\n };\n }\n\n updateGestureConfig({\n numberOfPointers = 1,\n direction,\n ...props\n }) {\n if (isnan(direction) || typeof direction !== 'number') {\n throw new GesturePropError('direction', direction, 'number');\n }\n\n return super.updateGestureConfig({\n numberOfPointers,\n direction,\n ...props\n });\n }\n\n}\n\nexport default FlingGestureHandler;\n//# sourceMappingURL=FlingGestureHandler.js.map","export class GesturePropError extends Error {\n constructor(name, value, expectedType) {\n super(`Invalid property \\`${name}: ${value}\\` expected \\`${expectedType}\\``);\n }\n\n}\n//# sourceMappingURL=Errors.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { findNodeHandle } from 'react-native';\nimport PointerEventManager from './PointerEventManager';\nimport TouchEventManager from './TouchEventManager';\nimport { State } from '../../State';\nimport { isPointerInBounds } from '../utils';\nimport { MouseButton } from '../../handlers/gestureHandlerCommon';\nexport class GestureHandlerWebDelegate {\n constructor() {\n _defineProperty(this, \"view\", void 0);\n\n _defineProperty(this, \"gestureHandler\", void 0);\n\n _defineProperty(this, \"eventManagers\", []);\n }\n\n getView() {\n return this.view;\n }\n\n init(viewRef, handler) {\n var _config$touchAction;\n\n if (!viewRef) {\n throw new Error(`Cannot find HTML Element for handler ${handler.getTag()}`);\n }\n\n this.gestureHandler = handler;\n this.view = findNodeHandle(viewRef);\n const config = handler.getConfig();\n this.addContextMenuListeners(config);\n\n if (!config.userSelect) {\n this.view.style['webkitUserSelect'] = 'none';\n this.view.style['userSelect'] = 'none';\n } else {\n this.view.style['webkitUserSelect'] = config.userSelect;\n this.view.style['userSelect'] = config.userSelect;\n }\n\n this.view.style['touchAction'] = (_config$touchAction = config.touchAction) !== null && _config$touchAction !== void 0 ? _config$touchAction : 'none'; //@ts-ignore This one disables default events on Safari\n\n this.view.style['WebkitTouchCallout'] = 'none';\n this.eventManagers.push(new PointerEventManager(this.view));\n this.eventManagers.push(new TouchEventManager(this.view));\n this.eventManagers.forEach(manager => this.gestureHandler.attachEventManager(manager));\n }\n\n isPointerInBounds({\n x,\n y\n }) {\n return isPointerInBounds(this.view, {\n x,\n y\n });\n }\n\n measureView() {\n const rect = this.view.getBoundingClientRect();\n return {\n pageX: rect.left,\n pageY: rect.top,\n width: rect.width,\n height: rect.height\n };\n }\n\n reset() {\n this.eventManagers.forEach(manager => manager.resetManager());\n }\n\n tryResetCursor() {\n const config = this.gestureHandler.getConfig();\n\n if (config.activeCursor && config.activeCursor !== 'auto' && this.gestureHandler.getState() === State.ACTIVE) {\n this.view.style.cursor = 'auto';\n }\n }\n\n shouldDisableContextMenu(config) {\n return config.enableContextMenu === undefined && this.gestureHandler.isButtonInConfig(MouseButton.RIGHT) || config.enableContextMenu === false;\n }\n\n addContextMenuListeners(config) {\n if (this.shouldDisableContextMenu(config)) {\n this.view.addEventListener('contextmenu', this.disableContextMenu);\n } else if (config.enableContextMenu) {\n this.view.addEventListener('contextmenu', this.enableContextMenu);\n }\n }\n\n removeContextMenuListeners(config) {\n if (this.shouldDisableContextMenu(config)) {\n this.view.removeEventListener('contextmenu', this.disableContextMenu);\n } else if (config.enableContextMenu) {\n this.view.removeEventListener('contextmenu', this.enableContextMenu);\n }\n }\n\n disableContextMenu(e) {\n e.preventDefault();\n }\n\n enableContextMenu(e) {\n e.stopPropagation();\n }\n\n onBegin() {// no-op for now\n }\n\n onActivate() {\n const config = this.gestureHandler.getConfig();\n\n if ((!this.view.style.cursor || this.view.style.cursor === 'auto') && config.activeCursor) {\n this.view.style.cursor = config.activeCursor;\n }\n }\n\n onEnd() {\n this.tryResetCursor();\n }\n\n onCancel() {\n this.tryResetCursor();\n }\n\n onFail() {\n this.tryResetCursor();\n }\n\n destroy(config) {\n this.removeContextMenuListeners(config);\n this.eventManagers.forEach(manager => {\n manager.unregisterListeners();\n });\n }\n\n}\n//# sourceMappingURL=GestureHandlerWebDelegate.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport EventManager from './EventManager';\nimport { MouseButton } from '../../handlers/gestureHandlerCommon';\nimport { EventTypes } from '../interfaces';\nimport { PointerTypeMapping, isPointerInBounds } from '../utils';\nimport { PointerType } from '../../PointerType';\nconst POINTER_CAPTURE_EXCLUDE_LIST = new Set(['SELECT', 'INPUT']);\nconst PointerTypes = {\n Touch: 'touch',\n Stylus: 'pen'\n};\nexport default class PointerEventManager extends EventManager {\n constructor(view) {\n super(view);\n\n _defineProperty(this, \"trackedPointers\", new Set());\n\n _defineProperty(this, \"mouseButtonsMapper\", new Map());\n\n _defineProperty(this, \"lastPosition\", void 0);\n\n _defineProperty(this, \"pointerDownCallback\", event => {\n if (event.pointerType === PointerTypes.Touch) {\n return;\n }\n\n if (!isPointerInBounds(this.view, {\n x: event.clientX,\n y: event.clientY\n })) {\n return;\n }\n\n const adaptedEvent = this.mapEvent(event, EventTypes.DOWN);\n const target = event.target;\n\n if (!POINTER_CAPTURE_EXCLUDE_LIST.has(target.tagName)) {\n target.setPointerCapture(adaptedEvent.pointerId);\n }\n\n this.markAsInBounds(adaptedEvent.pointerId);\n this.trackedPointers.add(adaptedEvent.pointerId);\n\n if (++this.activePointersCounter > 1) {\n adaptedEvent.eventType = EventTypes.ADDITIONAL_POINTER_DOWN;\n this.onPointerAdd(adaptedEvent);\n } else {\n this.onPointerDown(adaptedEvent);\n }\n });\n\n _defineProperty(this, \"pointerUpCallback\", event => {\n if (event.pointerType === PointerTypes.Touch) {\n return;\n } // When we call reset on gesture handlers, it also resets their event managers\n // In some handlers (like RotationGestureHandler) reset is called before all pointers leave view\n // This means, that activePointersCounter will be set to 0, while there are still remaining pointers on view\n // Removing them will end in activePointersCounter going below 0, therefore handlers won't behave properly\n\n\n if (this.activePointersCounter === 0) {\n return;\n }\n\n const adaptedEvent = this.mapEvent(event, EventTypes.UP);\n const target = event.target;\n\n if (!POINTER_CAPTURE_EXCLUDE_LIST.has(target.tagName)) {\n target.releasePointerCapture(adaptedEvent.pointerId);\n }\n\n this.markAsOutOfBounds(adaptedEvent.pointerId);\n this.trackedPointers.delete(adaptedEvent.pointerId);\n\n if (--this.activePointersCounter > 0) {\n adaptedEvent.eventType = EventTypes.ADDITIONAL_POINTER_UP;\n this.onPointerRemove(adaptedEvent);\n } else {\n this.onPointerUp(adaptedEvent);\n }\n });\n\n _defineProperty(this, \"pointerMoveCallback\", event => {\n if (event.pointerType === PointerTypes.Touch) {\n return;\n } // Stylus triggers `pointermove` event when it detects changes in pressure. Since it is very sensitive to those changes,\n // it constantly sends events, even though there was no change in position. To fix that we check whether\n // pointer has actually moved and if not, we do not send event.\n\n\n if (event.pointerType === PointerTypes.Stylus && event.x === this.lastPosition.x && event.y === this.lastPosition.y) {\n return;\n }\n\n const adaptedEvent = this.mapEvent(event, EventTypes.MOVE);\n const target = event.target; // You may be wondering why are we setting pointer capture here, when we\n // already set it in `pointerdown` handler. Well, that's a great question,\n // for which I don't have an answer. Specification (https://www.w3.org/TR/pointerevents2/#dom-element-setpointercapture)\n // says that the requirement for `setPointerCapture` to work is that pointer\n // must be in 'active buttons state`, otherwise it will fail silently, which\n // is lovely. Obviously, when `pointerdown` is fired, one of the buttons\n // (when using mouse) is pressed, but that doesn't mean that `setPointerCapture`\n // will succeed, for some reason. Since it fails silently, we don't actually know\n // if it worked or not (there's `gotpointercapture` event, but the complexity of\n // incorporating it here seems stupid), so we just call it again here, every time\n // pointer moves until it succeeds.\n // God, I do love web development.\n\n if (!target.hasPointerCapture(event.pointerId) && !POINTER_CAPTURE_EXCLUDE_LIST.has(target.tagName)) {\n target.setPointerCapture(event.pointerId);\n }\n\n const inBounds = isPointerInBounds(this.view, {\n x: adaptedEvent.x,\n y: adaptedEvent.y\n });\n const pointerIndex = this.pointersInBounds.indexOf(adaptedEvent.pointerId);\n\n if (inBounds) {\n if (pointerIndex < 0) {\n adaptedEvent.eventType = EventTypes.ENTER;\n this.onPointerEnter(adaptedEvent);\n this.markAsInBounds(adaptedEvent.pointerId);\n } else {\n this.onPointerMove(adaptedEvent);\n }\n } else {\n if (pointerIndex >= 0) {\n adaptedEvent.eventType = EventTypes.LEAVE;\n this.onPointerLeave(adaptedEvent);\n this.markAsOutOfBounds(adaptedEvent.pointerId);\n } else {\n this.onPointerOutOfBounds(adaptedEvent);\n }\n }\n\n this.lastPosition.x = event.x;\n this.lastPosition.y = event.y;\n });\n\n _defineProperty(this, \"pointerCancelCallback\", event => {\n if (event.pointerType === PointerTypes.Touch) {\n return;\n }\n\n const adaptedEvent = this.mapEvent(event, EventTypes.CANCEL);\n this.onPointerCancel(adaptedEvent);\n this.markAsOutOfBounds(adaptedEvent.pointerId);\n this.activePointersCounter = 0;\n this.trackedPointers.clear();\n });\n\n _defineProperty(this, \"pointerEnterCallback\", event => {\n if (event.pointerType === PointerTypes.Touch) {\n return;\n }\n\n const adaptedEvent = this.mapEvent(event, EventTypes.ENTER);\n this.onPointerMoveOver(adaptedEvent);\n });\n\n _defineProperty(this, \"pointerLeaveCallback\", event => {\n if (event.pointerType === PointerTypes.Touch) {\n return;\n }\n\n const adaptedEvent = this.mapEvent(event, EventTypes.LEAVE);\n this.onPointerMoveOut(adaptedEvent);\n });\n\n _defineProperty(this, \"lostPointerCaptureCallback\", event => {\n const adaptedEvent = this.mapEvent(event, EventTypes.CANCEL);\n\n if (this.trackedPointers.has(adaptedEvent.pointerId)) {\n // in some cases the `pointerup` event is not fired, but `lostpointercapture` is\n // we simulate the `pointercancel` event here to make sure the gesture handler stops tracking it\n this.onPointerCancel(adaptedEvent);\n this.activePointersCounter = 0;\n this.trackedPointers.clear();\n }\n });\n\n this.mouseButtonsMapper.set(0, MouseButton.LEFT);\n this.mouseButtonsMapper.set(1, MouseButton.MIDDLE);\n this.mouseButtonsMapper.set(2, MouseButton.RIGHT);\n this.mouseButtonsMapper.set(3, MouseButton.BUTTON_4);\n this.mouseButtonsMapper.set(4, MouseButton.BUTTON_5);\n this.lastPosition = {\n x: -Infinity,\n y: -Infinity\n };\n }\n\n registerListeners() {\n this.view.addEventListener('pointerdown', this.pointerDownCallback);\n this.view.addEventListener('pointerup', this.pointerUpCallback);\n this.view.addEventListener('pointermove', this.pointerMoveCallback);\n this.view.addEventListener('pointercancel', this.pointerCancelCallback); // onPointerEnter and onPointerLeave are triggered by a custom logic responsible for\n // handling shouldCancelWhenOutside flag, and are unreliable unless the pointer is down.\n // We therefore use pointerenter and pointerleave events to handle the hover gesture,\n // mapping them to onPointerMoveOver and onPointerMoveOut respectively.\n\n this.view.addEventListener('pointerenter', this.pointerEnterCallback);\n this.view.addEventListener('pointerleave', this.pointerLeaveCallback);\n this.view.addEventListener('lostpointercapture', this.lostPointerCaptureCallback);\n }\n\n unregisterListeners() {\n this.view.removeEventListener('pointerdown', this.pointerDownCallback);\n this.view.removeEventListener('pointerup', this.pointerUpCallback);\n this.view.removeEventListener('pointermove', this.pointerMoveCallback);\n this.view.removeEventListener('pointercancel', this.pointerCancelCallback);\n this.view.removeEventListener('pointerenter', this.pointerEnterCallback);\n this.view.removeEventListener('pointerleave', this.pointerLeaveCallback);\n this.view.removeEventListener('lostpointercapture', this.lostPointerCaptureCallback);\n }\n\n mapEvent(event, eventType) {\n var _PointerTypeMapping$g;\n\n return {\n x: event.clientX,\n y: event.clientY,\n offsetX: event.offsetX,\n offsetY: event.offsetY,\n pointerId: event.pointerId,\n eventType: eventType,\n pointerType: (_PointerTypeMapping$g = PointerTypeMapping.get(event.pointerType)) !== null && _PointerTypeMapping$g !== void 0 ? _PointerTypeMapping$g : PointerType.OTHER,\n button: this.mouseButtonsMapper.get(event.button),\n time: event.timeStamp\n };\n }\n\n resetManager() {\n super.resetManager();\n this.trackedPointers.clear();\n }\n\n}\n//# sourceMappingURL=PointerEventManager.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/* eslint-disable @typescript-eslint/no-empty-function */\nexport default class EventManager {\n constructor(view) {\n _defineProperty(this, \"view\", void 0);\n\n _defineProperty(this, \"pointersInBounds\", []);\n\n _defineProperty(this, \"activePointersCounter\", void 0);\n\n this.view = view;\n this.activePointersCounter = 0;\n }\n\n onPointerDown(_event) {}\n\n onPointerAdd(_event) {}\n\n onPointerUp(_event) {}\n\n onPointerRemove(_event) {}\n\n onPointerMove(_event) {}\n\n onPointerLeave(_event) {} // called only when pointer is pressed (or touching)\n\n\n onPointerEnter(_event) {} // called only when pointer is pressed (or touching)\n\n\n onPointerCancel(_event) {// When pointer cancel is triggered and there are more pointers on the view, only one pointer is cancelled\n // Because we want all pointers to be cancelled by that event, we are doing it manually by reseting handler and changing activePointersCounter to 0\n // Events that correspond to removing the pointer (pointerup, touchend) have condition, that they don't perform any action when activePointersCounter\n // is equal to 0. This prevents counter from going to negative values, when pointers are removed from view after one of them has been cancelled\n }\n\n onPointerOutOfBounds(_event) {}\n\n onPointerMoveOver(_event) {}\n\n onPointerMoveOut(_event) {}\n\n setOnPointerDown(callback) {\n this.onPointerDown = callback;\n }\n\n setOnPointerAdd(callback) {\n this.onPointerAdd = callback;\n }\n\n setOnPointerUp(callback) {\n this.onPointerUp = callback;\n }\n\n setOnPointerRemove(callback) {\n this.onPointerRemove = callback;\n }\n\n setOnPointerMove(callback) {\n this.onPointerMove = callback;\n }\n\n setOnPointerLeave(callback) {\n this.onPointerLeave = callback;\n }\n\n setOnPointerEnter(callback) {\n this.onPointerEnter = callback;\n }\n\n setOnPointerCancel(callback) {\n this.onPointerCancel = callback;\n }\n\n setOnPointerOutOfBounds(callback) {\n this.onPointerOutOfBounds = callback;\n }\n\n setOnPointerMoveOver(callback) {\n this.onPointerMoveOver = callback;\n }\n\n setOnPointerMoveOut(callback) {\n this.onPointerMoveOut = callback;\n }\n\n markAsInBounds(pointerId) {\n if (this.pointersInBounds.indexOf(pointerId) >= 0) {\n return;\n }\n\n this.pointersInBounds.push(pointerId);\n }\n\n markAsOutOfBounds(pointerId) {\n const index = this.pointersInBounds.indexOf(pointerId);\n\n if (index < 0) {\n return;\n }\n\n this.pointersInBounds.splice(index, 1);\n }\n\n resetManager() {\n // Reseting activePointersCounter is necessary to make gestures such as pinch work properly\n // There are gestures that end when there is still one active pointer (like pinch/rotation)\n // When these gestures end, they are reset, but they still receive events from pointer that is active\n // This causes trouble, since only onPointerDown registers gesture in orchestrator, and while gestures receive\n // Events from active pointer after they finished, next pointerdown event will be registered as additional pointer, not the first one\n // This casues trouble like gestures getting stuck in END state, even though they should have gone to UNDETERMINED\n this.activePointersCounter = 0;\n this.pointersInBounds = [];\n }\n\n}\n//# sourceMappingURL=EventManager.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { EventTypes, TouchEventType } from '../interfaces';\nimport EventManager from './EventManager';\nimport { isPointerInBounds } from '../utils';\nimport { PointerType } from '../../PointerType';\nexport default class TouchEventManager extends EventManager {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"touchStartCallback\", event => {\n for (let i = 0; i < event.changedTouches.length; ++i) {\n const adaptedEvent = this.mapEvent(event, EventTypes.DOWN, i, TouchEventType.DOWN); // Here we skip stylus, because in case of anything different than touch we want to handle it by using PointerEvents\n // If we leave stylus to send touch events, handlers will receive every action twice\n\n if (!isPointerInBounds(this.view, {\n x: adaptedEvent.x,\n y: adaptedEvent.y\n }) || //@ts-ignore touchType field does exist\n event.changedTouches[i].touchType === 'stylus') {\n continue;\n }\n\n this.markAsInBounds(adaptedEvent.pointerId);\n\n if (++this.activePointersCounter > 1) {\n adaptedEvent.eventType = EventTypes.ADDITIONAL_POINTER_DOWN;\n this.onPointerAdd(adaptedEvent);\n } else {\n this.onPointerDown(adaptedEvent);\n }\n }\n });\n\n _defineProperty(this, \"touchMoveCallback\", event => {\n for (let i = 0; i < event.changedTouches.length; ++i) {\n const adaptedEvent = this.mapEvent(event, EventTypes.MOVE, i, TouchEventType.MOVE); //@ts-ignore touchType field does exist\n\n if (event.changedTouches[i].touchType === 'stylus') {\n continue;\n }\n\n const inBounds = isPointerInBounds(this.view, {\n x: adaptedEvent.x,\n y: adaptedEvent.y\n });\n const pointerIndex = this.pointersInBounds.indexOf(adaptedEvent.pointerId);\n\n if (inBounds) {\n if (pointerIndex < 0) {\n adaptedEvent.eventType = EventTypes.ENTER;\n this.onPointerEnter(adaptedEvent);\n this.markAsInBounds(adaptedEvent.pointerId);\n } else {\n this.onPointerMove(adaptedEvent);\n }\n } else {\n if (pointerIndex >= 0) {\n adaptedEvent.eventType = EventTypes.LEAVE;\n this.onPointerLeave(adaptedEvent);\n this.markAsOutOfBounds(adaptedEvent.pointerId);\n } else {\n this.onPointerOutOfBounds(adaptedEvent);\n }\n }\n }\n });\n\n _defineProperty(this, \"touchEndCallback\", event => {\n for (let i = 0; i < event.changedTouches.length; ++i) {\n // When we call reset on gesture handlers, it also resets their event managers\n // In some handlers (like RotationGestureHandler) reset is called before all pointers leave view\n // This means, that activePointersCounter will be set to 0, while there are still remaining pointers on view\n // Removing them will end in activePointersCounter going below 0, therefore handlers won't behave properly\n if (this.activePointersCounter === 0) {\n break;\n } //@ts-ignore touchType field does exist\n\n\n if (event.changedTouches[i].touchType === 'stylus') {\n continue;\n }\n\n const adaptedEvent = this.mapEvent(event, EventTypes.UP, i, TouchEventType.UP);\n this.markAsOutOfBounds(adaptedEvent.pointerId);\n\n if (--this.activePointersCounter > 0) {\n adaptedEvent.eventType = EventTypes.ADDITIONAL_POINTER_UP;\n this.onPointerRemove(adaptedEvent);\n } else {\n this.onPointerUp(adaptedEvent);\n }\n }\n });\n\n _defineProperty(this, \"touchCancelCallback\", event => {\n for (let i = 0; i < event.changedTouches.length; ++i) {\n const adaptedEvent = this.mapEvent(event, EventTypes.CANCEL, i, TouchEventType.CANCELLED); //@ts-ignore touchType field does exist\n\n if (event.changedTouches[i].touchType === 'stylus') {\n continue;\n }\n\n this.onPointerCancel(adaptedEvent);\n this.markAsOutOfBounds(adaptedEvent.pointerId);\n this.activePointersCounter = 0;\n }\n });\n }\n\n registerListeners() {\n this.view.addEventListener('touchstart', this.touchStartCallback);\n this.view.addEventListener('touchmove', this.touchMoveCallback);\n this.view.addEventListener('touchend', this.touchEndCallback);\n this.view.addEventListener('touchcancel', this.touchCancelCallback);\n }\n\n unregisterListeners() {\n this.view.removeEventListener('touchstart', this.touchStartCallback);\n this.view.removeEventListener('touchmove', this.touchMoveCallback);\n this.view.removeEventListener('touchend', this.touchEndCallback);\n this.view.removeEventListener('touchcancel', this.touchCancelCallback);\n }\n\n mapEvent(event, eventType, index, touchEventType) {\n const rect = this.view.getBoundingClientRect();\n const clientX = event.changedTouches[index].clientX;\n const clientY = event.changedTouches[index].clientY;\n return {\n x: clientX,\n y: clientY,\n offsetX: clientX - rect.left,\n offsetY: clientY - rect.top,\n pointerId: event.changedTouches[index].identifier,\n eventType: eventType,\n pointerType: PointerType.TOUCH,\n time: event.timeStamp,\n allTouches: event.touches,\n changedTouches: event.changedTouches,\n touchEventType: touchEventType\n };\n }\n\n}\n//# sourceMappingURL=TouchEventManager.js.map","import * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport hoistNonReactStatics from 'hoist-non-react-statics';\nimport GestureHandlerRootView from './GestureHandlerRootView';\nexport default function gestureHandlerRootHOC(Component, containerStyles) {\n function Wrapper(props) {\n return /*#__PURE__*/React.createElement(GestureHandlerRootView, {\n style: [styles.container, containerStyles]\n }, /*#__PURE__*/React.createElement(Component, props));\n }\n\n Wrapper.displayName = `gestureHandlerRootHOC(${Component.displayName || Component.name})`; // @ts-ignore - hoistNonReactStatics uses old version of @types/react\n\n hoistNonReactStatics(Wrapper, Component);\n return Wrapper;\n}\nconst styles = StyleSheet.create({\n container: {\n flex: 1\n }\n});\n//# sourceMappingURL=gestureHandlerRootHOC.js.map","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"writingDirection\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport { atomic, classic, inline } from './compiler';\nimport { createSheet } from './dom';\nimport { localizeStyle } from 'styleq/transform-localize-style';\nimport { preprocess } from './preprocess';\nimport { styleq } from 'styleq';\nimport { validate } from './validate';\nimport canUseDOM from '../../modules/canUseDom';\nvar staticStyleMap = new WeakMap();\nvar sheet = createSheet();\nvar defaultPreprocessOptions = {\n shadow: true,\n textShadow: true\n};\nfunction customStyleq(styles, options) {\n if (options === void 0) {\n options = {};\n }\n var _options = options,\n writingDirection = _options.writingDirection,\n preprocessOptions = _objectWithoutPropertiesLoose(_options, _excluded);\n var isRTL = writingDirection === 'rtl';\n return styleq.factory({\n transform(style) {\n var compiledStyle = staticStyleMap.get(style);\n if (compiledStyle != null) {\n return localizeStyle(compiledStyle, isRTL);\n }\n return preprocess(style, _objectSpread(_objectSpread({}, defaultPreprocessOptions), preprocessOptions));\n }\n })(styles);\n}\nfunction insertRules(compiledOrderedRules) {\n compiledOrderedRules.forEach(_ref => {\n var rules = _ref[0],\n order = _ref[1];\n if (sheet != null) {\n rules.forEach(rule => {\n sheet.insert(rule, order);\n });\n }\n });\n}\nfunction compileAndInsertAtomic(style) {\n var _atomic = atomic(preprocess(style, defaultPreprocessOptions)),\n compiledStyle = _atomic[0],\n compiledOrderedRules = _atomic[1];\n insertRules(compiledOrderedRules);\n return compiledStyle;\n}\nfunction compileAndInsertReset(style, key) {\n var _classic = classic(style, key),\n compiledStyle = _classic[0],\n compiledOrderedRules = _classic[1];\n insertRules(compiledOrderedRules);\n return compiledStyle;\n}\n\n/* ----- API ----- */\n\nvar absoluteFillObject = {\n position: 'absolute',\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n};\nvar absoluteFill = create({\n x: _objectSpread({}, absoluteFillObject)\n}).x;\n\n/**\n * create\n */\nfunction create(styles) {\n Object.keys(styles).forEach(key => {\n var styleObj = styles[key];\n // Only compile at runtime if the style is not already compiled\n if (styleObj != null && styleObj.$$css !== true) {\n var compiledStyles;\n if (key.indexOf('$raw') > -1) {\n compiledStyles = compileAndInsertReset(styleObj, key.split('$raw')[0]);\n } else {\n if (process.env.NODE_ENV !== 'production') {\n validate(styleObj);\n styles[key] = Object.freeze(styleObj);\n }\n compiledStyles = compileAndInsertAtomic(styleObj);\n }\n staticStyleMap.set(styleObj, compiledStyles);\n }\n });\n return styles;\n}\n\n/**\n * compose\n */\nfunction compose(style1, style2) {\n if (process.env.NODE_ENV !== 'production') {\n /* eslint-disable prefer-rest-params */\n var len = arguments.length;\n if (len > 2) {\n var readableStyles = [...arguments].map(a => flatten(a));\n throw new Error(\"StyleSheet.compose() only accepts 2 arguments, received \" + len + \": \" + JSON.stringify(readableStyles));\n }\n /* eslint-enable prefer-rest-params */\n console.warn('StyleSheet.compose(a, b) is deprecated; use array syntax, i.e., [a,b].');\n }\n return [style1, style2];\n}\n\n/**\n * flatten\n */\nfunction flatten() {\n for (var _len = arguments.length, styles = new Array(_len), _key = 0; _key < _len; _key++) {\n styles[_key] = arguments[_key];\n }\n var flatArray = styles.flat(Infinity);\n var result = {};\n for (var i = 0; i < flatArray.length; i++) {\n var style = flatArray[i];\n if (style != null && typeof style === 'object') {\n // $FlowFixMe\n Object.assign(result, style);\n }\n }\n return result;\n}\n\n/**\n * getSheet\n */\nfunction getSheet() {\n return {\n id: sheet.id,\n textContent: sheet.getTextContent()\n };\n}\n\n/**\n * resolve\n */\n\nfunction StyleSheet(styles, options) {\n if (options === void 0) {\n options = {};\n }\n var isRTL = options.writingDirection === 'rtl';\n var styleProps = customStyleq(styles, options);\n if (Array.isArray(styleProps) && styleProps[1] != null) {\n styleProps[1] = inline(styleProps[1], isRTL);\n }\n return styleProps;\n}\nStyleSheet.absoluteFill = absoluteFill;\nStyleSheet.absoluteFillObject = absoluteFillObject;\nStyleSheet.create = create;\nStyleSheet.compose = compose;\nStyleSheet.flatten = flatten;\nStyleSheet.getSheet = getSheet;\n// `hairlineWidth` is not implemented using screen density as browsers may\n// round sub-pixel values down to `0`, causing the line not to be rendered.\nStyleSheet.hairlineWidth = 1;\nif (canUseDOM && window.__REACT_DEVTOOLS_GLOBAL_HOOK__) {\n window.__REACT_DEVTOOLS_GLOBAL_HOOK__.resolveRNStyle = StyleSheet.flatten;\n}\nvar stylesheet = StyleSheet;\nexport default stylesheet;","var defineProperty = require(\"./defineProperty.js\");\nfunction ownKeys(e, r) {\n var t = Object.keys(e);\n if (Object.getOwnPropertySymbols) {\n var o = Object.getOwnPropertySymbols(e);\n r && (o = o.filter(function (r) {\n return Object.getOwnPropertyDescriptor(e, r).enumerable;\n })), t.push.apply(t, o);\n }\n return t;\n}\nfunction _objectSpread2(e) {\n for (var r = 1; r < arguments.length; r++) {\n var t = null != arguments[r] ? arguments[r] : {};\n r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {\n defineProperty(e, r, t[r]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {\n Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));\n });\n }\n return e;\n}\nmodule.exports = _objectSpread2, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var toPropertyKey = require(\"./toPropertyKey.js\");\nfunction _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nmodule.exports = _defineProperty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar toPrimitive = require(\"./toPrimitive.js\");\nfunction _toPropertyKey(arg) {\n var key = toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}\nmodule.exports = _toPropertyKey, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return (module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports), _typeof(o);\n}\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nmodule.exports = _toPrimitive, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"animationKeyframes\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport createReactDOMStyle from './createReactDOMStyle';\nimport hash from './hash';\nimport hyphenateStyleName from './hyphenateStyleName';\nimport normalizeValueWithProperty from './normalizeValueWithProperty';\nimport prefixStyles from '../../../modules/prefixStyles';\nvar cache = new Map();\nvar emptyObject = {};\nvar classicGroup = 1;\nvar atomicGroup = 3;\nvar customGroup = {\n borderColor: 2,\n borderRadius: 2,\n borderStyle: 2,\n borderWidth: 2,\n display: 2,\n flex: 2,\n inset: 2,\n margin: 2,\n overflow: 2,\n overscrollBehavior: 2,\n padding: 2,\n insetBlock: 2.1,\n insetInline: 2.1,\n marginInline: 2.1,\n marginBlock: 2.1,\n paddingInline: 2.1,\n paddingBlock: 2.1,\n borderBlockStartColor: 2.2,\n borderBlockStartStyle: 2.2,\n borderBlockStartWidth: 2.2,\n borderBlockEndColor: 2.2,\n borderBlockEndStyle: 2.2,\n borderBlockEndWidth: 2.2,\n borderInlineStartColor: 2.2,\n borderInlineStartStyle: 2.2,\n borderInlineStartWidth: 2.2,\n borderInlineEndColor: 2.2,\n borderInlineEndStyle: 2.2,\n borderInlineEndWidth: 2.2,\n borderEndStartRadius: 2.2,\n borderEndEndRadius: 2.2,\n borderStartStartRadius: 2.2,\n borderStartEndRadius: 2.2,\n insetBlockEnd: 2.2,\n insetBlockStart: 2.2,\n insetInlineEnd: 2.2,\n insetInlineStart: 2.2,\n marginBlockStart: 2.2,\n marginBlockEnd: 2.2,\n marginInlineStart: 2.2,\n marginInlineEnd: 2.2,\n paddingBlockStart: 2.2,\n paddingBlockEnd: 2.2,\n paddingInlineStart: 2.2,\n paddingInlineEnd: 2.2\n};\nvar borderTopLeftRadius = 'borderTopLeftRadius';\nvar borderTopRightRadius = 'borderTopRightRadius';\nvar borderBottomLeftRadius = 'borderBottomLeftRadius';\nvar borderBottomRightRadius = 'borderBottomRightRadius';\nvar borderLeftColor = 'borderLeftColor';\nvar borderLeftStyle = 'borderLeftStyle';\nvar borderLeftWidth = 'borderLeftWidth';\nvar borderRightColor = 'borderRightColor';\nvar borderRightStyle = 'borderRightStyle';\nvar borderRightWidth = 'borderRightWidth';\nvar right = 'right';\nvar marginLeft = 'marginLeft';\nvar marginRight = 'marginRight';\nvar paddingLeft = 'paddingLeft';\nvar paddingRight = 'paddingRight';\nvar left = 'left';\n\n// Map of LTR property names to their BiDi equivalent.\nvar PROPERTIES_FLIP = {\n [borderTopLeftRadius]: borderTopRightRadius,\n [borderTopRightRadius]: borderTopLeftRadius,\n [borderBottomLeftRadius]: borderBottomRightRadius,\n [borderBottomRightRadius]: borderBottomLeftRadius,\n [borderLeftColor]: borderRightColor,\n [borderLeftStyle]: borderRightStyle,\n [borderLeftWidth]: borderRightWidth,\n [borderRightColor]: borderLeftColor,\n [borderRightStyle]: borderLeftStyle,\n [borderRightWidth]: borderLeftWidth,\n [left]: right,\n [marginLeft]: marginRight,\n [marginRight]: marginLeft,\n [paddingLeft]: paddingRight,\n [paddingRight]: paddingLeft,\n [right]: left\n};\n\n// Map of I18N property names to their LTR equivalent.\nvar PROPERTIES_I18N = {\n borderStartStartRadius: borderTopLeftRadius,\n borderStartEndRadius: borderTopRightRadius,\n borderEndStartRadius: borderBottomLeftRadius,\n borderEndEndRadius: borderBottomRightRadius,\n borderInlineStartColor: borderLeftColor,\n borderInlineStartStyle: borderLeftStyle,\n borderInlineStartWidth: borderLeftWidth,\n borderInlineEndColor: borderRightColor,\n borderInlineEndStyle: borderRightStyle,\n borderInlineEndWidth: borderRightWidth,\n insetInlineEnd: right,\n insetInlineStart: left,\n marginInlineStart: marginLeft,\n marginInlineEnd: marginRight,\n paddingInlineStart: paddingLeft,\n paddingInlineEnd: paddingRight\n};\nvar PROPERTIES_VALUE = ['clear', 'float', 'textAlign'];\nexport function atomic(style) {\n var compiledStyle = {\n $$css: true\n };\n var compiledRules = [];\n function atomicCompile(srcProp, prop, value) {\n var valueString = stringifyValueWithProperty(value, prop);\n var cacheKey = prop + valueString;\n var cachedResult = cache.get(cacheKey);\n var identifier;\n if (cachedResult != null) {\n identifier = cachedResult[0];\n compiledRules.push(cachedResult[1]);\n } else {\n var v = srcProp !== prop ? cacheKey : valueString;\n identifier = createIdentifier('r', srcProp, v);\n var order = customGroup[srcProp] || atomicGroup;\n var rules = createAtomicRules(identifier, prop, value);\n var orderedRules = [rules, order];\n compiledRules.push(orderedRules);\n cache.set(cacheKey, [identifier, orderedRules]);\n }\n return identifier;\n }\n Object.keys(style).sort().forEach(srcProp => {\n var value = style[srcProp];\n if (value != null) {\n var localizeableValue;\n // BiDi flip values\n if (PROPERTIES_VALUE.indexOf(srcProp) > -1) {\n var _left = atomicCompile(srcProp, srcProp, 'left');\n var _right = atomicCompile(srcProp, srcProp, 'right');\n if (value === 'start') {\n localizeableValue = [_left, _right];\n } else if (value === 'end') {\n localizeableValue = [_right, _left];\n }\n }\n // BiDi flip properties\n var propPolyfill = PROPERTIES_I18N[srcProp];\n if (propPolyfill != null) {\n var ltr = atomicCompile(srcProp, propPolyfill, value);\n var rtl = atomicCompile(srcProp, PROPERTIES_FLIP[propPolyfill], value);\n localizeableValue = [ltr, rtl];\n }\n // BiDi flip transitionProperty value\n if (srcProp === 'transitionProperty') {\n var values = Array.isArray(value) ? value : [value];\n var polyfillIndices = [];\n for (var i = 0; i < values.length; i++) {\n var val = values[i];\n if (typeof val === 'string' && PROPERTIES_I18N[val] != null) {\n polyfillIndices.push(i);\n }\n }\n if (polyfillIndices.length > 0) {\n var ltrPolyfillValues = [...values];\n var rtlPolyfillValues = [...values];\n polyfillIndices.forEach(i => {\n var ltrVal = ltrPolyfillValues[i];\n if (typeof ltrVal === 'string') {\n var ltrPolyfill = PROPERTIES_I18N[ltrVal];\n var rtlPolyfill = PROPERTIES_FLIP[ltrPolyfill];\n ltrPolyfillValues[i] = ltrPolyfill;\n rtlPolyfillValues[i] = rtlPolyfill;\n var _ltr = atomicCompile(srcProp, srcProp, ltrPolyfillValues);\n var _rtl = atomicCompile(srcProp, srcProp, rtlPolyfillValues);\n localizeableValue = [_ltr, _rtl];\n }\n });\n }\n }\n if (localizeableValue == null) {\n localizeableValue = atomicCompile(srcProp, srcProp, value);\n } else {\n compiledStyle['$$css$localize'] = true;\n }\n compiledStyle[srcProp] = localizeableValue;\n }\n });\n return [compiledStyle, compiledRules];\n}\n\n/**\n * Compile simple style object to classic CSS rules.\n * No support for 'placeholderTextColor', 'scrollbarWidth', or 'pointerEvents'.\n */\nexport function classic(style, name) {\n var compiledStyle = {\n $$css: true\n };\n var compiledRules = [];\n var animationKeyframes = style.animationKeyframes,\n rest = _objectWithoutPropertiesLoose(style, _excluded);\n var identifier = createIdentifier('css', name, JSON.stringify(style));\n var selector = \".\" + identifier;\n var animationName;\n if (animationKeyframes != null) {\n var _processKeyframesValu = processKeyframesValue(animationKeyframes),\n animationNames = _processKeyframesValu[0],\n keyframesRules = _processKeyframesValu[1];\n animationName = animationNames.join(',');\n compiledRules.push(...keyframesRules);\n }\n var block = createDeclarationBlock(_objectSpread(_objectSpread({}, rest), {}, {\n animationName\n }));\n compiledRules.push(\"\" + selector + block);\n compiledStyle[identifier] = identifier;\n return [compiledStyle, [[compiledRules, classicGroup]]];\n}\n\n/**\n * Compile simple style object to inline DOM styles.\n * No support for 'animationKeyframes', 'placeholderTextColor', 'scrollbarWidth', or 'pointerEvents'.\n */\nexport function inline(originalStyle, isRTL) {\n var style = originalStyle || emptyObject;\n var frozenProps = {};\n var nextStyle = {};\n var _loop = function _loop() {\n var originalValue = style[originalProp];\n var prop = originalProp;\n var value = originalValue;\n if (!Object.prototype.hasOwnProperty.call(style, originalProp) || originalValue == null) {\n return \"continue\";\n }\n\n // BiDi flip values\n if (PROPERTIES_VALUE.indexOf(originalProp) > -1) {\n if (originalValue === 'start') {\n value = isRTL ? 'right' : 'left';\n } else if (originalValue === 'end') {\n value = isRTL ? 'left' : 'right';\n }\n }\n // BiDi flip properties\n var propPolyfill = PROPERTIES_I18N[originalProp];\n if (propPolyfill != null) {\n prop = isRTL ? PROPERTIES_FLIP[propPolyfill] : propPolyfill;\n }\n // BiDi flip transitionProperty value\n if (originalProp === 'transitionProperty') {\n // $FlowFixMe\n var originalValues = Array.isArray(originalValue) ? originalValue : [originalValue];\n originalValues.forEach((val, i) => {\n if (typeof val === 'string') {\n var valuePolyfill = PROPERTIES_I18N[val];\n if (valuePolyfill != null) {\n originalValues[i] = isRTL ? PROPERTIES_FLIP[valuePolyfill] : valuePolyfill;\n value = originalValues.join(' ');\n }\n }\n });\n }\n\n // Create finalized style\n if (!frozenProps[prop]) {\n nextStyle[prop] = value;\n }\n if (prop === originalProp) {\n frozenProps[prop] = true;\n }\n\n // if (PROPERTIES_I18N.hasOwnProperty(originalProp)) {\n // frozenProps[prop] = true;\n //}\n };\n for (var originalProp in style) {\n var _ret = _loop();\n if (_ret === \"continue\") continue;\n }\n return createReactDOMStyle(nextStyle, true);\n}\n\n/**\n * Create a value string that normalizes different input values with a common\n * output.\n */\nexport function stringifyValueWithProperty(value, property) {\n // e.g., 0 => '0px', 'black' => 'rgba(0,0,0,1)'\n var normalizedValue = normalizeValueWithProperty(value, property);\n return typeof normalizedValue !== 'string' ? JSON.stringify(normalizedValue || '') : normalizedValue;\n}\n\n/**\n * Create the Atomic CSS rules needed for a given StyleSheet rule.\n * Translates StyleSheet declarations to CSS.\n */\nfunction createAtomicRules(identifier, property, value) {\n var rules = [];\n var selector = \".\" + identifier;\n\n // Handle non-standard properties and object values that require multiple\n // CSS rules to be created.\n switch (property) {\n case 'animationKeyframes':\n {\n var _processKeyframesValu2 = processKeyframesValue(value),\n animationNames = _processKeyframesValu2[0],\n keyframesRules = _processKeyframesValu2[1];\n var block = createDeclarationBlock({\n animationName: animationNames.join(',')\n });\n rules.push(\"\" + selector + block, ...keyframesRules);\n break;\n }\n\n // Equivalent to using '::placeholder'\n case 'placeholderTextColor':\n {\n var _block = createDeclarationBlock({\n color: value,\n opacity: 1\n });\n rules.push(selector + \"::-webkit-input-placeholder\" + _block, selector + \"::-moz-placeholder\" + _block, selector + \":-ms-input-placeholder\" + _block, selector + \"::placeholder\" + _block);\n break;\n }\n\n // Polyfill for additional 'pointer-events' values\n // See d13f78622b233a0afc0c7a200c0a0792c8ca9e58\n case 'pointerEvents':\n {\n var finalValue = value;\n if (value === 'auto' || value === 'box-only') {\n finalValue = 'auto!important';\n if (value === 'box-only') {\n var _block2 = createDeclarationBlock({\n pointerEvents: 'none'\n });\n rules.push(selector + \">*\" + _block2);\n }\n } else if (value === 'none' || value === 'box-none') {\n finalValue = 'none!important';\n if (value === 'box-none') {\n var _block3 = createDeclarationBlock({\n pointerEvents: 'auto'\n });\n rules.push(selector + \">*\" + _block3);\n }\n }\n var _block4 = createDeclarationBlock({\n pointerEvents: finalValue\n });\n rules.push(\"\" + selector + _block4);\n break;\n }\n\n // Polyfill for draft spec\n // https://drafts.csswg.org/css-scrollbars-1/\n case 'scrollbarWidth':\n {\n if (value === 'none') {\n rules.push(selector + \"::-webkit-scrollbar{display:none}\");\n }\n var _block5 = createDeclarationBlock({\n scrollbarWidth: value\n });\n rules.push(\"\" + selector + _block5);\n break;\n }\n default:\n {\n var _block6 = createDeclarationBlock({\n [property]: value\n });\n rules.push(\"\" + selector + _block6);\n break;\n }\n }\n return rules;\n}\n\n/**\n * Creates a CSS declaration block from a StyleSheet object.\n */\nfunction createDeclarationBlock(style) {\n var domStyle = prefixStyles(createReactDOMStyle(style));\n var declarationsString = Object.keys(domStyle).map(property => {\n var value = domStyle[property];\n var prop = hyphenateStyleName(property);\n // The prefixer may return an array of values:\n // { display: [ '-webkit-flex', 'flex' ] }\n // to represent \"fallback\" declarations\n // { display: -webkit-flex; display: flex; }\n if (Array.isArray(value)) {\n return value.map(v => prop + \":\" + v).join(';');\n } else {\n return prop + \":\" + value;\n }\n })\n // Once properties are hyphenated, this will put the vendor\n // prefixed and short-form properties first in the list.\n .sort().join(';');\n return \"{\" + declarationsString + \";}\";\n}\n\n/**\n * An identifier is associated with a unique set of styles.\n */\nfunction createIdentifier(prefix, name, key) {\n var hashedString = hash(name + key);\n return process.env.NODE_ENV !== 'production' ? prefix + \"-\" + name + \"-\" + hashedString : prefix + \"-\" + hashedString;\n}\n\n/**\n * Create individual CSS keyframes rules.\n */\nfunction createKeyframes(keyframes) {\n var prefixes = ['-webkit-', ''];\n var identifier = createIdentifier('r', 'animation', JSON.stringify(keyframes));\n var steps = '{' + Object.keys(keyframes).map(stepName => {\n var rule = keyframes[stepName];\n var block = createDeclarationBlock(rule);\n return \"\" + stepName + block;\n }).join('') + '}';\n var rules = prefixes.map(prefix => {\n return \"@\" + prefix + \"keyframes \" + identifier + steps;\n });\n return [identifier, rules];\n}\n\n/**\n * Create CSS keyframes rules and names from a StyleSheet keyframes object.\n */\nfunction processKeyframesValue(keyframesValue) {\n if (typeof keyframesValue === 'number') {\n throw new Error(\"Invalid CSS keyframes type: \" + typeof keyframesValue);\n }\n var animationNames = [];\n var rules = [];\n var value = Array.isArray(keyframesValue) ? keyframesValue : [keyframesValue];\n value.forEach(keyframes => {\n if (typeof keyframes === 'string') {\n // Support external animation libraries (identifiers only)\n animationNames.push(keyframes);\n } else {\n // Create rules for each of the keyframes\n var _createKeyframes = createKeyframes(keyframes),\n identifier = _createKeyframes[0],\n keyframesRules = _createKeyframes[1];\n animationNames.push(identifier);\n rules.push(...keyframesRules);\n }\n });\n return [animationNames, rules];\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport normalizeValueWithProperty from './normalizeValueWithProperty';\nimport canUseDOM from '../../../modules/canUseDom';\n/**\n * The browser implements the CSS cascade, where the order of properties is a\n * factor in determining which styles to paint. React Native is different. It\n * gives giving precedence to the more specific style property. For example,\n * the value of `paddingTop` takes precedence over that of `padding`.\n *\n * This module creates mutally exclusive style declarations by expanding all of\n * React Native's supported shortform properties (e.g. `padding`) to their\n * longfrom equivalents.\n */\n\nvar emptyObject = {};\nvar supportsCSS3TextDecoration = !canUseDOM || window.CSS != null && window.CSS.supports != null && (window.CSS.supports('text-decoration-line', 'none') || window.CSS.supports('-webkit-text-decoration-line', 'none'));\nvar MONOSPACE_FONT_STACK = 'monospace,monospace';\nvar SYSTEM_FONT_STACK = '-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Helvetica,Arial,sans-serif';\nvar STYLE_SHORT_FORM_EXPANSIONS = {\n borderColor: ['borderTopColor', 'borderRightColor', 'borderBottomColor', 'borderLeftColor'],\n borderBlockColor: ['borderTopColor', 'borderBottomColor'],\n borderInlineColor: ['borderRightColor', 'borderLeftColor'],\n borderRadius: ['borderTopLeftRadius', 'borderTopRightRadius', 'borderBottomRightRadius', 'borderBottomLeftRadius'],\n borderStyle: ['borderTopStyle', 'borderRightStyle', 'borderBottomStyle', 'borderLeftStyle'],\n borderBlockStyle: ['borderTopStyle', 'borderBottomStyle'],\n borderInlineStyle: ['borderRightStyle', 'borderLeftStyle'],\n borderWidth: ['borderTopWidth', 'borderRightWidth', 'borderBottomWidth', 'borderLeftWidth'],\n borderBlockWidth: ['borderTopWidth', 'borderBottomWidth'],\n borderInlineWidth: ['borderRightWidth', 'borderLeftWidth'],\n insetBlock: ['top', 'bottom'],\n insetInline: ['left', 'right'],\n marginBlock: ['marginTop', 'marginBottom'],\n marginInline: ['marginRight', 'marginLeft'],\n paddingBlock: ['paddingTop', 'paddingBottom'],\n paddingInline: ['paddingRight', 'paddingLeft'],\n overflow: ['overflowX', 'overflowY'],\n overscrollBehavior: ['overscrollBehaviorX', 'overscrollBehaviorY'],\n borderBlockStartColor: ['borderTopColor'],\n borderBlockStartStyle: ['borderTopStyle'],\n borderBlockStartWidth: ['borderTopWidth'],\n borderBlockEndColor: ['borderBottomColor'],\n borderBlockEndStyle: ['borderBottomStyle'],\n borderBlockEndWidth: ['borderBottomWidth'],\n //borderInlineStartColor: ['borderLeftColor'],\n //borderInlineStartStyle: ['borderLeftStyle'],\n //borderInlineStartWidth: ['borderLeftWidth'],\n //borderInlineEndColor: ['borderRightColor'],\n //borderInlineEndStyle: ['borderRightStyle'],\n //borderInlineEndWidth: ['borderRightWidth'],\n borderEndStartRadius: ['borderBottomLeftRadius'],\n borderEndEndRadius: ['borderBottomRightRadius'],\n borderStartStartRadius: ['borderTopLeftRadius'],\n borderStartEndRadius: ['borderTopRightRadius'],\n insetBlockEnd: ['bottom'],\n insetBlockStart: ['top'],\n //insetInlineEnd: ['right'],\n //insetInlineStart: ['left'],\n marginBlockStart: ['marginTop'],\n marginBlockEnd: ['marginBottom'],\n //marginInlineStart: ['marginLeft'],\n //marginInlineEnd: ['marginRight'],\n paddingBlockStart: ['paddingTop'],\n paddingBlockEnd: ['paddingBottom']\n //paddingInlineStart: ['marginLeft'],\n //paddingInlineEnd: ['marginRight'],\n};\n\n/**\n * Reducer\n */\n\nvar createReactDOMStyle = (style, isInline) => {\n if (!style) {\n return emptyObject;\n }\n var resolvedStyle = {};\n var _loop = function _loop() {\n var value = style[prop];\n if (\n // Ignore everything with a null value\n value == null) {\n return \"continue\";\n }\n if (prop === 'backgroundClip') {\n // TODO: remove once this issue is fixed\n // https://github.com/rofrischmann/inline-style-prefixer/issues/159\n if (value === 'text') {\n resolvedStyle.backgroundClip = value;\n resolvedStyle.WebkitBackgroundClip = value;\n }\n } else if (prop === 'flex') {\n if (value === -1) {\n resolvedStyle.flexGrow = 0;\n resolvedStyle.flexShrink = 1;\n resolvedStyle.flexBasis = 'auto';\n } else {\n resolvedStyle.flex = value;\n }\n } else if (prop === 'font') {\n resolvedStyle[prop] = value.replace('System', SYSTEM_FONT_STACK);\n } else if (prop === 'fontFamily') {\n if (value.indexOf('System') > -1) {\n var stack = value.split(/,\\s*/);\n stack[stack.indexOf('System')] = SYSTEM_FONT_STACK;\n resolvedStyle[prop] = stack.join(',');\n } else if (value === 'monospace') {\n resolvedStyle[prop] = MONOSPACE_FONT_STACK;\n } else {\n resolvedStyle[prop] = value;\n }\n } else if (prop === 'textDecorationLine') {\n // use 'text-decoration' for browsers that only support CSS2\n // text-decoration (e.g., IE, Edge)\n if (!supportsCSS3TextDecoration) {\n resolvedStyle.textDecoration = value;\n } else {\n resolvedStyle.textDecorationLine = value;\n }\n } else if (prop === 'writingDirection') {\n resolvedStyle.direction = value;\n } else {\n var _value = normalizeValueWithProperty(style[prop], prop);\n var longFormProperties = STYLE_SHORT_FORM_EXPANSIONS[prop];\n if (isInline && prop === 'inset') {\n if (style.insetInline == null) {\n resolvedStyle.left = _value;\n resolvedStyle.right = _value;\n }\n if (style.insetBlock == null) {\n resolvedStyle.top = _value;\n resolvedStyle.bottom = _value;\n }\n } else if (isInline && prop === 'margin') {\n if (style.marginInline == null) {\n resolvedStyle.marginLeft = _value;\n resolvedStyle.marginRight = _value;\n }\n if (style.marginBlock == null) {\n resolvedStyle.marginTop = _value;\n resolvedStyle.marginBottom = _value;\n }\n } else if (isInline && prop === 'padding') {\n if (style.paddingInline == null) {\n resolvedStyle.paddingLeft = _value;\n resolvedStyle.paddingRight = _value;\n }\n if (style.paddingBlock == null) {\n resolvedStyle.paddingTop = _value;\n resolvedStyle.paddingBottom = _value;\n }\n } else if (longFormProperties) {\n longFormProperties.forEach((longForm, i) => {\n // The value of any longform property in the original styles takes\n // precedence over the shortform's value.\n if (style[longForm] == null) {\n resolvedStyle[longForm] = _value;\n }\n });\n } else {\n resolvedStyle[prop] = _value;\n }\n }\n };\n for (var prop in style) {\n var _ret = _loop();\n if (_ret === \"continue\") continue;\n }\n return resolvedStyle;\n};\nexport default createReactDOMStyle;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport unitlessNumbers from './unitlessNumbers';\nimport normalizeColor from './normalizeColor';\nvar colorProps = {\n backgroundColor: true,\n borderColor: true,\n borderTopColor: true,\n borderRightColor: true,\n borderBottomColor: true,\n borderLeftColor: true,\n color: true,\n shadowColor: true,\n textDecorationColor: true,\n textShadowColor: true\n};\nexport default function normalizeValueWithProperty(value, property) {\n var returnValue = value;\n if ((property == null || !unitlessNumbers[property]) && typeof value === 'number') {\n returnValue = value + \"px\";\n } else if (property != null && colorProps[property]) {\n returnValue = normalizeColor(value);\n }\n return returnValue;\n}","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar unitlessNumbers = {\n animationIterationCount: true,\n aspectRatio: true,\n borderImageOutset: true,\n borderImageSlice: true,\n borderImageWidth: true,\n boxFlex: true,\n boxFlexGroup: true,\n boxOrdinalGroup: true,\n columnCount: true,\n flex: true,\n flexGrow: true,\n flexOrder: true,\n flexPositive: true,\n flexShrink: true,\n flexNegative: true,\n fontWeight: true,\n gridRow: true,\n gridRowEnd: true,\n gridRowGap: true,\n gridRowStart: true,\n gridColumn: true,\n gridColumnEnd: true,\n gridColumnGap: true,\n gridColumnStart: true,\n lineClamp: true,\n opacity: true,\n order: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n // SVG-related\n fillOpacity: true,\n floodOpacity: true,\n stopOpacity: true,\n strokeDasharray: true,\n strokeDashoffset: true,\n strokeMiterlimit: true,\n strokeOpacity: true,\n strokeWidth: true,\n // transform types\n scale: true,\n scaleX: true,\n scaleY: true,\n scaleZ: true,\n // RN properties\n shadowOpacity: true\n};\n\n/**\n * Support style names that may come passed in prefixed by adding permutations\n * of vendor prefixes.\n */\nvar prefixes = ['ms', 'Moz', 'O', 'Webkit'];\nvar prefixKey = (prefix, key) => {\n return prefix + key.charAt(0).toUpperCase() + key.substring(1);\n};\nObject.keys(unitlessNumbers).forEach(prop => {\n prefixes.forEach(prefix => {\n unitlessNumbers[prefixKey(prefix, prop)] = unitlessNumbers[prop];\n });\n});\nexport default unitlessNumbers;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport isWebColor from '../../../modules/isWebColor';\nimport processColor from '../../../exports/processColor';\nvar normalizeColor = function normalizeColor(color, opacity) {\n if (opacity === void 0) {\n opacity = 1;\n }\n if (color == null) return;\n if (typeof color === 'string' && isWebColor(color)) {\n return color;\n }\n var colorInt = processColor(color);\n if (colorInt != null) {\n var r = colorInt >> 16 & 255;\n var g = colorInt >> 8 & 255;\n var b = colorInt & 255;\n var a = (colorInt >> 24 & 255) / 255;\n var alpha = (a * opacity).toFixed(2);\n return \"rgba(\" + r + \",\" + g + \",\" + b + \",\" + alpha + \")\";\n }\n};\nexport default normalizeColor;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar isWebColor = color => color === 'currentcolor' || color === 'currentColor' || color === 'inherit' || color.indexOf('var(') === 0;\nexport default isWebColor;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport normalizeColor from '@react-native/normalize-colors';\nvar processColor = color => {\n if (color === undefined || color === null) {\n return color;\n }\n\n // convert number and hex\n var int32Color = normalizeColor(color);\n if (int32Color === undefined || int32Color === null) {\n return undefined;\n }\n int32Color = (int32Color << 24 | int32Color >>> 8) >>> 0;\n return int32Color;\n};\nexport default processColor;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * @noflow\n */\n\n/* eslint no-bitwise: 0 */\n\n'use strict';\n\nfunction normalizeColor(color) {\n if (typeof color === 'number') {\n if (color >>> 0 === color && color >= 0 && color <= 0xffffffff) {\n return color;\n }\n return null;\n }\n\n if (typeof color !== 'string') {\n return null;\n }\n\n const matchers = getMatchers();\n let match;\n\n // Ordered based on occurrences on Facebook codebase\n if ((match = matchers.hex6.exec(color))) {\n return parseInt(match[1] + 'ff', 16) >>> 0;\n }\n\n const colorFromKeyword = normalizeKeyword(color);\n if (colorFromKeyword != null) {\n return colorFromKeyword;\n }\n\n if ((match = matchers.rgb.exec(color))) {\n return (\n ((parse255(match[1]) << 24) | // r\n (parse255(match[2]) << 16) | // g\n (parse255(match[3]) << 8) | // b\n 0x000000ff) >>> // a\n 0\n );\n }\n\n if ((match = matchers.rgba.exec(color))) {\n // rgba(R G B / A) notation\n if (match[6] !== undefined) {\n return (\n ((parse255(match[6]) << 24) | // r\n (parse255(match[7]) << 16) | // g\n (parse255(match[8]) << 8) | // b\n parse1(match[9])) >>> // a\n 0\n );\n }\n\n // rgba(R, G, B, A) notation\n return (\n ((parse255(match[2]) << 24) | // r\n (parse255(match[3]) << 16) | // g\n (parse255(match[4]) << 8) | // b\n parse1(match[5])) >>> // a\n 0\n );\n }\n\n if ((match = matchers.hex3.exec(color))) {\n return (\n parseInt(\n match[1] +\n match[1] + // r\n match[2] +\n match[2] + // g\n match[3] +\n match[3] + // b\n 'ff', // a\n 16,\n ) >>> 0\n );\n }\n\n // https://drafts.csswg.org/css-color-4/#hex-notation\n if ((match = matchers.hex8.exec(color))) {\n return parseInt(match[1], 16) >>> 0;\n }\n\n if ((match = matchers.hex4.exec(color))) {\n return (\n parseInt(\n match[1] +\n match[1] + // r\n match[2] +\n match[2] + // g\n match[3] +\n match[3] + // b\n match[4] +\n match[4], // a\n 16,\n ) >>> 0\n );\n }\n\n if ((match = matchers.hsl.exec(color))) {\n return (\n (hslToRgb(\n parse360(match[1]), // h\n parsePercentage(match[2]), // s\n parsePercentage(match[3]), // l\n ) |\n 0x000000ff) >>> // a\n 0\n );\n }\n\n if ((match = matchers.hsla.exec(color))) {\n // hsla(H S L / A) notation\n if (match[6] !== undefined) {\n return (\n (hslToRgb(\n parse360(match[6]), // h\n parsePercentage(match[7]), // s\n parsePercentage(match[8]), // l\n ) |\n parse1(match[9])) >>> // a\n 0\n );\n }\n\n // hsla(H, S, L, A) notation\n return (\n (hslToRgb(\n parse360(match[2]), // h\n parsePercentage(match[3]), // s\n parsePercentage(match[4]), // l\n ) |\n parse1(match[5])) >>> // a\n 0\n );\n }\n\n if ((match = matchers.hwb.exec(color))) {\n return (\n (hwbToRgb(\n parse360(match[1]), // h\n parsePercentage(match[2]), // w\n parsePercentage(match[3]), // b\n ) |\n 0x000000ff) >>> // a\n 0\n );\n }\n\n return null;\n}\n\nfunction hue2rgb(p, q, t) {\n if (t < 0) {\n t += 1;\n }\n if (t > 1) {\n t -= 1;\n }\n if (t < 1 / 6) {\n return p + (q - p) * 6 * t;\n }\n if (t < 1 / 2) {\n return q;\n }\n if (t < 2 / 3) {\n return p + (q - p) * (2 / 3 - t) * 6;\n }\n return p;\n}\n\nfunction hslToRgb(h, s, l) {\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n const r = hue2rgb(p, q, h + 1 / 3);\n const g = hue2rgb(p, q, h);\n const b = hue2rgb(p, q, h - 1 / 3);\n\n return (\n (Math.round(r * 255) << 24) |\n (Math.round(g * 255) << 16) |\n (Math.round(b * 255) << 8)\n );\n}\n\nfunction hwbToRgb(h, w, b) {\n if (w + b >= 1) {\n const gray = Math.round((w * 255) / (w + b));\n\n return (gray << 24) | (gray << 16) | (gray << 8);\n }\n\n const red = hue2rgb(0, 1, h + 1 / 3) * (1 - w - b) + w;\n const green = hue2rgb(0, 1, h) * (1 - w - b) + w;\n const blue = hue2rgb(0, 1, h - 1 / 3) * (1 - w - b) + w;\n\n return (\n (Math.round(red * 255) << 24) |\n (Math.round(green * 255) << 16) |\n (Math.round(blue * 255) << 8)\n );\n}\n\nconst NUMBER = '[-+]?\\\\d*\\\\.?\\\\d+';\nconst PERCENTAGE = NUMBER + '%';\n\nfunction call(...args) {\n return '\\\\(\\\\s*(' + args.join(')\\\\s*,?\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nfunction callWithSlashSeparator(...args) {\n return (\n '\\\\(\\\\s*(' +\n args.slice(0, args.length - 1).join(')\\\\s*,?\\\\s*(') +\n ')\\\\s*/\\\\s*(' +\n args[args.length - 1] +\n ')\\\\s*\\\\)'\n );\n}\n\nfunction commaSeparatedCall(...args) {\n return '\\\\(\\\\s*(' + args.join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nlet cachedMatchers;\n\nfunction getMatchers() {\n if (cachedMatchers === undefined) {\n cachedMatchers = {\n rgb: new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER)),\n rgba: new RegExp(\n 'rgba(' +\n commaSeparatedCall(NUMBER, NUMBER, NUMBER, NUMBER) +\n '|' +\n callWithSlashSeparator(NUMBER, NUMBER, NUMBER, NUMBER) +\n ')',\n ),\n hsl: new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE)),\n hsla: new RegExp(\n 'hsla(' +\n commaSeparatedCall(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER) +\n '|' +\n callWithSlashSeparator(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER) +\n ')',\n ),\n hwb: new RegExp('hwb' + call(NUMBER, PERCENTAGE, PERCENTAGE)),\n hex3: /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex4: /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^#([0-9a-fA-F]{6})$/,\n hex8: /^#([0-9a-fA-F]{8})$/,\n };\n }\n return cachedMatchers;\n}\n\nfunction parse255(str) {\n const int = parseInt(str, 10);\n if (int < 0) {\n return 0;\n }\n if (int > 255) {\n return 255;\n }\n return int;\n}\n\nfunction parse360(str) {\n const int = parseFloat(str);\n return (((int % 360) + 360) % 360) / 360;\n}\n\nfunction parse1(str) {\n const num = parseFloat(str);\n if (num < 0) {\n return 0;\n }\n if (num > 1) {\n return 255;\n }\n return Math.round(num * 255);\n}\n\nfunction parsePercentage(str) {\n // parseFloat conveniently ignores the final %\n const int = parseFloat(str);\n if (int < 0) {\n return 0;\n }\n if (int > 100) {\n return 1;\n }\n return int / 100;\n}\n\nfunction normalizeKeyword(name) {\n // prettier-ignore\n switch (name) {\n case 'transparent': return 0x00000000;\n // http://www.w3.org/TR/css3-color/#svg-color\n case 'aliceblue': return 0xf0f8ffff;\n case 'antiquewhite': return 0xfaebd7ff;\n case 'aqua': return 0x00ffffff;\n case 'aquamarine': return 0x7fffd4ff;\n case 'azure': return 0xf0ffffff;\n case 'beige': return 0xf5f5dcff;\n case 'bisque': return 0xffe4c4ff;\n case 'black': return 0x000000ff;\n case 'blanchedalmond': return 0xffebcdff;\n case 'blue': return 0x0000ffff;\n case 'blueviolet': return 0x8a2be2ff;\n case 'brown': return 0xa52a2aff;\n case 'burlywood': return 0xdeb887ff;\n case 'burntsienna': return 0xea7e5dff;\n case 'cadetblue': return 0x5f9ea0ff;\n case 'chartreuse': return 0x7fff00ff;\n case 'chocolate': return 0xd2691eff;\n case 'coral': return 0xff7f50ff;\n case 'cornflowerblue': return 0x6495edff;\n case 'cornsilk': return 0xfff8dcff;\n case 'crimson': return 0xdc143cff;\n case 'cyan': return 0x00ffffff;\n case 'darkblue': return 0x00008bff;\n case 'darkcyan': return 0x008b8bff;\n case 'darkgoldenrod': return 0xb8860bff;\n case 'darkgray': return 0xa9a9a9ff;\n case 'darkgreen': return 0x006400ff;\n case 'darkgrey': return 0xa9a9a9ff;\n case 'darkkhaki': return 0xbdb76bff;\n case 'darkmagenta': return 0x8b008bff;\n case 'darkolivegreen': return 0x556b2fff;\n case 'darkorange': return 0xff8c00ff;\n case 'darkorchid': return 0x9932ccff;\n case 'darkred': return 0x8b0000ff;\n case 'darksalmon': return 0xe9967aff;\n case 'darkseagreen': return 0x8fbc8fff;\n case 'darkslateblue': return 0x483d8bff;\n case 'darkslategray': return 0x2f4f4fff;\n case 'darkslategrey': return 0x2f4f4fff;\n case 'darkturquoise': return 0x00ced1ff;\n case 'darkviolet': return 0x9400d3ff;\n case 'deeppink': return 0xff1493ff;\n case 'deepskyblue': return 0x00bfffff;\n case 'dimgray': return 0x696969ff;\n case 'dimgrey': return 0x696969ff;\n case 'dodgerblue': return 0x1e90ffff;\n case 'firebrick': return 0xb22222ff;\n case 'floralwhite': return 0xfffaf0ff;\n case 'forestgreen': return 0x228b22ff;\n case 'fuchsia': return 0xff00ffff;\n case 'gainsboro': return 0xdcdcdcff;\n case 'ghostwhite': return 0xf8f8ffff;\n case 'gold': return 0xffd700ff;\n case 'goldenrod': return 0xdaa520ff;\n case 'gray': return 0x808080ff;\n case 'green': return 0x008000ff;\n case 'greenyellow': return 0xadff2fff;\n case 'grey': return 0x808080ff;\n case 'honeydew': return 0xf0fff0ff;\n case 'hotpink': return 0xff69b4ff;\n case 'indianred': return 0xcd5c5cff;\n case 'indigo': return 0x4b0082ff;\n case 'ivory': return 0xfffff0ff;\n case 'khaki': return 0xf0e68cff;\n case 'lavender': return 0xe6e6faff;\n case 'lavenderblush': return 0xfff0f5ff;\n case 'lawngreen': return 0x7cfc00ff;\n case 'lemonchiffon': return 0xfffacdff;\n case 'lightblue': return 0xadd8e6ff;\n case 'lightcoral': return 0xf08080ff;\n case 'lightcyan': return 0xe0ffffff;\n case 'lightgoldenrodyellow': return 0xfafad2ff;\n case 'lightgray': return 0xd3d3d3ff;\n case 'lightgreen': return 0x90ee90ff;\n case 'lightgrey': return 0xd3d3d3ff;\n case 'lightpink': return 0xffb6c1ff;\n case 'lightsalmon': return 0xffa07aff;\n case 'lightseagreen': return 0x20b2aaff;\n case 'lightskyblue': return 0x87cefaff;\n case 'lightslategray': return 0x778899ff;\n case 'lightslategrey': return 0x778899ff;\n case 'lightsteelblue': return 0xb0c4deff;\n case 'lightyellow': return 0xffffe0ff;\n case 'lime': return 0x00ff00ff;\n case 'limegreen': return 0x32cd32ff;\n case 'linen': return 0xfaf0e6ff;\n case 'magenta': return 0xff00ffff;\n case 'maroon': return 0x800000ff;\n case 'mediumaquamarine': return 0x66cdaaff;\n case 'mediumblue': return 0x0000cdff;\n case 'mediumorchid': return 0xba55d3ff;\n case 'mediumpurple': return 0x9370dbff;\n case 'mediumseagreen': return 0x3cb371ff;\n case 'mediumslateblue': return 0x7b68eeff;\n case 'mediumspringgreen': return 0x00fa9aff;\n case 'mediumturquoise': return 0x48d1ccff;\n case 'mediumvioletred': return 0xc71585ff;\n case 'midnightblue': return 0x191970ff;\n case 'mintcream': return 0xf5fffaff;\n case 'mistyrose': return 0xffe4e1ff;\n case 'moccasin': return 0xffe4b5ff;\n case 'navajowhite': return 0xffdeadff;\n case 'navy': return 0x000080ff;\n case 'oldlace': return 0xfdf5e6ff;\n case 'olive': return 0x808000ff;\n case 'olivedrab': return 0x6b8e23ff;\n case 'orange': return 0xffa500ff;\n case 'orangered': return 0xff4500ff;\n case 'orchid': return 0xda70d6ff;\n case 'palegoldenrod': return 0xeee8aaff;\n case 'palegreen': return 0x98fb98ff;\n case 'paleturquoise': return 0xafeeeeff;\n case 'palevioletred': return 0xdb7093ff;\n case 'papayawhip': return 0xffefd5ff;\n case 'peachpuff': return 0xffdab9ff;\n case 'peru': return 0xcd853fff;\n case 'pink': return 0xffc0cbff;\n case 'plum': return 0xdda0ddff;\n case 'powderblue': return 0xb0e0e6ff;\n case 'purple': return 0x800080ff;\n case 'rebeccapurple': return 0x663399ff;\n case 'red': return 0xff0000ff;\n case 'rosybrown': return 0xbc8f8fff;\n case 'royalblue': return 0x4169e1ff;\n case 'saddlebrown': return 0x8b4513ff;\n case 'salmon': return 0xfa8072ff;\n case 'sandybrown': return 0xf4a460ff;\n case 'seagreen': return 0x2e8b57ff;\n case 'seashell': return 0xfff5eeff;\n case 'sienna': return 0xa0522dff;\n case 'silver': return 0xc0c0c0ff;\n case 'skyblue': return 0x87ceebff;\n case 'slateblue': return 0x6a5acdff;\n case 'slategray': return 0x708090ff;\n case 'slategrey': return 0x708090ff;\n case 'snow': return 0xfffafaff;\n case 'springgreen': return 0x00ff7fff;\n case 'steelblue': return 0x4682b4ff;\n case 'tan': return 0xd2b48cff;\n case 'teal': return 0x008080ff;\n case 'thistle': return 0xd8bfd8ff;\n case 'tomato': return 0xff6347ff;\n case 'turquoise': return 0x40e0d0ff;\n case 'violet': return 0xee82eeff;\n case 'wheat': return 0xf5deb3ff;\n case 'white': return 0xffffffff;\n case 'whitesmoke': return 0xf5f5f5ff;\n case 'yellow': return 0xffff00ff;\n case 'yellowgreen': return 0x9acd32ff;\n }\n return null;\n}\n\nmodule.exports = normalizeColor;\n","/* eslint-disable */\n\n/**\n * JS Implementation of MurmurHash2\n *\n * @author Gary Court\n * @see http://github.com/garycourt/murmurhash-js\n * @author Austin Appleby\n * @see http://sites.google.com/site/murmurhash/\n *\n * @param {string} str ASCII only\n * @param {number} seed Positive integer only\n * @return {number} 32-bit positive integer hash\n *\n * \n */\n\nfunction murmurhash2_32_gc(str, seed) {\n var l = str.length,\n h = seed ^ l,\n i = 0,\n k;\n while (l >= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k = (k & 0xffff) * 0x5bd1e995 + (((k >>> 16) * 0x5bd1e995 & 0xffff) << 16);\n k ^= k >>> 24;\n k = (k & 0xffff) * 0x5bd1e995 + (((k >>> 16) * 0x5bd1e995 & 0xffff) << 16);\n h = (h & 0xffff) * 0x5bd1e995 + (((h >>> 16) * 0x5bd1e995 & 0xffff) << 16) ^ k;\n l -= 4;\n ++i;\n }\n switch (l) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h = (h & 0xffff) * 0x5bd1e995 + (((h >>> 16) * 0x5bd1e995 & 0xffff) << 16);\n }\n h ^= h >>> 13;\n h = (h & 0xffff) * 0x5bd1e995 + (((h >>> 16) * 0x5bd1e995 & 0xffff) << 16);\n h ^= h >>> 15;\n return h >>> 0;\n}\nvar hash = str => murmurhash2_32_gc(str, 1).toString(36);\nexport default hash;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar uppercasePattern = /[A-Z]/g;\nvar msPattern = /^ms-/;\nvar cache = {};\nfunction toHyphenLower(match) {\n return '-' + match.toLowerCase();\n}\nfunction hyphenateStyleName(name) {\n if (name in cache) {\n return cache[name];\n }\n var hName = name.replace(uppercasePattern, toHyphenLower);\n return cache[name] = msPattern.test(hName) ? '-' + hName : hName;\n}\nexport default hyphenateStyleName;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport createPrefixer from 'inline-style-prefixer/lib/createPrefixer';\nimport staticData from './static';\nvar prefixAll = createPrefixer(staticData);\nexport default prefixAll;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = createPrefixer;\n\nvar _prefixProperty = require('./utils/prefixProperty');\n\nvar _prefixProperty2 = _interopRequireDefault(_prefixProperty);\n\nvar _prefixValue = require('./utils/prefixValue');\n\nvar _prefixValue2 = _interopRequireDefault(_prefixValue);\n\nvar _addNewValuesOnly = require('./utils/addNewValuesOnly');\n\nvar _addNewValuesOnly2 = _interopRequireDefault(_addNewValuesOnly);\n\nvar _isObject = require('./utils/isObject');\n\nvar _isObject2 = _interopRequireDefault(_isObject);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction createPrefixer(_ref) {\n var prefixMap = _ref.prefixMap,\n plugins = _ref.plugins;\n\n return function prefix(style) {\n for (var property in style) {\n var value = style[property];\n\n // handle nested objects\n if ((0, _isObject2.default)(value)) {\n style[property] = prefix(value);\n // handle array values\n } else if (Array.isArray(value)) {\n var combinedValue = [];\n\n for (var i = 0, len = value.length; i < len; ++i) {\n var processedValue = (0, _prefixValue2.default)(plugins, property, value[i], style, prefixMap);\n\n (0, _addNewValuesOnly2.default)(combinedValue, processedValue || value[i]);\n }\n\n // only modify the value if it was touched\n // by any plugin to prevent unnecessary mutations\n if (combinedValue.length > 0) {\n style[property] = combinedValue;\n }\n } else {\n var _processedValue = (0, _prefixValue2.default)(plugins, property, value, style, prefixMap);\n\n // only modify the value if it was touched\n // by any plugin to prevent unnecessary mutations\n if (_processedValue) {\n style[property] = _processedValue;\n }\n\n style = (0, _prefixProperty2.default)(prefixMap, property, style);\n }\n }\n\n return style;\n };\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = prefixProperty;\n\nvar _capitalizeString = require('./capitalizeString');\n\nvar _capitalizeString2 = _interopRequireDefault(_capitalizeString);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction prefixProperty(prefixProperties, property, style) {\n var requiredPrefixes = prefixProperties[property];\n\n if (requiredPrefixes && style.hasOwnProperty(property)) {\n var capitalizedProperty = (0, _capitalizeString2.default)(property);\n\n for (var i = 0; i < requiredPrefixes.length; ++i) {\n var prefixedProperty = requiredPrefixes[i] + capitalizedProperty;\n\n if (!style[prefixedProperty]) {\n style[prefixedProperty] = style[property];\n }\n }\n }\n\n return style;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = capitalizeString;\nfunction capitalizeString(str) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = prefixValue;\nfunction prefixValue(plugins, property, value, style, metaData) {\n for (var i = 0, len = plugins.length; i < len; ++i) {\n var processedValue = plugins[i](property, value, style, metaData);\n\n // we can stop processing if a value is returned\n // as all plugin criteria are unique\n if (processedValue) {\n return processedValue;\n }\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = addNewValuesOnly;\nfunction addIfNew(list, value) {\n if (list.indexOf(value) === -1) {\n list.push(value);\n }\n}\n\nfunction addNewValuesOnly(list, values) {\n if (Array.isArray(values)) {\n for (var i = 0, len = values.length; i < len; ++i) {\n addIfNew(list, values[i]);\n }\n } else {\n addIfNew(list, values);\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = isObject;\nfunction isObject(value) {\n return value instanceof Object && !Array.isArray(value);\n}","import backgroundClip from 'inline-style-prefixer/lib/plugins/backgroundClip';\nimport crossFade from 'inline-style-prefixer/lib/plugins/crossFade';\nimport cursor from 'inline-style-prefixer/lib/plugins/cursor';\nimport filter from 'inline-style-prefixer/lib/plugins/filter';\nimport imageSet from 'inline-style-prefixer/lib/plugins/imageSet';\nimport logical from 'inline-style-prefixer/lib/plugins/logical';\nimport position from 'inline-style-prefixer/lib/plugins/position';\nimport sizing from 'inline-style-prefixer/lib/plugins/sizing';\nimport transition from 'inline-style-prefixer/lib/plugins/transition';\nvar w = ['Webkit'];\nvar m = ['Moz'];\nvar wm = ['Webkit', 'Moz'];\nvar wms = ['Webkit', 'ms'];\nvar wmms = ['Webkit', 'Moz', 'ms'];\nexport default {\n plugins: [backgroundClip, crossFade, cursor, filter, imageSet, logical, position, sizing, transition],\n prefixMap: {\n appearance: wmms,\n userSelect: wm,\n textEmphasisPosition: wms,\n textEmphasis: wms,\n textEmphasisStyle: wms,\n textEmphasisColor: wms,\n boxDecorationBreak: wms,\n clipPath: w,\n maskImage: wms,\n maskMode: wms,\n maskRepeat: wms,\n maskPosition: wms,\n maskClip: wms,\n maskOrigin: wms,\n maskSize: wms,\n maskComposite: wms,\n mask: wms,\n maskBorderSource: wms,\n maskBorderMode: wms,\n maskBorderSlice: wms,\n maskBorderWidth: wms,\n maskBorderOutset: wms,\n maskBorderRepeat: wms,\n maskBorder: wms,\n maskType: wms,\n textDecorationStyle: w,\n textDecorationSkip: w,\n textDecorationLine: w,\n textDecorationColor: w,\n filter: w,\n breakAfter: w,\n breakBefore: w,\n breakInside: w,\n columnCount: w,\n columnFill: w,\n columnGap: w,\n columnRule: w,\n columnRuleColor: w,\n columnRuleStyle: w,\n columnRuleWidth: w,\n columns: w,\n columnSpan: w,\n columnWidth: w,\n backdropFilter: w,\n hyphens: w,\n flowInto: w,\n flowFrom: w,\n regionFragment: w,\n textOrientation: w,\n tabSize: m,\n fontKerning: w,\n textSizeAdjust: w\n }\n};","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = backgroundClip;\nfunction backgroundClip() {\n return null;\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = crossFade;\n\nvar _cssInJsUtils = require('css-in-js-utils');\n\nvar CROSS_FADE_REGEX = /cross-fade\\(/g;\n// http://caniuse.com/#search=cross-fade\nvar prefixes = ['-webkit-', ''];\n\nfunction crossFade(property, value) {\n if (typeof value === 'string' && !(0, _cssInJsUtils.isPrefixedValue)(value) && value.indexOf('cross-fade(') !== -1) {\n return prefixes.map(function (prefix) {\n return value.replace(CROSS_FADE_REGEX, prefix + 'cross-fade(');\n });\n }\n}","import assignStyle from './assignStyle';\nimport camelCaseProperty from './camelCaseProperty';\nimport cssifyDeclaration from './cssifyDeclaration';\nimport cssifyObject from './cssifyObject';\nimport hyphenateProperty from './hyphenateProperty';\nimport isPrefixedProperty from './isPrefixedProperty';\nimport isPrefixedValue from './isPrefixedValue';\nimport isUnitlessProperty from './isUnitlessProperty';\nimport normalizeProperty from './normalizeProperty';\nimport resolveArrayValue from './resolveArrayValue';\nimport unprefixProperty from './unprefixProperty';\nimport unprefixValue from './unprefixValue';\nexport { assignStyle, camelCaseProperty, cssifyDeclaration, cssifyObject, hyphenateProperty, isPrefixedProperty, isPrefixedValue, isUnitlessProperty, normalizeProperty, resolveArrayValue, unprefixProperty, unprefixValue };","function _typeof(obj) { \"@babel/helpers - typeof\"; 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 _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(n); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction filterUniqueArray(arr) {\n return arr.filter(function (val, index) {\n return arr.lastIndexOf(val) === index;\n });\n}\n\nexport default function assignStyle(base) {\n for (var i = 0, len = arguments.length <= 1 ? 0 : arguments.length - 1; i < len; ++i) {\n var style = i + 1 < 1 || arguments.length <= i + 1 ? undefined : arguments[i + 1];\n\n for (var property in style) {\n var value = style[property];\n var baseValue = base[property];\n\n if (baseValue && value) {\n if (Array.isArray(baseValue)) {\n base[property] = filterUniqueArray(baseValue.concat(value));\n continue;\n }\n\n if (Array.isArray(value)) {\n base[property] = filterUniqueArray([baseValue].concat(_toConsumableArray(value)));\n continue;\n }\n\n if (_typeof(value) === 'object') {\n base[property] = assignStyle({}, baseValue, value);\n continue;\n }\n }\n\n base[property] = value;\n }\n }\n\n return base;\n}","var DASH = /-([a-z])/g;\nvar MS = /^Ms/g;\nvar cache = {};\n\nfunction toUpper(match) {\n return match[1].toUpperCase();\n}\n\nexport default function camelCaseProperty(property) {\n if (cache.hasOwnProperty(property)) {\n return cache[property];\n }\n\n var camelProp = property.replace(DASH, toUpper).replace(MS, 'ms');\n cache[property] = camelProp;\n return camelProp;\n}","import hyphenateProperty from './hyphenateProperty';\nexport default function cssifyDeclaration(property, value) {\n return hyphenateProperty(property) + ':' + value;\n}","import hyphenateStyleName from 'hyphenate-style-name';\nexport default function hyphenateProperty(property) {\n return hyphenateStyleName(property);\n}","/* eslint-disable no-var, prefer-template */\nvar uppercasePattern = /[A-Z]/g\nvar msPattern = /^ms-/\nvar cache = {}\n\nfunction toHyphenLower(match) {\n return '-' + match.toLowerCase()\n}\n\nfunction hyphenateStyleName(name) {\n if (cache.hasOwnProperty(name)) {\n return cache[name]\n }\n\n var hName = name.replace(uppercasePattern, toHyphenLower)\n return (cache[name] = msPattern.test(hName) ? '-' + hName : hName)\n}\n\nexport default hyphenateStyleName\n","import cssifyDeclaration from './cssifyDeclaration';\nexport default function cssifyObject(style) {\n var css = '';\n\n for (var property in style) {\n var value = style[property];\n\n if (typeof value !== 'string' && typeof value !== 'number') {\n continue;\n } // prevents the semicolon after\n // the last rule declaration\n\n\n if (css) {\n css += ';';\n }\n\n css += cssifyDeclaration(property, value);\n }\n\n return css;\n}","var RE = /^(Webkit|Moz|O|ms)/;\nexport default function isPrefixedProperty(property) {\n return RE.test(property);\n}","var RE = /-webkit-|-moz-|-ms-/;\nexport default function isPrefixedValue(value) {\n return typeof value === 'string' && RE.test(value);\n}","import hyphenateProperty from './hyphenateProperty';\nvar unitlessProperties = {\n borderImageOutset: true,\n borderImageSlice: true,\n borderImageWidth: true,\n fontWeight: true,\n lineHeight: true,\n opacity: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n // SVG-related properties\n fillOpacity: true,\n floodOpacity: true,\n stopOpacity: true,\n strokeDasharray: true,\n strokeDashoffset: true,\n strokeMiterlimit: true,\n strokeOpacity: true,\n strokeWidth: true\n};\nvar prefixedUnitlessProperties = ['animationIterationCount', 'boxFlex', 'boxFlexGroup', 'boxOrdinalGroup', 'columnCount', 'flex', 'flexGrow', 'flexPositive', 'flexShrink', 'flexNegative', 'flexOrder', 'gridColumn', 'gridColumnEnd', 'gridColumnStart', 'gridRow', 'gridRowEnd', 'gridRowStart', 'lineClamp', 'order'];\nvar prefixes = ['Webkit', 'ms', 'Moz', 'O'];\n\nfunction getPrefixedProperty(prefix, property) {\n return prefix + property.charAt(0).toUpperCase() + property.slice(1);\n} // add all prefixed properties to the unitless properties\n\n\nfor (var i = 0, len = prefixedUnitlessProperties.length; i < len; ++i) {\n var property = prefixedUnitlessProperties[i];\n unitlessProperties[property] = true;\n\n for (var j = 0, jLen = prefixes.length; j < jLen; ++j) {\n unitlessProperties[getPrefixedProperty(prefixes[j], property)] = true;\n }\n} // add all hypenated properties as well\n\n\nfor (var _property in unitlessProperties) {\n unitlessProperties[hyphenateProperty(_property)] = true;\n}\n\nexport default function isUnitlessProperty(property) {\n return unitlessProperties.hasOwnProperty(property);\n}","import camelCaseProperty from './camelCaseProperty';\nimport unprefixProperty from './unprefixProperty';\nexport default function normalizeProperty(property) {\n return unprefixProperty(camelCaseProperty(property));\n}","var RE = /^(ms|Webkit|Moz|O)/;\nexport default function unprefixProperty(property) {\n var propertyWithoutPrefix = property.replace(RE, '');\n return propertyWithoutPrefix.charAt(0).toLowerCase() + propertyWithoutPrefix.slice(1);\n}","import hyphenateProperty from './hyphenateProperty';\nexport default function resolveArrayValue(property, value) {\n return value.join(';' + hyphenateProperty(property) + ':');\n}","var RE = /(-ms-|-webkit-|-moz-|-o-)/g;\nexport default function unprefixValue(value) {\n if (typeof value === 'string') {\n return value.replace(RE, '');\n }\n\n return value;\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = cursor;\nvar prefixes = ['-webkit-', '-moz-', ''];\n\nvar values = {\n 'zoom-in': true,\n 'zoom-out': true,\n grab: true,\n grabbing: true\n};\n\nfunction cursor(property, value) {\n if (property === 'cursor' && values.hasOwnProperty(value)) {\n return prefixes.map(function (prefix) {\n return prefix + value;\n });\n }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = filter;\n\nvar _cssInJsUtils = require('css-in-js-utils');\n\nvar FILTER_REGEX = /filter\\(/g;\n// http://caniuse.com/#feat=css-filter-function\nvar prefixes = ['-webkit-', ''];\n\nfunction filter(property, value) {\n if (typeof value === 'string' && !(0, _cssInJsUtils.isPrefixedValue)(value) && value.indexOf('filter(') !== -1) {\n return prefixes.map(function (prefix) {\n return value.replace(FILTER_REGEX, prefix + 'filter(');\n });\n }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = imageSet;\n\nvar _isPrefixedValue = require('css-in-js-utils/lib/isPrefixedValue');\n\nvar _isPrefixedValue2 = _interopRequireDefault(_isPrefixedValue);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n// http://caniuse.com/#feat=css-image-set\nvar prefixes = ['-webkit-', ''];\n\nfunction imageSet(property, value) {\n if (typeof value === 'string' && !(0, _isPrefixedValue2.default)(value) && value.indexOf('image-set(') > -1) {\n return prefixes.map(function (prefix) {\n return value.replace(/image-set\\(/g, prefix + 'image-set(');\n });\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = isPrefixedValue;\nvar RE = /-webkit-|-moz-|-ms-/;\n\nfunction isPrefixedValue(value) {\n return typeof value === 'string' && RE.test(value);\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = logical;\nvar alternativeProps = {\n marginBlockStart: ['WebkitMarginBefore'],\n marginBlockEnd: ['WebkitMarginAfter'],\n marginInlineStart: ['WebkitMarginStart', 'MozMarginStart'],\n marginInlineEnd: ['WebkitMarginEnd', 'MozMarginEnd'],\n paddingBlockStart: ['WebkitPaddingBefore'],\n paddingBlockEnd: ['WebkitPaddingAfter'],\n paddingInlineStart: ['WebkitPaddingStart', 'MozPaddingStart'],\n paddingInlineEnd: ['WebkitPaddingEnd', 'MozPaddingEnd'],\n borderBlockStart: ['WebkitBorderBefore'],\n borderBlockStartColor: ['WebkitBorderBeforeColor'],\n borderBlockStartStyle: ['WebkitBorderBeforeStyle'],\n borderBlockStartWidth: ['WebkitBorderBeforeWidth'],\n borderBlockEnd: ['WebkitBorderAfter'],\n borderBlockEndColor: ['WebkitBorderAfterColor'],\n borderBlockEndStyle: ['WebkitBorderAfterStyle'],\n borderBlockEndWidth: ['WebkitBorderAfterWidth'],\n borderInlineStart: ['WebkitBorderStart', 'MozBorderStart'],\n borderInlineStartColor: ['WebkitBorderStartColor', 'MozBorderStartColor'],\n borderInlineStartStyle: ['WebkitBorderStartStyle', 'MozBorderStartStyle'],\n borderInlineStartWidth: ['WebkitBorderStartWidth', 'MozBorderStartWidth'],\n borderInlineEnd: ['WebkitBorderEnd', 'MozBorderEnd'],\n borderInlineEndColor: ['WebkitBorderEndColor', 'MozBorderEndColor'],\n borderInlineEndStyle: ['WebkitBorderEndStyle', 'MozBorderEndStyle'],\n borderInlineEndWidth: ['WebkitBorderEndWidth', 'MozBorderEndWidth']\n};\n\nfunction logical(property, value, style) {\n if (Object.prototype.hasOwnProperty.call(alternativeProps, property)) {\n var alternativePropList = alternativeProps[property];\n for (var i = 0, len = alternativePropList.length; i < len; ++i) {\n style[alternativePropList[i]] = value;\n }\n }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = position;\nfunction position(property, value) {\n if (property === 'position' && value === 'sticky') {\n return ['-webkit-sticky', 'sticky'];\n }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = sizing;\nvar prefixes = ['-webkit-', '-moz-', ''];\n\nvar properties = {\n maxHeight: true,\n maxWidth: true,\n width: true,\n height: true,\n columnWidth: true,\n minWidth: true,\n minHeight: true\n};\nvar values = {\n 'min-content': true,\n 'max-content': true,\n 'fill-available': true,\n 'fit-content': true,\n 'contain-floats': true\n};\n\nfunction sizing(property, value) {\n if (properties.hasOwnProperty(property) && values.hasOwnProperty(value)) {\n return prefixes.map(function (prefix) {\n return prefix + value;\n });\n }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.default = transition;\n\nvar _hyphenateProperty = require('css-in-js-utils/lib/hyphenateProperty');\n\nvar _hyphenateProperty2 = _interopRequireDefault(_hyphenateProperty);\n\nvar _isPrefixedValue = require('css-in-js-utils/lib/isPrefixedValue');\n\nvar _isPrefixedValue2 = _interopRequireDefault(_isPrefixedValue);\n\nvar _capitalizeString = require('../utils/capitalizeString');\n\nvar _capitalizeString2 = _interopRequireDefault(_capitalizeString);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar properties = {\n transition: true,\n transitionProperty: true,\n WebkitTransition: true,\n WebkitTransitionProperty: true,\n MozTransition: true,\n MozTransitionProperty: true\n};\n\nvar prefixMapping = {\n Webkit: '-webkit-',\n Moz: '-moz-',\n ms: '-ms-'\n};\n\nfunction prefixValue(value, propertyPrefixMap) {\n if ((0, _isPrefixedValue2.default)(value)) {\n return value;\n }\n\n // only split multi values, not cubic beziers\n var multipleValues = value.split(/,(?![^()]*(?:\\([^()]*\\))?\\))/g);\n\n for (var i = 0, len = multipleValues.length; i < len; ++i) {\n var singleValue = multipleValues[i];\n var values = [singleValue];\n for (var property in propertyPrefixMap) {\n var dashCaseProperty = (0, _hyphenateProperty2.default)(property);\n\n if (singleValue.indexOf(dashCaseProperty) > -1 && dashCaseProperty !== 'order') {\n var prefixes = propertyPrefixMap[property];\n for (var j = 0, pLen = prefixes.length; j < pLen; ++j) {\n // join all prefixes and create a new value\n values.unshift(singleValue.replace(dashCaseProperty, prefixMapping[prefixes[j]] + dashCaseProperty));\n }\n }\n }\n\n multipleValues[i] = values.join(',');\n }\n\n return multipleValues.join(',');\n}\n\nfunction transition(property, value, style, propertyPrefixMap) {\n // also check for already prefixed transitions\n if (typeof value === 'string' && properties.hasOwnProperty(property)) {\n var outputValue = prefixValue(value, propertyPrefixMap);\n // if the property is already prefixed\n var webkitOutput = outputValue.split(/,(?![^()]*(?:\\([^()]*\\))?\\))/g).filter(function (val) {\n return !/-moz-|-ms-/.test(val);\n }).join(',');\n\n if (property.indexOf('Webkit') > -1) {\n return webkitOutput;\n }\n\n var mozOutput = outputValue.split(/,(?![^()]*(?:\\([^()]*\\))?\\))/g).filter(function (val) {\n return !/-webkit-|-ms-/.test(val);\n }).join(',');\n\n if (property.indexOf('Moz') > -1) {\n return mozOutput;\n }\n\n style['Webkit' + (0, _capitalizeString2.default)(property)] = webkitOutput;\n style['Moz' + (0, _capitalizeString2.default)(property)] = mozOutput;\n return outputValue;\n }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports[\"default\"] = hyphenateProperty;\n\nvar _hyphenateStyleName = require(\"hyphenate-style-name\");\n\nvar _hyphenateStyleName2 = _interopRequireDefault(_hyphenateStyleName);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nfunction hyphenateProperty(property) {\n return (0, _hyphenateStyleName2[\"default\"])(property);\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport canUseDOM from '../../../modules/canUseDom';\nimport createCSSStyleSheet from './createCSSStyleSheet';\nimport createOrderedCSSStyleSheet from './createOrderedCSSStyleSheet';\nvar defaultId = 'react-native-stylesheet';\nvar roots = new WeakMap();\nvar sheets = [];\nvar initialRules = [\n// minimal top-level reset\n'html{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:rgba(0,0,0,0);}', 'body{margin:0;}',\n// minimal form pseudo-element reset\n'button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0;}', 'input::-webkit-search-cancel-button,input::-webkit-search-decoration,input::-webkit-search-results-button,input::-webkit-search-results-decoration{display:none;}'];\nexport function createSheet(root, id) {\n if (id === void 0) {\n id = defaultId;\n }\n var sheet;\n if (canUseDOM) {\n var rootNode = root != null ? root.getRootNode() : document;\n // Create the initial style sheet\n if (sheets.length === 0) {\n sheet = createOrderedCSSStyleSheet(createCSSStyleSheet(id));\n initialRules.forEach(rule => {\n sheet.insert(rule, 0);\n });\n roots.set(rootNode, sheets.length);\n sheets.push(sheet);\n } else {\n var index = roots.get(rootNode);\n if (index == null) {\n var initialSheet = sheets[0];\n // If we're creating a new sheet, populate it with existing styles\n var textContent = initialSheet != null ? initialSheet.getTextContent() : '';\n // Cast rootNode to 'any' because Flow types for getRootNode are wrong\n sheet = createOrderedCSSStyleSheet(createCSSStyleSheet(id, rootNode, textContent));\n roots.set(rootNode, sheets.length);\n sheets.push(sheet);\n } else {\n sheet = sheets[index];\n }\n }\n } else {\n // Create the initial style sheet\n if (sheets.length === 0) {\n sheet = createOrderedCSSStyleSheet(createCSSStyleSheet(id));\n initialRules.forEach(rule => {\n sheet.insert(rule, 0);\n });\n sheets.push(sheet);\n } else {\n sheet = sheets[0];\n }\n }\n return {\n getTextContent() {\n return sheet.getTextContent();\n },\n id,\n insert(cssText, groupValue) {\n sheets.forEach(s => {\n s.insert(cssText, groupValue);\n });\n }\n };\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\nimport canUseDOM from '../../../modules/canUseDom';\n\n// $FlowFixMe: HTMLStyleElement is incorrectly typed - https://github.com/facebook/flow/issues/2696\nexport default function createCSSStyleSheet(id, rootNode, textContent) {\n if (canUseDOM) {\n var root = rootNode != null ? rootNode : document;\n var element = root.getElementById(id);\n if (element == null) {\n element = document.createElement('style');\n element.setAttribute('id', id);\n if (typeof textContent === 'string') {\n element.appendChild(document.createTextNode(textContent));\n }\n if (root instanceof ShadowRoot) {\n root.insertBefore(element, root.firstChild);\n } else {\n var head = root.head;\n if (head) {\n head.insertBefore(element, head.firstChild);\n }\n }\n }\n // $FlowFixMe: HTMLElement is incorrectly typed\n return element.sheet;\n } else {\n return null;\n }\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar slice = Array.prototype.slice;\n\n/**\n * Order-based insertion of CSS.\n *\n * Each rule is associated with a numerically defined group.\n * Groups are ordered within the style sheet according to their number, with the\n * lowest first.\n *\n * Groups are implemented using marker rules. The selector of the first rule of\n * each group is used only to encode the group number for hydration. An\n * alternative implementation could rely on CSSMediaRule, allowing groups to be\n * treated as a sub-sheet, but the Edge implementation of CSSMediaRule is\n * broken.\n * https://developer.mozilla.org/en-US/docs/Web/API/CSSMediaRule\n * https://gist.github.com/necolas/aa0c37846ad6bd3b05b727b959e82674\n */\nexport default function createOrderedCSSStyleSheet(sheet) {\n var groups = {};\n var selectors = {};\n\n /**\n * Hydrate approximate record from any existing rules in the sheet.\n */\n if (sheet != null) {\n var group;\n slice.call(sheet.cssRules).forEach((cssRule, i) => {\n var cssText = cssRule.cssText;\n // Create record of existing selectors and rules\n if (cssText.indexOf('stylesheet-group') > -1) {\n group = decodeGroupRule(cssRule);\n groups[group] = {\n start: i,\n rules: [cssText]\n };\n } else {\n var selectorText = getSelectorText(cssText);\n if (selectorText != null) {\n selectors[selectorText] = true;\n groups[group].rules.push(cssText);\n }\n }\n });\n }\n function sheetInsert(sheet, group, text) {\n var orderedGroups = getOrderedGroups(groups);\n var groupIndex = orderedGroups.indexOf(group);\n var nextGroupIndex = groupIndex + 1;\n var nextGroup = orderedGroups[nextGroupIndex];\n // Insert rule before the next group, or at the end of the stylesheet\n var position = nextGroup != null && groups[nextGroup].start != null ? groups[nextGroup].start : sheet.cssRules.length;\n var isInserted = insertRuleAt(sheet, text, position);\n if (isInserted) {\n // Set the starting index of the new group\n if (groups[group].start == null) {\n groups[group].start = position;\n }\n // Increment the starting index of all subsequent groups\n for (var i = nextGroupIndex; i < orderedGroups.length; i += 1) {\n var groupNumber = orderedGroups[i];\n var previousStart = groups[groupNumber].start || 0;\n groups[groupNumber].start = previousStart + 1;\n }\n }\n return isInserted;\n }\n var OrderedCSSStyleSheet = {\n /**\n * The textContent of the style sheet.\n */\n getTextContent() {\n return getOrderedGroups(groups).map(group => {\n var rules = groups[group].rules;\n // Sorting provides deterministic order of styles in group for\n // build-time extraction of the style sheet.\n var marker = rules.shift();\n rules.sort();\n rules.unshift(marker);\n return rules.join('\\n');\n }).join('\\n');\n },\n /**\n * Insert a rule into the style sheet\n */\n insert(cssText, groupValue) {\n var group = Number(groupValue);\n\n // Create a new group.\n if (groups[group] == null) {\n var markerRule = encodeGroupRule(group);\n // Create the internal record.\n groups[group] = {\n start: null,\n rules: [markerRule]\n };\n // Update CSSOM.\n if (sheet != null) {\n sheetInsert(sheet, group, markerRule);\n }\n }\n\n // selectorText is more reliable than cssText for insertion checks. The\n // browser excludes vendor-prefixed properties and rewrites certain values\n // making cssText more likely to be different from what was inserted.\n var selectorText = getSelectorText(cssText);\n if (selectorText != null && selectors[selectorText] == null) {\n // Update the internal records.\n selectors[selectorText] = true;\n groups[group].rules.push(cssText);\n // Update CSSOM.\n if (sheet != null) {\n var isInserted = sheetInsert(sheet, group, cssText);\n if (!isInserted) {\n // Revert internal record change if a rule was rejected (e.g.,\n // unrecognized pseudo-selector)\n groups[group].rules.pop();\n }\n }\n }\n }\n };\n return OrderedCSSStyleSheet;\n}\n\n/**\n * Helper functions\n */\n\nfunction encodeGroupRule(group) {\n return \"[stylesheet-group=\\\"\" + group + \"\\\"]{}\";\n}\nvar groupPattern = /[\"']/g;\nfunction decodeGroupRule(cssRule) {\n return Number(cssRule.selectorText.split(groupPattern)[1]);\n}\nfunction getOrderedGroups(obj) {\n return Object.keys(obj).map(Number).sort((a, b) => a > b ? 1 : -1);\n}\nvar selectorPattern = /\\s*([,])\\s*/g;\nfunction getSelectorText(cssText) {\n var selector = cssText.split('{')[0].trim();\n return selector !== '' ? selector.replace(selectorPattern, '$1') : null;\n}\nfunction insertRuleAt(root, cssText, position) {\n try {\n // $FlowFixMe: Flow is missing CSSOM types needed to type 'root'.\n root.insertRule(cssText, position);\n return true;\n } catch (e) {\n // JSDOM doesn't support `CSSSMediaRule#insertRule`.\n // Also ignore errors that occur from attempting to insert vendor-prefixed selectors.\n return false;\n }\n}","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nmodule.exports = require('./dist/transform-localize-style');\n","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.localizeStyle = localizeStyle;\nvar cache = new WeakMap();\nvar markerProp = '$$css$localize';\n/**\n * The compiler polyfills logical properties and values, generating a class\n * name for both writing directions. The style objects are annotated by\n * the compiler as needing this runtime transform. The results are memoized.\n *\n * { '$$css$localize': true, float: [ 'float-left', 'float-right' ] }\n * => { float: 'float-left' }\n */\n\nfunction compileStyle(style, isRTL) {\n // Create a new compiled style for styleq\n var compiledStyle = {};\n\n for (var prop in style) {\n if (prop !== markerProp) {\n var value = style[prop];\n\n if (Array.isArray(value)) {\n compiledStyle[prop] = isRTL ? value[1] : value[0];\n } else {\n compiledStyle[prop] = value;\n }\n }\n }\n\n return compiledStyle;\n}\n\nfunction localizeStyle(style, isRTL) {\n if (style[markerProp] != null) {\n var compiledStyleIndex = isRTL ? 1 : 0; // Check the cache in case we've already seen this object\n\n if (cache.has(style)) {\n var _cachedStyles = cache.get(style);\n\n var _compiledStyle = _cachedStyles[compiledStyleIndex];\n\n if (_compiledStyle == null) {\n // Update the missing cache entry\n _compiledStyle = compileStyle(style, isRTL);\n _cachedStyles[compiledStyleIndex] = _compiledStyle;\n cache.set(style, _cachedStyles);\n }\n\n return _compiledStyle;\n } // Create a new compiled style for styleq\n\n\n var compiledStyle = compileStyle(style, isRTL);\n var cachedStyles = new Array(2);\n cachedStyles[compiledStyleIndex] = compiledStyle;\n cache.set(style, cachedStyles);\n return compiledStyle;\n }\n\n return style;\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport normalizeColor from './compiler/normalizeColor';\nimport normalizeValueWithProperty from './compiler/normalizeValueWithProperty';\nimport { warnOnce } from '../../modules/warnOnce';\nvar emptyObject = {};\n\n/**\n * Shadows\n */\n\nvar defaultOffset = {\n height: 0,\n width: 0\n};\nexport var createBoxShadowValue = style => {\n var shadowColor = style.shadowColor,\n shadowOffset = style.shadowOffset,\n shadowOpacity = style.shadowOpacity,\n shadowRadius = style.shadowRadius;\n var _ref = shadowOffset || defaultOffset,\n height = _ref.height,\n width = _ref.width;\n var offsetX = normalizeValueWithProperty(width);\n var offsetY = normalizeValueWithProperty(height);\n var blurRadius = normalizeValueWithProperty(shadowRadius || 0);\n var color = normalizeColor(shadowColor || 'black', shadowOpacity);\n if (color != null && offsetX != null && offsetY != null && blurRadius != null) {\n return offsetX + \" \" + offsetY + \" \" + blurRadius + \" \" + color;\n }\n};\nexport var createTextShadowValue = style => {\n var textShadowColor = style.textShadowColor,\n textShadowOffset = style.textShadowOffset,\n textShadowRadius = style.textShadowRadius;\n var _ref2 = textShadowOffset || defaultOffset,\n height = _ref2.height,\n width = _ref2.width;\n var radius = textShadowRadius || 0;\n var offsetX = normalizeValueWithProperty(width);\n var offsetY = normalizeValueWithProperty(height);\n var blurRadius = normalizeValueWithProperty(radius);\n var color = normalizeValueWithProperty(textShadowColor, 'textShadowColor');\n if (color && (height !== 0 || width !== 0 || radius !== 0) && offsetX != null && offsetY != null && blurRadius != null) {\n return offsetX + \" \" + offsetY + \" \" + blurRadius + \" \" + color;\n }\n};\n\n// { scale: 2 } => 'scale(2)'\n// { translateX: 20 } => 'translateX(20px)'\n// { matrix: [1,2,3,4,5,6] } => 'matrix(1,2,3,4,5,6)'\nvar mapTransform = transform => {\n var type = Object.keys(transform)[0];\n var value = transform[type];\n if (type === 'matrix' || type === 'matrix3d') {\n return type + \"(\" + value.join(',') + \")\";\n } else {\n var normalizedValue = normalizeValueWithProperty(value, type);\n return type + \"(\" + normalizedValue + \")\";\n }\n};\nexport var createTransformValue = value => {\n return value.map(mapTransform).join(' ');\n};\nvar PROPERTIES_STANDARD = {\n borderBottomEndRadius: 'borderEndEndRadius',\n borderBottomStartRadius: 'borderEndStartRadius',\n borderTopEndRadius: 'borderStartEndRadius',\n borderTopStartRadius: 'borderStartStartRadius',\n borderEndColor: 'borderInlineEndColor',\n borderEndStyle: 'borderInlineEndStyle',\n borderEndWidth: 'borderInlineEndWidth',\n borderStartColor: 'borderInlineStartColor',\n borderStartStyle: 'borderInlineStartStyle',\n borderStartWidth: 'borderInlineStartWidth',\n end: 'insetInlineEnd',\n marginEnd: 'marginInlineEnd',\n marginHorizontal: 'marginInline',\n marginStart: 'marginInlineStart',\n marginVertical: 'marginBlock',\n paddingEnd: 'paddingInlineEnd',\n paddingHorizontal: 'paddingInline',\n paddingStart: 'paddingInlineStart',\n paddingVertical: 'paddingBlock',\n start: 'insetInlineStart'\n};\nvar ignoredProps = {\n elevation: true,\n overlayColor: true,\n resizeMode: true,\n tintColor: true\n};\n\n/**\n * Preprocess styles\n */\nexport var preprocess = function preprocess(originalStyle, options) {\n if (options === void 0) {\n options = {};\n }\n var style = originalStyle || emptyObject;\n var nextStyle = {};\n\n // Convert shadow styles\n if (options.shadow === true, style.shadowColor != null || style.shadowOffset != null || style.shadowOpacity != null || style.shadowRadius != null) {\n warnOnce('shadowStyles', \"\\\"shadow*\\\" style props are deprecated. Use \\\"boxShadow\\\".\");\n var boxShadowValue = createBoxShadowValue(style);\n if (boxShadowValue != null && nextStyle.boxShadow == null) {\n var boxShadow = style.boxShadow;\n var value = boxShadow ? boxShadow + \", \" + boxShadowValue : boxShadowValue;\n nextStyle.boxShadow = value;\n }\n }\n\n // Convert text shadow styles\n if (options.textShadow === true, style.textShadowColor != null || style.textShadowOffset != null || style.textShadowRadius != null) {\n warnOnce('textShadowStyles', \"\\\"textShadow*\\\" style props are deprecated. Use \\\"textShadow\\\".\");\n var textShadowValue = createTextShadowValue(style);\n if (textShadowValue != null && nextStyle.textShadow == null) {\n var textShadow = style.textShadow;\n var _value = textShadow ? textShadow + \", \" + textShadowValue : textShadowValue;\n nextStyle.textShadow = _value;\n }\n }\n for (var originalProp in style) {\n if (\n // Ignore some React Native styles\n ignoredProps[originalProp] != null || originalProp === 'shadowColor' || originalProp === 'shadowOffset' || originalProp === 'shadowOpacity' || originalProp === 'shadowRadius' || originalProp === 'textShadowColor' || originalProp === 'textShadowOffset' || originalProp === 'textShadowRadius') {\n continue;\n }\n var originalValue = style[originalProp];\n var prop = PROPERTIES_STANDARD[originalProp] || originalProp;\n var _value2 = originalValue;\n if (!Object.prototype.hasOwnProperty.call(style, originalProp) || prop !== originalProp && style[prop] != null) {\n continue;\n }\n if (prop === 'aspectRatio' && typeof _value2 === 'number') {\n nextStyle[prop] = _value2.toString();\n } else if (prop === 'fontVariant') {\n if (Array.isArray(_value2) && _value2.length > 0) {\n warnOnce('fontVariant', '\"fontVariant\" style array value is deprecated. Use space-separated values.');\n _value2 = _value2.join(' ');\n }\n nextStyle[prop] = _value2;\n } else if (prop === 'textAlignVertical') {\n warnOnce('textAlignVertical', '\"textAlignVertical\" style is deprecated. Use \"verticalAlign\".');\n if (style.verticalAlign == null) {\n nextStyle.verticalAlign = _value2 === 'center' ? 'middle' : _value2;\n }\n } else if (prop === 'transform') {\n if (Array.isArray(_value2)) {\n _value2 = createTransformValue(_value2);\n }\n nextStyle.transform = _value2;\n } else {\n nextStyle[prop] = _value2;\n }\n }\n\n // $FlowIgnore\n return nextStyle;\n};\nexport default preprocess;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar warnedKeys = {};\n\n/**\n * A simple function that prints a warning message once per session.\n *\n * @param {string} key - The key used to ensure the message is printed once.\n * This should be unique to the callsite.\n * @param {string} message - The message to print\n */\nexport function warnOnce(key, message) {\n if (process.env.NODE_ENV !== 'production') {\n if (warnedKeys[key]) {\n return;\n }\n console.warn(message);\n warnedKeys[key] = true;\n }\n}","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.styleq = void 0;\nvar cache = new WeakMap();\nvar compiledKey = '$$css';\n\nfunction createStyleq(options) {\n var disableCache;\n var disableMix;\n var transform;\n\n if (options != null) {\n disableCache = options.disableCache === true;\n disableMix = options.disableMix === true;\n transform = options.transform;\n }\n\n return function styleq() {\n // Keep track of property commits to the className\n var definedProperties = []; // The className and inline style to build up\n\n var className = '';\n var inlineStyle = null; // The current position in the cache graph\n\n var nextCache = disableCache ? null : cache; // This way of creating an array from arguments is fastest\n\n var styles = new Array(arguments.length);\n\n for (var i = 0; i < arguments.length; i++) {\n styles[i] = arguments[i];\n } // Iterate over styles from last to first\n\n\n while (styles.length > 0) {\n var possibleStyle = styles.pop(); // Skip empty items\n\n if (possibleStyle == null || possibleStyle === false) {\n continue;\n } // Push nested styles back onto the stack to be processed\n\n\n if (Array.isArray(possibleStyle)) {\n for (var _i = 0; _i < possibleStyle.length; _i++) {\n styles.push(possibleStyle[_i]);\n }\n\n continue;\n } // Process an individual style object\n\n\n var style = transform != null ? transform(possibleStyle) : possibleStyle;\n\n if (style.$$css) {\n // Build up the class names defined by this object\n var classNameChunk = ''; // Check the cache to see if we've already done this work\n\n if (nextCache != null && nextCache.has(style)) {\n // Cache: read\n var cacheEntry = nextCache.get(style);\n\n if (cacheEntry != null) {\n classNameChunk = cacheEntry[0]; // $FlowIgnore\n\n definedProperties.push.apply(definedProperties, cacheEntry[1]);\n nextCache = cacheEntry[2];\n }\n } // Update the chunks with data from this object\n else {\n // The properties defined by this object\n var definedPropertiesChunk = [];\n\n for (var prop in style) {\n var value = style[prop];\n if (prop === compiledKey) continue; // Each property value is used as an HTML class name\n // { 'debug.string': 'debug.string', opacity: 's-jskmnoqp' }\n\n if (typeof value === 'string' || value === null) {\n // Only add to chunks if this property hasn't already been seen\n if (!definedProperties.includes(prop)) {\n definedProperties.push(prop);\n\n if (nextCache != null) {\n definedPropertiesChunk.push(prop);\n }\n\n if (typeof value === 'string') {\n classNameChunk += classNameChunk ? ' ' + value : value;\n }\n }\n } // If we encounter a value that isn't a string or `null`\n else {\n console.error(\"styleq: \".concat(prop, \" typeof \").concat(String(value), \" is not \\\"string\\\" or \\\"null\\\".\"));\n }\n } // Cache: write\n\n\n if (nextCache != null) {\n // Create the next WeakMap for this sequence of styles\n var weakMap = new WeakMap();\n nextCache.set(style, [classNameChunk, definedPropertiesChunk, weakMap]);\n nextCache = weakMap;\n }\n } // Order of classes in chunks matches property-iteration order of style\n // object. Order of chunks matches passed order of styles from first to\n // last (which we iterate over in reverse).\n\n\n if (classNameChunk) {\n className = className ? classNameChunk + ' ' + className : classNameChunk;\n }\n } // ----- DYNAMIC: Process inline style object -----\n else {\n if (disableMix) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n\n inlineStyle = Object.assign({}, style, inlineStyle);\n } else {\n var subStyle = null;\n\n for (var _prop in style) {\n var _value = style[_prop];\n\n if (_value !== undefined) {\n if (!definedProperties.includes(_prop)) {\n if (_value != null) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n\n if (subStyle == null) {\n subStyle = {};\n }\n\n subStyle[_prop] = _value;\n }\n\n definedProperties.push(_prop); // Cache is unnecessary overhead if results can't be reused.\n\n nextCache = null;\n }\n }\n }\n\n if (subStyle != null) {\n inlineStyle = Object.assign(subStyle, inlineStyle);\n }\n }\n }\n }\n\n var styleProps = [className, inlineStyle];\n return styleProps;\n };\n}\n\nvar styleq = createStyleq();\nexports.styleq = styleq;\nstyleq.factory = createStyleq;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport valueParser from 'postcss-value-parser';\nvar invalidShortforms = {\n background: true,\n borderBottom: true,\n borderLeft: true,\n borderRight: true,\n borderTop: true,\n font: true,\n grid: true,\n outline: true,\n textDecoration: true\n};\nvar invalidMultiValueShortforms = {\n flex: true,\n margin: true,\n padding: true,\n borderColor: true,\n borderRadius: true,\n borderStyle: true,\n borderWidth: true,\n inset: true,\n insetBlock: true,\n insetInline: true,\n marginBlock: true,\n marginInline: true,\n marginHorizontal: true,\n marginVertical: true,\n paddingBlock: true,\n paddingInline: true,\n paddingHorizontal: true,\n paddingVertical: true,\n overflow: true,\n overscrollBehavior: true,\n backgroundPosition: true\n};\nfunction error(message) {\n console.error(message);\n}\nexport function validate(obj) {\n for (var k in obj) {\n var prop = k.trim();\n var value = obj[prop];\n var isInvalid = false;\n if (value === null) {\n continue;\n }\n if (typeof value === 'string' && value.indexOf('!important') > -1) {\n error(\"Invalid style declaration \\\"\" + prop + \":\" + value + \"\\\". Values cannot include \\\"!important\\\"\");\n isInvalid = true;\n } else {\n var suggestion = '';\n if (prop === 'animation' || prop === 'animationName') {\n suggestion = 'Did you mean \"animationKeyframes\"?';\n isInvalid = true;\n } else if (prop === 'direction') {\n suggestion = 'Did you mean \"writingDirection\"?';\n isInvalid = true;\n } else if (invalidShortforms[prop]) {\n suggestion = 'Please use long-form properties.';\n isInvalid = true;\n } else if (invalidMultiValueShortforms[prop]) {\n if (typeof value === 'string' && valueParser(value).nodes.length > 1) {\n suggestion = \"Value is \\\"\" + value + \"\\\" but only single values are supported.\";\n isInvalid = true;\n }\n }\n if (suggestion !== '') {\n error(\"Invalid style property of \\\"\" + prop + \"\\\". \" + suggestion);\n }\n }\n if (isInvalid) {\n delete obj[k];\n }\n }\n}","var parse = require(\"./parse\");\nvar walk = require(\"./walk\");\nvar stringify = require(\"./stringify\");\n\nfunction ValueParser(value) {\n if (this instanceof ValueParser) {\n this.nodes = parse(value);\n return this;\n }\n return new ValueParser(value);\n}\n\nValueParser.prototype.toString = function() {\n return Array.isArray(this.nodes) ? stringify(this.nodes) : \"\";\n};\n\nValueParser.prototype.walk = function(cb, bubble) {\n walk(this.nodes, cb, bubble);\n return this;\n};\n\nValueParser.unit = require(\"./unit\");\n\nValueParser.walk = walk;\n\nValueParser.stringify = stringify;\n\nmodule.exports = ValueParser;\n","var openParentheses = \"(\".charCodeAt(0);\nvar closeParentheses = \")\".charCodeAt(0);\nvar singleQuote = \"'\".charCodeAt(0);\nvar doubleQuote = '\"'.charCodeAt(0);\nvar backslash = \"\\\\\".charCodeAt(0);\nvar slash = \"/\".charCodeAt(0);\nvar comma = \",\".charCodeAt(0);\nvar colon = \":\".charCodeAt(0);\nvar star = \"*\".charCodeAt(0);\nvar uLower = \"u\".charCodeAt(0);\nvar uUpper = \"U\".charCodeAt(0);\nvar plus = \"+\".charCodeAt(0);\nvar isUnicodeRange = /^[a-f0-9?-]+$/i;\n\nmodule.exports = function(input) {\n var tokens = [];\n var value = input;\n\n var next,\n quote,\n prev,\n token,\n escape,\n escapePos,\n whitespacePos,\n parenthesesOpenPos;\n var pos = 0;\n var code = value.charCodeAt(pos);\n var max = value.length;\n var stack = [{ nodes: tokens }];\n var balanced = 0;\n var parent;\n\n var name = \"\";\n var before = \"\";\n var after = \"\";\n\n while (pos < max) {\n // Whitespaces\n if (code <= 32) {\n next = pos;\n do {\n next += 1;\n code = value.charCodeAt(next);\n } while (code <= 32);\n token = value.slice(pos, next);\n\n prev = tokens[tokens.length - 1];\n if (code === closeParentheses && balanced) {\n after = token;\n } else if (prev && prev.type === \"div\") {\n prev.after = token;\n prev.sourceEndIndex += token.length;\n } else if (\n code === comma ||\n code === colon ||\n (code === slash &&\n value.charCodeAt(next + 1) !== star &&\n (!parent ||\n (parent && parent.type === \"function\" && parent.value !== \"calc\")))\n ) {\n before = token;\n } else {\n tokens.push({\n type: \"space\",\n sourceIndex: pos,\n sourceEndIndex: next,\n value: token\n });\n }\n\n pos = next;\n\n // Quotes\n } else if (code === singleQuote || code === doubleQuote) {\n next = pos;\n quote = code === singleQuote ? \"'\" : '\"';\n token = {\n type: \"string\",\n sourceIndex: pos,\n quote: quote\n };\n do {\n escape = false;\n next = value.indexOf(quote, next + 1);\n if (~next) {\n escapePos = next;\n while (value.charCodeAt(escapePos - 1) === backslash) {\n escapePos -= 1;\n escape = !escape;\n }\n } else {\n value += quote;\n next = value.length - 1;\n token.unclosed = true;\n }\n } while (escape);\n token.value = value.slice(pos + 1, next);\n token.sourceEndIndex = token.unclosed ? next : next + 1;\n tokens.push(token);\n pos = next + 1;\n code = value.charCodeAt(pos);\n\n // Comments\n } else if (code === slash && value.charCodeAt(pos + 1) === star) {\n next = value.indexOf(\"*/\", pos);\n\n token = {\n type: \"comment\",\n sourceIndex: pos,\n sourceEndIndex: next + 2\n };\n\n if (next === -1) {\n token.unclosed = true;\n next = value.length;\n token.sourceEndIndex = next;\n }\n\n token.value = value.slice(pos + 2, next);\n tokens.push(token);\n\n pos = next + 2;\n code = value.charCodeAt(pos);\n\n // Operation within calc\n } else if (\n (code === slash || code === star) &&\n parent &&\n parent.type === \"function\" &&\n parent.value === \"calc\"\n ) {\n token = value[pos];\n tokens.push({\n type: \"word\",\n sourceIndex: pos - before.length,\n sourceEndIndex: pos + token.length,\n value: token\n });\n pos += 1;\n code = value.charCodeAt(pos);\n\n // Dividers\n } else if (code === slash || code === comma || code === colon) {\n token = value[pos];\n\n tokens.push({\n type: \"div\",\n sourceIndex: pos - before.length,\n sourceEndIndex: pos + token.length,\n value: token,\n before: before,\n after: \"\"\n });\n before = \"\";\n\n pos += 1;\n code = value.charCodeAt(pos);\n\n // Open parentheses\n } else if (openParentheses === code) {\n // Whitespaces after open parentheses\n next = pos;\n do {\n next += 1;\n code = value.charCodeAt(next);\n } while (code <= 32);\n parenthesesOpenPos = pos;\n token = {\n type: \"function\",\n sourceIndex: pos - name.length,\n value: name,\n before: value.slice(parenthesesOpenPos + 1, next)\n };\n pos = next;\n\n if (name === \"url\" && code !== singleQuote && code !== doubleQuote) {\n next -= 1;\n do {\n escape = false;\n next = value.indexOf(\")\", next + 1);\n if (~next) {\n escapePos = next;\n while (value.charCodeAt(escapePos - 1) === backslash) {\n escapePos -= 1;\n escape = !escape;\n }\n } else {\n value += \")\";\n next = value.length - 1;\n token.unclosed = true;\n }\n } while (escape);\n // Whitespaces before closed\n whitespacePos = next;\n do {\n whitespacePos -= 1;\n code = value.charCodeAt(whitespacePos);\n } while (code <= 32);\n if (parenthesesOpenPos < whitespacePos) {\n if (pos !== whitespacePos + 1) {\n token.nodes = [\n {\n type: \"word\",\n sourceIndex: pos,\n sourceEndIndex: whitespacePos + 1,\n value: value.slice(pos, whitespacePos + 1)\n }\n ];\n } else {\n token.nodes = [];\n }\n if (token.unclosed && whitespacePos + 1 !== next) {\n token.after = \"\";\n token.nodes.push({\n type: \"space\",\n sourceIndex: whitespacePos + 1,\n sourceEndIndex: next,\n value: value.slice(whitespacePos + 1, next)\n });\n } else {\n token.after = value.slice(whitespacePos + 1, next);\n token.sourceEndIndex = next;\n }\n } else {\n token.after = \"\";\n token.nodes = [];\n }\n pos = next + 1;\n token.sourceEndIndex = token.unclosed ? next : pos;\n code = value.charCodeAt(pos);\n tokens.push(token);\n } else {\n balanced += 1;\n token.after = \"\";\n token.sourceEndIndex = pos + 1;\n tokens.push(token);\n stack.push(token);\n tokens = token.nodes = [];\n parent = token;\n }\n name = \"\";\n\n // Close parentheses\n } else if (closeParentheses === code && balanced) {\n pos += 1;\n code = value.charCodeAt(pos);\n\n parent.after = after;\n parent.sourceEndIndex += after.length;\n after = \"\";\n balanced -= 1;\n stack[stack.length - 1].sourceEndIndex = pos;\n stack.pop();\n parent = stack[balanced];\n tokens = parent.nodes;\n\n // Words\n } else {\n next = pos;\n do {\n if (code === backslash) {\n next += 1;\n }\n next += 1;\n code = value.charCodeAt(next);\n } while (\n next < max &&\n !(\n code <= 32 ||\n code === singleQuote ||\n code === doubleQuote ||\n code === comma ||\n code === colon ||\n code === slash ||\n code === openParentheses ||\n (code === star &&\n parent &&\n parent.type === \"function\" &&\n parent.value === \"calc\") ||\n (code === slash &&\n parent.type === \"function\" &&\n parent.value === \"calc\") ||\n (code === closeParentheses && balanced)\n )\n );\n token = value.slice(pos, next);\n\n if (openParentheses === code) {\n name = token;\n } else if (\n (uLower === token.charCodeAt(0) || uUpper === token.charCodeAt(0)) &&\n plus === token.charCodeAt(1) &&\n isUnicodeRange.test(token.slice(2))\n ) {\n tokens.push({\n type: \"unicode-range\",\n sourceIndex: pos,\n sourceEndIndex: next,\n value: token\n });\n } else {\n tokens.push({\n type: \"word\",\n sourceIndex: pos,\n sourceEndIndex: next,\n value: token\n });\n }\n\n pos = next;\n }\n }\n\n for (pos = stack.length - 1; pos; pos -= 1) {\n stack[pos].unclosed = true;\n stack[pos].sourceEndIndex = value.length;\n }\n\n return stack[0].nodes;\n};\n","module.exports = function walk(nodes, cb, bubble) {\n var i, max, node, result;\n\n for (i = 0, max = nodes.length; i < max; i += 1) {\n node = nodes[i];\n if (!bubble) {\n result = cb(node, i, nodes);\n }\n\n if (\n result !== false &&\n node.type === \"function\" &&\n Array.isArray(node.nodes)\n ) {\n walk(node.nodes, cb, bubble);\n }\n\n if (bubble) {\n cb(node, i, nodes);\n }\n }\n};\n","function stringifyNode(node, custom) {\n var type = node.type;\n var value = node.value;\n var buf;\n var customResult;\n\n if (custom && (customResult = custom(node)) !== undefined) {\n return customResult;\n } else if (type === \"word\" || type === \"space\") {\n return value;\n } else if (type === \"string\") {\n buf = node.quote || \"\";\n return buf + value + (node.unclosed ? \"\" : buf);\n } else if (type === \"comment\") {\n return \"/*\" + value + (node.unclosed ? \"\" : \"*/\");\n } else if (type === \"div\") {\n return (node.before || \"\") + value + (node.after || \"\");\n } else if (Array.isArray(node.nodes)) {\n buf = stringify(node.nodes, custom);\n if (type !== \"function\") {\n return buf;\n }\n return (\n value +\n \"(\" +\n (node.before || \"\") +\n buf +\n (node.after || \"\") +\n (node.unclosed ? \"\" : \")\")\n );\n }\n return value;\n}\n\nfunction stringify(nodes, custom) {\n var result, i;\n\n if (Array.isArray(nodes)) {\n result = \"\";\n for (i = nodes.length - 1; ~i; i -= 1) {\n result = stringifyNode(nodes[i], custom) + result;\n }\n return result;\n }\n return stringifyNode(nodes, custom);\n}\n\nmodule.exports = stringify;\n","var minus = \"-\".charCodeAt(0);\nvar plus = \"+\".charCodeAt(0);\nvar dot = \".\".charCodeAt(0);\nvar exp = \"e\".charCodeAt(0);\nvar EXP = \"E\".charCodeAt(0);\n\n// Check if three code points would start a number\n// https://www.w3.org/TR/css-syntax-3/#starts-with-a-number\nfunction likeNumber(value) {\n var code = value.charCodeAt(0);\n var nextCode;\n\n if (code === plus || code === minus) {\n nextCode = value.charCodeAt(1);\n\n if (nextCode >= 48 && nextCode <= 57) {\n return true;\n }\n\n var nextNextCode = value.charCodeAt(2);\n\n if (nextCode === dot && nextNextCode >= 48 && nextNextCode <= 57) {\n return true;\n }\n\n return false;\n }\n\n if (code === dot) {\n nextCode = value.charCodeAt(1);\n\n if (nextCode >= 48 && nextCode <= 57) {\n return true;\n }\n\n return false;\n }\n\n if (code >= 48 && code <= 57) {\n return true;\n }\n\n return false;\n}\n\n// Consume a number\n// https://www.w3.org/TR/css-syntax-3/#consume-number\nmodule.exports = function(value) {\n var pos = 0;\n var length = value.length;\n var code;\n var nextCode;\n var nextNextCode;\n\n if (length === 0 || !likeNumber(value)) {\n return false;\n }\n\n code = value.charCodeAt(pos);\n\n if (code === plus || code === minus) {\n pos++;\n }\n\n while (pos < length) {\n code = value.charCodeAt(pos);\n\n if (code < 48 || code > 57) {\n break;\n }\n\n pos += 1;\n }\n\n code = value.charCodeAt(pos);\n nextCode = value.charCodeAt(pos + 1);\n\n if (code === dot && nextCode >= 48 && nextCode <= 57) {\n pos += 2;\n\n while (pos < length) {\n code = value.charCodeAt(pos);\n\n if (code < 48 || code > 57) {\n break;\n }\n\n pos += 1;\n }\n }\n\n code = value.charCodeAt(pos);\n nextCode = value.charCodeAt(pos + 1);\n nextNextCode = value.charCodeAt(pos + 2);\n\n if (\n (code === exp || code === EXP) &&\n ((nextCode >= 48 && nextCode <= 57) ||\n ((nextCode === plus || nextCode === minus) &&\n nextNextCode >= 48 &&\n nextNextCode <= 57))\n ) {\n pos += nextCode === plus || nextCode === minus ? 3 : 2;\n\n while (pos < length) {\n code = value.charCodeAt(pos);\n\n if (code < 48 || code > 57) {\n break;\n }\n\n pos += 1;\n }\n }\n\n return {\n number: value.slice(0, pos),\n unit: value.slice(pos)\n };\n};\n","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from 'react';\nimport { View, StyleSheet } from 'react-native';\nimport GestureHandlerRootViewContext from '../GestureHandlerRootViewContext';\nexport default function GestureHandlerRootView({\n style,\n ...rest\n}) {\n return /*#__PURE__*/React.createElement(GestureHandlerRootViewContext.Provider, {\n value: true\n }, /*#__PURE__*/React.createElement(View, _extends({\n style: style !== null && style !== void 0 ? style : styles.container\n }, rest)));\n}\nconst styles = StyleSheet.create({\n container: {\n flex: 1\n }\n});\n//# sourceMappingURL=GestureHandlerRootView.web.js.map","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"hrefAttrs\", \"onLayout\", \"onMoveShouldSetResponder\", \"onMoveShouldSetResponderCapture\", \"onResponderEnd\", \"onResponderGrant\", \"onResponderMove\", \"onResponderReject\", \"onResponderRelease\", \"onResponderStart\", \"onResponderTerminate\", \"onResponderTerminationRequest\", \"onScrollShouldSetResponder\", \"onScrollShouldSetResponderCapture\", \"onSelectionChangeShouldSetResponder\", \"onSelectionChangeShouldSetResponderCapture\", \"onStartShouldSetResponder\", \"onStartShouldSetResponderCapture\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport createElement from '../createElement';\nimport * as forwardedProps from '../../modules/forwardedProps';\nimport pick from '../../modules/pick';\nimport useElementLayout from '../../modules/useElementLayout';\nimport useMergeRefs from '../../modules/useMergeRefs';\nimport usePlatformMethods from '../../modules/usePlatformMethods';\nimport useResponderEvents from '../../modules/useResponderEvents';\nimport StyleSheet from '../StyleSheet';\nimport TextAncestorContext from '../Text/TextAncestorContext';\nimport { useLocaleContext, getLocaleDirection } from '../../modules/useLocale';\nvar forwardPropsList = Object.assign({}, forwardedProps.defaultProps, forwardedProps.accessibilityProps, forwardedProps.clickProps, forwardedProps.focusProps, forwardedProps.keyboardProps, forwardedProps.mouseProps, forwardedProps.touchProps, forwardedProps.styleProps, {\n href: true,\n lang: true,\n onScroll: true,\n onWheel: true,\n pointerEvents: true\n});\nvar pickProps = props => pick(props, forwardPropsList);\nvar View = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var hrefAttrs = props.hrefAttrs,\n onLayout = props.onLayout,\n onMoveShouldSetResponder = props.onMoveShouldSetResponder,\n onMoveShouldSetResponderCapture = props.onMoveShouldSetResponderCapture,\n onResponderEnd = props.onResponderEnd,\n onResponderGrant = props.onResponderGrant,\n onResponderMove = props.onResponderMove,\n onResponderReject = props.onResponderReject,\n onResponderRelease = props.onResponderRelease,\n onResponderStart = props.onResponderStart,\n onResponderTerminate = props.onResponderTerminate,\n onResponderTerminationRequest = props.onResponderTerminationRequest,\n onScrollShouldSetResponder = props.onScrollShouldSetResponder,\n onScrollShouldSetResponderCapture = props.onScrollShouldSetResponderCapture,\n onSelectionChangeShouldSetResponder = props.onSelectionChangeShouldSetResponder,\n onSelectionChangeShouldSetResponderCapture = props.onSelectionChangeShouldSetResponderCapture,\n onStartShouldSetResponder = props.onStartShouldSetResponder,\n onStartShouldSetResponderCapture = props.onStartShouldSetResponderCapture,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n if (process.env.NODE_ENV !== 'production') {\n React.Children.toArray(props.children).forEach(item => {\n if (typeof item === 'string') {\n console.error(\"Unexpected text node: \" + item + \". A text node cannot be a child of a .\");\n }\n });\n }\n var hasTextAncestor = React.useContext(TextAncestorContext);\n var hostRef = React.useRef(null);\n var _useLocaleContext = useLocaleContext(),\n contextDirection = _useLocaleContext.direction;\n useElementLayout(hostRef, onLayout);\n useResponderEvents(hostRef, {\n onMoveShouldSetResponder,\n onMoveShouldSetResponderCapture,\n onResponderEnd,\n onResponderGrant,\n onResponderMove,\n onResponderReject,\n onResponderRelease,\n onResponderStart,\n onResponderTerminate,\n onResponderTerminationRequest,\n onScrollShouldSetResponder,\n onScrollShouldSetResponderCapture,\n onSelectionChangeShouldSetResponder,\n onSelectionChangeShouldSetResponderCapture,\n onStartShouldSetResponder,\n onStartShouldSetResponderCapture\n });\n var component = 'div';\n var langDirection = props.lang != null ? getLocaleDirection(props.lang) : null;\n var componentDirection = props.dir || langDirection;\n var writingDirection = componentDirection || contextDirection;\n var supportedProps = pickProps(rest);\n supportedProps.dir = componentDirection;\n supportedProps.style = [styles.view$raw, hasTextAncestor && styles.inline, props.style];\n if (props.href != null) {\n component = 'a';\n if (hrefAttrs != null) {\n var download = hrefAttrs.download,\n rel = hrefAttrs.rel,\n target = hrefAttrs.target;\n if (download != null) {\n supportedProps.download = download;\n }\n if (rel != null) {\n supportedProps.rel = rel;\n }\n if (typeof target === 'string') {\n supportedProps.target = target.charAt(0) !== '_' ? '_' + target : target;\n }\n }\n }\n var platformMethodsRef = usePlatformMethods(supportedProps);\n var setRef = useMergeRefs(hostRef, platformMethodsRef, forwardedRef);\n supportedProps.ref = setRef;\n return createElement(component, supportedProps, {\n writingDirection\n });\n});\nView.displayName = 'View';\nvar styles = StyleSheet.create({\n view$raw: {\n alignItems: 'stretch',\n backgroundColor: 'transparent',\n border: '0 solid black',\n boxSizing: 'border-box',\n display: 'flex',\n flexBasis: 'auto',\n flexDirection: 'column',\n flexShrink: 0,\n listStyle: 'none',\n margin: 0,\n minHeight: 0,\n minWidth: 0,\n padding: 0,\n position: 'relative',\n textDecoration: 'none',\n zIndex: 0\n },\n inline: {\n display: 'inline-flex'\n }\n});\nexport default View;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport AccessibilityUtil from '../../modules/AccessibilityUtil';\nimport createDOMProps from '../../modules/createDOMProps';\nimport React from 'react';\nimport { LocaleProvider } from '../../modules/useLocale';\nvar createElement = (component, props, options) => {\n // Use equivalent platform elements where possible.\n var accessibilityComponent;\n if (component && component.constructor === String) {\n accessibilityComponent = AccessibilityUtil.propsToAccessibilityComponent(props);\n }\n var Component = accessibilityComponent || component;\n var domProps = createDOMProps(Component, props, options);\n var element = /*#__PURE__*/React.createElement(Component, domProps);\n\n // Update locale context if element's writing direction prop changes\n var elementWithLocaleProvider = domProps.dir ? /*#__PURE__*/React.createElement(LocaleProvider, {\n children: element,\n direction: domProps.dir,\n locale: domProps.lang\n }) : element;\n return elementWithLocaleProvider;\n};\nexport default createElement;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport isDisabled from './isDisabled';\nimport propsToAccessibilityComponent from './propsToAccessibilityComponent';\nimport propsToAriaRole from './propsToAriaRole';\nvar AccessibilityUtil = {\n isDisabled,\n propsToAccessibilityComponent,\n propsToAriaRole\n};\nexport default AccessibilityUtil;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar isDisabled = props => props.disabled || Array.isArray(props.accessibilityStates) && props.accessibilityStates.indexOf('disabled') > -1;\nexport default isDisabled;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport propsToAriaRole from './propsToAriaRole';\nvar roleComponents = {\n article: 'article',\n banner: 'header',\n blockquote: 'blockquote',\n button: 'button',\n code: 'code',\n complementary: 'aside',\n contentinfo: 'footer',\n deletion: 'del',\n emphasis: 'em',\n figure: 'figure',\n insertion: 'ins',\n form: 'form',\n list: 'ul',\n listitem: 'li',\n main: 'main',\n navigation: 'nav',\n paragraph: 'p',\n region: 'section',\n strong: 'strong'\n};\nvar emptyObject = {};\nvar propsToAccessibilityComponent = function propsToAccessibilityComponent(props) {\n if (props === void 0) {\n props = emptyObject;\n }\n var roleProp = props.role || props.accessibilityRole;\n // special-case for \"label\" role which doesn't map to an ARIA role\n if (roleProp === 'label') {\n return 'label';\n }\n var role = propsToAriaRole(props);\n if (role) {\n if (role === 'heading') {\n var level = props.accessibilityLevel || props['aria-level'];\n if (level != null) {\n return \"h\" + level;\n }\n return 'h1';\n }\n return roleComponents[role];\n }\n};\nexport default propsToAccessibilityComponent;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar accessibilityRoleToWebRole = {\n adjustable: 'slider',\n button: 'button',\n header: 'heading',\n image: 'img',\n imagebutton: null,\n keyboardkey: null,\n label: null,\n link: 'link',\n none: 'presentation',\n search: 'search',\n summary: 'region',\n text: null\n};\nvar propsToAriaRole = _ref => {\n var accessibilityRole = _ref.accessibilityRole,\n role = _ref.role;\n var _role = role || accessibilityRole;\n if (_role) {\n var inferredRole = accessibilityRoleToWebRole[_role];\n if (inferredRole !== null) {\n // ignore roles that don't map to web\n return inferredRole || _role;\n }\n }\n};\nexport default propsToAriaRole;","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"aria-activedescendant\", \"accessibilityActiveDescendant\", \"aria-atomic\", \"accessibilityAtomic\", \"aria-autocomplete\", \"accessibilityAutoComplete\", \"aria-busy\", \"accessibilityBusy\", \"aria-checked\", \"accessibilityChecked\", \"aria-colcount\", \"accessibilityColumnCount\", \"aria-colindex\", \"accessibilityColumnIndex\", \"aria-colspan\", \"accessibilityColumnSpan\", \"aria-controls\", \"accessibilityControls\", \"aria-current\", \"accessibilityCurrent\", \"aria-describedby\", \"accessibilityDescribedBy\", \"aria-details\", \"accessibilityDetails\", \"aria-disabled\", \"accessibilityDisabled\", \"aria-errormessage\", \"accessibilityErrorMessage\", \"aria-expanded\", \"accessibilityExpanded\", \"aria-flowto\", \"accessibilityFlowTo\", \"aria-haspopup\", \"accessibilityHasPopup\", \"aria-hidden\", \"accessibilityHidden\", \"aria-invalid\", \"accessibilityInvalid\", \"aria-keyshortcuts\", \"accessibilityKeyShortcuts\", \"aria-label\", \"accessibilityLabel\", \"aria-labelledby\", \"accessibilityLabelledBy\", \"aria-level\", \"accessibilityLevel\", \"aria-live\", \"accessibilityLiveRegion\", \"aria-modal\", \"accessibilityModal\", \"aria-multiline\", \"accessibilityMultiline\", \"aria-multiselectable\", \"accessibilityMultiSelectable\", \"aria-orientation\", \"accessibilityOrientation\", \"aria-owns\", \"accessibilityOwns\", \"aria-placeholder\", \"accessibilityPlaceholder\", \"aria-posinset\", \"accessibilityPosInSet\", \"aria-pressed\", \"accessibilityPressed\", \"aria-readonly\", \"accessibilityReadOnly\", \"aria-required\", \"accessibilityRequired\", \"role\", \"accessibilityRole\", \"aria-roledescription\", \"accessibilityRoleDescription\", \"aria-rowcount\", \"accessibilityRowCount\", \"aria-rowindex\", \"accessibilityRowIndex\", \"aria-rowspan\", \"accessibilityRowSpan\", \"aria-selected\", \"accessibilitySelected\", \"aria-setsize\", \"accessibilitySetSize\", \"aria-sort\", \"accessibilitySort\", \"aria-valuemax\", \"accessibilityValueMax\", \"aria-valuemin\", \"accessibilityValueMin\", \"aria-valuenow\", \"accessibilityValueNow\", \"aria-valuetext\", \"accessibilityValueText\", \"dataSet\", \"focusable\", \"id\", \"nativeID\", \"pointerEvents\", \"style\", \"tabIndex\", \"testID\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport AccessibilityUtil from '../AccessibilityUtil';\nimport StyleSheet from '../../exports/StyleSheet';\nimport { warnOnce } from '../warnOnce';\nvar emptyObject = {};\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\nvar uppercasePattern = /[A-Z]/g;\nfunction toHyphenLower(match) {\n return '-' + match.toLowerCase();\n}\nfunction hyphenateString(str) {\n return str.replace(uppercasePattern, toHyphenLower);\n}\nfunction processIDRefList(idRefList) {\n return isArray(idRefList) ? idRefList.join(' ') : idRefList;\n}\nvar pointerEventsStyles = StyleSheet.create({\n auto: {\n pointerEvents: 'auto'\n },\n 'box-none': {\n pointerEvents: 'box-none'\n },\n 'box-only': {\n pointerEvents: 'box-only'\n },\n none: {\n pointerEvents: 'none'\n }\n});\nvar createDOMProps = (elementType, props, options) => {\n if (!props) {\n props = emptyObject;\n }\n var _props = props,\n ariaActiveDescendant = _props['aria-activedescendant'],\n accessibilityActiveDescendant = _props.accessibilityActiveDescendant,\n ariaAtomic = _props['aria-atomic'],\n accessibilityAtomic = _props.accessibilityAtomic,\n ariaAutoComplete = _props['aria-autocomplete'],\n accessibilityAutoComplete = _props.accessibilityAutoComplete,\n ariaBusy = _props['aria-busy'],\n accessibilityBusy = _props.accessibilityBusy,\n ariaChecked = _props['aria-checked'],\n accessibilityChecked = _props.accessibilityChecked,\n ariaColumnCount = _props['aria-colcount'],\n accessibilityColumnCount = _props.accessibilityColumnCount,\n ariaColumnIndex = _props['aria-colindex'],\n accessibilityColumnIndex = _props.accessibilityColumnIndex,\n ariaColumnSpan = _props['aria-colspan'],\n accessibilityColumnSpan = _props.accessibilityColumnSpan,\n ariaControls = _props['aria-controls'],\n accessibilityControls = _props.accessibilityControls,\n ariaCurrent = _props['aria-current'],\n accessibilityCurrent = _props.accessibilityCurrent,\n ariaDescribedBy = _props['aria-describedby'],\n accessibilityDescribedBy = _props.accessibilityDescribedBy,\n ariaDetails = _props['aria-details'],\n accessibilityDetails = _props.accessibilityDetails,\n ariaDisabled = _props['aria-disabled'],\n accessibilityDisabled = _props.accessibilityDisabled,\n ariaErrorMessage = _props['aria-errormessage'],\n accessibilityErrorMessage = _props.accessibilityErrorMessage,\n ariaExpanded = _props['aria-expanded'],\n accessibilityExpanded = _props.accessibilityExpanded,\n ariaFlowTo = _props['aria-flowto'],\n accessibilityFlowTo = _props.accessibilityFlowTo,\n ariaHasPopup = _props['aria-haspopup'],\n accessibilityHasPopup = _props.accessibilityHasPopup,\n ariaHidden = _props['aria-hidden'],\n accessibilityHidden = _props.accessibilityHidden,\n ariaInvalid = _props['aria-invalid'],\n accessibilityInvalid = _props.accessibilityInvalid,\n ariaKeyShortcuts = _props['aria-keyshortcuts'],\n accessibilityKeyShortcuts = _props.accessibilityKeyShortcuts,\n ariaLabel = _props['aria-label'],\n accessibilityLabel = _props.accessibilityLabel,\n ariaLabelledBy = _props['aria-labelledby'],\n accessibilityLabelledBy = _props.accessibilityLabelledBy,\n ariaLevel = _props['aria-level'],\n accessibilityLevel = _props.accessibilityLevel,\n ariaLive = _props['aria-live'],\n accessibilityLiveRegion = _props.accessibilityLiveRegion,\n ariaModal = _props['aria-modal'],\n accessibilityModal = _props.accessibilityModal,\n ariaMultiline = _props['aria-multiline'],\n accessibilityMultiline = _props.accessibilityMultiline,\n ariaMultiSelectable = _props['aria-multiselectable'],\n accessibilityMultiSelectable = _props.accessibilityMultiSelectable,\n ariaOrientation = _props['aria-orientation'],\n accessibilityOrientation = _props.accessibilityOrientation,\n ariaOwns = _props['aria-owns'],\n accessibilityOwns = _props.accessibilityOwns,\n ariaPlaceholder = _props['aria-placeholder'],\n accessibilityPlaceholder = _props.accessibilityPlaceholder,\n ariaPosInSet = _props['aria-posinset'],\n accessibilityPosInSet = _props.accessibilityPosInSet,\n ariaPressed = _props['aria-pressed'],\n accessibilityPressed = _props.accessibilityPressed,\n ariaReadOnly = _props['aria-readonly'],\n accessibilityReadOnly = _props.accessibilityReadOnly,\n ariaRequired = _props['aria-required'],\n accessibilityRequired = _props.accessibilityRequired,\n ariaRole = _props.role,\n accessibilityRole = _props.accessibilityRole,\n ariaRoleDescription = _props['aria-roledescription'],\n accessibilityRoleDescription = _props.accessibilityRoleDescription,\n ariaRowCount = _props['aria-rowcount'],\n accessibilityRowCount = _props.accessibilityRowCount,\n ariaRowIndex = _props['aria-rowindex'],\n accessibilityRowIndex = _props.accessibilityRowIndex,\n ariaRowSpan = _props['aria-rowspan'],\n accessibilityRowSpan = _props.accessibilityRowSpan,\n ariaSelected = _props['aria-selected'],\n accessibilitySelected = _props.accessibilitySelected,\n ariaSetSize = _props['aria-setsize'],\n accessibilitySetSize = _props.accessibilitySetSize,\n ariaSort = _props['aria-sort'],\n accessibilitySort = _props.accessibilitySort,\n ariaValueMax = _props['aria-valuemax'],\n accessibilityValueMax = _props.accessibilityValueMax,\n ariaValueMin = _props['aria-valuemin'],\n accessibilityValueMin = _props.accessibilityValueMin,\n ariaValueNow = _props['aria-valuenow'],\n accessibilityValueNow = _props.accessibilityValueNow,\n ariaValueText = _props['aria-valuetext'],\n accessibilityValueText = _props.accessibilityValueText,\n dataSet = _props.dataSet,\n focusable = _props.focusable,\n id = _props.id,\n nativeID = _props.nativeID,\n pointerEvents = _props.pointerEvents,\n style = _props.style,\n tabIndex = _props.tabIndex,\n testID = _props.testID,\n domProps = _objectWithoutPropertiesLoose(_props, _excluded);\n if (accessibilityDisabled != null) {\n warnOnce('accessibilityDisabled', \"accessibilityDisabled is deprecated.\");\n }\n var disabled = ariaDisabled || accessibilityDisabled;\n var role = AccessibilityUtil.propsToAriaRole(props);\n\n // ACCESSIBILITY\n if (accessibilityActiveDescendant != null) {\n warnOnce('accessibilityActiveDescendant', \"accessibilityActiveDescendant is deprecated. Use aria-activedescendant.\");\n }\n var _ariaActiveDescendant = ariaActiveDescendant != null ? ariaActiveDescendant : accessibilityActiveDescendant;\n if (_ariaActiveDescendant != null) {\n domProps['aria-activedescendant'] = _ariaActiveDescendant;\n }\n if (accessibilityAtomic != null) {\n warnOnce('accessibilityAtomic', \"accessibilityAtomic is deprecated. Use aria-atomic.\");\n }\n var _ariaAtomic = ariaAtomic != null ? ariaActiveDescendant : accessibilityAtomic;\n if (_ariaAtomic != null) {\n domProps['aria-atomic'] = _ariaAtomic;\n }\n if (accessibilityAutoComplete != null) {\n warnOnce('accessibilityAutoComplete', \"accessibilityAutoComplete is deprecated. Use aria-autocomplete.\");\n }\n var _ariaAutoComplete = ariaAutoComplete != null ? ariaAutoComplete : accessibilityAutoComplete;\n if (_ariaAutoComplete != null) {\n domProps['aria-autocomplete'] = _ariaAutoComplete;\n }\n if (accessibilityBusy != null) {\n warnOnce('accessibilityBusy', \"accessibilityBusy is deprecated. Use aria-busy.\");\n }\n var _ariaBusy = ariaBusy != null ? ariaBusy : accessibilityBusy;\n if (_ariaBusy != null) {\n domProps['aria-busy'] = _ariaBusy;\n }\n if (accessibilityChecked != null) {\n warnOnce('accessibilityChecked', \"accessibilityChecked is deprecated. Use aria-checked.\");\n }\n var _ariaChecked = ariaChecked != null ? ariaChecked : accessibilityChecked;\n if (_ariaChecked != null) {\n domProps['aria-checked'] = _ariaChecked;\n }\n if (accessibilityColumnCount != null) {\n warnOnce('accessibilityColumnCount', \"accessibilityColumnCount is deprecated. Use aria-colcount.\");\n }\n var _ariaColumnCount = ariaColumnCount != null ? ariaColumnCount : accessibilityColumnCount;\n if (_ariaColumnCount != null) {\n domProps['aria-colcount'] = _ariaColumnCount;\n }\n if (accessibilityColumnIndex != null) {\n warnOnce('accessibilityColumnIndex', \"accessibilityColumnIndex is deprecated. Use aria-colindex.\");\n }\n var _ariaColumnIndex = ariaColumnIndex != null ? ariaColumnIndex : accessibilityColumnIndex;\n if (_ariaColumnIndex != null) {\n domProps['aria-colindex'] = _ariaColumnIndex;\n }\n if (accessibilityColumnSpan != null) {\n warnOnce('accessibilityColumnSpan', \"accessibilityColumnSpan is deprecated. Use aria-colspan.\");\n }\n var _ariaColumnSpan = ariaColumnSpan != null ? ariaColumnSpan : accessibilityColumnSpan;\n if (_ariaColumnSpan != null) {\n domProps['aria-colspan'] = _ariaColumnSpan;\n }\n if (accessibilityControls != null) {\n warnOnce('accessibilityControls', \"accessibilityControls is deprecated. Use aria-controls.\");\n }\n var _ariaControls = ariaControls != null ? ariaControls : accessibilityControls;\n if (_ariaControls != null) {\n domProps['aria-controls'] = processIDRefList(_ariaControls);\n }\n if (accessibilityCurrent != null) {\n warnOnce('accessibilityCurrent', \"accessibilityCurrent is deprecated. Use aria-current.\");\n }\n var _ariaCurrent = ariaCurrent != null ? ariaCurrent : accessibilityCurrent;\n if (_ariaCurrent != null) {\n domProps['aria-current'] = _ariaCurrent;\n }\n if (accessibilityDescribedBy != null) {\n warnOnce('accessibilityDescribedBy', \"accessibilityDescribedBy is deprecated. Use aria-describedby.\");\n }\n var _ariaDescribedBy = ariaDescribedBy != null ? ariaDescribedBy : accessibilityDescribedBy;\n if (_ariaDescribedBy != null) {\n domProps['aria-describedby'] = processIDRefList(_ariaDescribedBy);\n }\n if (accessibilityDetails != null) {\n warnOnce('accessibilityDetails', \"accessibilityDetails is deprecated. Use aria-details.\");\n }\n var _ariaDetails = ariaDetails != null ? ariaDetails : accessibilityDetails;\n if (_ariaDetails != null) {\n domProps['aria-details'] = _ariaDetails;\n }\n if (disabled === true) {\n domProps['aria-disabled'] = true;\n // Enhance with native semantics\n if (elementType === 'button' || elementType === 'form' || elementType === 'input' || elementType === 'select' || elementType === 'textarea') {\n domProps.disabled = true;\n }\n }\n if (accessibilityErrorMessage != null) {\n warnOnce('accessibilityErrorMessage', \"accessibilityErrorMessage is deprecated. Use aria-errormessage.\");\n }\n var _ariaErrorMessage = ariaErrorMessage != null ? ariaErrorMessage : accessibilityErrorMessage;\n if (_ariaErrorMessage != null) {\n domProps['aria-errormessage'] = _ariaErrorMessage;\n }\n if (accessibilityExpanded != null) {\n warnOnce('accessibilityExpanded', \"accessibilityExpanded is deprecated. Use aria-expanded.\");\n }\n var _ariaExpanded = ariaExpanded != null ? ariaExpanded : accessibilityExpanded;\n if (_ariaExpanded != null) {\n domProps['aria-expanded'] = _ariaExpanded;\n }\n if (accessibilityFlowTo != null) {\n warnOnce('accessibilityFlowTo', \"accessibilityFlowTo is deprecated. Use aria-flowto.\");\n }\n var _ariaFlowTo = ariaFlowTo != null ? ariaFlowTo : accessibilityFlowTo;\n if (_ariaFlowTo != null) {\n domProps['aria-flowto'] = processIDRefList(_ariaFlowTo);\n }\n if (accessibilityHasPopup != null) {\n warnOnce('accessibilityHasPopup', \"accessibilityHasPopup is deprecated. Use aria-haspopup.\");\n }\n var _ariaHasPopup = ariaHasPopup != null ? ariaHasPopup : accessibilityHasPopup;\n if (_ariaHasPopup != null) {\n domProps['aria-haspopup'] = _ariaHasPopup;\n }\n if (accessibilityHidden != null) {\n warnOnce('accessibilityHidden', \"accessibilityHidden is deprecated. Use aria-hidden.\");\n }\n var _ariaHidden = ariaHidden != null ? ariaHidden : accessibilityHidden;\n if (_ariaHidden === true) {\n domProps['aria-hidden'] = _ariaHidden;\n }\n if (accessibilityInvalid != null) {\n warnOnce('accessibilityInvalid', \"accessibilityInvalid is deprecated. Use aria-invalid.\");\n }\n var _ariaInvalid = ariaInvalid != null ? ariaInvalid : accessibilityInvalid;\n if (_ariaInvalid != null) {\n domProps['aria-invalid'] = _ariaInvalid;\n }\n if (accessibilityKeyShortcuts != null) {\n warnOnce('accessibilityKeyShortcuts', \"accessibilityKeyShortcuts is deprecated. Use aria-keyshortcuts.\");\n }\n var _ariaKeyShortcuts = ariaKeyShortcuts != null ? ariaKeyShortcuts : accessibilityKeyShortcuts;\n if (_ariaKeyShortcuts != null) {\n domProps['aria-keyshortcuts'] = processIDRefList(_ariaKeyShortcuts);\n }\n if (accessibilityLabel != null) {\n warnOnce('accessibilityLabel', \"accessibilityLabel is deprecated. Use aria-label.\");\n }\n var _ariaLabel = ariaLabel != null ? ariaLabel : accessibilityLabel;\n if (_ariaLabel != null) {\n domProps['aria-label'] = _ariaLabel;\n }\n if (accessibilityLabelledBy != null) {\n warnOnce('accessibilityLabelledBy', \"accessibilityLabelledBy is deprecated. Use aria-labelledby.\");\n }\n var _ariaLabelledBy = ariaLabelledBy != null ? ariaLabelledBy : accessibilityLabelledBy;\n if (_ariaLabelledBy != null) {\n domProps['aria-labelledby'] = processIDRefList(_ariaLabelledBy);\n }\n if (accessibilityLevel != null) {\n warnOnce('accessibilityLevel', \"accessibilityLevel is deprecated. Use aria-level.\");\n }\n var _ariaLevel = ariaLevel != null ? ariaLevel : accessibilityLevel;\n if (_ariaLevel != null) {\n domProps['aria-level'] = _ariaLevel;\n }\n if (accessibilityLiveRegion != null) {\n warnOnce('accessibilityLiveRegion', \"accessibilityLiveRegion is deprecated. Use aria-live.\");\n }\n var _ariaLive = ariaLive != null ? ariaLive : accessibilityLiveRegion;\n if (_ariaLive != null) {\n domProps['aria-live'] = _ariaLive === 'none' ? 'off' : _ariaLive;\n }\n if (accessibilityModal != null) {\n warnOnce('accessibilityModal', \"accessibilityModal is deprecated. Use aria-modal.\");\n }\n var _ariaModal = ariaModal != null ? ariaModal : accessibilityModal;\n if (_ariaModal != null) {\n domProps['aria-modal'] = _ariaModal;\n }\n if (accessibilityMultiline != null) {\n warnOnce('accessibilityMultiline', \"accessibilityMultiline is deprecated. Use aria-multiline.\");\n }\n var _ariaMultiline = ariaMultiline != null ? ariaMultiline : accessibilityMultiline;\n if (_ariaMultiline != null) {\n domProps['aria-multiline'] = _ariaMultiline;\n }\n if (accessibilityMultiSelectable != null) {\n warnOnce('accessibilityMultiSelectable', \"accessibilityMultiSelectable is deprecated. Use aria-multiselectable.\");\n }\n var _ariaMultiSelectable = ariaMultiSelectable != null ? ariaMultiSelectable : accessibilityMultiSelectable;\n if (_ariaMultiSelectable != null) {\n domProps['aria-multiselectable'] = _ariaMultiSelectable;\n }\n if (accessibilityOrientation != null) {\n warnOnce('accessibilityOrientation', \"accessibilityOrientation is deprecated. Use aria-orientation.\");\n }\n var _ariaOrientation = ariaOrientation != null ? ariaOrientation : accessibilityOrientation;\n if (_ariaOrientation != null) {\n domProps['aria-orientation'] = _ariaOrientation;\n }\n if (accessibilityOwns != null) {\n warnOnce('accessibilityOwns', \"accessibilityOwns is deprecated. Use aria-owns.\");\n }\n var _ariaOwns = ariaOwns != null ? ariaOwns : accessibilityOwns;\n if (_ariaOwns != null) {\n domProps['aria-owns'] = processIDRefList(_ariaOwns);\n }\n if (accessibilityPlaceholder != null) {\n warnOnce('accessibilityPlaceholder', \"accessibilityPlaceholder is deprecated. Use aria-placeholder.\");\n }\n var _ariaPlaceholder = ariaPlaceholder != null ? ariaPlaceholder : accessibilityPlaceholder;\n if (_ariaPlaceholder != null) {\n domProps['aria-placeholder'] = _ariaPlaceholder;\n }\n if (accessibilityPosInSet != null) {\n warnOnce('accessibilityPosInSet', \"accessibilityPosInSet is deprecated. Use aria-posinset.\");\n }\n var _ariaPosInSet = ariaPosInSet != null ? ariaPosInSet : accessibilityPosInSet;\n if (_ariaPosInSet != null) {\n domProps['aria-posinset'] = _ariaPosInSet;\n }\n if (accessibilityPressed != null) {\n warnOnce('accessibilityPressed', \"accessibilityPressed is deprecated. Use aria-pressed.\");\n }\n var _ariaPressed = ariaPressed != null ? ariaPressed : accessibilityPressed;\n if (_ariaPressed != null) {\n domProps['aria-pressed'] = _ariaPressed;\n }\n if (accessibilityReadOnly != null) {\n warnOnce('accessibilityReadOnly', \"accessibilityReadOnly is deprecated. Use aria-readonly.\");\n }\n var _ariaReadOnly = ariaReadOnly != null ? ariaReadOnly : accessibilityReadOnly;\n if (_ariaReadOnly != null) {\n domProps['aria-readonly'] = _ariaReadOnly;\n // Enhance with native semantics\n if (elementType === 'input' || elementType === 'select' || elementType === 'textarea') {\n domProps.readOnly = true;\n }\n }\n if (accessibilityRequired != null) {\n warnOnce('accessibilityRequired', \"accessibilityRequired is deprecated. Use aria-required.\");\n }\n var _ariaRequired = ariaRequired != null ? ariaRequired : accessibilityRequired;\n if (_ariaRequired != null) {\n domProps['aria-required'] = _ariaRequired;\n // Enhance with native semantics\n if (elementType === 'input' || elementType === 'select' || elementType === 'textarea') {\n domProps.required = accessibilityRequired;\n }\n }\n if (accessibilityRole != null) {\n warnOnce('accessibilityRole', \"accessibilityRole is deprecated. Use role.\");\n }\n if (role != null) {\n // 'presentation' synonym has wider browser support\n domProps['role'] = role === 'none' ? 'presentation' : role;\n }\n if (accessibilityRoleDescription != null) {\n warnOnce('accessibilityRoleDescription', \"accessibilityRoleDescription is deprecated. Use aria-roledescription.\");\n }\n var _ariaRoleDescription = ariaRoleDescription != null ? ariaRoleDescription : accessibilityRoleDescription;\n if (_ariaRoleDescription != null) {\n domProps['aria-roledescription'] = _ariaRoleDescription;\n }\n if (accessibilityRowCount != null) {\n warnOnce('accessibilityRowCount', \"accessibilityRowCount is deprecated. Use aria-rowcount.\");\n }\n var _ariaRowCount = ariaRowCount != null ? ariaRowCount : accessibilityRowCount;\n if (_ariaRowCount != null) {\n domProps['aria-rowcount'] = _ariaRowCount;\n }\n if (accessibilityRowIndex != null) {\n warnOnce('accessibilityRowIndex', \"accessibilityRowIndex is deprecated. Use aria-rowindex.\");\n }\n var _ariaRowIndex = ariaRowIndex != null ? ariaRowIndex : accessibilityRowIndex;\n if (_ariaRowIndex != null) {\n domProps['aria-rowindex'] = _ariaRowIndex;\n }\n if (accessibilityRowSpan != null) {\n warnOnce('accessibilityRowSpan', \"accessibilityRowSpan is deprecated. Use aria-rowspan.\");\n }\n var _ariaRowSpan = ariaRowSpan != null ? ariaRowSpan : accessibilityRowSpan;\n if (_ariaRowSpan != null) {\n domProps['aria-rowspan'] = _ariaRowSpan;\n }\n if (accessibilitySelected != null) {\n warnOnce('accessibilitySelected', \"accessibilitySelected is deprecated. Use aria-selected.\");\n }\n var _ariaSelected = ariaSelected != null ? ariaSelected : accessibilitySelected;\n if (_ariaSelected != null) {\n domProps['aria-selected'] = _ariaSelected;\n }\n if (accessibilitySetSize != null) {\n warnOnce('accessibilitySetSize', \"accessibilitySetSize is deprecated. Use aria-setsize.\");\n }\n var _ariaSetSize = ariaSetSize != null ? ariaSetSize : accessibilitySetSize;\n if (_ariaSetSize != null) {\n domProps['aria-setsize'] = _ariaSetSize;\n }\n if (accessibilitySort != null) {\n warnOnce('accessibilitySort', \"accessibilitySort is deprecated. Use aria-sort.\");\n }\n var _ariaSort = ariaSort != null ? ariaSort : accessibilitySort;\n if (_ariaSort != null) {\n domProps['aria-sort'] = _ariaSort;\n }\n if (accessibilityValueMax != null) {\n warnOnce('accessibilityValueMax', \"accessibilityValueMax is deprecated. Use aria-valuemax.\");\n }\n var _ariaValueMax = ariaValueMax != null ? ariaValueMax : accessibilityValueMax;\n if (_ariaValueMax != null) {\n domProps['aria-valuemax'] = _ariaValueMax;\n }\n if (accessibilityValueMin != null) {\n warnOnce('accessibilityValueMin', \"accessibilityValueMin is deprecated. Use aria-valuemin.\");\n }\n var _ariaValueMin = ariaValueMin != null ? ariaValueMin : accessibilityValueMin;\n if (_ariaValueMin != null) {\n domProps['aria-valuemin'] = _ariaValueMin;\n }\n if (accessibilityValueNow != null) {\n warnOnce('accessibilityValueNow', \"accessibilityValueNow is deprecated. Use aria-valuenow.\");\n }\n var _ariaValueNow = ariaValueNow != null ? ariaValueNow : accessibilityValueNow;\n if (_ariaValueNow != null) {\n domProps['aria-valuenow'] = _ariaValueNow;\n }\n if (accessibilityValueText != null) {\n warnOnce('accessibilityValueText', \"accessibilityValueText is deprecated. Use aria-valuetext.\");\n }\n var _ariaValueText = ariaValueText != null ? ariaValueText : accessibilityValueText;\n if (_ariaValueText != null) {\n domProps['aria-valuetext'] = _ariaValueText;\n }\n\n // \"dataSet\" replaced with \"data-*\"\n if (dataSet != null) {\n for (var dataProp in dataSet) {\n if (hasOwnProperty.call(dataSet, dataProp)) {\n var dataName = hyphenateString(dataProp);\n var dataValue = dataSet[dataProp];\n if (dataValue != null) {\n domProps[\"data-\" + dataName] = dataValue;\n }\n }\n }\n }\n\n // FOCUS\n if (tabIndex === 0 || tabIndex === '0' || tabIndex === -1 || tabIndex === '-1') {\n domProps.tabIndex = tabIndex;\n } else {\n if (focusable != null) {\n warnOnce('focusable', \"focusable is deprecated.\");\n }\n\n // \"focusable\" indicates that an element may be a keyboard tab-stop.\n if (focusable === false) {\n domProps.tabIndex = '-1';\n }\n if (\n // These native elements are keyboard focusable by default\n elementType === 'a' || elementType === 'button' || elementType === 'input' || elementType === 'select' || elementType === 'textarea') {\n if (focusable === false || accessibilityDisabled === true) {\n domProps.tabIndex = '-1';\n }\n } else if (\n // These roles are made keyboard focusable by default\n role === 'button' || role === 'checkbox' || role === 'link' || role === 'radio' || role === 'textbox' || role === 'switch') {\n if (focusable !== false) {\n domProps.tabIndex = '0';\n }\n } else {\n // Everything else must explicitly set the prop\n if (focusable === true) {\n domProps.tabIndex = '0';\n }\n }\n }\n\n // Resolve styles\n if (pointerEvents != null) {\n warnOnce('pointerEvents', \"props.pointerEvents is deprecated. Use style.pointerEvents\");\n }\n var _StyleSheet = StyleSheet([style, pointerEvents && pointerEventsStyles[pointerEvents]], _objectSpread({\n writingDirection: 'ltr'\n }, options)),\n className = _StyleSheet[0],\n inlineStyle = _StyleSheet[1];\n if (className) {\n domProps.className = className;\n }\n if (inlineStyle) {\n domProps.style = inlineStyle;\n }\n\n // OTHER\n // Native element ID\n if (nativeID != null) {\n warnOnce('nativeID', \"nativeID is deprecated. Use id.\");\n }\n var _id = id != null ? id : nativeID;\n if (_id != null) {\n domProps.id = _id;\n }\n // Automated test IDs\n if (testID != null) {\n domProps['data-testid'] = testID;\n }\n if (domProps.type == null && elementType === 'button') {\n domProps.type = 'button';\n }\n return domProps;\n};\nexport default createDOMProps;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport React, { createContext, useContext } from 'react';\nimport { isLocaleRTL } from './isLocaleRTL';\nvar defaultLocale = {\n direction: 'ltr',\n locale: 'en-US'\n};\nvar LocaleContext = /*#__PURE__*/createContext(defaultLocale);\nexport function getLocaleDirection(locale) {\n return isLocaleRTL(locale) ? 'rtl' : 'ltr';\n}\nexport function LocaleProvider(props) {\n var direction = props.direction,\n locale = props.locale,\n children = props.children;\n var needsContext = direction || locale;\n return needsContext ? /*#__PURE__*/React.createElement(LocaleContext.Provider, {\n children: children,\n value: {\n direction: locale ? getLocaleDirection(locale) : direction,\n locale\n }\n }) : children;\n}\nexport function useLocaleContext() {\n return useContext(LocaleContext);\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar rtlScripts = new Set(['Arab', 'Syrc', 'Samr', 'Mand', 'Thaa', 'Mend', 'Nkoo', 'Adlm', 'Rohg', 'Hebr']);\nvar rtlLangs = new Set(['ae',\n// Avestan\n'ar',\n// Arabic\n'arc',\n// Aramaic\n'bcc',\n// Southern Balochi\n'bqi',\n// Bakthiari\n'ckb',\n// Sorani\n'dv',\n// Dhivehi\n'fa', 'far',\n// Persian\n'glk',\n// Gilaki\n'he', 'iw',\n// Hebrew\n'khw',\n// Khowar\n'ks',\n// Kashmiri\n'ku',\n// Kurdish\n'mzn',\n// Mazanderani\n'nqo',\n// N'Ko\n'pnb',\n// Western Punjabi\n'ps',\n// Pashto\n'sd',\n// Sindhi\n'ug',\n// Uyghur\n'ur',\n// Urdu\n'yi' // Yiddish\n]);\n\nvar cache = new Map();\n\n/**\n * Determine the writing direction of a locale\n */\nexport function isLocaleRTL(locale) {\n var cachedRTL = cache.get(locale);\n if (cachedRTL) {\n return cachedRTL;\n }\n var isRTL = false;\n // $FlowFixMe\n if (Intl.Locale) {\n // $FlowFixMe\n var script = new Intl.Locale(locale).maximize().script;\n isRTL = rtlScripts.has(script);\n } else {\n // Fallback to inferring from language\n var lang = locale.split('-')[0];\n isRTL = rtlLangs.has(lang);\n }\n cache.set(locale, isRTL);\n return isRTL;\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nexport var defaultProps = {\n children: true,\n dataSet: true,\n dir: true,\n id: true,\n ref: true,\n suppressHydrationWarning: true,\n tabIndex: true,\n testID: true,\n // @deprecated\n focusable: true,\n nativeID: true\n};\nexport var accessibilityProps = {\n 'aria-activedescendant': true,\n 'aria-atomic': true,\n 'aria-autocomplete': true,\n 'aria-busy': true,\n 'aria-checked': true,\n 'aria-colcount': true,\n 'aria-colindex': true,\n 'aria-colspan': true,\n 'aria-controls': true,\n 'aria-current': true,\n 'aria-describedby': true,\n 'aria-details': true,\n 'aria-disabled': true,\n 'aria-errormessage': true,\n 'aria-expanded': true,\n 'aria-flowto': true,\n 'aria-haspopup': true,\n 'aria-hidden': true,\n 'aria-invalid': true,\n 'aria-keyshortcuts': true,\n 'aria-label': true,\n 'aria-labelledby': true,\n 'aria-level': true,\n 'aria-live': true,\n 'aria-modal': true,\n 'aria-multiline': true,\n 'aria-multiselectable': true,\n 'aria-orientation': true,\n 'aria-owns': true,\n 'aria-placeholder': true,\n 'aria-posinset': true,\n 'aria-pressed': true,\n 'aria-readonly': true,\n 'aria-required': true,\n role: true,\n 'aria-roledescription': true,\n 'aria-rowcount': true,\n 'aria-rowindex': true,\n 'aria-rowspan': true,\n 'aria-selected': true,\n 'aria-setsize': true,\n 'aria-sort': true,\n 'aria-valuemax': true,\n 'aria-valuemin': true,\n 'aria-valuenow': true,\n 'aria-valuetext': true,\n // @deprecated\n accessibilityActiveDescendant: true,\n accessibilityAtomic: true,\n accessibilityAutoComplete: true,\n accessibilityBusy: true,\n accessibilityChecked: true,\n accessibilityColumnCount: true,\n accessibilityColumnIndex: true,\n accessibilityColumnSpan: true,\n accessibilityControls: true,\n accessibilityCurrent: true,\n accessibilityDescribedBy: true,\n accessibilityDetails: true,\n accessibilityDisabled: true,\n accessibilityErrorMessage: true,\n accessibilityExpanded: true,\n accessibilityFlowTo: true,\n accessibilityHasPopup: true,\n accessibilityHidden: true,\n accessibilityInvalid: true,\n accessibilityKeyShortcuts: true,\n accessibilityLabel: true,\n accessibilityLabelledBy: true,\n accessibilityLevel: true,\n accessibilityLiveRegion: true,\n accessibilityModal: true,\n accessibilityMultiline: true,\n accessibilityMultiSelectable: true,\n accessibilityOrientation: true,\n accessibilityOwns: true,\n accessibilityPlaceholder: true,\n accessibilityPosInSet: true,\n accessibilityPressed: true,\n accessibilityReadOnly: true,\n accessibilityRequired: true,\n accessibilityRole: true,\n accessibilityRoleDescription: true,\n accessibilityRowCount: true,\n accessibilityRowIndex: true,\n accessibilityRowSpan: true,\n accessibilitySelected: true,\n accessibilitySetSize: true,\n accessibilitySort: true,\n accessibilityValueMax: true,\n accessibilityValueMin: true,\n accessibilityValueNow: true,\n accessibilityValueText: true\n};\nexport var clickProps = {\n onClick: true,\n onAuxClick: true,\n onContextMenu: true,\n onGotPointerCapture: true,\n onLostPointerCapture: true,\n onPointerCancel: true,\n onPointerDown: true,\n onPointerEnter: true,\n onPointerMove: true,\n onPointerLeave: true,\n onPointerOut: true,\n onPointerOver: true,\n onPointerUp: true\n};\nexport var focusProps = {\n onBlur: true,\n onFocus: true\n};\nexport var keyboardProps = {\n onKeyDown: true,\n onKeyDownCapture: true,\n onKeyUp: true,\n onKeyUpCapture: true\n};\nexport var mouseProps = {\n onMouseDown: true,\n onMouseEnter: true,\n onMouseLeave: true,\n onMouseMove: true,\n onMouseOver: true,\n onMouseOut: true,\n onMouseUp: true\n};\nexport var touchProps = {\n onTouchCancel: true,\n onTouchCancelCapture: true,\n onTouchEnd: true,\n onTouchEndCapture: true,\n onTouchMove: true,\n onTouchMoveCapture: true,\n onTouchStart: true,\n onTouchStartCapture: true\n};\nexport var styleProps = {\n style: true\n};","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nexport default function pick(obj, list) {\n var nextObj = {};\n for (var key in obj) {\n if (obj.hasOwnProperty(key)) {\n if (list[key] === true) {\n nextObj[key] = obj[key];\n }\n }\n }\n return nextObj;\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport useLayoutEffect from '../useLayoutEffect';\nimport UIManager from '../../exports/UIManager';\nimport canUseDOM from '../canUseDom';\nvar DOM_LAYOUT_HANDLER_NAME = '__reactLayoutHandler';\nvar didWarn = !canUseDOM;\nvar resizeObserver = null;\nfunction getResizeObserver() {\n if (canUseDOM && typeof window.ResizeObserver !== 'undefined') {\n if (resizeObserver == null) {\n resizeObserver = new window.ResizeObserver(function (entries) {\n entries.forEach(entry => {\n var node = entry.target;\n var onLayout = node[DOM_LAYOUT_HANDLER_NAME];\n if (typeof onLayout === 'function') {\n // We still need to measure the view because browsers don't yet provide\n // border-box dimensions in the entry\n UIManager.measure(node, (x, y, width, height, left, top) => {\n var event = {\n // $FlowFixMe\n nativeEvent: {\n layout: {\n x,\n y,\n width,\n height,\n left,\n top\n }\n },\n timeStamp: Date.now()\n };\n Object.defineProperty(event.nativeEvent, 'target', {\n enumerable: true,\n get: () => entry.target\n });\n onLayout(event);\n });\n }\n });\n });\n }\n } else if (!didWarn) {\n if (process.env.NODE_ENV !== 'production' && process.env.NODE_ENV !== 'test') {\n console.warn('onLayout relies on ResizeObserver which is not supported by your browser. ' + 'Please include a polyfill, e.g., https://github.com/que-etc/resize-observer-polyfill.');\n didWarn = true;\n }\n }\n return resizeObserver;\n}\nexport default function useElementLayout(ref, onLayout) {\n var observer = getResizeObserver();\n useLayoutEffect(() => {\n var node = ref.current;\n if (node != null) {\n node[DOM_LAYOUT_HANDLER_NAME] = onLayout;\n }\n }, [ref, onLayout]);\n\n // Observing is done in a separate effect to avoid this effect running\n // when 'onLayout' changes.\n useLayoutEffect(() => {\n var node = ref.current;\n if (node != null && observer != null) {\n if (typeof node[DOM_LAYOUT_HANDLER_NAME] === 'function') {\n observer.observe(node);\n } else {\n observer.unobserve(node);\n }\n }\n return () => {\n if (node != null && observer != null) {\n observer.unobserve(node);\n }\n };\n }, [ref, observer]);\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * useLayoutEffect throws an error on the server. On the few occasions where is\n * problematic, use this hook.\n *\n * \n */\n\nimport { useEffect, useLayoutEffect } from 'react';\nimport canUseDOM from '../canUseDom';\nvar useLayoutEffectImpl = canUseDOM ? useLayoutEffect : useEffect;\nexport default useLayoutEffectImpl;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport getBoundingClientRect from '../../modules/getBoundingClientRect';\nimport setValueForStyles from '../../modules/setValueForStyles';\nvar getRect = node => {\n var height = node.offsetHeight;\n var width = node.offsetWidth;\n var left = node.offsetLeft;\n var top = node.offsetTop;\n node = node.offsetParent;\n while (node && node.nodeType === 1 /* Node.ELEMENT_NODE */) {\n left += node.offsetLeft + node.clientLeft - node.scrollLeft;\n top += node.offsetTop + node.clientTop - node.scrollTop;\n node = node.offsetParent;\n }\n top -= window.scrollY;\n left -= window.scrollX;\n return {\n width,\n height,\n top,\n left\n };\n};\nvar measureLayout = (node, relativeToNativeNode, callback) => {\n var relativeNode = relativeToNativeNode || node && node.parentNode;\n if (node && relativeNode) {\n setTimeout(() => {\n if (node.isConnected && relativeNode.isConnected) {\n var relativeRect = getRect(relativeNode);\n var _getRect = getRect(node),\n height = _getRect.height,\n left = _getRect.left,\n top = _getRect.top,\n width = _getRect.width;\n var x = left - relativeRect.left;\n var y = top - relativeRect.top;\n callback(x, y, width, height, left, top);\n }\n }, 0);\n }\n};\nvar elementsToIgnore = {\n A: true,\n BODY: true,\n INPUT: true,\n SELECT: true,\n TEXTAREA: true\n};\nvar UIManager = {\n blur(node) {\n try {\n node.blur();\n } catch (err) {}\n },\n focus(node) {\n try {\n var name = node.nodeName;\n // A tabIndex of -1 allows element to be programmatically focused but\n // prevents keyboard focus. We don't want to set the tabindex value on\n // elements that should not prevent keyboard focus.\n if (node.getAttribute('tabIndex') == null && node.isContentEditable !== true && elementsToIgnore[name] == null) {\n node.setAttribute('tabIndex', '-1');\n }\n node.focus();\n } catch (err) {}\n },\n measure(node, callback) {\n measureLayout(node, null, callback);\n },\n measureInWindow(node, callback) {\n if (node) {\n setTimeout(() => {\n var _getBoundingClientRec = getBoundingClientRect(node),\n height = _getBoundingClientRec.height,\n left = _getBoundingClientRec.left,\n top = _getBoundingClientRec.top,\n width = _getBoundingClientRec.width;\n callback(left, top, width, height);\n }, 0);\n }\n },\n measureLayout(node, relativeToNativeNode, onFail, onSuccess) {\n measureLayout(node, relativeToNativeNode, onSuccess);\n },\n updateView(node, props) {\n for (var prop in props) {\n if (!Object.prototype.hasOwnProperty.call(props, prop)) {\n continue;\n }\n var value = props[prop];\n switch (prop) {\n case 'style':\n {\n setValueForStyles(node, value);\n break;\n }\n case 'class':\n case 'className':\n {\n node.setAttribute('class', value);\n break;\n }\n case 'text':\n case 'value':\n // native platforms use `text` prop to replace text input value\n node.value = value;\n break;\n default:\n node.setAttribute(prop, value);\n }\n }\n },\n configureNextLayoutAnimation(config, onAnimationDidEnd) {\n onAnimationDidEnd();\n },\n // mocks\n setLayoutAnimationEnabledExperimental() {}\n};\nexport default UIManager;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar getBoundingClientRect = node => {\n if (node != null) {\n var isElement = node.nodeType === 1; /* Node.ELEMENT_NODE */\n if (isElement && typeof node.getBoundingClientRect === 'function') {\n return node.getBoundingClientRect();\n }\n }\n};\nexport default getBoundingClientRect;","/* eslint-disable */\n\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * From React 16.3.0\n * \n */\n\nimport dangerousStyleValue from './dangerousStyleValue';\n\n/**\n * Sets the value for multiple styles on a node. If a value is specified as\n * '' (empty string), the corresponding style property will be unset.\n *\n * @param {DOMElement} node\n * @param {object} styles\n */\nfunction setValueForStyles(node, styles) {\n var style = node.style;\n for (var styleName in styles) {\n if (!styles.hasOwnProperty(styleName)) {\n continue;\n }\n var isCustomProperty = styleName.indexOf('--') === 0;\n var styleValue = dangerousStyleValue(styleName, styles[styleName], isCustomProperty);\n if (styleName === 'float') {\n styleName = 'cssFloat';\n }\n if (isCustomProperty) {\n style.setProperty(styleName, styleValue);\n } else {\n style[styleName] = styleValue;\n }\n }\n}\nexport default setValueForStyles;","/* eslint-disable */\n\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * From React 16.0.0\n * \n */\n\nimport isUnitlessNumber from '../unitlessNumbers';\n\n/**\n * Convert a value into the proper css writable value. The style name `name`\n * should be logical (no hyphens), as specified\n * in `CSSProperty.isUnitlessNumber`.\n *\n * @param {string} name CSS property name such as `topMargin`.\n * @param {*} value CSS property value such as `10px`.\n * @return {string} Normalized style value with dimensions applied.\n */\nfunction dangerousStyleValue(name, value, isCustomProperty) {\n // Note that we've removed escapeTextForBrowser() calls here since the\n // whole string will be escaped when the attribute is injected into\n // the markup. If you provide unsafe user data here they can inject\n // arbitrary CSS which may be problematic (I couldn't repro this):\n // https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet\n // http://www.thespanner.co.uk/2007/11/26/ultimate-xss-css-injection/\n // This is not an XSS hole but instead a potential CSS injection issue\n // which has lead to a greater discussion about how we're going to\n // trust URLs moving forward. See #2115901\n\n var isEmpty = value == null || typeof value === 'boolean' || value === '';\n if (isEmpty) {\n return '';\n }\n if (!isCustomProperty && typeof value === 'number' && value !== 0 && !(isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name])) {\n return value + 'px'; // Presumes implicit 'px' suffix for unitless numbers\n }\n\n return ('' + value).trim();\n}\nexport default dangerousStyleValue;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar unitlessNumbers = {\n animationIterationCount: true,\n aspectRatio: true,\n borderImageOutset: true,\n borderImageSlice: true,\n borderImageWidth: true,\n boxFlex: true,\n boxFlexGroup: true,\n boxOrdinalGroup: true,\n columnCount: true,\n flex: true,\n flexGrow: true,\n flexOrder: true,\n flexPositive: true,\n flexShrink: true,\n flexNegative: true,\n fontWeight: true,\n gridRow: true,\n gridRowEnd: true,\n gridRowGap: true,\n gridRowStart: true,\n gridColumn: true,\n gridColumnEnd: true,\n gridColumnGap: true,\n gridColumnStart: true,\n lineClamp: true,\n opacity: true,\n order: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n // SVG-related\n fillOpacity: true,\n floodOpacity: true,\n stopOpacity: true,\n strokeDasharray: true,\n strokeDashoffset: true,\n strokeMiterlimit: true,\n strokeOpacity: true,\n strokeWidth: true,\n // transform types\n scale: true,\n scaleX: true,\n scaleY: true,\n scaleZ: true,\n // RN properties\n shadowOpacity: true\n};\n\n/**\n * Support style names that may come passed in prefixed by adding permutations\n * of vendor prefixes.\n */\nvar prefixes = ['ms', 'Moz', 'O', 'Webkit'];\nvar prefixKey = (prefix, key) => {\n return prefix + key.charAt(0).toUpperCase() + key.substring(1);\n};\nObject.keys(unitlessNumbers).forEach(prop => {\n prefixes.forEach(prefix => {\n unitlessNumbers[prefixKey(prefix, prop)] = unitlessNumbers[prop];\n });\n});\nexport default unitlessNumbers;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport mergeRefs from '../mergeRefs';\nexport default function useMergeRefs() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return React.useMemo(() => mergeRefs(...args),\n // eslint-disable-next-line\n [...args]);\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nexport default function mergeRefs() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return function forwardRef(node) {\n args.forEach(ref => {\n if (ref == null) {\n return;\n }\n if (typeof ref === 'function') {\n ref(node);\n return;\n }\n if (typeof ref === 'object') {\n ref.current = node;\n return;\n }\n console.error(\"mergeRefs cannot handle Refs of type boolean, number or string, received ref \" + String(ref));\n });\n };\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport UIManager from '../../exports/UIManager';\nimport useStable from '../useStable';\n\n/**\n * Adds non-standard methods to the hode element. This is temporarily until an\n * API like `ReactNative.measure(hostRef, callback)` is added to React Native.\n */\nexport default function usePlatformMethods(_ref) {\n var pointerEvents = _ref.pointerEvents,\n style = _ref.style;\n // Avoid creating a new ref on every render.\n var ref = useStable(() => hostNode => {\n if (hostNode != null) {\n hostNode.measure = callback => UIManager.measure(hostNode, callback);\n hostNode.measureLayout = (relativeToNode, success, failure) => UIManager.measureLayout(hostNode, relativeToNode, failure, success);\n hostNode.measureInWindow = callback => UIManager.measureInWindow(hostNode, callback);\n }\n });\n return ref;\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nvar UNINITIALIZED = typeof Symbol === 'function' && typeof Symbol() === 'symbol' ? Symbol() : Object.freeze({});\nexport default function useStable(getInitialValue) {\n var ref = React.useRef(UNINITIALIZED);\n if (ref.current === UNINITIALIZED) {\n ref.current = getInitialValue();\n }\n // $FlowFixMe (#64650789) Trouble refining types where `Symbol` is concerned.\n return ref.current;\n}","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\n/**\n * Hook for integrating the Responder System into React\n *\n * function SomeComponent({ onStartShouldSetResponder }) {\n * const ref = useRef(null);\n * useResponderEvents(ref, { onStartShouldSetResponder });\n * return
\n * }\n */\n\nimport * as React from 'react';\nimport * as ResponderSystem from './ResponderSystem';\nvar emptyObject = {};\nvar idCounter = 0;\nfunction useStable(getInitialValue) {\n var ref = React.useRef(null);\n if (ref.current == null) {\n ref.current = getInitialValue();\n }\n return ref.current;\n}\nexport default function useResponderEvents(hostRef, config) {\n if (config === void 0) {\n config = emptyObject;\n }\n var id = useStable(() => idCounter++);\n var isAttachedRef = React.useRef(false);\n\n // This is a separate effects so it doesn't run when the config changes.\n // On initial mount, attach global listeners if needed.\n // On unmount, remove node potentially attached to the Responder System.\n React.useEffect(() => {\n ResponderSystem.attachListeners();\n return () => {\n ResponderSystem.removeNode(id);\n };\n }, [id]);\n\n // Register and unregister with the Responder System as necessary\n React.useEffect(() => {\n var _config = config,\n onMoveShouldSetResponder = _config.onMoveShouldSetResponder,\n onMoveShouldSetResponderCapture = _config.onMoveShouldSetResponderCapture,\n onScrollShouldSetResponder = _config.onScrollShouldSetResponder,\n onScrollShouldSetResponderCapture = _config.onScrollShouldSetResponderCapture,\n onSelectionChangeShouldSetResponder = _config.onSelectionChangeShouldSetResponder,\n onSelectionChangeShouldSetResponderCapture = _config.onSelectionChangeShouldSetResponderCapture,\n onStartShouldSetResponder = _config.onStartShouldSetResponder,\n onStartShouldSetResponderCapture = _config.onStartShouldSetResponderCapture;\n var requiresResponderSystem = onMoveShouldSetResponder != null || onMoveShouldSetResponderCapture != null || onScrollShouldSetResponder != null || onScrollShouldSetResponderCapture != null || onSelectionChangeShouldSetResponder != null || onSelectionChangeShouldSetResponderCapture != null || onStartShouldSetResponder != null || onStartShouldSetResponderCapture != null;\n var node = hostRef.current;\n if (requiresResponderSystem) {\n ResponderSystem.addNode(id, node, config);\n isAttachedRef.current = true;\n } else if (isAttachedRef.current) {\n ResponderSystem.removeNode(id);\n isAttachedRef.current = false;\n }\n }, [config, hostRef, id]);\n React.useDebugValue({\n isResponder: hostRef.current === ResponderSystem.getResponderNode()\n });\n React.useDebugValue(config);\n}","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\n/**\n * RESPONDER EVENT SYSTEM\n *\n * A single, global \"interaction lock\" on views. For a view to be the \"responder\" means\n * that pointer interactions are exclusive to that view and none other. The \"interaction\n * lock\" can be transferred (only) to ancestors of the current \"responder\" as long as\n * pointers continue to be active.\n *\n * Responder being granted:\n *\n * A view can become the \"responder\" after the following events:\n * * \"pointerdown\" (implemented using \"touchstart\", \"mousedown\")\n * * \"pointermove\" (implemented using \"touchmove\", \"mousemove\")\n * * \"scroll\" (while a pointer is down)\n * * \"selectionchange\" (while a pointer is down)\n *\n * If nothing is already the \"responder\", the event propagates to (capture) and from\n * (bubble) the event target until a view returns `true` for\n * `on*ShouldSetResponder(Capture)`.\n *\n * If something is already the responder, the event propagates to (capture) and from\n * (bubble) the lowest common ancestor of the event target and the current \"responder\".\n * Then negotiation happens between the current \"responder\" and a view that wants to\n * become the \"responder\": see the timing diagram below.\n *\n * (NOTE: Scrolled views either automatically become the \"responder\" or release the\n * \"interaction lock\". A native scroll view that isn't built on top of the responder\n * system must result in the current \"responder\" being notified that it no longer has\n * the \"interaction lock\" - the native system has taken over.\n *\n * Responder being released:\n *\n * As soon as there are no more active pointers that *started* inside descendants\n * of the *current* \"responder\", an `onResponderRelease` event is dispatched to the\n * current \"responder\", and the responder lock is released.\n *\n * Typical sequence of events:\n * * startShouldSetResponder\n * * responderGrant/Reject\n * * responderStart\n * * responderMove\n * * responderEnd\n * * responderRelease\n */\n\n/* Negotiation Performed\n +-----------------------+\n / \\\nProcess low level events to + Current Responder + wantsResponderID\ndetermine who to perform negot-| (if any exists at all) |\niation/transition | Otherwise just pass through|\n-------------------------------+----------------------------+------------------+\nBubble to find first ID | |\nto return true:wantsResponderID| |\n | |\n +--------------+ | |\n | onTouchStart | | |\n +------+-------+ none | |\n | return| |\n+-----------v-------------+true| +------------------------+ |\n|onStartShouldSetResponder|----->| onResponderStart (cur) |<-----------+\n+-----------+-------------+ | +------------------------+ | |\n | | | +--------+-------+\n | returned true for| false:REJECT +-------->|onResponderReject\n | wantsResponderID | | | +----------------+\n | (now attempt | +------------------+-----+ |\n | handoff) | | onResponder | |\n +------------------->| TerminationRequest | |\n | +------------------+-----+ |\n | | | +----------------+\n | true:GRANT +-------->|onResponderGrant|\n | | +--------+-------+\n | +------------------------+ | |\n | | onResponderTerminate |<-----------+\n | +------------------+-----+ |\n | | | +----------------+\n | +-------->|onResponderStart|\n | | +----------------+\nBubble to find first ID | |\nto return true:wantsResponderID| |\n | |\n +-------------+ | |\n | onTouchMove | | |\n +------+------+ none | |\n | return| |\n+-----------v-------------+true| +------------------------+ |\n|onMoveShouldSetResponder |----->| onResponderMove (cur) |<-----------+\n+-----------+-------------+ | +------------------------+ | |\n | | | +--------+-------+\n | returned true for| false:REJECT +-------->|onResponderReject\n | wantsResponderID | | | +----------------+\n | (now attempt | +------------------+-----+ |\n | handoff) | | onResponder | |\n +------------------->| TerminationRequest| |\n | +------------------+-----+ |\n | | | +----------------+\n | true:GRANT +-------->|onResponderGrant|\n | | +--------+-------+\n | +------------------------+ | |\n | | onResponderTerminate |<-----------+\n | +------------------+-----+ |\n | | | +----------------+\n | +-------->|onResponderMove |\n | | +----------------+\n | |\n | |\n Some active touch started| |\n inside current responder | +------------------------+ |\n +------------------------->| onResponderEnd | |\n | | +------------------------+ |\n +---+---------+ | |\n | onTouchEnd | | |\n +---+---------+ | |\n | | +------------------------+ |\n +------------------------->| onResponderEnd | |\n No active touches started| +-----------+------------+ |\n inside current responder | | |\n | v |\n | +------------------------+ |\n | | onResponderRelease | |\n | +------------------------+ |\n | |\n + + */\n\nimport createResponderEvent from './createResponderEvent';\nimport { isCancelish, isEndish, isMoveish, isScroll, isSelectionChange, isStartish } from './ResponderEventTypes';\nimport { getLowestCommonAncestor, getResponderPaths, hasTargetTouches, hasValidSelection, isPrimaryPointerDown, setResponderId } from './utils';\nimport { ResponderTouchHistoryStore } from './ResponderTouchHistoryStore';\nimport canUseDOM from '../canUseDom';\n\n/* ------------ TYPES ------------ */\n\nvar emptyObject = {};\n\n/* ------------ IMPLEMENTATION ------------ */\n\nvar startRegistration = ['onStartShouldSetResponderCapture', 'onStartShouldSetResponder', {\n bubbles: true\n}];\nvar moveRegistration = ['onMoveShouldSetResponderCapture', 'onMoveShouldSetResponder', {\n bubbles: true\n}];\nvar scrollRegistration = ['onScrollShouldSetResponderCapture', 'onScrollShouldSetResponder', {\n bubbles: false\n}];\nvar shouldSetResponderEvents = {\n touchstart: startRegistration,\n mousedown: startRegistration,\n touchmove: moveRegistration,\n mousemove: moveRegistration,\n scroll: scrollRegistration\n};\nvar emptyResponder = {\n id: null,\n idPath: null,\n node: null\n};\nvar responderListenersMap = new Map();\nvar isEmulatingMouseEvents = false;\nvar trackedTouchCount = 0;\nvar currentResponder = {\n id: null,\n node: null,\n idPath: null\n};\nvar responderTouchHistoryStore = new ResponderTouchHistoryStore();\nfunction changeCurrentResponder(responder) {\n currentResponder = responder;\n}\nfunction getResponderConfig(id) {\n var config = responderListenersMap.get(id);\n return config != null ? config : emptyObject;\n}\n\n/**\n * Process native events\n *\n * A single event listener is used to manage the responder system.\n * All pointers are tracked in the ResponderTouchHistoryStore. Native events\n * are interpreted in terms of the Responder System and checked to see if\n * the responder should be transferred. Each host node that is attached to\n * the Responder System has an ID, which is used to look up its associated\n * callbacks.\n */\nfunction eventListener(domEvent) {\n var eventType = domEvent.type;\n var eventTarget = domEvent.target;\n\n /**\n * Manage emulated events and early bailout.\n * Since PointerEvent is not used yet (lack of support in older Safari), it's\n * necessary to manually manage the mess of browser touch/mouse events.\n * And bailout early for termination events when there is no active responder.\n */\n\n // Flag when browser may produce emulated events\n if (eventType === 'touchstart') {\n isEmulatingMouseEvents = true;\n }\n // Remove flag when browser will not produce emulated events\n if (eventType === 'touchmove' || trackedTouchCount > 1) {\n isEmulatingMouseEvents = false;\n }\n // Ignore various events in particular circumstances\n if (\n // Ignore browser emulated mouse events\n eventType === 'mousedown' && isEmulatingMouseEvents || eventType === 'mousemove' && isEmulatingMouseEvents ||\n // Ignore mousemove if a mousedown didn't occur first\n eventType === 'mousemove' && trackedTouchCount < 1) {\n return;\n }\n // Remove flag after emulated events are finished\n if (isEmulatingMouseEvents && eventType === 'mouseup') {\n if (trackedTouchCount === 0) {\n isEmulatingMouseEvents = false;\n }\n return;\n }\n var isStartEvent = isStartish(eventType) && isPrimaryPointerDown(domEvent);\n var isMoveEvent = isMoveish(eventType);\n var isEndEvent = isEndish(eventType);\n var isScrollEvent = isScroll(eventType);\n var isSelectionChangeEvent = isSelectionChange(eventType);\n var responderEvent = createResponderEvent(domEvent, responderTouchHistoryStore);\n\n /**\n * Record the state of active pointers\n */\n\n if (isStartEvent || isMoveEvent || isEndEvent) {\n if (domEvent.touches) {\n trackedTouchCount = domEvent.touches.length;\n } else {\n if (isStartEvent) {\n trackedTouchCount = 1;\n } else if (isEndEvent) {\n trackedTouchCount = 0;\n }\n }\n responderTouchHistoryStore.recordTouchTrack(eventType, responderEvent.nativeEvent);\n }\n\n /**\n * Responder System logic\n */\n\n var eventPaths = getResponderPaths(domEvent);\n var wasNegotiated = false;\n var wantsResponder;\n\n // If an event occured that might change the current responder...\n if (isStartEvent || isMoveEvent || isScrollEvent && trackedTouchCount > 0) {\n // If there is already a responder, prune the event paths to the lowest common ancestor\n // of the existing responder and deepest target of the event.\n var currentResponderIdPath = currentResponder.idPath;\n var eventIdPath = eventPaths.idPath;\n if (currentResponderIdPath != null && eventIdPath != null) {\n var lowestCommonAncestor = getLowestCommonAncestor(currentResponderIdPath, eventIdPath);\n if (lowestCommonAncestor != null) {\n var indexOfLowestCommonAncestor = eventIdPath.indexOf(lowestCommonAncestor);\n // Skip the current responder so it doesn't receive unexpected \"shouldSet\" events.\n var index = indexOfLowestCommonAncestor + (lowestCommonAncestor === currentResponder.id ? 1 : 0);\n eventPaths = {\n idPath: eventIdPath.slice(index),\n nodePath: eventPaths.nodePath.slice(index)\n };\n } else {\n eventPaths = null;\n }\n }\n if (eventPaths != null) {\n // If a node wants to become the responder, attempt to transfer.\n wantsResponder = findWantsResponder(eventPaths, domEvent, responderEvent);\n if (wantsResponder != null) {\n // Sets responder if none exists, or negotates with existing responder.\n attemptTransfer(responderEvent, wantsResponder);\n wasNegotiated = true;\n }\n }\n }\n\n // If there is now a responder, invoke its callbacks for the lifecycle of the gesture.\n if (currentResponder.id != null && currentResponder.node != null) {\n var _currentResponder = currentResponder,\n id = _currentResponder.id,\n node = _currentResponder.node;\n var _getResponderConfig = getResponderConfig(id),\n onResponderStart = _getResponderConfig.onResponderStart,\n onResponderMove = _getResponderConfig.onResponderMove,\n onResponderEnd = _getResponderConfig.onResponderEnd,\n onResponderRelease = _getResponderConfig.onResponderRelease,\n onResponderTerminate = _getResponderConfig.onResponderTerminate,\n onResponderTerminationRequest = _getResponderConfig.onResponderTerminationRequest;\n responderEvent.bubbles = false;\n responderEvent.cancelable = false;\n responderEvent.currentTarget = node;\n\n // Start\n if (isStartEvent) {\n if (onResponderStart != null) {\n responderEvent.dispatchConfig.registrationName = 'onResponderStart';\n onResponderStart(responderEvent);\n }\n }\n // Move\n else if (isMoveEvent) {\n if (onResponderMove != null) {\n responderEvent.dispatchConfig.registrationName = 'onResponderMove';\n onResponderMove(responderEvent);\n }\n } else {\n var isTerminateEvent = isCancelish(eventType) ||\n // native context menu\n eventType === 'contextmenu' ||\n // window blur\n eventType === 'blur' && eventTarget === window ||\n // responder (or ancestors) blur\n eventType === 'blur' && eventTarget.contains(node) && domEvent.relatedTarget !== node ||\n // native scroll without using a pointer\n isScrollEvent && trackedTouchCount === 0 ||\n // native scroll on node that is parent of the responder (allow siblings to scroll)\n isScrollEvent && eventTarget.contains(node) && eventTarget !== node ||\n // native select/selectionchange on node\n isSelectionChangeEvent && hasValidSelection(domEvent);\n var isReleaseEvent = isEndEvent && !isTerminateEvent && !hasTargetTouches(node, domEvent.touches);\n\n // End\n if (isEndEvent) {\n if (onResponderEnd != null) {\n responderEvent.dispatchConfig.registrationName = 'onResponderEnd';\n onResponderEnd(responderEvent);\n }\n }\n // Release\n if (isReleaseEvent) {\n if (onResponderRelease != null) {\n responderEvent.dispatchConfig.registrationName = 'onResponderRelease';\n onResponderRelease(responderEvent);\n }\n changeCurrentResponder(emptyResponder);\n }\n // Terminate\n if (isTerminateEvent) {\n var shouldTerminate = true;\n\n // Responders can still avoid termination but only for these events.\n if (eventType === 'contextmenu' || eventType === 'scroll' || eventType === 'selectionchange') {\n // Only call this function is it wasn't already called during negotiation.\n if (wasNegotiated) {\n shouldTerminate = false;\n } else if (onResponderTerminationRequest != null) {\n responderEvent.dispatchConfig.registrationName = 'onResponderTerminationRequest';\n if (onResponderTerminationRequest(responderEvent) === false) {\n shouldTerminate = false;\n }\n }\n }\n if (shouldTerminate) {\n if (onResponderTerminate != null) {\n responderEvent.dispatchConfig.registrationName = 'onResponderTerminate';\n onResponderTerminate(responderEvent);\n }\n changeCurrentResponder(emptyResponder);\n isEmulatingMouseEvents = false;\n trackedTouchCount = 0;\n }\n }\n }\n }\n}\n\n/**\n * Walk the event path to/from the target node. At each node, stop and call the\n * relevant \"shouldSet\" functions for the given event type. If any of those functions\n * call \"stopPropagation\" on the event, stop searching for a responder.\n */\nfunction findWantsResponder(eventPaths, domEvent, responderEvent) {\n var shouldSetCallbacks = shouldSetResponderEvents[domEvent.type]; // for Flow\n\n if (shouldSetCallbacks != null) {\n var idPath = eventPaths.idPath,\n nodePath = eventPaths.nodePath;\n var shouldSetCallbackCaptureName = shouldSetCallbacks[0];\n var shouldSetCallbackBubbleName = shouldSetCallbacks[1];\n var bubbles = shouldSetCallbacks[2].bubbles;\n var check = function check(id, node, callbackName) {\n var config = getResponderConfig(id);\n var shouldSetCallback = config[callbackName];\n if (shouldSetCallback != null) {\n responderEvent.currentTarget = node;\n if (shouldSetCallback(responderEvent) === true) {\n // Start the path from the potential responder\n var prunedIdPath = idPath.slice(idPath.indexOf(id));\n return {\n id,\n node,\n idPath: prunedIdPath\n };\n }\n }\n };\n\n // capture\n for (var i = idPath.length - 1; i >= 0; i--) {\n var id = idPath[i];\n var node = nodePath[i];\n var result = check(id, node, shouldSetCallbackCaptureName);\n if (result != null) {\n return result;\n }\n if (responderEvent.isPropagationStopped() === true) {\n return;\n }\n }\n\n // bubble\n if (bubbles) {\n for (var _i = 0; _i < idPath.length; _i++) {\n var _id = idPath[_i];\n var _node = nodePath[_i];\n var _result = check(_id, _node, shouldSetCallbackBubbleName);\n if (_result != null) {\n return _result;\n }\n if (responderEvent.isPropagationStopped() === true) {\n return;\n }\n }\n } else {\n var _id2 = idPath[0];\n var _node2 = nodePath[0];\n var target = domEvent.target;\n if (target === _node2) {\n return check(_id2, _node2, shouldSetCallbackBubbleName);\n }\n }\n }\n}\n\n/**\n * Attempt to transfer the responder.\n */\nfunction attemptTransfer(responderEvent, wantsResponder) {\n var _currentResponder2 = currentResponder,\n currentId = _currentResponder2.id,\n currentNode = _currentResponder2.node;\n var id = wantsResponder.id,\n node = wantsResponder.node;\n var _getResponderConfig2 = getResponderConfig(id),\n onResponderGrant = _getResponderConfig2.onResponderGrant,\n onResponderReject = _getResponderConfig2.onResponderReject;\n responderEvent.bubbles = false;\n responderEvent.cancelable = false;\n responderEvent.currentTarget = node;\n\n // Set responder\n if (currentId == null) {\n if (onResponderGrant != null) {\n responderEvent.currentTarget = node;\n responderEvent.dispatchConfig.registrationName = 'onResponderGrant';\n onResponderGrant(responderEvent);\n }\n changeCurrentResponder(wantsResponder);\n }\n // Negotiate with current responder\n else {\n var _getResponderConfig3 = getResponderConfig(currentId),\n onResponderTerminate = _getResponderConfig3.onResponderTerminate,\n onResponderTerminationRequest = _getResponderConfig3.onResponderTerminationRequest;\n var allowTransfer = true;\n if (onResponderTerminationRequest != null) {\n responderEvent.currentTarget = currentNode;\n responderEvent.dispatchConfig.registrationName = 'onResponderTerminationRequest';\n if (onResponderTerminationRequest(responderEvent) === false) {\n allowTransfer = false;\n }\n }\n if (allowTransfer) {\n // Terminate existing responder\n if (onResponderTerminate != null) {\n responderEvent.currentTarget = currentNode;\n responderEvent.dispatchConfig.registrationName = 'onResponderTerminate';\n onResponderTerminate(responderEvent);\n }\n // Grant next responder\n if (onResponderGrant != null) {\n responderEvent.currentTarget = node;\n responderEvent.dispatchConfig.registrationName = 'onResponderGrant';\n onResponderGrant(responderEvent);\n }\n changeCurrentResponder(wantsResponder);\n } else {\n // Reject responder request\n if (onResponderReject != null) {\n responderEvent.currentTarget = node;\n responderEvent.dispatchConfig.registrationName = 'onResponderReject';\n onResponderReject(responderEvent);\n }\n }\n }\n}\n\n/* ------------ PUBLIC API ------------ */\n\n/**\n * Attach Listeners\n *\n * Use native events as ReactDOM doesn't have a non-plugin API to implement\n * this system.\n */\nvar documentEventsCapturePhase = ['blur', 'scroll'];\nvar documentEventsBubblePhase = [\n// mouse\n'mousedown', 'mousemove', 'mouseup', 'dragstart',\n// touch\n'touchstart', 'touchmove', 'touchend', 'touchcancel',\n// other\n'contextmenu', 'select', 'selectionchange'];\nexport function attachListeners() {\n if (canUseDOM && window.__reactResponderSystemActive == null) {\n window.addEventListener('blur', eventListener);\n documentEventsBubblePhase.forEach(eventType => {\n document.addEventListener(eventType, eventListener);\n });\n documentEventsCapturePhase.forEach(eventType => {\n document.addEventListener(eventType, eventListener, true);\n });\n window.__reactResponderSystemActive = true;\n }\n}\n\n/**\n * Register a node with the ResponderSystem.\n */\nexport function addNode(id, node, config) {\n setResponderId(node, id);\n responderListenersMap.set(id, config);\n}\n\n/**\n * Unregister a node with the ResponderSystem.\n */\nexport function removeNode(id) {\n if (currentResponder.id === id) {\n terminateResponder();\n }\n if (responderListenersMap.has(id)) {\n responderListenersMap.delete(id);\n }\n}\n\n/**\n * Allow the current responder to be terminated from within components to support\n * more complex requirements, such as use with other React libraries for working\n * with scroll views, input views, etc.\n */\nexport function terminateResponder() {\n var _currentResponder3 = currentResponder,\n id = _currentResponder3.id,\n node = _currentResponder3.node;\n if (id != null && node != null) {\n var _getResponderConfig4 = getResponderConfig(id),\n onResponderTerminate = _getResponderConfig4.onResponderTerminate;\n if (onResponderTerminate != null) {\n var event = createResponderEvent({}, responderTouchHistoryStore);\n event.currentTarget = node;\n onResponderTerminate(event);\n }\n changeCurrentResponder(emptyResponder);\n }\n isEmulatingMouseEvents = false;\n trackedTouchCount = 0;\n}\n\n/**\n * Allow unit tests to inspect the current responder in the system.\n * FOR TESTING ONLY.\n */\nexport function getResponderNode() {\n return currentResponder.node;\n}","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport getBoundingClientRect from '../../modules/getBoundingClientRect';\nvar emptyFunction = () => {};\nvar emptyObject = {};\nvar emptyArray = [];\n\n/**\n * Safari produces very large identifiers that would cause the `touchBank` array\n * length to be so large as to crash the browser, if not normalized like this.\n * In the future the `touchBank` should use an object/map instead.\n */\nfunction normalizeIdentifier(identifier) {\n return identifier > 20 ? identifier % 20 : identifier;\n}\n\n/**\n * Converts a native DOM event to a ResponderEvent.\n * Mouse events are transformed into fake touch events.\n */\nexport default function createResponderEvent(domEvent, responderTouchHistoryStore) {\n var rect;\n var propagationWasStopped = false;\n var changedTouches;\n var touches;\n var domEventChangedTouches = domEvent.changedTouches;\n var domEventType = domEvent.type;\n var metaKey = domEvent.metaKey === true;\n var shiftKey = domEvent.shiftKey === true;\n var force = domEventChangedTouches && domEventChangedTouches[0].force || 0;\n var identifier = normalizeIdentifier(domEventChangedTouches && domEventChangedTouches[0].identifier || 0);\n var clientX = domEventChangedTouches && domEventChangedTouches[0].clientX || domEvent.clientX;\n var clientY = domEventChangedTouches && domEventChangedTouches[0].clientY || domEvent.clientY;\n var pageX = domEventChangedTouches && domEventChangedTouches[0].pageX || domEvent.pageX;\n var pageY = domEventChangedTouches && domEventChangedTouches[0].pageY || domEvent.pageY;\n var preventDefault = typeof domEvent.preventDefault === 'function' ? domEvent.preventDefault.bind(domEvent) : emptyFunction;\n var timestamp = domEvent.timeStamp;\n function normalizeTouches(touches) {\n return Array.prototype.slice.call(touches).map(touch => {\n return {\n force: touch.force,\n identifier: normalizeIdentifier(touch.identifier),\n get locationX() {\n return locationX(touch.clientX);\n },\n get locationY() {\n return locationY(touch.clientY);\n },\n pageX: touch.pageX,\n pageY: touch.pageY,\n target: touch.target,\n timestamp\n };\n });\n }\n if (domEventChangedTouches != null) {\n changedTouches = normalizeTouches(domEventChangedTouches);\n touches = normalizeTouches(domEvent.touches);\n } else {\n var emulatedTouches = [{\n force,\n identifier,\n get locationX() {\n return locationX(clientX);\n },\n get locationY() {\n return locationY(clientY);\n },\n pageX,\n pageY,\n target: domEvent.target,\n timestamp\n }];\n changedTouches = emulatedTouches;\n touches = domEventType === 'mouseup' || domEventType === 'dragstart' ? emptyArray : emulatedTouches;\n }\n var responderEvent = {\n bubbles: true,\n cancelable: true,\n // `currentTarget` is set before dispatch\n currentTarget: null,\n defaultPrevented: domEvent.defaultPrevented,\n dispatchConfig: emptyObject,\n eventPhase: domEvent.eventPhase,\n isDefaultPrevented() {\n return domEvent.defaultPrevented;\n },\n isPropagationStopped() {\n return propagationWasStopped;\n },\n isTrusted: domEvent.isTrusted,\n nativeEvent: {\n altKey: false,\n ctrlKey: false,\n metaKey,\n shiftKey,\n changedTouches,\n force,\n identifier,\n get locationX() {\n return locationX(clientX);\n },\n get locationY() {\n return locationY(clientY);\n },\n pageX,\n pageY,\n target: domEvent.target,\n timestamp,\n touches,\n type: domEventType\n },\n persist: emptyFunction,\n preventDefault,\n stopPropagation() {\n propagationWasStopped = true;\n },\n target: domEvent.target,\n timeStamp: timestamp,\n touchHistory: responderTouchHistoryStore.touchHistory\n };\n\n // Using getters and functions serves two purposes:\n // 1) The value of `currentTarget` is not initially available.\n // 2) Measuring the clientRect may cause layout jank and should only be done on-demand.\n function locationX(x) {\n rect = rect || getBoundingClientRect(responderEvent.currentTarget);\n if (rect) {\n return x - rect.left;\n }\n }\n function locationY(y) {\n rect = rect || getBoundingClientRect(responderEvent.currentTarget);\n if (rect) {\n return y - rect.top;\n }\n }\n return responderEvent;\n}","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nexport var BLUR = 'blur';\nexport var CONTEXT_MENU = 'contextmenu';\nexport var FOCUS_OUT = 'focusout';\nexport var MOUSE_DOWN = 'mousedown';\nexport var MOUSE_MOVE = 'mousemove';\nexport var MOUSE_UP = 'mouseup';\nexport var MOUSE_CANCEL = 'dragstart';\nexport var TOUCH_START = 'touchstart';\nexport var TOUCH_MOVE = 'touchmove';\nexport var TOUCH_END = 'touchend';\nexport var TOUCH_CANCEL = 'touchcancel';\nexport var SCROLL = 'scroll';\nexport var SELECT = 'select';\nexport var SELECTION_CHANGE = 'selectionchange';\nexport function isStartish(eventType) {\n return eventType === TOUCH_START || eventType === MOUSE_DOWN;\n}\nexport function isMoveish(eventType) {\n return eventType === TOUCH_MOVE || eventType === MOUSE_MOVE;\n}\nexport function isEndish(eventType) {\n return eventType === TOUCH_END || eventType === MOUSE_UP || isCancelish(eventType);\n}\nexport function isCancelish(eventType) {\n return eventType === TOUCH_CANCEL || eventType === MOUSE_CANCEL;\n}\nexport function isScroll(eventType) {\n return eventType === SCROLL;\n}\nexport function isSelectionChange(eventType) {\n return eventType === SELECT || eventType === SELECTION_CHANGE;\n}","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport isSelectionValid from '../../modules/isSelectionValid';\nvar keyName = '__reactResponderId';\nfunction getEventPath(domEvent) {\n // The 'selectionchange' event always has the 'document' as the target.\n // Use the anchor node as the initial target to reconstruct a path.\n // (We actually only need the first \"responder\" node in practice.)\n if (domEvent.type === 'selectionchange') {\n var target = window.getSelection().anchorNode;\n return composedPathFallback(target);\n } else {\n var path = domEvent.composedPath != null ? domEvent.composedPath() : composedPathFallback(domEvent.target);\n return path;\n }\n}\nfunction composedPathFallback(target) {\n var path = [];\n while (target != null && target !== document.body) {\n path.push(target);\n target = target.parentNode;\n }\n return path;\n}\n\n/**\n * Retrieve the responderId from a host node\n */\nfunction getResponderId(node) {\n if (node != null) {\n return node[keyName];\n }\n return null;\n}\n\n/**\n * Store the responderId on a host node\n */\nexport function setResponderId(node, id) {\n if (node != null) {\n node[keyName] = id;\n }\n}\n\n/**\n * Filter the event path to contain only the nodes attached to the responder system\n */\nexport function getResponderPaths(domEvent) {\n var idPath = [];\n var nodePath = [];\n var eventPath = getEventPath(domEvent);\n for (var i = 0; i < eventPath.length; i++) {\n var node = eventPath[i];\n var id = getResponderId(node);\n if (id != null) {\n idPath.push(id);\n nodePath.push(node);\n }\n }\n return {\n idPath,\n nodePath\n };\n}\n\n/**\n * Walk the paths and find the first common ancestor\n */\nexport function getLowestCommonAncestor(pathA, pathB) {\n var pathALength = pathA.length;\n var pathBLength = pathB.length;\n if (\n // If either path is empty\n pathALength === 0 || pathBLength === 0 ||\n // If the last elements aren't the same there can't be a common ancestor\n // that is connected to the responder system\n pathA[pathALength - 1] !== pathB[pathBLength - 1]) {\n return null;\n }\n var itemA = pathA[0];\n var indexA = 0;\n var itemB = pathB[0];\n var indexB = 0;\n\n // If A is deeper, skip indices that can't match.\n if (pathALength - pathBLength > 0) {\n indexA = pathALength - pathBLength;\n itemA = pathA[indexA];\n pathALength = pathBLength;\n }\n\n // If B is deeper, skip indices that can't match\n if (pathBLength - pathALength > 0) {\n indexB = pathBLength - pathALength;\n itemB = pathB[indexB];\n pathBLength = pathALength;\n }\n\n // Walk in lockstep until a match is found\n var depth = pathALength;\n while (depth--) {\n if (itemA === itemB) {\n return itemA;\n }\n itemA = pathA[indexA++];\n itemB = pathB[indexB++];\n }\n return null;\n}\n\n/**\n * Determine whether any of the active touches are within the current responder.\n * This cannot rely on W3C `targetTouches`, as neither IE11 nor Safari implement it.\n */\nexport function hasTargetTouches(target, touches) {\n if (!touches || touches.length === 0) {\n return false;\n }\n for (var i = 0; i < touches.length; i++) {\n var node = touches[i].target;\n if (node != null) {\n if (target.contains(node)) {\n return true;\n }\n }\n }\n return false;\n}\n\n/**\n * Ignore 'selectionchange' events that don't correspond with a person's intent to\n * select text.\n */\nexport function hasValidSelection(domEvent) {\n if (domEvent.type === 'selectionchange') {\n return isSelectionValid();\n }\n return domEvent.type === 'select';\n}\n\n/**\n * Events are only valid if the primary button was used without specific modifier keys.\n */\nexport function isPrimaryPointerDown(domEvent) {\n var altKey = domEvent.altKey,\n button = domEvent.button,\n buttons = domEvent.buttons,\n ctrlKey = domEvent.ctrlKey,\n type = domEvent.type;\n var isTouch = type === 'touchstart' || type === 'touchmove';\n var isPrimaryMouseDown = type === 'mousedown' && (button === 0 || buttons === 1);\n var isPrimaryMouseMove = type === 'mousemove' && buttons === 1;\n var noModifiers = altKey === false && ctrlKey === false;\n if (isTouch || isPrimaryMouseDown && noModifiers || isPrimaryMouseMove && noModifiers) {\n return true;\n }\n return false;\n}","/**\n * Copyright (c) Nicolas Gallagher\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nexport default function isSelectionValid() {\n var selection = window.getSelection();\n var string = selection.toString();\n var anchorNode = selection.anchorNode;\n var focusNode = selection.focusNode;\n var isTextNode = anchorNode && anchorNode.nodeType === window.Node.TEXT_NODE || focusNode && focusNode.nodeType === window.Node.TEXT_NODE;\n return string.length >= 1 && string !== '\\n' && isTextNode;\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport { isStartish, isMoveish, isEndish } from './ResponderEventTypes';\n/**\n * Tracks the position and time of each active touch by `touch.identifier`. We\n * should typically only see IDs in the range of 1-20 because IDs get recycled\n * when touches end and start again.\n */\n\nvar __DEV__ = process.env.NODE_ENV !== 'production';\nvar MAX_TOUCH_BANK = 20;\nfunction timestampForTouch(touch) {\n // The legacy internal implementation provides \"timeStamp\", which has been\n // renamed to \"timestamp\".\n return touch.timeStamp || touch.timestamp;\n}\n\n/**\n * TODO: Instead of making gestures recompute filtered velocity, we could\n * include a built in velocity computation that can be reused globally.\n */\nfunction createTouchRecord(touch) {\n return {\n touchActive: true,\n startPageX: touch.pageX,\n startPageY: touch.pageY,\n startTimeStamp: timestampForTouch(touch),\n currentPageX: touch.pageX,\n currentPageY: touch.pageY,\n currentTimeStamp: timestampForTouch(touch),\n previousPageX: touch.pageX,\n previousPageY: touch.pageY,\n previousTimeStamp: timestampForTouch(touch)\n };\n}\nfunction resetTouchRecord(touchRecord, touch) {\n touchRecord.touchActive = true;\n touchRecord.startPageX = touch.pageX;\n touchRecord.startPageY = touch.pageY;\n touchRecord.startTimeStamp = timestampForTouch(touch);\n touchRecord.currentPageX = touch.pageX;\n touchRecord.currentPageY = touch.pageY;\n touchRecord.currentTimeStamp = timestampForTouch(touch);\n touchRecord.previousPageX = touch.pageX;\n touchRecord.previousPageY = touch.pageY;\n touchRecord.previousTimeStamp = timestampForTouch(touch);\n}\nfunction getTouchIdentifier(_ref) {\n var identifier = _ref.identifier;\n if (identifier == null) {\n console.error('Touch object is missing identifier.');\n }\n if (__DEV__) {\n if (identifier > MAX_TOUCH_BANK) {\n console.error('Touch identifier %s is greater than maximum supported %s which causes ' + 'performance issues backfilling array locations for all of the indices.', identifier, MAX_TOUCH_BANK);\n }\n }\n return identifier;\n}\nfunction recordTouchStart(touch, touchHistory) {\n var identifier = getTouchIdentifier(touch);\n var touchRecord = touchHistory.touchBank[identifier];\n if (touchRecord) {\n resetTouchRecord(touchRecord, touch);\n } else {\n touchHistory.touchBank[identifier] = createTouchRecord(touch);\n }\n touchHistory.mostRecentTimeStamp = timestampForTouch(touch);\n}\nfunction recordTouchMove(touch, touchHistory) {\n var touchRecord = touchHistory.touchBank[getTouchIdentifier(touch)];\n if (touchRecord) {\n touchRecord.touchActive = true;\n touchRecord.previousPageX = touchRecord.currentPageX;\n touchRecord.previousPageY = touchRecord.currentPageY;\n touchRecord.previousTimeStamp = touchRecord.currentTimeStamp;\n touchRecord.currentPageX = touch.pageX;\n touchRecord.currentPageY = touch.pageY;\n touchRecord.currentTimeStamp = timestampForTouch(touch);\n touchHistory.mostRecentTimeStamp = timestampForTouch(touch);\n } else {\n console.warn('Cannot record touch move without a touch start.\\n', \"Touch Move: \" + printTouch(touch) + \"\\n\", \"Touch Bank: \" + printTouchBank(touchHistory));\n }\n}\nfunction recordTouchEnd(touch, touchHistory) {\n var touchRecord = touchHistory.touchBank[getTouchIdentifier(touch)];\n if (touchRecord) {\n touchRecord.touchActive = false;\n touchRecord.previousPageX = touchRecord.currentPageX;\n touchRecord.previousPageY = touchRecord.currentPageY;\n touchRecord.previousTimeStamp = touchRecord.currentTimeStamp;\n touchRecord.currentPageX = touch.pageX;\n touchRecord.currentPageY = touch.pageY;\n touchRecord.currentTimeStamp = timestampForTouch(touch);\n touchHistory.mostRecentTimeStamp = timestampForTouch(touch);\n } else {\n console.warn('Cannot record touch end without a touch start.\\n', \"Touch End: \" + printTouch(touch) + \"\\n\", \"Touch Bank: \" + printTouchBank(touchHistory));\n }\n}\nfunction printTouch(touch) {\n return JSON.stringify({\n identifier: touch.identifier,\n pageX: touch.pageX,\n pageY: touch.pageY,\n timestamp: timestampForTouch(touch)\n });\n}\nfunction printTouchBank(touchHistory) {\n var touchBank = touchHistory.touchBank;\n var printed = JSON.stringify(touchBank.slice(0, MAX_TOUCH_BANK));\n if (touchBank.length > MAX_TOUCH_BANK) {\n printed += ' (original size: ' + touchBank.length + ')';\n }\n return printed;\n}\nexport class ResponderTouchHistoryStore {\n constructor() {\n this._touchHistory = {\n touchBank: [],\n //Array\n numberActiveTouches: 0,\n // If there is only one active touch, we remember its location. This prevents\n // us having to loop through all of the touches all the time in the most\n // common case.\n indexOfSingleActiveTouch: -1,\n mostRecentTimeStamp: 0\n };\n }\n recordTouchTrack(topLevelType, nativeEvent) {\n var touchHistory = this._touchHistory;\n if (isMoveish(topLevelType)) {\n nativeEvent.changedTouches.forEach(touch => recordTouchMove(touch, touchHistory));\n } else if (isStartish(topLevelType)) {\n nativeEvent.changedTouches.forEach(touch => recordTouchStart(touch, touchHistory));\n touchHistory.numberActiveTouches = nativeEvent.touches.length;\n if (touchHistory.numberActiveTouches === 1) {\n touchHistory.indexOfSingleActiveTouch = nativeEvent.touches[0].identifier;\n }\n } else if (isEndish(topLevelType)) {\n nativeEvent.changedTouches.forEach(touch => recordTouchEnd(touch, touchHistory));\n touchHistory.numberActiveTouches = nativeEvent.touches.length;\n if (touchHistory.numberActiveTouches === 1) {\n var touchBank = touchHistory.touchBank;\n for (var i = 0; i < touchBank.length; i++) {\n var touchTrackToCheck = touchBank[i];\n if (touchTrackToCheck != null && touchTrackToCheck.touchActive) {\n touchHistory.indexOfSingleActiveTouch = i;\n break;\n }\n }\n if (__DEV__) {\n var activeRecord = touchBank[touchHistory.indexOfSingleActiveTouch];\n if (!(activeRecord != null && activeRecord.touchActive)) {\n console.error('Cannot find single active touch.');\n }\n }\n }\n }\n }\n get touchHistory() {\n return this._touchHistory;\n }\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport { createContext } from 'react';\nvar TextAncestorContext = /*#__PURE__*/createContext(false);\nexport default TextAncestorContext;","import React from 'react';\nexport default /*#__PURE__*/React.createContext(false);\n//# sourceMappingURL=GestureHandlerRootViewContext.js.map","import createHandler from './createHandler';\nimport { baseGestureHandlerProps } from './gestureHandlerCommon';\nexport const tapGestureHandlerProps = ['maxDurationMs', 'maxDelayMs', 'numberOfTaps', 'maxDeltaX', 'maxDeltaY', 'maxDist', 'minPointers'];\nexport const tapHandlerName = 'TapGestureHandler';\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const TapGestureHandler = createHandler({\n name: tapHandlerName,\n allowedProps: [...baseGestureHandlerProps, ...tapGestureHandlerProps],\n config: {\n shouldCancelWhenOutside: true\n }\n});\n//# sourceMappingURL=TapGestureHandler.js.map","var _UIManagerAny$getView, _UIManagerAny$getView2, _UIManagerAny$getCons;\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport * as React from 'react';\nimport { Platform, UIManager, DeviceEventEmitter } from 'react-native';\nimport { customDirectEventTypes } from './customDirectEventTypes'; // @ts-ignore - it isn't typed by TS & don't have definitelyTyped types\n\nimport deepEqual from 'lodash/isEqual';\nimport RNGestureHandlerModule from '../RNGestureHandlerModule';\nimport { State } from '../State';\nimport { handlerIDToTag, getNextHandlerTag, registerOldGestureHandler } from './handlersRegistry';\nimport { filterConfig, findNodeHandle, scheduleFlushOperations } from './gestureHandlerCommon';\nimport { isFabric, isJestEnv, tagMessage } from '../utils';\nimport { ActionType } from '../ActionType';\nimport { PressabilityDebugView } from './PressabilityDebugView';\nimport GestureHandlerRootViewContext from '../GestureHandlerRootViewContext';\nimport { ghQueueMicrotask } from '../ghQueueMicrotask';\nconst UIManagerAny = UIManager;\ncustomDirectEventTypes.topGestureHandlerEvent = {\n registrationName: 'onGestureHandlerEvent'\n};\nconst customGHEventsConfigFabricAndroid = {\n topOnGestureHandlerEvent: {\n registrationName: 'onGestureHandlerEvent'\n },\n topOnGestureHandlerStateChange: {\n registrationName: 'onGestureHandlerStateChange'\n }\n};\nconst customGHEventsConfig = {\n onGestureHandlerEvent: {\n registrationName: 'onGestureHandlerEvent'\n },\n onGestureHandlerStateChange: {\n registrationName: 'onGestureHandlerStateChange'\n },\n // When using React Native Gesture Handler for Animated.event with useNativeDriver: true\n // on Android with Fabric enabled, the native part still sends the native events to JS\n // but prefixed with \"top\". We cannot simply rename the events above so they are prefixed\n // with \"top\" instead of \"on\" because in such case Animated.events would not be registered.\n // That's why we need to register another pair of event names.\n // The incoming events will be queued but never handled.\n // Without this piece of code below, you'll get the following JS error:\n // Unsupported top level event type \"topOnGestureHandlerEvent\" dispatched\n ...(isFabric() && Platform.OS === 'android' && customGHEventsConfigFabricAndroid)\n}; // Add gesture specific events to genericDirectEventTypes object exported from UIManager\n// native module.\n// Once new event types are registered with react it is possible to dispatch these\n// events to all kind of native views.\n\nUIManagerAny.genericDirectEventTypes = { ...UIManagerAny.genericDirectEventTypes,\n ...customGHEventsConfig\n}; // In newer versions of RN the `genericDirectEventTypes` is located in the object\n// returned by UIManager.getViewManagerConfig('getConstants') or in older RN UIManager.getConstants(), we need to add it there as well to make\n// it compatible with RN 61+\n\nconst UIManagerConstants = (_UIManagerAny$getView = (_UIManagerAny$getView2 = UIManagerAny.getViewManagerConfig) === null || _UIManagerAny$getView2 === void 0 ? void 0 : _UIManagerAny$getView2.call(UIManagerAny, 'getConstants')) !== null && _UIManagerAny$getView !== void 0 ? _UIManagerAny$getView : (_UIManagerAny$getCons = UIManagerAny.getConstants) === null || _UIManagerAny$getCons === void 0 ? void 0 : _UIManagerAny$getCons.call(UIManagerAny);\n\nif (UIManagerConstants) {\n UIManagerConstants.genericDirectEventTypes = { ...UIManagerConstants.genericDirectEventTypes,\n ...customGHEventsConfig\n };\n} // Wrap JS responder calls and notify gesture handler manager\n\n\nconst {\n setJSResponder: oldSetJSResponder = () => {//no operation\n },\n clearJSResponder: oldClearJSResponder = () => {//no operation\n }\n} = UIManagerAny;\n\nUIManagerAny.setJSResponder = (tag, blockNativeResponder) => {\n RNGestureHandlerModule.handleSetJSResponder(tag, blockNativeResponder);\n oldSetJSResponder(tag, blockNativeResponder);\n};\n\nUIManagerAny.clearJSResponder = () => {\n RNGestureHandlerModule.handleClearJSResponder();\n oldClearJSResponder();\n};\n\nlet allowTouches = true;\nconst DEV_ON_ANDROID = __DEV__ && Platform.OS === 'android'; // Toggled inspector blocks touch events in order to allow inspecting on Android\n// This needs to be a global variable in order to set initial state for `allowTouches` property in Handler component\n\nif (DEV_ON_ANDROID) {\n DeviceEventEmitter.addListener('toggleElementInspector', () => {\n allowTouches = !allowTouches;\n });\n}\n\nfunction hasUnresolvedRefs(props) {\n // TODO(TS) - add type for extract arg\n const extract = refs => {\n if (!Array.isArray(refs)) {\n return refs && refs.current === null;\n }\n\n return refs.some(r => r && r.current === null);\n };\n\n return extract(props['simultaneousHandlers']) || extract(props['waitFor']);\n}\n\nconst stateToPropMappings = {\n [State.UNDETERMINED]: undefined,\n [State.BEGAN]: 'onBegan',\n [State.FAILED]: 'onFailed',\n [State.CANCELLED]: 'onCancelled',\n [State.ACTIVE]: 'onActivated',\n [State.END]: 'onEnded'\n};\nconst UNRESOLVED_REFS_RETRY_LIMIT = 1; // TODO(TS) - make sure that BaseGestureHandlerProps doesn't need other generic parameter to work with custom properties.\n\nexport default function createHandler({\n name,\n allowedProps = [],\n config = {},\n transformProps,\n customNativeProps = []\n}) {\n class Handler extends React.Component {\n constructor(props) {\n super(props);\n\n _defineProperty(this, \"handlerTag\", void 0);\n\n _defineProperty(this, \"config\", void 0);\n\n _defineProperty(this, \"propsRef\", void 0);\n\n _defineProperty(this, \"isMountedRef\", void 0);\n\n _defineProperty(this, \"viewNode\", void 0);\n\n _defineProperty(this, \"viewTag\", void 0);\n\n _defineProperty(this, \"inspectorToggleListener\", void 0);\n\n _defineProperty(this, \"onGestureHandlerEvent\", event => {\n if (event.nativeEvent.handlerTag === this.handlerTag) {\n if (typeof this.props.onGestureEvent === 'function') {\n var _this$props$onGesture, _this$props;\n\n (_this$props$onGesture = (_this$props = this.props).onGestureEvent) === null || _this$props$onGesture === void 0 ? void 0 : _this$props$onGesture.call(_this$props, event);\n }\n } else {\n var _this$props$onGesture2, _this$props2;\n\n (_this$props$onGesture2 = (_this$props2 = this.props).onGestureHandlerEvent) === null || _this$props$onGesture2 === void 0 ? void 0 : _this$props$onGesture2.call(_this$props2, event);\n }\n });\n\n _defineProperty(this, \"onGestureHandlerStateChange\", event => {\n if (event.nativeEvent.handlerTag === this.handlerTag) {\n if (typeof this.props.onHandlerStateChange === 'function') {\n var _this$props$onHandler, _this$props3;\n\n (_this$props$onHandler = (_this$props3 = this.props).onHandlerStateChange) === null || _this$props$onHandler === void 0 ? void 0 : _this$props$onHandler.call(_this$props3, event);\n }\n\n const state = event.nativeEvent.state;\n const stateEventName = stateToPropMappings[state];\n const eventHandler = stateEventName && this.props[stateEventName];\n\n if (eventHandler && typeof eventHandler === 'function') {\n eventHandler(event);\n }\n } else {\n var _this$props$onGesture3, _this$props4;\n\n (_this$props$onGesture3 = (_this$props4 = this.props).onGestureHandlerStateChange) === null || _this$props$onGesture3 === void 0 ? void 0 : _this$props$onGesture3.call(_this$props4, event);\n }\n });\n\n _defineProperty(this, \"refHandler\", node => {\n this.viewNode = node;\n const child = React.Children.only(this.props.children); // TODO(TS) fix ref type\n\n const {\n ref\n } = child;\n\n if (ref !== null) {\n if (typeof ref === 'function') {\n ref(node);\n } else {\n ref.current = node;\n }\n }\n });\n\n _defineProperty(this, \"createGestureHandler\", newConfig => {\n this.config = newConfig;\n RNGestureHandlerModule.createGestureHandler(name, this.handlerTag, newConfig);\n });\n\n _defineProperty(this, \"attachGestureHandler\", newViewTag => {\n this.viewTag = newViewTag;\n\n if (Platform.OS === 'web') {\n // typecast due to dynamic resolution, attachGestureHandler should have web version signature in this branch\n RNGestureHandlerModule.attachGestureHandler(this.handlerTag, newViewTag, ActionType.JS_FUNCTION_OLD_API, // ignored on web\n this.propsRef);\n } else {\n registerOldGestureHandler(this.handlerTag, {\n onGestureEvent: this.onGestureHandlerEvent,\n onGestureStateChange: this.onGestureHandlerStateChange\n });\n\n const actionType = (() => {\n var _this$props5, _this$props6;\n\n const onGestureEvent = (_this$props5 = this.props) === null || _this$props5 === void 0 ? void 0 : _this$props5.onGestureEvent;\n const isGestureHandlerWorklet = onGestureEvent && ('current' in onGestureEvent || 'workletEventHandler' in onGestureEvent);\n const onHandlerStateChange = (_this$props6 = this.props) === null || _this$props6 === void 0 ? void 0 : _this$props6.onHandlerStateChange;\n const isStateChangeHandlerWorklet = onHandlerStateChange && ('current' in onHandlerStateChange || 'workletEventHandler' in onHandlerStateChange);\n const isReanimatedHandler = isGestureHandlerWorklet || isStateChangeHandlerWorklet;\n\n if (isReanimatedHandler) {\n // Reanimated worklet\n return ActionType.REANIMATED_WORKLET;\n } else if (onGestureEvent && '__isNative' in onGestureEvent) {\n // Animated.event with useNativeDriver: true\n return ActionType.NATIVE_ANIMATED_EVENT;\n } else {\n // JS callback or Animated.event with useNativeDriver: false\n return ActionType.JS_FUNCTION_OLD_API;\n }\n })();\n\n RNGestureHandlerModule.attachGestureHandler(this.handlerTag, newViewTag, actionType);\n }\n\n scheduleFlushOperations();\n });\n\n _defineProperty(this, \"updateGestureHandler\", newConfig => {\n this.config = newConfig;\n RNGestureHandlerModule.updateGestureHandler(this.handlerTag, newConfig);\n scheduleFlushOperations();\n });\n\n this.handlerTag = getNextHandlerTag();\n this.config = {};\n this.propsRef = /*#__PURE__*/React.createRef();\n this.isMountedRef = /*#__PURE__*/React.createRef();\n this.state = {\n allowTouches\n };\n\n if (props.id) {\n if (handlerIDToTag[props.id] !== undefined) {\n throw new Error(`Handler with ID \"${props.id}\" already registered`);\n }\n\n handlerIDToTag[props.id] = this.handlerTag;\n }\n }\n\n componentDidMount() {\n const props = this.props;\n this.isMountedRef.current = true;\n\n if (DEV_ON_ANDROID) {\n this.inspectorToggleListener = DeviceEventEmitter.addListener('toggleElementInspector', () => {\n this.setState(_ => ({\n allowTouches\n }));\n this.update(UNRESOLVED_REFS_RETRY_LIMIT);\n });\n }\n\n if (hasUnresolvedRefs(props)) {\n // If there are unresolved refs (e.g. \".current\" has not yet been set)\n // passed as `simultaneousHandlers` or `waitFor`, we enqueue a call to\n // _update method that will try to update native handler props using\n // queueMicrotask. This makes it so update() function gets called after all\n // react components are mounted and we expect the missing ref object to\n // be resolved by then.\n ghQueueMicrotask(() => {\n this.update(UNRESOLVED_REFS_RETRY_LIMIT);\n });\n }\n\n this.createGestureHandler(filterConfig(transformProps ? transformProps(this.props) : this.props, [...allowedProps, ...customNativeProps], config));\n this.attachGestureHandler(findNodeHandle(this.viewNode)); // TODO(TS) - check if this can be null\n }\n\n componentDidUpdate() {\n const viewTag = findNodeHandle(this.viewNode);\n\n if (this.viewTag !== viewTag) {\n this.attachGestureHandler(viewTag); // TODO(TS) - check interaction between _viewTag & findNodeHandle\n }\n\n this.update(UNRESOLVED_REFS_RETRY_LIMIT);\n }\n\n componentWillUnmount() {\n var _this$inspectorToggle;\n\n (_this$inspectorToggle = this.inspectorToggleListener) === null || _this$inspectorToggle === void 0 ? void 0 : _this$inspectorToggle.remove();\n this.isMountedRef.current = false;\n RNGestureHandlerModule.dropGestureHandler(this.handlerTag);\n scheduleFlushOperations(); // We can't use this.props.id directly due to TS generic type narrowing bug, see https://github.com/microsoft/TypeScript/issues/13995 for more context\n\n const handlerID = this.props.id;\n\n if (handlerID) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete handlerIDToTag[handlerID];\n }\n }\n\n update(remainingTries) {\n if (!this.isMountedRef.current) {\n return;\n }\n\n const props = this.props; // When ref is set via a function i.e. `ref={(r) => refObject.current = r}` instead of\n // `ref={refObject}` it's possible that it won't be resolved in time. Seems like trying\n // again is easy enough fix.\n\n if (hasUnresolvedRefs(props) && remainingTries > 0) {\n ghQueueMicrotask(() => {\n this.update(remainingTries - 1);\n });\n } else {\n const newConfig = filterConfig(transformProps ? transformProps(this.props) : this.props, [...allowedProps, ...customNativeProps], config);\n\n if (!deepEqual(this.config, newConfig)) {\n this.updateGestureHandler(newConfig);\n }\n }\n }\n\n setNativeProps(updates) {\n const mergedProps = { ...this.props,\n ...updates\n };\n const newConfig = filterConfig(transformProps ? transformProps(mergedProps) : mergedProps, [...allowedProps, ...customNativeProps], config);\n this.updateGestureHandler(newConfig);\n }\n\n render() {\n var _this$props$testID;\n\n if (__DEV__ && !this.context && !isJestEnv() && Platform.OS !== 'web') {\n throw new Error(name + ' must be used as a descendant of GestureHandlerRootView. Otherwise the gestures will not be recognized. See https://docs.swmansion.com/react-native-gesture-handler/docs/installation for more details.');\n }\n\n let gestureEventHandler = this.onGestureHandlerEvent; // Another instance of https://github.com/microsoft/TypeScript/issues/13995\n\n const {\n onGestureEvent,\n onGestureHandlerEvent\n } = this.props;\n\n if (onGestureEvent && typeof onGestureEvent !== 'function') {\n // If it's not a method it should be an native Animated.event\n // object. We set it directly as the handler for the view\n // In this case nested handlers are not going to be supported\n if (onGestureHandlerEvent) {\n throw new Error('Nesting touch handlers with native animated driver is not supported yet');\n }\n\n gestureEventHandler = onGestureEvent;\n } else {\n if (onGestureHandlerEvent && typeof onGestureHandlerEvent !== 'function') {\n throw new Error('Nesting touch handlers with native animated driver is not supported yet');\n }\n }\n\n let gestureStateEventHandler = this.onGestureHandlerStateChange; // Another instance of https://github.com/microsoft/TypeScript/issues/13995\n\n const {\n onHandlerStateChange,\n onGestureHandlerStateChange\n } = this.props;\n\n if (onHandlerStateChange && typeof onHandlerStateChange !== 'function') {\n // If it's not a method it should be an native Animated.event\n // object. We set it directly as the handler for the view\n // In this case nested handlers are not going to be supported\n if (onGestureHandlerStateChange) {\n throw new Error('Nesting touch handlers with native animated driver is not supported yet');\n }\n\n gestureStateEventHandler = onHandlerStateChange;\n } else {\n if (onGestureHandlerStateChange && typeof onGestureHandlerStateChange !== 'function') {\n throw new Error('Nesting touch handlers with native animated driver is not supported yet');\n }\n }\n\n const events = {\n onGestureHandlerEvent: this.state.allowTouches ? gestureEventHandler : undefined,\n onGestureHandlerStateChange: this.state.allowTouches ? gestureStateEventHandler : undefined\n };\n this.propsRef.current = events;\n let child = null;\n\n try {\n child = React.Children.only(this.props.children);\n } catch (e) {\n throw new Error(tagMessage(`${name} got more than one view as a child. If you want the gesture to work on multiple views, wrap them with a common parent and attach the gesture to that view.`));\n }\n\n let grandChildren = child.props.children;\n\n if (__DEV__ && child.type && (child.type === 'RNGestureHandlerButton' || child.type.name === 'View' || child.type.displayName === 'View')) {\n grandChildren = React.Children.toArray(grandChildren);\n grandChildren.push( /*#__PURE__*/React.createElement(PressabilityDebugView, {\n key: \"pressabilityDebugView\",\n color: \"mediumspringgreen\",\n hitSlop: child.props.hitSlop\n }));\n }\n\n return /*#__PURE__*/React.cloneElement(child, {\n ref: this.refHandler,\n collapsable: false,\n ...(isJestEnv() ? {\n handlerType: name,\n handlerTag: this.handlerTag\n } : {}),\n testID: (_this$props$testID = this.props.testID) !== null && _this$props$testID !== void 0 ? _this$props$testID : child.props.testID,\n ...events\n }, grandChildren);\n }\n\n }\n\n _defineProperty(Handler, \"displayName\", name);\n\n _defineProperty(Handler, \"contextType\", GestureHandlerRootViewContext);\n\n return Handler;\n}\n//# sourceMappingURL=createHandler.js.map","// customDirectEventTypes doesn't exist in react-native-web, therefore importing it\n// directly in createHandler.tsx would end in crash.\nconst customDirectEventTypes = {};\nexport { customDirectEventTypes };\n//# sourceMappingURL=customDirectEventTypes.web.js.map","var baseIsEqual = require('./_baseIsEqual');\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\nmodule.exports = isEqual;\n","var baseIsEqualDeep = require('./_baseIsEqualDeep'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\nmodule.exports = baseIsEqual;\n","var Stack = require('./_Stack'),\n equalArrays = require('./_equalArrays'),\n equalByTag = require('./_equalByTag'),\n equalObjects = require('./_equalObjects'),\n getTag = require('./_getTag'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isTypedArray = require('./isTypedArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\nmodule.exports = baseIsEqualDeep;\n","var ListCache = require('./_ListCache'),\n stackClear = require('./_stackClear'),\n stackDelete = require('./_stackDelete'),\n stackGet = require('./_stackGet'),\n stackHas = require('./_stackHas'),\n stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n","var listCacheClear = require('./_listCacheClear'),\n listCacheDelete = require('./_listCacheDelete'),\n listCacheGet = require('./_listCacheGet'),\n listCacheHas = require('./_listCacheHas'),\n listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nmodule.exports = listCacheDelete;\n","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nmodule.exports = assocIndexOf;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nmodule.exports = listCacheSet;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nmodule.exports = stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nmodule.exports = stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n","var ListCache = require('./_ListCache'),\n Map = require('./_Map'),\n MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nmodule.exports = stackSet;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","var baseIsNative = require('./_baseIsNative'),\n getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","var isFunction = require('./isFunction'),\n isMasked = require('./_isMasked'),\n isObject = require('./isObject'),\n toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nmodule.exports = toSource;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","var mapCacheClear = require('./_mapCacheClear'),\n mapCacheDelete = require('./_mapCacheDelete'),\n mapCacheGet = require('./_mapCacheGet'),\n mapCacheHas = require('./_mapCacheHas'),\n mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n","var Hash = require('./_Hash'),\n ListCache = require('./_ListCache'),\n Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nmodule.exports = mapCacheClear;\n","var hashClear = require('./_hashClear'),\n hashDelete = require('./_hashDelete'),\n hashGet = require('./_hashGet'),\n hashHas = require('./_hashHas'),\n hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nmodule.exports = hashClear;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nmodule.exports = hashSet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = mapCacheDelete;\n","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nmodule.exports = getMapData;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nmodule.exports = isKeyable;\n","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nmodule.exports = mapCacheSet;\n","var SetCache = require('./_SetCache'),\n arraySome = require('./_arraySome'),\n cacheHas = require('./_cacheHas');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Check that cyclic values are equal.\n var arrStacked = stack.get(array);\n var othStacked = stack.get(other);\n if (arrStacked && othStacked) {\n return arrStacked == other && othStacked == array;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalArrays;\n","var MapCache = require('./_MapCache'),\n setCacheAdd = require('./_setCacheAdd'),\n setCacheHas = require('./_setCacheHas');\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nmodule.exports = SetCache;\n","/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\nmodule.exports = setCacheAdd;\n","/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\nmodule.exports = setCacheHas;\n","/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arraySome;\n","/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\nmodule.exports = cacheHas;\n","var Symbol = require('./_Symbol'),\n Uint8Array = require('./_Uint8Array'),\n eq = require('./eq'),\n equalArrays = require('./_equalArrays'),\n mapToArray = require('./_mapToArray'),\n setToArray = require('./_setToArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\nmodule.exports = equalByTag;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\nmodule.exports = mapToArray;\n","/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\nmodule.exports = setToArray;\n","var getAllKeys = require('./_getAllKeys');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Check that cyclic values are equal.\n var objStacked = stack.get(object);\n var othStacked = stack.get(other);\n if (objStacked && othStacked) {\n return objStacked == other && othStacked == object;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalObjects;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbols = require('./_getSymbols'),\n keys = require('./keys');\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nmodule.exports = getAllKeys;\n","var arrayPush = require('./_arrayPush'),\n isArray = require('./isArray');\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nmodule.exports = baseGetAllKeys;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nmodule.exports = arrayPush;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","var arrayFilter = require('./_arrayFilter'),\n stubArray = require('./stubArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nmodule.exports = getSymbols;\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nmodule.exports = arrayFilter;\n","/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nmodule.exports = stubArray;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeys = require('./_baseKeys'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nmodule.exports = keys;\n","var baseTimes = require('./_baseTimes'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isIndex = require('./_isIndex'),\n isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = arrayLikeKeys;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nmodule.exports = baseTimes;\n","var baseIsArguments = require('./_baseIsArguments'),\n isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var root = require('./_root'),\n stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = stubFalse;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","var baseGetTag = require('./_baseGetTag'),\n isLength = require('./isLength'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nmodule.exports = baseUnary;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n","var isPrototype = require('./_isPrototype'),\n nativeKeys = require('./_nativeKeys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeys;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nmodule.exports = isPrototype;\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nmodule.exports = overArg;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","var DataView = require('./_DataView'),\n Map = require('./_Map'),\n Promise = require('./_Promise'),\n Set = require('./_Set'),\n WeakMap = require('./_WeakMap'),\n baseGetTag = require('./_baseGetTag'),\n toSource = require('./_toSource');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nmodule.exports = getTag;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n","export const ActionType = {\n REANIMATED_WORKLET: 1,\n NATIVE_ANIMATED_EVENT: 2,\n JS_FUNCTION_OLD_API: 3,\n JS_FUNCTION_NEW_API: 4\n}; // eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; it can be used as a type and as a value\n//# sourceMappingURL=ActionType.js.map","// PressabilityDebugView is not implemented in react-native-web\nexport function PressabilityDebugView() {\n return null;\n}\n//# sourceMappingURL=PressabilityDebugView.web.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport React from 'react';\nimport { tagMessage } from '../utils';\nimport PlatformConstants from '../PlatformConstants';\nimport createHandler from './createHandler';\nimport { baseGestureHandlerProps } from './gestureHandlerCommon';\nexport const forceTouchGestureHandlerProps = ['minForce', 'maxForce', 'feedbackOnActivation']; // implicit `children` prop has been removed in @types/react^18.0.0\n\nclass ForceTouchFallback extends React.Component {\n componentDidMount() {\n console.warn(tagMessage('ForceTouchGestureHandler is not available on this platform. Please use ForceTouchGestureHandler.forceTouchAvailable to conditionally render other components that would provide a fallback behavior specific to your usecase'));\n }\n\n render() {\n return this.props.children;\n }\n\n}\n\n_defineProperty(ForceTouchFallback, \"forceTouchAvailable\", false);\n\nexport const forceTouchHandlerName = 'ForceTouchGestureHandler'; // eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\n\nexport const ForceTouchGestureHandler = PlatformConstants !== null && PlatformConstants !== void 0 && PlatformConstants.forceTouchAvailable ? createHandler({\n name: forceTouchHandlerName,\n allowedProps: [...baseGestureHandlerProps, ...forceTouchGestureHandlerProps],\n config: {}\n}) : ForceTouchFallback;\nForceTouchGestureHandler.forceTouchAvailable = (PlatformConstants === null || PlatformConstants === void 0 ? void 0 : PlatformConstants.forceTouchAvailable) || false;\n//# sourceMappingURL=ForceTouchGestureHandler.js.map","export default {\n get forceTouchAvailable() {\n return false;\n }\n\n};\n//# sourceMappingURL=PlatformConstants.web.js.map","import createHandler from './createHandler';\nimport { baseGestureHandlerProps } from './gestureHandlerCommon';\nexport const longPressGestureHandlerProps = ['minDurationMs', 'maxDist'];\nexport const longPressHandlerName = 'LongPressGestureHandler';\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const LongPressGestureHandler = createHandler({\n name: longPressHandlerName,\n allowedProps: [...baseGestureHandlerProps, ...longPressGestureHandlerProps],\n config: {\n shouldCancelWhenOutside: true\n }\n});\n//# sourceMappingURL=LongPressGestureHandler.js.map","import createHandler from './createHandler';\nimport { baseGestureHandlerProps } from './gestureHandlerCommon';\nexport const panGestureHandlerProps = ['activeOffsetY', 'activeOffsetX', 'failOffsetY', 'failOffsetX', 'minDist', 'minVelocity', 'minVelocityX', 'minVelocityY', 'minPointers', 'maxPointers', 'avgTouches', 'enableTrackpadTwoFingerGesture', 'activateAfterLongPress'];\nexport const panGestureHandlerCustomNativeProps = ['activeOffsetYStart', 'activeOffsetYEnd', 'activeOffsetXStart', 'activeOffsetXEnd', 'failOffsetYStart', 'failOffsetYEnd', 'failOffsetXStart', 'failOffsetXEnd'];\nexport const panHandlerName = 'PanGestureHandler';\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const PanGestureHandler = createHandler({\n name: panHandlerName,\n allowedProps: [...baseGestureHandlerProps, ...panGestureHandlerProps],\n config: {},\n transformProps: managePanProps,\n customNativeProps: panGestureHandlerCustomNativeProps\n});\n\nfunction validatePanGestureHandlerProps(props) {\n if (Array.isArray(props.activeOffsetX) && (props.activeOffsetX[0] > 0 || props.activeOffsetX[1] < 0)) {\n throw new Error(`First element of activeOffsetX should be negative, a the second one should be positive`);\n }\n\n if (Array.isArray(props.activeOffsetY) && (props.activeOffsetY[0] > 0 || props.activeOffsetY[1] < 0)) {\n throw new Error(`First element of activeOffsetY should be negative, a the second one should be positive`);\n }\n\n if (Array.isArray(props.failOffsetX) && (props.failOffsetX[0] > 0 || props.failOffsetX[1] < 0)) {\n throw new Error(`First element of failOffsetX should be negative, a the second one should be positive`);\n }\n\n if (Array.isArray(props.failOffsetY) && (props.failOffsetY[0] > 0 || props.failOffsetY[1] < 0)) {\n throw new Error(`First element of failOffsetY should be negative, a the second one should be positive`);\n }\n\n if (props.minDist && (props.failOffsetX || props.failOffsetY)) {\n throw new Error(`It is not supported to use minDist with failOffsetX or failOffsetY, use activeOffsetX and activeOffsetY instead`);\n }\n\n if (props.minDist && (props.activeOffsetX || props.activeOffsetY)) {\n throw new Error(`It is not supported to use minDist with activeOffsetX or activeOffsetY`);\n }\n}\n\nfunction transformPanGestureHandlerProps(props) {\n const res = { ...props\n };\n\n if (props.activeOffsetX !== undefined) {\n delete res.activeOffsetX;\n\n if (Array.isArray(props.activeOffsetX)) {\n res.activeOffsetXStart = props.activeOffsetX[0];\n res.activeOffsetXEnd = props.activeOffsetX[1];\n } else if (props.activeOffsetX < 0) {\n res.activeOffsetXStart = props.activeOffsetX;\n } else {\n res.activeOffsetXEnd = props.activeOffsetX;\n }\n }\n\n if (props.activeOffsetY !== undefined) {\n delete res.activeOffsetY;\n\n if (Array.isArray(props.activeOffsetY)) {\n res.activeOffsetYStart = props.activeOffsetY[0];\n res.activeOffsetYEnd = props.activeOffsetY[1];\n } else if (props.activeOffsetY < 0) {\n res.activeOffsetYStart = props.activeOffsetY;\n } else {\n res.activeOffsetYEnd = props.activeOffsetY;\n }\n }\n\n if (props.failOffsetX !== undefined) {\n delete res.failOffsetX;\n\n if (Array.isArray(props.failOffsetX)) {\n res.failOffsetXStart = props.failOffsetX[0];\n res.failOffsetXEnd = props.failOffsetX[1];\n } else if (props.failOffsetX < 0) {\n res.failOffsetXStart = props.failOffsetX;\n } else {\n res.failOffsetXEnd = props.failOffsetX;\n }\n }\n\n if (props.failOffsetY !== undefined) {\n delete res.failOffsetY;\n\n if (Array.isArray(props.failOffsetY)) {\n res.failOffsetYStart = props.failOffsetY[0];\n res.failOffsetYEnd = props.failOffsetY[1];\n } else if (props.failOffsetY < 0) {\n res.failOffsetYStart = props.failOffsetY;\n } else {\n res.failOffsetYEnd = props.failOffsetY;\n }\n }\n\n return res;\n}\n\nexport function managePanProps(props) {\n if (__DEV__) {\n validatePanGestureHandlerProps(props);\n }\n\n return transformPanGestureHandlerProps(props);\n}\n//# sourceMappingURL=PanGestureHandler.js.map","import createHandler from './createHandler';\nimport { baseGestureHandlerProps } from './gestureHandlerCommon';\nexport const pinchHandlerName = 'PinchGestureHandler';\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const PinchGestureHandler = createHandler({\n name: pinchHandlerName,\n allowedProps: baseGestureHandlerProps,\n config: {}\n});\n//# sourceMappingURL=PinchGestureHandler.js.map","import createHandler from './createHandler';\nimport { baseGestureHandlerProps } from './gestureHandlerCommon';\nexport const rotationHandlerName = 'RotationGestureHandler';\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const RotationGestureHandler = createHandler({\n name: rotationHandlerName,\n allowedProps: baseGestureHandlerProps,\n config: {}\n});\n//# sourceMappingURL=RotationGestureHandler.js.map","import createHandler from './createHandler';\nimport { baseGestureHandlerProps } from './gestureHandlerCommon';\nexport const flingGestureHandlerProps = ['numberOfPointers', 'direction'];\nexport const flingHandlerName = 'FlingGestureHandler';\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const FlingGestureHandler = createHandler({\n name: flingHandlerName,\n allowedProps: [...baseGestureHandlerProps, ...flingGestureHandlerProps],\n config: {}\n});\n//# sourceMappingURL=FlingGestureHandler.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from 'react';\nimport { useImperativeHandle, useRef } from 'react';\nimport { NativeViewGestureHandler, nativeViewProps } from './NativeViewGestureHandler';\n/*\n * This array should consist of:\n * - All keys in propTypes from NativeGestureHandler\n * (and all keys in GestureHandlerPropTypes)\n * - 'onGestureHandlerEvent'\n * - 'onGestureHandlerStateChange'\n */\n\nconst NATIVE_WRAPPER_PROPS_FILTER = [...nativeViewProps, 'onGestureHandlerEvent', 'onGestureHandlerStateChange'];\nexport default function createNativeWrapper(Component, config = {}) {\n var _Component$render;\n\n const ComponentWrapper = /*#__PURE__*/React.forwardRef((props, ref) => {\n // filter out props that should be passed to gesture handler wrapper\n const gestureHandlerProps = Object.keys(props).reduce((res, key) => {\n // TS being overly protective with it's types, see https://github.com/microsoft/TypeScript/issues/26255#issuecomment-458013731 for more info\n const allowedKeys = NATIVE_WRAPPER_PROPS_FILTER;\n\n if (allowedKeys.includes(key)) {\n // @ts-ignore FIXME(TS)\n res[key] = props[key];\n }\n\n return res;\n }, { ...config\n } // watch out not to modify config\n );\n\n const _ref = useRef();\n\n const _gestureHandlerRef = useRef();\n\n useImperativeHandle(ref, // @ts-ignore TODO(TS) decide how nulls work in this context\n () => {\n const node = _gestureHandlerRef.current; // add handlerTag for relations config\n\n if (_ref.current && node) {\n // @ts-ignore FIXME(TS) think about createHandler return type\n _ref.current.handlerTag = node.handlerTag;\n return _ref.current;\n }\n\n return null;\n }, [_ref, _gestureHandlerRef]);\n return /*#__PURE__*/React.createElement(NativeViewGestureHandler, _extends({}, gestureHandlerProps, {\n // @ts-ignore TODO(TS)\n ref: _gestureHandlerRef\n }), /*#__PURE__*/React.createElement(Component, _extends({}, props, {\n ref: _ref\n })));\n }); // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\n ComponentWrapper.displayName = (Component === null || Component === void 0 ? void 0 : Component.displayName) || ( // @ts-ignore if render doesn't exist it will return undefined and go further\n Component === null || Component === void 0 ? void 0 : (_Component$render = Component.render) === null || _Component$render === void 0 ? void 0 : _Component$render.name) || typeof Component === 'string' && Component || 'ComponentWrapper';\n return ComponentWrapper;\n}\n//# sourceMappingURL=createNativeWrapper.js.map","import createHandler from './createHandler';\nimport { baseGestureHandlerProps } from './gestureHandlerCommon';\nexport const nativeViewGestureHandlerProps = ['shouldActivateOnStart', 'disallowInterruption'];\nexport const nativeViewProps = [...baseGestureHandlerProps, ...nativeViewGestureHandlerProps];\nexport const nativeViewHandlerName = 'NativeViewGestureHandler';\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const NativeViewGestureHandler = createHandler({\n name: nativeViewHandlerName,\n allowedProps: nativeViewProps,\n config: {}\n});\n//# sourceMappingURL=NativeViewGestureHandler.js.map","var _Reanimated$default$c, _Reanimated$default;\n\nimport React, { useContext, useEffect, useRef, useState } from 'react';\nimport { BaseGesture, CALLBACK_TYPE } from './gesture';\nimport { Reanimated } from './reanimatedWrapper';\nimport { registerHandler, unregisterHandler } from '../handlersRegistry';\nimport RNGestureHandlerModule from '../../RNGestureHandlerModule';\nimport { baseGestureHandlerWithMonitorProps, filterConfig, findNodeHandle, scheduleFlushOperations } from '../gestureHandlerCommon';\nimport { GestureStateManager } from './gestureStateManager';\nimport { flingGestureHandlerProps } from '../FlingGestureHandler';\nimport { forceTouchGestureHandlerProps } from '../ForceTouchGestureHandler';\nimport { longPressGestureHandlerProps } from '../LongPressGestureHandler';\nimport { panGestureHandlerProps, panGestureHandlerCustomNativeProps } from '../PanGestureHandler';\nimport { tapGestureHandlerProps } from '../TapGestureHandler';\nimport { hoverGestureHandlerProps } from './hoverGesture';\nimport { State } from '../../State';\nimport { TouchEventType } from '../../TouchEventType';\nimport { ActionType } from '../../ActionType';\nimport { isFabric, isJestEnv, tagMessage } from '../../utils';\nimport { getReactNativeVersion } from '../../getReactNativeVersion';\nimport { getShadowNodeFromRef } from '../../getShadowNodeFromRef';\nimport { Platform } from 'react-native';\nimport { onGestureHandlerEvent } from './eventReceiver';\nimport { RNRenderer } from '../../RNRenderer';\nimport { isNewWebImplementationEnabled } from '../../EnableNewWebImplementation';\nimport { nativeViewGestureHandlerProps } from '../NativeViewGestureHandler';\nimport GestureHandlerRootViewContext from '../../GestureHandlerRootViewContext';\nimport { ghQueueMicrotask } from '../../ghQueueMicrotask';\nconst ALLOWED_PROPS = [...baseGestureHandlerWithMonitorProps, ...tapGestureHandlerProps, ...panGestureHandlerProps, ...panGestureHandlerCustomNativeProps, ...longPressGestureHandlerProps, ...forceTouchGestureHandlerProps, ...flingGestureHandlerProps, ...hoverGestureHandlerProps, ...nativeViewGestureHandlerProps];\n\nfunction convertToHandlerTag(ref) {\n if (typeof ref === 'number') {\n return ref;\n } else if (ref instanceof BaseGesture) {\n return ref.handlerTag;\n } else {\n var _ref$current$handlerT, _ref$current;\n\n // @ts-ignore in this case it should be a ref either to gesture object or\n // a gesture handler component, in both cases handlerTag property exists\n return (_ref$current$handlerT = (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.handlerTag) !== null && _ref$current$handlerT !== void 0 ? _ref$current$handlerT : -1;\n }\n}\n\nfunction extractValidHandlerTags(interactionGroup) {\n var _interactionGroup$map, _interactionGroup$map2;\n\n return (_interactionGroup$map = interactionGroup === null || interactionGroup === void 0 ? void 0 : (_interactionGroup$map2 = interactionGroup.map(convertToHandlerTag)) === null || _interactionGroup$map2 === void 0 ? void 0 : _interactionGroup$map2.filter(tag => tag > 0)) !== null && _interactionGroup$map !== void 0 ? _interactionGroup$map : [];\n}\n\nfunction dropHandlers(preparedGesture) {\n for (const handler of preparedGesture.config) {\n RNGestureHandlerModule.dropGestureHandler(handler.handlerTag);\n unregisterHandler(handler.handlerTag, handler.config.testId);\n }\n\n scheduleFlushOperations();\n}\n\nfunction checkGestureCallbacksForWorklets(gesture) {\n // if a gesture is explicitly marked to run on the JS thread there is no need to check\n // if callbacks are worklets as the user is aware they will be ran on the JS thread\n if (gesture.config.runOnJS) {\n return;\n }\n\n const areSomeNotWorklets = gesture.handlers.isWorklet.includes(false);\n const areSomeWorklets = gesture.handlers.isWorklet.includes(true); // if some of the callbacks are worklets and some are not, and the gesture is not\n // explicitly marked with `.runOnJS(true)` show an error\n\n if (areSomeNotWorklets && areSomeWorklets) {\n console.error(tagMessage(`Some of the callbacks in the gesture are worklets and some are not. Either make sure that all calbacks are marked as 'worklet' if you wish to run them on the UI thread or use '.runOnJS(true)' modifier on the gesture explicitly to run all callbacks on the JS thread.`));\n }\n}\n\nfunction attachHandlers({\n preparedGesture,\n gestureConfig,\n gesture,\n viewTag,\n webEventHandlersRef,\n mountedRef\n}) {\n if (!preparedGesture.firstExecution) {\n gestureConfig.initialize();\n } else {\n preparedGesture.firstExecution = false;\n } // use queueMicrotask to extract handlerTags, because all refs should be initialized\n // when it's ran\n\n\n ghQueueMicrotask(() => {\n if (!mountedRef.current) {\n return;\n }\n\n gestureConfig.prepare();\n });\n\n for (const handler of gesture) {\n checkGestureCallbacksForWorklets(handler);\n RNGestureHandlerModule.createGestureHandler(handler.handlerName, handler.handlerTag, filterConfig(handler.config, ALLOWED_PROPS));\n registerHandler(handler.handlerTag, handler, handler.config.testId);\n } // use queueMicrotask to extract handlerTags, because all refs should be initialized\n // when it's ran\n\n\n ghQueueMicrotask(() => {\n if (!mountedRef.current) {\n return;\n }\n\n for (const handler of gesture) {\n let requireToFail = [];\n\n if (handler.config.requireToFail) {\n requireToFail = extractValidHandlerTags(handler.config.requireToFail);\n }\n\n let simultaneousWith = [];\n\n if (handler.config.simultaneousWith) {\n simultaneousWith = extractValidHandlerTags(handler.config.simultaneousWith);\n }\n\n let blocksHandlers = [];\n\n if (handler.config.blocksHandlers) {\n blocksHandlers = extractValidHandlerTags(handler.config.blocksHandlers);\n }\n\n RNGestureHandlerModule.updateGestureHandler(handler.handlerTag, filterConfig(handler.config, ALLOWED_PROPS, {\n simultaneousHandlers: simultaneousWith,\n waitFor: requireToFail,\n blocksHandlers: blocksHandlers\n }));\n }\n\n scheduleFlushOperations();\n });\n preparedGesture.config = gesture;\n\n for (const gesture of preparedGesture.config) {\n const actionType = gesture.shouldUseReanimated ? ActionType.REANIMATED_WORKLET : ActionType.JS_FUNCTION_NEW_API;\n\n if (Platform.OS === 'web') {\n RNGestureHandlerModule.attachGestureHandler(gesture.handlerTag, viewTag, ActionType.JS_FUNCTION_OLD_API, // ignored on web\n webEventHandlersRef);\n } else {\n RNGestureHandlerModule.attachGestureHandler(gesture.handlerTag, viewTag, actionType);\n }\n }\n\n if (preparedGesture.animatedHandlers) {\n const isAnimatedGesture = g => g.shouldUseReanimated;\n\n preparedGesture.animatedHandlers.value = gesture.filter(isAnimatedGesture).map(g => g.handlers);\n }\n}\n\nfunction updateHandlers(preparedGesture, gestureConfig, gesture, mountedRef) {\n gestureConfig.prepare();\n\n for (let i = 0; i < gesture.length; i++) {\n const handler = preparedGesture.config[i];\n checkGestureCallbacksForWorklets(handler); // only update handlerTag when it's actually different, it may be the same\n // if gesture config object is wrapped with useMemo\n\n if (gesture[i].handlerTag !== handler.handlerTag) {\n gesture[i].handlerTag = handler.handlerTag;\n gesture[i].handlers.handlerTag = handler.handlerTag;\n }\n } // use queueMicrotask to extract handlerTags, because when it's ran, all refs should be updated\n // and handlerTags in BaseGesture references should be updated in the loop above (we need to wait\n // in case of external relations)\n\n\n ghQueueMicrotask(() => {\n if (!mountedRef.current) {\n return;\n }\n\n for (let i = 0; i < gesture.length; i++) {\n const handler = preparedGesture.config[i];\n handler.config = gesture[i].config;\n handler.handlers = gesture[i].handlers;\n const requireToFail = extractValidHandlerTags(handler.config.requireToFail);\n const simultaneousWith = extractValidHandlerTags(handler.config.simultaneousWith);\n RNGestureHandlerModule.updateGestureHandler(handler.handlerTag, filterConfig(handler.config, ALLOWED_PROPS, {\n simultaneousHandlers: simultaneousWith,\n waitFor: requireToFail\n }));\n registerHandler(handler.handlerTag, handler, handler.config.testId);\n }\n\n if (preparedGesture.animatedHandlers) {\n var _preparedGesture$anim;\n\n const previousHandlersValue = (_preparedGesture$anim = preparedGesture.animatedHandlers.value) !== null && _preparedGesture$anim !== void 0 ? _preparedGesture$anim : [];\n const newHandlersValue = preparedGesture.config.filter(g => g.shouldUseReanimated) // ignore gestures that shouldn't run on UI\n .map(g => g.handlers); // if amount of gesture configs changes, we need to update the callbacks in shared value\n\n let shouldUpdateSharedValue = previousHandlersValue.length !== newHandlersValue.length;\n\n if (!shouldUpdateSharedValue) {\n // if the amount is the same, we need to check if any of the configs inside has changed\n for (let i = 0; i < newHandlersValue.length; i++) {\n if ( // we can use the `gestureId` prop as it's unique for every config instance\n newHandlersValue[i].gestureId !== previousHandlersValue[i].gestureId) {\n shouldUpdateSharedValue = true;\n break;\n }\n }\n }\n\n if (shouldUpdateSharedValue) {\n preparedGesture.animatedHandlers.value = newHandlersValue;\n }\n }\n\n scheduleFlushOperations();\n });\n}\n\nfunction needsToReattach(preparedGesture, gesture) {\n if (gesture.length !== preparedGesture.config.length) {\n return true;\n }\n\n for (let i = 0; i < gesture.length; i++) {\n if (gesture[i].handlerName !== preparedGesture.config[i].handlerName || gesture[i].shouldUseReanimated !== preparedGesture.config[i].shouldUseReanimated) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction isStateChangeEvent(event) {\n 'worklet'; // @ts-ignore Yes, the oldState prop is missing on GestureTouchEvent, that's the point\n\n return event.oldState != null;\n}\n\nfunction isTouchEvent(event) {\n 'worklet';\n\n return event.eventType != null;\n}\n\nfunction getHandler(type, gesture) {\n 'worklet';\n\n switch (type) {\n case CALLBACK_TYPE.BEGAN:\n return gesture.onBegin;\n\n case CALLBACK_TYPE.START:\n return gesture.onStart;\n\n case CALLBACK_TYPE.UPDATE:\n return gesture.onUpdate;\n\n case CALLBACK_TYPE.CHANGE:\n return gesture.onChange;\n\n case CALLBACK_TYPE.END:\n return gesture.onEnd;\n\n case CALLBACK_TYPE.FINALIZE:\n return gesture.onFinalize;\n\n case CALLBACK_TYPE.TOUCHES_DOWN:\n return gesture.onTouchesDown;\n\n case CALLBACK_TYPE.TOUCHES_MOVE:\n return gesture.onTouchesMove;\n\n case CALLBACK_TYPE.TOUCHES_UP:\n return gesture.onTouchesUp;\n\n case CALLBACK_TYPE.TOUCHES_CANCELLED:\n return gesture.onTouchesCancelled;\n }\n}\n\nfunction touchEventTypeToCallbackType(eventType) {\n 'worklet';\n\n switch (eventType) {\n case TouchEventType.TOUCHES_DOWN:\n return CALLBACK_TYPE.TOUCHES_DOWN;\n\n case TouchEventType.TOUCHES_MOVE:\n return CALLBACK_TYPE.TOUCHES_MOVE;\n\n case TouchEventType.TOUCHES_UP:\n return CALLBACK_TYPE.TOUCHES_UP;\n\n case TouchEventType.TOUCHES_CANCELLED:\n return CALLBACK_TYPE.TOUCHES_CANCELLED;\n }\n\n return CALLBACK_TYPE.UNDEFINED;\n}\n\nfunction runWorklet(type, gesture, event, ...args) {\n 'worklet';\n\n const handler = getHandler(type, gesture);\n\n if (gesture.isWorklet[type]) {\n // @ts-ignore Logic below makes sure the correct event is send to the\n // correct handler.\n handler === null || handler === void 0 ? void 0 : handler(event, ...args);\n } else if (handler) {\n console.warn(tagMessage('Animated gesture callback must be a worklet'));\n }\n}\n\nfunction useAnimatedGesture(preparedGesture, needsRebuild) {\n if (!Reanimated) {\n return;\n } // Hooks are called conditionally, but the condition is whether the\n // react-native-reanimated is installed, which shouldn't change while running\n // eslint-disable-next-line react-hooks/rules-of-hooks\n\n\n const sharedHandlersCallbacks = Reanimated.useSharedValue(null); // eslint-disable-next-line react-hooks/rules-of-hooks\n\n const lastUpdateEvent = Reanimated.useSharedValue([]); // not every gesture needs a state controller, init them lazily\n\n const stateControllers = [];\n\n const callback = event => {\n 'worklet';\n\n const currentCallback = sharedHandlersCallbacks.value;\n\n if (!currentCallback) {\n return;\n }\n\n for (let i = 0; i < currentCallback.length; i++) {\n const gesture = currentCallback[i];\n\n if (event.handlerTag === gesture.handlerTag) {\n if (isStateChangeEvent(event)) {\n if (event.oldState === State.UNDETERMINED && event.state === State.BEGAN) {\n runWorklet(CALLBACK_TYPE.BEGAN, gesture, event);\n } else if ((event.oldState === State.BEGAN || event.oldState === State.UNDETERMINED) && event.state === State.ACTIVE) {\n runWorklet(CALLBACK_TYPE.START, gesture, event);\n lastUpdateEvent.value[gesture.handlerTag] = undefined;\n } else if (event.oldState !== event.state && event.state === State.END) {\n if (event.oldState === State.ACTIVE) {\n runWorklet(CALLBACK_TYPE.END, gesture, event, true);\n }\n\n runWorklet(CALLBACK_TYPE.FINALIZE, gesture, event, true);\n } else if ((event.state === State.FAILED || event.state === State.CANCELLED) && event.state !== event.oldState) {\n if (event.oldState === State.ACTIVE) {\n runWorklet(CALLBACK_TYPE.END, gesture, event, false);\n }\n\n runWorklet(CALLBACK_TYPE.FINALIZE, gesture, event, false);\n }\n } else if (isTouchEvent(event)) {\n if (!stateControllers[i]) {\n stateControllers[i] = GestureStateManager.create(event.handlerTag);\n }\n\n if (event.eventType !== TouchEventType.UNDETERMINED) {\n runWorklet(touchEventTypeToCallbackType(event.eventType), gesture, event, stateControllers[i]);\n }\n } else {\n runWorklet(CALLBACK_TYPE.UPDATE, gesture, event);\n\n if (gesture.onChange && gesture.changeEventCalculator) {\n var _gesture$changeEventC;\n\n runWorklet(CALLBACK_TYPE.CHANGE, gesture, (_gesture$changeEventC = gesture.changeEventCalculator) === null || _gesture$changeEventC === void 0 ? void 0 : _gesture$changeEventC.call(gesture, event, lastUpdateEvent.value[gesture.handlerTag]));\n lastUpdateEvent.value[gesture.handlerTag] = event;\n }\n }\n }\n }\n }; // eslint-disable-next-line react-hooks/rules-of-hooks\n\n\n const event = Reanimated.useEvent(callback, ['onGestureHandlerStateChange', 'onGestureHandlerEvent'], needsRebuild);\n preparedGesture.animatedEventHandler = event;\n preparedGesture.animatedHandlers = sharedHandlersCallbacks;\n} // eslint-disable-next-line @typescript-eslint/no-explicit-any\n\n\nfunction validateDetectorChildren(ref) {\n // finds the first native view under the Wrap component and traverses the fiber tree upwards\n // to check whether there is more than one native view as a pseudo-direct child of GestureDetector\n // i.e. this is not ok:\n // Wrap\n // |\n // / \\\n // / \\\n // / \\\n // / \\\n // NativeView NativeView\n //\n // but this is fine:\n // Wrap\n // |\n // NativeView\n // |\n // / \\\n // / \\\n // / \\\n // / \\\n // NativeView NativeView\n if (__DEV__ && Platform.OS !== 'web') {\n const REACT_NATIVE_VERSION = getReactNativeVersion(); // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\n const wrapType = REACT_NATIVE_VERSION.minor > 63 || REACT_NATIVE_VERSION.major > 0 ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n ref._reactInternals.elementType : // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n ref._reactInternalFiber.elementType; // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\n let instance = RNRenderer.findHostInstance_DEPRECATED(ref)._internalFiberInstanceHandleDEV; // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n\n\n while (instance && instance.elementType !== wrapType) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (instance.sibling) {\n throw new Error('GestureDetector has more than one native view as its children. This can happen if you are using a custom component that renders multiple views, like React.Fragment. You should wrap content of GestureDetector with a or .');\n } // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\n\n\n instance = instance.return;\n }\n }\n}\n\nconst applyUserSelectProp = (userSelect, gesture) => {\n for (const g of gesture.toGestureArray()) {\n g.config.userSelect = userSelect;\n }\n};\n\nconst applyEnableContextMenuProp = (enableContextMenu, gesture) => {\n for (const g of gesture.toGestureArray()) {\n g.config.enableContextMenu = enableContextMenu;\n }\n};\n\nconst applyTouchActionProp = (touchAction, gesture) => {\n for (const g of gesture.toGestureArray()) {\n g.config.touchAction = touchAction;\n }\n};\n\n/**\n * `GestureDetector` is responsible for creating and updating native gesture handlers based on the config of provided gesture.\n *\n * ### Props\n * - `gesture`\n * - `userSelect` (**Web only**)\n * - `enableContextMenu` (**Web only**)\n * - `touchAction` (**Web only**)\n *\n * ### Remarks\n * - Gesture Detector will use first native view in its subtree to recognize gestures, however if this view is used only to group its children it may get automatically collapsed.\n * - Using the same instance of a gesture across multiple Gesture Detectors is not possible.\n *\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/gesture-detector\n */\nexport const GestureDetector = props => {\n const rootViewContext = useContext(GestureHandlerRootViewContext);\n\n if (__DEV__ && !rootViewContext && !isJestEnv() && Platform.OS !== 'web') {\n throw new Error('GestureDetector must be used as a descendant of GestureHandlerRootView. Otherwise the gestures will not be recognized. See https://docs.swmansion.com/react-native-gesture-handler/docs/installation for more details.');\n }\n\n const gestureConfig = props.gesture;\n\n if (props.userSelect) {\n applyUserSelectProp(props.userSelect, gestureConfig);\n }\n\n if (props.enableContextMenu !== undefined) {\n applyEnableContextMenuProp(props.enableContextMenu, gestureConfig);\n }\n\n if (props.touchAction !== undefined) {\n applyTouchActionProp(props.touchAction, gestureConfig);\n }\n\n const gesture = gestureConfig.toGestureArray();\n const useReanimatedHook = gesture.some(g => g.shouldUseReanimated); // store state in ref to prevent unnecessary renders\n\n const state = useRef({\n firstRender: true,\n viewRef: null,\n previousViewTag: -1,\n forceReattach: false\n }).current;\n const mountedRef = useRef(false);\n const webEventHandlersRef = useRef({\n onGestureHandlerEvent: e => {\n onGestureHandlerEvent(e.nativeEvent);\n },\n onGestureHandlerStateChange: isNewWebImplementationEnabled() ? e => {\n onGestureHandlerEvent(e.nativeEvent);\n } : undefined\n });\n const [renderState, setRenderState] = useState(false);\n\n function forceRender() {\n setRenderState(!renderState);\n }\n\n const preparedGesture = React.useRef({\n config: gesture,\n animatedEventHandler: null,\n animatedHandlers: null,\n firstExecution: true,\n useReanimatedHook: useReanimatedHook\n }).current;\n\n if (useReanimatedHook !== preparedGesture.useReanimatedHook) {\n throw new Error(tagMessage('You cannot change the thread the callbacks are ran on while the app is running'));\n }\n\n function onHandlersUpdate(skipConfigUpdate) {\n // if the underlying view has changed we need to reattach handlers to the new view\n const viewTag = findNodeHandle(state.viewRef);\n const forceReattach = viewTag !== state.previousViewTag;\n\n if (forceReattach || needsToReattach(preparedGesture, gesture)) {\n validateDetectorChildren(state.viewRef);\n dropHandlers(preparedGesture);\n attachHandlers({\n preparedGesture,\n gestureConfig,\n gesture,\n webEventHandlersRef,\n viewTag,\n mountedRef\n });\n state.previousViewTag = viewTag;\n state.forceReattach = forceReattach;\n\n if (forceReattach) {\n forceRender();\n }\n } else if (!skipConfigUpdate) {\n updateHandlers(preparedGesture, gestureConfig, gesture, mountedRef);\n }\n } // Reanimated event should be rebuilt only when gestures are reattached, otherwise\n // config update will be enough as all necessary items are stored in shared values anyway\n\n\n const needsToRebuildReanimatedEvent = preparedGesture.firstExecution || needsToReattach(preparedGesture, gesture) || state.forceReattach;\n state.forceReattach = false;\n\n if (preparedGesture.firstExecution) {\n gestureConfig.initialize();\n }\n\n if (useReanimatedHook) {\n // Whether animatedGesture or gesture is used shouldn't change while the app is running\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useAnimatedGesture(preparedGesture, needsToRebuildReanimatedEvent);\n }\n\n useEffect(() => {\n const viewTag = findNodeHandle(state.viewRef);\n state.firstRender = true;\n mountedRef.current = true;\n validateDetectorChildren(state.viewRef);\n attachHandlers({\n preparedGesture,\n gestureConfig,\n gesture,\n webEventHandlersRef,\n viewTag,\n mountedRef\n });\n return () => {\n mountedRef.current = false;\n dropHandlers(preparedGesture);\n };\n }, []);\n useEffect(() => {\n if (!state.firstRender) {\n onHandlersUpdate();\n } else {\n state.firstRender = false;\n }\n }, [props]);\n\n const refFunction = ref => {\n if (ref !== null) {\n // @ts-ignore Just setting the view ref\n state.viewRef = ref; // if it's the first render, also set the previousViewTag to prevent reattaching gestures when not needed\n\n if (state.previousViewTag === -1) {\n state.previousViewTag = findNodeHandle(state.viewRef);\n } // pass true as `skipConfigUpdate`, here we only want to trigger the eventual reattaching of handlers\n // in case the view has changed, while config update would be handled be the `useEffect` above\n\n\n onHandlersUpdate(true);\n\n if (isFabric() && global.isFormsStackingContext) {\n const node = getShadowNodeFromRef(ref);\n\n if (global.isFormsStackingContext(node) === false) {\n console.error(tagMessage('GestureDetector has received a child that may get view-flattened. ' + '\\nTo prevent it from misbehaving you need to wrap the child with a ``.'));\n }\n }\n }\n };\n\n if (useReanimatedHook) {\n return /*#__PURE__*/React.createElement(AnimatedWrap, {\n ref: refFunction,\n onGestureHandlerEvent: preparedGesture.animatedEventHandler\n }, props.children);\n } else {\n return /*#__PURE__*/React.createElement(Wrap, {\n ref: refFunction\n }, props.children);\n }\n};\n\nclass Wrap extends React.Component {\n render() {\n try {\n // I don't think that fighting with types over such a simple function is worth it\n // The only thing it does is add 'collapsable: false' to the child component\n // to make sure it is in the native view hierarchy so the detector can find\n // correct viewTag to attach to.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const child = React.Children.only(this.props.children);\n return /*#__PURE__*/React.cloneElement(child, {\n collapsable: false\n }, // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n child.props.children);\n } catch (e) {\n throw new Error(tagMessage(`GestureDetector got more than one view as a child. If you want the gesture to work on multiple views, wrap them with a common parent and attach the gesture to that view.`));\n }\n }\n\n}\n\nconst AnimatedWrap = (_Reanimated$default$c = Reanimated === null || Reanimated === void 0 ? void 0 : (_Reanimated$default = Reanimated.default) === null || _Reanimated$default === void 0 ? void 0 : _Reanimated$default.createAnimatedComponent(Wrap)) !== null && _Reanimated$default$c !== void 0 ? _Reanimated$default$c : Wrap;\n//# sourceMappingURL=GestureDetector.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { getNextHandlerTag } from '../handlersRegistry';\nimport { isRemoteDebuggingEnabled } from '../../utils';\nexport const CALLBACK_TYPE = {\n UNDEFINED: 0,\n BEGAN: 1,\n START: 2,\n UPDATE: 3,\n CHANGE: 4,\n END: 5,\n FINALIZE: 6,\n TOUCHES_DOWN: 7,\n TOUCHES_MOVE: 8,\n TOUCHES_UP: 9,\n TOUCHES_CANCELLED: 10\n}; // Allow using CALLBACK_TYPE as object and type\n// eslint-disable-next-line @typescript-eslint/no-redeclare\n\nexport class Gesture {}\nlet nextGestureId = 0;\nexport class BaseGesture extends Gesture {\n constructor() {\n super(); // Used to check whether the gesture config has been updated when wrapping it\n // with `useMemo`. Since every config will have a unique id, when the dependencies\n // don't change, the config won't be recreated and the id will stay the same.\n // If the id is different, it means that the config has changed and the gesture\n // needs to be updated.\n\n _defineProperty(this, \"gestureId\", -1);\n\n _defineProperty(this, \"handlerTag\", -1);\n\n _defineProperty(this, \"handlerName\", '');\n\n _defineProperty(this, \"config\", {});\n\n _defineProperty(this, \"handlers\", {\n gestureId: -1,\n handlerTag: -1,\n isWorklet: []\n });\n\n this.gestureId = nextGestureId++;\n this.handlers.gestureId = this.gestureId;\n }\n\n addDependency(key, gesture) {\n const value = this.config[key];\n this.config[key] = value ? Array().concat(value, gesture) : [gesture];\n }\n /**\n * Sets a `ref` to the gesture object, allowing for interoperability with the old API.\n * @param ref\n */\n\n\n withRef(ref) {\n this.config.ref = ref;\n return this;\n } // eslint-disable-next-line @typescript-eslint/ban-types\n\n\n isWorklet(callback) {\n //@ts-ignore if callback is a worklet, the property will be available, if not then the check will return false\n return callback.__workletHash !== undefined;\n }\n /**\n * Set the callback that is being called when given gesture handler starts receiving touches.\n * At the moment of this callback the handler is in `BEGAN` state and we don't know yet if it will recognize the gesture at all.\n * @param callback\n */\n\n\n onBegin(callback) {\n this.handlers.onBegin = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.BEGAN] = this.isWorklet(callback);\n return this;\n }\n /**\n * Set the callback that is being called when the gesture is recognized by the handler and it transitions to the `ACTIVE` state.\n * @param callback\n */\n\n\n onStart(callback) {\n this.handlers.onStart = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.START] = this.isWorklet(callback);\n return this;\n }\n /**\n * Set the callback that is being called when the gesture that was recognized by the handler finishes and handler reaches `END` state.\n * It will be called only if the handler was previously in the `ACTIVE` state.\n * @param callback\n */\n\n\n onEnd(callback) {\n this.handlers.onEnd = callback; //@ts-ignore if callback is a worklet, the property will be available, if not then the check will return false\n\n this.handlers.isWorklet[CALLBACK_TYPE.END] = this.isWorklet(callback);\n return this;\n }\n /**\n * Set the callback that is being called when the handler finalizes handling gesture - the gesture was recognized and has finished or it failed to recognize.\n * @param callback\n */\n\n\n onFinalize(callback) {\n this.handlers.onFinalize = callback; //@ts-ignore if callback is a worklet, the property will be available, if not then the check will return false\n\n this.handlers.isWorklet[CALLBACK_TYPE.FINALIZE] = this.isWorklet(callback);\n return this;\n }\n /**\n * Set the `onTouchesDown` callback which is called every time a pointer is placed on the screen.\n * @param callback\n */\n\n\n onTouchesDown(callback) {\n this.config.needsPointerData = true;\n this.handlers.onTouchesDown = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.TOUCHES_DOWN] = this.isWorklet(callback);\n return this;\n }\n /**\n * Set the `onTouchesMove` callback which is called every time a pointer is moved on the screen.\n * @param callback\n */\n\n\n onTouchesMove(callback) {\n this.config.needsPointerData = true;\n this.handlers.onTouchesMove = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.TOUCHES_MOVE] = this.isWorklet(callback);\n return this;\n }\n /**\n * Set the `onTouchesUp` callback which is called every time a pointer is lifted from the screen.\n * @param callback\n */\n\n\n onTouchesUp(callback) {\n this.config.needsPointerData = true;\n this.handlers.onTouchesUp = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.TOUCHES_UP] = this.isWorklet(callback);\n return this;\n }\n /**\n * Set the `onTouchesCancelled` callback which is called every time a pointer stops being tracked, for example when the gesture finishes.\n * @param callback\n */\n\n\n onTouchesCancelled(callback) {\n this.config.needsPointerData = true;\n this.handlers.onTouchesCancelled = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.TOUCHES_CANCELLED] = this.isWorklet(callback);\n return this;\n }\n /**\n * Indicates whether the given handler should be analyzing stream of touch events or not.\n * @param enabled\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture#enabledvalue-boolean\n */\n\n\n enabled(enabled) {\n this.config.enabled = enabled;\n return this;\n }\n /**\n * When true the handler will cancel or fail recognition (depending on its current state) whenever the finger leaves the area of the connected view.\n * @param value\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture#shouldcancelwhenoutsidevalue-boolean\n */\n\n\n shouldCancelWhenOutside(value) {\n this.config.shouldCancelWhenOutside = value;\n return this;\n }\n /**\n * This parameter enables control over what part of the connected view area can be used to begin recognizing the gesture.\n * When a negative number is provided the bounds of the view will reduce the area by the given number of points in each of the sides evenly.\n * @param hitSlop\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture#hitslopsettings\n */\n\n\n hitSlop(hitSlop) {\n this.config.hitSlop = hitSlop;\n return this;\n }\n /**\n * #### Web only\n * This parameter allows to specify which `cursor` should be used when gesture activates.\n * Supports all CSS cursor values (e.g. `\"grab\"`, `\"zoom-in\"`). Default value is set to `\"auto\"`.\n * @param activeCursor\n */\n\n\n activeCursor(activeCursor) {\n this.config.activeCursor = activeCursor;\n return this;\n }\n /**\n * #### Web & Android only\n * Allows users to choose which mouse button should handler respond to.\n * Arguments can be combined using `|` operator, e.g. `mouseButton(MouseButton.LEFT | MouseButton.RIGHT)`.\n * Default value is set to `MouseButton.LEFT`.\n * @param mouseButton\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture#mousebuttonvalue-mousebutton-web--android-only\n */\n\n\n mouseButton(mouseButton) {\n this.config.mouseButton = mouseButton;\n return this;\n }\n /**\n * When `react-native-reanimated` is installed, the callbacks passed to the gestures are automatically workletized and run on the UI thread when called.\n * This option allows for changing this behavior: when `true`, all the callbacks will be run on the JS thread instead of the UI thread, regardless of whether they are worklets or not.\n * Defaults to `false`.\n * @param runOnJS\n */\n\n\n runOnJS(runOnJS) {\n this.config.runOnJS = runOnJS;\n return this;\n }\n /**\n * Allows gestures across different components to be recognized simultaneously.\n * @param gestures\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/fundamentals/gesture-composition/#simultaneouswithexternalgesture\n */\n\n\n simultaneousWithExternalGesture(...gestures) {\n for (const gesture of gestures) {\n this.addDependency('simultaneousWith', gesture);\n }\n\n return this;\n }\n /**\n * Allows to delay activation of the handler until all handlers passed as arguments to this method fail (or don't begin at all).\n * @param gestures\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/fundamentals/gesture-composition/#requireexternalgesturetofail\n */\n\n\n requireExternalGestureToFail(...gestures) {\n for (const gesture of gestures) {\n this.addDependency('requireToFail', gesture);\n }\n\n return this;\n }\n /**\n * Works similarily to `requireExternalGestureToFail` but the direction of the relation is reversed - instead of being one-to-many relation, it's many-to-one.\n * @param gestures\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/fundamentals/gesture-composition/#blocksexternalgesture\n */\n\n\n blocksExternalGesture(...gestures) {\n for (const gesture of gestures) {\n this.addDependency('blocksHandlers', gesture);\n }\n\n return this;\n }\n /**\n * Sets a `testID` property for gesture object, allowing for querying for it in tests.\n * @param id\n */\n\n\n withTestId(id) {\n this.config.testId = id;\n return this;\n }\n /**\n * #### iOS only\n * When `true`, the handler will cancel touches for native UI components (`UIButton`, `UISwitch`, etc) it's attached to when it becomes `ACTIVE`.\n * Default value is `true`.\n * @param value\n */\n\n\n cancelsTouchesInView(value) {\n this.config.cancelsTouchesInView = value;\n return this;\n }\n\n initialize() {\n this.handlerTag = getNextHandlerTag();\n this.handlers = { ...this.handlers,\n handlerTag: this.handlerTag\n };\n\n if (this.config.ref) {\n this.config.ref.current = this;\n }\n }\n\n toGestureArray() {\n return [this];\n } // eslint-disable-next-line @typescript-eslint/no-empty-function\n\n\n prepare() {}\n\n get shouldUseReanimated() {\n // use Reanimated when runOnJS isn't set explicitly,\n // and all defined callbacks are worklets,\n // and remote debugging is disabled\n return this.config.runOnJS !== true && !this.handlers.isWorklet.includes(false) && !isRemoteDebuggingEnabled();\n }\n\n}\nexport class ContinousBaseGesture extends BaseGesture {\n /**\n * Set the callback that is being called every time the gesture receives an update while it's active.\n * @param callback\n */\n onUpdate(callback) {\n this.handlers.onUpdate = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.UPDATE] = this.isWorklet(callback);\n return this;\n }\n /**\n * Set the callback that is being called every time the gesture receives an update while it's active.\n * This callback will receive information about change in value in relation to the last received event.\n * @param callback\n */\n\n\n onChange(callback) {\n this.handlers.onChange = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.CHANGE] = this.isWorklet(callback);\n return this;\n }\n /**\n * When `true` the handler will not activate by itself even if its activation criteria are met.\n * Instead you can manipulate its state using state manager.\n * @param manualActivation\n */\n\n\n manualActivation(manualActivation) {\n this.config.manualActivation = manualActivation;\n return this;\n }\n\n}\n//# sourceMappingURL=gesture.js.map","var _Reanimated;\n\nimport { tagMessage } from '../../utils';\nlet Reanimated;\n\ntry {\n Reanimated = require('react-native-reanimated');\n} catch (e) {\n // When 'react-native-reanimated' is not available we want to quietly continue\n // @ts-ignore TS demands the variable to be initialized\n Reanimated = undefined;\n}\n\nif (!((_Reanimated = Reanimated) !== null && _Reanimated !== void 0 && _Reanimated.useSharedValue)) {\n // @ts-ignore Make sure the loaded module is actually Reanimated, if it's not\n // reset the module to undefined so we can fallback to the default implementation\n Reanimated = undefined;\n}\n\nif (Reanimated !== undefined && !Reanimated.setGestureState) {\n // The loaded module is Reanimated but it doesn't have the setGestureState defined\n Reanimated.setGestureState = () => {\n 'worklet';\n\n console.warn(tagMessage('Please use newer version of react-native-reanimated in order to control state of the gestures.'));\n };\n}\n\nexport { Reanimated };\n//# sourceMappingURL=reanimatedWrapper.js.map","'use strict';\n\nexport * from './reanimated2';\nexport * as default from './Animated'; // If this line fails, you probably forgot some installation steps. Check out the installation guide here: https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/getting-started#installation 1) Make sure reanimated's babel plugin is installed in your babel.config.js (you should have 'react-native-reanimated/plugin' listed there - also see the above link for details) 2) Make sure you reset build cache after updating the config, run: yarn start --reset-cache\n//# sourceMappingURL=index.web.js.map","'use strict';\n\nimport './publicGlobals';\nexport { runOnJS, runOnUI, createWorkletRuntime, runOnRuntime, makeMutable, makeShareableCloneRecursive, isReanimated3, isConfigured, enableLayoutAnimations, getViewProp, executeOnUIRuntimeSync } from './core';\nexport { useAnimatedProps, useEvent, useHandler, useWorkletCallback, useSharedValue, useReducedMotion, useAnimatedStyle, useAnimatedGestureHandler, useAnimatedReaction, useAnimatedRef, useAnimatedScrollHandler, useDerivedValue, useAnimatedSensor, useFrameCallback, useAnimatedKeyboard, useScrollViewOffset } from './hook';\nexport { cancelAnimation, defineAnimation, withClamp, withDecay, withDelay, withRepeat, withSequence, withSpring, withTiming } from './animation';\nexport { Extrapolation, interpolate, clamp } from './interpolation';\nexport {\n/**\n * @deprecated Please use {@link Extrapolation} instead.\n */\nExtrapolate, ColorSpace, interpolateColor, useInterpolateConfig } from './interpolateColor';\nexport { Easing } from './Easing';\nexport { measure, dispatchCommand, scrollTo, setGestureState, setNativeProps, getRelativeCoords } from './platformFunctions';\nexport { isColor, processColor, convertToRGBA } from './Colors';\nexport { createAnimatedPropAdapter } from './PropAdapters';\nexport { BaseAnimationBuilder, ComplexAnimationBuilder, Keyframe,\n// Flip\nFlipInXUp, FlipInYLeft, FlipInXDown, FlipInYRight, FlipInEasyX, FlipInEasyY, FlipOutXUp, FlipOutYLeft, FlipOutXDown, FlipOutYRight, FlipOutEasyX, FlipOutEasyY,\n// Stretch\nStretchInX, StretchInY, StretchOutX, StretchOutY,\n// Fade\nFadeIn, FadeInRight, FadeInLeft, FadeInUp, FadeInDown, FadeOut, FadeOutRight, FadeOutLeft, FadeOutUp, FadeOutDown,\n// Slide\nSlideInRight, SlideInLeft, SlideOutRight, SlideOutLeft, SlideInUp, SlideInDown, SlideOutUp, SlideOutDown,\n// Zoom\nZoomIn, ZoomInRotate, ZoomInLeft, ZoomInRight, ZoomInUp, ZoomInDown, ZoomInEasyUp, ZoomInEasyDown, ZoomOut, ZoomOutRotate, ZoomOutLeft, ZoomOutRight, ZoomOutUp, ZoomOutDown, ZoomOutEasyUp, ZoomOutEasyDown,\n// Bounce\nBounceIn, BounceInDown, BounceInUp, BounceInLeft, BounceInRight, BounceOut, BounceOutDown, BounceOutUp, BounceOutLeft, BounceOutRight,\n// Lightspeed\nLightSpeedInRight, LightSpeedInLeft, LightSpeedOutRight, LightSpeedOutLeft,\n// Pinwheel\nPinwheelIn, PinwheelOut,\n// Rotate\nRotateInDownLeft, RotateInDownRight, RotateInUpLeft, RotateInUpRight, RotateOutDownLeft, RotateOutDownRight, RotateOutUpLeft, RotateOutUpRight,\n// Roll\nRollInLeft, RollInRight, RollOutLeft, RollOutRight,\n// Transitions\nLayout, LinearTransition, FadingTransition, SequencedTransition, JumpingTransition, CurvedTransition, EntryExitTransition, combineTransition,\n// SET\nSharedTransition, SharedTransitionType } from './layoutReanimation';\nexport { isSharedValue } from './isSharedValue';\nexport { SensorType, IOSReferenceFrame, InterfaceOrientation, KeyboardState, ReduceMotion, isWorkletFunction } from './commonTypes';\nexport { getUseOfValueInStyleWarning } from './pluginUtils';\nexport { withReanimatedTimer, advanceAnimationByTime, advanceAnimationByFrame, setUpTests, getAnimatedStyle } from './jestUtils';\nexport { LayoutAnimationConfig } from './component/LayoutAnimationConfig';\nexport { PerformanceMonitor } from './component/PerformanceMonitor';\nexport { startMapper, stopMapper } from './mappers';\nexport { startScreenTransition, finishScreenTransition, ScreenTransition } from './screenTransition';\n//# sourceMappingURL=index.js.map","'use strict';\n\n/* eslint-disable no-var */\nexport {};\n//# sourceMappingURL=publicGlobals.js.map","'use strict';\n\nimport NativeReanimatedModule from './NativeReanimated';\nimport { isWeb, shouldBeUseWeb, isFabric } from './PlatformChecker';\nimport { makeShareableCloneRecursive } from './shareables';\nimport { initializeUIRuntime } from './initializers';\nimport { SensorContainer } from './SensorContainer';\nexport { startMapper, stopMapper } from './mappers';\nexport { runOnJS, runOnUI, executeOnUIRuntimeSync } from './threads';\nexport { createWorkletRuntime, runOnRuntime } from './runtimes';\nexport { makeShareable, makeShareableCloneRecursive } from './shareables';\nexport { makeMutable } from './mutables';\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\n\n/**\n * @returns `true` in Reanimated 3, doesn't exist in Reanimated 2 or 1\n */\nexport const isReanimated3 = () => true;\n\n// Superseded by check in `/src/threads.ts`.\n// Used by `react-navigation` to detect if using Reanimated 2 or 3.\n/**\n * @deprecated This function was superseded by other checks.\n * We keep it here for backward compatibility reasons.\n * If you need to check if you are using Reanimated 3 or Reanimated 2\n * please use `isReanimated3` function instead.\n * @returns `true` in Reanimated 3, doesn't exist in Reanimated 2\n */\nexport const isConfigured = isReanimated3;\n\n// this is for web implementation\nif (SHOULD_BE_USE_WEB) {\n global._WORKLET = false;\n global._log = console.log;\n global._getAnimationTimestamp = () => performance.now();\n}\nexport function getViewProp(viewTag, propName, component) {\n if (isFabric() && !component) {\n throw new Error('[Reanimated] Function `getViewProp` requires a component to be passed as an argument on Fabric.');\n }\n\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n return new Promise((resolve, reject) => {\n return NativeReanimatedModule.getViewProp(viewTag, propName, component, result => {\n if (typeof result === 'string' && result.substr(0, 6) === 'error:') {\n reject(result);\n } else {\n resolve(result);\n }\n });\n });\n}\nfunction getSensorContainer() {\n if (!global.__sensorContainer) {\n global.__sensorContainer = new SensorContainer();\n }\n return global.__sensorContainer;\n}\nexport function registerEventHandler(eventHandler, eventName, emitterReactTag = -1) {\n function handleAndFlushAnimationFrame(eventTimestamp, event) {\n 'worklet';\n\n global.__frameTimestamp = eventTimestamp;\n eventHandler(event);\n global.__flushAnimationFrame(eventTimestamp);\n global.__frameTimestamp = undefined;\n }\n return NativeReanimatedModule.registerEventHandler(makeShareableCloneRecursive(handleAndFlushAnimationFrame), eventName, emitterReactTag);\n}\nexport function unregisterEventHandler(id) {\n return NativeReanimatedModule.unregisterEventHandler(id);\n}\nexport function subscribeForKeyboardEvents(eventHandler, options) {\n // TODO: this should really go with the same code path as other events, that is\n // via registerEventHandler. For now we are copying the code from there.\n function handleAndFlushAnimationFrame(state, height) {\n 'worklet';\n\n const now = global._getAnimationTimestamp();\n global.__frameTimestamp = now;\n eventHandler(state, height);\n global.__flushAnimationFrame(now);\n global.__frameTimestamp = undefined;\n }\n return NativeReanimatedModule.subscribeForKeyboardEvents(makeShareableCloneRecursive(handleAndFlushAnimationFrame), options.isStatusBarTranslucentAndroid ?? false);\n}\nexport function unsubscribeFromKeyboardEvents(listenerId) {\n return NativeReanimatedModule.unsubscribeFromKeyboardEvents(listenerId);\n}\nexport function registerSensor(sensorType, config, eventHandler) {\n const sensorContainer = getSensorContainer();\n return sensorContainer.registerSensor(sensorType, config, makeShareableCloneRecursive(eventHandler));\n}\nexport function initializeSensor(sensorType, config) {\n const sensorContainer = getSensorContainer();\n return sensorContainer.initializeSensor(sensorType, config);\n}\nexport function unregisterSensor(sensorId) {\n const sensorContainer = getSensorContainer();\n return sensorContainer.unregisterSensor(sensorId);\n}\nif (!isWeb()) {\n initializeUIRuntime();\n}\nlet featuresConfig = {\n enableLayoutAnimations: false,\n setByUser: false\n};\nexport function enableLayoutAnimations(flag, isCallByUser = true) {\n if (isCallByUser) {\n featuresConfig = {\n enableLayoutAnimations: flag,\n setByUser: true\n };\n NativeReanimatedModule.enableLayoutAnimations(flag);\n } else if (!featuresConfig.setByUser && featuresConfig.enableLayoutAnimations !== flag) {\n featuresConfig.enableLayoutAnimations = flag;\n NativeReanimatedModule.enableLayoutAnimations(flag);\n }\n}\nexport function configureLayoutAnimationBatch(layoutAnimationsBatch) {\n NativeReanimatedModule.configureLayoutAnimationBatch(layoutAnimationsBatch);\n}\nexport function setShouldAnimateExitingForTag(viewTag, shouldAnimate) {\n NativeReanimatedModule.setShouldAnimateExitingForTag(viewTag, shouldAnimate);\n}\nexport function jsiConfigureProps(uiProps, nativeProps) {\n if (!SHOULD_BE_USE_WEB) {\n NativeReanimatedModule.configureProps(uiProps, nativeProps);\n }\n}\n//# sourceMappingURL=core.js.map","'use strict';\n\n// this file was created to prevent NativeReanimated from being included in the web bundle\nexport { default } from '../js-reanimated';\n//# sourceMappingURL=index.web.js.map","'use strict';\n\nimport JSReanimated from './JSReanimated';\nimport { isWeb } from '../PlatformChecker';\nimport { PropsAllowlists } from '../../propsAllowlists';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nlet createReactDOMStyle;\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nlet createTransformValue;\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nlet createTextShadowValue;\nif (isWeb()) {\n try {\n createReactDOMStyle =\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n require('react-native-web/dist/exports/StyleSheet/compiler/createReactDOMStyle').default;\n } catch (e) {}\n try {\n // React Native Web 0.19+\n createTransformValue =\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n require('react-native-web/dist/exports/StyleSheet/preprocess').createTransformValue;\n } catch (e) {}\n try {\n createTextShadowValue =\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n require('react-native-web/dist/exports/StyleSheet/preprocess').createTextShadowValue;\n } catch (e) {}\n}\nconst reanimatedJS = new JSReanimated();\nglobal._makeShareableClone = () => {\n throw new Error('[Reanimated] _makeShareableClone should never be called in JSReanimated.');\n};\nglobal._scheduleOnJS = () => {\n throw new Error('[Reanimated] _scheduleOnJS should never be called in JSReanimated.');\n};\nglobal._scheduleOnRuntime = () => {\n throw new Error('[Reanimated] _scheduleOnRuntime should never be called in JSReanimated.');\n};\nexport const _updatePropsJS = (updates, viewRef, isAnimatedProps) => {\n if (viewRef._component) {\n const component = viewRef._component;\n const [rawStyles] = Object.keys(updates).reduce((acc, key) => {\n const value = updates[key];\n const index = typeof value === 'function' ? 1 : 0;\n acc[index][key] = value;\n return acc;\n }, [{}, {}]);\n if (typeof component.setNativeProps === 'function') {\n // This is the legacy way to update props on React Native Web <= 0.18.\n // Also, some components (e.g. from react-native-svg) don't have styles\n // and always provide setNativeProps function instead (even on React Native Web 0.19+).\n setNativeProps(component, rawStyles, isAnimatedProps);\n } else if (createReactDOMStyle !== undefined && component.style !== undefined) {\n // React Native Web 0.19+ no longer provides setNativeProps function,\n // so we need to update DOM nodes directly.\n updatePropsDOM(component, rawStyles, isAnimatedProps);\n } else if (Object.keys(component.props).length > 0) {\n Object.keys(component.props).forEach(key => {\n if (!rawStyles[key]) {\n return;\n }\n const dashedKey = key.replace(/[A-Z]/g, m => '-' + m.toLowerCase());\n component._touchableNode.setAttribute(dashedKey, rawStyles[key]);\n });\n } else {\n const componentName = 'className' in component ? component === null || component === void 0 ? void 0 : component.className : '';\n console.warn(`[Reanimated] It's not possible to manipulate the component ${componentName}`);\n }\n }\n};\nconst setNativeProps = (component, newProps, isAnimatedProps) => {\n var _component$setNativeP2;\n if (isAnimatedProps) {\n var _component$setNativeP;\n const uiProps = {};\n for (const key in newProps) {\n if (isNativeProp(key)) {\n uiProps[key] = newProps[key];\n }\n }\n // Only update UI props directly on the component,\n // other props can be updated as standard style props.\n (_component$setNativeP = component.setNativeProps) === null || _component$setNativeP === void 0 || _component$setNativeP.call(component, uiProps);\n }\n const previousStyle = component.previousStyle ? component.previousStyle : {};\n const currentStyle = {\n ...previousStyle,\n ...newProps\n };\n component.previousStyle = currentStyle;\n (_component$setNativeP2 = component.setNativeProps) === null || _component$setNativeP2 === void 0 || _component$setNativeP2.call(component, {\n style: currentStyle\n });\n};\nconst updatePropsDOM = (component, style, isAnimatedProps) => {\n const previousStyle = component.previousStyle ? component.previousStyle : {};\n const currentStyle = {\n ...previousStyle,\n ...style\n };\n component.previousStyle = currentStyle;\n const domStyle = createReactDOMStyle(currentStyle);\n if (Array.isArray(domStyle.transform) && createTransformValue !== undefined) {\n domStyle.transform = createTransformValue(domStyle.transform);\n }\n if (createTextShadowValue !== undefined && (domStyle.textShadowColor || domStyle.textShadowRadius || domStyle.textShadowOffset)) {\n domStyle.textShadow = createTextShadowValue({\n textShadowColor: domStyle.textShadowColor,\n textShadowOffset: domStyle.textShadowOffset,\n textShadowRadius: domStyle.textShadowRadius\n });\n }\n for (const key in domStyle) {\n if (isAnimatedProps) {\n component.setAttribute(key, domStyle[key]);\n } else {\n component.style[key] = domStyle[key];\n }\n }\n};\nfunction isNativeProp(propName) {\n return !!PropsAllowlists.NATIVE_THREAD_PROPS_WHITELIST[propName];\n}\nexport default reanimatedJS;\n//# sourceMappingURL=index.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { isChromeDebugger, isJest, isWeb, isWindowAvailable } from '../PlatformChecker';\nimport { SensorType } from '../commonTypes';\nimport { mockedRequestAnimationFrame } from '../mockedRequestAnimationFrame';\n// In Node.js environments (like when static rendering with Expo Router)\n// requestAnimationFrame is unavailable, so we use our mock.\n// It also has to be mocked for Jest purposes (see `initializeUIRuntime`).\nconst requestAnimationFrameImpl = isJest() || !globalThis.requestAnimationFrame ? mockedRequestAnimationFrame : globalThis.requestAnimationFrame;\nexport default class JSReanimated {\n constructor() {\n _defineProperty(this, \"nextSensorId\", 0);\n _defineProperty(this, \"sensors\", new Map());\n _defineProperty(this, \"platform\", undefined);\n _defineProperty(this, \"getSensorCallback\", (sensor, sensorType, eventHandler) => {\n switch (sensorType) {\n case SensorType.ACCELEROMETER:\n case SensorType.GRAVITY:\n return () => {\n let {\n x,\n y,\n z\n } = sensor;\n\n // Web Android sensors have a different coordinate system than iOS\n if (this.platform === Platform.WEB_ANDROID) {\n [x, y, z] = [-x, -y, -z];\n }\n // TODO TYPESCRIPT on web ShareableRef is the value itself so we call it directly\n eventHandler({\n x,\n y,\n z,\n interfaceOrientation: 0\n });\n };\n case SensorType.GYROSCOPE:\n case SensorType.MAGNETIC_FIELD:\n return () => {\n const {\n x,\n y,\n z\n } = sensor;\n // TODO TYPESCRIPT on web ShareableRef is the value itself so we call it directly\n eventHandler({\n x,\n y,\n z,\n interfaceOrientation: 0\n });\n };\n case SensorType.ROTATION:\n return () => {\n let [qw, qx, qy, qz] = sensor.quaternion;\n\n // Android sensors have a different coordinate system than iOS\n if (this.platform === Platform.WEB_ANDROID) {\n [qy, qz] = [qz, -qy];\n }\n\n // reference: https://stackoverflow.com/questions/5782658/extracting-yaw-from-a-quaternion\n const yaw = -Math.atan2(2.0 * (qy * qz + qw * qx), qw * qw - qx * qx - qy * qy + qz * qz);\n const pitch = Math.sin(-2.0 * (qx * qz - qw * qy));\n const roll = -Math.atan2(2.0 * (qx * qy + qw * qz), qw * qw + qx * qx - qy * qy - qz * qz);\n // TODO TYPESCRIPT on web ShareableRef is the value itself so we call it directly\n eventHandler({\n qw,\n qx,\n qy,\n qz,\n yaw,\n pitch,\n roll,\n interfaceOrientation: 0\n });\n };\n }\n });\n }\n makeShareableClone() {\n throw new Error('[Reanimated] makeShareableClone should never be called in JSReanimated.');\n }\n scheduleOnUI(worklet) {\n // @ts-ignore web implementation has still not been updated after the rewrite, this will be addressed once the web implementation updates are ready\n requestAnimationFrameImpl(worklet);\n }\n createWorkletRuntime(_name, _initializer) {\n throw new Error('[Reanimated] createWorkletRuntime is not available in JSReanimated.');\n }\n scheduleOnRuntime() {\n throw new Error('[Reanimated] scheduleOnRuntime is not available in JSReanimated.');\n }\n registerEventHandler(_eventHandler, _eventName, _emitterReactTag) {\n throw new Error('[Reanimated] registerEventHandler is not available in JSReanimated.');\n }\n unregisterEventHandler(_) {\n throw new Error('[Reanimated] unregisterEventHandler is not available in JSReanimated.');\n }\n enableLayoutAnimations() {\n if (isWeb()) {\n console.warn('[Reanimated] Layout Animations are not supported on web yet.');\n } else if (isJest()) {\n console.warn('[Reanimated] Layout Animations are no-ops when using Jest.');\n } else if (isChromeDebugger()) {\n console.warn('[Reanimated] Layout Animations are no-ops when using Chrome Debugger.');\n } else {\n console.warn('[Reanimated] Layout Animations are not supported on this configuration.');\n }\n }\n configureLayoutAnimationBatch() {\n // no-op\n }\n setShouldAnimateExitingForTag() {\n // no-op\n }\n registerSensor(sensorType, interval, _iosReferenceFrame, eventHandler) {\n if (!isWindowAvailable()) {\n // the window object is unavailable when building the server portion of a site that uses SSG\n // this check is here to ensure that the server build won't fail\n return -1;\n }\n if (this.platform === undefined) {\n this.detectPlatform();\n }\n if (!(this.getSensorName(sensorType) in window)) {\n // https://w3c.github.io/sensors/#secure-context\n console.warn('[Reanimated] Sensor is not available.' + (isWeb() && location.protocol !== 'https:' ? ' Make sure you use secure origin with `npx expo start --web --https`.' : '') + (this.platform === Platform.WEB_IOS ? ' For iOS web, you will also have to also grant permission in the browser: https://dev.to/li/how-to-requestpermission-for-devicemotion-and-deviceorientation-events-in-ios-13-46g2.' : ''));\n return -1;\n }\n if (this.platform === undefined) {\n this.detectPlatform();\n }\n const sensor = this.initializeSensor(sensorType, interval);\n sensor.addEventListener('reading', this.getSensorCallback(sensor, sensorType, eventHandler));\n sensor.start();\n this.sensors.set(this.nextSensorId, sensor);\n return this.nextSensorId++;\n }\n unregisterSensor(id) {\n const sensor = this.sensors.get(id);\n if (sensor !== undefined) {\n sensor.stop();\n this.sensors.delete(id);\n }\n }\n subscribeForKeyboardEvents(_) {\n if (isWeb()) {\n console.warn('[Reanimated] useAnimatedKeyboard is not available on web yet.');\n } else if (isJest()) {\n console.warn('[Reanimated] useAnimatedKeyboard is not available when using Jest.');\n } else if (isChromeDebugger()) {\n console.warn('[Reanimated] useAnimatedKeyboard is not available when using Chrome Debugger.');\n } else {\n console.warn('[Reanimated] useAnimatedKeyboard is not available on this configuration.');\n }\n return -1;\n }\n unsubscribeFromKeyboardEvents(_) {\n // noop\n }\n initializeSensor(sensorType, interval) {\n const config = interval <= 0 ? {\n referenceFrame: 'device'\n } : {\n frequency: 1000 / interval\n };\n switch (sensorType) {\n case SensorType.ACCELEROMETER:\n return new window.Accelerometer(config);\n case SensorType.GYROSCOPE:\n return new window.Gyroscope(config);\n case SensorType.GRAVITY:\n return new window.GravitySensor(config);\n case SensorType.MAGNETIC_FIELD:\n return new window.Magnetometer(config);\n case SensorType.ROTATION:\n return new window.AbsoluteOrientationSensor(config);\n }\n }\n getSensorName(sensorType) {\n switch (sensorType) {\n case SensorType.ACCELEROMETER:\n return 'Accelerometer';\n case SensorType.GRAVITY:\n return 'GravitySensor';\n case SensorType.GYROSCOPE:\n return 'Gyroscope';\n case SensorType.MAGNETIC_FIELD:\n return 'Magnetometer';\n case SensorType.ROTATION:\n return 'AbsoluteOrientationSensor';\n }\n }\n detectPlatform() {\n const userAgent = navigator.userAgent || navigator.vendor || window.opera;\n if (userAgent === undefined) {\n this.platform = Platform.UNKNOWN;\n } else if (/iPad|iPhone|iPod/.test(userAgent)) {\n this.platform = Platform.WEB_IOS;\n } else if (/android/i.test(userAgent)) {\n this.platform = Platform.WEB_ANDROID;\n } else {\n this.platform = Platform.WEB;\n }\n }\n getViewProp(_viewTag, _propName, _component, _callback) {\n throw new Error('[Reanimated] getViewProp is not available in JSReanimated.');\n }\n configureProps() {\n throw new Error('[Reanimated] configureProps is not available in JSReanimated.');\n }\n executeOnUIRuntimeSync(_shareable) {\n throw new Error('[Reanimated] `executeOnUIRuntimeSync` is not available in JSReanimated.');\n }\n}\nvar Platform = /*#__PURE__*/function (Platform) {\n Platform[\"WEB_IOS\"] = \"web iOS\";\n Platform[\"WEB_ANDROID\"] = \"web Android\";\n Platform[\"WEB\"] = \"web\";\n Platform[\"UNKNOWN\"] = \"unknown\";\n return Platform;\n}(Platform || {});\n//# sourceMappingURL=JSReanimated.js.map","'use strict';\n\nimport { Platform } from 'react-native';\n\n// This type is necessary since some libraries tend to do a lib check\n// and this file causes type errors on `global` access.\n\nexport function isJest() {\n return !!process.env.JEST_WORKER_ID;\n}\n\n// `isChromeDebugger` also returns true in Jest environment, so `isJest()` check should always be performed first\nexport function isChromeDebugger() {\n return (!global.nativeCallSyncHook || !!global.__REMOTEDEV__) && !global.RN$Bridgeless;\n}\nexport function isWeb() {\n return Platform.OS === 'web';\n}\nexport function isAndroid() {\n return Platform.OS === 'android';\n}\nfunction isWindows() {\n return Platform.OS === 'windows';\n}\nexport function shouldBeUseWeb() {\n return isJest() || isChromeDebugger() || isWeb() || isWindows();\n}\nexport function isFabric() {\n return !!global._IS_FABRIC;\n}\nexport function isWindowAvailable() {\n // the window object is unavailable when building the server portion of a site that uses SSG\n // this function shouldn't be used to conditionally render components\n // https://www.joshwcomeau.com/react/the-perils-of-rehydration/\n // @ts-ignore Fallback if `window` is undefined.\n return typeof window !== 'undefined';\n}\nexport function isReducedMotion() {\n return isWeb() ? isWindowAvailable() ?\n // @ts-ignore Fallback if `window` is undefined.\n !window.matchMedia('(prefers-reduced-motion: no-preference)').matches : false : !!global._REANIMATED_IS_REDUCED_MOTION;\n}\n//# sourceMappingURL=PlatformChecker.js.map","'use strict';\n\n/**\n * A value that can be used both on the [JavaScript thread](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#javascript-thread) and the [UI thread](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#ui-thread).\n *\n * Shared values are defined using [useSharedValue](https://docs.swmansion.com/react-native-reanimated/docs/core/useSharedValue) hook. You access and modify shared values by their `.value` property.\n */\n\n// The below type is used for HostObjects returned by the JSI API that don't have\n// any accessible fields or methods but can carry data that is accessed from the\n// c++ side. We add a field to the type to make it possible for typescript to recognize\n// which JSI methods accept those types as arguments and to be able to correctly type\n// check other methods that may use them. However, this field is not actually defined\n// nor should be used for anything else as assigning any data to those objects will\n// throw an error.\n\n// In case of objects with depth or arrays of objects or arrays of arrays etc.\n// we add this utility type that makes it a SharaebleRef of the outermost type.\n\n/**\n * This function allows you to determine if a given function is a worklet. It only works\n * with Reanimated Babel plugin enabled. Unless you are doing something with internals of\n * Reanimated you shouldn't need to use this function.\n *\n * ### Note\n * Do not call it before the worklet is declared, as it will always return false then. E.g.:\n *\n * ```ts\n * isWorkletFunction(myWorklet); // Will always return false.\n *\n * function myWorklet() {\n * 'worklet';\n * };\n * ```\n *\n * ### Maintainer note\n * This function works well on the JS thread performance-wise, since the JIT can inline it.\n * However, on other threads it will not get optimized and we will get a function call overhead.\n * We want to change it in the future, but it's not feasible at the moment.\n */\nexport function isWorkletFunction(value) {\n 'worklet';\n\n // Since host objects always return true for `in` operator, we have to use dot notation to check if the property exists.\n // See https://github.com/facebook/hermes/blob/340726ef8cf666a7cce75bc60b02fa56b3e54560/lib/VM/JSObject.cpp#L1276.\n return typeof value === 'function' && !!value.__workletHash;\n}\nexport let SensorType = /*#__PURE__*/function (SensorType) {\n SensorType[SensorType[\"ACCELEROMETER\"] = 1] = \"ACCELEROMETER\";\n SensorType[SensorType[\"GYROSCOPE\"] = 2] = \"GYROSCOPE\";\n SensorType[SensorType[\"GRAVITY\"] = 3] = \"GRAVITY\";\n SensorType[SensorType[\"MAGNETIC_FIELD\"] = 4] = \"MAGNETIC_FIELD\";\n SensorType[SensorType[\"ROTATION\"] = 5] = \"ROTATION\";\n return SensorType;\n}({});\nexport let IOSReferenceFrame = /*#__PURE__*/function (IOSReferenceFrame) {\n IOSReferenceFrame[IOSReferenceFrame[\"XArbitraryZVertical\"] = 0] = \"XArbitraryZVertical\";\n IOSReferenceFrame[IOSReferenceFrame[\"XArbitraryCorrectedZVertical\"] = 1] = \"XArbitraryCorrectedZVertical\";\n IOSReferenceFrame[IOSReferenceFrame[\"XMagneticNorthZVertical\"] = 2] = \"XMagneticNorthZVertical\";\n IOSReferenceFrame[IOSReferenceFrame[\"XTrueNorthZVertical\"] = 3] = \"XTrueNorthZVertical\";\n IOSReferenceFrame[IOSReferenceFrame[\"Auto\"] = 4] = \"Auto\";\n return IOSReferenceFrame;\n}({});\n\n/**\n * A function called upon animation completion. If the animation is cancelled, the callback will receive `false` as the argument; otherwise, it will receive `true`.\n */\n\nexport let InterfaceOrientation = /*#__PURE__*/function (InterfaceOrientation) {\n InterfaceOrientation[InterfaceOrientation[\"ROTATION_0\"] = 0] = \"ROTATION_0\";\n InterfaceOrientation[InterfaceOrientation[\"ROTATION_90\"] = 90] = \"ROTATION_90\";\n InterfaceOrientation[InterfaceOrientation[\"ROTATION_180\"] = 180] = \"ROTATION_180\";\n InterfaceOrientation[InterfaceOrientation[\"ROTATION_270\"] = 270] = \"ROTATION_270\";\n return InterfaceOrientation;\n}({});\nexport let KeyboardState = /*#__PURE__*/function (KeyboardState) {\n KeyboardState[KeyboardState[\"UNKNOWN\"] = 0] = \"UNKNOWN\";\n KeyboardState[KeyboardState[\"OPENING\"] = 1] = \"OPENING\";\n KeyboardState[KeyboardState[\"OPEN\"] = 2] = \"OPEN\";\n KeyboardState[KeyboardState[\"CLOSING\"] = 3] = \"CLOSING\";\n KeyboardState[KeyboardState[\"CLOSED\"] = 4] = \"CLOSED\";\n return KeyboardState;\n}({});\n\n/**\n * @param x - A number representing X coordinate relative to the parent component.\n * @param y - A number representing Y coordinate relative to the parent component.\n * @param width - A number representing the width of the component.\n * @param height - A number representing the height of the component.\n * @param pageX - A number representing X coordinate relative to the screen.\n * @param pageY - A number representing Y coordinate relative to the screen.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/advanced/measure#returns\n */\n\n/**\n * @param System - If the `Reduce motion` accessibility setting is enabled on the device, disable the animation. Otherwise, enable the animation.\n * @param Always - Disable the animation.\n * @param Never - Enable the animation.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/guides/accessibility\n */\nexport let ReduceMotion = /*#__PURE__*/function (ReduceMotion) {\n ReduceMotion[\"System\"] = \"system\";\n ReduceMotion[\"Always\"] = \"always\";\n ReduceMotion[\"Never\"] = \"never\";\n return ReduceMotion;\n}({});\n//# sourceMappingURL=commonTypes.js.map","'use strict';\n\n// This is Jest implementation of `requestAnimationFrame` that is required\n// by React Native for test purposes.\nexport function mockedRequestAnimationFrame(callback) {\n return setTimeout(() => callback(performance.now()), 0);\n}\n//# sourceMappingURL=mockedRequestAnimationFrame.js.map","'use strict';\n\nexport const PropsAllowlists = {\n /**\n * Styles allowed to be direcly updated in UI thread\n */\n UI_THREAD_PROPS_WHITELIST: {\n opacity: true,\n transform: true,\n /* colors */\n backgroundColor: true,\n borderRightColor: true,\n borderBottomColor: true,\n borderColor: true,\n borderEndColor: true,\n borderLeftColor: true,\n borderStartColor: true,\n borderTopColor: true,\n /* ios styles */\n shadowOpacity: true,\n shadowRadius: true,\n /* legacy android transform properties */\n scaleX: true,\n scaleY: true,\n translateX: true,\n translateY: true\n },\n /**\n * Whitelist of view props that can be updated in native thread via UIManagerModule\n */\n NATIVE_THREAD_PROPS_WHITELIST: {\n borderBottomWidth: true,\n borderEndWidth: true,\n borderLeftWidth: true,\n borderRightWidth: true,\n borderStartWidth: true,\n borderTopWidth: true,\n borderWidth: true,\n bottom: true,\n flex: true,\n flexGrow: true,\n flexShrink: true,\n height: true,\n left: true,\n margin: true,\n marginBottom: true,\n marginEnd: true,\n marginHorizontal: true,\n marginLeft: true,\n marginRight: true,\n marginStart: true,\n marginTop: true,\n marginVertical: true,\n maxHeight: true,\n maxWidth: true,\n minHeight: true,\n minWidth: true,\n padding: true,\n paddingBottom: true,\n paddingEnd: true,\n paddingHorizontal: true,\n paddingLeft: true,\n paddingRight: true,\n paddingStart: true,\n paddingTop: true,\n paddingVertical: true,\n right: true,\n start: true,\n top: true,\n width: true,\n zIndex: true,\n borderBottomEndRadius: true,\n borderBottomLeftRadius: true,\n borderBottomRightRadius: true,\n borderBottomStartRadius: true,\n borderRadius: true,\n borderTopEndRadius: true,\n borderTopLeftRadius: true,\n borderTopRightRadius: true,\n borderTopStartRadius: true,\n elevation: true,\n fontSize: true,\n lineHeight: true,\n textShadowRadius: true,\n textShadowOffset: true,\n letterSpacing: true,\n aspectRatio: true,\n columnGap: true,\n // iOS only\n end: true,\n // number or string\n flexBasis: true,\n // number or string\n gap: true,\n rowGap: true,\n /* strings */\n display: true,\n backfaceVisibility: true,\n overflow: true,\n resizeMode: true,\n fontStyle: true,\n fontWeight: true,\n textAlign: true,\n textDecorationLine: true,\n fontFamily: true,\n textAlignVertical: true,\n fontVariant: true,\n textDecorationStyle: true,\n textTransform: true,\n writingDirection: true,\n alignContent: true,\n alignItems: true,\n alignSelf: true,\n direction: true,\n // iOS only\n flexDirection: true,\n flexWrap: true,\n justifyContent: true,\n position: true,\n /* text color */\n color: true,\n tintColor: true,\n shadowColor: true,\n placeholderTextColor: true\n }\n};\n//# sourceMappingURL=propsAllowlists.js.map","'use strict';\n\nimport NativeReanimatedModule from './NativeReanimated';\nimport { isWorkletFunction } from './commonTypes';\nimport { shouldBeUseWeb } from './PlatformChecker';\nimport { registerWorkletStackDetails } from './errors';\nimport { jsVersion } from './platform-specific/jsVersion';\nimport { shareableMappingCache, shareableMappingFlag } from './shareableMappingCache';\n\n// for web/chrome debugger/jest environments this file provides a stub implementation\n// where no shareable references are used. Instead, the objects themselves are used\n// instead of shareable references, because of the fact that we don't have to deal with\n// runnning the code on separate VMs.\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\nconst MAGIC_KEY = 'REANIMATED_MAGIC_KEY';\nfunction isHostObject(value) {\n 'worklet';\n\n // We could use JSI to determine whether an object is a host object, however\n // the below workaround works well and is way faster than an additional JSI call.\n // We use the fact that host objects have broken implementation of `hasOwnProperty`\n // and hence return true for all `in` checks regardless of the key we ask for.\n return MAGIC_KEY in value;\n}\nfunction isPlainJSObject(object) {\n return Object.getPrototypeOf(object) === Object.prototype;\n}\n\n// The below object is used as a replacement for objects that cannot be transferred\n// as shareable values. In makeShareableCloneRecursive we detect if an object is of\n// a plain Object.prototype and only allow such objects to be transferred. This lets\n// us avoid all sorts of react internals from leaking into the UI runtime. To make it\n// possible to catch errors when someone actually tries to access such object on the UI\n// runtime, we use the below Proxy object which is instantiated on the UI runtime and\n// throws whenever someone tries to access its fields.\nconst INACCESSIBLE_OBJECT = {\n __init: () => {\n 'worklet';\n\n return new Proxy({}, {\n get: (_, prop) => {\n if (prop === '_isReanimatedSharedValue' || prop === '__remoteFunction') {\n // not very happy about this check here, but we need to allow for\n // \"inaccessible\" objects to be tested with isSharedValue check\n // as it is being used in the mappers when extracting inputs recursively\n // as well as with isRemoteFunction when cloning objects recursively.\n // Apparently we can't check if a key exists there as HostObjects always\n // return true for such tests, so the only possibility for us is to\n // actually access that key and see if it is set to true. We therefore\n // need to allow for this key to be accessed here.\n return false;\n }\n throw new Error(`[Reanimated] Trying to access property \\`${String(prop)}\\` of an object which cannot be sent to the UI runtime.`);\n },\n set: () => {\n throw new Error('[Reanimated] Trying to write to an object which cannot be sent to the UI runtime.');\n }\n });\n }\n};\nconst VALID_ARRAY_VIEWS_NAMES = ['Int8Array', 'Uint8Array', 'Uint8ClampedArray', 'Int16Array', 'Uint16Array', 'Int32Array', 'Uint32Array', 'Float32Array', 'Float64Array', 'BigInt64Array', 'BigUint64Array', 'DataView'];\nconst DETECT_CYCLIC_OBJECT_DEPTH_THRESHOLD = 30;\n// Below variable stores object that we process in makeShareableCloneRecursive at the specified depth.\n// We use it to check if later on the function reenters with the same object\nlet processedObjectAtThresholdDepth;\nexport function makeShareableCloneRecursive(value, shouldPersistRemote = false, depth = 0) {\n if (SHOULD_BE_USE_WEB) {\n return value;\n }\n if (depth >= DETECT_CYCLIC_OBJECT_DEPTH_THRESHOLD) {\n // if we reach certain recursion depth we suspect that we are dealing with a cyclic object.\n // this type of objects are not supported and cannot be trasferred as shareable, so we\n // implement a simple detection mechanism that remembers the value at a given depth and\n // tests whether we try reenter this method later on with the same value. If that happens\n // we throw an appropriate error.\n if (depth === DETECT_CYCLIC_OBJECT_DEPTH_THRESHOLD) {\n processedObjectAtThresholdDepth = value;\n } else if (value === processedObjectAtThresholdDepth) {\n throw new Error('[Reanimated] Trying to convert a cyclic object to a shareable. This is not supported.');\n }\n } else {\n processedObjectAtThresholdDepth = undefined;\n }\n // This one actually may be worth to be moved to c++, we also need similar logic to run on the UI thread\n const type = typeof value;\n const isTypeObject = type === 'object';\n const isTypeFunction = type === 'function';\n if ((isTypeObject || isTypeFunction) && value !== null) {\n const cached = shareableMappingCache.get(value);\n if (cached === shareableMappingFlag) {\n return value;\n } else if (cached !== undefined) {\n return cached;\n } else {\n let toAdapt;\n if (Array.isArray(value)) {\n toAdapt = value.map(element => makeShareableCloneRecursive(element, shouldPersistRemote, depth + 1));\n } else if (isTypeFunction && !isWorkletFunction(value)) {\n // this is a remote function\n toAdapt = value;\n } else if (isHostObject(value)) {\n // for host objects we pass the reference to the object as shareable and\n // then recreate new host object wrapping the same instance on the UI thread.\n // there is no point of iterating over keys as we do for regular objects.\n toAdapt = value;\n } else if (isPlainJSObject(value) || isTypeFunction) {\n toAdapt = {};\n if (isWorkletFunction(value)) {\n if (__DEV__) {\n const babelVersion = value.__initData.version;\n if (babelVersion !== undefined && babelVersion !== jsVersion) {\n throw new Error(`[Reanimated] Mismatch between JavaScript code version and Reanimated Babel plugin version (${jsVersion} vs. ${babelVersion}). \nSee \\`https://docs.swmansion.com/react-native-reanimated/docs/guides/troubleshooting#mismatch-between-javascript-code-version-and-reanimated-babel-plugin-version\\` for more details.\nOffending code was: \\`${getWorkletCode(value)}\\``);\n }\n registerWorkletStackDetails(value.__workletHash, value.__stackDetails);\n }\n if (value.__stackDetails) {\n // `Error` type of value cannot be copied to the UI thread, so we\n // remove it after we handled it in dev mode or delete it to ignore it in production mode.\n // Not removing this would cause an infinite loop in production mode and it just\n // seems more elegant to handle it this way.\n delete value.__stackDetails;\n }\n // to save on transferring static __initData field of worklet structure\n // we request shareable value to persist its UI counterpart. This means\n // that the __initData field that contains long strings represeting the\n // worklet code, source map, and location, will always be\n // serialized/deserialized once.\n toAdapt.__initData = makeShareableCloneRecursive(value.__initData, true, depth + 1);\n }\n for (const [key, element] of Object.entries(value)) {\n if (key === '__initData' && toAdapt.__initData !== undefined) {\n continue;\n }\n toAdapt[key] = makeShareableCloneRecursive(element, shouldPersistRemote, depth + 1);\n }\n } else if (value instanceof RegExp) {\n const pattern = value.source;\n const flags = value.flags;\n const handle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n\n return new RegExp(pattern, flags);\n }\n });\n shareableMappingCache.set(value, handle);\n return handle;\n } else if (value instanceof Error) {\n const {\n name,\n message,\n stack\n } = value;\n const handle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n\n const error = new Error();\n error.name = name;\n error.message = message;\n error.stack = stack;\n return error;\n }\n });\n shareableMappingCache.set(value, handle);\n return handle;\n } else if (value instanceof ArrayBuffer) {\n toAdapt = value;\n } else if (ArrayBuffer.isView(value)) {\n // typed array (e.g. Int32Array, Uint8ClampedArray) or DataView\n const buffer = value.buffer;\n const typeName = value.constructor.name;\n const handle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n\n if (!VALID_ARRAY_VIEWS_NAMES.includes(typeName)) {\n throw new Error(`[Reanimated] Invalid array view name \\`${typeName}\\`.`);\n }\n const constructor = global[typeName];\n if (constructor === undefined) {\n throw new Error(`[Reanimated] Constructor for \\`${typeName}\\` not found.`);\n }\n return new constructor(buffer);\n }\n });\n shareableMappingCache.set(value, handle);\n return handle;\n } else {\n // This is reached for object types that are not of plain Object.prototype.\n // We don't support such objects from being transferred as shareables to\n // the UI runtime and hence we replace them with \"inaccessible object\"\n // which is implemented as a Proxy object that throws on any attempt\n // of accessing its fields. We argue that such objects can sometimes leak\n // as attributes of objects being captured by worklets but should never\n // be used on the UI runtime regardless. If they are being accessed, the user\n // will get an appropriate error message.\n const inaccessibleObject = makeShareableCloneRecursive(INACCESSIBLE_OBJECT);\n shareableMappingCache.set(value, inaccessibleObject);\n return inaccessibleObject;\n }\n if (__DEV__) {\n // we freeze objects that are transformed to shareable. This should help\n // detect issues when someone modifies data after it's been converted to\n // shareable. Meaning that they may be doing a faulty assumption in their\n // code expecting that the updates are going to automatically populate to\n // the object sent to the UI thread. If the user really wants some objects\n // to be mutable they should use shared values instead.\n Object.freeze(value);\n }\n const adopted = NativeReanimatedModule.makeShareableClone(toAdapt, shouldPersistRemote, value);\n shareableMappingCache.set(value, adopted);\n shareableMappingCache.set(adopted);\n return adopted;\n }\n }\n return NativeReanimatedModule.makeShareableClone(value, shouldPersistRemote, undefined);\n}\nconst WORKLET_CODE_THRESHOLD = 255;\nfunction getWorkletCode(value) {\n var _value$__initData;\n // @ts-ignore this is fine\n const code = value === null || value === void 0 || (_value$__initData = value.__initData) === null || _value$__initData === void 0 ? void 0 : _value$__initData.code;\n if (!code) {\n return 'unknown';\n }\n if (code.length > WORKLET_CODE_THRESHOLD) {\n return `${code.substring(0, WORKLET_CODE_THRESHOLD)}...`;\n }\n return code;\n}\nfunction isRemoteFunction(value) {\n 'worklet';\n\n return !!value.__remoteFunction;\n}\nexport function makeShareableCloneOnUIRecursive(value) {\n 'worklet';\n\n if (SHOULD_BE_USE_WEB) {\n // @ts-ignore web is an interesting place where we don't run a secondary VM on the UI thread\n // see more details in the comment where USE_STUB_IMPLEMENTATION is defined.\n return value;\n }\n // eslint-disable-next-line @typescript-eslint/no-shadow\n function cloneRecursive(value) {\n if (typeof value === 'object' && value !== null || typeof value === 'function') {\n if (isHostObject(value)) {\n // We call `_makeShareableClone` to wrap the provided HostObject\n // inside ShareableJSRef.\n return global._makeShareableClone(value, undefined);\n }\n if (isRemoteFunction(value)) {\n // RemoteFunctions are created by us therefore they are\n // a Shareable out of the box and there is no need to\n // call `_makeShareableClone`.\n return value.__remoteFunction;\n }\n if (Array.isArray(value)) {\n return global._makeShareableClone(value.map(cloneRecursive), undefined);\n }\n const toAdapt = {};\n for (const [key, element] of Object.entries(value)) {\n toAdapt[key] = cloneRecursive(element);\n }\n return global._makeShareableClone(toAdapt, value);\n }\n return global._makeShareableClone(value, undefined);\n }\n return cloneRecursive(value);\n}\nfunction makeShareableJS(value) {\n return value;\n}\nfunction makeShareableNative(value) {\n if (shareableMappingCache.get(value)) {\n return value;\n }\n const handle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n\n return value;\n }\n });\n shareableMappingCache.set(value, handle);\n return value;\n}\n\n/**\n * This function creates a value on UI with persistent state - changes to it on the UI\n * thread will be seen by all worklets. Use it when you want to create a value\n * that is read and written only on the UI thread.\n */\nexport const makeShareable = SHOULD_BE_USE_WEB ? makeShareableJS : makeShareableNative;\n//# sourceMappingURL=shareables.js.map","'use strict';\n\nconst _workletStackDetails = new Map();\nexport function registerWorkletStackDetails(hash, stackDetails) {\n _workletStackDetails.set(hash, stackDetails);\n}\nfunction getBundleOffset(error) {\n var _error$stack;\n const frame = (_error$stack = error.stack) === null || _error$stack === void 0 || (_error$stack = _error$stack.split('\\n')) === null || _error$stack === void 0 ? void 0 : _error$stack[0];\n if (frame) {\n const parsedFrame = /@([^@]+):(\\d+):(\\d+)/.exec(frame);\n if (parsedFrame) {\n const [, file, line, col] = parsedFrame;\n return [file, Number(line), Number(col)];\n }\n }\n return ['unknown', 0, 0];\n}\nfunction processStack(stack) {\n const workletStackEntries = stack.match(/worklet_(\\d+):(\\d+):(\\d+)/g);\n let result = stack;\n workletStackEntries === null || workletStackEntries === void 0 || workletStackEntries.forEach(match => {\n const [, hash, origLine, origCol] = match.split(/:|_/).map(Number);\n const errorDetails = _workletStackDetails.get(hash);\n if (!errorDetails) {\n return;\n }\n const [error, lineOffset, colOffset] = errorDetails;\n const [bundleFile, bundleLine, bundleCol] = getBundleOffset(error);\n const line = origLine + bundleLine + lineOffset;\n const col = origCol + bundleCol + colOffset;\n result = result.replace(match, `${bundleFile}:${line}:${col}`);\n });\n return result;\n}\nexport function reportFatalErrorOnJS({\n message,\n stack\n}) {\n const error = new Error();\n error.message = message;\n error.stack = stack ? processStack(stack) : undefined;\n error.name = 'ReanimatedError';\n // @ts-ignore React Native's ErrorUtils implementation extends the Error type with jsEngine field\n error.jsEngine = 'reanimated';\n // @ts-ignore the reportFatalError method is an internal method of ErrorUtils not exposed in the type definitions\n global.ErrorUtils.reportFatalError(error);\n}\n//# sourceMappingURL=errors.js.map","'use strict';\n\n/**\n * We hardcode the version of Reanimated here in order to compare it\n * with the version used to build the native part of the library in runtime.\n * Remember to keep this in sync with the version declared in `package.json`\n */\nexport const jsVersion = '3.10.1';\n//# sourceMappingURL=jsVersion.js.map","'use strict';\n\nimport { shouldBeUseWeb } from './PlatformChecker';\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\n\n/**\n * This symbol is used to represent a mapping from the value to itself.\n *\n * It's used to prevent converting a shareable that's already converted -\n * for example a Shared Value that's in worklet's closure.\n **/\nexport const shareableMappingFlag = Symbol('shareable flag');\n\n/*\nDuring a fast refresh, React holds the same instance of a Mutable\n(that's guaranteed by `useRef`) but `shareableCache` gets regenerated and thus\nbecoming empty. This happens when editing the file that contains the definition of this cache.\n\nBecause of it, `makeShareableCloneRecursive` can't find given mapping\nin `shareableCache` for the Mutable and tries to clone it as if it was a regular JS object.\nDuring cloning we use `Object.entries` to iterate over the keys which throws an error on accessing `_value`.\nFor convenience we moved this cache to a separate file so it doesn't scare us with red squiggles.\n*/\n\nconst cache = SHOULD_BE_USE_WEB ? null : new WeakMap();\nexport const shareableMappingCache = SHOULD_BE_USE_WEB ? {\n set() {\n // NOOP\n },\n get() {\n return null;\n }\n} : {\n set(shareable, shareableRef) {\n cache.set(shareable, shareableRef || shareableMappingFlag);\n },\n get: cache.get.bind(cache)\n};\n//# sourceMappingURL=shareableMappingCache.js.map","'use strict';\n\nimport { reportFatalErrorOnJS } from './errors';\nimport { isChromeDebugger, isJest, shouldBeUseWeb } from './PlatformChecker';\nimport { runOnJS, setupMicrotasks, callMicrotasks, runOnUIImmediately } from './threads';\nimport { mockedRequestAnimationFrame } from './mockedRequestAnimationFrame';\nconst IS_JEST = isJest();\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\nconst IS_CHROME_DEBUGGER = isChromeDebugger();\n\n// callGuard is only used with debug builds\nexport function callGuardDEV(fn, ...args) {\n 'worklet';\n\n try {\n return fn(...args);\n } catch (e) {\n if (global.__ErrorUtils) {\n global.__ErrorUtils.reportFatalError(e);\n } else {\n throw e;\n }\n }\n}\nexport function setupCallGuard() {\n 'worklet';\n\n global.__callGuardDEV = callGuardDEV;\n global.__ErrorUtils = {\n reportFatalError: error => {\n runOnJS(reportFatalErrorOnJS)({\n message: error.message,\n stack: error.stack\n });\n }\n };\n}\n\n// We really have to create a copy of console here. Function runOnJS we use on elements inside\n// this object makes it not configurable\nconst capturableConsole = {\n ...console\n};\nexport function setupConsole() {\n 'worklet';\n\n if (!IS_CHROME_DEBUGGER) {\n // @ts-ignore TypeScript doesn't like that there are missing methods in console object, but we don't provide all the methods for the UI runtime console version\n global.console = {\n /* eslint-disable @typescript-eslint/unbound-method */\n assert: runOnJS(capturableConsole.assert),\n debug: runOnJS(capturableConsole.debug),\n log: runOnJS(capturableConsole.log),\n warn: runOnJS(capturableConsole.warn),\n error: runOnJS(capturableConsole.error),\n info: runOnJS(capturableConsole.info)\n /* eslint-enable @typescript-eslint/unbound-method */\n };\n }\n}\nfunction setupRequestAnimationFrame() {\n 'worklet';\n\n // Jest mocks requestAnimationFrame API and it does not like if that mock gets overridden\n // so we avoid doing requestAnimationFrame batching in Jest environment.\n const nativeRequestAnimationFrame = global.requestAnimationFrame;\n let animationFrameCallbacks = [];\n let lastNativeAnimationFrameTimestamp = -1;\n global.__flushAnimationFrame = frameTimestamp => {\n const currentCallbacks = animationFrameCallbacks;\n animationFrameCallbacks = [];\n currentCallbacks.forEach(f => f(frameTimestamp));\n callMicrotasks();\n };\n global.requestAnimationFrame = callback => {\n animationFrameCallbacks.push(callback);\n if (animationFrameCallbacks.length === 1) {\n // We schedule native requestAnimationFrame only when the first callback\n // is added and then use it to execute all the enqueued callbacks. Once\n // the callbacks are run, we clear the array.\n nativeRequestAnimationFrame(timestamp => {\n if (lastNativeAnimationFrameTimestamp >= timestamp) {\n // Make sure we only execute the callbacks once for a given frame\n return;\n }\n lastNativeAnimationFrameTimestamp = timestamp;\n global.__frameTimestamp = timestamp;\n global.__flushAnimationFrame(timestamp);\n global.__frameTimestamp = undefined;\n });\n }\n // Reanimated currently does not support cancelling callbacks requested with\n // requestAnimationFrame. We return -1 as identifier which isn't in line\n // with the spec but it should give users better clue in case they actually\n // attempt to store the value returned from rAF and use it for cancelling.\n return -1;\n };\n}\nexport function initializeUIRuntime() {\n if (IS_JEST) {\n // requestAnimationFrame react-native jest's setup is incorrect as it polyfills\n // the method directly using setTimeout, therefore the callback doesn't get the\n // expected timestamp as the only argument: https://github.com/facebook/react-native/blob/main/packages/react-native/jest/setup.js#L28\n // We override this setup here to make sure that callbacks get the proper timestamps\n // when executed. For non-jest environments we define requestAnimationFrame in setupRequestAnimationFrame\n // @ts-ignore TypeScript uses Node definition for rAF, setTimeout, etc which returns a Timeout object rather than a number\n globalThis.requestAnimationFrame = mockedRequestAnimationFrame;\n }\n runOnUIImmediately(() => {\n 'worklet';\n\n setupCallGuard();\n setupConsole();\n if (!SHOULD_BE_USE_WEB) {\n setupMicrotasks();\n setupRequestAnimationFrame();\n }\n })();\n}\n//# sourceMappingURL=initializers.js.map","'use strict';\n\nimport NativeReanimatedModule from './NativeReanimated';\nimport { isJest, shouldBeUseWeb } from './PlatformChecker';\nimport { makeShareableCloneOnUIRecursive, makeShareableCloneRecursive } from './shareables';\nimport { isWorkletFunction } from './commonTypes';\nconst IS_JEST = isJest();\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\n\n/**\n * An array of [worklet, args] pairs.\n * */\nlet _runOnUIQueue = [];\nexport function setupMicrotasks() {\n 'worklet';\n\n let microtasksQueue = [];\n let isExecutingMicrotasksQueue = false;\n global.queueMicrotask = callback => {\n microtasksQueue.push(callback);\n };\n global.__callMicrotasks = () => {\n if (isExecutingMicrotasksQueue) {\n return;\n }\n try {\n isExecutingMicrotasksQueue = true;\n for (let index = 0; index < microtasksQueue.length; index += 1) {\n // we use classic 'for' loop because the size of the currentTasks array may change while executing some of the callbacks due to queueMicrotask calls\n microtasksQueue[index]();\n }\n microtasksQueue = [];\n global._maybeFlushUIUpdatesQueue();\n } finally {\n isExecutingMicrotasksQueue = false;\n }\n };\n}\nfunction callMicrotasksOnUIThread() {\n 'worklet';\n\n global.__callMicrotasks();\n}\nexport const callMicrotasks = SHOULD_BE_USE_WEB ? () => {\n // on web flushing is a noop as immediates are handled by the browser\n} : callMicrotasksOnUIThread;\n\n/**\n * Lets you asynchronously run [workletized](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#to-workletize) functions on the [UI thread](https://docs.swmansion.com/react-native-reanimated/docs/threading/runOnUI).\n *\n * This method does not schedule the work immediately but instead waits for other worklets\n * to be scheduled within the same JS loop. It uses queueMicrotask to schedule all the worklets\n * at once making sure they will run within the same frame boundaries on the UI thread.\n *\n * @param fun - A reference to a function you want to execute on the [UI thread](https://docs.swmansion.com/react-native-reanimated/docs/threading/runOnUI) from the [JavaScript thread](https://docs.swmansion.com/react-native-reanimated/docs/threading/runOnUI).\n * @returns A function that accepts arguments for the function passed as the first argument.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/threading/runOnUI\n */\n// @ts-expect-error This overload is correct since it's what user sees in his code\n// before it's transformed by Reanimated Babel plugin.\n\nexport function runOnUI(worklet) {\n 'worklet';\n\n if (__DEV__ && !SHOULD_BE_USE_WEB && _WORKLET) {\n throw new Error('[Reanimated] `runOnUI` cannot be called on the UI runtime. Please call the function synchronously or use `queueMicrotask` or `requestAnimationFrame` instead.');\n }\n if (__DEV__ && !SHOULD_BE_USE_WEB && !isWorkletFunction(worklet)) {\n throw new Error('[Reanimated] `runOnUI` can only be used on worklets.');\n }\n return (...args) => {\n if (IS_JEST) {\n // Mocking time in Jest is tricky as both requestAnimationFrame and queueMicrotask\n // callbacks run on the same queue and can be interleaved. There is no way\n // to flush particular queue in Jest and the only control over mocked timers\n // is by using jest.advanceTimersByTime() method which advances all types\n // of timers including immediate and animation callbacks. Ideally we'd like\n // to have some way here to schedule work along with React updates, but\n // that's not possible, and hence in Jest environment instead of using scheduling\n // mechanism we just schedule the work ommiting the queue. This is ok for the\n // uses that we currently have but may not be ok for future tests that we write.\n NativeReanimatedModule.scheduleOnUI(makeShareableCloneRecursive(() => {\n 'worklet';\n\n worklet(...args);\n }));\n return;\n }\n if (__DEV__) {\n // in DEV mode we call shareable conversion here because in case the object\n // can't be converted, we will get a meaningful stack-trace as opposed to the\n // situation when conversion is only done via microtask queue. This does not\n // make the app particularily less efficient as converted objects are cached\n // and for a given worklet the conversion only happens once.\n makeShareableCloneRecursive(worklet);\n makeShareableCloneRecursive(args);\n }\n _runOnUIQueue.push([worklet, args]);\n if (_runOnUIQueue.length === 1) {\n queueMicrotask(() => {\n const queue = _runOnUIQueue;\n _runOnUIQueue = [];\n NativeReanimatedModule.scheduleOnUI(makeShareableCloneRecursive(() => {\n 'worklet';\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n queue.forEach(([worklet, args]) => {\n worklet(...args);\n });\n callMicrotasks();\n }));\n });\n }\n };\n}\n\n// @ts-expect-error Check `executeOnUIRuntimeSync` overload above.\n\nexport function executeOnUIRuntimeSync(worklet) {\n return (...args) => {\n return NativeReanimatedModule.executeOnUIRuntimeSync(makeShareableCloneRecursive(() => {\n 'worklet';\n\n const result = worklet(...args);\n return makeShareableCloneOnUIRecursive(result);\n }));\n };\n}\n\n// @ts-expect-error Check `runOnUI` overload above.\n\n/**\n * Schedule a worklet to execute on the UI runtime skipping batching mechanism.\n */\nexport function runOnUIImmediately(worklet) {\n 'worklet';\n\n if (__DEV__ && !SHOULD_BE_USE_WEB && _WORKLET) {\n throw new Error('[Reanimated] `runOnUIImmediately` cannot be called on the UI runtime. Please call the function synchronously or use `queueMicrotask` or `requestAnimationFrame` instead.');\n }\n if (__DEV__ && !SHOULD_BE_USE_WEB && !isWorkletFunction(worklet)) {\n throw new Error('[Reanimated] `runOnUIImmediately` can only be used on worklets.');\n }\n return (...args) => {\n NativeReanimatedModule.scheduleOnUI(makeShareableCloneRecursive(() => {\n 'worklet';\n\n worklet(...args);\n }));\n };\n}\nfunction runWorkletOnJS(worklet, ...args) {\n // remote function that calls a worklet synchronously on the JS runtime\n worklet(...args);\n}\n\n/**\n * Lets you asynchronously run non-[workletized](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#to-workletize) functions that couldn't otherwise run on the [UI thread](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#ui-thread).\n * This applies to most external libraries as they don't have their functions marked with \"worklet\"; directive.\n *\n * @param fun - A reference to a function you want to execute on the JavaScript thread from the UI thread.\n * @returns A function that accepts arguments for the function passed as the first argument.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/threading/runOnJS\n */\nexport function runOnJS(fun) {\n 'worklet';\n\n if (SHOULD_BE_USE_WEB || !_WORKLET) {\n // if we are already on the JS thread, we just schedule the worklet on the JS queue\n return (...args) => queueMicrotask(args.length ? () => fun(...args) : fun);\n }\n if (isWorkletFunction(fun)) {\n // If `fun` is a worklet, we schedule a call of a remote function `runWorkletOnJS`\n // and pass the worklet as a first argument followed by original arguments.\n\n return (...args) => runOnJS(runWorkletOnJS)(fun, ...args);\n }\n if (fun.__remoteFunction) {\n // In development mode the function provided as `fun` throws an error message\n // such that when someone accidentally calls it directly on the UI runtime, they\n // see that they should use `runOnJS` instead. To facilitate that we put the\n // reference to the original remote function in the `__remoteFunction` property.\n fun = fun.__remoteFunction;\n }\n return (...args) => {\n global._scheduleOnJS(fun, args.length > 0 ?\n // TODO TYPESCRIPT this cast is terrible but will be fixed\n makeShareableCloneOnUIRecursive(args) : undefined);\n };\n}\n//# sourceMappingURL=threads.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport Sensor from './Sensor';\nexport class SensorContainer {\n constructor() {\n _defineProperty(this, \"nativeSensors\", new Map());\n }\n getSensorId(sensorType, config) {\n return sensorType * 100 + config.iosReferenceFrame * 10 + Number(config.adjustToInterfaceOrientation);\n }\n initializeSensor(sensorType, config) {\n const sensorId = this.getSensorId(sensorType, config);\n if (!this.nativeSensors.has(sensorId)) {\n const newSensor = new Sensor(sensorType, config);\n this.nativeSensors.set(sensorId, newSensor);\n }\n const sensor = this.nativeSensors.get(sensorId);\n return sensor.getSharedValue();\n }\n registerSensor(sensorType, config, handler) {\n const sensorId = this.getSensorId(sensorType, config);\n if (!this.nativeSensors.has(sensorId)) {\n return -1;\n }\n const sensor = this.nativeSensors.get(sensorId);\n if (sensor && sensor.isAvailable() && (sensor.isRunning() || sensor.register(handler))) {\n sensor.listenersNumber++;\n return sensorId;\n }\n return -1;\n }\n unregisterSensor(sensorId) {\n if (this.nativeSensors.has(sensorId)) {\n const sensor = this.nativeSensors.get(sensorId);\n if (sensor && sensor.isRunning()) {\n sensor.listenersNumber--;\n if (sensor.listenersNumber === 0) {\n sensor.unregister();\n }\n }\n }\n }\n}\n//# sourceMappingURL=SensorContainer.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport NativeReanimatedModule from './NativeReanimated';\nimport { SensorType } from './commonTypes';\nimport { makeMutable } from './mutables';\nfunction initSensorData(sensorType) {\n if (sensorType === SensorType.ROTATION) {\n return makeMutable({\n qw: 0,\n qx: 0,\n qy: 0,\n qz: 0,\n yaw: 0,\n pitch: 0,\n roll: 0,\n interfaceOrientation: 0\n });\n } else {\n return makeMutable({\n x: 0,\n y: 0,\n z: 0,\n interfaceOrientation: 0\n });\n }\n}\nexport default class Sensor {\n constructor(sensorType, config) {\n _defineProperty(this, \"listenersNumber\", 0);\n _defineProperty(this, \"sensorId\", null);\n _defineProperty(this, \"sensorType\", void 0);\n _defineProperty(this, \"data\", void 0);\n _defineProperty(this, \"config\", void 0);\n this.sensorType = sensorType;\n this.config = config;\n this.data = initSensorData(sensorType);\n }\n register(eventHandler) {\n const config = this.config;\n const sensorType = this.sensorType;\n this.sensorId = NativeReanimatedModule.registerSensor(sensorType, config.interval === 'auto' ? -1 : config.interval, config.iosReferenceFrame, eventHandler);\n return this.sensorId !== -1;\n }\n isRunning() {\n return this.sensorId !== -1 && this.sensorId !== null;\n }\n isAvailable() {\n return this.sensorId !== -1;\n }\n getSharedValue() {\n return this.data;\n }\n unregister() {\n if (this.sensorId !== null && this.sensorId !== -1) {\n NativeReanimatedModule.unregisterSensor(this.sensorId);\n }\n this.sensorId = null;\n }\n}\n//# sourceMappingURL=Sensor.js.map","'use strict';\n\nimport { shouldBeUseWeb } from './PlatformChecker';\nimport { makeShareableCloneRecursive } from './shareables';\nimport { shareableMappingCache } from './shareableMappingCache';\nimport { executeOnUIRuntimeSync, runOnUI } from './threads';\nimport { valueSetter } from './valueSetter';\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\nexport function makeUIMutable(initial) {\n 'worklet';\n\n const listeners = new Map();\n let value = initial;\n const self = {\n set value(newValue) {\n valueSetter(self, newValue);\n },\n get value() {\n return value;\n },\n /**\n * _value prop should only be accessed by the valueSetter implementation\n * which may make the decision about updating the mutable value depending\n * on the provided new value. All other places should only attempt to modify\n * the mutable by assigning to value prop directly.\n */\n set _value(newValue) {\n value = newValue;\n listeners.forEach(listener => {\n listener(newValue);\n });\n },\n get _value() {\n return value;\n },\n modify: (modifier, forceUpdate = true) => {\n valueSetter(self, modifier !== undefined ? modifier(value) : value, forceUpdate);\n },\n addListener: (id, listener) => {\n listeners.set(id, listener);\n },\n removeListener: id => {\n listeners.delete(id);\n },\n _animation: null,\n _isReanimatedSharedValue: true\n };\n return self;\n}\nexport function makeMutable(initial) {\n let value = initial;\n const handle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n\n return makeUIMutable(initial);\n }\n });\n // listeners can only work on JS thread on Web and jest environments\n const listeners = SHOULD_BE_USE_WEB ? new Map() : undefined;\n const mutable = {\n set value(newValue) {\n if (SHOULD_BE_USE_WEB) {\n valueSetter(mutable, newValue);\n } else {\n runOnUI(() => {\n mutable.value = newValue;\n })();\n }\n },\n get value() {\n if (SHOULD_BE_USE_WEB) {\n return value;\n }\n const uiValueGetter = executeOnUIRuntimeSync(sv => {\n return sv.value;\n });\n return uiValueGetter(mutable);\n },\n set _value(newValue) {\n if (!SHOULD_BE_USE_WEB) {\n throw new Error('[Reanimated] Setting `_value` directly is only possible on the UI runtime. Perhaps you want to assign to `value` instead?');\n }\n value = newValue;\n listeners.forEach(listener => {\n listener(newValue);\n });\n },\n get _value() {\n if (SHOULD_BE_USE_WEB) {\n return value;\n }\n throw new Error('[Reanimated] Reading from `_value` directly is only possible on the UI runtime. Perhaps you passed an Animated Style to a non-animated component?');\n },\n modify: (modifier, forceUpdate = true) => {\n if (!SHOULD_BE_USE_WEB) {\n runOnUI(() => {\n mutable.modify(modifier, forceUpdate);\n })();\n } else {\n valueSetter(mutable, modifier !== undefined ? modifier(mutable.value) : mutable.value, forceUpdate);\n }\n },\n addListener: (id, listener) => {\n if (!SHOULD_BE_USE_WEB) {\n throw new Error('[Reanimated] Adding listeners is only possible on the UI runtime.');\n }\n listeners.set(id, listener);\n },\n removeListener: id => {\n if (!SHOULD_BE_USE_WEB) {\n throw new Error('[Reanimated] Removing listeners is only possible on the UI runtime.');\n }\n listeners.delete(id);\n },\n _isReanimatedSharedValue: true\n };\n shareableMappingCache.set(mutable, handle);\n return mutable;\n}\n//# sourceMappingURL=mutables.js.map","'use strict';\n\nexport function valueSetter(mutable, value, forceUpdate = false) {\n 'worklet';\n\n const previousAnimation = mutable._animation;\n if (previousAnimation) {\n previousAnimation.cancelled = true;\n mutable._animation = null;\n }\n if (typeof value === 'function' || value !== null && typeof value === 'object' &&\n // TODO TYPESCRIPT fix this after fixing AnimationObject type\n value.onFrame !== undefined) {\n const animation = typeof value === 'function' ?\n // TODO TYPESCRIPT fix this after fixing AnimationObject type\n value() :\n // TODO TYPESCRIPT fix this after fixing AnimationObject type\n value;\n // prevent setting again to the same value\n // and triggering the mappers that treat this value as an input\n // this happens when the animation's target value(stored in animation.current until animation.onStart is called) is set to the same value as a current one(this._value)\n // built in animations that are not higher order(withTiming, withSpring) hold target value in .current\n if (mutable._value === animation.current && !animation.isHigherOrder && !forceUpdate) {\n animation.callback && animation.callback(true);\n return;\n }\n // animated set\n const initializeAnimation = timestamp => {\n animation.onStart(animation, mutable.value, timestamp, previousAnimation);\n };\n const currentTimestamp = global.__frameTimestamp || global._getAnimationTimestamp();\n initializeAnimation(currentTimestamp);\n const step = newTimestamp => {\n // Function `requestAnimationFrame` adds callback to an array, all the callbacks are flushed with function `__flushAnimationFrame`\n // Usually we flush them inside function `nativeRequestAnimationFrame` and then the given timestamp is the timestamp of end of the current frame.\n // However function `__flushAnimationFrame` may also be called inside `registerEventHandler` - then we get actual timestamp which is earlier than the end of the frame.\n\n const timestamp = newTimestamp < (animation.timestamp || 0) ? animation.timestamp : newTimestamp;\n if (animation.cancelled) {\n animation.callback && animation.callback(false /* finished */);\n return;\n }\n const finished = animation.onFrame(animation, timestamp);\n animation.finished = true;\n animation.timestamp = timestamp;\n // TODO TYPESCRIPT\n // For now I'll assume that `animation.current` is always defined\n // but actually need to dive into animations to understand it\n mutable._value = animation.current;\n if (finished) {\n animation.callback && animation.callback(true /* finished */);\n } else {\n requestAnimationFrame(step);\n }\n };\n mutable._animation = animation;\n step(currentTimestamp);\n } else {\n // prevent setting again to the same value\n // and triggering the mappers that treat this value as an input\n if (mutable._value === value && !forceUpdate) {\n return;\n }\n mutable._value = value;\n }\n}\n//# sourceMappingURL=valueSetter.js.map","'use strict';\n\nimport { isJest } from './PlatformChecker';\nimport { runOnUI } from './threads';\nimport { isSharedValue } from './isSharedValue';\nconst IS_JEST = isJest();\nfunction createMapperRegistry() {\n 'worklet';\n\n const mappers = new Map();\n let sortedMappers = [];\n let runRequested = false;\n let processingMappers = false;\n function updateMappersOrder() {\n // sort mappers topologically\n // the algorithm here takes adventage of a fact that the topological order\n // of a transposed graph is a reverse topological order of the original graph\n // The graph in our case consists of mappers and an edge between two mappers\n // A and B exists if there is a shared value that's on A's output lists and on\n // B's input list.\n //\n // We don't need however to calculate that graph as it is easier to work with\n // the transposed version of it that can be calculated ad-hoc. For the transposed\n // version to be traversed we use \"pre\" map that maps share value to mappers that\n // output that shared value. Then we can infer all the outgoing edges for a given\n // mapper simply by scanning it's input list and checking if any of the shared values\n // from that list exists in the \"pre\" map. If they do, then we have an edge between\n // that mapper and the mappers from the \"pre\" list for the given shared value.\n //\n // For topological sorting we use a dfs-based approach that requires the graph to\n // be traversed in dfs order and each node after being processed lands at the\n // beginning of the topological order list. Since we traverse a transposed graph,\n // instead of reversing that order we can use a normal array and push processed\n // mappers to the end. There is no need to reverse that array after we are done.\n const pre = new Map(); // map from sv -> mapper that outputs that sv\n mappers.forEach(mapper => {\n if (mapper.outputs) {\n for (const output of mapper.outputs) {\n const preMappers = pre.get(output);\n if (preMappers === undefined) {\n pre.set(output, [mapper]);\n } else {\n preMappers.push(mapper);\n }\n }\n }\n });\n const visited = new Set();\n const newOrder = [];\n function dfs(mapper) {\n visited.add(mapper);\n for (const input of mapper.inputs) {\n const preMappers = pre.get(input);\n if (preMappers) {\n for (const preMapper of preMappers) {\n if (!visited.has(preMapper)) {\n dfs(preMapper);\n }\n }\n }\n }\n newOrder.push(mapper);\n }\n mappers.forEach(mapper => {\n if (!visited.has(mapper)) {\n dfs(mapper);\n }\n });\n sortedMappers = newOrder;\n }\n function mapperRun() {\n runRequested = false;\n if (processingMappers) {\n return;\n }\n try {\n processingMappers = true;\n if (mappers.size !== sortedMappers.length) {\n updateMappersOrder();\n }\n for (const mapper of sortedMappers) {\n if (mapper.dirty) {\n mapper.dirty = false;\n mapper.worklet();\n }\n }\n } finally {\n processingMappers = false;\n }\n }\n function maybeRequestUpdates() {\n if (IS_JEST) {\n // On Jest environment we avoid using queueMicrotask as that'd require test\n // to advance the clock manually. This on other hand would require tests\n // to know how many times mappers need to run. As we don't want tests to\n // make any assumptions on that number it is easier to execute mappers\n // immediately for testing purposes and only expect test to advance timers\n // if they want to make any assertions on the effects of animations being run.\n mapperRun();\n } else if (!runRequested) {\n if (processingMappers) {\n // In general, we should avoid having mappers trigger updates as this may\n // result in unpredictable behavior. Specifically, the updated value can\n // be read by mappers that run later in the same frame but previous mappers\n // would access the old value. Updating mappers during the mapper-run phase\n // breaks the order in which we should execute the mappers. However, doing\n // that is still a possibility and there are some instances where people use\n // the API in that way, hence we need to prevent mapper-run phase falling into\n // an infinite loop. We do that by detecting when mapper-run is requested while\n // we are already in mapper-run phase, and in that case we use `requestAnimationFrame`\n // instead of `queueMicrotask` which will schedule mapper run for the next\n // frame instead of queuing another set of updates in the same frame.\n requestAnimationFrame(mapperRun);\n } else {\n queueMicrotask(mapperRun);\n }\n runRequested = true;\n }\n }\n function extractInputs(inputs, resultArray) {\n if (Array.isArray(inputs)) {\n for (const input of inputs) {\n input && extractInputs(input, resultArray);\n }\n } else if (isSharedValue(inputs)) {\n resultArray.push(inputs);\n } else if (Object.getPrototypeOf(inputs) === Object.prototype) {\n // we only extract inputs recursively from \"plain\" objects here, if object\n // is of a derivative class (e.g. HostObject on web, or Map) we don't scan\n // it recursively\n for (const element of Object.values(inputs)) {\n element && extractInputs(element, resultArray);\n }\n }\n return resultArray;\n }\n return {\n start: (mapperID, worklet, inputs, outputs) => {\n const mapper = {\n id: mapperID,\n dirty: true,\n worklet,\n inputs: extractInputs(inputs, []),\n outputs\n };\n mappers.set(mapper.id, mapper);\n sortedMappers = [];\n for (const sv of mapper.inputs) {\n sv.addListener(mapper.id, () => {\n mapper.dirty = true;\n maybeRequestUpdates();\n });\n }\n maybeRequestUpdates();\n },\n stop: mapperID => {\n const mapper = mappers.get(mapperID);\n if (mapper) {\n mappers.delete(mapper.id);\n sortedMappers = [];\n for (const sv of mapper.inputs) {\n sv.removeListener(mapper.id);\n }\n }\n }\n };\n}\nlet MAPPER_ID = 9999;\nexport function startMapper(worklet, inputs = [], outputs = []) {\n const mapperID = MAPPER_ID += 1;\n runOnUI(() => {\n let mapperRegistry = global.__mapperRegistry;\n if (mapperRegistry === undefined) {\n mapperRegistry = global.__mapperRegistry = createMapperRegistry();\n }\n mapperRegistry.start(mapperID, worklet, inputs, outputs);\n })();\n return mapperID;\n}\nexport function stopMapper(mapperID) {\n runOnUI(() => {\n const mapperRegistry = global.__mapperRegistry;\n mapperRegistry === null || mapperRegistry === void 0 || mapperRegistry.stop(mapperID);\n })();\n}\n//# sourceMappingURL=mappers.js.map","'use strict';\n\nexport function isSharedValue(value) {\n 'worklet';\n\n // We cannot use `in` operator here because `value` could be a HostObject and therefore we cast.\n return (value === null || value === void 0 ? void 0 : value._isReanimatedSharedValue) === true;\n}\n//# sourceMappingURL=isSharedValue.js.map","'use strict';\n\nimport { isWorkletFunction } from './commonTypes';\nimport { setupCallGuard, setupConsole } from './initializers';\nimport NativeReanimatedModule from './NativeReanimated';\nimport { shouldBeUseWeb } from './PlatformChecker';\nimport { makeShareableCloneOnUIRecursive, makeShareableCloneRecursive } from './shareables';\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\n\n/**\n * Lets you create a new JS runtime which can be used to run worklets possibly on different threads than JS or UI thread.\n *\n * @param name - A name used to identify the runtime which will appear in devices list in Chrome DevTools.\n * @param initializer - An optional worklet that will be run synchronously on the same thread immediately after the runtime is created.\n * @returns WorkletRuntime which is a jsi::HostObject\\ - {@link WorkletRuntime}\n * @see https://docs.swmansion.com/react-native-reanimated/docs/threading/createWorkletRuntime\n */\n// @ts-expect-error Check `runOnUI` overload.\n\nexport function createWorkletRuntime(name, initializer) {\n return NativeReanimatedModule.createWorkletRuntime(name, makeShareableCloneRecursive(() => {\n 'worklet';\n\n setupCallGuard();\n setupConsole();\n initializer === null || initializer === void 0 || initializer();\n }));\n}\n\n// @ts-expect-error Check `runOnUI` overload.\n\n/**\n * Schedule a worklet to execute on the background queue.\n */\nexport function runOnRuntime(workletRuntime, worklet) {\n 'worklet';\n\n if (__DEV__ && !SHOULD_BE_USE_WEB && !isWorkletFunction(worklet)) {\n throw new Error('[Reanimated] The function passed to `runOnRuntime` is not a worklet.' + (_WORKLET ? ' Please make sure that `processNestedWorklets` option in Reanimated Babel plugin is enabled.' : ''));\n }\n if (_WORKLET) {\n return (...args) => global._scheduleOnRuntime(workletRuntime, makeShareableCloneOnUIRecursive(() => {\n 'worklet';\n\n worklet(...args);\n }));\n }\n return (...args) => NativeReanimatedModule.scheduleOnRuntime(workletRuntime, makeShareableCloneRecursive(() => {\n 'worklet';\n\n worklet(...args);\n }));\n}\n//# sourceMappingURL=runtimes.js.map","'use strict';\n\nexport { useAnimatedProps } from './useAnimatedProps';\nexport { useWorkletCallback } from './useWorkletCallback';\nexport { useSharedValue } from './useSharedValue';\nexport { useReducedMotion } from './useReducedMotion';\nexport { useAnimatedStyle } from './useAnimatedStyle';\nexport { useAnimatedGestureHandler } from './useAnimatedGestureHandler';\nexport { useAnimatedReaction } from './useAnimatedReaction';\nexport { useAnimatedRef } from './useAnimatedRef';\nexport { useAnimatedScrollHandler } from './useAnimatedScrollHandler';\nexport { useDerivedValue } from './useDerivedValue';\nexport { useAnimatedSensor } from './useAnimatedSensor';\nexport { useFrameCallback } from './useFrameCallback';\nexport { useAnimatedKeyboard } from './useAnimatedKeyboard';\nexport { useScrollViewOffset } from './useScrollViewOffset';\nexport { useEvent } from './useEvent';\nexport { useHandler } from './useHandler';\n//# sourceMappingURL=index.js.map","'use strict';\n\nimport { useAnimatedStyle } from './useAnimatedStyle';\nimport { shouldBeUseWeb } from '../PlatformChecker';\n\n// TODO: we should make sure that when useAP is used we are not assigning styles\n\nfunction useAnimatedPropsJS(updater, deps, adapters) {\n return useAnimatedStyle(updater, deps, adapters, true);\n}\nconst useAnimatedPropsNative = useAnimatedStyle;\n\n/**\n * Lets you create an animated props object which can be animated using shared values.\n *\n * @param updater - A function returning an object with properties you want to animate.\n * @param dependencies - An optional array of dependencies. Only relevant when using Reanimated without the Babel plugin on the Web.\n * @param adapters - An optional function or array of functions allowing to adopt prop naming between JS and the native side.\n * @returns An animated props object which has to be passed to `animatedProps` property of an Animated component that you want to animate.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/core/useAnimatedProps\n */\nexport const useAnimatedProps = shouldBeUseWeb() ? useAnimatedPropsJS : useAnimatedPropsNative;\n//# sourceMappingURL=useAnimatedProps.js.map","'use strict';\n\nimport { useEffect, useRef } from 'react';\nimport { makeShareable, startMapper, stopMapper } from '../core';\nimport updateProps, { updatePropsJestWrapper } from '../UpdateProps';\nimport { initialUpdaterRun } from '../animation';\nimport { useSharedValue } from './useSharedValue';\nimport { buildWorkletsHash, isAnimated, shallowEqual, validateAnimatedStyles } from './utils';\nimport { makeViewDescriptorsSet, useViewRefSet } from '../ViewDescriptorsSet';\nimport { isJest, shouldBeUseWeb } from '../PlatformChecker';\nimport { isWorkletFunction } from '../commonTypes';\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\nfunction prepareAnimation(frameTimestamp, animatedProp, lastAnimation, lastValue) {\n 'worklet';\n\n if (Array.isArray(animatedProp)) {\n animatedProp.forEach((prop, index) => {\n prepareAnimation(frameTimestamp, prop, lastAnimation && lastAnimation[index], lastValue && lastValue[index]);\n });\n // return animatedProp;\n }\n if (typeof animatedProp === 'object' && animatedProp.onFrame) {\n const animation = animatedProp;\n let value = animation.current;\n if (lastValue !== undefined && lastValue !== null) {\n if (typeof lastValue === 'object') {\n if (lastValue.value !== undefined) {\n // previously it was a shared value\n value = lastValue.value;\n } else if (lastValue.onFrame !== undefined) {\n if ((lastAnimation === null || lastAnimation === void 0 ? void 0 : lastAnimation.current) !== undefined) {\n // it was an animation before, copy its state\n value = lastAnimation.current;\n } else if ((lastValue === null || lastValue === void 0 ? void 0 : lastValue.current) !== undefined) {\n // it was initialized\n value = lastValue.current;\n }\n }\n } else {\n // previously it was a plain value, just set it as starting point\n value = lastValue;\n }\n }\n animation.callStart = timestamp => {\n animation.onStart(animation, value, timestamp, lastAnimation);\n };\n animation.callStart(frameTimestamp);\n animation.callStart = null;\n } else if (typeof animatedProp === 'object') {\n // it is an object\n Object.keys(animatedProp).forEach(key => prepareAnimation(frameTimestamp, animatedProp[key], lastAnimation && lastAnimation[key], lastValue && lastValue[key]));\n }\n}\nfunction runAnimations(animation, timestamp, key, result, animationsActive) {\n 'worklet';\n\n if (!animationsActive.value) {\n return true;\n }\n if (Array.isArray(animation)) {\n result[key] = [];\n let allFinished = true;\n animation.forEach((entry, index) => {\n if (!runAnimations(entry, timestamp, index, result[key], animationsActive)) {\n allFinished = false;\n }\n });\n return allFinished;\n } else if (typeof animation === 'object' && animation.onFrame) {\n let finished = true;\n if (!animation.finished) {\n if (animation.callStart) {\n animation.callStart(timestamp);\n animation.callStart = null;\n }\n finished = animation.onFrame(animation, timestamp);\n animation.timestamp = timestamp;\n if (finished) {\n animation.finished = true;\n animation.callback && animation.callback(true /* finished */);\n }\n }\n result[key] = animation.current;\n return finished;\n } else if (typeof animation === 'object') {\n result[key] = {};\n let allFinished = true;\n Object.keys(animation).forEach(k => {\n if (!runAnimations(animation[k], timestamp, k, result[key], animationsActive)) {\n allFinished = false;\n }\n });\n return allFinished;\n } else {\n result[key] = animation;\n return true;\n }\n}\nfunction styleUpdater(viewDescriptors, updater, state, maybeViewRef, animationsActive, isAnimatedProps = false) {\n 'worklet';\n\n const animations = state.animations ?? {};\n const newValues = updater() ?? {};\n const oldValues = state.last;\n const nonAnimatedNewValues = {};\n let hasAnimations = false;\n let frameTimestamp;\n let hasNonAnimatedValues = false;\n for (const key in newValues) {\n const value = newValues[key];\n if (isAnimated(value)) {\n frameTimestamp = global.__frameTimestamp || global._getAnimationTimestamp();\n prepareAnimation(frameTimestamp, value, animations[key], oldValues[key]);\n animations[key] = value;\n hasAnimations = true;\n } else {\n hasNonAnimatedValues = true;\n nonAnimatedNewValues[key] = value;\n delete animations[key];\n }\n }\n if (hasAnimations) {\n const frame = timestamp => {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {\n animations,\n last,\n isAnimationCancelled\n } = state;\n if (isAnimationCancelled) {\n state.isAnimationRunning = false;\n return;\n }\n const updates = {};\n let allFinished = true;\n for (const propName in animations) {\n const finished = runAnimations(animations[propName], timestamp, propName, updates, animationsActive);\n if (finished) {\n last[propName] = updates[propName];\n delete animations[propName];\n } else {\n allFinished = false;\n }\n }\n if (updates) {\n updateProps(viewDescriptors, updates, maybeViewRef);\n }\n if (!allFinished) {\n requestAnimationFrame(frame);\n } else {\n state.isAnimationRunning = false;\n }\n };\n state.animations = animations;\n if (!state.isAnimationRunning) {\n state.isAnimationCancelled = false;\n state.isAnimationRunning = true;\n frame(frameTimestamp);\n }\n if (hasNonAnimatedValues) {\n updateProps(viewDescriptors, nonAnimatedNewValues, maybeViewRef);\n }\n } else {\n state.isAnimationCancelled = true;\n state.animations = [];\n if (!shallowEqual(oldValues, newValues)) {\n updateProps(viewDescriptors, newValues, maybeViewRef, isAnimatedProps);\n }\n }\n state.last = newValues;\n}\nfunction jestStyleUpdater(viewDescriptors, updater, state, maybeViewRef, animationsActive, animatedStyle, adapters) {\n 'worklet';\n\n const animations = state.animations ?? {};\n const newValues = updater() ?? {};\n const oldValues = state.last;\n\n // extract animated props\n let hasAnimations = false;\n let frameTimestamp;\n Object.keys(animations).forEach(key => {\n const value = newValues[key];\n if (!isAnimated(value)) {\n delete animations[key];\n }\n });\n Object.keys(newValues).forEach(key => {\n const value = newValues[key];\n if (isAnimated(value)) {\n frameTimestamp = global.__frameTimestamp || global._getAnimationTimestamp();\n prepareAnimation(frameTimestamp, value, animations[key], oldValues[key]);\n animations[key] = value;\n hasAnimations = true;\n }\n });\n function frame(timestamp) {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {\n animations,\n last,\n isAnimationCancelled\n } = state;\n if (isAnimationCancelled) {\n state.isAnimationRunning = false;\n return;\n }\n const updates = {};\n let allFinished = true;\n Object.keys(animations).forEach(propName => {\n const finished = runAnimations(animations[propName], timestamp, propName, updates, animationsActive);\n if (finished) {\n last[propName] = updates[propName];\n delete animations[propName];\n } else {\n allFinished = false;\n }\n });\n if (Object.keys(updates).length) {\n updatePropsJestWrapper(viewDescriptors, updates, maybeViewRef, animatedStyle, adapters);\n }\n if (!allFinished) {\n requestAnimationFrame(frame);\n } else {\n state.isAnimationRunning = false;\n }\n }\n if (hasAnimations) {\n state.animations = animations;\n if (!state.isAnimationRunning) {\n state.isAnimationCancelled = false;\n state.isAnimationRunning = true;\n frame(frameTimestamp);\n }\n } else {\n state.isAnimationCancelled = true;\n state.animations = [];\n }\n\n // calculate diff\n state.last = newValues;\n if (!shallowEqual(oldValues, newValues)) {\n updatePropsJestWrapper(viewDescriptors, newValues, maybeViewRef, animatedStyle, adapters);\n }\n}\n\n// check for invalid usage of shared values in returned object\nfunction checkSharedValueUsage(prop, currentKey) {\n if (Array.isArray(prop)) {\n // if it's an array (i.ex. transform) validate all its elements\n for (const element of prop) {\n checkSharedValueUsage(element, currentKey);\n }\n } else if (typeof prop === 'object' && prop !== null && prop.value === undefined) {\n // if it's a nested object, run validation for all its props\n for (const key of Object.keys(prop)) {\n checkSharedValueUsage(prop[key], key);\n }\n } else if (currentKey !== undefined && typeof prop === 'object' && prop !== null && prop.value !== undefined) {\n // if shared value is passed insted of its value, throw an error\n throw new Error(`[Reanimated] Invalid value passed to \\`${currentKey}\\`, maybe you forgot to use \\`.value\\`?`);\n }\n}\n\n/**\n * Lets you create a styles object, similar to StyleSheet styles, which can be animated using shared values.\n *\n * @param updater - A function returning an object with style properties you want to animate.\n * @param dependencies - An optional array of dependencies. Only relevant when using Reanimated without the Babel plugin on the Web.\n * @returns An animated style object which has to be passed to the `style` property of an Animated component you want to animate.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/core/useAnimatedStyle\n */\n// You cannot pass Shared Values to `useAnimatedStyle` directly.\n// @ts-expect-error This overload is required by our API.\n\nexport function useAnimatedStyle(updater, dependencies, adapters, isAnimatedProps = false) {\n const viewsRef = useViewRefSet();\n const animatedUpdaterData = useRef();\n let inputs = Object.values(updater.__closure ?? {});\n if (SHOULD_BE_USE_WEB) {\n var _dependencies;\n if (!inputs.length && (_dependencies = dependencies) !== null && _dependencies !== void 0 && _dependencies.length) {\n // let web work without a Babel plugin\n inputs = dependencies;\n }\n if (__DEV__ && !inputs.length && !dependencies && !isWorkletFunction(updater)) {\n throw new Error(`[Reanimated] \\`useAnimatedStyle\\` was used without a dependency array or Babel plugin. Please explicitly pass a dependency array, or enable the Babel plugin.\nFor more, see the docs: \\`https://docs.swmansion.com/react-native-reanimated/docs/guides/web-support#web-without-the-babel-plugin\\`.`);\n }\n }\n const adaptersArray = adapters ? Array.isArray(adapters) ? adapters : [adapters] : [];\n const adaptersHash = adapters ? buildWorkletsHash(adaptersArray) : null;\n const areAnimationsActive = useSharedValue(true);\n const jestAnimatedStyle = useRef({});\n\n // build dependencies\n if (!dependencies) {\n dependencies = [...inputs, updater.__workletHash];\n } else {\n dependencies.push(updater.__workletHash);\n }\n adaptersHash && dependencies.push(adaptersHash);\n if (!animatedUpdaterData.current) {\n const initialStyle = initialUpdaterRun(updater);\n if (__DEV__) {\n validateAnimatedStyles(initialStyle);\n }\n animatedUpdaterData.current = {\n initial: {\n value: initialStyle,\n updater\n },\n remoteState: makeShareable({\n last: initialStyle,\n animations: {},\n isAnimationCancelled: false,\n isAnimationRunning: false\n }),\n viewDescriptors: makeViewDescriptorsSet()\n };\n }\n const {\n initial,\n remoteState,\n viewDescriptors\n } = animatedUpdaterData.current;\n const shareableViewDescriptors = viewDescriptors.shareableViewDescriptors;\n dependencies.push(shareableViewDescriptors);\n useEffect(() => {\n let fun;\n let updaterFn = updater;\n if (adapters) {\n updaterFn = () => {\n 'worklet';\n\n const newValues = updater();\n adaptersArray.forEach(adapter => {\n adapter(newValues);\n });\n return newValues;\n };\n }\n if (isJest()) {\n fun = () => {\n 'worklet';\n\n jestStyleUpdater(shareableViewDescriptors, updater, remoteState, viewsRef, areAnimationsActive, jestAnimatedStyle, adaptersArray);\n };\n } else {\n fun = () => {\n 'worklet';\n\n styleUpdater(shareableViewDescriptors, updaterFn, remoteState, viewsRef, areAnimationsActive, isAnimatedProps);\n };\n }\n const mapperId = startMapper(fun, inputs);\n return () => {\n stopMapper(mapperId);\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, dependencies);\n useEffect(() => {\n areAnimationsActive.value = true;\n return () => {\n areAnimationsActive.value = false;\n };\n }, [areAnimationsActive]);\n checkSharedValueUsage(initial.value);\n const animatedStyleHandle = useRef(null);\n if (!animatedStyleHandle.current) {\n animatedStyleHandle.current = isJest() ? {\n viewDescriptors,\n initial,\n viewsRef,\n jestAnimatedStyle\n } : {\n initial,\n viewsRef,\n viewDescriptors\n };\n }\n return animatedStyleHandle.current;\n}\n//# sourceMappingURL=useAnimatedStyle.js.map","/* eslint-disable @typescript-eslint/no-redundant-type-constituents */\n'use strict';\n\nimport { processColorsInProps } from './Colors';\nimport { _updatePropsJS } from './js-reanimated';\nimport { isFabric, isJest, shouldBeUseWeb } from './PlatformChecker';\nimport { runOnUIImmediately } from './threads';\nlet updateProps;\nif (shouldBeUseWeb()) {\n updateProps = (_, updates, maybeViewRef, isAnimatedProps) => {\n 'worklet';\n\n if (maybeViewRef) {\n maybeViewRef.items.forEach((item, _index) => {\n _updatePropsJS(updates, item, isAnimatedProps);\n });\n }\n };\n} else {\n updateProps = (viewDescriptors, updates) => {\n 'worklet';\n\n processColorsInProps(updates);\n global.UpdatePropsManager.update(viewDescriptors, updates);\n };\n}\nexport const updatePropsJestWrapper = (viewDescriptors, updates, maybeViewRef, animatedStyle, adapters) => {\n adapters.forEach(adapter => {\n adapter(updates);\n });\n animatedStyle.current.value = {\n ...animatedStyle.current.value,\n ...updates\n };\n updateProps(viewDescriptors, updates, maybeViewRef);\n};\nexport default updateProps;\nconst createUpdatePropsManager = isFabric() ? () => {\n 'worklet';\n\n // Fabric\n const operations = [];\n return {\n update(viewDescriptors, updates) {\n viewDescriptors.value.forEach(viewDescriptor => {\n operations.push({\n shadowNodeWrapper: viewDescriptor.shadowNodeWrapper,\n updates\n });\n if (operations.length === 1) {\n queueMicrotask(this.flush);\n }\n });\n },\n flush() {\n global._updatePropsFabric(operations);\n operations.length = 0;\n }\n };\n} : () => {\n 'worklet';\n\n // Paper\n const operations = [];\n return {\n update(viewDescriptors, updates) {\n viewDescriptors.value.forEach(viewDescriptor => {\n operations.push({\n tag: viewDescriptor.tag,\n name: viewDescriptor.name || 'RCTView',\n updates\n });\n if (operations.length === 1) {\n queueMicrotask(this.flush);\n }\n });\n },\n flush() {\n global._updatePropsPaper(operations);\n operations.length = 0;\n }\n };\n};\nif (shouldBeUseWeb()) {\n const maybeThrowError = () => {\n // Jest attempts to access a property of this object to check if it is a Jest mock\n // so we can't throw an error in the getter.\n if (!isJest()) {\n throw new Error('[Reanimated] `UpdatePropsManager` is not available on non-native platform.');\n }\n };\n global.UpdatePropsManager = new Proxy({}, {\n get: maybeThrowError,\n set: () => {\n maybeThrowError();\n return false;\n }\n });\n} else {\n runOnUIImmediately(() => {\n 'worklet';\n\n global.UpdatePropsManager = createUpdatePropsManager();\n })();\n}\n//# sourceMappingURL=UpdateProps.js.map","'use strict';\n\n/**\n * Copied from:\n * react-native/Libraries/StyleSheet/normalizeColor.js\n * react-native/Libraries/StyleSheet/processColor.js\n * https://github.com/wcandillon/react-native-redash/blob/master/src/Colors.ts\n */\n\n/* eslint no-bitwise: 0 */\nimport { makeShareable } from './core';\nimport { isAndroid, isWeb } from './PlatformChecker';\n// var INTEGER = '[-+]?\\\\d+';\nconst NUMBER = '[-+]?(?:\\\\d+(?:\\\\.\\\\d*)?|\\\\.\\\\d+)';\nconst PERCENTAGE = NUMBER + '%';\nfunction call(...args) {\n 'worklet';\n\n return '\\\\(\\\\s*(' + args.join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\nconst MATCHERS = {\n rgb: new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER)),\n rgba: new RegExp('rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER)),\n hsl: new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE)),\n hsla: new RegExp('hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER)),\n hex3: /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex4: /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^#([0-9a-fA-F]{6})$/,\n hex8: /^#([0-9a-fA-F]{8})$/\n};\nfunction hue2rgb(p, q, t) {\n 'worklet';\n\n if (t < 0) {\n t += 1;\n }\n if (t > 1) {\n t -= 1;\n }\n if (t < 1 / 6) {\n return p + (q - p) * 6 * t;\n }\n if (t < 1 / 2) {\n return q;\n }\n if (t < 2 / 3) {\n return p + (q - p) * (2 / 3 - t) * 6;\n }\n return p;\n}\nfunction hslToRgb(h, s, l) {\n 'worklet';\n\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n const r = hue2rgb(p, q, h + 1 / 3);\n const g = hue2rgb(p, q, h);\n const b = hue2rgb(p, q, h - 1 / 3);\n return Math.round(r * 255) << 24 | Math.round(g * 255) << 16 | Math.round(b * 255) << 8;\n}\nfunction parse255(str) {\n 'worklet';\n\n const int = Number.parseInt(str, 10);\n if (int < 0) {\n return 0;\n }\n if (int > 255) {\n return 255;\n }\n return int;\n}\nfunction parse360(str) {\n 'worklet';\n\n const int = Number.parseFloat(str);\n return (int % 360 + 360) % 360 / 360;\n}\nfunction parse1(str) {\n 'worklet';\n\n const num = Number.parseFloat(str);\n if (num < 0) {\n return 0;\n }\n if (num > 1) {\n return 255;\n }\n return Math.round(num * 255);\n}\nfunction parsePercentage(str) {\n 'worklet';\n\n // parseFloat conveniently ignores the final %\n const int = Number.parseFloat(str);\n if (int < 0) {\n return 0;\n }\n if (int > 100) {\n return 1;\n }\n return int / 100;\n}\nconst names = makeShareable({\n transparent: 0x00000000,\n // http://www.w3.org/TR/css3-color/#svg-color\n aliceblue: 0xf0f8ffff,\n antiquewhite: 0xfaebd7ff,\n aqua: 0x00ffffff,\n aquamarine: 0x7fffd4ff,\n azure: 0xf0ffffff,\n beige: 0xf5f5dcff,\n bisque: 0xffe4c4ff,\n black: 0x000000ff,\n blanchedalmond: 0xffebcdff,\n blue: 0x0000ffff,\n blueviolet: 0x8a2be2ff,\n brown: 0xa52a2aff,\n burlywood: 0xdeb887ff,\n burntsienna: 0xea7e5dff,\n cadetblue: 0x5f9ea0ff,\n chartreuse: 0x7fff00ff,\n chocolate: 0xd2691eff,\n coral: 0xff7f50ff,\n cornflowerblue: 0x6495edff,\n cornsilk: 0xfff8dcff,\n crimson: 0xdc143cff,\n cyan: 0x00ffffff,\n darkblue: 0x00008bff,\n darkcyan: 0x008b8bff,\n darkgoldenrod: 0xb8860bff,\n darkgray: 0xa9a9a9ff,\n darkgreen: 0x006400ff,\n darkgrey: 0xa9a9a9ff,\n darkkhaki: 0xbdb76bff,\n darkmagenta: 0x8b008bff,\n darkolivegreen: 0x556b2fff,\n darkorange: 0xff8c00ff,\n darkorchid: 0x9932ccff,\n darkred: 0x8b0000ff,\n darksalmon: 0xe9967aff,\n darkseagreen: 0x8fbc8fff,\n darkslateblue: 0x483d8bff,\n darkslategray: 0x2f4f4fff,\n darkslategrey: 0x2f4f4fff,\n darkturquoise: 0x00ced1ff,\n darkviolet: 0x9400d3ff,\n deeppink: 0xff1493ff,\n deepskyblue: 0x00bfffff,\n dimgray: 0x696969ff,\n dimgrey: 0x696969ff,\n dodgerblue: 0x1e90ffff,\n firebrick: 0xb22222ff,\n floralwhite: 0xfffaf0ff,\n forestgreen: 0x228b22ff,\n fuchsia: 0xff00ffff,\n gainsboro: 0xdcdcdcff,\n ghostwhite: 0xf8f8ffff,\n gold: 0xffd700ff,\n goldenrod: 0xdaa520ff,\n gray: 0x808080ff,\n green: 0x008000ff,\n greenyellow: 0xadff2fff,\n grey: 0x808080ff,\n honeydew: 0xf0fff0ff,\n hotpink: 0xff69b4ff,\n indianred: 0xcd5c5cff,\n indigo: 0x4b0082ff,\n ivory: 0xfffff0ff,\n khaki: 0xf0e68cff,\n lavender: 0xe6e6faff,\n lavenderblush: 0xfff0f5ff,\n lawngreen: 0x7cfc00ff,\n lemonchiffon: 0xfffacdff,\n lightblue: 0xadd8e6ff,\n lightcoral: 0xf08080ff,\n lightcyan: 0xe0ffffff,\n lightgoldenrodyellow: 0xfafad2ff,\n lightgray: 0xd3d3d3ff,\n lightgreen: 0x90ee90ff,\n lightgrey: 0xd3d3d3ff,\n lightpink: 0xffb6c1ff,\n lightsalmon: 0xffa07aff,\n lightseagreen: 0x20b2aaff,\n lightskyblue: 0x87cefaff,\n lightslategray: 0x778899ff,\n lightslategrey: 0x778899ff,\n lightsteelblue: 0xb0c4deff,\n lightyellow: 0xffffe0ff,\n lime: 0x00ff00ff,\n limegreen: 0x32cd32ff,\n linen: 0xfaf0e6ff,\n magenta: 0xff00ffff,\n maroon: 0x800000ff,\n mediumaquamarine: 0x66cdaaff,\n mediumblue: 0x0000cdff,\n mediumorchid: 0xba55d3ff,\n mediumpurple: 0x9370dbff,\n mediumseagreen: 0x3cb371ff,\n mediumslateblue: 0x7b68eeff,\n mediumspringgreen: 0x00fa9aff,\n mediumturquoise: 0x48d1ccff,\n mediumvioletred: 0xc71585ff,\n midnightblue: 0x191970ff,\n mintcream: 0xf5fffaff,\n mistyrose: 0xffe4e1ff,\n moccasin: 0xffe4b5ff,\n navajowhite: 0xffdeadff,\n navy: 0x000080ff,\n oldlace: 0xfdf5e6ff,\n olive: 0x808000ff,\n olivedrab: 0x6b8e23ff,\n orange: 0xffa500ff,\n orangered: 0xff4500ff,\n orchid: 0xda70d6ff,\n palegoldenrod: 0xeee8aaff,\n palegreen: 0x98fb98ff,\n paleturquoise: 0xafeeeeff,\n palevioletred: 0xdb7093ff,\n papayawhip: 0xffefd5ff,\n peachpuff: 0xffdab9ff,\n peru: 0xcd853fff,\n pink: 0xffc0cbff,\n plum: 0xdda0ddff,\n powderblue: 0xb0e0e6ff,\n purple: 0x800080ff,\n rebeccapurple: 0x663399ff,\n red: 0xff0000ff,\n rosybrown: 0xbc8f8fff,\n royalblue: 0x4169e1ff,\n saddlebrown: 0x8b4513ff,\n salmon: 0xfa8072ff,\n sandybrown: 0xf4a460ff,\n seagreen: 0x2e8b57ff,\n seashell: 0xfff5eeff,\n sienna: 0xa0522dff,\n silver: 0xc0c0c0ff,\n skyblue: 0x87ceebff,\n slateblue: 0x6a5acdff,\n slategray: 0x708090ff,\n slategrey: 0x708090ff,\n snow: 0xfffafaff,\n springgreen: 0x00ff7fff,\n steelblue: 0x4682b4ff,\n tan: 0xd2b48cff,\n teal: 0x008080ff,\n thistle: 0xd8bfd8ff,\n tomato: 0xff6347ff,\n turquoise: 0x40e0d0ff,\n violet: 0xee82eeff,\n wheat: 0xf5deb3ff,\n white: 0xffffffff,\n whitesmoke: 0xf5f5f5ff,\n yellow: 0xffff00ff,\n yellowgreen: 0x9acd32ff\n});\n\n// copied from react-native/Libraries/Components/View/ReactNativeStyleAttributes\nexport const ColorProperties = makeShareable(['backgroundColor', 'borderBottomColor', 'borderColor', 'borderLeftColor', 'borderRightColor', 'borderTopColor', 'borderStartColor', 'borderEndColor', 'borderBlockColor', 'borderBlockEndColor', 'borderBlockStartColor', 'color', 'shadowColor', 'textDecorationColor', 'tintColor', 'textShadowColor', 'overlayColor']);\nfunction normalizeColor(color) {\n 'worklet';\n\n if (typeof color === 'number') {\n if (color >>> 0 === color && color >= 0 && color <= 0xffffffff) {\n return color;\n }\n return null;\n }\n if (typeof color !== 'string') {\n return null;\n }\n let match;\n\n // Ordered based on occurrences on Facebook codebase\n if (match = MATCHERS.hex6.exec(color)) {\n return Number.parseInt(match[1] + 'ff', 16) >>> 0;\n }\n if (names[color] !== undefined) {\n return names[color];\n }\n if (match = MATCHERS.rgb.exec(color)) {\n return (\n // b\n (parse255(match[1]) << 24 |\n // r\n parse255(match[2]) << 16 |\n // g\n parse255(match[3]) << 8 | 0x000000ff) >>>\n // a\n 0\n );\n }\n if (match = MATCHERS.rgba.exec(color)) {\n return (\n // b\n (parse255(match[1]) << 24 |\n // r\n parse255(match[2]) << 16 |\n // g\n parse255(match[3]) << 8 | parse1(match[4])) >>>\n // a\n 0\n );\n }\n if (match = MATCHERS.hex3.exec(color)) {\n return Number.parseInt(match[1] + match[1] +\n // r\n match[2] + match[2] +\n // g\n match[3] + match[3] +\n // b\n 'ff',\n // a\n 16) >>> 0;\n }\n\n // https://drafts.csswg.org/css-color-4/#hex-notation\n if (match = MATCHERS.hex8.exec(color)) {\n return Number.parseInt(match[1], 16) >>> 0;\n }\n if (match = MATCHERS.hex4.exec(color)) {\n return Number.parseInt(match[1] + match[1] +\n // r\n match[2] + match[2] +\n // g\n match[3] + match[3] +\n // b\n match[4] + match[4],\n // a\n 16) >>> 0;\n }\n if (match = MATCHERS.hsl.exec(color)) {\n return (hslToRgb(parse360(match[1]),\n // h\n parsePercentage(match[2]),\n // s\n parsePercentage(match[3]) // l\n ) | 0x000000ff) >>>\n // a\n 0;\n }\n if (match = MATCHERS.hsla.exec(color)) {\n return (hslToRgb(parse360(match[1]),\n // h\n parsePercentage(match[2]),\n // s\n parsePercentage(match[3]) // l\n ) | parse1(match[4])) >>>\n // a\n 0;\n }\n return null;\n}\nexport const opacity = c => {\n 'worklet';\n\n return (c >> 24 & 255) / 255;\n};\nexport const red = c => {\n 'worklet';\n\n return c >> 16 & 255;\n};\nexport const green = c => {\n 'worklet';\n\n return c >> 8 & 255;\n};\nexport const blue = c => {\n 'worklet';\n\n return c & 255;\n};\nconst IS_WEB = isWeb();\nconst IS_ANDROID = isAndroid();\nexport const rgbaColor = (r, g, b, alpha = 1) => {\n 'worklet';\n\n if (IS_WEB || !_WORKLET) {\n return `rgba(${r}, ${g}, ${b}, ${alpha})`;\n }\n const c = Math.round(alpha * 255) * (1 << 24) + Math.round(r) * (1 << 16) + Math.round(g) * (1 << 8) + Math.round(b);\n if (IS_ANDROID) {\n // on Android color is represented as signed 32 bit int\n return c < 1 << 31 >>> 0 ? c : c - 4294967296; // 4294967296 == Math.pow(2, 32);\n }\n return c;\n};\n\n/**\n *\n * @param r - red value (0-255)\n * @param g - green value (0-255)\n * @param b - blue value (0-255)\n * @returns \\{h: hue (0-1), s: saturation (0-1), v: value (0-1)\\}\n */\nexport function RGBtoHSV(r, g, b) {\n 'worklet';\n\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const d = max - min;\n const s = max === 0 ? 0 : d / max;\n const v = max / 255;\n let h = 0;\n switch (max) {\n case min:\n break;\n case r:\n h = g - b + d * (g < b ? 6 : 0);\n h /= 6 * d;\n break;\n case g:\n h = b - r + d * 2;\n h /= 6 * d;\n break;\n case b:\n h = r - g + d * 4;\n h /= 6 * d;\n break;\n }\n return {\n h,\n s,\n v\n };\n}\n\n/**\n *\n * @param h - hue (0-1)\n * @param s - saturation (0-1)\n * @param v - value (0-1)\n * @returns \\{r: red (0-255), g: green (0-255), b: blue (0-255)\\}\n */\nfunction HSVtoRGB(h, s, v) {\n 'worklet';\n\n let r, g, b;\n const i = Math.floor(h * 6);\n const f = h * 6 - i;\n const p = v * (1 - s);\n const q = v * (1 - f * s);\n const t = v * (1 - (1 - f) * s);\n switch (i % 6) {\n case 0:\n [r, g, b] = [v, t, p];\n break;\n case 1:\n [r, g, b] = [q, v, p];\n break;\n case 2:\n [r, g, b] = [p, v, t];\n break;\n case 3:\n [r, g, b] = [p, q, v];\n break;\n case 4:\n [r, g, b] = [t, p, v];\n break;\n case 5:\n [r, g, b] = [v, p, q];\n break;\n }\n return {\n r: Math.round(r * 255),\n g: Math.round(g * 255),\n b: Math.round(b * 255)\n };\n}\nexport const hsvToColor = (h, s, v, a) => {\n 'worklet';\n\n const {\n r,\n g,\n b\n } = HSVtoRGB(h, s, v);\n return rgbaColor(r, g, b, a);\n};\nfunction processColorInitially(color) {\n 'worklet';\n\n if (color === null || color === undefined || typeof color === 'number') {\n return color;\n }\n let normalizedColor = normalizeColor(color);\n if (normalizedColor === null || normalizedColor === undefined) {\n return undefined;\n }\n if (typeof normalizedColor !== 'number') {\n return null;\n }\n normalizedColor = (normalizedColor << 24 | normalizedColor >>> 8) >>> 0; // argb\n return normalizedColor;\n}\nexport function isColor(value) {\n 'worklet';\n\n if (typeof value !== 'string') {\n return false;\n }\n return processColorInitially(value) != null;\n}\nexport function processColor(color) {\n 'worklet';\n\n let normalizedColor = processColorInitially(color);\n if (normalizedColor === null || normalizedColor === undefined) {\n return undefined;\n }\n if (typeof normalizedColor !== 'number') {\n return null;\n }\n if (IS_ANDROID) {\n // Android use 32 bit *signed* integer to represent the color\n // We utilize the fact that bitwise operations in JS also operates on\n // signed 32 bit integers, so that we can use those to convert from\n // *unsigned* to *signed* 32bit int that way.\n normalizedColor = normalizedColor | 0x0;\n }\n return normalizedColor;\n}\nexport function processColorsInProps(props) {\n 'worklet';\n\n for (const key in props) {\n if (ColorProperties.includes(key)) {\n props[key] = processColor(props[key]);\n }\n }\n}\nexport function convertToRGBA(color) {\n 'worklet';\n\n const processedColor = processColorInitially(color); // argb;\n const a = (processedColor >>> 24) / 255;\n const r = (processedColor << 8 >>> 24) / 255;\n const g = (processedColor << 16 >>> 24) / 255;\n const b = (processedColor << 24 >>> 24) / 255;\n return [r, g, b, a];\n}\nexport function rgbaArrayToRGBAColor(RGBA) {\n 'worklet';\n\n return `rgba(${Math.round(RGBA[0] * 255)}, ${Math.round(RGBA[1] * 255)}, ${Math.round(RGBA[2] * 255)}, ${RGBA[3]})`;\n}\nexport function toLinearSpace(RGBA, gamma = 2.2) {\n 'worklet';\n\n const res = [];\n for (let i = 0; i < 3; ++i) {\n res.push(Math.pow(RGBA[i], gamma));\n }\n res.push(RGBA[3]);\n return res;\n}\nexport function toGammaSpace(RGBA, gamma = 2.2) {\n 'worklet';\n\n const res = [];\n for (let i = 0; i < 3; ++i) {\n res.push(Math.pow(RGBA[i], 1 / gamma));\n }\n res.push(RGBA[3]);\n return res;\n}\n//# sourceMappingURL=Colors.js.map","'use strict';\n\nexport { cancelAnimation, defineAnimation, initialUpdaterRun } from './util';\nexport { withTiming } from './timing';\nexport { withSpring } from './spring';\nexport { withDecay } from './decay';\nexport { withClamp } from './clamp';\nexport { withDelay } from './delay';\nexport { withRepeat } from './repeat';\nexport { withSequence } from './sequence';\nexport { withStyleAnimation } from './styleAnimation';\n//# sourceMappingURL=index.js.map","/* eslint-disable @typescript-eslint/no-shadow */\n'use strict';\n\nimport { isColor, convertToRGBA, rgbaArrayToRGBAColor, toGammaSpace, toLinearSpace } from '../Colors';\nimport { ReduceMotion, isWorkletFunction } from '../commonTypes';\nimport { flatten, multiplyMatrices, scaleMatrix, addMatrices, decomposeMatrixIntoMatricesAndAngles, isAffineMatrixFlat, subtractMatrices, getRotationMatrix } from './transformationMatrix/matrixUtils';\nimport { isReducedMotion, shouldBeUseWeb } from '../PlatformChecker';\nlet IN_STYLE_UPDATER = false;\nconst IS_REDUCED_MOTION = isReducedMotion();\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\nif (__DEV__ && IS_REDUCED_MOTION) {\n console.warn(`[Reanimated] Reduced motion setting is enabled on this device. This warning is visible only in the development mode. Some animations will be disabled by default. You can override the behavior for individual animations, see https://docs.swmansion.com/react-native-reanimated/docs/guides/troubleshooting#reduced-motion-setting-is-enabled-on-this-device.`);\n}\nexport function assertEasingIsWorklet(easing) {\n 'worklet';\n\n if (_WORKLET) {\n // If this is called on UI (for example from gesture handler with worklets), we don't get easing,\n // but its bound copy, which is not a worklet. We don't want to throw any error then.\n return;\n }\n if (SHOULD_BE_USE_WEB) {\n // It is possible to run reanimated on web without plugin, so let's skip this check on web\n return;\n }\n // @ts-ignore typescript wants us to use `in` instead, which doesn't work with host objects\n if (easing !== null && easing !== void 0 && easing.factory) {\n return;\n }\n if (!isWorkletFunction(easing)) {\n throw new Error('[Reanimated] The easing function is not a worklet. Please make sure you import `Easing` from react-native-reanimated.');\n }\n}\nexport function initialUpdaterRun(updater) {\n IN_STYLE_UPDATER = true;\n const result = updater();\n IN_STYLE_UPDATER = false;\n return result;\n}\nexport function recognizePrefixSuffix(value) {\n 'worklet';\n\n if (typeof value === 'string') {\n const match = value.match(/([A-Za-z]*)(-?\\d*\\.?\\d*)([eE][-+]?[0-9]+)?([A-Za-z%]*)/);\n if (!match) {\n throw new Error(\"[Reanimated] Couldn't parse animation value.\");\n }\n const prefix = match[1];\n const suffix = match[4];\n // number with scientific notation\n const number = match[2] + (match[3] ?? '');\n return {\n prefix,\n suffix,\n strippedValue: parseFloat(number)\n };\n } else {\n return {\n strippedValue: value\n };\n }\n}\n\n/**\n * Returns whether the motion should be reduced for a specified config.\n * By default returns the system setting.\n */\nexport function getReduceMotionFromConfig(config) {\n 'worklet';\n\n return !config || config === ReduceMotion.System ? IS_REDUCED_MOTION : config === ReduceMotion.Always;\n}\n\n/**\n * Returns the value that should be assigned to `animation.reduceMotion`\n * for a given config. If the config is not defined, `undefined` is returned.\n */\nexport function getReduceMotionForAnimation(config) {\n 'worklet';\n\n // if the config is not defined, we want `reduceMotion` to be undefined,\n // so the parent animation knows if it should overwrite it\n if (!config) {\n return undefined;\n }\n return getReduceMotionFromConfig(config);\n}\nfunction applyProgressToMatrix(progress, a, b) {\n 'worklet';\n\n return addMatrices(a, scaleMatrix(subtractMatrices(b, a), progress));\n}\nfunction applyProgressToNumber(progress, a, b) {\n 'worklet';\n\n return a + progress * (b - a);\n}\nfunction decorateAnimation(animation) {\n 'worklet';\n\n const baseOnStart = animation.onStart;\n const baseOnFrame = animation.onFrame;\n if (animation.isHigherOrder) {\n animation.onStart = (animation, value, timestamp, previousAnimation) => {\n if (animation.reduceMotion === undefined) {\n animation.reduceMotion = getReduceMotionFromConfig();\n }\n return baseOnStart(animation, value, timestamp, previousAnimation);\n };\n return;\n }\n const animationCopy = Object.assign({}, animation);\n delete animationCopy.callback;\n const prefNumberSuffOnStart = (animation, value, timestamp, previousAnimation) => {\n // recognize prefix, suffix, and updates stripped value on animation start\n const {\n prefix,\n suffix,\n strippedValue\n } = recognizePrefixSuffix(value);\n animation.__prefix = prefix;\n animation.__suffix = suffix;\n animation.strippedCurrent = strippedValue;\n const {\n strippedValue: strippedToValue\n } = recognizePrefixSuffix(animation.toValue);\n animation.current = strippedValue;\n animation.startValue = strippedValue;\n animation.toValue = strippedToValue;\n if (previousAnimation && previousAnimation !== animation) {\n const {\n prefix: paPrefix,\n suffix: paSuffix,\n strippedValue: paStrippedValue\n } = recognizePrefixSuffix(previousAnimation.current);\n previousAnimation.current = paStrippedValue;\n previousAnimation.__prefix = paPrefix;\n previousAnimation.__suffix = paSuffix;\n }\n baseOnStart(animation, strippedValue, timestamp, previousAnimation);\n animation.current = (animation.__prefix ?? '') + animation.current + (animation.__suffix ?? '');\n if (previousAnimation && previousAnimation !== animation) {\n previousAnimation.current = (previousAnimation.__prefix ?? '') +\n // FIXME\n // eslint-disable-next-line @typescript-eslint/restrict-plus-operands\n previousAnimation.current + (previousAnimation.__suffix ?? '');\n }\n };\n const prefNumberSuffOnFrame = (animation, timestamp) => {\n animation.current = animation.strippedCurrent;\n const res = baseOnFrame(animation, timestamp);\n animation.strippedCurrent = animation.current;\n animation.current = (animation.__prefix ?? '') + animation.current + (animation.__suffix ?? '');\n return res;\n };\n const tab = ['R', 'G', 'B', 'A'];\n const colorOnStart = (animation, value, timestamp, previousAnimation) => {\n let RGBAValue;\n let RGBACurrent;\n let RGBAToValue;\n const res = [];\n if (isColor(value)) {\n RGBACurrent = toLinearSpace(convertToRGBA(animation.current));\n RGBAValue = toLinearSpace(convertToRGBA(value));\n if (animation.toValue) {\n RGBAToValue = toLinearSpace(convertToRGBA(animation.toValue));\n }\n }\n tab.forEach((i, index) => {\n animation[i] = Object.assign({}, animationCopy);\n animation[i].current = RGBACurrent[index];\n animation[i].toValue = RGBAToValue ? RGBAToValue[index] : undefined;\n animation[i].onStart(animation[i], RGBAValue[index], timestamp, previousAnimation ? previousAnimation[i] : undefined);\n res.push(animation[i].current);\n });\n animation.current = rgbaArrayToRGBAColor(toGammaSpace(res));\n };\n const colorOnFrame = (animation, timestamp) => {\n const RGBACurrent = toLinearSpace(convertToRGBA(animation.current));\n const res = [];\n let finished = true;\n tab.forEach((i, index) => {\n animation[i].current = RGBACurrent[index];\n const result = animation[i].onFrame(animation[i], timestamp);\n // We really need to assign this value to result, instead of passing it directly - otherwise once \"finished\" is false, onFrame won't be called\n finished = finished && result;\n res.push(animation[i].current);\n });\n animation.current = rgbaArrayToRGBAColor(toGammaSpace(res));\n return finished;\n };\n const transformationMatrixOnStart = (animation, value, timestamp, previousAnimation) => {\n const toValue = animation.toValue;\n animation.startMatrices = decomposeMatrixIntoMatricesAndAngles(value);\n animation.stopMatrices = decomposeMatrixIntoMatricesAndAngles(toValue);\n\n // We create an animation copy to animate single value between 0 and 100\n // We set limits from 0 to 100 (instead of 0-1) to make spring look good\n // with default thresholds.\n\n animation[0] = Object.assign({}, animationCopy);\n animation[0].current = 0;\n animation[0].toValue = 100;\n animation[0].onStart(animation[0], 0, timestamp, previousAnimation ? previousAnimation[0] : undefined);\n animation.current = value;\n };\n const transformationMatrixOnFrame = (animation, timestamp) => {\n let finished = true;\n const result = animation[0].onFrame(animation[0], timestamp);\n // We really need to assign this value to result, instead of passing it directly - otherwise once \"finished\" is false, onFrame won't be called\n finished = finished && result;\n const progress = animation[0].current / 100;\n const transforms = ['translationMatrix', 'scaleMatrix', 'skewMatrix'];\n const mappedTransforms = [];\n transforms.forEach((key, _) => mappedTransforms.push(applyProgressToMatrix(progress, animation.startMatrices[key], animation.stopMatrices[key])));\n const [currentTranslation, currentScale, skewMatrix] = mappedTransforms;\n const rotations = ['x', 'y', 'z'];\n const mappedRotations = [];\n rotations.forEach((key, _) => {\n const angle = applyProgressToNumber(progress, animation.startMatrices['r' + key], animation.stopMatrices['r' + key]);\n mappedRotations.push(getRotationMatrix(angle, key));\n });\n const [rotationMatrixX, rotationMatrixY, rotationMatrixZ] = mappedRotations;\n const rotationMatrix = multiplyMatrices(rotationMatrixX, multiplyMatrices(rotationMatrixY, rotationMatrixZ));\n const updated = flatten(multiplyMatrices(multiplyMatrices(currentScale, multiplyMatrices(skewMatrix, rotationMatrix)), currentTranslation));\n animation.current = updated;\n return finished;\n };\n const arrayOnStart = (animation, value, timestamp, previousAnimation) => {\n value.forEach((v, i) => {\n animation[i] = Object.assign({}, animationCopy);\n animation[i].current = v;\n animation[i].toValue = animation.toValue[i];\n animation[i].onStart(animation[i], v, timestamp, previousAnimation ? previousAnimation[i] : undefined);\n });\n animation.current = value;\n };\n const arrayOnFrame = (animation, timestamp) => {\n let finished = true;\n animation.current.forEach((_, i) => {\n const result = animation[i].onFrame(animation[i], timestamp);\n // We really need to assign this value to result, instead of passing it directly - otherwise once \"finished\" is false, onFrame won't be called\n finished = finished && result;\n animation.current[i] = animation[i].current;\n });\n return finished;\n };\n const objectOnStart = (animation, value, timestamp, previousAnimation) => {\n for (const key in value) {\n animation[key] = Object.assign({}, animationCopy);\n animation[key].onStart = animation.onStart;\n animation[key].current = value[key];\n animation[key].toValue = animation.toValue[key];\n animation[key].onStart(animation[key], value[key], timestamp, previousAnimation ? previousAnimation[key] : undefined);\n }\n animation.current = value;\n };\n const objectOnFrame = (animation, timestamp) => {\n let finished = true;\n const newObject = {};\n for (const key in animation.current) {\n const result = animation[key].onFrame(animation[key], timestamp);\n // We really need to assign this value to result, instead of passing it directly - otherwise once \"finished\" is false, onFrame won't be called\n finished = finished && result;\n newObject[key] = animation[key].current;\n }\n animation.current = newObject;\n return finished;\n };\n animation.onStart = (animation, value, timestamp, previousAnimation) => {\n if (animation.reduceMotion === undefined) {\n animation.reduceMotion = getReduceMotionFromConfig();\n }\n if (animation.reduceMotion) {\n if (animation.toValue !== undefined) {\n animation.current = animation.toValue;\n } else {\n // if there is no `toValue`, then the base function is responsible for setting the current value\n baseOnStart(animation, value, timestamp, previousAnimation);\n }\n animation.startTime = 0;\n animation.onFrame = () => true;\n return;\n }\n if (isColor(value)) {\n colorOnStart(animation, value, timestamp, previousAnimation);\n animation.onFrame = colorOnFrame;\n return;\n } else if (isAffineMatrixFlat(value)) {\n transformationMatrixOnStart(animation, value, timestamp, previousAnimation);\n animation.onFrame = transformationMatrixOnFrame;\n return;\n } else if (Array.isArray(value)) {\n arrayOnStart(animation, value, timestamp, previousAnimation);\n animation.onFrame = arrayOnFrame;\n return;\n } else if (typeof value === 'string') {\n prefNumberSuffOnStart(animation, value, timestamp, previousAnimation);\n animation.onFrame = prefNumberSuffOnFrame;\n return;\n } else if (typeof value === 'object' && value !== null) {\n objectOnStart(animation, value, timestamp, previousAnimation);\n animation.onFrame = objectOnFrame;\n return;\n }\n baseOnStart(animation, value, timestamp, previousAnimation);\n };\n}\nexport function defineAnimation(starting, factory) {\n 'worklet';\n\n if (IN_STYLE_UPDATER) {\n return starting;\n }\n const create = () => {\n 'worklet';\n\n const animation = factory();\n decorateAnimation(animation);\n return animation;\n };\n if (_WORKLET || SHOULD_BE_USE_WEB) {\n return create();\n }\n // @ts-ignore: eslint-disable-line\n return create;\n}\n\n/**\n * Lets you cancel a running animation paired to a shared value.\n *\n * @param sharedValue - The shared value of a running animation that you want to cancel.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/core/cancelAnimation\n */\nexport function cancelAnimation(sharedValue) {\n 'worklet';\n\n // setting the current value cancels the animation if one is currently running\n sharedValue.value = sharedValue.value; // eslint-disable-line no-self-assign\n}\n//# sourceMappingURL=util.js.map","'use strict';\n\nexport function isAffineMatrixFlat(x) {\n 'worklet';\n\n return Array.isArray(x) && x.length === 16 && x.every(element => typeof element === 'number' && !isNaN(element));\n}\n\n// ts-prune-ignore-next This function is exported to be tested\nexport function isAffineMatrix(x) {\n 'worklet';\n\n return Array.isArray(x) && x.length === 4 && x.every(row => Array.isArray(row) && row.length === 4 && row.every(element => typeof element === 'number' && !isNaN(element)));\n}\nexport function flatten(matrix) {\n 'worklet';\n\n return matrix.flat();\n}\n\n// ts-prune-ignore-next This function is exported to be tested\nexport function unflatten(m) {\n 'worklet';\n\n return [[m[0], m[1], m[2], m[3]], [m[4], m[5], m[6], m[7]], [m[8], m[9], m[10], m[11]], [m[12], m[13], m[14], m[15]]];\n}\nfunction maybeFlattenMatrix(matrix) {\n 'worklet';\n\n return isAffineMatrix(matrix) ? flatten(matrix) : matrix;\n}\nexport function multiplyMatrices(a, b) {\n 'worklet';\n\n return [[a[0][0] * b[0][0] + a[0][1] * b[1][0] + a[0][2] * b[2][0] + a[0][3] * b[3][0], a[0][0] * b[0][1] + a[0][1] * b[1][1] + a[0][2] * b[2][1] + a[0][3] * b[3][1], a[0][0] * b[0][2] + a[0][1] * b[1][2] + a[0][2] * b[2][2] + a[0][3] * b[3][2], a[0][0] * b[0][3] + a[0][1] * b[1][3] + a[0][2] * b[2][3] + a[0][3] * b[3][3]], [a[1][0] * b[0][0] + a[1][1] * b[1][0] + a[1][2] * b[2][0] + a[1][3] * b[3][0], a[1][0] * b[0][1] + a[1][1] * b[1][1] + a[1][2] * b[2][1] + a[1][3] * b[3][1], a[1][0] * b[0][2] + a[1][1] * b[1][2] + a[1][2] * b[2][2] + a[1][3] * b[3][2], a[1][0] * b[0][3] + a[1][1] * b[1][3] + a[1][2] * b[2][3] + a[1][3] * b[3][3]], [a[2][0] * b[0][0] + a[2][1] * b[1][0] + a[2][2] * b[2][0] + a[2][3] * b[3][0], a[2][0] * b[0][1] + a[2][1] * b[1][1] + a[2][2] * b[2][1] + a[2][3] * b[3][1], a[2][0] * b[0][2] + a[2][1] * b[1][2] + a[2][2] * b[2][2] + a[2][3] * b[3][2], a[2][0] * b[0][3] + a[2][1] * b[1][3] + a[2][2] * b[2][3] + a[2][3] * b[3][3]], [a[3][0] * b[0][0] + a[3][1] * b[1][0] + a[3][2] * b[2][0] + a[3][3] * b[3][0], a[3][0] * b[0][1] + a[3][1] * b[1][1] + a[3][2] * b[2][1] + a[3][3] * b[3][1], a[3][0] * b[0][2] + a[3][1] * b[1][2] + a[3][2] * b[2][2] + a[3][3] * b[3][2], a[3][0] * b[0][3] + a[3][1] * b[1][3] + a[3][2] * b[2][3] + a[3][3] * b[3][3]]];\n}\nexport function subtractMatrices(maybeFlatA, maybeFlatB) {\n 'worklet';\n\n const isFlatOnStart = isAffineMatrixFlat(maybeFlatA);\n const a = maybeFlattenMatrix(maybeFlatA);\n const b = maybeFlattenMatrix(maybeFlatB);\n const c = a.map((_, i) => a[i] - b[i]);\n return isFlatOnStart ? c : unflatten(c);\n}\nexport function addMatrices(maybeFlatA, maybeFlatB) {\n 'worklet';\n\n const isFlatOnStart = isAffineMatrixFlat(maybeFlatA);\n const a = maybeFlattenMatrix(maybeFlatA);\n const b = maybeFlattenMatrix(maybeFlatB);\n const c = a.map((_, i) => a[i] + b[i]);\n return isFlatOnStart ? c : unflatten(c);\n}\nexport function scaleMatrix(maybeFlatA, scalar) {\n 'worklet';\n\n const isFlatOnStart = isAffineMatrixFlat(maybeFlatA);\n const a = maybeFlattenMatrix(maybeFlatA);\n const b = a.map(x => x * scalar);\n return isFlatOnStart ? b : unflatten(b);\n}\nexport function getRotationMatrix(angle, axis = 'z') {\n 'worklet';\n\n const cos = Math.cos(angle);\n const sin = Math.sin(angle);\n switch (axis) {\n case 'z':\n return [[cos, sin, 0, 0], [-sin, cos, 0, 0], [0, 0, 1, 0], [0, 0, 0, 1]];\n case 'y':\n return [[cos, 0, -sin, 0], [0, 1, 0, 0], [sin, 0, cos, 0], [0, 0, 0, 1]];\n case 'x':\n return [[1, 0, 0, 0], [0, cos, sin, 0], [0, -sin, cos, 0], [0, 0, 0, 1]];\n }\n}\nfunction norm3d(x, y, z) {\n 'worklet';\n\n return Math.sqrt(x * x + y * y + z * z);\n}\nfunction transposeMatrix(matrix) {\n 'worklet';\n\n const m = flatten(matrix);\n return [[m[0], m[4], m[8], m[12]], [m[1], m[5], m[9], m[13]], [m[2], m[6], m[10], m[14]], [m[3], m[7], m[11], m[15]]];\n}\nfunction assertVectorsHaveEqualLengths(a, b) {\n 'worklet';\n\n if (__DEV__ && a.length !== b.length) {\n throw new Error(`[Reanimated] Cannot calculate inner product of two vectors of different lengths. Length of ${a.toString()} is ${a.length} and length of ${b.toString()} is ${b.length}.`);\n }\n}\nfunction innerProduct(a, b) {\n 'worklet';\n\n assertVectorsHaveEqualLengths(a, b);\n return a.reduce((acc, _, i) => acc + a[i] * b[i], 0);\n}\nfunction projection(u, a) {\n 'worklet';\n\n assertVectorsHaveEqualLengths(u, a);\n const s = innerProduct(u, a) / innerProduct(u, u);\n return u.map(e => e * s);\n}\nfunction subtractVectors(a, b) {\n 'worklet';\n\n assertVectorsHaveEqualLengths(a, b);\n return a.map((_, i) => a[i] - b[i]);\n}\nfunction scaleVector(u, a) {\n 'worklet';\n\n return u.map(e => e * a);\n}\nfunction gramSchmidtAlgorithm(matrix) {\n // Gram-Schmidt orthogonalization decomposes any matrix with non-zero determinant into an orthogonal and a triangular matrix\n // These matrices are equal to rotation and skew matrices respectively, because we apply it to transformation matrix\n // That is expected to already have extracted the remaining transforms (scale & translation)\n 'worklet';\n\n const [a0, a1, a2, a3] = matrix;\n const u0 = a0;\n const u1 = subtractVectors(a1, projection(u0, a1));\n const u2 = subtractVectors(subtractVectors(a2, projection(u0, a2)), projection(u1, a2));\n const u3 = subtractVectors(subtractVectors(subtractVectors(a3, projection(u0, a3)), projection(u1, a3)), projection(u2, a3));\n const [e0, e1, e2, e3] = [u0, u1, u2, u3].map(u => scaleVector(u, 1 / Math.sqrt(innerProduct(u, u))));\n const rotationMatrix = [[e0[0], e1[0], e2[0], e3[0]], [e0[1], e1[1], e2[1], e3[1]], [e0[2], e1[2], e2[2], e3[2]], [e0[3], e1[3], e2[3], e3[3]]];\n const skewMatrix = [[innerProduct(e0, a0), innerProduct(e0, a1), innerProduct(e0, a2), innerProduct(e0, a3)], [0, innerProduct(e1, a1), innerProduct(e1, a2), innerProduct(e1, a3)], [0, 0, innerProduct(e2, a2), innerProduct(e2, a3)], [0, 0, 0, innerProduct(e3, a3)]];\n return {\n rotationMatrix: transposeMatrix(rotationMatrix),\n skewMatrix: transposeMatrix(skewMatrix)\n };\n}\n\n// ts-prune-ignore-next This function is exported to be tested\nexport function decomposeMatrix(unknownTypeMatrix) {\n 'worklet';\n\n const matrix = maybeFlattenMatrix(unknownTypeMatrix);\n\n // normalize matrix\n if (matrix[15] === 0) {\n throw new Error('[Reanimated] Invalid transform matrix.');\n }\n matrix.forEach((_, i) => matrix[i] /= matrix[15]);\n const translationMatrix = [[1, 0, 0, 0], [0, 1, 0, 0], [0, 0, 1, 0], [matrix[12], matrix[13], matrix[14], 1]];\n const sx = matrix[15] * norm3d(matrix[0], matrix[4], matrix[8]);\n const sy = matrix[15] * norm3d(matrix[1], matrix[5], matrix[9]);\n const sz = matrix[15] * norm3d(matrix[2], matrix[6], matrix[10]);\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const scaleMatrix = [[sx, 0, 0, 0], [0, sy, 0, 0], [0, 0, sz, 0], [0, 0, 0, 1]];\n const rotationAndSkewMatrix = [[matrix[0] / sx, matrix[1] / sx, matrix[2] / sx, 0], [matrix[4] / sy, matrix[5] / sy, matrix[6] / sy, 0], [matrix[8] / sz, matrix[9] / sz, matrix[10] / sz, 0], [0, 0, 0, 1]];\n const {\n rotationMatrix,\n skewMatrix\n } = gramSchmidtAlgorithm(rotationAndSkewMatrix);\n return {\n translationMatrix,\n scaleMatrix,\n rotationMatrix,\n skewMatrix\n };\n}\nexport function decomposeMatrixIntoMatricesAndAngles(matrix) {\n 'worklet';\n\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {\n scaleMatrix,\n rotationMatrix,\n translationMatrix,\n skewMatrix\n } = decomposeMatrix(matrix);\n const sinRy = -rotationMatrix[0][2];\n const ry = Math.asin(sinRy);\n let rx;\n let rz;\n if (sinRy === 1 || sinRy === -1) {\n rz = 0;\n rx = Math.atan2(sinRy * rotationMatrix[0][1], sinRy * rotationMatrix[0][2]);\n } else {\n rz = Math.atan2(rotationMatrix[0][1], rotationMatrix[0][0]);\n rx = Math.atan2(rotationMatrix[1][2], rotationMatrix[2][2]);\n }\n return {\n scaleMatrix,\n rotationMatrix,\n translationMatrix,\n skewMatrix,\n rx: rx || 0,\n ry: ry || 0,\n rz: rz || 0\n };\n}\n//# sourceMappingURL=matrixUtils.js.map","'use strict';\n\nimport { Easing } from '../Easing';\nimport { assertEasingIsWorklet, defineAnimation, getReduceMotionForAnimation } from './util';\n\n/**\n * The timing animation configuration.\n *\n * @param duration - Length of the animation (in milliseconds). Defaults to 300.\n * @param easing - An easing function which defines the animation curve. Defaults to `Easing.inOut(Easing.quad)`.\n * @param reduceMotion - Determines how the animation responds to the device's reduced motion accessibility setting. Default to `ReduceMotion.System` - {@link ReduceMotion}.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withTiming#config-\n */\n\n// TODO TYPESCRIPT This is temporary type put in here to get rid of our .d.ts file\n\n/**\n * Lets you create an animation based on duration and easing.\n *\n * @param toValue - The value on which the animation will come at rest - {@link AnimatableValue}.\n * @param config - The timing animation configuration - {@link TimingConfig}.\n * @param callback - A function called on animation complete - {@link AnimationCallback}.\n * @returns An [animation object](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animation-object) which holds the current state of the animation.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withTiming\n */\nexport const withTiming = function (toValue, userConfig, callback) {\n 'worklet';\n\n if (__DEV__ && userConfig !== null && userConfig !== void 0 && userConfig.easing) {\n assertEasingIsWorklet(userConfig.easing);\n }\n return defineAnimation(toValue, () => {\n 'worklet';\n\n const config = {\n duration: 300,\n easing: Easing.inOut(Easing.quad)\n };\n if (userConfig) {\n Object.keys(userConfig).forEach(key => config[key] = userConfig[key]);\n }\n function timing(animation, now) {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {\n toValue,\n startTime,\n startValue\n } = animation;\n const runtime = now - startTime;\n if (runtime >= config.duration) {\n // reset startTime to avoid reusing finished animation config in `start` method\n animation.startTime = 0;\n animation.current = toValue;\n return true;\n }\n const progress = animation.easing(runtime / config.duration);\n animation.current = startValue + (toValue - startValue) * progress;\n return false;\n }\n function onStart(animation, value, now, previousAnimation) {\n if (previousAnimation && previousAnimation.type === 'timing' && previousAnimation.toValue === toValue && previousAnimation.startTime) {\n // to maintain continuity of timing animations we check if we are starting\n // new timing over the old one with the same parameters. If so, we want\n // to copy animation timeline properties\n animation.startTime = previousAnimation.startTime;\n animation.startValue = previousAnimation.startValue;\n } else {\n animation.startTime = now;\n animation.startValue = value;\n }\n animation.current = value;\n if (typeof config.easing === 'object') {\n animation.easing = config.easing.factory();\n } else {\n animation.easing = config.easing;\n }\n }\n return {\n type: 'timing',\n onFrame: timing,\n onStart: onStart,\n progress: 0,\n toValue,\n startValue: 0,\n startTime: 0,\n easing: () => 0,\n current: toValue,\n callback,\n reduceMotion: getReduceMotionForAnimation(userConfig === null || userConfig === void 0 ? void 0 : userConfig.reduceMotion)\n };\n });\n};\n//# sourceMappingURL=timing.js.map","'use strict';\n\nimport { Bezier } from './Bezier';\n\n/**\n * The `Easing` module implements common easing functions. This module is used\n * by [Animate.timing()](docs/animate.html#timing) to convey physically\n * believable motion in animations.\n *\n * You can find a visualization of some common easing functions at\n * http://easings.net/\n *\n * ### Predefined animations\n *\n * The `Easing` module provides several predefined animations through the\n * following methods:\n *\n * - [`back`](docs/easing.html#back) provides a simple animation where the\n * object goes slightly back before moving forward\n * - [`bounce`](docs/easing.html#bounce) provides a bouncing animation\n * - [`ease`](docs/easing.html#ease) provides a simple inertial animation\n * - [`elastic`](docs/easing.html#elastic) provides a simple spring interaction\n *\n * ### Standard functions\n *\n * Three standard easing functions are provided:\n *\n * - [`linear`](docs/easing.html#linear)\n * - [`quad`](docs/easing.html#quad)\n * - [`cubic`](docs/easing.html#cubic)\n *\n * The [`poly`](docs/easing.html#poly) function can be used to implement\n * quartic, quintic, and other higher power functions.\n *\n * ### Additional functions\n *\n * Additional mathematical functions are provided by the following methods:\n *\n * - [`bezier`](docs/easing.html#bezier) provides a cubic bezier curve\n * - [`circle`](docs/easing.html#circle) provides a circular function\n * - [`sin`](docs/easing.html#sin) provides a sinusoidal function\n * - [`exp`](docs/easing.html#exp) provides an exponential function\n *\n * The following helpers are used to modify other easing functions.\n *\n * - [`in`](docs/easing.html#in) runs an easing function forwards\n * - [`inOut`](docs/easing.html#inout) makes any easing function symmetrical\n * - [`out`](docs/easing.html#out) runs an easing function backwards\n */\n\n/**\n * @deprecated Please use {@link EasingFunction} type instead.\n */\n\n/**\n * @deprecated Please use {@link EasingFunctionFactory} type instead.\n */\n\n/**\n * A linear function, `f(t) = t`. Position correlates to elapsed time one to\n * one.\n *\n * http://cubic-bezier.com/#0,0,1,1\n */\nfunction linear(t) {\n 'worklet';\n\n return t;\n}\n\n/**\n * A simple inertial interaction, similar to an object slowly accelerating to\n * speed.\n *\n * http://cubic-bezier.com/#.42,0,1,1\n */\nfunction ease(t) {\n 'worklet';\n\n return Bezier(0.42, 0, 1, 1)(t);\n}\n\n/**\n * A quadratic function, `f(t) = t * t`. Position equals the square of elapsed\n * time.\n *\n * http://easings.net/#easeInQuad\n */\nfunction quad(t) {\n 'worklet';\n\n return t * t;\n}\n\n/**\n * A cubic function, `f(t) = t * t * t`. Position equals the cube of elapsed\n * time.\n *\n * http://easings.net/#easeInCubic\n */\nfunction cubic(t) {\n 'worklet';\n\n return t * t * t;\n}\n\n/**\n * A power function. Position is equal to the Nth power of elapsed time.\n *\n * n = 4: http://easings.net/#easeInQuart\n * n = 5: http://easings.net/#easeInQuint\n */\nfunction poly(n) {\n 'worklet';\n\n return t => {\n 'worklet';\n\n return Math.pow(t, n);\n };\n}\n\n/**\n * A sinusoidal function.\n *\n * http://easings.net/#easeInSine\n */\nfunction sin(t) {\n 'worklet';\n\n return 1 - Math.cos(t * Math.PI / 2);\n}\n\n/**\n * A circular function.\n *\n * http://easings.net/#easeInCirc\n */\nfunction circle(t) {\n 'worklet';\n\n return 1 - Math.sqrt(1 - t * t);\n}\n\n/**\n * An exponential function.\n *\n * http://easings.net/#easeInExpo\n */\nfunction exp(t) {\n 'worklet';\n\n return Math.pow(2, 10 * (t - 1));\n}\n\n/**\n * A simple elastic interaction, similar to a spring oscillating back and\n * forth.\n *\n * Default bounciness is 1, which overshoots a little bit once. 0 bounciness\n * doesn't overshoot at all, and bounciness of N \\> 1 will overshoot about N\n * times.\n *\n * http://easings.net/#easeInElastic\n */\nfunction elastic(bounciness = 1) {\n 'worklet';\n\n const p = bounciness * Math.PI;\n return t => {\n 'worklet';\n\n return 1 - Math.pow(Math.cos(t * Math.PI / 2), 3) * Math.cos(t * p);\n };\n}\n\n/**\n * Use with `Animated.parallel()` to create a simple effect where the object\n * animates back slightly as the animation starts.\n *\n * Wolfram Plot:\n *\n * - http://tiny.cc/back_default (s = 1.70158, default)\n */\nfunction back(s = 1.70158) {\n 'worklet';\n\n return t => {\n 'worklet';\n\n return t * t * ((s + 1) * t - s);\n };\n}\n\n/**\n * Provides a simple bouncing effect.\n *\n * http://easings.net/#easeInBounce\n */\nfunction bounce(t) {\n 'worklet';\n\n if (t < 1 / 2.75) {\n return 7.5625 * t * t;\n }\n if (t < 2 / 2.75) {\n const t2 = t - 1.5 / 2.75;\n return 7.5625 * t2 * t2 + 0.75;\n }\n if (t < 2.5 / 2.75) {\n const t2 = t - 2.25 / 2.75;\n return 7.5625 * t2 * t2 + 0.9375;\n }\n const t2 = t - 2.625 / 2.75;\n return 7.5625 * t2 * t2 + 0.984375;\n}\n\n/**\n * Provides a cubic bezier curve, equivalent to CSS Transitions'\n * `transition-timing-function`.\n *\n * A useful tool to visualize cubic bezier curves can be found at\n * http://cubic-bezier.com/\n */\nfunction bezier(x1, y1, x2, y2) {\n 'worklet';\n\n return {\n factory: () => {\n 'worklet';\n\n return Bezier(x1, y1, x2, y2);\n }\n };\n}\nfunction bezierFn(x1, y1, x2, y2) {\n 'worklet';\n\n return Bezier(x1, y1, x2, y2);\n}\n\n/**\n * Runs an easing function forwards.\n */\nfunction in_(easing) {\n 'worklet';\n\n return easing;\n}\n\n/**\n * Runs an easing function backwards.\n */\nfunction out(easing) {\n 'worklet';\n\n return t => {\n 'worklet';\n\n return 1 - easing(1 - t);\n };\n}\n\n/**\n * Makes any easing function symmetrical. The easing function will run\n * forwards for half of the duration, then backwards for the rest of the\n * duration.\n */\nfunction inOut(easing) {\n 'worklet';\n\n return t => {\n 'worklet';\n\n if (t < 0.5) {\n return easing(t * 2) / 2;\n }\n return 1 - easing((1 - t) * 2) / 2;\n };\n}\n\n/**\n * The `steps` easing function jumps between discrete values at regular intervals,\n * creating a stepped animation effect. The `n` parameter determines the number of\n * steps in the animation, and the `roundToNextStep` parameter determines whether the animation\n * should start at the beginning or end of each step.\n */\nfunction steps(n = 10, roundToNextStep = true) {\n 'worklet';\n\n return t => {\n 'worklet';\n\n const value = Math.min(Math.max(t, 0), 1) * n;\n if (roundToNextStep) {\n return Math.ceil(value) / n;\n }\n return Math.floor(value) / n;\n };\n}\nconst EasingObject = {\n linear,\n ease,\n quad,\n cubic,\n poly,\n sin,\n circle,\n exp,\n elastic,\n back,\n bounce,\n bezier,\n bezierFn,\n steps,\n in: in_,\n out,\n inOut\n};\nexport const Easing = EasingObject;\n//# sourceMappingURL=Easing.js.map","'use strict';\n\n/**\n * https://github.com/gre/bezier-easing\n * BezierEasing - use bezier curve for transition easing function\n * by Gaëtan Renaudeau 2014 - 2015 – MIT License\n */\n\n// These values are established by empiricism with tests (tradeoff: performance VS precision)\nconst NEWTON_ITERATIONS = 4;\nconst NEWTON_MIN_SLOPE = 0.001;\nconst SUBDIVISION_PRECISION = 0.0000001;\nconst SUBDIVISION_MAX_ITERATIONS = 10;\nconst kSplineTableSize = 11;\nconst kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\nfunction A(aA1, aA2) {\n 'worklet';\n\n return 1.0 - 3.0 * aA2 + 3.0 * aA1;\n}\nfunction B(aA1, aA2) {\n 'worklet';\n\n return 3.0 * aA2 - 6.0 * aA1;\n}\nfunction C(aA1) {\n 'worklet';\n\n return 3.0 * aA1;\n}\n\n// Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.\nfunction calcBezier(aT, aA1, aA2) {\n 'worklet';\n\n return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT;\n}\n\n// Returns dx/dt given t, x1, and x2, or dy/dt given t, y1, and y2.\nfunction getSlope(aT, aA1, aA2) {\n 'worklet';\n\n return 3.0 * A(aA1, aA2) * aT * aT + 2.0 * B(aA1, aA2) * aT + C(aA1);\n}\nfunction binarySubdivide(aX, aA, aB, mX1, mX2) {\n 'worklet';\n\n let currentX;\n let currentT;\n let i = 0;\n do {\n currentT = aA + (aB - aA) / 2.0;\n currentX = calcBezier(currentT, mX1, mX2) - aX;\n if (currentX > 0.0) {\n aB = currentT;\n } else {\n aA = currentT;\n }\n } while (Math.abs(currentX) > SUBDIVISION_PRECISION && ++i < SUBDIVISION_MAX_ITERATIONS);\n return currentT;\n}\nfunction newtonRaphsonIterate(aX, aGuessT, mX1, mX2) {\n 'worklet';\n\n for (let i = 0; i < NEWTON_ITERATIONS; ++i) {\n const currentSlope = getSlope(aGuessT, mX1, mX2);\n if (currentSlope === 0.0) {\n return aGuessT;\n }\n const currentX = calcBezier(aGuessT, mX1, mX2) - aX;\n aGuessT -= currentX / currentSlope;\n }\n return aGuessT;\n}\nexport function Bezier(mX1, mY1, mX2, mY2) {\n 'worklet';\n\n function LinearEasing(x) {\n 'worklet';\n\n return x;\n }\n if (!(mX1 >= 0 && mX1 <= 1 && mX2 >= 0 && mX2 <= 1)) {\n throw new Error('[Reanimated] Bezier x values must be in [0, 1] range.');\n }\n if (mX1 === mY1 && mX2 === mY2) {\n return LinearEasing;\n }\n\n // FIXME: Float32Array is not available in Hermes right now\n //\n // var float32ArraySupported = typeof Float32Array === 'function';\n // const sampleValues = float32ArraySupported\n // ? new Float32Array(kSplineTableSize)\n // : new Array(kSplineTableSize);\n\n // Precompute samples table\n const sampleValues = new Array(kSplineTableSize);\n for (let i = 0; i < kSplineTableSize; ++i) {\n sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n }\n function getTForX(aX) {\n 'worklet';\n\n let intervalStart = 0.0;\n let currentSample = 1;\n const lastSample = kSplineTableSize - 1;\n for (; currentSample !== lastSample && sampleValues[currentSample] <= aX; ++currentSample) {\n intervalStart += kSampleStepSize;\n }\n --currentSample;\n\n // Interpolate to provide an initial guess for t\n const dist = (aX - sampleValues[currentSample]) / (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n const guessForT = intervalStart + dist * kSampleStepSize;\n const initialSlope = getSlope(guessForT, mX1, mX2);\n if (initialSlope >= NEWTON_MIN_SLOPE) {\n return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n } else if (initialSlope === 0.0) {\n return guessForT;\n } else {\n return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2);\n }\n }\n return function BezierEasing(x) {\n 'worklet';\n\n if (mX1 === mY1 && mX2 === mY2) {\n return x; // linear\n }\n // Because JavaScript number are imprecise, we should guarantee the extremes are right.\n if (x === 0) {\n return 0;\n }\n if (x === 1) {\n return 1;\n }\n return calcBezier(getTForX(x), mY1, mY2);\n };\n}\n//# sourceMappingURL=Bezier.js.map","'use strict';\n\nimport { defineAnimation, getReduceMotionForAnimation } from './util';\nimport { initialCalculations, calculateNewMassToMatchDuration, underDampedSpringCalculations, criticallyDampedSpringCalculations, isAnimationTerminatingCalculation, scaleZetaToMatchClamps, checkIfConfigIsValid } from './springUtils';\n\n// TODO TYPESCRIPT This is a temporary type to get rid of .d.ts file.\n\n/**\n * Lets you create spring-based animations.\n *\n * @param toValue - the value at which the animation will come to rest - {@link AnimatableValue}\n * @param config - the spring animation configuration - {@link SpringConfig}\n * @param callback - a function called on animation complete - {@link AnimationCallback}\n * @returns an [animation object](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animation-object) which holds the current state of the animation\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withSpring\n */\nexport const withSpring = (toValue, userConfig, callback) => {\n 'worklet';\n\n return defineAnimation(toValue, () => {\n 'worklet';\n\n const defaultConfig = {\n damping: 10,\n mass: 1,\n stiffness: 100,\n overshootClamping: false,\n restDisplacementThreshold: 0.01,\n restSpeedThreshold: 2,\n velocity: 0,\n duration: 2000,\n dampingRatio: 0.5,\n reduceMotion: undefined,\n clamp: undefined\n };\n const config = {\n ...defaultConfig,\n ...userConfig,\n useDuration: !!(userConfig !== null && userConfig !== void 0 && userConfig.duration || userConfig !== null && userConfig !== void 0 && userConfig.dampingRatio),\n skipAnimation: false\n };\n config.skipAnimation = !checkIfConfigIsValid(config);\n if (config.duration === 0) {\n config.skipAnimation = true;\n }\n function springOnFrame(animation, now) {\n // eslint-disable-next-line @typescript-eslint/no-shadow\n const {\n toValue,\n startTimestamp,\n current\n } = animation;\n const timeFromStart = now - startTimestamp;\n if (config.useDuration && timeFromStart >= config.duration) {\n animation.current = toValue;\n // clear lastTimestamp to avoid using stale value by the next spring animation that starts after this one\n animation.lastTimestamp = 0;\n return true;\n }\n if (config.skipAnimation) {\n animation.current = toValue;\n animation.lastTimestamp = 0;\n return true;\n }\n const {\n lastTimestamp,\n velocity\n } = animation;\n const deltaTime = Math.min(now - lastTimestamp, 64);\n animation.lastTimestamp = now;\n const t = deltaTime / 1000;\n const v0 = -velocity;\n const x0 = toValue - current;\n const {\n zeta,\n omega0,\n omega1\n } = animation;\n const {\n position: newPosition,\n velocity: newVelocity\n } = zeta < 1 ? underDampedSpringCalculations(animation, {\n zeta,\n v0,\n x0,\n omega0,\n omega1,\n t\n }) : criticallyDampedSpringCalculations(animation, {\n v0,\n x0,\n omega0,\n t\n });\n animation.current = newPosition;\n animation.velocity = newVelocity;\n const {\n isOvershooting,\n isVelocity,\n isDisplacement\n } = isAnimationTerminatingCalculation(animation, config);\n const springIsNotInMove = isOvershooting || isVelocity && isDisplacement;\n if (!config.useDuration && springIsNotInMove) {\n animation.velocity = 0;\n animation.current = toValue;\n // clear lastTimestamp to avoid using stale value by the next spring animation that starts after this one\n animation.lastTimestamp = 0;\n return true;\n }\n return false;\n }\n function isTriggeredTwice(previousAnimation, animation) {\n return (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.lastTimestamp) && (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.startTimestamp) && (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.toValue) === animation.toValue && (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.duration) === animation.duration && (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.dampingRatio) === animation.dampingRatio;\n }\n function onStart(animation, value, now, previousAnimation) {\n animation.current = value;\n animation.startValue = value;\n let mass = config.mass;\n const triggeredTwice = isTriggeredTwice(previousAnimation, animation);\n const duration = config.duration;\n const x0 = triggeredTwice ? // If animation is triggered twice we want to continue the previous animation\n // form the previous starting point\n previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.startValue : Number(animation.toValue) - value;\n if (previousAnimation) {\n animation.velocity = (triggeredTwice ? previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.velocity : (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.velocity) + config.velocity) || 0;\n } else {\n animation.velocity = config.velocity || 0;\n }\n if (triggeredTwice) {\n animation.zeta = (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.zeta) || 0;\n animation.omega0 = (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.omega0) || 0;\n animation.omega1 = (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.omega1) || 0;\n } else {\n if (config.useDuration) {\n const actualDuration = triggeredTwice ?\n // If animation is triggered twice we want to continue the previous animation\n // so we need to include the time that already elapsed\n duration - (((previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.lastTimestamp) || 0) - ((previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.startTimestamp) || 0)) : duration;\n config.duration = actualDuration;\n mass = calculateNewMassToMatchDuration(x0, config, animation.velocity);\n }\n const {\n zeta,\n omega0,\n omega1\n } = initialCalculations(mass, config);\n animation.zeta = zeta;\n animation.omega0 = omega0;\n animation.omega1 = omega1;\n if (config.clamp !== undefined) {\n animation.zeta = scaleZetaToMatchClamps(animation, config.clamp);\n }\n }\n animation.lastTimestamp = (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.lastTimestamp) || now;\n animation.startTimestamp = triggeredTwice ? (previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.startTimestamp) || now : now;\n }\n return {\n onFrame: springOnFrame,\n onStart,\n toValue,\n velocity: config.velocity || 0,\n current: toValue,\n startValue: 0,\n callback,\n lastTimestamp: 0,\n startTimestamp: 0,\n zeta: 0,\n omega0: 0,\n omega1: 0,\n reduceMotion: getReduceMotionForAnimation(config.reduceMotion)\n };\n });\n};\n//# sourceMappingURL=spring.js.map","'use strict';\n\n/**\n * Spring animation configuration.\n *\n * @param mass - The weight of the spring. Reducing this value makes the animation faster. Defaults to 1.\n * @param damping - How quickly a spring slows down. Higher damping means the spring will come to rest faster. Defaults to 10.\n * @param duration - Length of the animation (in milliseconds). Defaults to 2000.\n * @param dampingRatio - How damped the spring is. Value 1 means the spring is critically damped, and value \\>1 means the spring is overdamped. Defaults to 0.5.\n * @param stiffness - How bouncy the spring is. Defaults to 100.\n * @param velocity - Initial velocity applied to the spring equation. Defaults to 0.\n * @param overshootClamping - Whether a spring can bounce over the `toValue`. Defaults to false.\n * @param restDisplacementThreshold - The displacement below which the spring will snap to toValue without further oscillations. Defaults to 0.01.\n * @param restSpeedThreshold - The speed in pixels per second from which the spring will snap to toValue without further oscillations. Defaults to 2.\n * @param reduceMotion - Determines how the animation responds to the device's reduced motion accessibility setting. Default to `ReduceMotion.System` - {@link ReduceMotion}.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withSpring/#config-\n */\n\n// This type contains all the properties from SpringConfig, which are changed to be required,\n// except for optional 'reduceMotion' and 'clamp'\n\nexport function checkIfConfigIsValid(config) {\n 'worklet';\n\n var _config$clamp, _config$clamp2;\n let errorMessage = '';\n ['stiffness', 'damping', 'dampingRatio', 'restDisplacementThreshold', 'restSpeedThreshold', 'mass'].forEach(prop => {\n const value = config[prop];\n if (value <= 0) {\n errorMessage += `, ${prop} must be grater than zero but got ${value}`;\n }\n });\n if (config.duration < 0) {\n errorMessage += `, duration can't be negative, got ${config.duration}`;\n }\n if ((_config$clamp = config.clamp) !== null && _config$clamp !== void 0 && _config$clamp.min && (_config$clamp2 = config.clamp) !== null && _config$clamp2 !== void 0 && _config$clamp2.max && config.clamp.min > config.clamp.max) {\n errorMessage += `, clamp.min should be lower than clamp.max, got clamp: {min: ${config.clamp.min}, max: ${config.clamp.max}} `;\n }\n if (errorMessage !== '') {\n console.warn('[Reanimated] Invalid spring config' + errorMessage);\n }\n return errorMessage === '';\n}\n\n// ts-prune-ignore-next This function is exported to be tested\nexport function bisectRoot({\n min,\n max,\n func,\n maxIterations = 20\n}) {\n 'worklet';\n\n const ACCURACY = 0.00005;\n let idx = maxIterations;\n let current = (max + min) / 2;\n while (Math.abs(func(current)) > ACCURACY && idx > 0) {\n idx -= 1;\n if (func(current) < 0) {\n min = current;\n } else {\n max = current;\n }\n current = (min + max) / 2;\n }\n return current;\n}\nexport function initialCalculations(mass = 0, config) {\n 'worklet';\n\n if (config.skipAnimation) {\n return {\n zeta: 0,\n omega0: 0,\n omega1: 0\n };\n }\n if (config.useDuration) {\n const {\n stiffness: k,\n dampingRatio: zeta\n } = config;\n\n /** omega0 and omega1 denote angular frequency and natural angular frequency, see this link for formulas:\n * https://courses.lumenlearning.com/suny-osuniversityphysics/chapter/15-5-damped-oscillations/\n */\n const omega0 = Math.sqrt(k / mass);\n const omega1 = omega0 * Math.sqrt(1 - zeta ** 2);\n return {\n zeta,\n omega0,\n omega1\n };\n } else {\n const {\n damping: c,\n mass: m,\n stiffness: k\n } = config;\n const zeta = c / (2 * Math.sqrt(k * m)); // damping ratio\n const omega0 = Math.sqrt(k / m); // undamped angular frequency of the oscillator (rad/ms)\n const omega1 = omega0 * Math.sqrt(1 - zeta ** 2); // exponential decay\n\n return {\n zeta,\n omega0,\n omega1\n };\n }\n}\n\n/** We make an assumption that we can manipulate zeta without changing duration of movement.\n * According to theory this change is small and tests shows that we can indeed ignore it.\n */\nexport function scaleZetaToMatchClamps(animation, clamp) {\n 'worklet';\n\n const {\n zeta,\n toValue,\n startValue\n } = animation;\n const toValueNum = Number(toValue);\n if (toValueNum === startValue) {\n return zeta;\n }\n const [firstBound, secondBound] = toValueNum - startValue > 0 ? [clamp.min, clamp.max] : [clamp.max, clamp.min];\n\n /** The extrema we get from equation below are relative (we obtain a ratio),\n * To get absolute extrema we convert it as follows:\n *\n * AbsoluteExtremum = startValue ± RelativeExtremum * (toValue - startValue)\n * Where ± denotes:\n * + if extremum is over the target\n * - otherwise\n */\n\n const relativeExtremum1 = secondBound !== undefined ? Math.abs((secondBound - toValueNum) / (toValueNum - startValue)) : undefined;\n const relativeExtremum2 = firstBound !== undefined ? Math.abs((firstBound - toValueNum) / (toValueNum - startValue)) : undefined;\n\n /** Use this formula http://hyperphysics.phy-astr.gsu.edu/hbase/oscda.html to calculate\n * first two extrema. These extrema are located where cos = +- 1\n *\n * Therefore the first two extrema are:\n *\n * Math.exp(-zeta * Math.PI); (over the target)\n * Math.exp(-zeta * 2 * Math.PI); (before the target)\n */\n\n const newZeta1 = relativeExtremum1 !== undefined ? Math.abs(Math.log(relativeExtremum1) / Math.PI) : undefined;\n const newZeta2 = relativeExtremum2 !== undefined ? Math.abs(Math.log(relativeExtremum2) / (2 * Math.PI)) : undefined;\n const zetaSatisfyingClamp = [newZeta1, newZeta2].filter(x => x !== undefined);\n // The bigger is zeta the smaller are bounces, we return the biggest one\n // because it should satisfy all conditions\n return Math.max(...zetaSatisfyingClamp, zeta);\n}\n\n/** Runs before initial */\nexport function calculateNewMassToMatchDuration(x0, config, v0) {\n 'worklet';\n\n if (config.skipAnimation) {\n return 0;\n }\n\n /** Use this formula: https://phys.libretexts.org/Bookshelves/University_Physics/Book%3A_University_Physics_(OpenStax)/Book%3A_University_Physics_I_-_Mechanics_Sound_Oscillations_and_Waves_(OpenStax)/15%3A_Oscillations/15.06%3A_Damped_Oscillations\n * to find the asymptote and estimate the damping that gives us the expected duration \n ⎛ ⎛ c⎞ ⎞ \n ⎜-⎜──⎟ ⋅ duration⎟ \n ⎝ ⎝2m⎠ ⎠ \n A ⋅ e = threshold\n \n Amplitude calculated using \"Conservation of energy\"\n _________________\n ╱ 2 2\n ╱ m ⋅ v0 + k ⋅ x0 \n amplitude = ╱ ─────────────────\n ╲╱ k \n And replace mass with damping ratio which is provided: m = (c^2)/(4 * k * zeta^2) \n */\n const {\n stiffness: k,\n dampingRatio: zeta,\n restSpeedThreshold: threshold,\n duration\n } = config;\n const durationForMass = mass => {\n 'worklet';\n\n const amplitude = (mass * v0 * v0 + k * x0 * x0) / (Math.exp(1 - 0.5 * zeta) * k);\n const c = zeta * 2 * Math.sqrt(k * mass);\n return 1000 * (-2 * mass / c) * Math.log(threshold * 0.01 / amplitude) - duration;\n };\n\n // Bisection turns out to be much faster than Newton's method in our case\n return bisectRoot({\n min: 0,\n max: 100,\n func: durationForMass\n });\n}\nexport function criticallyDampedSpringCalculations(animation, precalculatedValues) {\n 'worklet';\n\n const {\n toValue\n } = animation;\n const {\n v0,\n x0,\n omega0,\n t\n } = precalculatedValues;\n const criticallyDampedEnvelope = Math.exp(-omega0 * t);\n const criticallyDampedPosition = toValue - criticallyDampedEnvelope * (x0 + (v0 + omega0 * x0) * t);\n const criticallyDampedVelocity = criticallyDampedEnvelope * (v0 * (t * omega0 - 1) + t * x0 * omega0 * omega0);\n return {\n position: criticallyDampedPosition,\n velocity: criticallyDampedVelocity\n };\n}\nexport function underDampedSpringCalculations(animation, precalculatedValues) {\n 'worklet';\n\n const {\n toValue,\n current,\n velocity\n } = animation;\n const {\n zeta,\n t,\n omega0,\n omega1\n } = precalculatedValues;\n const v0 = -velocity;\n const x0 = toValue - current;\n const sin1 = Math.sin(omega1 * t);\n const cos1 = Math.cos(omega1 * t);\n\n // under damped\n const underDampedEnvelope = Math.exp(-zeta * omega0 * t);\n const underDampedFrag1 = underDampedEnvelope * (sin1 * ((v0 + zeta * omega0 * x0) / omega1) + x0 * cos1);\n const underDampedPosition = toValue - underDampedFrag1;\n // This looks crazy -- it's actually just the derivative of the oscillation function\n const underDampedVelocity = zeta * omega0 * underDampedFrag1 - underDampedEnvelope * (cos1 * (v0 + zeta * omega0 * x0) - omega1 * x0 * sin1);\n return {\n position: underDampedPosition,\n velocity: underDampedVelocity\n };\n}\nexport function isAnimationTerminatingCalculation(animation, config) {\n 'worklet';\n\n const {\n toValue,\n velocity,\n startValue,\n current\n } = animation;\n const isOvershooting = config.overshootClamping ? current > toValue && startValue < toValue || current < toValue && startValue > toValue : false;\n const isVelocity = Math.abs(velocity) < config.restSpeedThreshold;\n const isDisplacement = Math.abs(toValue - current) < config.restDisplacementThreshold;\n return {\n isOvershooting,\n isVelocity,\n isDisplacement\n };\n}\n//# sourceMappingURL=springUtils.js.map","'use strict';\n\nexport { withDecay } from './decay';\n//# sourceMappingURL=index.js.map","'use strict';\n\nimport { defineAnimation, getReduceMotionForAnimation } from '../util';\nimport { rubberBandDecay } from './rubberBandDecay';\nimport { isValidRubberBandConfig } from './utils';\nimport { rigidDecay } from './rigidDecay';\n\n// TODO TYPESCRIPT This is a temporary type to get rid of .d.ts file.\n\nfunction validateConfig(config) {\n 'worklet';\n\n if (config.clamp) {\n if (!Array.isArray(config.clamp)) {\n throw new Error(`[Reanimated] \\`config.clamp\\` must be an array but is ${typeof config.clamp}.`);\n }\n if (config.clamp.length !== 2) {\n throw new Error(`[Reanimated] \\`clamp array\\` must contain 2 items but is given ${config.clamp.length}.`);\n }\n }\n if (config.velocityFactor <= 0) {\n throw new Error(`[Reanimated] \\`config.velocityFactor\\` must be greather then 0 but is ${config.velocityFactor}.`);\n }\n if (config.rubberBandEffect && !config.clamp) {\n throw new Error('[Reanimated] You need to set `clamp` property when using `rubberBandEffect`.');\n }\n}\n\n/**\n * Lets you create animations that mimic objects in motion with friction.\n *\n * @param config - The decay animation configuration - {@link DecayConfig}.\n * @param callback - A function called upon animation completion - {@link AnimationCallback}.\n * @returns An [animation object](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animation-object) which holds the current state of the animation.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withDecay\n */\nexport const withDecay = function (userConfig, callback) {\n 'worklet';\n\n return defineAnimation(0, () => {\n 'worklet';\n\n const config = {\n deceleration: 0.998,\n velocityFactor: 1,\n velocity: 0,\n rubberBandFactor: 0.6\n };\n if (userConfig) {\n Object.keys(userConfig).forEach(key => config[key] = userConfig[key]);\n }\n const decay = isValidRubberBandConfig(config) ? (animation, now) => rubberBandDecay(animation, now, config) : (animation, now) => rigidDecay(animation, now, config);\n function onStart(animation, value, now) {\n animation.current = value;\n animation.lastTimestamp = now;\n animation.startTimestamp = now;\n animation.initialVelocity = config.velocity;\n validateConfig(config);\n if (animation.reduceMotion && config.clamp) {\n if (value < config.clamp[0]) {\n animation.current = config.clamp[0];\n } else if (value > config.clamp[1]) {\n animation.current = config.clamp[1];\n }\n }\n }\n return {\n onFrame: decay,\n onStart,\n callback,\n velocity: config.velocity ?? 0,\n initialVelocity: 0,\n current: 0,\n lastTimestamp: 0,\n startTimestamp: 0,\n reduceMotion: getReduceMotionForAnimation(config.reduceMotion)\n };\n });\n};\n//# sourceMappingURL=decay.js.map","'use strict';\n\nimport { SLOPE_FACTOR, VELOCITY_EPS } from './utils';\nconst DERIVATIVE_EPS = 0.1;\nexport function rubberBandDecay(animation, now, config) {\n 'worklet';\n\n const {\n lastTimestamp,\n startTimestamp,\n current,\n velocity\n } = animation;\n const deltaTime = Math.min(now - lastTimestamp, 64);\n const clampIndex = Math.abs(current - config.clamp[0]) < Math.abs(current - config.clamp[1]) ? 0 : 1;\n let derivative = 0;\n if (current < config.clamp[0] || current > config.clamp[1]) {\n derivative = current - config.clamp[clampIndex];\n }\n const v = velocity * Math.exp(-(1 - config.deceleration) * (now - startTimestamp) * SLOPE_FACTOR) - derivative * config.rubberBandFactor;\n if (Math.abs(derivative) > DERIVATIVE_EPS) {\n animation.springActive = true;\n } else if (animation.springActive) {\n animation.current = config.clamp[clampIndex];\n return true;\n } else if (Math.abs(v) < VELOCITY_EPS) {\n return true;\n }\n animation.current = current + v * config.velocityFactor * deltaTime / 1000;\n animation.velocity = v;\n animation.lastTimestamp = now;\n return false;\n}\n//# sourceMappingURL=rubberBandDecay.js.map","'use strict';\n\nimport { isWeb } from '../../PlatformChecker';\nconst IS_WEB = isWeb();\nexport const VELOCITY_EPS = IS_WEB ? 1 / 20 : 1;\nexport const SLOPE_FACTOR = 0.1;\n\n/**\n * The decay animation configuration.\n *\n * @param velocity - Initial velocity of the animation. Defaults to 0.\n * @param deceleration - The rate at which the velocity decreases over time. Defaults to 0.998.\n * @param clamp - Array of two numbers which restricts animation's range. Defaults to [].\n * @param velocityFactor - Velocity multiplier. Defaults to 1.\n * @param rubberBandEffect - Makes the animation bounce over the limit specified in `clamp`. Defaults to `false`.\n * @param rubberBandFactor - Strength of the rubber band effect. Defaults to 0.6.\n * @param reduceMotion - Determines how the animation responds to the device's reduced motion accessibility setting. Default to `ReduceMotion.System` - {@link ReduceMotion}.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withDecay#config\n */\n\n// If user wants to use rubber band decay animation we have to make sure he has provided clamp\n\nexport function isValidRubberBandConfig(config) {\n 'worklet';\n\n return !!config.rubberBandEffect && Array.isArray(config.clamp) && config.clamp.length === 2;\n}\n//# sourceMappingURL=utils.js.map","'use strict';\n\nimport { SLOPE_FACTOR, VELOCITY_EPS } from './utils';\nexport function rigidDecay(animation, now, config) {\n 'worklet';\n\n const {\n lastTimestamp,\n startTimestamp,\n initialVelocity,\n current,\n velocity\n } = animation;\n const deltaTime = Math.min(now - lastTimestamp, 64);\n const v = velocity * Math.exp(-(1 - config.deceleration) * (now - startTimestamp) * SLOPE_FACTOR);\n animation.current = current + v * config.velocityFactor * deltaTime / 1000;\n animation.velocity = v;\n animation.lastTimestamp = now;\n if (config.clamp) {\n if (initialVelocity < 0 && animation.current <= config.clamp[0]) {\n animation.current = config.clamp[0];\n return true;\n } else if (initialVelocity > 0 && animation.current >= config.clamp[1]) {\n animation.current = config.clamp[1];\n return true;\n }\n }\n return Math.abs(v) < VELOCITY_EPS;\n}\n//# sourceMappingURL=rigidDecay.js.map","'use strict';\n\nimport { defineAnimation, getReduceMotionForAnimation, recognizePrefixSuffix } from './util';\nexport const withClamp = function (config, _animationToClamp) {\n 'worklet';\n\n return defineAnimation(_animationToClamp, () => {\n 'worklet';\n\n const animationToClamp = typeof _animationToClamp === 'function' ? _animationToClamp() : _animationToClamp;\n const strippedMin = config.min === undefined ? undefined : recognizePrefixSuffix(config.min).strippedValue;\n const strippedMax = config.max === undefined ? undefined : recognizePrefixSuffix(config.max).strippedValue;\n function clampOnFrame(animation, now) {\n const finished = animationToClamp.onFrame(animationToClamp, now);\n if (animationToClamp.current === undefined) {\n console.warn(\"[Reanimated] Error inside 'withClamp' animation, the inner animation has invalid current value\");\n return true;\n } else {\n const {\n prefix,\n strippedValue,\n suffix\n } = recognizePrefixSuffix(animationToClamp.current);\n let newValue;\n if (strippedMax !== undefined && strippedMax < strippedValue) {\n newValue = strippedMax;\n } else if (strippedMin !== undefined && strippedMin > strippedValue) {\n newValue = strippedMin;\n } else {\n newValue = strippedValue;\n }\n animation.current = typeof animationToClamp.current === 'number' ? newValue : `${prefix === undefined ? '' : prefix}${newValue}${suffix === undefined ? '' : suffix}`;\n }\n return finished;\n }\n function onStart(animation, value, now, previousAnimation) {\n animation.current = value;\n animation.previousAnimation = animationToClamp;\n const animationBeforeClamped = previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.previousAnimation;\n if (config.max !== undefined && config.min !== undefined && config.max < config.min) {\n console.warn('[Reanimated] Wrong config was provided to withClamp. Min value is bigger than max');\n }\n animationToClamp.onStart(animationToClamp,\n /** provide the current value of the previous animation of the clamped animation \n so we can animate from the original \"un-truncated\" value\n */\n (animationBeforeClamped === null || animationBeforeClamped === void 0 ? void 0 : animationBeforeClamped.current) || value, now, animationBeforeClamped);\n }\n const callback = finished => {\n if (animationToClamp.callback) {\n animationToClamp.callback(finished);\n }\n };\n return {\n isHigherOrder: true,\n onFrame: clampOnFrame,\n onStart,\n current: animationToClamp.current,\n callback,\n previousAnimation: null,\n reduceMotion: getReduceMotionForAnimation(config.reduceMotion)\n };\n });\n};\n//# sourceMappingURL=clamp.js.map","'use strict';\n\nimport { defineAnimation, getReduceMotionForAnimation } from './util';\n\n// TODO TYPESCRIPT This is a temporary type to get rid of .d.ts file.\n\n/**\n * An animation modifier that lets you start an animation with a delay.\n *\n * @param delayMs - Duration (in milliseconds) before the animation starts.\n * @param nextAnimation - The animation to delay.\n * @param reduceMotion - Determines how the animation responds to the device's reduced motion accessibility setting. Default to `ReduceMotion.System` - {@link ReduceMotion}.\n * @returns An [animation object](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animation-object) which holds the current state of the animation.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withDelay\n */\nexport const withDelay = function (delayMs, _nextAnimation, reduceMotion) {\n 'worklet';\n\n return defineAnimation(_nextAnimation, () => {\n 'worklet';\n\n const nextAnimation = typeof _nextAnimation === 'function' ? _nextAnimation() : _nextAnimation;\n function delay(animation, now) {\n const {\n startTime,\n started,\n previousAnimation\n } = animation;\n const current = animation.current;\n if (now - startTime > delayMs || animation.reduceMotion) {\n if (!started) {\n nextAnimation.onStart(nextAnimation, current, now, previousAnimation);\n animation.previousAnimation = null;\n animation.started = true;\n }\n const finished = nextAnimation.onFrame(nextAnimation, now);\n animation.current = nextAnimation.current;\n return finished;\n } else if (previousAnimation) {\n const finished = previousAnimation.finished || previousAnimation.onFrame(previousAnimation, now);\n animation.current = previousAnimation.current;\n if (finished) {\n animation.previousAnimation = null;\n }\n }\n return false;\n }\n function onStart(animation, value, now, previousAnimation) {\n animation.startTime = now;\n animation.started = false;\n animation.current = value;\n if (previousAnimation === animation) {\n animation.previousAnimation = previousAnimation.previousAnimation;\n } else {\n animation.previousAnimation = previousAnimation;\n }\n\n // child animations inherit the setting, unless they already have it defined\n // they will have it defined only if the user used the `reduceMotion` prop\n if (nextAnimation.reduceMotion === undefined) {\n nextAnimation.reduceMotion = animation.reduceMotion;\n }\n }\n const callback = finished => {\n if (nextAnimation.callback) {\n nextAnimation.callback(finished);\n }\n };\n return {\n isHigherOrder: true,\n onFrame: delay,\n onStart,\n current: nextAnimation.current,\n callback,\n previousAnimation: null,\n startTime: 0,\n started: false,\n reduceMotion: getReduceMotionForAnimation(reduceMotion)\n };\n });\n};\n//# sourceMappingURL=delay.js.map","'use strict';\n\nimport { defineAnimation, getReduceMotionForAnimation } from './util';\n\n// TODO TYPESCRIPT This is a temporary type to get rid of .d.ts file.\n\n/**\n * Lets you repeat an animation given number of times or run it indefinitely.\n *\n * @param animation - An animation object you want to repeat.\n * @param numberOfReps - The number of times the animation is going to be repeated. Defaults to 2.\n * @param reverse - Whether the animation should run in reverse every other repetition. Defaults to false.\n * @param callback - A function called on animation complete.\n * @param reduceMotion - Determines how the animation responds to the device's reduced motion accessibility setting. Default to `ReduceMotion.System` - {@link ReduceMotion}.\n * @returns An [animation object](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animation-object) which holds the current state of the animation.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withRepeat\n */\nexport const withRepeat = function (_nextAnimation, numberOfReps = 2, reverse = false, callback, reduceMotion) {\n 'worklet';\n\n return defineAnimation(_nextAnimation, () => {\n 'worklet';\n\n const nextAnimation = typeof _nextAnimation === 'function' ? _nextAnimation() : _nextAnimation;\n function repeat(animation, now) {\n const finished = nextAnimation.onFrame(nextAnimation, now);\n animation.current = nextAnimation.current;\n if (finished) {\n animation.reps += 1;\n // call inner animation's callback on every repetition\n // as the second argument the animation's current value is passed\n if (nextAnimation.callback) {\n nextAnimation.callback(true /* finished */, animation.current);\n }\n if (animation.reduceMotion || numberOfReps > 0 && animation.reps >= numberOfReps) {\n return true;\n }\n const startValue = reverse ? nextAnimation.current : animation.startValue;\n if (reverse) {\n nextAnimation.toValue = animation.startValue;\n animation.startValue = startValue;\n }\n nextAnimation.onStart(nextAnimation, startValue, now, nextAnimation.previousAnimation);\n return false;\n }\n return false;\n }\n const repCallback = finished => {\n if (callback) {\n callback(finished);\n }\n // when cancelled call inner animation's callback\n if (!finished && nextAnimation.callback) {\n nextAnimation.callback(false /* finished */);\n }\n };\n function onStart(animation, value, now, previousAnimation) {\n animation.startValue = value;\n animation.reps = 0;\n\n // child animations inherit the setting, unless they already have it defined\n // they will have it defined only if the user used the `reduceMotion` prop\n if (nextAnimation.reduceMotion === undefined) {\n nextAnimation.reduceMotion = animation.reduceMotion;\n }\n\n // don't start the animation if reduced motion is enabled and\n // the animation would end at its starting point\n if (animation.reduceMotion && reverse && (numberOfReps <= 0 || numberOfReps % 2 === 0)) {\n animation.current = animation.startValue;\n animation.onFrame = () => true;\n } else {\n nextAnimation.onStart(nextAnimation, value, now, previousAnimation);\n }\n }\n return {\n isHigherOrder: true,\n onFrame: repeat,\n onStart,\n reps: 0,\n current: nextAnimation.current,\n callback: repCallback,\n startValue: 0,\n reduceMotion: getReduceMotionForAnimation(reduceMotion)\n };\n });\n};\n//# sourceMappingURL=repeat.js.map","'use strict';\n\nimport { defineAnimation, getReduceMotionForAnimation } from './util';\n\n/**\n * Lets you run animations in a sequence.\n *\n * @param reduceMotion - Determines how the animation responds to the device's reduced motion accessibility setting. Default to `ReduceMotion.System` - {@link ReduceMotion}.\n * @param animations - Any number of animation objects to be run in a sequence.\n * @returns An [animation object](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animation-object) which holds the current state of the animation/\n * @see https://docs.swmansion.com/react-native-reanimated/docs/animations/withSequence\n */\n\nexport function withSequence(_reduceMotionOrFirstAnimation, ..._animations) {\n 'worklet';\n\n let reduceMotion;\n\n // the first argument is either a config or an animation\n // this is done to allow the reduce motion config prop to be optional\n if (_reduceMotionOrFirstAnimation) {\n if (typeof _reduceMotionOrFirstAnimation === 'string') {\n reduceMotion = _reduceMotionOrFirstAnimation;\n } else {\n _animations.unshift(_reduceMotionOrFirstAnimation);\n }\n }\n if (_animations.length === 0) {\n console.warn('[Reanimated] No animation was provided for the sequence');\n return defineAnimation(0, () => {\n 'worklet';\n\n return {\n onStart: (animation, value) => animation.current = value,\n onFrame: () => true,\n current: 0,\n animationIndex: 0,\n reduceMotion: getReduceMotionForAnimation(reduceMotion)\n };\n });\n }\n return defineAnimation(_animations[0], () => {\n 'worklet';\n\n const animations = _animations.map(a => {\n const result = typeof a === 'function' ? a() : a;\n result.finished = false;\n return result;\n });\n function findNextNonReducedMotionAnimationIndex(index) {\n // the last animation is returned even if reduced motion is enabled,\n // because we want the sequence to finish at the right spot\n while (index < animations.length - 1 && animations[index].reduceMotion) {\n index++;\n }\n return index;\n }\n const callback = finished => {\n if (finished) {\n // we want to call the callback after every single animation\n // not after all of them\n return;\n }\n // this is going to be called only if sequence has been cancelled\n animations.forEach(animation => {\n if (typeof animation.callback === 'function' && !animation.finished) {\n animation.callback(finished);\n }\n });\n };\n function sequence(animation, now) {\n const currentAnim = animations[animation.animationIndex];\n const finished = currentAnim.onFrame(currentAnim, now);\n animation.current = currentAnim.current;\n if (finished) {\n // we want to call the callback after every single animation\n if (currentAnim.callback) {\n currentAnim.callback(true /* finished */);\n }\n currentAnim.finished = true;\n animation.animationIndex = findNextNonReducedMotionAnimationIndex(animation.animationIndex + 1);\n if (animation.animationIndex < animations.length) {\n const nextAnim = animations[animation.animationIndex];\n nextAnim.onStart(nextAnim, currentAnim.current, now, currentAnim);\n return false;\n }\n return true;\n }\n return false;\n }\n function onStart(animation, value, now, previousAnimation) {\n // child animations inherit the setting, unless they already have it defined\n // they will have it defined only if the user used the `reduceMotion` prop\n animations.forEach(anim => {\n if (anim.reduceMotion === undefined) {\n anim.reduceMotion = animation.reduceMotion;\n }\n });\n animation.animationIndex = findNextNonReducedMotionAnimationIndex(0);\n if (previousAnimation === undefined) {\n previousAnimation = animations[animations.length - 1];\n }\n const currentAnimation = animations[animation.animationIndex];\n currentAnimation.onStart(currentAnimation, value, now, previousAnimation);\n }\n return {\n isHigherOrder: true,\n onFrame: sequence,\n onStart,\n animationIndex: 0,\n current: animations[0].current,\n callback,\n reduceMotion: getReduceMotionForAnimation(reduceMotion)\n };\n });\n}\n//# sourceMappingURL=sequence.js.map","'use strict';\n\nimport { defineAnimation } from './util';\nimport { withTiming } from './timing';\nimport { ColorProperties, processColor } from '../Colors';\n\n// resolves path to value for nested objects\n// if path cannot be resolved returns undefined\nfunction resolvePath(obj, path) {\n 'worklet';\n\n const keys = Array.isArray(path) ? path : [path];\n return keys.reduce((acc, current) => {\n if (Array.isArray(acc) && typeof current === 'number') {\n return acc[current];\n } else if (acc !== null && typeof acc === 'object' && current in acc) {\n return acc[current];\n }\n return undefined;\n }, obj);\n}\n\n// set value at given path\n\nfunction setPath(obj, path, value) {\n 'worklet';\n\n const keys = Array.isArray(path) ? path : [path];\n let currObj = obj;\n for (let i = 0; i < keys.length - 1; i++) {\n // creates entry if there isn't one\n currObj = currObj;\n if (!(keys[i] in currObj)) {\n // if next key is a number create an array\n if (typeof keys[i + 1] === 'number') {\n currObj[keys[i]] = [];\n } else {\n currObj[keys[i]] = {};\n }\n }\n currObj = currObj[keys[i]];\n }\n currObj[keys[keys.length - 1]] = value;\n}\nexport function withStyleAnimation(styleAnimations) {\n 'worklet';\n\n return defineAnimation({}, () => {\n 'worklet';\n\n const onFrame = (animation, now) => {\n let stillGoing = false;\n const entriesToCheck = [{\n value: animation.styleAnimations,\n path: []\n }];\n while (entriesToCheck.length > 0) {\n const currentEntry = entriesToCheck.pop();\n if (Array.isArray(currentEntry.value)) {\n for (let index = 0; index < currentEntry.value.length; index++) {\n entriesToCheck.push({\n value: currentEntry.value[index],\n path: currentEntry.path.concat(index)\n });\n }\n } else if (typeof currentEntry.value === 'object' && currentEntry.value.onFrame === undefined) {\n // nested object\n for (const key of Object.keys(currentEntry.value)) {\n entriesToCheck.push({\n value: currentEntry.value[key],\n path: currentEntry.path.concat(key)\n });\n }\n } else {\n const currentStyleAnimation = currentEntry.value;\n if (currentStyleAnimation.finished) {\n continue;\n }\n const finished = currentStyleAnimation.onFrame(currentStyleAnimation, now);\n if (finished) {\n currentStyleAnimation.finished = true;\n if (currentStyleAnimation.callback) {\n currentStyleAnimation.callback(true);\n }\n } else {\n stillGoing = true;\n }\n\n // When working with animations changing colors, we need to make sure that each one of them begins with a rgba, not a processed number.\n // Thus, we only set the path to a processed color, but currentStyleAnimation.current stays as rgba.\n const isAnimatingColorProp = ColorProperties.includes(currentEntry.path[0]);\n setPath(animation.current, currentEntry.path, isAnimatingColorProp ? processColor(currentStyleAnimation.current) : currentStyleAnimation.current);\n }\n }\n return !stillGoing;\n };\n const onStart = (animation, value, now, previousAnimation) => {\n const entriesToCheck = [{\n value: styleAnimations,\n path: []\n }];\n while (entriesToCheck.length > 0) {\n const currentEntry = entriesToCheck.pop();\n if (Array.isArray(currentEntry.value)) {\n for (let index = 0; index < currentEntry.value.length; index++) {\n entriesToCheck.push({\n value: currentEntry.value[index],\n path: currentEntry.path.concat(index)\n });\n }\n } else if (typeof currentEntry.value === 'object' && currentEntry.value.onStart === undefined) {\n for (const key of Object.keys(currentEntry.value)) {\n entriesToCheck.push({\n value: currentEntry.value[key],\n path: currentEntry.path.concat(key)\n });\n }\n } else {\n const prevAnimation = resolvePath(previousAnimation === null || previousAnimation === void 0 ? void 0 : previousAnimation.styleAnimations, currentEntry.path);\n let prevVal = resolvePath(value, currentEntry.path);\n if (prevAnimation && !prevVal) {\n prevVal = prevAnimation.current;\n }\n if (prevVal === undefined) {\n console.warn(`Initial values for animation are missing for property ${currentEntry.path.join('.')}`);\n }\n setPath(animation.current, currentEntry.path, prevVal);\n let currentAnimation;\n if (typeof currentEntry.value !== 'object' || !currentEntry.value.onStart) {\n currentAnimation = withTiming(currentEntry.value, {\n duration: 0\n }); // TODO TYPESCRIPT this temporary cast is to get rid of .d.ts file.\n setPath(animation.styleAnimations, currentEntry.path, currentAnimation);\n } else {\n currentAnimation = currentEntry.value;\n }\n currentAnimation.onStart(currentAnimation, prevVal, now, prevAnimation);\n }\n }\n };\n const callback = finished => {\n if (!finished) {\n const animationsToCheck = [styleAnimations];\n while (animationsToCheck.length > 0) {\n const currentAnimation = animationsToCheck.pop();\n if (Array.isArray(currentAnimation)) {\n for (const element of currentAnimation) {\n animationsToCheck.push(element);\n }\n } else if (typeof currentAnimation === 'object' && currentAnimation.onStart === undefined) {\n for (const value of Object.values(currentAnimation)) {\n animationsToCheck.push(value);\n }\n } else {\n const currentStyleAnimation = currentAnimation;\n if (!currentStyleAnimation.finished && currentStyleAnimation.callback) {\n currentStyleAnimation.callback(false);\n }\n }\n }\n }\n };\n return {\n isHigherOrder: true,\n onFrame,\n onStart,\n current: {},\n styleAnimations,\n callback\n };\n });\n}\n//# sourceMappingURL=styleAnimation.js.map","'use strict';\n\nimport { useEffect, useState } from 'react';\nimport { cancelAnimation } from '../animation';\nimport { makeMutable } from '../core';\n\n/**\n * Lets you define [shared values](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#shared-value) in your components.\n *\n * @param initialValue - The value you want to be initially stored to a `.value` property.\n * @returns A shared value with a single `.value` property initially set to the `initialValue` - {@link SharedValue}.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/core/useSharedValue\n */\nexport function useSharedValue(initialValue) {\n const [mutable] = useState(() => makeMutable(initialValue));\n useEffect(() => {\n return () => {\n cancelAnimation(mutable);\n };\n }, [mutable]);\n return mutable;\n}\n//# sourceMappingURL=useSharedValue.js.map","'use strict';\n\n// Builds one big hash from multiple worklets' hashes.\nexport function buildWorkletsHash(worklets) {\n // For arrays `Object.values` returns the array itself.\n return Object.values(worklets).reduce((acc, worklet) => acc + worklet.__workletHash.toString(), '');\n}\n\n// Builds dependencies array for useEvent handlers.\nexport function buildDependencies(dependencies, handlers) {\n const handlersList = Object.values(handlers).filter(handler => handler !== undefined);\n if (!dependencies) {\n dependencies = handlersList.map(handler => {\n return {\n workletHash: handler.__workletHash,\n closure: handler.__closure\n };\n });\n } else {\n dependencies.push(buildWorkletsHash(handlersList));\n }\n return dependencies;\n}\n\n// This is supposed to work as useEffect comparison.\nexport function areDependenciesEqual(nextDependencies, prevDependencies) {\n function is(x, y) {\n return x === y && (x !== 0 || 1 / x === 1 / y) || Number.isNaN(x) && Number.isNaN(y);\n }\n const objectIs = typeof Object.is === 'function' ? Object.is : is;\n function areHookInputsEqual(nextDeps, prevDeps) {\n if (!nextDeps || !prevDeps || prevDeps.length !== nextDeps.length) {\n return false;\n }\n for (let i = 0; i < prevDeps.length; ++i) {\n if (!objectIs(nextDeps[i], prevDeps[i])) {\n return false;\n }\n }\n return true;\n }\n return areHookInputsEqual(nextDependencies, prevDependencies);\n}\nexport function isAnimated(prop) {\n 'worklet';\n\n if (Array.isArray(prop)) {\n return prop.some(isAnimated);\n } else if (typeof prop === 'object' && prop !== null) {\n if (prop.onFrame !== undefined) {\n return true;\n } else {\n return Object.values(prop).some(isAnimated);\n }\n }\n return false;\n}\n\n// This function works because `Object.keys`\n// return empty array of primitives and on arrays\n// it returns array of its indices.\nexport function shallowEqual(a, b) {\n 'worklet';\n\n const aKeys = Object.keys(a);\n const bKeys = Object.keys(b);\n if (aKeys.length !== bKeys.length) {\n return false;\n }\n for (let i = 0; i < aKeys.length; i++) {\n if (a[aKeys[i]] !== b[aKeys[i]]) {\n return false;\n }\n }\n return true;\n}\nexport function validateAnimatedStyles(styles) {\n 'worklet';\n\n if (typeof styles !== 'object') {\n throw new Error(`[Reanimated] \\`useAnimatedStyle\\` has to return an object, found ${typeof styles} instead.`);\n } else if (Array.isArray(styles)) {\n throw new Error('[Reanimated] `useAnimatedStyle` has to return an object and cannot return static styles combined with dynamic ones. Please do merging where a component receives props.');\n }\n}\n//# sourceMappingURL=utils.js.map","'use strict';\n\nimport { useRef } from 'react';\nimport { makeMutable } from './core';\nimport { shouldBeUseWeb } from './PlatformChecker';\nexport function makeViewDescriptorsSet() {\n const shareableViewDescriptors = makeMutable([]);\n const data = {\n shareableViewDescriptors,\n add: item => {\n shareableViewDescriptors.modify(descriptors => {\n 'worklet';\n\n const index = descriptors.findIndex(descriptor => descriptor.tag === item.tag);\n if (index !== -1) {\n descriptors[index] = item;\n } else {\n descriptors.push(item);\n }\n return descriptors;\n }, false);\n },\n remove: viewTag => {\n shareableViewDescriptors.modify(descriptors => {\n 'worklet';\n\n const index = descriptors.findIndex(descriptor => descriptor.tag === viewTag);\n if (index !== -1) {\n descriptors.splice(index, 1);\n }\n return descriptors;\n }, false);\n }\n };\n return data;\n}\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\nexport const useViewRefSet = SHOULD_BE_USE_WEB ? useViewRefSetJS : useViewRefSetNative;\nfunction useViewRefSetNative() {\n // Stub native implementation.\n return undefined;\n}\nfunction useViewRefSetJS() {\n const ref = useRef(null);\n if (ref.current === null) {\n const data = {\n items: new Set(),\n add: item => {\n if (data.items.has(item)) return;\n data.items.add(item);\n },\n remove: item => {\n data.items.delete(item);\n }\n };\n ref.current = data;\n }\n return ref.current;\n}\n//# sourceMappingURL=ViewDescriptorsSet.js.map","'use strict';\n\nimport { useCallback } from 'react';\n/**\n * @deprecated don't use\n */\nexport function useWorkletCallback(worklet, deps) {\n return useCallback(worklet, deps ?? []);\n}\n//# sourceMappingURL=useWorkletCallback.js.map","'use strict';\n\nimport { isReducedMotion } from '../PlatformChecker';\nconst IS_REDUCED_MOTION = isReducedMotion();\n\n/**\n * Lets you query the reduced motion system setting.\n *\n * Changing the reduced motion system setting doesn't cause your components to rerender.\n *\n * @returns A boolean indicating whether the reduced motion setting was enabled when the app started.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/device/useReducedMotion\n */\nexport function useReducedMotion() {\n return IS_REDUCED_MOTION;\n}\n//# sourceMappingURL=useReducedMotion.js.map","'use strict';\n\nimport { useHandler } from './useHandler';\nimport { useEvent } from './useEvent';\nconst EVENT_TYPE = {\n UNDETERMINED: 0,\n FAILED: 1,\n BEGAN: 2,\n CANCELLED: 3,\n ACTIVE: 4,\n END: 5\n};\n\n// This type comes from React Native Gesture Handler\n// import type { PanGestureHandlerGestureEvent as DefaultEvent } from 'react-native-gesture-handler';\n\n/**\n * @deprecated useAnimatedGestureHandler is an old API which is no longer supported.\n *\n * Please check https://docs.swmansion.com/react-native-gesture-handler/docs/guides/upgrading-to-2/\n * for information about how to migrate to `react-native-gesture-handler` v2\n */\nexport function useAnimatedGestureHandler(handlers, dependencies) {\n const {\n context,\n doDependenciesDiffer,\n useWeb\n } = useHandler(handlers, dependencies);\n const handler = e => {\n 'worklet';\n\n const event = useWeb ?\n // On Web we get events straight from React Native and they don't have\n // the `eventName` field there. To simplify the types here we just\n // cast it as the field was available.\n e.nativeEvent : e;\n if (event.state === EVENT_TYPE.BEGAN && handlers.onStart) {\n handlers.onStart(event, context);\n }\n if (event.state === EVENT_TYPE.ACTIVE && handlers.onActive) {\n handlers.onActive(event, context);\n }\n if (event.oldState === EVENT_TYPE.ACTIVE && event.state === EVENT_TYPE.END && handlers.onEnd) {\n handlers.onEnd(event, context);\n }\n if (event.oldState === EVENT_TYPE.BEGAN && event.state === EVENT_TYPE.FAILED && handlers.onFail) {\n handlers.onFail(event, context);\n }\n if (event.oldState === EVENT_TYPE.ACTIVE && event.state === EVENT_TYPE.CANCELLED && handlers.onCancel) {\n handlers.onCancel(event, context);\n }\n if ((event.oldState === EVENT_TYPE.BEGAN || event.oldState === EVENT_TYPE.ACTIVE) && event.state !== EVENT_TYPE.BEGAN && event.state !== EVENT_TYPE.ACTIVE && handlers.onFinish) {\n handlers.onFinish(event, context, event.state === EVENT_TYPE.CANCELLED || event.state === EVENT_TYPE.FAILED);\n }\n };\n if (useWeb) {\n return handler;\n }\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n return useEvent(handler, ['onGestureHandlerStateChange', 'onGestureHandlerEvent'], doDependenciesDiffer\n // This is not correct but we want to make GH think it receives a function.\n );\n}\n//# sourceMappingURL=useAnimatedGestureHandler.js.map","'use strict';\n\nimport { useEffect, useRef } from 'react';\nimport { isWeb, isJest } from '../PlatformChecker';\nimport { areDependenciesEqual, buildDependencies } from './utils';\nimport { makeShareable } from '../shareables';\n\n/**\n * Lets you find out whether the event handler dependencies have changed.\n *\n * @param handlers - An object of event handlers.\n * @param dependencies - An optional array of dependencies.\n * @returns An object containing a boolean indicating whether the dependencies have changed, and a boolean indicating whether the code is running on the web.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/advanced/useHandler\n */\n// @ts-expect-error This overload is required by our API.\n\nexport function useHandler(handlers, dependencies) {\n const initRef = useRef(null);\n if (initRef.current === null) {\n const context = makeShareable({});\n initRef.current = {\n context,\n savedDependencies: []\n };\n }\n useEffect(() => {\n return () => {\n initRef.current = null;\n };\n }, []);\n const {\n context,\n savedDependencies\n } = initRef.current;\n dependencies = buildDependencies(dependencies, handlers);\n const doDependenciesDiffer = !areDependenciesEqual(dependencies, savedDependencies);\n initRef.current.savedDependencies = dependencies;\n const useWeb = isWeb() || isJest();\n return {\n context,\n doDependenciesDiffer,\n useWeb\n };\n}\n//# sourceMappingURL=useHandler.js.map","'use strict';\n\nimport { useRef } from 'react';\nimport { WorkletEventHandler } from '../WorkletEventHandler';\n\n/**\n * Worklet to provide as an argument to `useEvent` hook.\n */\n\n/**\n * Lets you run a function whenever a specified native event occurs.\n *\n * @param handler - A function that receives an event object with event data - {@link EventHandler}.\n * @param eventNames - An array of event names the `handler` callback will react to.\n * @param rebuild - Whether the event handler should be rebuilt. Defaults to `false`.\n * @returns A function that will be called when the event occurs - {@link EventHandlerProcessed}.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/advanced/useEvent\n */\n// @ts-expect-error This overload is required by our API.\n// We don't know which properites of a component that is made into\n// an AnimatedComponent are event handlers and we don't want to force the user to define it.\n// Therefore we disguise `useEvent` return type as a simple function and we handle\n// it being a React Ref in `createAnimatedComponent`.\n\nexport function useEvent(handler, eventNames = [], rebuild = false) {\n const initRef = useRef(null);\n if (initRef.current === null) {\n const workletEventHandler = new WorkletEventHandler(handler, eventNames);\n initRef.current = {\n workletEventHandler\n };\n } else if (rebuild) {\n const workletEventHandler = initRef.current.workletEventHandler;\n workletEventHandler.updateEventHandler(handler, eventNames);\n initRef.current = {\n workletEventHandler\n };\n }\n return initRef.current;\n}\n//# sourceMappingURL=useEvent.js.map","'use strict';\n\nfunction _classPrivateFieldInitSpec(obj, privateMap, value) { _checkPrivateRedeclaration(obj, privateMap); privateMap.set(obj, value); }\nfunction _checkPrivateRedeclaration(obj, privateCollection) { if (privateCollection.has(obj)) { throw new TypeError(\"Cannot initialize the same private elements twice on an object\"); } }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nfunction _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); }\nfunction _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; }\nfunction _assertClassBrand(e, t, n) { if (\"function\" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError(\"Private element is not present on this object\"); }\nimport { registerEventHandler, unregisterEventHandler } from './core';\nimport { shouldBeUseWeb } from './PlatformChecker';\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\n// In JS implementation (e.g. for web) we don't use Reanimated's\n// event emitter, therefore we have to handle here\n// the event that came from React Native and convert it.\nfunction jsListener(eventName, handler) {\n return evt => {\n handler({\n ...evt.nativeEvent,\n eventName\n });\n };\n}\nvar _viewTags = /*#__PURE__*/new WeakMap();\nvar _registrations = /*#__PURE__*/new WeakMap();\nclass WorkletEventHandlerNative {\n // keys are viewTags, values are arrays of registration ID's for each viewTag\n constructor(worklet, eventNames) {\n _defineProperty(this, \"eventNames\", void 0);\n _defineProperty(this, \"worklet\", void 0);\n _classPrivateFieldInitSpec(this, _viewTags, void 0);\n _classPrivateFieldInitSpec(this, _registrations, void 0);\n this.worklet = worklet;\n this.eventNames = eventNames;\n _classPrivateFieldSet(_viewTags, this, new Set());\n _classPrivateFieldSet(_registrations, this, new Map());\n }\n updateEventHandler(newWorklet, newEvents) {\n // Update worklet and event names\n this.worklet = newWorklet;\n this.eventNames = newEvents;\n\n // Detach all events\n _classPrivateFieldGet(_registrations, this).forEach(registrationIDs => {\n registrationIDs.forEach(id => unregisterEventHandler(id));\n // No need to remove registrationIDs from map, since it gets overwritten when attaching\n });\n\n // Attach new events with new worklet\n Array.from(_classPrivateFieldGet(_viewTags, this)).forEach(tag => {\n const newRegistrations = this.eventNames.map(eventName => registerEventHandler(this.worklet, eventName, tag));\n _classPrivateFieldGet(_registrations, this).set(tag, newRegistrations);\n });\n }\n registerForEvents(viewTag, fallbackEventName) {\n _classPrivateFieldGet(_viewTags, this).add(viewTag);\n const newRegistrations = this.eventNames.map(eventName => registerEventHandler(this.worklet, eventName, viewTag));\n _classPrivateFieldGet(_registrations, this).set(viewTag, newRegistrations);\n if (this.eventNames.length === 0 && fallbackEventName) {\n const newRegistration = registerEventHandler(this.worklet, fallbackEventName, viewTag);\n _classPrivateFieldGet(_registrations, this).set(viewTag, [newRegistration]);\n }\n }\n unregisterFromEvents(viewTag) {\n var _classPrivateFieldGet2;\n _classPrivateFieldGet(_viewTags, this).delete(viewTag);\n (_classPrivateFieldGet2 = _classPrivateFieldGet(_registrations, this).get(viewTag)) === null || _classPrivateFieldGet2 === void 0 || _classPrivateFieldGet2.forEach(id => {\n unregisterEventHandler(id);\n });\n _classPrivateFieldGet(_registrations, this).delete(viewTag);\n }\n}\nclass WorkletEventHandlerWeb {\n constructor(worklet, eventNames = []) {\n _defineProperty(this, \"eventNames\", void 0);\n _defineProperty(this, \"listeners\", void 0);\n _defineProperty(this, \"worklet\", void 0);\n this.worklet = worklet;\n this.eventNames = eventNames;\n this.listeners = {};\n this.setupWebListeners();\n }\n setupWebListeners() {\n this.listeners = {};\n this.eventNames.forEach(eventName => {\n this.listeners[eventName] = jsListener(eventName, this.worklet);\n });\n }\n updateEventHandler(newWorklet, newEvents) {\n // Update worklet and event names\n this.worklet = newWorklet;\n this.eventNames = newEvents;\n this.setupWebListeners();\n }\n registerForEvents(_viewTag, _fallbackEventName) {\n // noop\n }\n unregisterFromEvents(_viewTag) {\n // noop\n }\n}\nexport const WorkletEventHandler = SHOULD_BE_USE_WEB ? WorkletEventHandlerWeb : WorkletEventHandlerNative;\n//# sourceMappingURL=WorkletEventHandler.js.map","'use strict';\n\nimport { useEffect } from 'react';\nimport { startMapper, stopMapper } from '../core';\nimport { useSharedValue } from './useSharedValue';\nimport { shouldBeUseWeb } from '../PlatformChecker';\n\n/**\n * Lets you to respond to changes in a [shared value](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#shared-value). It's especially useful when comparing values previously stored in the shared value with the current one.\n *\n * @param prepare - A function that should return a value to which you'd like to react.\n * @param react - A function that reacts to changes in the value returned by the `prepare` function.\n * @param dependencies - an optional array of dependencies. Only relevant when using Reanimated without the Babel plugin on the Web.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/advanced/useAnimatedReaction\n */\n// @ts-expect-error This overload is required by our API.\n\nexport function useAnimatedReaction(prepare, react, dependencies) {\n const previous = useSharedValue(null);\n let inputs = Object.values(prepare.__closure ?? {});\n if (shouldBeUseWeb()) {\n var _dependencies;\n if (!inputs.length && (_dependencies = dependencies) !== null && _dependencies !== void 0 && _dependencies.length) {\n // let web work without a Reanimated Babel plugin\n inputs = dependencies;\n }\n }\n if (dependencies === undefined) {\n dependencies = [...Object.values(prepare.__closure ?? {}), ...Object.values(react.__closure ?? {}), prepare.__workletHash, react.__workletHash];\n } else {\n dependencies.push(prepare.__workletHash, react.__workletHash);\n }\n useEffect(() => {\n const fun = () => {\n 'worklet';\n\n const input = prepare();\n react(input, previous.value);\n previous.value = input;\n };\n const mapperId = startMapper(fun, inputs);\n return () => {\n stopMapper(mapperId);\n };\n }, dependencies);\n}\n//# sourceMappingURL=useAnimatedReaction.js.map","'use strict';\n\nimport { useRef } from 'react';\nimport { useSharedValue } from './useSharedValue';\nimport { getShadowNodeWrapperFromRef } from '../fabricUtils';\nimport { makeShareableCloneRecursive } from '../shareables';\nimport { shareableMappingCache } from '../shareableMappingCache';\nimport { Platform, findNodeHandle } from 'react-native';\nimport { isFabric, isWeb } from '../PlatformChecker';\nconst IS_WEB = isWeb();\nfunction getComponentOrScrollable(component) {\n if (isFabric() && component.getNativeScrollRef) {\n return component.getNativeScrollRef();\n } else if (!isFabric() && component.getScrollableNode) {\n return component.getScrollableNode();\n }\n return component;\n}\n\n/**\n * Lets you get a reference of a view that you can use inside a worklet.\n *\n * @returns An object with a `.current` property which contains an instance of a component.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/core/useAnimatedRef\n */\nexport function useAnimatedRef() {\n const tag = useSharedValue(-1);\n const viewName = useSharedValue(null);\n const ref = useRef();\n if (!ref.current) {\n const fun = component => {\n // enters when ref is set by attaching to a component\n if (component) {\n const getTagValueFunction = isFabric() ? getShadowNodeWrapperFromRef : findNodeHandle;\n const getTagOrShadowNodeWrapper = () => {\n return IS_WEB ? getComponentOrScrollable(component) : getTagValueFunction(getComponentOrScrollable(component));\n };\n tag.value = getTagOrShadowNodeWrapper();\n\n // On Fabric we have to unwrap the tag from the shadow node wrapper\n fun.getTag = isFabric() ? () => findNodeHandle(getComponentOrScrollable(component)) : getTagOrShadowNodeWrapper;\n fun.current = component;\n // viewName is required only on iOS with Paper\n if (Platform.OS === 'ios' && !isFabric()) {\n var _viewConfig;\n viewName.value = (component === null || component === void 0 || (_viewConfig = component.viewConfig) === null || _viewConfig === void 0 ? void 0 : _viewConfig.uiViewClassName) || 'RCTView';\n }\n }\n return tag.value;\n };\n fun.current = null;\n const animatedRefShareableHandle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n\n const f = () => tag.value;\n f.viewName = viewName;\n return f;\n }\n });\n shareableMappingCache.set(fun, animatedRefShareableHandle);\n ref.current = fun;\n }\n return ref.current;\n}\n//# sourceMappingURL=useAnimatedRef.js.map","'use strict';\n\nexport function getShadowNodeWrapperFromRef() {\n throw new Error('[Reanimated] Trying to call `getShadowNodeWrapperFromRef` on web.');\n}\n//# sourceMappingURL=fabricUtils.web.js.map","'use strict';\n\nimport { useHandler } from './useHandler';\nimport { useEvent } from './useEvent';\n\n/**\n * Lets you run callbacks on ScrollView events. Supports `onScroll`, `onBeginDrag`, `onEndDrag`, `onMomentumBegin`, and `onMomentumEnd` events.\n *\n * These callbacks are automatically workletized and ran on the UI thread.\n *\n * @param handlers - An object containing event handlers.\n * @param dependencies - An optional array of dependencies. Only relevant when using Reanimated without the Babel plugin on the Web.\n * @returns An object you need to pass to `onScroll` prop on the `Animated.ScrollView` component.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/scroll/useAnimatedScrollHandler\n */\n// @ts-expect-error This overload is required by our API.\n\nexport function useAnimatedScrollHandler(handlers, dependencies) {\n // case when handlers is a function\n const scrollHandlers = typeof handlers === 'function' ? {\n onScroll: handlers\n } : handlers;\n const {\n context,\n doDependenciesDiffer\n } = useHandler(scrollHandlers, dependencies);\n\n // build event subscription array\n const subscribeForEvents = ['onScroll'];\n if (scrollHandlers.onBeginDrag !== undefined) {\n subscribeForEvents.push('onScrollBeginDrag');\n }\n if (scrollHandlers.onEndDrag !== undefined) {\n subscribeForEvents.push('onScrollEndDrag');\n }\n if (scrollHandlers.onMomentumBegin !== undefined) {\n subscribeForEvents.push('onMomentumScrollBegin');\n }\n if (scrollHandlers.onMomentumEnd !== undefined) {\n subscribeForEvents.push('onMomentumScrollEnd');\n }\n return useEvent(event => {\n 'worklet';\n\n const {\n onScroll,\n onBeginDrag,\n onEndDrag,\n onMomentumBegin,\n onMomentumEnd\n } = scrollHandlers;\n if (onScroll && event.eventName.endsWith('onScroll')) {\n onScroll(event, context);\n } else if (onBeginDrag && event.eventName.endsWith('onScrollBeginDrag')) {\n onBeginDrag(event, context);\n } else if (onEndDrag && event.eventName.endsWith('onScrollEndDrag')) {\n onEndDrag(event, context);\n } else if (onMomentumBegin && event.eventName.endsWith('onMomentumScrollBegin')) {\n onMomentumBegin(event, context);\n } else if (onMomentumEnd && event.eventName.endsWith('onMomentumScrollEnd')) {\n onMomentumEnd(event, context);\n }\n }, subscribeForEvents, doDependenciesDiffer\n // Read https://github.com/software-mansion/react-native-reanimated/pull/5056\n // for more information about this cast.\n );\n}\n//# sourceMappingURL=useAnimatedScrollHandler.js.map","'use strict';\n\nimport { useEffect, useRef } from 'react';\nimport { initialUpdaterRun } from '../animation';\nimport { makeMutable, startMapper, stopMapper } from '../core';\nimport { shouldBeUseWeb } from '../PlatformChecker';\n\n/**\n * Lets you create new shared values based on existing ones while keeping them reactive.\n *\n * @param updater - A function called whenever at least one of the shared values or state used in the function body changes.\n * @param dependencies - An optional array of dependencies. Only relevant when using Reanimated without the Babel plugin on the Web.\n * @returns A new readonly shared value based on a value returned from the updater function\n * @see https://docs.swmansion.com/react-native-reanimated/docs/core/useDerivedValue\n */\n// @ts-expect-error This overload is required by our API.\n\nexport function useDerivedValue(updater, dependencies) {\n const initRef = useRef(null);\n let inputs = Object.values(updater.__closure ?? {});\n if (shouldBeUseWeb()) {\n var _dependencies;\n if (!inputs.length && (_dependencies = dependencies) !== null && _dependencies !== void 0 && _dependencies.length) {\n // let web work without a Babel/SWC plugin\n inputs = dependencies;\n }\n }\n\n // build dependencies\n if (dependencies === undefined) {\n dependencies = [...inputs, updater.__workletHash];\n } else {\n dependencies.push(updater.__workletHash);\n }\n if (initRef.current === null) {\n initRef.current = makeMutable(initialUpdaterRun(updater));\n }\n const sharedValue = initRef.current;\n useEffect(() => {\n const fun = () => {\n 'worklet';\n\n sharedValue.value = updater();\n };\n const mapperId = startMapper(fun, inputs, [sharedValue]);\n return () => {\n stopMapper(mapperId);\n };\n }, dependencies);\n useEffect(() => {\n return () => {\n initRef.current = null;\n };\n }, []);\n return sharedValue;\n}\n//# sourceMappingURL=useDerivedValue.js.map","'use strict';\n\nimport { useEffect, useMemo, useRef } from 'react';\nimport { initializeSensor, registerSensor, unregisterSensor } from '../core';\nimport { SensorType, IOSReferenceFrame, InterfaceOrientation } from '../commonTypes';\nimport { callMicrotasks } from '../threads';\n\n// euler angles are in order ZXY, z = yaw, x = pitch, y = roll\n// https://github.com/mrdoob/three.js/blob/dev/src/math/Quaternion.js#L237\nfunction eulerToQuaternion(pitch, roll, yaw) {\n 'worklet';\n\n const c1 = Math.cos(pitch / 2);\n const s1 = Math.sin(pitch / 2);\n const c2 = Math.cos(roll / 2);\n const s2 = Math.sin(roll / 2);\n const c3 = Math.cos(yaw / 2);\n const s3 = Math.sin(yaw / 2);\n return [s1 * c2 * c3 - c1 * s2 * s3, c1 * s2 * c3 + s1 * c2 * s3, c1 * c2 * s3 + s1 * s2 * c3, c1 * c2 * c3 - s1 * s2 * s3];\n}\nfunction adjustRotationToInterfaceOrientation(data) {\n 'worklet';\n\n const {\n interfaceOrientation,\n pitch,\n roll,\n yaw\n } = data;\n if (interfaceOrientation === InterfaceOrientation.ROTATION_90) {\n data.pitch = roll;\n data.roll = -pitch;\n data.yaw = yaw - Math.PI / 2;\n } else if (interfaceOrientation === InterfaceOrientation.ROTATION_270) {\n data.pitch = -roll;\n data.roll = pitch;\n data.yaw = yaw + Math.PI / 2;\n } else if (interfaceOrientation === InterfaceOrientation.ROTATION_180) {\n data.pitch *= -1;\n data.roll *= -1;\n data.yaw *= -1;\n }\n const q = eulerToQuaternion(data.pitch, data.roll, data.yaw);\n data.qx = q[0];\n data.qy = q[1];\n data.qz = q[2];\n data.qw = q[3];\n return data;\n}\nfunction adjustVectorToInterfaceOrientation(data) {\n 'worklet';\n\n const {\n interfaceOrientation,\n x,\n y\n } = data;\n if (interfaceOrientation === InterfaceOrientation.ROTATION_90) {\n data.x = -y;\n data.y = x;\n } else if (interfaceOrientation === InterfaceOrientation.ROTATION_270) {\n data.x = y;\n data.y = -x;\n } else if (interfaceOrientation === InterfaceOrientation.ROTATION_180) {\n data.x *= -1;\n data.y *= -1;\n }\n return data;\n}\n\n/**\n * Lets you create animations based on data from the device's sensors.\n *\n * @param sensorType - Type of the sensor to use. Configured with {@link SensorType} enum.\n * @param config - The sensor configuration - {@link SensorConfig}.\n * @returns An object containing the sensor measurements [shared value](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#shared-value) and a function to unregister the sensor\n * @see https://docs.swmansion.com/react-native-reanimated/docs/device/useAnimatedSensor\n */\n\nexport function useAnimatedSensor(sensorType, userConfig) {\n var _userConfigRef$curren, _userConfigRef$curren2, _userConfigRef$curren3;\n const userConfigRef = useRef(userConfig);\n const hasConfigChanged = ((_userConfigRef$curren = userConfigRef.current) === null || _userConfigRef$curren === void 0 ? void 0 : _userConfigRef$curren.adjustToInterfaceOrientation) !== (userConfig === null || userConfig === void 0 ? void 0 : userConfig.adjustToInterfaceOrientation) || ((_userConfigRef$curren2 = userConfigRef.current) === null || _userConfigRef$curren2 === void 0 ? void 0 : _userConfigRef$curren2.interval) !== (userConfig === null || userConfig === void 0 ? void 0 : userConfig.interval) || ((_userConfigRef$curren3 = userConfigRef.current) === null || _userConfigRef$curren3 === void 0 ? void 0 : _userConfigRef$curren3.iosReferenceFrame) !== (userConfig === null || userConfig === void 0 ? void 0 : userConfig.iosReferenceFrame);\n if (hasConfigChanged) {\n userConfigRef.current = {\n ...userConfig\n };\n }\n const config = useMemo(() => ({\n interval: 'auto',\n adjustToInterfaceOrientation: true,\n iosReferenceFrame: IOSReferenceFrame.Auto,\n ...userConfigRef.current\n }), [userConfigRef.current]);\n const ref = useRef({\n sensor: initializeSensor(sensorType, config),\n unregister: () => {\n // NOOP\n },\n isAvailable: false,\n config\n });\n useEffect(() => {\n ref.current = {\n sensor: initializeSensor(sensorType, config),\n unregister: () => {\n // NOOP\n },\n isAvailable: false,\n config\n };\n const sensorData = ref.current.sensor;\n const adjustToInterfaceOrientation = ref.current.config.adjustToInterfaceOrientation;\n const id = registerSensor(sensorType, config, data => {\n 'worklet';\n\n if (adjustToInterfaceOrientation) {\n if (sensorType === SensorType.ROTATION) {\n data = adjustRotationToInterfaceOrientation(data);\n } else {\n data = adjustVectorToInterfaceOrientation(data);\n }\n }\n sensorData.value = data;\n callMicrotasks();\n });\n if (id !== -1) {\n // if sensor is available\n ref.current.unregister = () => unregisterSensor(id);\n ref.current.isAvailable = true;\n } else {\n // if sensor is unavailable\n ref.current.unregister = () => {\n // NOOP\n };\n ref.current.isAvailable = false;\n }\n return () => {\n ref.current.unregister();\n };\n }, [sensorType, config]);\n return ref.current;\n}\n//# sourceMappingURL=useAnimatedSensor.js.map","'use strict';\n\nimport { useEffect, useRef } from 'react';\nimport FrameCallbackRegistryJS from '../frameCallback/FrameCallbackRegistryJS';\n\n/**\n * @param setActive - A function that lets you start the frame callback or stop it from running.\n * @param isActive - A boolean indicating whether a callback is running.\n * @param callbackId - A number indicating a unique identifier of the frame callback.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/advanced/useFrameCallback#returns\n */\n\nconst frameCallbackRegistry = new FrameCallbackRegistryJS();\n\n/**\n * Lets you run a function on every frame update.\n *\n * @param callback - A function executed on every frame update.\n * @param autostart - Whether the callback should start automatically. Defaults to `true`.\n * @returns A frame callback object - {@link FrameCallback}.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/advanced/useFrameCallback\n */\nexport function useFrameCallback(callback, autostart = true) {\n const ref = useRef({\n setActive: isActive => {\n frameCallbackRegistry.manageStateFrameCallback(ref.current.callbackId, isActive);\n ref.current.isActive = isActive;\n },\n isActive: autostart,\n callbackId: -1\n });\n useEffect(() => {\n ref.current.callbackId = frameCallbackRegistry.registerFrameCallback(callback);\n ref.current.setActive(ref.current.isActive);\n return () => {\n frameCallbackRegistry.unregisterFrameCallback(ref.current.callbackId);\n ref.current.callbackId = -1;\n };\n }, [callback, autostart]);\n return ref.current;\n}\n//# sourceMappingURL=useFrameCallback.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { runOnUI } from '../core';\nimport { prepareUIRegistry } from './FrameCallbackRegistryUI';\nexport default class FrameCallbackRegistryJS {\n constructor() {\n _defineProperty(this, \"nextCallbackId\", 0);\n prepareUIRegistry();\n }\n registerFrameCallback(callback) {\n if (!callback) {\n return -1;\n }\n const callbackId = this.nextCallbackId;\n this.nextCallbackId++;\n runOnUI(() => {\n global._frameCallbackRegistry.registerFrameCallback(callback, callbackId);\n })();\n return callbackId;\n }\n unregisterFrameCallback(callbackId) {\n runOnUI(() => {\n global._frameCallbackRegistry.unregisterFrameCallback(callbackId);\n })();\n }\n manageStateFrameCallback(callbackId, state) {\n runOnUI(() => {\n global._frameCallbackRegistry.manageStateFrameCallback(callbackId, state);\n })();\n }\n}\n//# sourceMappingURL=FrameCallbackRegistryJS.js.map","'use strict';\n\nimport { runOnUIImmediately } from '../threads';\nexport const prepareUIRegistry = runOnUIImmediately(() => {\n 'worklet';\n\n const frameCallbackRegistry = {\n frameCallbackRegistry: new Map(),\n activeFrameCallbacks: new Set(),\n previousFrameTimestamp: null,\n nextCallId: 0,\n runCallbacks(callId) {\n const loop = timestamp => {\n if (callId !== this.nextCallId) {\n return;\n }\n if (this.previousFrameTimestamp === null) {\n this.previousFrameTimestamp = timestamp;\n }\n const delta = timestamp - this.previousFrameTimestamp;\n this.activeFrameCallbacks.forEach(callbackId => {\n const callbackDetails = this.frameCallbackRegistry.get(callbackId);\n const {\n startTime\n } = callbackDetails;\n if (startTime === null) {\n // First frame\n callbackDetails.startTime = timestamp;\n callbackDetails.callback({\n timestamp,\n timeSincePreviousFrame: null,\n timeSinceFirstFrame: 0\n });\n } else {\n // Next frame\n callbackDetails.callback({\n timestamp,\n timeSincePreviousFrame: delta,\n timeSinceFirstFrame: timestamp - startTime\n });\n }\n });\n if (this.activeFrameCallbacks.size > 0) {\n this.previousFrameTimestamp = timestamp;\n requestAnimationFrame(loop);\n } else {\n this.previousFrameTimestamp = null;\n }\n };\n\n // runCallback() should only be called after registering a callback,\n // so if there is only one active callback, then it means that there were\n // zero previously and the loop isn't running yet.\n if (this.activeFrameCallbacks.size === 1 && callId === this.nextCallId) {\n requestAnimationFrame(loop);\n }\n },\n registerFrameCallback(callback, callbackId) {\n this.frameCallbackRegistry.set(callbackId, {\n callback,\n startTime: null\n });\n },\n unregisterFrameCallback(callbackId) {\n this.manageStateFrameCallback(callbackId, false);\n this.frameCallbackRegistry.delete(callbackId);\n },\n manageStateFrameCallback(callbackId, state) {\n if (callbackId === -1) {\n return;\n }\n if (state) {\n this.activeFrameCallbacks.add(callbackId);\n this.runCallbacks(this.nextCallId);\n } else {\n const callback = this.frameCallbackRegistry.get(callbackId);\n callback.startTime = null;\n this.activeFrameCallbacks.delete(callbackId);\n if (this.activeFrameCallbacks.size === 0) {\n this.nextCallId += 1;\n }\n }\n }\n };\n global._frameCallbackRegistry = frameCallbackRegistry;\n});\n//# sourceMappingURL=FrameCallbackRegistryUI.js.map","'use strict';\n\nimport { useEffect, useRef } from 'react';\nimport { makeMutable, subscribeForKeyboardEvents, unsubscribeFromKeyboardEvents } from '../core';\nimport { KeyboardState } from '../commonTypes';\n\n/**\n * Lets you synchronously get the position and state of the keyboard.\n *\n * @param options - An additional keyboard configuration options.\n * @returns An object with the current keyboard `height` and `state` as [shared values](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#shared-value).\n * @see https://docs.swmansion.com/react-native-reanimated/docs/device/useAnimatedKeyboard\n */\nexport function useAnimatedKeyboard(options = {\n isStatusBarTranslucentAndroid: false\n}) {\n const ref = useRef(null);\n const listenerId = useRef(-1);\n const isSubscribed = useRef(false);\n if (ref.current === null) {\n const keyboardEventData = {\n state: makeMutable(KeyboardState.UNKNOWN),\n height: makeMutable(0)\n };\n listenerId.current = subscribeForKeyboardEvents((state, height) => {\n 'worklet';\n\n keyboardEventData.state.value = state;\n keyboardEventData.height.value = height;\n }, options);\n ref.current = keyboardEventData;\n isSubscribed.current = true;\n }\n useEffect(() => {\n if (isSubscribed.current === false && ref.current !== null) {\n const keyboardEventData = ref.current;\n // subscribe again after Fast Refresh\n listenerId.current = subscribeForKeyboardEvents((state, height) => {\n 'worklet';\n\n keyboardEventData.state.value = state;\n keyboardEventData.height.value = height;\n }, options);\n isSubscribed.current = true;\n }\n return () => {\n unsubscribeFromKeyboardEvents(listenerId.current);\n isSubscribed.current = false;\n };\n }, []);\n return ref.current;\n}\n//# sourceMappingURL=useAnimatedKeyboard.js.map","'use strict';\n\nimport { useEffect, useRef, useCallback } from 'react';\nimport { useEvent } from './useEvent';\nimport { useSharedValue } from './useSharedValue';\nimport { isWeb } from '../PlatformChecker';\nconst IS_WEB = isWeb();\n\n/**\n * Lets you synchronously get the current offset of a `ScrollView`.\n *\n * @param animatedRef - An [animated ref](https://docs.swmansion.com/react-native-reanimated/docs/core/useAnimatedRef) attached to an Animated.ScrollView component.\n * @returns A shared value which holds the current offset of the `ScrollView`.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/scroll/useScrollViewOffset\n */\nexport const useScrollViewOffset = IS_WEB ? useScrollViewOffsetWeb : useScrollViewOffsetNative;\nfunction useScrollViewOffsetWeb(animatedRef, providedOffset) {\n const internalOffset = useSharedValue(0);\n const offset = useRef(providedOffset ?? internalOffset).current;\n const scrollRef = useRef(null);\n const eventHandler = useCallback(() => {\n 'worklet';\n\n const element = getWebScrollableElement(animatedRef.current);\n // scrollLeft is the X axis scrolled offset, works properly also with RTL layout\n offset.value = element.scrollLeft === 0 ? element.scrollTop : element.scrollLeft;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [animatedRef, animatedRef.current]);\n useEffect(() => {\n // We need to make sure that listener for old animatedRef value is removed\n if (scrollRef.current !== null) {\n getWebScrollableElement(scrollRef.current).removeEventListener('scroll', eventHandler);\n }\n scrollRef.current = animatedRef.current;\n const element = getWebScrollableElement(animatedRef.current);\n element.addEventListener('scroll', eventHandler);\n return () => {\n element.removeEventListener('scroll', eventHandler);\n };\n // React here has a problem with `animatedRef.current` since a Ref .current\n // field shouldn't be used as a dependency. However, in this case we have\n // to do it this way.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [animatedRef, animatedRef.current, eventHandler]);\n return offset;\n}\nfunction useScrollViewOffsetNative(animatedRef, providedOffset) {\n const internalOffset = useSharedValue(0);\n const offset = useRef(providedOffset ?? internalOffset).current;\n const scrollRef = useRef(null);\n const scrollRefTag = useRef(null);\n const eventHandler = useEvent(event => {\n 'worklet';\n\n offset.value = event.contentOffset.x === 0 ? event.contentOffset.y : event.contentOffset.x;\n }, scrollNativeEventNames\n // Read https://github.com/software-mansion/react-native-reanimated/pull/5056\n // for more information about this cast.\n );\n useEffect(() => {\n // We need to make sure that listener for old animatedRef value is removed\n if (scrollRef.current !== null && scrollRefTag.current !== null) {\n eventHandler.workletEventHandler.unregisterFromEvents(scrollRefTag.current);\n }\n\n // Store the ref and viewTag for future cleanup\n scrollRef.current = animatedRef.current;\n scrollRefTag.current = animatedRef.getTag();\n if (scrollRefTag === null) {\n console.warn('[Reanimated] ScrollViewOffset failed to resolve the view tag from animated ref. Did you forget to attach the ref to a component?');\n } else {\n eventHandler.workletEventHandler.registerForEvents(scrollRefTag.current);\n }\n return () => {\n if (scrollRefTag.current !== null) {\n eventHandler.workletEventHandler.unregisterFromEvents(scrollRefTag.current);\n }\n };\n // React here has a problem with `animatedRef.current` since a Ref .current\n // field shouldn't be used as a dependency. However, in this case we have\n // to do it this way.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [animatedRef, animatedRef.current, eventHandler]);\n return offset;\n}\nfunction getWebScrollableElement(scrollComponent) {\n return (scrollComponent === null || scrollComponent === void 0 ? void 0 : scrollComponent.getScrollableNode()) ?? scrollComponent;\n}\nconst scrollNativeEventNames = ['onScroll', 'onScrollBeginDrag', 'onScrollEndDrag', 'onMomentumScrollBegin', 'onMomentumScrollEnd'];\n//# sourceMappingURL=useScrollViewOffset.js.map","'use strict';\n\n/**\n * Extrapolation type.\n *\n * @param IDENTITY - Returns the provided value as is.\n * @param CLAMP - Clamps the value to the edge of the output range.\n * @param EXTEND - Predicts the values beyond the output range.\n */\nexport let Extrapolation = /*#__PURE__*/function (Extrapolation) {\n Extrapolation[\"IDENTITY\"] = \"identity\";\n Extrapolation[\"CLAMP\"] = \"clamp\";\n Extrapolation[\"EXTEND\"] = \"extend\";\n return Extrapolation;\n}({});\n\n/**\n * Represents the possible values for extrapolation as a string.\n */\n\n/**\n * Allows to specify extrapolation for left and right edge of the interpolation.\n */\n\n/**\n * Configuration options for extrapolation.\n */\n\nfunction getVal(type, coef, val, leftEdgeOutput, rightEdgeOutput, x) {\n 'worklet';\n\n switch (type) {\n case Extrapolation.IDENTITY:\n return x;\n case Extrapolation.CLAMP:\n if (coef * val < coef * leftEdgeOutput) {\n return leftEdgeOutput;\n }\n return rightEdgeOutput;\n case Extrapolation.EXTEND:\n default:\n return val;\n }\n}\nfunction isExtrapolate(value) {\n 'worklet';\n\n return /* eslint-disable @typescript-eslint/no-unsafe-enum-comparison */(\n value === Extrapolation.EXTEND || value === Extrapolation.CLAMP || value === Extrapolation.IDENTITY\n /* eslint-enable @typescript-eslint/no-unsafe-enum-comparison */\n );\n}\n\n// validates extrapolations type\n// if type is correct, converts it to ExtrapolationConfig\nfunction validateType(type) {\n 'worklet';\n\n // initialize extrapolationConfig with default extrapolation\n const extrapolationConfig = {\n extrapolateLeft: Extrapolation.EXTEND,\n extrapolateRight: Extrapolation.EXTEND\n };\n if (!type) {\n return extrapolationConfig;\n }\n if (typeof type === 'string') {\n if (!isExtrapolate(type)) {\n throw new Error(`[Reanimated] Unsupported value for \"interpolate\" \\nSupported values: [\"extend\", \"clamp\", \"identity\", Extrapolatation.CLAMP, Extrapolatation.EXTEND, Extrapolatation.IDENTITY]\\n Valid example:\n interpolate(value, [inputRange], [outputRange], \"clamp\")`);\n }\n extrapolationConfig.extrapolateLeft = type;\n extrapolationConfig.extrapolateRight = type;\n return extrapolationConfig;\n }\n\n // otherwise type is extrapolation config object\n if (type.extrapolateLeft && !isExtrapolate(type.extrapolateLeft) || type.extrapolateRight && !isExtrapolate(type.extrapolateRight)) {\n throw new Error(`[Reanimated] Unsupported value for \"interpolate\" \\nSupported values: [\"extend\", \"clamp\", \"identity\", Extrapolatation.CLAMP, Extrapolatation.EXTEND, Extrapolatation.IDENTITY]\\n Valid example:\n interpolate(value, [inputRange], [outputRange], {\n extrapolateLeft: Extrapolation.CLAMP,\n extrapolateRight: Extrapolation.IDENTITY\n }})`);\n }\n Object.assign(extrapolationConfig, type);\n return extrapolationConfig;\n}\nfunction internalInterpolate(x, narrowedInput, extrapolationConfig) {\n 'worklet';\n\n const {\n leftEdgeInput,\n rightEdgeInput,\n leftEdgeOutput,\n rightEdgeOutput\n } = narrowedInput;\n if (rightEdgeInput - leftEdgeInput === 0) return leftEdgeOutput;\n const progress = (x - leftEdgeInput) / (rightEdgeInput - leftEdgeInput);\n const val = leftEdgeOutput + progress * (rightEdgeOutput - leftEdgeOutput);\n const coef = rightEdgeOutput >= leftEdgeOutput ? 1 : -1;\n if (coef * val < coef * leftEdgeOutput) {\n return getVal(extrapolationConfig.extrapolateLeft, coef, val, leftEdgeOutput, rightEdgeOutput, x);\n } else if (coef * val > coef * rightEdgeOutput) {\n return getVal(extrapolationConfig.extrapolateRight, coef, val, leftEdgeOutput, rightEdgeOutput, x);\n }\n return val;\n}\n\n/**\n * Lets you map a value from one range to another using linear interpolation.\n *\n * @param value - A number from the `input` range that is going to be mapped to the `output` range.\n * @param inputRange - An array of numbers specifying the input range of the interpolation.\n * @param outputRange - An array of numbers specifying the output range of the interpolation.\n * @param extrapolate - determines what happens when the `value` goes beyond the `input` range. Defaults to `Extrapolation.EXTEND` - {@link ExtrapolationType}.\n * @returns A mapped value within the output range.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/utilities/interpolate\n */\nexport function interpolate(x, inputRange, outputRange, type) {\n 'worklet';\n\n if (inputRange.length < 2 || outputRange.length < 2) {\n throw new Error('[Reanimated] Interpolation input and output ranges should contain at least two values.');\n }\n const extrapolationConfig = validateType(type);\n const length = inputRange.length;\n const narrowedInput = {\n leftEdgeInput: inputRange[0],\n rightEdgeInput: inputRange[1],\n leftEdgeOutput: outputRange[0],\n rightEdgeOutput: outputRange[1]\n };\n if (length > 2) {\n if (x > inputRange[length - 1]) {\n narrowedInput.leftEdgeInput = inputRange[length - 2];\n narrowedInput.rightEdgeInput = inputRange[length - 1];\n narrowedInput.leftEdgeOutput = outputRange[length - 2];\n narrowedInput.rightEdgeOutput = outputRange[length - 1];\n } else {\n for (let i = 1; i < length; ++i) {\n if (x <= inputRange[i]) {\n narrowedInput.leftEdgeInput = inputRange[i - 1];\n narrowedInput.rightEdgeInput = inputRange[i];\n narrowedInput.leftEdgeOutput = outputRange[i - 1];\n narrowedInput.rightEdgeOutput = outputRange[i];\n break;\n }\n }\n }\n }\n return internalInterpolate(x, narrowedInput, extrapolationConfig);\n}\n\n/**\n * Lets you limit a value within a specified range.\n *\n * @param value - A number that will be returned as long as the provided value is in range between `min` and `max`.\n * @param min - A number which will be returned when provided `value` is lower than `min`.\n * @param max - A number which will be returned when provided `value` is higher than `max`.\n * @returns A number between min and max bounds.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/utilities/clamp/\n */\nexport function clamp(value, min, max) {\n 'worklet';\n\n return Math.min(Math.max(value, min), max);\n}\n//# sourceMappingURL=interpolation.js.map","'use strict';\n\nimport { hsvToColor, RGBtoHSV, rgbaColor, processColor, red, green, blue, opacity } from './Colors';\nimport { makeMutable } from './core';\nimport { Extrapolation, interpolate } from './interpolation';\nimport { useSharedValue } from './hook/useSharedValue';\n\n/**\n * @deprecated Please use Extrapolation instead\n */\nexport const Extrapolate = Extrapolation;\n\n/**\n * Options for color interpolation.\n *\n * @param gamma - Gamma value used in gamma correction. Defaults to `2.2`.\n * @param useCorrectedHSVInterpolation - Whether to reduce the number of colors the interpolation has to go through. Defaults to `true`.\n */\n\nconst interpolateColorsHSV = (value, inputRange, colors, options) => {\n 'worklet';\n\n let h = 0;\n const {\n useCorrectedHSVInterpolation = true\n } = options;\n if (useCorrectedHSVInterpolation) {\n // if the difference between hues in a range is > 180 deg\n // then move the hue at the right end of the range +/- 360 deg\n // and add the next point in the original place + 0.00001 with original hue\n // to not break the next range\n const correctedInputRange = [inputRange[0]];\n const originalH = colors.h;\n const correctedH = [originalH[0]];\n for (let i = 1; i < originalH.length; ++i) {\n const d = originalH[i] - originalH[i - 1];\n if (originalH[i] > originalH[i - 1] && d > 0.5) {\n correctedInputRange.push(inputRange[i]);\n correctedInputRange.push(inputRange[i] + 0.00001);\n correctedH.push(originalH[i] - 1);\n correctedH.push(originalH[i]);\n } else if (originalH[i] < originalH[i - 1] && d < -0.5) {\n correctedInputRange.push(inputRange[i]);\n correctedInputRange.push(inputRange[i] + 0.00001);\n correctedH.push(originalH[i] + 1);\n correctedH.push(originalH[i]);\n } else {\n correctedInputRange.push(inputRange[i]);\n correctedH.push(originalH[i]);\n }\n }\n h = (interpolate(value, correctedInputRange, correctedH, Extrapolation.CLAMP) + 1) % 1;\n } else {\n h = interpolate(value, inputRange, colors.h, Extrapolation.CLAMP);\n }\n const s = interpolate(value, inputRange, colors.s, Extrapolation.CLAMP);\n const v = interpolate(value, inputRange, colors.v, Extrapolation.CLAMP);\n const a = interpolate(value, inputRange, colors.a, Extrapolation.CLAMP);\n return hsvToColor(h, s, v, a);\n};\nconst toLinearSpace = (x, gamma) => {\n 'worklet';\n\n return x.map(v => Math.pow(v / 255, gamma));\n};\nconst toGammaSpace = (x, gamma) => {\n 'worklet';\n\n return Math.round(Math.pow(x, 1 / gamma) * 255);\n};\nconst interpolateColorsRGB = (value, inputRange, colors, options) => {\n 'worklet';\n\n const {\n gamma = 2.2\n } = options;\n let {\n r: outputR,\n g: outputG,\n b: outputB\n } = colors;\n if (gamma !== 1) {\n outputR = toLinearSpace(outputR, gamma);\n outputG = toLinearSpace(outputG, gamma);\n outputB = toLinearSpace(outputB, gamma);\n }\n const r = interpolate(value, inputRange, outputR, Extrapolation.CLAMP);\n const g = interpolate(value, inputRange, outputG, Extrapolation.CLAMP);\n const b = interpolate(value, inputRange, outputB, Extrapolation.CLAMP);\n const a = interpolate(value, inputRange, colors.a, Extrapolation.CLAMP);\n if (gamma === 1) {\n return rgbaColor(r, g, b, a);\n }\n return rgbaColor(toGammaSpace(r, gamma), toGammaSpace(g, gamma), toGammaSpace(b, gamma), a);\n};\nconst getInterpolateRGB = colors => {\n 'worklet';\n\n const r = [];\n const g = [];\n const b = [];\n const a = [];\n for (let i = 0; i < colors.length; ++i) {\n const color = colors[i];\n const processedColor = processColor(color);\n // explicit check in case if processedColor is 0\n if (processedColor !== null && processedColor !== undefined) {\n r.push(red(processedColor));\n g.push(green(processedColor));\n b.push(blue(processedColor));\n a.push(opacity(processedColor));\n }\n }\n return {\n r,\n g,\n b,\n a\n };\n};\nconst getInterpolateHSV = colors => {\n 'worklet';\n\n const h = [];\n const s = [];\n const v = [];\n const a = [];\n for (let i = 0; i < colors.length; ++i) {\n const color = colors[i];\n const processedColor = processColor(color);\n if (typeof processedColor === 'number') {\n const processedHSVColor = RGBtoHSV(red(processedColor), green(processedColor), blue(processedColor));\n h.push(processedHSVColor.h);\n s.push(processedHSVColor.s);\n v.push(processedHSVColor.v);\n a.push(opacity(processedColor));\n }\n }\n return {\n h,\n s,\n v,\n a\n };\n};\n\n/**\n * Lets you map a value from a range of numbers to a range of colors using linear interpolation.\n *\n * @param value - A number from the `input` range that is going to be mapped to the color in the `output` range.\n * @param inputRange - An array of numbers specifying the input range of the interpolation.\n * @param outputRange - An array of output colors values (eg. \"red\", \"#00FFCC\", \"rgba(255, 0, 0, 0.5)\").\n * @param colorSpace - The color space to use for interpolation. Defaults to 'RGB'.\n * @param options - Additional options for interpolation - {@link InterpolationOptions}.\n * @returns The color after interpolation from within the output range in rgba(r, g, b, a) format.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/utilities/interpolateColor\n */\n\nexport function interpolateColor(value, inputRange, outputRange, colorSpace = 'RGB', options = {}) {\n 'worklet';\n\n if (colorSpace === 'HSV') {\n return interpolateColorsHSV(value, inputRange, getInterpolateHSV(outputRange), options);\n } else if (colorSpace === 'RGB') {\n return interpolateColorsRGB(value, inputRange, getInterpolateRGB(outputRange), options);\n }\n throw new Error(`[Reanimated] Invalid color space provided: ${colorSpace}. Supported values are: ['RGB', 'HSV'].`);\n}\nexport let ColorSpace = /*#__PURE__*/function (ColorSpace) {\n ColorSpace[ColorSpace[\"RGB\"] = 0] = \"RGB\";\n ColorSpace[ColorSpace[\"HSV\"] = 1] = \"HSV\";\n return ColorSpace;\n}({});\nexport function useInterpolateConfig(inputRange, outputRange, colorSpace = ColorSpace.RGB, options = {}) {\n return useSharedValue({\n inputRange,\n outputRange,\n colorSpace,\n cache: makeMutable(null),\n options\n });\n}\n//# sourceMappingURL=interpolateColor.js.map","'use strict';\n\nexport { dispatchCommand } from './dispatchCommand';\nexport { measure } from './measure';\nexport { scrollTo } from './scrollTo';\nexport { setGestureState } from './setGestureState';\nexport { setNativeProps } from './setNativeProps';\nexport { getRelativeCoords } from './getRelativeCoords';\n//# sourceMappingURL=index.js.map","'use strict';\n\nexport function dispatchCommand() {\n console.warn('[Reanimated] dispatchCommand() is not supported on web.');\n}\n//# sourceMappingURL=dispatchCommand.web.js.map","'use strict';\n\nexport function measure(animatedRef) {\n const element = animatedRef();\n if (element === -1) {\n console.warn(`[Reanimated] The view with tag ${element} is not a valid argument for measure(). This may be because the view is not currently rendered, which may not be a bug (e.g. an off-screen FlatList item).`);\n return null;\n }\n const viewportOffset = element.getBoundingClientRect();\n return {\n width: element.offsetWidth,\n height: element.offsetHeight,\n x: element.offsetLeft,\n y: element.offsetTop,\n pageX: viewportOffset.left,\n pageY: viewportOffset.top\n };\n}\n//# sourceMappingURL=measure.web.js.map","'use strict';\n\nexport function scrollTo(animatedRef, x, y, animated) {\n const element = animatedRef();\n\n // This prevents crashes if ref has not been set yet\n if (element !== -1) {\n // By ScrollView we mean any scrollable component\n const scrollView = element;\n scrollView === null || scrollView === void 0 || scrollView.scrollTo({\n x,\n y,\n animated\n });\n }\n}\n//# sourceMappingURL=scrollTo.web.js.map","'use strict';\n\nexport function setGestureState() {\n console.warn('[Reanimated] setGestureState() is not available on web.');\n}\n//# sourceMappingURL=setGestureState.web.js.map","'use strict';\n\nimport { _updatePropsJS } from '../js-reanimated';\nexport function setNativeProps(animatedRef, updates) {\n const component = animatedRef();\n _updatePropsJS(updates, {\n _component: component\n });\n}\n//# sourceMappingURL=setNativeProps.web.js.map","'use strict';\n\nimport { measure } from './measure';\n\n/**\n * An object which contains relative coordinates.\n */\n\n/**\n * Lets you determines the location on the screen, relative to the given view.\n *\n * @param animatedRef - An [animated ref](https://docs.swmansion.com/react-native-reanimated/docs/core/useAnimatedRef#returns) connected to the component you'd want to get the coordinates from.\n * @param absoluteX - A number which is an absolute x coordinate.\n * @param absoluteY - A number which is an absolute y coordinate.\n * @returns An object which contains relative coordinates - {@link ComponentCoords}.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/utilities/getRelativeCoords\n */\nexport function getRelativeCoords(animatedRef, absoluteX, absoluteY) {\n 'worklet';\n\n const parentCoords = measure(animatedRef);\n if (parentCoords === null) {\n return null;\n }\n return {\n x: absoluteX - parentCoords.pageX,\n y: absoluteY - parentCoords.pageY\n };\n}\n//# sourceMappingURL=getRelativeCoords.js.map","'use strict';\n\nimport { addWhitelistedNativeProps } from '../ConfigHelper';\n\n// @ts-expect-error This overload is required by our API.\n\nexport function createAnimatedPropAdapter(adapter, nativeProps) {\n const nativePropsToAdd = {};\n nativeProps === null || nativeProps === void 0 || nativeProps.forEach(prop => {\n nativePropsToAdd[prop] = true;\n });\n addWhitelistedNativeProps(nativePropsToAdd);\n return adapter;\n}\n//# sourceMappingURL=PropAdapters.js.map","'use strict';\n\nimport { PropsAllowlists } from './propsAllowlists';\nimport { jsiConfigureProps } from './reanimated2/core';\nfunction assertNoOverlapInLists() {\n for (const key in PropsAllowlists.NATIVE_THREAD_PROPS_WHITELIST) {\n if (key in PropsAllowlists.UI_THREAD_PROPS_WHITELIST) {\n throw new Error(`[Reanimated] Property \\`${key}\\` was whitelisted both as UI and native prop. Please remove it from one of the lists.`);\n }\n }\n}\nexport function configureProps() {\n assertNoOverlapInLists();\n jsiConfigureProps(Object.keys(PropsAllowlists.UI_THREAD_PROPS_WHITELIST), Object.keys(PropsAllowlists.NATIVE_THREAD_PROPS_WHITELIST));\n}\nexport function addWhitelistedNativeProps(props) {\n const oldSize = Object.keys(PropsAllowlists.NATIVE_THREAD_PROPS_WHITELIST).length;\n PropsAllowlists.NATIVE_THREAD_PROPS_WHITELIST = {\n ...PropsAllowlists.NATIVE_THREAD_PROPS_WHITELIST,\n ...props\n };\n if (oldSize !== Object.keys(PropsAllowlists.NATIVE_THREAD_PROPS_WHITELIST).length) {\n configureProps();\n }\n}\nexport function addWhitelistedUIProps(props) {\n const oldSize = Object.keys(PropsAllowlists.UI_THREAD_PROPS_WHITELIST).length;\n PropsAllowlists.UI_THREAD_PROPS_WHITELIST = {\n ...PropsAllowlists.UI_THREAD_PROPS_WHITELIST,\n ...props\n };\n if (oldSize !== Object.keys(PropsAllowlists.UI_THREAD_PROPS_WHITELIST).length) {\n configureProps();\n }\n}\nconst PROCESSED_VIEW_NAMES = new Set();\n/**\n * updates UI props whitelist for given view host instance\n * this will work just once for every view name\n */\n\nexport function adaptViewConfig(viewConfig) {\n const viewName = viewConfig.uiViewClassName;\n const props = viewConfig.validAttributes;\n\n // update whitelist of UI props for this view name only once\n if (!PROCESSED_VIEW_NAMES.has(viewName)) {\n const propsToAdd = {};\n Object.keys(props).forEach(key => {\n // we don't want to add native props as they affect layout\n // we also skip props which repeat here\n if (!(key in PropsAllowlists.NATIVE_THREAD_PROPS_WHITELIST) && !(key in PropsAllowlists.UI_THREAD_PROPS_WHITELIST)) {\n propsToAdd[key] = true;\n }\n });\n addWhitelistedUIProps(propsToAdd);\n PROCESSED_VIEW_NAMES.add(viewName);\n }\n}\nconfigureProps();\n//# sourceMappingURL=ConfigHelper.js.map","'use strict';\n\nimport './animationsManager';\nexport * from './animationBuilder';\nexport * from './defaultAnimations';\nexport * from './defaultTransitions';\nexport * from './sharedTransitions';\n//# sourceMappingURL=index.js.map","'use strict';\n\nimport { withStyleAnimation } from '../animation/styleAnimation';\nimport { makeUIMutable } from '../mutables';\nimport { LayoutAnimationType } from './animationBuilder';\nimport { runOnUIImmediately } from '../threads';\nconst TAG_OFFSET = 1e9;\nfunction startObservingProgress(tag, sharedValue, animationType) {\n 'worklet';\n\n const isSharedTransition = animationType === LayoutAnimationType.SHARED_ELEMENT_TRANSITION;\n sharedValue.addListener(tag + TAG_OFFSET, () => {\n global._notifyAboutProgress(tag, sharedValue.value, isSharedTransition);\n });\n}\nfunction stopObservingProgress(tag, sharedValue, removeView = false) {\n 'worklet';\n\n sharedValue.removeListener(tag + TAG_OFFSET);\n global._notifyAboutEnd(tag, removeView);\n}\nfunction createLayoutAnimationManager() {\n 'worklet';\n\n const currentAnimationForTag = new Map();\n const mutableValuesForTag = new Map();\n return {\n start(tag, type,\n /**\n * createLayoutAnimationManager creates an animation manager for both Layout animations and Shared Transition Elements animations.\n */\n yogaValues, config) {\n if (type === LayoutAnimationType.SHARED_ELEMENT_TRANSITION_PROGRESS) {\n global.ProgressTransitionRegister.onTransitionStart(tag, yogaValues);\n return;\n }\n const style = config(yogaValues);\n let currentAnimation = style.animations;\n\n // When layout animation is requested, but a previous one is still running, we merge\n // new layout animation targets into the ongoing animation\n const previousAnimation = currentAnimationForTag.get(tag);\n if (previousAnimation) {\n currentAnimation = {\n ...previousAnimation,\n ...style.animations\n };\n }\n currentAnimationForTag.set(tag, currentAnimation);\n let value = mutableValuesForTag.get(tag);\n if (value === undefined) {\n value = makeUIMutable(style.initialValues);\n mutableValuesForTag.set(tag, value);\n } else {\n stopObservingProgress(tag, value);\n value._value = style.initialValues;\n }\n\n // @ts-ignore The line below started failing because I added types to the method – don't have time to fix it right now\n const animation = withStyleAnimation(currentAnimation);\n animation.callback = finished => {\n if (finished) {\n currentAnimationForTag.delete(tag);\n mutableValuesForTag.delete(tag);\n const shouldRemoveView = type === LayoutAnimationType.EXITING;\n stopObservingProgress(tag, value, shouldRemoveView);\n }\n style.callback && style.callback(finished === undefined ? false : finished);\n };\n startObservingProgress(tag, value, type);\n value.value = animation;\n },\n stop(tag) {\n const value = mutableValuesForTag.get(tag);\n if (!value) {\n return;\n }\n stopObservingProgress(tag, value);\n }\n };\n}\nrunOnUIImmediately(() => {\n 'worklet';\n\n global.LayoutAnimationsManager = createLayoutAnimationManager();\n})();\n//# sourceMappingURL=animationsManager.js.map","'use strict';\n\nexport { BaseAnimationBuilder } from './BaseAnimationBuilder';\nexport { ComplexAnimationBuilder } from './ComplexAnimationBuilder';\nexport { Keyframe } from './Keyframe';\nexport { LayoutAnimationType, SharedTransitionType } from './commonTypes';\n//# sourceMappingURL=index.js.map","'use strict';\n\nvar _BaseAnimationBuilder;\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { withDelay } from '../../animation';\nimport { ReduceMotion } from '../../commonTypes';\nimport { getReduceMotionFromConfig } from '../../animation/util';\nexport class BaseAnimationBuilder {\n constructor() {\n _defineProperty(this, \"durationV\", void 0);\n _defineProperty(this, \"delayV\", void 0);\n _defineProperty(this, \"reduceMotionV\", ReduceMotion.System);\n _defineProperty(this, \"randomizeDelay\", false);\n _defineProperty(this, \"callbackV\", void 0);\n _defineProperty(this, \"build\", () => {\n throw new Error('[Reanimated] Unimplemented method in child class.');\n });\n }\n /**\n * Lets you adjust the animation duration. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param durationMs - Length of the animation (in milliseconds).\n */\n static duration(durationMs) {\n const instance = this.createInstance();\n return instance.duration(durationMs);\n }\n duration(durationMs) {\n this.durationV = durationMs;\n return this;\n }\n\n /**\n * Lets you adjust the delay before the animation starts (in milliseconds). Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param delayMs - Delay before the animation starts (in milliseconds).\n */\n static delay(delayMs) {\n const instance = this.createInstance();\n return instance.delay(delayMs);\n }\n delay(delayMs) {\n this.delayV = delayMs;\n return this;\n }\n\n /**\n * The callback that will fire after the animation ends. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param callback - Callback that will fire after the animation ends.\n */\n static withCallback(callback) {\n const instance = this.createInstance();\n return instance.withCallback(callback);\n }\n withCallback(callback) {\n this.callbackV = callback;\n return this;\n }\n\n /**\n * Lets you adjust the behavior when the device's reduced motion accessibility setting is turned on. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param reduceMotion - Determines how the animation responds to the device's reduced motion accessibility setting. Default to `ReduceMotion.System` - {@link ReduceMotion}.\n */\n static reduceMotion(reduceMotion) {\n const instance = this.createInstance();\n return instance.reduceMotion(reduceMotion);\n }\n reduceMotion(reduceMotionV) {\n this.reduceMotionV = reduceMotionV;\n return this;\n }\n\n // 300ms is the default animation duration. If any animation has different default has to override this method.\n static getDuration() {\n return 300;\n }\n getDuration() {\n return this.durationV ?? 300;\n }\n\n /**\n * @deprecated Use `.delay()` with `Math.random()` instead\n */\n static randomDelay() {\n const instance = this.createInstance();\n return instance.randomDelay();\n }\n randomDelay() {\n this.randomizeDelay = true;\n return this;\n }\n\n // when randomizeDelay is set to true, randomize delay between 0 and provided value (or 1000ms if delay is not provided)\n getDelay() {\n return this.randomizeDelay ? Math.random() * (this.delayV ?? 1000) : this.delayV ?? 0;\n }\n getReduceMotion() {\n return this.reduceMotionV;\n }\n getDelayFunction() {\n const isDelayProvided = this.randomizeDelay || this.delayV;\n const reduceMotion = this.getReduceMotion();\n return isDelayProvided ? (delay, animation) => {\n 'worklet';\n\n return withDelay(delay, animation, reduceMotion);\n } : (_, animation) => {\n 'worklet';\n\n animation.reduceMotion = getReduceMotionFromConfig(reduceMotion);\n return animation;\n };\n }\n static build() {\n const instance = this.createInstance();\n return instance.build();\n }\n}\n_BaseAnimationBuilder = BaseAnimationBuilder;\n_defineProperty(BaseAnimationBuilder, \"createInstance\", void 0);\n//# sourceMappingURL=BaseAnimationBuilder.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { withTiming, withSpring } from '../../animation';\nimport { BaseAnimationBuilder } from './BaseAnimationBuilder';\nimport { assertEasingIsWorklet } from '../../animation/util';\nexport class ComplexAnimationBuilder extends BaseAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"easingV\", void 0);\n _defineProperty(this, \"rotateV\", void 0);\n _defineProperty(this, \"type\", void 0);\n _defineProperty(this, \"dampingV\", void 0);\n _defineProperty(this, \"dampingRatioV\", void 0);\n _defineProperty(this, \"massV\", void 0);\n _defineProperty(this, \"stiffnessV\", void 0);\n _defineProperty(this, \"overshootClampingV\", void 0);\n _defineProperty(this, \"restDisplacementThresholdV\", void 0);\n _defineProperty(this, \"restSpeedThresholdV\", void 0);\n _defineProperty(this, \"initialValues\", void 0);\n }\n /**\n * Lets you change the easing curve of the animation. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param easingFunction - An easing function which defines the animation curve.\n */\n static easing(easingFunction) {\n const instance = this.createInstance();\n return instance.easing(easingFunction);\n }\n easing(easingFunction) {\n if (__DEV__) {\n assertEasingIsWorklet(easingFunction);\n }\n this.easingV = easingFunction;\n return this;\n }\n\n /**\n * Lets you rotate the element. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param degree - The rotation degree.\n */\n static rotate(degree) {\n const instance = this.createInstance();\n return instance.rotate(degree);\n }\n rotate(degree) {\n this.rotateV = degree;\n return this;\n }\n\n /**\n * Enables the spring-based animation configuration. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param duration - An optional duration of the spring animation (in milliseconds).\n */\n static springify(duration) {\n const instance = this.createInstance();\n return instance.springify(duration);\n }\n springify(duration) {\n this.durationV = duration;\n this.type = withSpring;\n return this;\n }\n\n /**\n * Lets you adjust the spring animation damping ratio. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param dampingRatio - How damped the spring is.\n */\n static dampingRatio(dampingRatio) {\n const instance = this.createInstance();\n return instance.dampingRatio(dampingRatio);\n }\n dampingRatio(value) {\n this.dampingRatioV = value;\n return this;\n }\n\n /**\n * Lets you adjust the spring animation damping. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param value - Decides how quickly a spring stops moving. Higher damping means the spring will come to rest faster.\n */\n static damping(damping) {\n const instance = this.createInstance();\n return instance.damping(damping);\n }\n damping(damping) {\n this.dampingV = damping;\n return this;\n }\n\n /**\n * Lets you adjust the spring animation mass. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param mass - The weight of the spring. Reducing this value makes the animation faster.\n */\n static mass(mass) {\n const instance = this.createInstance();\n return instance.mass(mass);\n }\n mass(mass) {\n this.massV = mass;\n return this;\n }\n\n /**\n * Lets you adjust the stiffness of the spring animation. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param stiffness - How bouncy the spring is.\n */\n static stiffness(stiffness) {\n const instance = this.createInstance();\n return instance.stiffness(stiffness);\n }\n stiffness(stiffness) {\n this.stiffnessV = stiffness;\n return this;\n }\n\n /**\n * Lets you adjust overshoot clamping of the spring. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param overshootClamping - Whether a spring can bounce over the final position.\n */\n static overshootClamping(overshootClamping) {\n const instance = this.createInstance();\n return instance.overshootClamping(overshootClamping);\n }\n overshootClamping(overshootClamping) {\n this.overshootClampingV = overshootClamping;\n return this;\n }\n\n /**\n * Lets you adjust the rest displacement threshold of the spring animation. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param restDisplacementThreshold - The displacement below which the spring will snap to the designated position without further oscillations.\n */\n static restDisplacementThreshold(restDisplacementThreshold) {\n const instance = this.createInstance();\n return instance.restDisplacementThreshold(restDisplacementThreshold);\n }\n restDisplacementThreshold(restDisplacementThreshold) {\n this.restDisplacementThresholdV = restDisplacementThreshold;\n return this;\n }\n\n /**\n * Lets you adjust the rest speed threshold of the spring animation. Can be chained alongside other [layout animation modifiers](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#layout-animation-modifier).\n *\n * @param restSpeedThreshold - The speed in pixels per second from which the spring will snap to the designated position without further oscillations.\n */\n static restSpeedThreshold(restSpeedThreshold) {\n const instance = this.createInstance();\n return instance.restSpeedThreshold(restSpeedThreshold);\n }\n restSpeedThreshold(restSpeedThreshold) {\n this.restSpeedThresholdV = restSpeedThreshold;\n return this;\n }\n\n /**\n * Lets you override the initial config of the animation\n *\n * @param values - An object containing the styles to override.\n */\n static withInitialValues(values) {\n const instance = this.createInstance();\n return instance.withInitialValues(values);\n }\n withInitialValues(values) {\n this.initialValues = values;\n return this;\n }\n getAnimationAndConfig() {\n const duration = this.durationV;\n const easing = this.easingV;\n const rotate = this.rotateV;\n const type = this.type ? this.type : withTiming;\n const damping = this.dampingV;\n const dampingRatio = this.dampingRatioV;\n const mass = this.massV;\n const stiffness = this.stiffnessV;\n const overshootClamping = this.overshootClampingV;\n const restDisplacementThreshold = this.restDisplacementThresholdV;\n const restSpeedThreshold = this.restSpeedThresholdV;\n const animation = type;\n const config = {};\n function maybeSetConfigValue(value, variableName) {\n if (value) {\n config[variableName] = value;\n }\n }\n if (type === withTiming) {\n maybeSetConfigValue(easing, 'easing');\n }\n [{\n variableName: 'damping',\n value: damping\n }, {\n variableName: 'dampingRatio',\n value: dampingRatio\n }, {\n variableName: 'mass',\n value: mass\n }, {\n variableName: 'stiffness',\n value: stiffness\n }, {\n variableName: 'overshootClamping',\n value: overshootClamping\n }, {\n variableName: 'restDisplacementThreshold',\n value: restDisplacementThreshold\n }, {\n variableName: 'restSpeedThreshold',\n value: restSpeedThreshold\n }, {\n variableName: 'duration',\n value: duration\n }, {\n variableName: 'rotate',\n value: rotate\n }].forEach(({\n value,\n variableName\n }) => maybeSetConfigValue(value, variableName));\n return [animation, config];\n }\n}\n_defineProperty(ComplexAnimationBuilder, \"createInstance\", void 0);\n//# sourceMappingURL=ComplexAnimationBuilder.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { Easing } from '../../Easing';\nimport { withDelay, withSequence, withTiming } from '../../animation';\nimport { ReduceMotion } from '../../commonTypes';\nimport { assertEasingIsWorklet, getReduceMotionFromConfig } from '../../animation/util';\nclass InnerKeyframe {\n /*\n Keyframe definition should be passed in the constructor as the map\n which keys are between range 0 - 100 (%) and correspond to the point in the animation progress.\n */\n constructor(definitions) {\n _defineProperty(this, \"durationV\", void 0);\n _defineProperty(this, \"delayV\", void 0);\n _defineProperty(this, \"reduceMotionV\", ReduceMotion.System);\n _defineProperty(this, \"callbackV\", void 0);\n _defineProperty(this, \"definitions\", void 0);\n _defineProperty(this, \"build\", () => {\n const delay = this.delayV;\n const delayFunction = this.getDelayFunction();\n const {\n keyframes,\n initialValues\n } = this.parseDefinitions();\n const callback = this.callbackV;\n return () => {\n 'worklet';\n\n const animations = {};\n\n /* \n For each style property, an animations sequence is created that corresponds with its key points.\n Transform style properties require special handling because of their nested structure.\n */\n const addAnimation = key => {\n const keyframePoints = keyframes[key];\n // in case if property was only passed as initial value\n if (keyframePoints.length === 0) {\n return;\n }\n const animation = delayFunction(delay, keyframePoints.length === 1 ? withTiming(keyframePoints[0].value, {\n duration: keyframePoints[0].duration,\n easing: keyframePoints[0].easing ? keyframePoints[0].easing : Easing.linear\n }) : withSequence(...keyframePoints.map(keyframePoint => withTiming(keyframePoint.value, {\n duration: keyframePoint.duration,\n easing: keyframePoint.easing ? keyframePoint.easing : Easing.linear\n }))));\n if (key.includes('transform')) {\n if (!('transform' in animations)) {\n animations.transform = [];\n }\n animations.transform.push({\n [key.split(':')[1]]: animation\n });\n } else {\n animations[key] = animation;\n }\n };\n Object.keys(initialValues).forEach(key => {\n if (key.includes('transform')) {\n initialValues[key].forEach((transformProp, index) => {\n Object.keys(transformProp).forEach(transformPropKey => {\n addAnimation(makeKeyframeKey(index, transformPropKey));\n });\n });\n } else {\n addAnimation(key);\n }\n });\n return {\n animations,\n initialValues,\n callback\n };\n };\n });\n this.definitions = definitions;\n }\n parseDefinitions() {\n /* \n Each style property contain an array with all their key points: \n value, duration of transition to that value, and optional easing function (defaults to Linear)\n */\n const parsedKeyframes = {};\n /*\n Parsing keyframes 'from' and 'to'.\n */\n if (this.definitions.from) {\n if (this.definitions['0']) {\n throw new Error(\"[Reanimated] You cannot provide both keyframe 0 and 'from' as they both specified initial values.\");\n }\n this.definitions['0'] = this.definitions.from;\n delete this.definitions.from;\n }\n if (this.definitions.to) {\n if (this.definitions['100']) {\n throw new Error(\"[Reanimated] You cannot provide both keyframe 100 and 'to' as they both specified values at the end of the animation.\");\n }\n this.definitions['100'] = this.definitions.to;\n delete this.definitions.to;\n }\n /* \n One of the assumptions is that keyframe 0 is required to properly set initial values.\n Every other keyframe should contain properties from the set provided as initial values.\n */\n if (!this.definitions['0']) {\n throw new Error(\"[Reanimated] Please provide 0 or 'from' keyframe with initial state of your object.\");\n }\n const initialValues = this.definitions['0'];\n /*\n Initialize parsedKeyframes for properties provided in initial keyframe\n */\n Object.keys(initialValues).forEach(styleProp => {\n if (styleProp === 'transform') {\n if (!Array.isArray(initialValues.transform)) {\n return;\n }\n initialValues.transform.forEach((transformStyle, index) => {\n Object.keys(transformStyle).forEach(transformProp => {\n parsedKeyframes[makeKeyframeKey(index, transformProp)] = [];\n });\n });\n } else {\n parsedKeyframes[styleProp] = [];\n }\n });\n const duration = this.durationV ? this.durationV : 500;\n const animationKeyPoints = Array.from(Object.keys(this.definitions));\n const getAnimationDuration = (key, currentKeyPoint) => {\n const maxDuration = currentKeyPoint / 100 * duration;\n const currentDuration = parsedKeyframes[key].reduce((acc, value) => acc + value.duration, 0);\n return maxDuration - currentDuration;\n };\n\n /* \n Other keyframes can't contain properties that were not specified in initial keyframe.\n */\n const addKeyPoint = ({\n key,\n value,\n currentKeyPoint,\n easing\n }) => {\n if (!(key in parsedKeyframes)) {\n throw new Error(\"[Reanimated] Keyframe can contain only that set of properties that were provide with initial values (keyframe 0 or 'from')\");\n }\n if (__DEV__ && easing) {\n assertEasingIsWorklet(easing);\n }\n parsedKeyframes[key].push({\n duration: getAnimationDuration(key, currentKeyPoint),\n value,\n easing\n });\n };\n animationKeyPoints.filter(value => parseInt(value) !== 0).sort((a, b) => parseInt(a) - parseInt(b)).forEach(keyPoint => {\n if (parseInt(keyPoint) < 0 || parseInt(keyPoint) > 100) {\n throw new Error('[Reanimated] Keyframe should be in between range 0 - 100.');\n }\n const keyframe = this.definitions[keyPoint];\n const easing = keyframe.easing;\n delete keyframe.easing;\n const addKeyPointWith = (key, value) => addKeyPoint({\n key,\n value,\n currentKeyPoint: parseInt(keyPoint),\n easing\n });\n Object.keys(keyframe).forEach(key => {\n if (key === 'transform') {\n if (!Array.isArray(keyframe.transform)) {\n return;\n }\n keyframe.transform.forEach((transformStyle, index) => {\n Object.keys(transformStyle).forEach(transformProp => {\n addKeyPointWith(makeKeyframeKey(index, transformProp), transformStyle[transformProp] // Here we assume that user has passed props of proper type.\n // I don't think it's worthwhile to check if he passed i.e. `Animated.Node`.\n );\n });\n });\n } else {\n addKeyPointWith(key, keyframe[key]);\n }\n });\n });\n return {\n initialValues,\n keyframes: parsedKeyframes\n };\n }\n duration(durationMs) {\n this.durationV = durationMs;\n return this;\n }\n delay(delayMs) {\n this.delayV = delayMs;\n return this;\n }\n withCallback(callback) {\n this.callbackV = callback;\n return this;\n }\n reduceMotion(reduceMotionV) {\n this.reduceMotionV = reduceMotionV;\n return this;\n }\n getDelayFunction() {\n const delay = this.delayV;\n const reduceMotion = this.reduceMotionV;\n return delay ?\n // eslint-disable-next-line @typescript-eslint/no-shadow\n (delay, animation) => {\n 'worklet';\n\n return withDelay(delay, animation, reduceMotion);\n } : (_, animation) => {\n 'worklet';\n\n animation.reduceMotion = getReduceMotionFromConfig(reduceMotion);\n return animation;\n };\n }\n}\nfunction makeKeyframeKey(index, transformProp) {\n 'worklet';\n\n return `${index}_transform:${transformProp}`;\n}\n\n// TODO TYPESCRIPT This is a temporary type to get rid of .d.ts file.\n\n// TODO TYPESCRIPT This temporary cast is to get rid of .d.ts file.\nexport const Keyframe = InnerKeyframe;\n//# sourceMappingURL=Keyframe.js.map","'use strict';\n\n// this is just a temporary mock\n\nexport let LayoutAnimationType = /*#__PURE__*/function (LayoutAnimationType) {\n LayoutAnimationType[LayoutAnimationType[\"ENTERING\"] = 1] = \"ENTERING\";\n LayoutAnimationType[LayoutAnimationType[\"EXITING\"] = 2] = \"EXITING\";\n LayoutAnimationType[LayoutAnimationType[\"LAYOUT\"] = 3] = \"LAYOUT\";\n LayoutAnimationType[LayoutAnimationType[\"SHARED_ELEMENT_TRANSITION\"] = 4] = \"SHARED_ELEMENT_TRANSITION\";\n LayoutAnimationType[LayoutAnimationType[\"SHARED_ELEMENT_TRANSITION_PROGRESS\"] = 5] = \"SHARED_ELEMENT_TRANSITION_PROGRESS\";\n return LayoutAnimationType;\n}({});\n/**\n * Used to configure the `.defaultTransitionType()` shared transition modifier.\n * @experimental\n */\nexport let SharedTransitionType = /*#__PURE__*/function (SharedTransitionType) {\n SharedTransitionType[\"ANIMATION\"] = \"animation\";\n SharedTransitionType[\"PROGRESS_ANIMATION\"] = \"progressAnimation\";\n return SharedTransitionType;\n}({});\n//# sourceMappingURL=commonTypes.js.map","'use strict';\n\nexport * from './Flip';\nexport * from './Stretch';\nexport * from './Fade';\nexport * from './Slide';\nexport * from './Zoom';\nexport * from './Bounce';\nexport * from './Lightspeed';\nexport * from './Pinwheel';\nexport * from './Rotate';\nexport * from './Roll';\n//# sourceMappingURL=index.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\n/**\n * Rotate from top on the X axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\nexport class FlipInXUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return targetValues => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateX: '90deg'\n }, {\n translateY: -targetValues.targetHeight\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: 500\n }, {\n rotateX: delayFunction(delay, animation('0deg', config))\n }, {\n translateY: delayFunction(delay, animation(0, config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipInXUp();\n }\n}\n\n/**\n * Rotate from left on the Y axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipInXUp, \"presetName\", 'FlipInXUp');\nexport class FlipInYLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return targetValues => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateY: '-90deg'\n }, {\n translateX: -targetValues.targetWidth\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateY: delayFunction(delay, animation('0deg', config))\n }, {\n translateX: delayFunction(delay, animation(0, config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipInYLeft();\n }\n}\n\n/**\n * Rotate from bottom on the X axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipInYLeft, \"presetName\", 'FlipInYLeft');\nexport class FlipInXDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return targetValues => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateX: '-90deg'\n }, {\n translateY: targetValues.targetHeight\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateX: delayFunction(delay, animation('0deg', config))\n }, {\n translateY: delayFunction(delay, animation(0, config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipInXDown();\n }\n}\n\n/**\n * Rotate from right on the Y axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipInXDown, \"presetName\", 'FlipInXDown');\nexport class FlipInYRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return targetValues => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateY: '90deg'\n }, {\n translateX: targetValues.targetWidth\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateY: delayFunction(delay, animation('0deg', config))\n }, {\n translateX: delayFunction(delay, animation(0, config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipInYRight();\n }\n}\n\n/**\n * Eased rotate in on the X axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipInYRight, \"presetName\", 'FlipInYRight');\nexport class FlipInEasyX extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateX: '90deg'\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateX: delayFunction(delay, animation('0deg', config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipInEasyX();\n }\n}\n\n/**\n * Eased rotate in on the Y axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipInEasyX, \"presetName\", 'FlipInEasyX');\nexport class FlipInEasyY extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateY: '90deg'\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateY: delayFunction(delay, animation('0deg', config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipInEasyY();\n }\n}\n\n/**\n * Rotate to top animation on the X axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipInEasyY, \"presetName\", 'FlipInEasyY');\nexport class FlipOutXUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return targetValues => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateX: '0deg'\n }, {\n translateY: 0\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateX: delayFunction(delay, animation('90deg', config))\n }, {\n translateY: delayFunction(delay, animation(-targetValues.currentHeight, config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipOutXUp();\n }\n}\n\n/**\n * Rotate to left on the Y axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipOutXUp, \"presetName\", 'FlipOutXUp');\nexport class FlipOutYLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return targetValues => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateY: '0deg'\n }, {\n translateX: 0\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateY: delayFunction(delay, animation('-90deg', config))\n }, {\n translateX: delayFunction(delay, animation(-targetValues.currentWidth, config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipOutYLeft();\n }\n}\n\n/**\n * Rotate to bottom on the X axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipOutYLeft, \"presetName\", 'FlipOutYLeft');\nexport class FlipOutXDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return targetValues => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateX: '0deg'\n }, {\n translateY: 0\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateX: delayFunction(delay, animation('-90deg', config))\n }, {\n translateY: delayFunction(delay, animation(targetValues.currentHeight, config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipOutXDown();\n }\n}\n\n/**\n * Rotate to right animation on the Y axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipOutXDown, \"presetName\", 'FlipOutXDown');\nexport class FlipOutYRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return targetValues => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateY: '0deg'\n }, {\n translateX: 0\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateY: delayFunction(delay, animation('90deg', config))\n }, {\n translateX: delayFunction(delay, animation(targetValues.currentWidth, config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipOutYRight();\n }\n}\n\n/**\n * Eased rotate on the X axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipOutYRight, \"presetName\", 'FlipOutYRight');\nexport class FlipOutEasyX extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateX: '0deg'\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateX: delayFunction(delay, animation('90deg', config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipOutEasyX();\n }\n}\n\n/**\n * Eased rotate on the Y axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#flip\n */\n_defineProperty(FlipOutEasyX, \"presetName\", 'FlipOutEasyX');\nexport class FlipOutEasyY extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n initialValues: {\n transform: [{\n perspective: 500\n }, {\n rotateY: '0deg'\n }],\n ...initialValues\n },\n animations: {\n transform: [{\n perspective: delayFunction(delay, animation(500, config))\n }, {\n rotateY: delayFunction(delay, animation('90deg', config))\n }]\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FlipOutEasyY();\n }\n}\n_defineProperty(FlipOutEasyY, \"presetName\", 'FlipOutEasyY');\n//# sourceMappingURL=Flip.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\n/**\n * Stretch animation on the X axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#stretch\n */\nexport class StretchInX extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scaleX: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n scaleX: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new StretchInX();\n }\n}\n\n/**\n * Stretch animation on the Y axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#stretch\n */\n_defineProperty(StretchInX, \"presetName\", 'StretchInX');\nexport class StretchInY extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scaleY: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n scaleY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new StretchInY();\n }\n}\n\n/**\n * Stretch animation on the X axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#stretch\n */\n_defineProperty(StretchInY, \"presetName\", 'StretchInY');\nexport class StretchOutX extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scaleX: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n scaleX: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new StretchOutX();\n }\n}\n\n/**\n * Stretch animation on the Y axis. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#stretch\n */\n_defineProperty(StretchOutX, \"presetName\", 'StretchOutX');\nexport class StretchOutY extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scaleY: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n scaleY: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new StretchOutY();\n }\n}\n_defineProperty(StretchOutY, \"presetName\", 'StretchOutY');\n//# sourceMappingURL=Stretch.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\n/**\n * Fade in animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\nexport class FadeIn extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config))\n },\n initialValues: {\n opacity: 0,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeIn();\n }\n}\n\n/**\n * Fade from right animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeIn, \"presetName\", 'FadeIn');\nexport class FadeInRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n translateX: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n translateX: 25\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeInRight();\n }\n}\n\n/**\n * Fade from left animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeInRight, \"presetName\", 'FadeInRight');\nexport class FadeInLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n translateX: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n translateX: -25\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeInLeft();\n }\n}\n\n/**\n * Fade from top animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeInLeft, \"presetName\", 'FadeInLeft');\nexport class FadeInUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n translateY: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n translateY: -25\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeInUp();\n }\n}\n\n/**\n * Fade from bottom animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeInUp, \"presetName\", 'FadeInUp');\nexport class FadeInDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n translateY: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n translateY: 25\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeInDown();\n }\n}\n\n/**\n * Fade out animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeInDown, \"presetName\", 'FadeInDown');\nexport class FadeOut extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config))\n },\n initialValues: {\n opacity: 1,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeOut();\n }\n}\n\n/**\n * Fade to right animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeOut, \"presetName\", 'FadeOut');\nexport class FadeOutRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n translateX: delayFunction(delay, animation(25, config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n translateX: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeOutRight();\n }\n}\n\n/**\n * Fade to left animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeOutRight, \"presetName\", 'FadeOutRight');\nexport class FadeOutLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n translateX: delayFunction(delay, animation(-25, config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n translateX: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeOutLeft();\n }\n}\n/**\n * Fade to top animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeOutLeft, \"presetName\", 'FadeOutLeft');\nexport class FadeOutUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n translateY: delayFunction(delay, animation(-25, config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n translateY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeOutUp();\n }\n}\n\n/**\n * Fade to bottom animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#fade\n */\n_defineProperty(FadeOutUp, \"presetName\", 'FadeOutUp');\nexport class FadeOutDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n translateY: delayFunction(delay, animation(25, config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n translateY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadeOutDown();\n }\n}\n_defineProperty(FadeOutDown, \"presetName\", 'FadeOutDown');\n//# sourceMappingURL=Fade.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\n/**\n * Slide from right animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#slide\n */\nexport class SlideInRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n originX: delayFunction(delay, animation(values.targetOriginX, config))\n },\n initialValues: {\n originX: values.targetOriginX + values.windowWidth,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SlideInRight();\n }\n}\n\n/**\n * Slide from left animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#slide\n */\n_defineProperty(SlideInRight, \"presetName\", 'SlideInRight');\nexport class SlideInLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n originX: delayFunction(delay, animation(values.targetOriginX, config))\n },\n initialValues: {\n originX: values.targetOriginX - values.windowWidth,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SlideInLeft();\n }\n}\n\n/**\n * Slide to right animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#slide\n */\n_defineProperty(SlideInLeft, \"presetName\", 'SlideInLeft');\nexport class SlideOutRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n originX: delayFunction(delay, animation(Math.max(values.currentOriginX + values.windowWidth, values.windowWidth), config))\n },\n initialValues: {\n originX: values.currentOriginX,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SlideOutRight();\n }\n}\n\n/**\n * Slide to left animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#slide\n */\n_defineProperty(SlideOutRight, \"presetName\", 'SlideOutRight');\nexport class SlideOutLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n originX: delayFunction(delay, animation(Math.min(values.currentOriginX - values.windowWidth, -values.windowWidth), config))\n },\n initialValues: {\n originX: values.currentOriginX,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SlideOutLeft();\n }\n}\n\n/**\n * Slide from top animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#slide\n */\n_defineProperty(SlideOutLeft, \"presetName\", 'SlideOutLeft');\nexport class SlideInUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n originY: delayFunction(delay, animation(values.targetOriginY, config))\n },\n initialValues: {\n originY: -values.windowHeight,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SlideInUp();\n }\n}\n\n/**\n * Slide from bottom animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#slide\n */\n_defineProperty(SlideInUp, \"presetName\", 'SlideInUp');\nexport class SlideInDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n originY: delayFunction(delay, animation(values.targetOriginY, config))\n },\n initialValues: {\n originY: values.targetOriginY + values.windowHeight,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SlideInDown();\n }\n}\n\n/**\n * Slide to top animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#slide\n */\n_defineProperty(SlideInDown, \"presetName\", 'SlideInDown');\nexport class SlideOutUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n originY: delayFunction(delay, animation(Math.min(values.currentOriginY - values.windowHeight, -values.windowHeight), config))\n },\n initialValues: {\n originY: values.currentOriginY,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SlideOutUp();\n }\n}\n\n/**\n * Slide to bottom animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#slide\n */\n_defineProperty(SlideOutUp, \"presetName\", 'SlideOutUp');\nexport class SlideOutDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n originY: delayFunction(delay, animation(Math.max(values.currentOriginY + values.windowHeight, values.windowHeight), config))\n },\n initialValues: {\n originY: values.currentOriginY,\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SlideOutDown();\n }\n}\n_defineProperty(SlideOutDown, \"presetName\", 'SlideOutDown');\n//# sourceMappingURL=Slide.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\n/**\n * Scale from center animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\nexport class ZoomIn extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scale: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n scale: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomIn();\n }\n}\n\n/**\n * Scale from center with rotation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomIn, \"presetName\", 'ZoomIn');\nexport class ZoomInRotate extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const rotate = this.rotateV ? this.rotateV : '0.3';\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scale: delayFunction(delay, animation(1, config))\n }, {\n rotate: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n scale: 0\n }, {\n rotate\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomInRotate();\n }\n}\n\n/**\n * Scale from left animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomInRotate, \"presetName\", 'ZoomInRotate');\nexport class ZoomInLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, animation(0, config))\n }, {\n scale: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n translateX: -values.windowWidth\n }, {\n scale: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomInLeft();\n }\n}\n\n/**\n * Scale from right animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomInLeft, \"presetName\", 'ZoomInLeft');\nexport class ZoomInRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, animation(0, config))\n }, {\n scale: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n translateX: values.windowWidth\n }, {\n scale: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomInRight();\n }\n}\n\n/**\n * Scale from top animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomInRight, \"presetName\", 'ZoomInRight');\nexport class ZoomInUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, animation(0, config))\n }, {\n scale: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n translateY: -values.windowHeight\n }, {\n scale: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomInUp();\n }\n}\n\n/**\n * Scale from bottom animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomInUp, \"presetName\", 'ZoomInUp');\nexport class ZoomInDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, animation(0, config))\n }, {\n scale: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n translateY: values.windowHeight\n }, {\n scale: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomInDown();\n }\n}\n\n/**\n * Eased scale from top animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomInDown, \"presetName\", 'ZoomInDown');\nexport class ZoomInEasyUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, animation(0, config))\n }, {\n scale: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n translateY: -values.targetHeight\n }, {\n scale: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomInEasyUp();\n }\n}\n\n/**\n * Eased scale from bottom animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomInEasyUp, \"presetName\", 'ZoomInEasyUp');\nexport class ZoomInEasyDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, animation(0, config))\n }, {\n scale: delayFunction(delay, animation(1, config))\n }]\n },\n initialValues: {\n transform: [{\n translateY: values.targetHeight\n }, {\n scale: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomInEasyDown();\n }\n}\n\n/**\n * Scale to center animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomInEasyDown, \"presetName\", 'ZoomInEasyDown');\nexport class ZoomOut extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scale: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n scale: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomOut();\n }\n}\n\n/**\n * Scale to center with rotation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomOut, \"presetName\", 'ZoomOut');\nexport class ZoomOutRotate extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const rotate = this.rotateV ? this.rotateV : '0.3';\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scale: delayFunction(delay, animation(0, config))\n }, {\n rotate: delayFunction(delay, animation(rotate, config))\n }]\n },\n initialValues: {\n transform: [{\n scale: 1\n }, {\n rotate: '0'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomOutRotate();\n }\n}\n\n/**\n * Scale to left animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomOutRotate, \"presetName\", 'ZoomOutRotate');\nexport class ZoomOutLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, animation(-values.windowWidth, config))\n }, {\n scale: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n translateX: 0\n }, {\n scale: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomOutLeft();\n }\n}\n\n/**\n * Scale to right animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomOutLeft, \"presetName\", 'ZoomOutLeft');\nexport class ZoomOutRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, animation(values.windowWidth, config))\n }, {\n scale: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n translateX: 0\n }, {\n scale: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomOutRight();\n }\n}\n\n/**\n * Scale to top animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomOutRight, \"presetName\", 'ZoomOutRight');\nexport class ZoomOutUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, animation(-values.windowHeight, config))\n }, {\n scale: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n translateY: 0\n }, {\n scale: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomOutUp();\n }\n}\n\n/**\n * Scale to bottom animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomOutUp, \"presetName\", 'ZoomOutUp');\nexport class ZoomOutDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, animation(values.windowHeight, config))\n }, {\n scale: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n translateY: 0\n }, {\n scale: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomOutDown();\n }\n}\n\n/**\n * Eased scale to top animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomOutDown, \"presetName\", 'ZoomOutDown');\nexport class ZoomOutEasyUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, animation(-values.currentHeight, config))\n }, {\n scale: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n translateY: 0\n }, {\n scale: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomOutEasyUp();\n }\n}\n\n/**\n * Eased scale to bottom animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#zoom\n */\n_defineProperty(ZoomOutEasyUp, \"presetName\", 'ZoomOutEasyUp');\nexport class ZoomOutEasyDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, animation(values.currentHeight, config))\n }, {\n scale: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n transform: [{\n translateY: 0\n }, {\n scale: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new ZoomOutEasyDown();\n }\n}\n_defineProperty(ZoomOutEasyDown, \"presetName\", 'ZoomOutEasyDown');\n//# sourceMappingURL=Zoom.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { withSequence, withTiming } from '../../animation';\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\n/**\n * Bounce entering animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\nexport class BounceIn extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scale: delayFunction(delay, withSequence(withTiming(1.2, {\n duration: duration * 0.55\n }), withTiming(0.9, {\n duration: duration * 0.15\n }), withTiming(1.1, {\n duration: duration * 0.15\n }), withTiming(1, {\n duration: duration * 0.15\n })))\n }]\n },\n initialValues: {\n transform: [{\n scale: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceIn();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce from bottom animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceIn, \"presetName\", 'BounceIn');\nexport class BounceInDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, withSequence(withTiming(-20, {\n duration: duration * 0.55\n }), withTiming(10, {\n duration: duration * 0.15\n }), withTiming(-10, {\n duration: duration * 0.15\n }), withTiming(0, {\n duration: duration * 0.15\n })))\n }]\n },\n initialValues: {\n transform: [{\n translateY: values.windowHeight\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceInDown();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce from top animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceInDown, \"presetName\", 'BounceInDown');\nexport class BounceInUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, withSequence(withTiming(20, {\n duration: duration * 0.55\n }), withTiming(-10, {\n duration: duration * 0.15\n }), withTiming(10, {\n duration: duration * 0.15\n }), withTiming(0, {\n duration: duration * 0.15\n })))\n }]\n },\n initialValues: {\n transform: [{\n translateY: -values.windowHeight\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceInUp();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce from left animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceInUp, \"presetName\", 'BounceInUp');\nexport class BounceInLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, withSequence(withTiming(20, {\n duration: duration * 0.55\n }), withTiming(-10, {\n duration: duration * 0.15\n }), withTiming(10, {\n duration: duration * 0.15\n }), withTiming(0, {\n duration: duration * 0.15\n })))\n }]\n },\n initialValues: {\n transform: [{\n translateX: -values.windowWidth\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceInLeft();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce from right animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceInLeft, \"presetName\", 'BounceInLeft');\nexport class BounceInRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, withSequence(withTiming(-20, {\n duration: duration * 0.55\n }), withTiming(10, {\n duration: duration * 0.15\n }), withTiming(-10, {\n duration: duration * 0.15\n }), withTiming(0, {\n duration: duration * 0.15\n })))\n }]\n },\n initialValues: {\n transform: [{\n translateX: values.windowWidth\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceInRight();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce exiting animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceInRight, \"presetName\", 'BounceInRight');\nexport class BounceOut extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n scale: delayFunction(delay, withSequence(withTiming(1.1, {\n duration: duration * 0.15\n }), withTiming(0.9, {\n duration: duration * 0.15\n }), withTiming(1.2, {\n duration: duration * 0.15\n }), withTiming(0, {\n duration: duration * 0.55\n })))\n }]\n },\n initialValues: {\n transform: [{\n scale: 1\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceOut();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce to bottom animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceOut, \"presetName\", 'BounceOut');\nexport class BounceOutDown extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, withSequence(withTiming(-10, {\n duration: duration * 0.15\n }), withTiming(10, {\n duration: duration * 0.15\n }), withTiming(-20, {\n duration: duration * 0.15\n }), withTiming(values.windowHeight, {\n duration: duration * 0.55\n })))\n }]\n },\n initialValues: {\n transform: [{\n translateY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceOutDown();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce to top animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceOutDown, \"presetName\", 'BounceOutDown');\nexport class BounceOutUp extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateY: delayFunction(delay, withSequence(withTiming(10, {\n duration: duration * 0.15\n }), withTiming(-10, {\n duration: duration * 0.15\n }), withTiming(20, {\n duration: duration * 0.15\n }), withTiming(-values.windowHeight, {\n duration: duration * 0.55\n })))\n }]\n },\n initialValues: {\n transform: [{\n translateY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceOutUp();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce to left animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceOutUp, \"presetName\", 'BounceOutUp');\nexport class BounceOutLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, withSequence(withTiming(10, {\n duration: duration * 0.15\n }), withTiming(-10, {\n duration: duration * 0.15\n }), withTiming(20, {\n duration: duration * 0.15\n }), withTiming(-values.windowWidth, {\n duration: duration * 0.55\n })))\n }]\n },\n initialValues: {\n transform: [{\n translateX: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceOutLeft();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n\n/**\n * Bounce to right animation. You can modify the behavior by chaining methods like `.delay(300)` or `.duration(100)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#bounce\n */\n_defineProperty(BounceOutLeft, \"presetName\", 'BounceOutLeft');\nexport class BounceOutRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, withSequence(withTiming(-10, {\n duration: duration * 0.15\n }), withTiming(10, {\n duration: duration * 0.15\n }), withTiming(-20, {\n duration: duration * 0.15\n }), withTiming(values.windowWidth, {\n duration: duration * 0.55\n })))\n }]\n },\n initialValues: {\n transform: [{\n translateX: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new BounceOutRight();\n }\n static getDuration() {\n return 600;\n }\n getDuration() {\n return this.durationV ?? 600;\n }\n}\n_defineProperty(BounceOutRight, \"presetName\", 'BounceOutRight');\n//# sourceMappingURL=Bounce.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { withSequence, withTiming } from '../../animation';\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n/**\n * Entry from right animation with change in skew and opacity. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#lightspeed\n */\nexport class LightSpeedInRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, withTiming(1, {\n duration\n })),\n transform: [{\n translateX: delayFunction(delay, animation(0, {\n ...config,\n duration: duration * 0.7\n }))\n }, {\n skewX: delayFunction(delay, withSequence(withTiming('10deg', {\n duration: duration * 0.7\n }), withTiming('-5deg', {\n duration: duration * 0.15\n }), withTiming('0deg', {\n duration: duration * 0.15\n })))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n translateX: values.windowWidth\n }, {\n skewX: '-45deg'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new LightSpeedInRight();\n }\n}\n\n/**\n * Entry from left animation with change in skew and opacity. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#lightspeed\n */\n_defineProperty(LightSpeedInRight, \"presetName\", 'LightSpeedInRight');\nexport class LightSpeedInLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, withTiming(1, {\n duration\n })),\n transform: [{\n translateX: delayFunction(delay, animation(0, {\n ...config,\n duration: duration * 0.7\n }))\n }, {\n skewX: delayFunction(delay, withSequence(withTiming('-10deg', {\n duration: duration * 0.7\n }), withTiming('5deg', {\n duration: duration * 0.15\n }), withTiming('0deg', {\n duration: duration * 0.15\n })))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n translateX: -values.windowWidth\n }, {\n skewX: '45deg'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new LightSpeedInLeft();\n }\n}\n\n/**\n * Exit to right animation with change in skew and opacity. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#lightspeed\n */\n_defineProperty(LightSpeedInLeft, \"presetName\", 'LightSpeedInLeft');\nexport class LightSpeedOutRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n translateX: delayFunction(delay, animation(values.windowWidth, config))\n }, {\n skewX: delayFunction(delay, animation('-45deg', config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n translateX: 0\n }, {\n skewX: '0deg'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new LightSpeedOutRight();\n }\n}\n\n/**\n * Exit to left animation with change in skew and opacity. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations/#lightspeed\n */\n_defineProperty(LightSpeedOutRight, \"presetName\", 'LightSpeedOutRight');\nexport class LightSpeedOutLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n translateX: delayFunction(delay, animation(-values.windowWidth, config))\n }, {\n skewX: delayFunction(delay, animation('45deg', config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n translateX: 0\n }, {\n skewX: '0deg'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new LightSpeedOutLeft();\n }\n}\n_defineProperty(LightSpeedOutLeft, \"presetName\", 'LightSpeedOutLeft');\n//# sourceMappingURL=Lightspeed.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n/**\n * Entry with change in rotation, scale, and opacity. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#pinwheel\n */\nexport class PinwheelIn extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n scale: delayFunction(delay, animation(1, config))\n }, {\n rotate: delayFunction(delay, animation('0', config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n scale: 0\n }, {\n rotate: '5'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new PinwheelIn();\n }\n}\n\n/**\n * Exit with change in rotation, scale, and opacity. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#pinwheel\n */\n_defineProperty(PinwheelIn, \"presetName\", 'PinwheelIn');\nexport class PinwheelOut extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return () => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n scale: delayFunction(delay, animation(0, config))\n }, {\n rotate: delayFunction(delay, animation('5', config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n scale: 1\n }, {\n rotate: '0'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new PinwheelOut();\n }\n}\n_defineProperty(PinwheelOut, \"presetName\", 'PinwheelOut');\n//# sourceMappingURL=Pinwheel.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n/**\n * Rotate to bottom from left edge. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#rotate\n */\nexport class RotateInDownLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n rotate: delayFunction(delay, animation('0deg', config))\n }, {\n translateX: delayFunction(delay, animation(0, config))\n }, {\n translateY: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n rotate: '-90deg'\n }, {\n translateX: values.targetWidth / 2 - values.targetHeight / 2\n }, {\n translateY: -(values.targetWidth / 2 - values.targetHeight / 2)\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RotateInDownLeft();\n }\n}\n\n/**\n * Rotate to bottom from right edge. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#rotate\n */\n_defineProperty(RotateInDownLeft, \"presetName\", 'RotateInDownLeft');\nexport class RotateInDownRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n rotate: delayFunction(delay, animation('0deg', config))\n }, {\n translateX: delayFunction(delay, animation(0, config))\n }, {\n translateY: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n rotate: '90deg'\n }, {\n translateX: -(values.targetWidth / 2 - values.targetHeight / 2)\n }, {\n translateY: -(values.targetWidth / 2 - values.targetHeight / 2)\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RotateInDownRight();\n }\n}\n\n/**\n * Rotate to top from left edge. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#rotate\n */\n_defineProperty(RotateInDownRight, \"presetName\", 'RotateInDownRight');\nexport class RotateInUpLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n rotate: delayFunction(delay, animation('0deg', config))\n }, {\n translateX: delayFunction(delay, animation(0, config))\n }, {\n translateY: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n rotate: '90deg'\n }, {\n translateX: values.targetWidth / 2 - values.targetHeight / 2\n }, {\n translateY: values.targetWidth / 2 - values.targetHeight / 2\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RotateInUpLeft();\n }\n}\n\n/**\n * Rotate to top from right edge. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#rotate\n */\n_defineProperty(RotateInUpLeft, \"presetName\", 'RotateInUpLeft');\nexport class RotateInUpRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [{\n rotate: delayFunction(delay, animation('0deg', config))\n }, {\n translateX: delayFunction(delay, animation(0, config))\n }, {\n translateY: delayFunction(delay, animation(0, config))\n }]\n },\n initialValues: {\n opacity: 0,\n transform: [{\n rotate: '-90deg'\n }, {\n translateX: -(values.targetWidth / 2 - values.targetHeight / 2)\n }, {\n translateY: values.targetWidth / 2 - values.targetHeight / 2\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RotateInUpRight();\n }\n}\n\n/**\n * Rotate to bottom from left edge. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#rotate\n */\n_defineProperty(RotateInUpRight, \"presetName\", 'RotateInUpRight');\nexport class RotateOutDownLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n rotate: delayFunction(delay, animation('90deg', config))\n }, {\n translateX: delayFunction(delay, animation(values.currentWidth / 2 - values.currentHeight / 2, config))\n }, {\n translateY: delayFunction(delay, animation(values.currentWidth / 2 - values.currentHeight / 2, config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n rotate: '0deg'\n }, {\n translateX: 0\n }, {\n translateY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RotateOutDownLeft();\n }\n}\n\n/**\n * Rotate to bottom from right edge. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#rotate\n */\n_defineProperty(RotateOutDownLeft, \"presetName\", 'RotateOutDownLeft');\nexport class RotateOutDownRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n rotate: delayFunction(delay, animation('-90deg', config))\n }, {\n translateX: delayFunction(delay, animation(-(values.currentWidth / 2 - values.currentHeight / 2), config))\n }, {\n translateY: delayFunction(delay, animation(values.currentWidth / 2 - values.currentHeight / 2, config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n rotate: '0deg'\n }, {\n translateX: 0\n }, {\n translateY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RotateOutDownRight();\n }\n}\n\n/**\n * Rotate to top from left edge. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#rotate\n */\n_defineProperty(RotateOutDownRight, \"presetName\", 'RotateOutDownRight');\nexport class RotateOutUpLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n rotate: delayFunction(delay, animation('-90deg', config))\n }, {\n translateX: delayFunction(delay, animation(values.currentWidth / 2 - values.currentHeight / 2, config))\n }, {\n translateY: delayFunction(delay, animation(-(values.currentWidth / 2 - values.currentHeight / 2), config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n rotate: '0deg'\n }, {\n translateX: 0\n }, {\n translateY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RotateOutUpLeft();\n }\n}\n\n/**\n * Rotate to top from right edge. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#rotate\n */\n_defineProperty(RotateOutUpLeft, \"presetName\", 'RotateOutUpLeft');\nexport class RotateOutUpRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [{\n rotate: delayFunction(delay, animation('90deg', config))\n }, {\n translateX: delayFunction(delay, animation(-(values.currentWidth / 2 - values.currentHeight / 2), config))\n }, {\n translateY: delayFunction(delay, animation(-(values.currentWidth / 2 - values.currentHeight / 2), config))\n }]\n },\n initialValues: {\n opacity: 1,\n transform: [{\n rotate: '0deg'\n }, {\n translateX: 0\n }, {\n translateY: 0\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RotateOutUpRight();\n }\n}\n_defineProperty(RotateOutUpRight, \"presetName\", 'RotateOutUpRight');\n//# sourceMappingURL=Rotate.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n/**\n * Roll from left animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#roll\n */\nexport class RollInLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, animation(0), config)\n }, {\n rotate: delayFunction(delay, animation('0deg', config))\n }]\n },\n initialValues: {\n transform: [{\n translateX: -values.windowWidth\n }, {\n rotate: '-180deg'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RollInLeft();\n }\n}\n\n/**\n * Roll from right animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `entering` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#roll\n */\n_defineProperty(RollInLeft, \"presetName\", 'RollInLeft');\nexport class RollInRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, animation(0, config))\n }, {\n rotate: delayFunction(delay, animation('0deg', config))\n }]\n },\n initialValues: {\n transform: [{\n translateX: values.windowWidth\n }, {\n rotate: '180deg'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RollInRight();\n }\n}\n\n/**\n * Roll to left animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#roll\n */\n_defineProperty(RollInRight, \"presetName\", 'RollInRight');\nexport class RollOutLeft extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, animation(-values.windowWidth, config))\n }, {\n rotate: delayFunction(delay, animation('-180deg', config))\n }]\n },\n initialValues: {\n transform: [{\n translateX: 0\n }, {\n rotate: '0deg'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RollOutLeft();\n }\n}\n\n/**\n * Roll to right animation. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `exiting` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/entering-exiting-animations#roll\n */\n_defineProperty(RollOutLeft, \"presetName\", 'RollOutLeft');\nexport class RollOutRight extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n return values => {\n 'worklet';\n\n return {\n animations: {\n transform: [{\n translateX: delayFunction(delay, animation(values.windowWidth, config))\n }, {\n rotate: delayFunction(delay, animation('180deg', config))\n }]\n },\n initialValues: {\n transform: [{\n translateX: 0\n }, {\n rotate: '0deg'\n }],\n ...initialValues\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new RollOutRight();\n }\n}\n_defineProperty(RollOutRight, \"presetName\", 'RollOutRight');\n//# sourceMappingURL=Roll.js.map","'use strict';\n\nexport * from './LinearTransition';\nexport * from './FadingTransition';\nexport * from './SequencedTransition';\nexport * from './JumpingTransition';\nexport * from './CurvedTransition';\nexport * from './EntryExitTransition';\n//# sourceMappingURL=index.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n/**\n * Linearly transforms the layout from one position to another. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `layout` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/layout-transitions#linear-transition\n */\nexport class LinearTransition extends ComplexAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const delay = this.getDelay();\n return values => {\n 'worklet';\n\n return {\n initialValues: {\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight\n },\n animations: {\n originX: delayFunction(delay, animation(values.targetOriginX, config)),\n originY: delayFunction(delay, animation(values.targetOriginY, config)),\n width: delayFunction(delay, animation(values.targetWidth, config)),\n height: delayFunction(delay, animation(values.targetHeight, config))\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new LinearTransition();\n }\n}\n\n/**\n * @deprecated Please use {@link LinearTransition} instead.\n */\nexport const Layout = LinearTransition;\n//# sourceMappingURL=LinearTransition.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { withSequence, withTiming } from '../../animation';\nimport { BaseAnimationBuilder } from '../animationBuilder';\n\n/**\n * Fades out components from one position and shows them in another. You can modify the behavior by chaining methods like `.duration(500)` or `.delay(500)`.\n *\n * You pass it to the `layout` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/layout-transitions#fading-transition\n */\nexport class FadingTransition extends BaseAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const duration = this.durationV ?? 500;\n return values => {\n 'worklet';\n\n return {\n initialValues: {\n opacity: 1,\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight\n },\n animations: {\n opacity: delayFunction(delay, withSequence(withTiming(0, {\n duration\n }), withTiming(1, {\n duration\n }))),\n originX: delayFunction(delay + duration, withTiming(values.targetOriginX, {\n duration: 50\n })),\n originY: delayFunction(delay + duration, withTiming(values.targetOriginY, {\n duration: 50\n })),\n width: delayFunction(delay + duration, withTiming(values.targetWidth, {\n duration: 50\n })),\n height: delayFunction(delay + duration, withTiming(values.targetHeight, {\n duration: 50\n }))\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new FadingTransition();\n }\n}\n//# sourceMappingURL=FadingTransition.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { withSequence, withTiming } from '../../animation';\nimport { BaseAnimationBuilder } from '../animationBuilder';\n\n/**\n * Transforms layout starting from the X-axis and width first, followed by the Y-axis and height. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `layout` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/layout-transitions#sequenced-transition\n */\nexport class SequencedTransition extends BaseAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"reversed\", false);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const sequenceDuration = (this.durationV ?? 500) / 2;\n const config = {\n duration: sequenceDuration\n };\n const reverse = this.reversed;\n return values => {\n 'worklet';\n\n return {\n initialValues: {\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight\n },\n animations: {\n originX: delayFunction(delay, withSequence(withTiming(reverse ? values.currentOriginX : values.targetOriginX, config), withTiming(values.targetOriginX, config))),\n originY: delayFunction(delay, withSequence(withTiming(reverse ? values.targetOriginY : values.currentOriginY, config), withTiming(values.targetOriginY, config))),\n width: delayFunction(delay, withSequence(withTiming(reverse ? values.currentWidth : values.targetWidth, config), withTiming(values.targetWidth, config))),\n height: delayFunction(delay, withSequence(withTiming(reverse ? values.targetHeight : values.currentHeight, config), withTiming(values.targetHeight, config)))\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new SequencedTransition();\n }\n static reverse() {\n const instance = SequencedTransition.createInstance();\n return instance.reverse();\n }\n reverse() {\n this.reversed = !this.reversed;\n return this;\n }\n}\n//# sourceMappingURL=SequencedTransition.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { withSequence, withTiming } from '../../animation';\nimport { Easing } from '../../Easing';\nimport { BaseAnimationBuilder } from '../animationBuilder';\n\n/**\n * Layout jumps - quite literally - from one position to another. You can modify the behavior by chaining methods like `.springify()` or `.duration(500)`.\n *\n * You pass it to the `layout` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/layout-transitions#jumping-transition\n */\nexport class JumpingTransition extends BaseAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const duration = (this.durationV ?? 300) / 2;\n const config = {\n duration: duration * 2\n };\n return values => {\n 'worklet';\n\n const d = Math.max(Math.abs(values.targetOriginX - values.currentOriginX), Math.abs(values.targetOriginY - values.currentOriginY));\n return {\n initialValues: {\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight\n },\n animations: {\n originX: delayFunction(delay, withTiming(values.targetOriginX, config)),\n originY: delayFunction(delay, withSequence(withTiming(Math.min(values.targetOriginY, values.currentOriginY) - d, {\n duration,\n easing: Easing.out(Easing.exp)\n }), withTiming(values.targetOriginY, {\n ...config,\n duration,\n easing: Easing.bounce\n }))),\n width: delayFunction(delay, withTiming(values.targetWidth, config)),\n height: delayFunction(delay, withTiming(values.targetHeight, config))\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new JumpingTransition();\n }\n}\n//# sourceMappingURL=JumpingTransition.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { BaseAnimationBuilder } from '../animationBuilder';\nimport { Easing } from '../../Easing';\nimport { withTiming } from '../../animation';\nimport { assertEasingIsWorklet } from '../../animation/util';\n\n/**\n * Layout transitions with a curved animation. You can modify the behavior by chaining methods like `.duration(500)` or `.delay(500)`.\n *\n * You pass it to the `layout` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n *\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/layout-transitions#fading-transition\n */\nexport class CurvedTransition extends BaseAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"easingXV\", Easing.in(Easing.ease));\n _defineProperty(this, \"easingYV\", Easing.out(Easing.ease));\n _defineProperty(this, \"easingWidthV\", Easing.in(Easing.exp));\n _defineProperty(this, \"easingHeightV\", Easing.out(Easing.exp));\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const duration = this.durationV ?? 300;\n const easing = {\n easingX: this.easingXV,\n easingY: this.easingYV,\n easingWidth: this.easingWidthV,\n easingHeight: this.easingHeightV\n };\n return values => {\n 'worklet';\n\n return {\n initialValues: {\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight\n },\n animations: {\n originX: delayFunction(delay, withTiming(values.targetOriginX, {\n duration,\n easing: easing.easingX\n })),\n originY: delayFunction(delay, withTiming(values.targetOriginY, {\n duration,\n easing: easing.easingY\n })),\n width: delayFunction(delay, withTiming(values.targetWidth, {\n duration,\n easing: easing.easingWidth\n })),\n height: delayFunction(delay, withTiming(values.targetHeight, {\n duration,\n easing: easing.easingHeight\n }))\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new CurvedTransition();\n }\n static easingX(easing) {\n const instance = this.createInstance();\n return instance.easingX(easing);\n }\n easingX(easing) {\n if (__DEV__) {\n assertEasingIsWorklet(easing);\n }\n this.easingXV = easing;\n return this;\n }\n static easingY(easing) {\n const instance = this.createInstance();\n return instance.easingY(easing);\n }\n easingY(easing) {\n if (__DEV__) {\n assertEasingIsWorklet(easing);\n }\n this.easingYV = easing;\n return this;\n }\n static easingWidth(easing) {\n const instance = this.createInstance();\n return instance.easingWidth(easing);\n }\n easingWidth(easing) {\n if (__DEV__) {\n assertEasingIsWorklet(easing);\n }\n this.easingWidthV = easing;\n return this;\n }\n static easingHeight(easing) {\n const instance = this.createInstance();\n return instance.easingHeight(easing);\n }\n easingHeight(easing) {\n if (__DEV__) {\n assertEasingIsWorklet(easing);\n }\n this.easingHeightV = easing;\n return this;\n }\n}\n//# sourceMappingURL=CurvedTransition.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { BaseAnimationBuilder } from '../animationBuilder';\nimport { withSequence, withTiming } from '../../animation';\nimport { FadeIn, FadeOut } from '../defaultAnimations/Fade';\nexport class EntryExitTransition extends BaseAnimationBuilder {\n constructor(...args) {\n super(...args);\n _defineProperty(this, \"enteringV\", FadeIn);\n _defineProperty(this, \"exitingV\", FadeOut);\n _defineProperty(this, \"build\", () => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n // @ts-ignore Calling `.build()` both static and instance methods works fine here, but `this` types are incompatible. They are not used though, so it's fine.\n const enteringAnimation = this.enteringV.build();\n // @ts-ignore Calling `.build()` both static and instance methods works fine here, but `this` types are incompatible. They are not used though, so it's fine.\n const exitingAnimation = this.exitingV.build();\n const exitingDuration = this.exitingV.getDuration();\n return values => {\n 'worklet';\n\n const enteringValues = enteringAnimation(values);\n const exitingValues = exitingAnimation(values);\n const animations = {\n transform: []\n };\n for (const prop of Object.keys(exitingValues.animations)) {\n if (prop === 'transform') {\n if (!Array.isArray(exitingValues.animations.transform)) {\n continue;\n }\n exitingValues.animations.transform.forEach((value, index) => {\n for (const transformProp of Object.keys(value)) {\n animations.transform.push({\n [transformProp]: delayFunction(delay, withSequence(value[transformProp], withTiming(exitingValues.initialValues.transform ?\n // TODO TYPESCRIPT\n // @ts-ignore This line of code fails tragically\n // in newer versions of React Native, where they have\n // narrowed down the type of `transform` even further.\n // Since this piece of code improperly typed anyway\n // (e.g. it assumes types from RN Animated here) I'd rather\n // fix it in the future when types for animations\n // are properly defined.\n exitingValues.initialValues.transform[index][transformProp] : 0, {\n duration: 0\n })))\n });\n }\n });\n } else {\n const sequence = enteringValues.animations[prop] !== undefined ? [exitingValues.animations[prop], withTiming(enteringValues.initialValues[prop], {\n duration: 0\n }), enteringValues.animations[prop]] : [exitingValues.animations[prop], withTiming(Object.keys(values).includes(prop) ? values[prop] : exitingValues.initialValues[prop], {\n duration: 0\n })];\n animations[prop] = delayFunction(delay, withSequence(...sequence));\n }\n }\n for (const prop of Object.keys(enteringValues.animations)) {\n if (prop === 'transform') {\n if (!Array.isArray(enteringValues.animations.transform)) {\n continue;\n }\n enteringValues.animations.transform.forEach((value, index) => {\n for (const transformProp of Object.keys(value)) {\n animations.transform.push({\n [transformProp]: delayFunction(delay + exitingDuration, withSequence(withTiming(enteringValues.initialValues.transform ? enteringValues.initialValues.transform[index][transformProp] : 0, {\n duration: exitingDuration\n }), value[transformProp]))\n });\n }\n });\n } else if (animations[prop] !== undefined) {\n // it was already added in the previous loop\n continue;\n } else {\n animations[prop] = delayFunction(delay, withSequence(withTiming(enteringValues.initialValues[prop], {\n duration: 0\n }), enteringValues.animations[prop]));\n }\n }\n const mergedTransform = (Array.isArray(exitingValues.initialValues.transform) ? exitingValues.initialValues.transform : []).concat((Array.isArray(enteringValues.animations.transform) ? enteringValues.animations.transform : []).map(value => {\n const objectKeys = Object.keys(value);\n if ((objectKeys === null || objectKeys === void 0 ? void 0 : objectKeys.length) < 1) {\n console.error(`[Reanimated]: \\${value} is not a valid Transform object`);\n return value;\n }\n const transformProp = objectKeys[0];\n const current =\n // TODO TYPESCRIPT\n // @ts-ignore Read similar comment above.\n value[transformProp].current;\n if (typeof current === 'string') {\n if (current.includes('deg')) {\n return {\n [transformProp]: '0deg'\n };\n } else {\n return {\n [transformProp]: '0'\n };\n }\n } else if (transformProp.includes('translate')) {\n return {\n [transformProp]: 0\n };\n } else {\n return {\n [transformProp]: 1\n };\n }\n }));\n return {\n initialValues: {\n ...exitingValues.initialValues,\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight,\n transform: mergedTransform\n },\n animations: {\n originX: delayFunction(delay + exitingDuration, withTiming(values.targetOriginX, {\n duration: exitingDuration\n })),\n originY: delayFunction(delay + exitingDuration, withTiming(values.targetOriginY, {\n duration: exitingDuration\n })),\n width: delayFunction(delay + exitingDuration, withTiming(values.targetWidth, {\n duration: exitingDuration\n })),\n height: delayFunction(delay + exitingDuration, withTiming(values.targetHeight, {\n duration: exitingDuration\n })),\n ...animations\n },\n callback\n };\n };\n });\n }\n static createInstance() {\n return new EntryExitTransition();\n }\n static entering(animation) {\n const instance = this.createInstance();\n return instance.entering(animation);\n }\n entering(animation) {\n this.enteringV = animation;\n return this;\n }\n static exiting(animation) {\n const instance = this.createInstance();\n return instance.exiting(animation);\n }\n exiting(animation) {\n this.exitingV = animation;\n return this;\n }\n}\n\n/**\n * Lets you combine two layout animations into a layout transition. You can modify the behavior by chaining methods like `.delay(500)`.\n *\n * @param exiting - Layout animation used when components are removed from layout (eg. `FadeOut`).\n * @param entering - Layout animation used when components are added to layout (eg. `FadeIn`).\n * @returns A custom layout transition. You pass it to the `layout` prop on [an Animated component](https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary#animated-component).\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/layout-transitions#combine-transition\n */\nexport function combineTransition(exiting, entering) {\n return EntryExitTransition.entering(entering).exiting(exiting);\n}\n//# sourceMappingURL=EntryExitTransition.js.map","'use strict';\n\nexport * from './SharedTransition';\nexport * from './ProgressTransitionManager';\n//# sourceMappingURL=index.js.map","'use strict';\n\nimport { ReduceMotion } from '../../commonTypes';\nexport class SharedTransition {\n custom() {\n return this;\n }\n progressAnimation() {\n return this;\n }\n duration() {\n return this;\n }\n reduceMotion() {\n return this;\n }\n defaultTransitionType() {\n return this;\n }\n registerTransition() {\n // no-op\n }\n unregisterTransition() {\n // no-op\n }\n getReduceMotion() {\n return ReduceMotion.System;\n }\n\n // static builder methods\n\n static custom() {\n return new SharedTransition();\n }\n static duration() {\n return new SharedTransition();\n }\n static progressAnimation() {\n return new SharedTransition();\n }\n static defaultTransitionType() {\n return new SharedTransition();\n }\n static reduceMotion() {\n return new SharedTransition();\n }\n}\n//# sourceMappingURL=SharedTransition.web.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { runOnUIImmediately } from '../../threads';\nimport { registerEventHandler, unregisterEventHandler } from '../../core';\nimport { Platform } from 'react-native';\nimport { isJest, shouldBeUseWeb } from '../../PlatformChecker';\nconst IS_ANDROID = Platform.OS === 'android';\nexport class ProgressTransitionManager {\n constructor() {\n _defineProperty(this, \"_sharedElementCount\", 0);\n _defineProperty(this, \"_eventHandler\", {\n isRegistered: false,\n onTransitionProgress: -1,\n onAppear: -1,\n onDisappear: -1,\n onSwipeDismiss: -1\n });\n }\n addProgressAnimation(viewTag, progressAnimation) {\n runOnUIImmediately(() => {\n 'worklet';\n\n global.ProgressTransitionRegister.addProgressAnimation(viewTag, progressAnimation);\n })();\n this.registerEventHandlers();\n }\n removeProgressAnimation(viewTag, isUnmounting = true) {\n this.unregisterEventHandlers();\n runOnUIImmediately(() => {\n 'worklet';\n\n global.ProgressTransitionRegister.removeProgressAnimation(viewTag, isUnmounting);\n })();\n }\n registerEventHandlers() {\n this._sharedElementCount++;\n const eventHandler = this._eventHandler;\n if (!eventHandler.isRegistered) {\n eventHandler.isRegistered = true;\n const eventPrefix = IS_ANDROID ? 'on' : 'top';\n let lastProgressValue = -1;\n eventHandler.onTransitionProgress = registerEventHandler(event => {\n 'worklet';\n\n const progress = event.progress;\n if (progress === lastProgressValue) {\n // During screen transition, handler receives two events with the same progress\n // value for both screens, but for modals, there is only one event. To optimize\n // performance and avoid unnecessary worklet calls, let's skip the second event.\n return;\n }\n lastProgressValue = progress;\n global.ProgressTransitionRegister.frame(progress);\n }, eventPrefix + 'TransitionProgress');\n eventHandler.onAppear = registerEventHandler(() => {\n 'worklet';\n\n global.ProgressTransitionRegister.onTransitionEnd();\n }, eventPrefix + 'Appear');\n if (IS_ANDROID) {\n // onFinishTransitioning event is available only on Android and\n // is used to handle closing modals\n eventHandler.onDisappear = registerEventHandler(() => {\n 'worklet';\n\n global.ProgressTransitionRegister.onAndroidFinishTransitioning();\n }, 'onFinishTransitioning');\n } else if (Platform.OS === 'ios') {\n // topDisappear event is required to handle closing modals on iOS\n eventHandler.onDisappear = registerEventHandler(() => {\n 'worklet';\n\n global.ProgressTransitionRegister.onTransitionEnd(true);\n }, 'topDisappear');\n eventHandler.onSwipeDismiss = registerEventHandler(() => {\n 'worklet';\n\n global.ProgressTransitionRegister.onTransitionEnd();\n }, 'topGestureCancel');\n }\n }\n }\n unregisterEventHandlers() {\n this._sharedElementCount--;\n if (this._sharedElementCount === 0) {\n const eventHandler = this._eventHandler;\n eventHandler.isRegistered = false;\n if (eventHandler.onTransitionProgress !== -1) {\n unregisterEventHandler(eventHandler.onTransitionProgress);\n eventHandler.onTransitionProgress = -1;\n }\n if (eventHandler.onAppear !== -1) {\n unregisterEventHandler(eventHandler.onAppear);\n eventHandler.onAppear = -1;\n }\n if (eventHandler.onDisappear !== -1) {\n unregisterEventHandler(eventHandler.onDisappear);\n eventHandler.onDisappear = -1;\n }\n if (eventHandler.onSwipeDismiss !== -1) {\n unregisterEventHandler(eventHandler.onSwipeDismiss);\n eventHandler.onSwipeDismiss = -1;\n }\n }\n }\n}\nfunction createProgressTransitionRegister() {\n 'worklet';\n\n const progressAnimations = new Map();\n const snapshots = new Map();\n const currentTransitions = new Set();\n const toRemove = new Set();\n let skipCleaning = false;\n let isTransitionRestart = false;\n const progressTransitionManager = {\n addProgressAnimation: (viewTag, progressAnimation) => {\n if (currentTransitions.size > 0 && !progressAnimations.has(viewTag)) {\n // there is no need to prevent cleaning on android\n isTransitionRestart = !IS_ANDROID;\n }\n progressAnimations.set(viewTag, progressAnimation);\n },\n removeProgressAnimation: (viewTag, isUnmounting) => {\n if (currentTransitions.size > 0) {\n // there is no need to prevent cleaning on android\n isTransitionRestart = !IS_ANDROID;\n }\n if (isUnmounting) {\n // Remove the animation config after the transition is finished\n toRemove.add(viewTag);\n } else {\n // if the animation is removed, without ever being started, it can be removed immediately\n progressAnimations.delete(viewTag);\n }\n },\n onTransitionStart: (viewTag, snapshot) => {\n skipCleaning = isTransitionRestart;\n snapshots.set(viewTag, snapshot);\n currentTransitions.add(viewTag);\n // set initial style for re-parented components\n progressTransitionManager.frame(0);\n },\n frame: progress => {\n for (const viewTag of currentTransitions) {\n const progressAnimation = progressAnimations.get(viewTag);\n if (!progressAnimation) {\n continue;\n }\n const snapshot = snapshots.get(viewTag);\n progressAnimation(viewTag, snapshot, progress);\n }\n },\n onAndroidFinishTransitioning: () => {\n if (toRemove.size > 0) {\n // it should be ran only on modal closing\n progressTransitionManager.onTransitionEnd();\n }\n },\n onTransitionEnd: (removeViews = false) => {\n if (currentTransitions.size === 0) {\n toRemove.clear();\n return;\n }\n if (skipCleaning) {\n skipCleaning = false;\n isTransitionRestart = false;\n return;\n }\n for (const viewTag of currentTransitions) {\n global._notifyAboutEnd(viewTag, removeViews);\n }\n currentTransitions.clear();\n if (isTransitionRestart) {\n // on transition restart, progressAnimations should be saved\n // because they potentially can be used in the next transition\n return;\n }\n snapshots.clear();\n if (toRemove.size > 0) {\n for (const viewTag of toRemove) {\n progressAnimations.delete(viewTag);\n global._notifyAboutEnd(viewTag, removeViews);\n }\n toRemove.clear();\n }\n }\n };\n return progressTransitionManager;\n}\nif (shouldBeUseWeb()) {\n const maybeThrowError = () => {\n // Jest attempts to access a property of this object to check if it is a Jest mock\n // so we can't throw an error in the getter.\n if (!isJest()) {\n throw new Error('[Reanimated] `ProgressTransitionRegister` is not available on non-native platform.');\n }\n };\n global.ProgressTransitionRegister = new Proxy({}, {\n get: maybeThrowError,\n set: () => {\n maybeThrowError();\n return false;\n }\n });\n} else {\n runOnUIImmediately(() => {\n 'worklet';\n\n global.ProgressTransitionRegister = createProgressTransitionRegister();\n })();\n}\n//# sourceMappingURL=ProgressTransitionManager.js.map","'use strict';\n\nexport function getUseOfValueInStyleWarning() {\n return \"It looks like you might be using shared value's .value inside reanimated inline style. \" + 'If you want a component to update when shared value changes you should use the shared value' + ' directly instead of its current state represented by `.value`. See documentation here: ' + 'https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/glossary/#animations-in-inline-styling';\n}\n//# sourceMappingURL=pluginUtils.js.map","'use strict';\n\n/*\n * Stubbed for web, where we don't use this file;\n */\nexport function withReanimatedTimer() {\n // NOOP\n}\nexport function advanceAnimationByTime() {\n // NOOP\n}\nexport function advanceAnimationByFrame() {\n // NOOP\n}\nexport function setUpTests() {\n // NOOP\n}\nexport function getAnimatedStyle() {\n // NOOP\n}\n//# sourceMappingURL=jestUtils.web.js.map","'use strict';\n\nimport React, { Children, Component, createContext, useEffect, useRef } from 'react';\nimport { setShouldAnimateExitingForTag } from '../core';\nimport { findNodeHandle } from 'react-native';\nexport const SkipEnteringContext = /*#__PURE__*/createContext(null);\n\n// skipEntering - don't animate entering of children on wrapper mount\n// skipExiting - don't animate exiting of children on wrapper unmount\n\nfunction SkipEntering(props) {\n const skipValueRef = useRef(props.shouldSkip);\n useEffect(() => {\n skipValueRef.current = false;\n }, [skipValueRef]);\n return /*#__PURE__*/React.createElement(SkipEnteringContext.Provider, {\n value: skipValueRef\n }, props.children);\n}\n\n// skipExiting (unlike skipEntering) cannot be done by conditionally\n// configuring the animation in `createAnimatedComponent`, since at this stage\n// we don't know if the wrapper is going to be unmounted or not.\n// That's why we need to pass the skipExiting flag to the native side\n// when the wrapper is unmounted to prevent the animation.\n// Since `ReactNode` can be a list of nodes, we wrap every child with our wrapper\n// so we are able to access its tag with `findNodeHandle`.\n/**\n * A component that lets you skip entering and exiting animations.\n *\n * @param skipEntering - A boolean indicating whether children's entering animations should be skipped when `LayoutAnimationConfig` is mounted.\n * @param skipExiting - A boolean indicating whether children's exiting animations should be skipped when LayoutAnimationConfig is unmounted.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/layout-animations/layout-animation-config/\n */\nexport class LayoutAnimationConfig extends Component {\n getMaybeWrappedChildren() {\n return Children.count(this.props.children) > 1 && this.props.skipExiting ? Children.map(this.props.children, child => /*#__PURE__*/React.createElement(LayoutAnimationConfig, {\n skipExiting: true\n }, child)) : this.props.children;\n }\n setShouldAnimateExiting() {\n if (Children.count(this.props.children) === 1) {\n const tag = findNodeHandle(this);\n if (tag) {\n setShouldAnimateExitingForTag(tag, !this.props.skipExiting);\n }\n }\n }\n componentWillUnmount() {\n if (this.props.skipExiting !== undefined) {\n this.setShouldAnimateExiting();\n }\n }\n render() {\n const children = this.getMaybeWrappedChildren();\n if (this.props.skipEntering === undefined) {\n return children;\n }\n return /*#__PURE__*/React.createElement(SkipEntering, {\n shouldSkip: this.props.skipEntering\n }, children);\n }\n}\n//# sourceMappingURL=LayoutAnimationConfig.js.map","'use strict';\n\nimport React, { useEffect, useRef } from 'react';\nimport { TextInput, StyleSheet, View } from 'react-native';\nimport { useSharedValue, useAnimatedProps, useFrameCallback } from '../hook';\nimport { createAnimatedComponent } from '../../createAnimatedComponent';\nimport { addWhitelistedNativeProps } from '../../ConfigHelper';\nfunction createCircularDoublesBuffer(size) {\n 'worklet';\n\n return {\n next: 0,\n buffer: new Float32Array(size),\n size,\n count: 0,\n push(value) {\n const oldValue = this.buffer[this.next];\n const oldCount = this.count;\n this.buffer[this.next] = value;\n this.next = (this.next + 1) % this.size;\n this.count = Math.min(this.size, this.count + 1);\n return oldCount === this.size ? oldValue : null;\n },\n front() {\n const notEmpty = this.count > 0;\n if (notEmpty) {\n const current = this.next - 1;\n const index = current < 0 ? this.size - 1 : current;\n return this.buffer[index];\n }\n return null;\n },\n back() {\n const notEmpty = this.count > 0;\n return notEmpty ? this.buffer[this.next] : null;\n }\n };\n}\nconst DEFAULT_BUFFER_SIZE = 60;\naddWhitelistedNativeProps({\n text: true\n});\nconst AnimatedTextInput = createAnimatedComponent(TextInput);\nfunction loopAnimationFrame(fn) {\n let lastTime = 0;\n function loop() {\n requestAnimationFrame(time => {\n if (lastTime > 0) {\n fn(lastTime, time);\n }\n lastTime = time;\n requestAnimationFrame(loop);\n });\n }\n loop();\n}\nfunction getFps(renderTimeInMs) {\n 'worklet';\n\n return 1000 / renderTimeInMs;\n}\nfunction getTimeDelta(timestamp, previousTimestamp) {\n 'worklet';\n\n return previousTimestamp !== null ? timestamp - previousTimestamp : 0;\n}\nfunction completeBufferRoutine(buffer, timestamp, previousTimestamp, totalRenderTime) {\n 'worklet';\n\n timestamp = Math.round(timestamp);\n previousTimestamp = Math.round(previousTimestamp) ?? timestamp;\n const droppedTimestamp = buffer.push(timestamp);\n const nextToDrop = buffer.back();\n const delta = getTimeDelta(timestamp, previousTimestamp);\n const droppedDelta = getTimeDelta(nextToDrop, droppedTimestamp);\n totalRenderTime.value += delta - droppedDelta;\n return getFps(totalRenderTime.value / buffer.count);\n}\nfunction JsPerformance() {\n const jsFps = useSharedValue(null);\n const totalRenderTime = useSharedValue(0);\n const circularBuffer = useRef(createCircularDoublesBuffer(DEFAULT_BUFFER_SIZE));\n useEffect(() => {\n loopAnimationFrame((_, timestamp) => {\n timestamp = Math.round(timestamp);\n const previousTimestamp = circularBuffer.current.front() ?? timestamp;\n const currentFps = completeBufferRoutine(circularBuffer.current, timestamp, previousTimestamp, totalRenderTime);\n\n // JS fps have to be measured every 2nd frame,\n // thus 2x multiplication has to occur here\n jsFps.value = (currentFps * 2).toFixed(0);\n });\n }, []);\n const animatedProps = useAnimatedProps(() => {\n const text = 'JS: ' + jsFps.value ?? 'N/A';\n return {\n text,\n defaultValue: text\n };\n });\n return /*#__PURE__*/React.createElement(View, {\n style: styles.container\n }, /*#__PURE__*/React.createElement(AnimatedTextInput, {\n style: styles.text,\n animatedProps: animatedProps,\n editable: false\n }));\n}\nfunction UiPerformance() {\n const uiFps = useSharedValue(null);\n const totalRenderTime = useSharedValue(0);\n const circularBuffer = useSharedValue(null);\n useFrameCallback(({\n timestamp\n }) => {\n if (circularBuffer.value === null) {\n circularBuffer.value = createCircularDoublesBuffer(DEFAULT_BUFFER_SIZE);\n }\n timestamp = Math.round(timestamp);\n const previousTimestamp = circularBuffer.value.front() ?? timestamp;\n const currentFps = completeBufferRoutine(circularBuffer.value, timestamp, previousTimestamp, totalRenderTime);\n uiFps.value = currentFps.toFixed(0);\n });\n const animatedProps = useAnimatedProps(() => {\n const text = 'UI: ' + uiFps.value ?? 'N/A';\n return {\n text,\n defaultValue: text\n };\n });\n return /*#__PURE__*/React.createElement(View, {\n style: styles.container\n }, /*#__PURE__*/React.createElement(AnimatedTextInput, {\n style: styles.text,\n animatedProps: animatedProps,\n editable: false\n }));\n}\nexport function PerformanceMonitor() {\n return /*#__PURE__*/React.createElement(View, {\n style: styles.monitor\n }, /*#__PURE__*/React.createElement(JsPerformance, null), /*#__PURE__*/React.createElement(UiPerformance, null));\n}\nconst styles = StyleSheet.create({\n monitor: {\n flexDirection: 'row',\n position: 'absolute',\n backgroundColor: '#0006',\n zIndex: 1000\n },\n header: {\n fontSize: 14,\n color: '#ffff',\n paddingHorizontal: 5\n },\n text: {\n fontSize: 13,\n color: '#ffff',\n fontFamily: 'monospace',\n paddingHorizontal: 3\n },\n container: {\n alignItems: 'center',\n justifyContent: 'center',\n flexDirection: 'row',\n flexWrap: 'wrap'\n }\n});\n//# sourceMappingURL=PerformanceMonitor.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport createElement from '../createElement';\nimport * as forwardedProps from '../../modules/forwardedProps';\nimport pick from '../../modules/pick';\nimport useElementLayout from '../../modules/useElementLayout';\nimport useLayoutEffect from '../../modules/useLayoutEffect';\nimport useMergeRefs from '../../modules/useMergeRefs';\nimport usePlatformMethods from '../../modules/usePlatformMethods';\nimport useResponderEvents from '../../modules/useResponderEvents';\nimport { getLocaleDirection, useLocaleContext } from '../../modules/useLocale';\nimport StyleSheet from '../StyleSheet';\nimport TextInputState from '../../modules/TextInputState';\nimport { warnOnce } from '../../modules/warnOnce';\n\n/**\n * Determines whether a 'selection' prop differs from a node's existing\n * selection state.\n */\nvar isSelectionStale = (node, selection) => {\n var selectionEnd = node.selectionEnd,\n selectionStart = node.selectionStart;\n var start = selection.start,\n end = selection.end;\n return start !== selectionStart || end !== selectionEnd;\n};\n\n/**\n * Certain input types do no support 'selectSelectionRange' and will throw an\n * error.\n */\nvar setSelection = (node, selection) => {\n if (isSelectionStale(node, selection)) {\n var start = selection.start,\n end = selection.end;\n try {\n node.setSelectionRange(start, end || start);\n } catch (e) {}\n }\n};\nvar forwardPropsList = Object.assign({}, forwardedProps.defaultProps, forwardedProps.accessibilityProps, forwardedProps.clickProps, forwardedProps.focusProps, forwardedProps.keyboardProps, forwardedProps.mouseProps, forwardedProps.touchProps, forwardedProps.styleProps, {\n autoCapitalize: true,\n autoComplete: true,\n autoCorrect: true,\n autoFocus: true,\n defaultValue: true,\n disabled: true,\n lang: true,\n maxLength: true,\n onChange: true,\n onScroll: true,\n placeholder: true,\n pointerEvents: true,\n readOnly: true,\n rows: true,\n spellCheck: true,\n value: true,\n type: true\n});\nvar pickProps = props => pick(props, forwardPropsList);\n\n// If an Input Method Editor is processing key input, the 'keyCode' is 229.\n// https://www.w3.org/TR/uievents/#determine-keydown-keyup-keyCode\nfunction isEventComposing(nativeEvent) {\n return nativeEvent.isComposing || nativeEvent.keyCode === 229;\n}\nvar focusTimeout = null;\nvar TextInput = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var _props$autoCapitalize = props.autoCapitalize,\n autoCapitalize = _props$autoCapitalize === void 0 ? 'sentences' : _props$autoCapitalize,\n autoComplete = props.autoComplete,\n autoCompleteType = props.autoCompleteType,\n _props$autoCorrect = props.autoCorrect,\n autoCorrect = _props$autoCorrect === void 0 ? true : _props$autoCorrect,\n blurOnSubmit = props.blurOnSubmit,\n caretHidden = props.caretHidden,\n clearTextOnFocus = props.clearTextOnFocus,\n dir = props.dir,\n editable = props.editable,\n enterKeyHint = props.enterKeyHint,\n inputMode = props.inputMode,\n keyboardType = props.keyboardType,\n _props$multiline = props.multiline,\n multiline = _props$multiline === void 0 ? false : _props$multiline,\n numberOfLines = props.numberOfLines,\n onBlur = props.onBlur,\n onChange = props.onChange,\n onChangeText = props.onChangeText,\n onContentSizeChange = props.onContentSizeChange,\n onFocus = props.onFocus,\n onKeyPress = props.onKeyPress,\n onLayout = props.onLayout,\n onMoveShouldSetResponder = props.onMoveShouldSetResponder,\n onMoveShouldSetResponderCapture = props.onMoveShouldSetResponderCapture,\n onResponderEnd = props.onResponderEnd,\n onResponderGrant = props.onResponderGrant,\n onResponderMove = props.onResponderMove,\n onResponderReject = props.onResponderReject,\n onResponderRelease = props.onResponderRelease,\n onResponderStart = props.onResponderStart,\n onResponderTerminate = props.onResponderTerminate,\n onResponderTerminationRequest = props.onResponderTerminationRequest,\n onScrollShouldSetResponder = props.onScrollShouldSetResponder,\n onScrollShouldSetResponderCapture = props.onScrollShouldSetResponderCapture,\n onSelectionChange = props.onSelectionChange,\n onSelectionChangeShouldSetResponder = props.onSelectionChangeShouldSetResponder,\n onSelectionChangeShouldSetResponderCapture = props.onSelectionChangeShouldSetResponderCapture,\n onStartShouldSetResponder = props.onStartShouldSetResponder,\n onStartShouldSetResponderCapture = props.onStartShouldSetResponderCapture,\n onSubmitEditing = props.onSubmitEditing,\n placeholderTextColor = props.placeholderTextColor,\n _props$readOnly = props.readOnly,\n readOnly = _props$readOnly === void 0 ? false : _props$readOnly,\n returnKeyType = props.returnKeyType,\n rows = props.rows,\n _props$secureTextEntr = props.secureTextEntry,\n secureTextEntry = _props$secureTextEntr === void 0 ? false : _props$secureTextEntr,\n selection = props.selection,\n selectTextOnFocus = props.selectTextOnFocus,\n showSoftInputOnFocus = props.showSoftInputOnFocus,\n spellCheck = props.spellCheck;\n var type;\n var _inputMode;\n if (inputMode != null) {\n _inputMode = inputMode;\n if (inputMode === 'email') {\n type = 'email';\n } else if (inputMode === 'tel') {\n type = 'tel';\n } else if (inputMode === 'search') {\n type = 'search';\n } else if (inputMode === 'url') {\n type = 'url';\n } else {\n type = 'text';\n }\n } else if (keyboardType != null) {\n warnOnce('keyboardType', 'keyboardType is deprecated. Use inputMode.');\n switch (keyboardType) {\n case 'email-address':\n type = 'email';\n break;\n case 'number-pad':\n case 'numeric':\n _inputMode = 'numeric';\n break;\n case 'decimal-pad':\n _inputMode = 'decimal';\n break;\n case 'phone-pad':\n type = 'tel';\n break;\n case 'search':\n case 'web-search':\n type = 'search';\n break;\n case 'url':\n type = 'url';\n break;\n default:\n type = 'text';\n }\n }\n if (secureTextEntry) {\n type = 'password';\n }\n var dimensions = React.useRef({\n height: null,\n width: null\n });\n var hostRef = React.useRef(null);\n var prevSelection = React.useRef(null);\n var prevSecureTextEntry = React.useRef(false);\n React.useEffect(() => {\n if (hostRef.current && prevSelection.current) {\n setSelection(hostRef.current, prevSelection.current);\n }\n prevSecureTextEntry.current = secureTextEntry;\n }, [secureTextEntry]);\n var handleContentSizeChange = React.useCallback(hostNode => {\n if (multiline && onContentSizeChange && hostNode != null) {\n var newHeight = hostNode.scrollHeight;\n var newWidth = hostNode.scrollWidth;\n if (newHeight !== dimensions.current.height || newWidth !== dimensions.current.width) {\n dimensions.current.height = newHeight;\n dimensions.current.width = newWidth;\n onContentSizeChange({\n nativeEvent: {\n contentSize: {\n height: dimensions.current.height,\n width: dimensions.current.width\n }\n }\n });\n }\n }\n }, [multiline, onContentSizeChange]);\n var imperativeRef = React.useMemo(() => hostNode => {\n // TextInput needs to add more methods to the hostNode in addition to those\n // added by `usePlatformMethods`. This is temporarily until an API like\n // `TextInput.clear(hostRef)` is added to React Native.\n if (hostNode != null) {\n hostNode.clear = function () {\n if (hostNode != null) {\n hostNode.value = '';\n }\n };\n hostNode.isFocused = function () {\n return hostNode != null && TextInputState.currentlyFocusedField() === hostNode;\n };\n handleContentSizeChange(hostNode);\n }\n }, [handleContentSizeChange]);\n function handleBlur(e) {\n TextInputState._currentlyFocusedNode = null;\n if (onBlur) {\n e.nativeEvent.text = e.target.value;\n onBlur(e);\n }\n }\n function handleChange(e) {\n var hostNode = e.target;\n var text = hostNode.value;\n e.nativeEvent.text = text;\n handleContentSizeChange(hostNode);\n if (onChange) {\n onChange(e);\n }\n if (onChangeText) {\n onChangeText(text);\n }\n }\n function handleFocus(e) {\n var hostNode = e.target;\n if (onFocus) {\n e.nativeEvent.text = hostNode.value;\n onFocus(e);\n }\n if (hostNode != null) {\n TextInputState._currentlyFocusedNode = hostNode;\n if (clearTextOnFocus) {\n hostNode.value = '';\n }\n if (selectTextOnFocus) {\n // Safari requires selection to occur in a setTimeout\n if (focusTimeout != null) {\n clearTimeout(focusTimeout);\n }\n focusTimeout = setTimeout(() => {\n if (hostNode != null) {\n hostNode.select();\n }\n }, 0);\n }\n }\n }\n function handleKeyDown(e) {\n var hostNode = e.target;\n // Prevent key events bubbling (see #612)\n e.stopPropagation();\n var blurOnSubmitDefault = !multiline;\n var shouldBlurOnSubmit = blurOnSubmit == null ? blurOnSubmitDefault : blurOnSubmit;\n var nativeEvent = e.nativeEvent;\n var isComposing = isEventComposing(nativeEvent);\n if (onKeyPress) {\n onKeyPress(e);\n }\n if (e.key === 'Enter' && !e.shiftKey &&\n // Do not call submit if composition is occuring.\n !isComposing && !e.isDefaultPrevented()) {\n if ((blurOnSubmit || !multiline) && onSubmitEditing) {\n // prevent \"Enter\" from inserting a newline or submitting a form\n e.preventDefault();\n nativeEvent.text = e.target.value;\n onSubmitEditing(e);\n }\n if (shouldBlurOnSubmit && hostNode != null) {\n setTimeout(() => hostNode.blur(), 0);\n }\n }\n }\n function handleSelectionChange(e) {\n try {\n var _e$target = e.target,\n selectionStart = _e$target.selectionStart,\n selectionEnd = _e$target.selectionEnd;\n var _selection = {\n start: selectionStart,\n end: selectionEnd\n };\n if (onSelectionChange) {\n e.nativeEvent.selection = _selection;\n e.nativeEvent.text = e.target.value;\n onSelectionChange(e);\n }\n if (prevSecureTextEntry.current === secureTextEntry) {\n prevSelection.current = _selection;\n }\n } catch (e) {}\n }\n useLayoutEffect(() => {\n var node = hostRef.current;\n if (node != null && selection != null) {\n setSelection(node, selection);\n }\n if (document.activeElement === node) {\n TextInputState._currentlyFocusedNode = node;\n }\n }, [hostRef, selection]);\n var component = multiline ? 'textarea' : 'input';\n useElementLayout(hostRef, onLayout);\n useResponderEvents(hostRef, {\n onMoveShouldSetResponder,\n onMoveShouldSetResponderCapture,\n onResponderEnd,\n onResponderGrant,\n onResponderMove,\n onResponderReject,\n onResponderRelease,\n onResponderStart,\n onResponderTerminate,\n onResponderTerminationRequest,\n onScrollShouldSetResponder,\n onScrollShouldSetResponderCapture,\n onSelectionChangeShouldSetResponder,\n onSelectionChangeShouldSetResponderCapture,\n onStartShouldSetResponder,\n onStartShouldSetResponderCapture\n });\n var _useLocaleContext = useLocaleContext(),\n contextDirection = _useLocaleContext.direction;\n var supportedProps = pickProps(props);\n supportedProps.autoCapitalize = autoCapitalize;\n supportedProps.autoComplete = autoComplete || autoCompleteType || 'on';\n supportedProps.autoCorrect = autoCorrect ? 'on' : 'off';\n // 'auto' by default allows browsers to infer writing direction\n supportedProps.dir = dir !== undefined ? dir : 'auto';\n if (returnKeyType != null) {\n warnOnce('returnKeyType', 'returnKeyType is deprecated. Use enterKeyHint.');\n }\n supportedProps.enterKeyHint = enterKeyHint || returnKeyType;\n supportedProps.inputMode = _inputMode;\n supportedProps.onBlur = handleBlur;\n supportedProps.onChange = handleChange;\n supportedProps.onFocus = handleFocus;\n supportedProps.onKeyDown = handleKeyDown;\n supportedProps.onSelect = handleSelectionChange;\n if (editable != null) {\n warnOnce('editable', 'editable is deprecated. Use readOnly.');\n }\n supportedProps.readOnly = readOnly === true || editable === false;\n if (numberOfLines != null) {\n warnOnce('numberOfLines', 'TextInput numberOfLines is deprecated. Use rows.');\n }\n supportedProps.rows = multiline ? rows != null ? rows : numberOfLines : 1;\n supportedProps.spellCheck = spellCheck != null ? spellCheck : autoCorrect;\n supportedProps.style = [{\n '--placeholderTextColor': placeholderTextColor\n }, styles.textinput$raw, styles.placeholder, props.style, caretHidden && styles.caretHidden];\n supportedProps.type = multiline ? undefined : type;\n supportedProps.virtualkeyboardpolicy = showSoftInputOnFocus === false ? 'manual' : 'auto';\n var platformMethodsRef = usePlatformMethods(supportedProps);\n var setRef = useMergeRefs(hostRef, platformMethodsRef, imperativeRef, forwardedRef);\n supportedProps.ref = setRef;\n var langDirection = props.lang != null ? getLocaleDirection(props.lang) : null;\n var componentDirection = props.dir || langDirection;\n var writingDirection = componentDirection || contextDirection;\n var element = createElement(component, supportedProps, {\n writingDirection\n });\n return element;\n});\nTextInput.displayName = 'TextInput';\n// $FlowFixMe\nTextInput.State = TextInputState;\nvar styles = StyleSheet.create({\n textinput$raw: {\n MozAppearance: 'textfield',\n WebkitAppearance: 'none',\n backgroundColor: 'transparent',\n border: '0 solid black',\n borderRadius: 0,\n boxSizing: 'border-box',\n font: '14px System',\n margin: 0,\n padding: 0,\n resize: 'none'\n },\n placeholder: {\n placeholderTextColor: 'var(--placeholderTextColor)'\n },\n caretHidden: {\n caretColor: 'transparent'\n }\n});\nexport default TextInput;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport UIManager from '../../exports/UIManager';\n\n/**\n * This class is responsible for coordinating the \"focused\"\n * state for TextInputs. All calls relating to the keyboard\n * should be funneled through here\n */\nvar TextInputState = {\n /**\n * Internal state\n */\n _currentlyFocusedNode: null,\n /**\n * Returns the ID of the currently focused text field, if one exists\n * If no text field is focused it returns null\n */\n currentlyFocusedField() {\n if (document.activeElement !== this._currentlyFocusedNode) {\n this._currentlyFocusedNode = null;\n }\n return this._currentlyFocusedNode;\n },\n /**\n * @param {Object} TextInputID id of the text field to focus\n * Focuses the specified text field\n * noop if the text field was already focused\n */\n focusTextInput(textFieldNode) {\n if (textFieldNode !== null) {\n this._currentlyFocusedNode = textFieldNode;\n if (document.activeElement !== textFieldNode) {\n UIManager.focus(textFieldNode);\n }\n }\n },\n /**\n * @param {Object} textFieldNode id of the text field to focus\n * Unfocuses the specified text field\n * noop if it wasn't focused\n */\n blurTextInput(textFieldNode) {\n if (textFieldNode !== null) {\n this._currentlyFocusedNode = null;\n if (document.activeElement === textFieldNode) {\n UIManager.blur(textFieldNode);\n }\n }\n }\n};\nexport default TextInputState;","'use strict';\n\nexport { createAnimatedComponent } from './createAnimatedComponent';\n//# sourceMappingURL=index.js.map","'use strict';\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport React from 'react';\nimport { findNodeHandle, Platform } from 'react-native';\nimport { WorkletEventHandler } from '../reanimated2/WorkletEventHandler';\nimport '../reanimated2/layoutReanimation/animationsManager';\nimport invariant from 'invariant';\nimport { adaptViewConfig } from '../ConfigHelper';\nimport { RNRenderer } from '../reanimated2/platform-specific/RNRenderer';\nimport { enableLayoutAnimations } from '../reanimated2/core';\nimport { SharedTransition, LayoutAnimationType } from '../reanimated2/layoutReanimation';\nimport { getShadowNodeWrapperFromRef } from '../reanimated2/fabricUtils';\nimport { removeFromPropsRegistry } from '../reanimated2/PropsRegistry';\nimport { getReduceMotionFromConfig } from '../reanimated2/animation/util';\nimport { maybeBuild } from '../animationBuilder';\nimport { SkipEnteringContext } from '../reanimated2/component/LayoutAnimationConfig';\nimport JSPropsUpdater from './JSPropsUpdater';\nimport { has, flattenArray } from './utils';\nimport setAndForwardRef from './setAndForwardRef';\nimport { isFabric, isJest, isWeb, shouldBeUseWeb } from '../reanimated2/PlatformChecker';\nimport { InlinePropManager } from './InlinePropManager';\nimport { PropsFilter } from './PropsFilter';\nimport { startWebLayoutAnimation, tryActivateLayoutTransition, configureWebLayoutAnimations, getReducedMotionFromConfig, saveSnapshot } from '../reanimated2/layoutReanimation/web';\nimport { updateLayoutAnimations } from '../reanimated2/UpdateLayoutAnimations';\nimport { addHTMLMutationObserver } from '../reanimated2/layoutReanimation/web/domUtils';\nimport { getViewInfo } from './getViewInfo';\nconst IS_WEB = isWeb();\nif (IS_WEB) {\n configureWebLayoutAnimations();\n}\nfunction onlyAnimatedStyles(styles) {\n return styles.filter(style => style === null || style === void 0 ? void 0 : style.viewDescriptors);\n}\n\n/**\n * Lets you create an Animated version of any React Native component.\n *\n * @param component - The component you want to make animatable.\n * @returns A component that Reanimated is capable of animating.\n * @see https://docs.swmansion.com/react-native-reanimated/docs/core/createAnimatedComponent\n */\n\n// Don't change the order of overloads, since such a change breaks current behavior\n\n/**\n * @deprecated Please use `Animated.FlatList` component instead of calling `Animated.createAnimatedComponent(FlatList)` manually.\n */\n// @ts-ignore This is required to create this overload, since type of createAnimatedComponent is incorrect and doesn't include typeof FlatList\n\nexport function createAnimatedComponent(Component, options) {\n invariant(typeof Component !== 'function' || Component.prototype && Component.prototype.isReactComponent, `Looks like you're passing a function component \\`${Component.name}\\` to \\`createAnimatedComponent\\` function which supports only class components. Please wrap your function component with \\`React.forwardRef()\\` or use a class component instead.`);\n class AnimatedComponent extends React.Component {\n constructor(props) {\n super(props);\n _defineProperty(this, \"_styles\", null);\n _defineProperty(this, \"_animatedProps\", void 0);\n _defineProperty(this, \"_viewTag\", -1);\n _defineProperty(this, \"_isFirstRender\", true);\n _defineProperty(this, \"jestAnimatedStyle\", {\n value: {}\n });\n _defineProperty(this, \"_component\", null);\n _defineProperty(this, \"_sharedElementTransition\", null);\n _defineProperty(this, \"_jsPropsUpdater\", new JSPropsUpdater());\n _defineProperty(this, \"_InlinePropManager\", new InlinePropManager());\n _defineProperty(this, \"_PropsFilter\", new PropsFilter());\n _defineProperty(this, \"_viewInfo\", void 0);\n _defineProperty(this, \"context\", void 0);\n _defineProperty(this, \"_setComponentRef\", setAndForwardRef({\n getForwardedRef: () => this.props.forwardedRef,\n setLocalRef: ref => {\n // TODO update config\n\n const tag = IS_WEB ? ref : findNodeHandle(ref);\n this._viewTag = tag;\n const {\n layout,\n entering,\n exiting,\n sharedTransitionTag\n } = this.props;\n if ((layout || entering || exiting || sharedTransitionTag) && tag != null) {\n var _this$context;\n if (!shouldBeUseWeb()) {\n enableLayoutAnimations(true, false);\n }\n if (sharedTransitionTag) {\n this._configureSharedTransition();\n }\n const skipEntering = (_this$context = this.context) === null || _this$context === void 0 ? void 0 : _this$context.current;\n if (entering && !skipEntering) {\n var _this$props;\n updateLayoutAnimations(tag, LayoutAnimationType.ENTERING, maybeBuild(entering, (_this$props = this.props) === null || _this$props === void 0 ? void 0 : _this$props.style, AnimatedComponent.displayName));\n }\n }\n if (ref !== this._component) {\n this._component = ref;\n }\n }\n }));\n if (isJest()) {\n this.jestAnimatedStyle = {\n value: {}\n };\n }\n }\n componentDidMount() {\n this._viewTag = this._getViewInfo().viewTag;\n this._attachNativeEvents();\n this._jsPropsUpdater.addOnJSPropsChangeListener(this);\n this._attachAnimatedStyles();\n this._InlinePropManager.attachInlineProps(this, this._getViewInfo());\n const layout = this.props.layout;\n if (layout) {\n this._configureLayoutTransition();\n }\n if (IS_WEB) {\n if (this.props.exiting) {\n saveSnapshot(this._component);\n }\n if (!this.props.entering || getReducedMotionFromConfig(this.props.entering)) {\n this._isFirstRender = false;\n return;\n }\n startWebLayoutAnimation(this.props, this._component, LayoutAnimationType.ENTERING);\n }\n this._isFirstRender = false;\n }\n componentWillUnmount() {\n var _this$_sharedElementT;\n this._detachNativeEvents();\n this._jsPropsUpdater.removeOnJSPropsChangeListener(this);\n this._detachStyles();\n this._InlinePropManager.detachInlineProps();\n if (this.props.sharedTransitionTag) {\n this._configureSharedTransition(true);\n }\n (_this$_sharedElementT = this._sharedElementTransition) === null || _this$_sharedElementT === void 0 || _this$_sharedElementT.unregisterTransition(this._viewTag, true);\n const exiting = this.props.exiting;\n if (IS_WEB && this._component && this.props.exiting && !getReducedMotionFromConfig(this.props.exiting)) {\n addHTMLMutationObserver();\n startWebLayoutAnimation(this.props, this._component, LayoutAnimationType.EXITING);\n } else if (exiting) {\n const reduceMotionInExiting = 'getReduceMotion' in exiting && typeof exiting.getReduceMotion === 'function' ? getReduceMotionFromConfig(exiting.getReduceMotion()) : getReduceMotionFromConfig();\n if (!reduceMotionInExiting) {\n var _this$props2;\n updateLayoutAnimations(this._viewTag, LayoutAnimationType.EXITING, maybeBuild(exiting, (_this$props2 = this.props) === null || _this$props2 === void 0 ? void 0 : _this$props2.style, AnimatedComponent.displayName));\n }\n }\n }\n _getEventViewRef() {\n var _this$_component, _getScrollableNode, _ref;\n // Make sure to get the scrollable node for components that implement\n // `ScrollResponder.Mixin`.\n return (_this$_component = this._component) !== null && _this$_component !== void 0 && _this$_component.getScrollableNode ? (_getScrollableNode = (_ref = this._component).getScrollableNode) === null || _getScrollableNode === void 0 ? void 0 : _getScrollableNode.call(_ref) : this._component;\n }\n _attachNativeEvents() {\n for (const key in this.props) {\n const prop = this.props[key];\n if (has('workletEventHandler', prop) && prop.workletEventHandler instanceof WorkletEventHandler) {\n prop.workletEventHandler.registerForEvents(this._viewTag, key);\n }\n }\n }\n _detachNativeEvents() {\n for (const key in this.props) {\n const prop = this.props[key];\n if (has('workletEventHandler', prop) && prop.workletEventHandler instanceof WorkletEventHandler) {\n prop.workletEventHandler.unregisterFromEvents(this._viewTag);\n }\n }\n }\n _detachStyles() {\n if (IS_WEB && this._styles !== null) {\n for (const style of this._styles) {\n style.viewsRef.remove(this);\n }\n } else if (this._viewTag !== -1 && this._styles !== null) {\n var _this$props$animatedP;\n for (const style of this._styles) {\n style.viewDescriptors.remove(this._viewTag);\n }\n if ((_this$props$animatedP = this.props.animatedProps) !== null && _this$props$animatedP !== void 0 && _this$props$animatedP.viewDescriptors) {\n this.props.animatedProps.viewDescriptors.remove(this._viewTag);\n }\n if (isFabric()) {\n removeFromPropsRegistry(this._viewTag);\n }\n }\n }\n _updateNativeEvents(prevProps) {\n for (const key in prevProps) {\n const prevProp = prevProps[key];\n if (has('workletEventHandler', prevProp) && prevProp.workletEventHandler instanceof WorkletEventHandler) {\n const newProp = this.props[key];\n if (!newProp) {\n // Prop got deleted\n prevProp.workletEventHandler.unregisterFromEvents(this._viewTag);\n } else if (has('workletEventHandler', newProp) && newProp.workletEventHandler instanceof WorkletEventHandler && newProp.workletEventHandler !== prevProp.workletEventHandler) {\n // Prop got changed\n prevProp.workletEventHandler.unregisterFromEvents(this._viewTag);\n newProp.workletEventHandler.registerForEvents(this._viewTag);\n }\n }\n }\n for (const key in this.props) {\n const newProp = this.props[key];\n if (has('workletEventHandler', newProp) && newProp.workletEventHandler instanceof WorkletEventHandler && !prevProps[key]) {\n // Prop got added\n newProp.workletEventHandler.registerForEvents(this._viewTag);\n }\n }\n }\n _updateFromNative(props) {\n if (options !== null && options !== void 0 && options.setNativeProps) {\n options.setNativeProps(this._component, props);\n } else {\n var _this$_component2, _this$_component2$set;\n (_this$_component2 = this._component) === null || _this$_component2 === void 0 || (_this$_component2$set = _this$_component2.setNativeProps) === null || _this$_component2$set === void 0 || _this$_component2$set.call(_this$_component2, props);\n }\n }\n _getViewInfo() {\n var _this$_component3, _getAnimatableRef, _ref2;\n if (this._viewInfo !== undefined) {\n return this._viewInfo;\n }\n let viewTag;\n let viewName;\n let shadowNodeWrapper = null;\n let viewConfig;\n // Component can specify ref which should be animated when animated version of the component is created.\n // Otherwise, we animate the component itself.\n const component = (_this$_component3 = this._component) !== null && _this$_component3 !== void 0 && _this$_component3.getAnimatableRef ? (_getAnimatableRef = (_ref2 = this._component).getAnimatableRef) === null || _getAnimatableRef === void 0 ? void 0 : _getAnimatableRef.call(_ref2) : this;\n if (IS_WEB) {\n // At this point I assume that `_setComponentRef` was already called and `_component` is set.\n // `this._component` on web represents HTMLElement of our component, that's why we use casting\n viewTag = this._component;\n viewName = null;\n shadowNodeWrapper = null;\n viewConfig = null;\n } else {\n // hostInstance can be null for a component that doesn't render anything (render function returns null). Example: svg Stop: https://github.com/react-native-svg/react-native-svg/blob/develop/src/elements/Stop.tsx\n const hostInstance = RNRenderer.findHostInstance_DEPRECATED(component);\n if (!hostInstance) {\n throw new Error('[Reanimated] Cannot find host instance for this component. Maybe it renders nothing?');\n }\n const viewInfo = getViewInfo(hostInstance);\n viewTag = viewInfo.viewTag;\n viewName = viewInfo.viewName;\n viewConfig = viewInfo.viewConfig;\n shadowNodeWrapper = isFabric() ? getShadowNodeWrapperFromRef(this) : null;\n }\n this._viewInfo = {\n viewTag,\n viewName,\n shadowNodeWrapper,\n viewConfig\n };\n return this._viewInfo;\n }\n _attachAnimatedStyles() {\n var _this$props$animatedP2, _this$props$animatedP3;\n const styles = this.props.style ? onlyAnimatedStyles(flattenArray(this.props.style)) : [];\n const prevStyles = this._styles;\n this._styles = styles;\n const prevAnimatedProps = this._animatedProps;\n this._animatedProps = this.props.animatedProps;\n const {\n viewTag,\n viewName,\n shadowNodeWrapper,\n viewConfig\n } = this._getViewInfo();\n\n // update UI props whitelist for this view\n const hasReanimated2Props = ((_this$props$animatedP2 = this.props.animatedProps) === null || _this$props$animatedP2 === void 0 ? void 0 : _this$props$animatedP2.viewDescriptors) || styles.length;\n if (hasReanimated2Props && viewConfig) {\n adaptViewConfig(viewConfig);\n }\n this._viewTag = viewTag;\n\n // remove old styles\n if (prevStyles) {\n // in most of the cases, views have only a single animated style and it remains unchanged\n const hasOneSameStyle = styles.length === 1 && prevStyles.length === 1 && styles[0] === prevStyles[0];\n if (!hasOneSameStyle) {\n // otherwise, remove each style that is not present in new styles\n for (const prevStyle of prevStyles) {\n const isPresent = styles.some(style => style === prevStyle);\n if (!isPresent) {\n prevStyle.viewDescriptors.remove(viewTag);\n }\n }\n }\n }\n styles.forEach(style => {\n style.viewDescriptors.add({\n tag: viewTag,\n name: viewName,\n shadowNodeWrapper\n });\n if (isJest()) {\n /**\n * We need to connect Jest's TestObject instance whose contains just props object\n * with the updateProps() function where we update the properties of the component.\n * We can't update props object directly because TestObject contains a copy of props - look at render function:\n * const props = this._filterNonAnimatedProps(this.props);\n */\n this.jestAnimatedStyle.value = {\n ...this.jestAnimatedStyle.value,\n ...style.initial.value\n };\n style.jestAnimatedStyle.current = this.jestAnimatedStyle;\n }\n });\n\n // detach old animatedProps\n if (prevAnimatedProps && prevAnimatedProps !== this.props.animatedProps) {\n prevAnimatedProps.viewDescriptors.remove(viewTag);\n }\n\n // attach animatedProps property\n if ((_this$props$animatedP3 = this.props.animatedProps) !== null && _this$props$animatedP3 !== void 0 && _this$props$animatedP3.viewDescriptors) {\n this.props.animatedProps.viewDescriptors.add({\n tag: viewTag,\n name: viewName,\n shadowNodeWrapper: shadowNodeWrapper\n });\n }\n }\n componentDidUpdate(prevProps, _prevState,\n // This type comes straight from React\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n snapshot) {\n const layout = this.props.layout;\n const oldLayout = prevProps.layout;\n if (layout !== oldLayout) {\n this._configureLayoutTransition();\n }\n if (this.props.sharedTransitionTag !== undefined || prevProps.sharedTransitionTag !== undefined) {\n this._configureSharedTransition();\n }\n this._updateNativeEvents(prevProps);\n this._attachAnimatedStyles();\n this._InlinePropManager.attachInlineProps(this, this._getViewInfo());\n if (IS_WEB && this.props.exiting) {\n saveSnapshot(this._component);\n }\n\n // Snapshot won't be undefined because it comes from getSnapshotBeforeUpdate method\n if (IS_WEB && snapshot !== null && this.props.layout && !getReducedMotionFromConfig(this.props.layout)) {\n tryActivateLayoutTransition(this.props, this._component, snapshot);\n }\n }\n _configureLayoutTransition() {\n const layout = this.props.layout ? maybeBuild(this.props.layout, undefined /* We don't have to warn user if style has common properties with animation for LAYOUT */, AnimatedComponent.displayName) : undefined;\n updateLayoutAnimations(this._viewTag, LayoutAnimationType.LAYOUT, layout);\n }\n _configureSharedTransition(isUnmounting = false) {\n if (IS_WEB) {\n return;\n }\n const {\n sharedTransitionTag\n } = this.props;\n if (!sharedTransitionTag) {\n var _this$_sharedElementT2;\n (_this$_sharedElementT2 = this._sharedElementTransition) === null || _this$_sharedElementT2 === void 0 || _this$_sharedElementT2.unregisterTransition(this._viewTag, isUnmounting);\n this._sharedElementTransition = null;\n return;\n }\n const sharedElementTransition = this.props.sharedTransitionStyle ?? this._sharedElementTransition ?? new SharedTransition();\n sharedElementTransition.registerTransition(this._viewTag, sharedTransitionTag, isUnmounting);\n this._sharedElementTransition = sharedElementTransition;\n }\n // This is a component lifecycle method from React, therefore we are not calling it directly.\n // It is called before the component gets rerendered. This way we can access components' position before it changed\n // and later on, in componentDidUpdate, calculate translation for layout transition.\n getSnapshotBeforeUpdate() {\n var _this$_component4;\n if (IS_WEB && ((_this$_component4 = this._component) === null || _this$_component4 === void 0 ? void 0 : _this$_component4.getBoundingClientRect) !== undefined) {\n return this._component.getBoundingClientRect();\n }\n return null;\n }\n render() {\n const filteredProps = this._PropsFilter.filterNonAnimatedProps(this);\n if (isJest()) {\n filteredProps.jestAnimatedStyle = this.jestAnimatedStyle;\n }\n\n // Layout animations on web are set inside `componentDidMount` method, which is called after first render.\n // Because of that we can encounter a situation in which component is visible for a short amount of time, and later on animation triggers.\n // I've tested that on various browsers and devices and it did not happen to me. To be sure that it won't happen to someone else,\n // I've decided to hide component at first render. Its visibility is reset in `componentDidMount`.\n if (this._isFirstRender && IS_WEB && filteredProps.entering && !getReducedMotionFromConfig(filteredProps.entering)) {\n filteredProps.style = {\n ...(filteredProps.style ?? {}),\n visibility: 'hidden' // Hide component until `componentDidMount` triggers\n };\n }\n const platformProps = Platform.select({\n web: {},\n default: {\n collapsable: false\n }\n });\n return /*#__PURE__*/React.createElement(Component, _extends({}, filteredProps, {\n // Casting is used here, because ref can be null - in that case it cannot be assigned to HTMLElement.\n // After spending some time trying to figure out what to do with this problem, we decided to leave it this way\n ref: this._setComponentRef\n }, platformProps));\n }\n }\n _defineProperty(AnimatedComponent, \"displayName\", void 0);\n _defineProperty(AnimatedComponent, \"contextType\", SkipEnteringContext);\n AnimatedComponent.displayName = `AnimatedComponent(${Component.displayName || Component.name || 'Component'})`;\n return /*#__PURE__*/React.forwardRef((props, ref) => {\n return /*#__PURE__*/React.createElement(AnimatedComponent, _extends({}, props, ref === null ? null : {\n forwardedRef: ref\n }));\n });\n}\n//# sourceMappingURL=createAnimatedComponent.js.map","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar invariant = function(condition, format, a, b, c, d, e, f) {\n if (process.env.NODE_ENV !== 'production') {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n }\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error(\n 'Minified exception occurred; use the non-minified dev environment ' +\n 'for the full error message and additional helpful warnings.'\n );\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(\n format.replace(/%s/g, function() { return args[argIndex++]; })\n );\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n};\n\nmodule.exports = invariant;\n","'use strict';\n\n// RNRender is not used for web. An export is still defined to eliminate warnings from bundlers such as esbuild.\nmodule.exports = null;\n//# sourceMappingURL=RNRenderer.web.js.map","'use strict';\n\nimport { isFabric } from './PlatformChecker';\nimport { runOnUI } from './threads';\nlet VIEW_TAGS = [];\nexport function removeFromPropsRegistry(viewTag) {\n VIEW_TAGS.push(viewTag);\n if (VIEW_TAGS.length === 1) {\n queueMicrotask(flush);\n }\n}\nfunction flush() {\n if (__DEV__ && !isFabric()) {\n throw new Error('[Reanimated] PropsRegistry is only available on Fabric.');\n }\n runOnUI(removeFromPropsRegistryOnUI)(VIEW_TAGS);\n VIEW_TAGS = [];\n}\nfunction removeFromPropsRegistryOnUI(viewTags) {\n 'worklet';\n\n global._removeFromPropsRegistry(viewTags);\n}\n//# sourceMappingURL=PropsRegistry.js.map","'use strict';\n\nconst mockTargetValues = {\n targetOriginX: 0,\n targetOriginY: 0,\n targetWidth: 0,\n targetHeight: 0,\n targetGlobalOriginX: 0,\n targetGlobalOriginY: 0,\n targetBorderRadius: 0,\n windowWidth: 0,\n windowHeight: 0,\n currentOriginX: 0,\n currentOriginY: 0,\n currentWidth: 0,\n currentHeight: 0,\n currentGlobalOriginX: 0,\n currentGlobalOriginY: 0,\n currentBorderRadius: 0\n};\nfunction getCommonProperties(layoutStyle, componentStyle) {\n let componentStyleFlat = Array.isArray(componentStyle) ? componentStyle.flat() : [componentStyle];\n componentStyleFlat = componentStyleFlat.filter(Boolean);\n componentStyleFlat = componentStyleFlat.map(style => 'initial' in style ? style.initial.value // Include properties of animated style\n : style);\n const componentStylesKeys = componentStyleFlat.flatMap(style => Object.keys(style));\n const commonKeys = Object.keys(layoutStyle).filter(key => componentStylesKeys.includes(key));\n return commonKeys;\n}\nfunction maybeReportOverwrittenProperties(layoutAnimationStyle, style, displayName) {\n const commonProperties = getCommonProperties(layoutAnimationStyle, style);\n if (commonProperties.length > 0) {\n console.warn(`[Reanimated] ${commonProperties.length === 1 ? 'Property' : 'Properties'} \"${commonProperties.join(', ')}\" of ${displayName} may be overwritten by a layout animation. Please wrap your component with an animated view and apply the layout animation on the wrapper.`);\n }\n}\nexport function maybeBuild(layoutAnimationOrBuilder, style, displayName) {\n const isAnimationBuilder = value => 'build' in layoutAnimationOrBuilder && typeof layoutAnimationOrBuilder.build === 'function';\n if (isAnimationBuilder(layoutAnimationOrBuilder)) {\n const animationFactory = layoutAnimationOrBuilder.build();\n if (__DEV__ && style) {\n const layoutAnimation = animationFactory(mockTargetValues);\n maybeReportOverwrittenProperties(layoutAnimation.animations, style, displayName);\n }\n return animationFactory;\n } else {\n return layoutAnimationOrBuilder;\n }\n}\n//# sourceMappingURL=animationBuilder.js.map","'use strict';\n\nexport default class JSPropsUpdaterWeb {\n addOnJSPropsChangeListener(_animatedComponent) {\n // noop\n }\n removeOnJSPropsChangeListener(_animatedComponent) {\n // noop\n }\n}\n//# sourceMappingURL=JSPropsUpdater.web.js.map","'use strict';\n\nexport function flattenArray(array) {\n if (!Array.isArray(array)) {\n return [array];\n }\n const resultArr = [];\n const _flattenArray = arr => {\n arr.forEach(item => {\n if (Array.isArray(item)) {\n _flattenArray(item);\n } else {\n resultArr.push(item);\n }\n });\n };\n _flattenArray(array);\n return resultArr;\n}\nexport const has = (key, x) => {\n if (typeof x === 'function' || typeof x === 'object') {\n if (x === null || x === undefined) {\n return false;\n } else {\n return key in x;\n }\n }\n return false;\n};\n//# sourceMappingURL=utils.js.map","'use strict';\n\n/**\n * imported from react-native\n */\n/* eslint-disable */\n/**\n * This is a helper function for when a component needs to be able to forward a ref\n * to a child component, but still needs to have access to that component as part of\n * its implementation.\n *\n * Its main use case is in wrappers for native components.\n *\n * Usage:\n *\n * class MyView extends React.Component {\n * _nativeRef = null;\n *\n * _setNativeRef = setAndForwardRef({\n * getForwardedRef: () => this.props.forwardedRef,\n * setLocalRef: ref => {\n * this._nativeRef = ref;\n * },\n * });\n *\n * render() {\n * return ;\n * }\n * }\n *\n * const MyViewWithRef = React.forwardRef((props, ref) => (\n * \n * ));\n *\n * module.exports = MyViewWithRef;\n */\n/* eslint-enable */\nfunction setAndForwardRef({\n getForwardedRef,\n setLocalRef\n}) {\n return function forwardRef(ref) {\n const forwardedRef = getForwardedRef();\n setLocalRef(ref);\n\n // Forward to user ref prop (if one has been specified)\n if (typeof forwardedRef === 'function') {\n // Handle function-based refs. String-based refs are handled as functions.\n forwardedRef(ref);\n } else if (typeof forwardedRef === 'object' && forwardedRef != null) {\n // Handle createRef-based refs\n forwardedRef.current = ref;\n }\n };\n}\nexport default setAndForwardRef;\n//# sourceMappingURL=setAndForwardRef.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { flattenArray } from './utils';\nimport { makeViewDescriptorsSet } from '../reanimated2/ViewDescriptorsSet';\nimport { adaptViewConfig } from '../ConfigHelper';\nimport updateProps from '../reanimated2/UpdateProps';\nimport { stopMapper, startMapper } from '../reanimated2/mappers';\nimport { isSharedValue } from '../reanimated2/isSharedValue';\nimport { shouldBeUseWeb } from '../reanimated2/PlatformChecker';\nconst SHOULD_BE_USE_WEB = shouldBeUseWeb();\nfunction isInlineStyleTransform(transform) {\n if (!Array.isArray(transform)) {\n return false;\n }\n return transform.some(t => hasInlineStyles(t));\n}\nfunction inlinePropsHasChanged(styles1, styles2) {\n if (Object.keys(styles1).length !== Object.keys(styles2).length) {\n return true;\n }\n for (const key of Object.keys(styles1)) {\n if (styles1[key] !== styles2[key]) return true;\n }\n return false;\n}\nfunction getInlinePropsUpdate(inlineProps) {\n 'worklet';\n\n const update = {};\n for (const [key, styleValue] of Object.entries(inlineProps)) {\n if (isSharedValue(styleValue)) {\n update[key] = styleValue.value;\n } else if (Array.isArray(styleValue)) {\n update[key] = styleValue.map(item => {\n return getInlinePropsUpdate(item);\n });\n } else if (typeof styleValue === 'object') {\n update[key] = getInlinePropsUpdate(styleValue);\n } else {\n update[key] = styleValue;\n }\n }\n return update;\n}\nfunction extractSharedValuesMapFromProps(props) {\n const inlineProps = {};\n for (const key in props) {\n const value = props[key];\n if (key === 'style') {\n const styles = flattenArray(props.style ?? []);\n styles.forEach(style => {\n if (!style) {\n return;\n }\n for (const [styleKey, styleValue] of Object.entries(style)) {\n if (isSharedValue(styleValue)) {\n inlineProps[styleKey] = styleValue;\n } else if (styleKey === 'transform' && isInlineStyleTransform(styleValue)) {\n inlineProps[styleKey] = styleValue;\n }\n }\n });\n } else if (isSharedValue(value)) {\n inlineProps[key] = value;\n }\n }\n return inlineProps;\n}\nexport function hasInlineStyles(style) {\n if (!style) {\n return false;\n }\n return Object.keys(style).some(key => {\n const styleValue = style[key];\n return isSharedValue(styleValue) || key === 'transform' && isInlineStyleTransform(styleValue);\n });\n}\nexport function getInlineStyle(style, shouldGetInitialStyle) {\n if (shouldGetInitialStyle) {\n return getInlinePropsUpdate(style);\n }\n const newStyle = {};\n for (const [key, styleValue] of Object.entries(style)) {\n if (!isSharedValue(styleValue) && !(key === 'transform' && isInlineStyleTransform(styleValue))) {\n newStyle[key] = styleValue;\n }\n }\n return newStyle;\n}\nexport class InlinePropManager {\n constructor() {\n _defineProperty(this, \"_inlinePropsViewDescriptors\", null);\n _defineProperty(this, \"_inlinePropsMapperId\", null);\n _defineProperty(this, \"_inlineProps\", {});\n }\n attachInlineProps(animatedComponent, viewInfo) {\n const newInlineProps = extractSharedValuesMapFromProps(animatedComponent.props);\n const hasChanged = inlinePropsHasChanged(newInlineProps, this._inlineProps);\n if (hasChanged) {\n if (!this._inlinePropsViewDescriptors) {\n this._inlinePropsViewDescriptors = makeViewDescriptorsSet();\n const {\n viewTag,\n viewName,\n shadowNodeWrapper,\n viewConfig\n } = viewInfo;\n if (Object.keys(newInlineProps).length && viewConfig) {\n adaptViewConfig(viewConfig);\n }\n this._inlinePropsViewDescriptors.add({\n tag: viewTag,\n name: viewName,\n shadowNodeWrapper: shadowNodeWrapper\n });\n }\n const shareableViewDescriptors = this._inlinePropsViewDescriptors.shareableViewDescriptors;\n const maybeViewRef = SHOULD_BE_USE_WEB ? {\n items: new Set([animatedComponent])\n } // see makeViewsRefSet\n : undefined;\n const updaterFunction = () => {\n 'worklet';\n\n const update = getInlinePropsUpdate(newInlineProps);\n updateProps(shareableViewDescriptors, update, maybeViewRef);\n };\n this._inlineProps = newInlineProps;\n if (this._inlinePropsMapperId) {\n stopMapper(this._inlinePropsMapperId);\n }\n this._inlinePropsMapperId = null;\n if (Object.keys(newInlineProps).length) {\n this._inlinePropsMapperId = startMapper(updaterFunction, Object.values(newInlineProps));\n }\n }\n }\n detachInlineProps() {\n if (this._inlinePropsMapperId) {\n stopMapper(this._inlinePropsMapperId);\n }\n }\n}\n//# sourceMappingURL=InlinePropManager.js.map","'use strict';\n\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(t) { var i = _toPrimitive(t, \"string\"); return \"symbol\" == typeof i ? i : i + \"\"; }\nfunction _toPrimitive(t, r) { if (\"object\" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || \"default\"); if (\"object\" != typeof i) return i; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (\"string\" === r ? String : Number)(t); }\nimport { shallowEqual } from '../reanimated2/hook/utils';\nimport { isSharedValue } from '../reanimated2/isSharedValue';\nimport { isChromeDebugger } from '../reanimated2/PlatformChecker';\nimport { WorkletEventHandler } from '../reanimated2/WorkletEventHandler';\nimport { initialUpdaterRun } from '../reanimated2/animation';\nimport { hasInlineStyles, getInlineStyle } from './InlinePropManager';\nimport { flattenArray, has } from './utils';\nimport { StyleSheet } from 'react-native';\nfunction dummyListener() {\n // empty listener we use to assign to listener properties for which animated\n // event is used.\n}\nexport class PropsFilter {\n constructor() {\n _defineProperty(this, \"_initialStyle\", {});\n _defineProperty(this, \"_previousProps\", null);\n _defineProperty(this, \"_requiresNewInitials\", true);\n }\n filterNonAnimatedProps(component) {\n const inputProps = component.props;\n this._maybePrepareForNewInitials(inputProps);\n const props = {};\n for (const key in inputProps) {\n const value = inputProps[key];\n if (key === 'style') {\n const styleProp = inputProps.style;\n const styles = flattenArray(styleProp ?? []);\n if (this._requiresNewInitials) {\n this._initialStyle = {};\n }\n const processedStyle = styles.map(style => {\n if (style && style.viewDescriptors) {\n var _style$viewsRef;\n // this is how we recognize styles returned by useAnimatedStyle\n // TODO - refactor, since `viewsRef` is only present on Web\n (_style$viewsRef = style.viewsRef) === null || _style$viewsRef === void 0 || _style$viewsRef.add(component);\n if (this._requiresNewInitials) {\n this._initialStyle = {\n ...style.initial.value,\n ...this._initialStyle,\n ...initialUpdaterRun(style.initial.updater)\n };\n }\n return this._initialStyle;\n } else if (hasInlineStyles(style)) {\n return getInlineStyle(style, this._requiresNewInitials);\n } else {\n return style;\n }\n });\n props[key] = StyleSheet.flatten(processedStyle);\n } else if (key === 'animatedProps') {\n const animatedProp = inputProps.animatedProps;\n if (animatedProp.initial !== undefined) {\n Object.keys(animatedProp.initial.value).forEach(initialValueKey => {\n var _animatedProp$initial, _animatedProp$viewsRe;\n props[initialValueKey] = (_animatedProp$initial = animatedProp.initial) === null || _animatedProp$initial === void 0 ? void 0 : _animatedProp$initial.value[initialValueKey];\n // TODO - refacotr, since `viewsRef` is only present on Web\n (_animatedProp$viewsRe = animatedProp.viewsRef) === null || _animatedProp$viewsRe === void 0 || _animatedProp$viewsRe.add(component);\n });\n }\n } else if (has('workletEventHandler', value) && value.workletEventHandler instanceof WorkletEventHandler) {\n if (value.workletEventHandler.eventNames.length > 0) {\n value.workletEventHandler.eventNames.forEach(eventName => {\n props[eventName] = has('listeners', value.workletEventHandler) ? value.workletEventHandler.listeners[eventName] : dummyListener;\n });\n } else {\n props[key] = dummyListener;\n }\n } else if (isSharedValue(value)) {\n if (this._requiresNewInitials) {\n props[key] = value.value;\n }\n } else if (key !== 'onGestureHandlerStateChange' || !isChromeDebugger()) {\n props[key] = value;\n }\n }\n this._requiresNewInitials = false;\n return props;\n }\n _maybePrepareForNewInitials(inputProps) {\n if (this._previousProps && inputProps.style) {\n this._requiresNewInitials = !shallowEqual(this._previousProps, inputProps);\n }\n this._previousProps = inputProps;\n }\n}\n//# sourceMappingURL=PropsFilter.js.map","'use strict';\n\nexport { startWebLayoutAnimation, tryActivateLayoutTransition } from './animationsManager';\nexport { getReducedMotionFromConfig, saveSnapshot } from './componentUtils';\nexport { configureWebLayoutAnimations } from './domUtils';\n//# sourceMappingURL=index.js.map","'use strict';\n\nimport { Animations } from './config';\nimport { LayoutAnimationType } from '../animationBuilder/commonTypes';\nimport { createAnimationWithExistingTransform } from './createAnimation';\nimport { extractTransformFromStyle, getProcessedConfig, handleExitingAnimation, handleLayoutTransition, setElementAnimation } from './componentUtils';\nimport { areDOMRectsEqual } from './domUtils';\nimport { makeElementVisible } from './componentStyle';\nfunction chooseConfig(animationType, props) {\n const config = animationType === LayoutAnimationType.ENTERING ? props.entering : animationType === LayoutAnimationType.EXITING ? props.exiting : animationType === LayoutAnimationType.LAYOUT ? props.layout : null;\n return config;\n}\nfunction checkUndefinedAnimationFail(initialAnimationName, isLayoutTransition) {\n // This prevents crashes if we try to set animations that are not defined.\n // We don't care about layout transitions since they're created dynamically\n if (initialAnimationName in Animations || isLayoutTransition) {\n return false;\n }\n console.warn(\"[Reanimated] Couldn't load entering/exiting animation. Current version supports only predefined animations with modifiers: duration, delay, easing, randomizeDelay, withCallback, reducedMotion.\");\n return true;\n}\nfunction chooseAction(animationType, animationConfig, element, transitionData, transform) {\n switch (animationType) {\n case LayoutAnimationType.ENTERING:\n setElementAnimation(element, animationConfig, transform);\n break;\n case LayoutAnimationType.LAYOUT:\n transitionData.reversed = animationConfig.reversed;\n handleLayoutTransition(element, animationConfig, transitionData, transform);\n break;\n case LayoutAnimationType.EXITING:\n handleExitingAnimation(element, animationConfig);\n break;\n }\n}\nfunction tryGetAnimationConfigWithTransform(props, animationType) {\n const config = chooseConfig(animationType, props);\n if (!config) {\n return null;\n }\n const isLayoutTransition = animationType === LayoutAnimationType.LAYOUT;\n const initialAnimationName = typeof config === 'function' ? config.presetName : config.constructor.presetName;\n const shouldFail = checkUndefinedAnimationFail(initialAnimationName, isLayoutTransition);\n if (shouldFail) {\n return null;\n }\n const transform = extractTransformFromStyle(props.style);\n const animationName = transform && animationType !== LayoutAnimationType.EXITING ? createAnimationWithExistingTransform(initialAnimationName, transform) : initialAnimationName;\n const animationConfig = getProcessedConfig(animationName, animationType, config, initialAnimationName);\n return {\n animationConfig,\n transform\n };\n}\nexport function startWebLayoutAnimation(props, element, animationType, transitionData) {\n const maybeAnimationConfigWithTransform = tryGetAnimationConfigWithTransform(props, animationType);\n if (maybeAnimationConfigWithTransform) {\n const {\n animationConfig,\n transform\n } = maybeAnimationConfigWithTransform;\n chooseAction(animationType, animationConfig, element, transitionData, transform);\n } else {\n makeElementVisible(element, 0);\n }\n}\nexport function tryActivateLayoutTransition(props, element, snapshot) {\n if (!props.layout) {\n return;\n }\n const rect = element.getBoundingClientRect();\n if (areDOMRectsEqual(rect, snapshot)) {\n return;\n }\n const transitionData = {\n translateX: snapshot.x - rect.x,\n translateY: snapshot.y - rect.y,\n scaleX: snapshot.width / rect.width,\n scaleY: snapshot.height / rect.height,\n reversed: false // This field is used only in `SequencedTransition`, so by default it will be false\n };\n startWebLayoutAnimation(props, element, LayoutAnimationType.LAYOUT, transitionData);\n}\n//# sourceMappingURL=animationsManager.js.map","'use strict';\n\nimport { BounceIn, BounceInData, BounceOut, BounceOutData } from './animation/Bounce.web';\nimport { FadeIn, FadeInData, FadeOut, FadeOutData } from './animation/Fade.web';\nimport { FlipIn, FlipInData, FlipOut, FlipOutData } from './animation/Flip.web';\nimport { LightSpeedIn, LightSpeedInData, LightSpeedOut, LightSpeedOutData } from './animation/Lightspeed.web';\nimport { Pinwheel, PinwheelData } from './animation/Pinwheel.web';\nimport { RollIn, RollInData, RollOut, RollOutData } from './animation/Roll.web';\nimport { RotateIn, RotateInData, RotateOut, RotateOutData } from './animation/Rotate.web';\nimport { SlideIn, SlideInData, SlideOut, SlideOutData } from './animation/Slide.web';\nimport { StretchIn, StretchInData, StretchOut, StretchOutData } from './animation/Stretch.web';\nimport { ZoomIn, ZoomInData, ZoomOut, ZoomOutData } from './animation/Zoom.web';\nexport let TransitionType = /*#__PURE__*/function (TransitionType) {\n TransitionType[TransitionType[\"LINEAR\"] = 0] = \"LINEAR\";\n TransitionType[TransitionType[\"SEQUENCED\"] = 1] = \"SEQUENCED\";\n TransitionType[TransitionType[\"FADING\"] = 2] = \"FADING\";\n return TransitionType;\n}({});\nexport const AnimationsData = {\n ...FadeInData,\n ...FadeOutData,\n ...BounceInData,\n ...BounceOutData,\n ...FlipInData,\n ...FlipOutData,\n ...StretchInData,\n ...StretchOutData,\n ...ZoomInData,\n ...ZoomOutData,\n ...SlideInData,\n ...SlideOutData,\n ...LightSpeedInData,\n ...LightSpeedOutData,\n ...PinwheelData,\n ...RotateInData,\n ...RotateOutData,\n ...RollInData,\n ...RollOutData\n};\nexport const Animations = {\n ...FadeIn,\n ...FadeOut,\n ...BounceIn,\n ...BounceOut,\n ...FlipIn,\n ...FlipOut,\n ...StretchIn,\n ...StretchOut,\n ...ZoomIn,\n ...ZoomOut,\n ...SlideIn,\n ...SlideOut,\n ...LightSpeedIn,\n ...LightSpeedOut,\n ...Pinwheel,\n ...RotateIn,\n ...RotateOut,\n ...RollIn,\n ...RollOut\n};\n\n// Those are the easings that can be implemented using Bezier curves.\n// Others should be done as CSS animations\nexport const WebEasings = {\n linear: [0, 0, 1, 1],\n ease: [0.42, 0, 1, 1],\n quad: [0.11, 0, 0.5, 0],\n cubic: [0.32, 0, 0.67, 0],\n sin: [0.12, 0, 0.39, 0],\n circle: [0.55, 0, 1, 0.45],\n exp: [0.7, 0, 0.84, 0]\n};\n//# sourceMappingURL=config.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_BOUNCE_TIME = 0.6;\nexport const BounceInData = {\n BounceIn: {\n name: 'BounceIn',\n style: {\n 0: {\n transform: [{\n scale: 0\n }]\n },\n 55: {\n transform: [{\n scale: 1.2\n }]\n },\n 70: {\n transform: [{\n scale: 0.9\n }]\n },\n 85: {\n transform: [{\n scale: 1.1\n }]\n },\n 100: {\n transform: [{\n scale: 1\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n },\n BounceInRight: {\n name: 'BounceInRight',\n style: {\n 0: {\n transform: [{\n translateX: '100vw'\n }]\n },\n 55: {\n transform: [{\n translateX: '-20px'\n }]\n },\n 70: {\n transform: [{\n translateX: '10px'\n }]\n },\n 85: {\n transform: [{\n translateX: '-10px'\n }]\n },\n 100: {\n transform: [{\n translateX: '0px'\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n },\n BounceInLeft: {\n name: 'BounceInLeft',\n style: {\n 0: {\n transform: [{\n translateX: '-100vw'\n }]\n },\n 55: {\n transform: [{\n translateX: '20px'\n }]\n },\n 70: {\n transform: [{\n translateX: '-10px'\n }]\n },\n 85: {\n transform: [{\n translateX: '10px'\n }]\n },\n 100: {\n transform: [{\n translateX: '0px'\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n },\n BounceInUp: {\n name: 'BounceInUp',\n style: {\n 0: {\n transform: [{\n translateY: '-100vh'\n }]\n },\n 55: {\n transform: [{\n translateY: '20px'\n }]\n },\n 70: {\n transform: [{\n translateY: '-10px'\n }]\n },\n 85: {\n transform: [{\n translateY: '10px'\n }]\n },\n 100: {\n transform: [{\n translateY: '0px'\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n },\n BounceInDown: {\n name: 'BounceInDown',\n style: {\n 0: {\n transform: [{\n translateY: '100vh'\n }]\n },\n 55: {\n transform: [{\n translateY: '-20px'\n }]\n },\n 70: {\n transform: [{\n translateY: '10px'\n }]\n },\n 85: {\n transform: [{\n translateY: '-10px'\n }]\n },\n 100: {\n transform: [{\n translateY: '0px'\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n }\n};\nexport const BounceOutData = {\n BounceOut: {\n name: 'BounceOut',\n style: {\n 15: {\n transform: [{\n scale: 1.1\n }]\n },\n 30: {\n transform: [{\n scale: 0.9\n }]\n },\n 45: {\n transform: [{\n scale: 1.2\n }]\n },\n 100: {\n transform: [{\n scale: 0.1\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n },\n BounceOutRight: {\n name: 'BounceOutRight',\n style: {\n 15: {\n transform: [{\n translateX: '-10px'\n }]\n },\n 30: {\n transform: [{\n translateX: '10px'\n }]\n },\n 45: {\n transform: [{\n translateX: '-20px'\n }]\n },\n 100: {\n transform: [{\n translateX: '100vh'\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n },\n BounceOutLeft: {\n name: 'BounceOutLeft',\n style: {\n 15: {\n transform: [{\n translateX: '10px'\n }]\n },\n 30: {\n transform: [{\n translateX: '-10px'\n }]\n },\n 45: {\n transform: [{\n translateX: '20px'\n }]\n },\n 100: {\n transform: [{\n translateX: '-100vh'\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n },\n BounceOutUp: {\n name: 'BounceOutUp',\n style: {\n 15: {\n transform: [{\n translateY: '10px'\n }]\n },\n 30: {\n transform: [{\n translateY: '-10px'\n }]\n },\n 45: {\n transform: [{\n translateY: '20px'\n }]\n },\n 100: {\n transform: [{\n translateY: '-100vh'\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n },\n BounceOutDown: {\n name: 'BounceOutDown',\n style: {\n 15: {\n transform: [{\n translateY: '-10px'\n }]\n },\n 30: {\n transform: [{\n translateY: '10px'\n }]\n },\n 45: {\n transform: [{\n translateY: '-20px'\n }]\n },\n 100: {\n transform: [{\n translateY: '100vh'\n }]\n }\n },\n duration: DEFAULT_BOUNCE_TIME\n }\n};\nexport const BounceIn = {\n BounceIn: {\n style: convertAnimationObjectToKeyframes(BounceInData.BounceIn),\n duration: BounceInData.BounceIn.duration\n },\n BounceInRight: {\n style: convertAnimationObjectToKeyframes(BounceInData.BounceInRight),\n duration: BounceInData.BounceInRight.duration\n },\n BounceInLeft: {\n style: convertAnimationObjectToKeyframes(BounceInData.BounceInLeft),\n duration: BounceInData.BounceInLeft.duration\n },\n BounceInUp: {\n style: convertAnimationObjectToKeyframes(BounceInData.BounceInUp),\n duration: BounceInData.BounceInUp.duration\n },\n BounceInDown: {\n style: convertAnimationObjectToKeyframes(BounceInData.BounceInDown),\n duration: BounceInData.BounceInDown.duration\n }\n};\nexport const BounceOut = {\n BounceOut: {\n style: convertAnimationObjectToKeyframes(BounceOutData.BounceOut),\n duration: BounceOutData.BounceOut.duration\n },\n BounceOutRight: {\n style: convertAnimationObjectToKeyframes(BounceOutData.BounceOutRight),\n duration: BounceOutData.BounceOutRight.duration\n },\n BounceOutLeft: {\n style: convertAnimationObjectToKeyframes(BounceOutData.BounceOutLeft),\n duration: BounceOutData.BounceOutLeft.duration\n },\n BounceOutUp: {\n style: convertAnimationObjectToKeyframes(BounceOutData.BounceOutUp),\n duration: BounceOutData.BounceOutUp.duration\n },\n BounceOutDown: {\n style: convertAnimationObjectToKeyframes(BounceOutData.BounceOutDown),\n duration: BounceOutData.BounceOutDown.duration\n }\n};\n//# sourceMappingURL=Bounce.web.js.map","'use strict';\n\nexport function convertAnimationObjectToKeyframes(animationObject) {\n let keyframe = `@keyframes ${animationObject.name} { `;\n for (const [timestamp, style] of Object.entries(animationObject.style)) {\n keyframe += `${timestamp}% { `;\n for (const [property, values] of Object.entries(style)) {\n if (property !== 'transform') {\n keyframe += `${property}: ${values}; `;\n continue;\n }\n keyframe += `transform:`;\n values.forEach(value => {\n for (const [transformProperty, transformPropertyValue] of Object.entries(value)) {\n keyframe += ` ${transformProperty}(${transformPropertyValue})`;\n }\n });\n keyframe += `; `; // Property end\n }\n keyframe += `} `; // Timestamp end\n }\n keyframe += `} `; // Keyframe end\n\n return keyframe;\n}\nexport function convertTransformToString(transform) {\n if (!transform) {\n return '';\n }\n let transformString = '';\n\n // @ts-ignore `transform` cannot be string because in that case\n // we throw error in `extractTransformFromStyle`\n transform.forEach(transformObject => {\n for (const [key, value] of Object.entries(transformObject)) {\n if (key === 'reversed') {\n continue;\n }\n if (key.indexOf('translate') < 0) {\n transformString += `${key}(${value}) `;\n } else {\n transformString += `${key}(${value}px) `;\n }\n }\n });\n return transformString;\n}\n//# sourceMappingURL=animationParser.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_FADE_TIME = 0.3;\nexport const FadeInData = {\n FadeIn: {\n name: 'FadeIn',\n style: {\n 0: {\n opacity: 0\n }\n },\n duration: DEFAULT_FADE_TIME\n },\n FadeInRight: {\n name: 'FadeInRight',\n style: {\n 0: {\n opacity: 0,\n transform: [{\n translateX: '25px'\n }]\n }\n },\n duration: DEFAULT_FADE_TIME\n },\n FadeInLeft: {\n name: 'FadeInLeft',\n style: {\n 0: {\n opacity: 0,\n transform: [{\n translateX: '-25px'\n }]\n }\n },\n duration: DEFAULT_FADE_TIME\n },\n FadeInUp: {\n name: 'FadeInUp',\n style: {\n 0: {\n opacity: 0,\n transform: [{\n translateY: '-25px'\n }]\n }\n },\n duration: DEFAULT_FADE_TIME\n },\n FadeInDown: {\n name: 'FadeInDown',\n style: {\n 0: {\n opacity: 0,\n transform: [{\n translateY: '25px'\n }]\n }\n },\n duration: DEFAULT_FADE_TIME\n }\n};\nexport const FadeOutData = {\n FadeOut: {\n name: 'FadeOut',\n style: {\n 100: {\n opacity: 0\n }\n },\n duration: DEFAULT_FADE_TIME\n },\n FadeOutRight: {\n name: 'FadeOutRight',\n style: {\n 100: {\n opacity: 0,\n transform: [{\n translateX: '25px'\n }]\n }\n },\n duration: DEFAULT_FADE_TIME\n },\n FadeOutLeft: {\n name: 'FadeOutLeft',\n style: {\n 100: {\n opacity: 0,\n transform: [{\n translateX: '-25px'\n }]\n }\n },\n duration: DEFAULT_FADE_TIME\n },\n FadeOutUp: {\n name: 'FadeOutUp',\n style: {\n 100: {\n opacity: 0,\n transform: [{\n translateY: '-25px'\n }]\n }\n },\n duration: DEFAULT_FADE_TIME\n },\n FadeOutDown: {\n name: 'FadeOutDown',\n style: {\n 100: {\n opacity: 0,\n transform: [{\n translateY: '25px'\n }]\n }\n },\n duration: DEFAULT_FADE_TIME\n }\n};\nexport const FadeIn = {\n FadeIn: {\n style: convertAnimationObjectToKeyframes(FadeInData.FadeIn),\n duration: FadeInData.FadeIn.duration\n },\n FadeInRight: {\n style: convertAnimationObjectToKeyframes(FadeInData.FadeInRight),\n duration: FadeInData.FadeInRight.duration\n },\n FadeInLeft: {\n style: convertAnimationObjectToKeyframes(FadeInData.FadeInLeft),\n duration: FadeInData.FadeInLeft.duration\n },\n FadeInUp: {\n style: convertAnimationObjectToKeyframes(FadeInData.FadeInUp),\n duration: FadeInData.FadeInUp.duration\n },\n FadeInDown: {\n style: convertAnimationObjectToKeyframes(FadeInData.FadeInDown),\n duration: FadeInData.FadeInDown.duration\n }\n};\nexport const FadeOut = {\n FadeOut: {\n style: convertAnimationObjectToKeyframes(FadeOutData.FadeOut),\n duration: FadeOutData.FadeOut.duration\n },\n FadeOutRight: {\n style: convertAnimationObjectToKeyframes(FadeOutData.FadeOutRight),\n duration: FadeOutData.FadeOutRight.duration\n },\n FadeOutLeft: {\n style: convertAnimationObjectToKeyframes(FadeOutData.FadeOutLeft),\n duration: FadeOutData.FadeOutLeft.duration\n },\n FadeOutUp: {\n style: convertAnimationObjectToKeyframes(FadeOutData.FadeOutUp),\n duration: FadeOutData.FadeOutUp.duration\n },\n FadeOutDown: {\n style: convertAnimationObjectToKeyframes(FadeOutData.FadeOutDown),\n duration: FadeOutData.FadeOutDown.duration\n }\n};\n//# sourceMappingURL=Fade.web.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_FLIP_TIME = 0.3;\nexport const FlipInData = {\n FlipInYRight: {\n name: 'FlipInYRight',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateY: '90deg',\n translateX: '100%'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateY: '0deg',\n translateX: '0%'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipInYLeft: {\n name: 'FlipInYLeft',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateY: '-90deg',\n translateX: '-100%'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateY: '0deg',\n translateX: '0%'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipInXUp: {\n name: 'FlipInXUp',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateX: '90deg',\n translateY: '-100%'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateX: '0deg',\n translateY: '0%'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipInXDown: {\n name: 'FlipInXDown',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateX: '-90deg',\n translateY: '100%'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateX: '0deg',\n translateY: '0%'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipInEasyX: {\n name: 'FlipInEasyX',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateX: '90deg'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateX: '0deg'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipInEasyY: {\n name: 'FlipInEasyY',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateY: '90deg'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateY: '0deg'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n }\n};\nexport const FlipOutData = {\n FlipOutYRight: {\n name: 'FlipOutYRight',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateY: '0deg',\n translateX: '0%'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateY: '90deg',\n translateX: '100%'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipOutYLeft: {\n name: 'FlipOutYLeft',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateY: '0deg',\n translateX: '0%'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateY: '-90deg',\n translateX: '-100%'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipOutXUp: {\n name: 'FlipOutXUp',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateX: '0deg',\n translateY: '0%'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateX: '90deg',\n translateY: '-100%'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipOutXDown: {\n name: 'FlipOutXDown',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateX: '0deg',\n translateY: '0%'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateX: '-90deg',\n translateY: '100%'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipOutEasyX: {\n name: 'FlipOutEasyX',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateX: '0deg'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateX: '90deg'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n },\n FlipOutEasyY: {\n name: 'FlipOutEasyY',\n style: {\n 0: {\n transform: [{\n perspective: '500px',\n rotateY: '0deg'\n }]\n },\n 100: {\n transform: [{\n perspective: '500px',\n rotateY: '90deg'\n }]\n }\n },\n duration: DEFAULT_FLIP_TIME\n }\n};\nexport const FlipIn = {\n FlipInYRight: {\n style: convertAnimationObjectToKeyframes(FlipInData.FlipInYRight),\n duration: FlipInData.FlipInYRight.duration\n },\n FlipInYLeft: {\n style: convertAnimationObjectToKeyframes(FlipInData.FlipInYLeft),\n duration: FlipInData.FlipInYLeft.duration\n },\n FlipInXUp: {\n style: convertAnimationObjectToKeyframes(FlipInData.FlipInXUp),\n duration: FlipInData.FlipInXUp.duration\n },\n FlipInXDown: {\n style: convertAnimationObjectToKeyframes(FlipInData.FlipInXDown),\n duration: FlipInData.FlipInXDown.duration\n },\n FlipInEasyX: {\n style: convertAnimationObjectToKeyframes(FlipInData.FlipInEasyX),\n duration: FlipInData.FlipInEasyX.duration\n },\n FlipInEasyY: {\n style: convertAnimationObjectToKeyframes(FlipInData.FlipInEasyY),\n duration: FlipInData.FlipInEasyY.duration\n }\n};\nexport const FlipOut = {\n FlipOutYRight: {\n style: convertAnimationObjectToKeyframes(FlipOutData.FlipOutYRight),\n duration: FlipOutData.FlipOutYRight.duration\n },\n FlipOutYLeft: {\n style: convertAnimationObjectToKeyframes(FlipOutData.FlipOutYLeft),\n duration: FlipOutData.FlipOutYLeft.duration\n },\n FlipOutXUp: {\n style: convertAnimationObjectToKeyframes(FlipOutData.FlipOutXUp),\n duration: FlipOutData.FlipOutXUp.duration\n },\n FlipOutXDown: {\n style: convertAnimationObjectToKeyframes(FlipOutData.FlipOutXDown),\n duration: FlipOutData.FlipOutXDown.duration\n },\n FlipOutEasyX: {\n style: convertAnimationObjectToKeyframes(FlipOutData.FlipOutEasyX),\n duration: FlipOutData.FlipOutEasyX.duration\n },\n FlipOutEasyY: {\n style: convertAnimationObjectToKeyframes(FlipOutData.FlipOutEasyY),\n duration: FlipOutData.FlipOutEasyY.duration\n }\n};\n//# sourceMappingURL=Flip.web.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_LIGHTSPEED_TIME = 0.3;\nexport const LightSpeedInData = {\n LightSpeedInRight: {\n name: 'LightSpeedInRight',\n style: {\n 0: {\n transform: [{\n translateX: '100vw',\n skewX: '-45deg'\n }],\n opacity: 0\n },\n 70: {\n transform: [{\n skewX: '10deg'\n }]\n },\n 85: {\n transform: [{\n skewX: '-5deg'\n }]\n },\n 100: {\n transform: [{\n skewX: '0deg'\n }]\n }\n },\n duration: DEFAULT_LIGHTSPEED_TIME\n },\n LightSpeedInLeft: {\n name: 'LightSpeedInLeft',\n style: {\n 0: {\n transform: [{\n translateX: '-100vw',\n skewX: '45deg'\n }],\n opacity: 0\n },\n 70: {\n transform: [{\n skewX: '-10deg'\n }]\n },\n 85: {\n transform: [{\n skewX: '5deg'\n }]\n },\n 100: {\n transform: [{\n skewX: '0deg'\n }]\n }\n },\n duration: DEFAULT_LIGHTSPEED_TIME\n }\n};\nexport const LightSpeedOutData = {\n LightSpeedOutRight: {\n name: 'LightSpeedOutRight',\n style: {\n 100: {\n transform: [{\n translateX: '100vw',\n skewX: '-45deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_LIGHTSPEED_TIME\n },\n LightSpeedOutLeft: {\n name: 'LightSpeedOutLeft',\n style: {\n 100: {\n transform: [{\n translateX: '-100vw',\n skew: '45deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_LIGHTSPEED_TIME\n }\n};\nexport const LightSpeedIn = {\n LightSpeedInRight: {\n style: convertAnimationObjectToKeyframes(LightSpeedInData.LightSpeedInRight),\n duration: LightSpeedInData.LightSpeedInRight.duration\n },\n LightSpeedInLeft: {\n style: convertAnimationObjectToKeyframes(LightSpeedInData.LightSpeedInLeft),\n duration: LightSpeedInData.LightSpeedInLeft.duration\n }\n};\nexport const LightSpeedOut = {\n LightSpeedOutRight: {\n style: convertAnimationObjectToKeyframes(LightSpeedOutData.LightSpeedOutRight),\n duration: LightSpeedOutData.LightSpeedOutRight.duration\n },\n LightSpeedOutLeft: {\n style: convertAnimationObjectToKeyframes(LightSpeedOutData.LightSpeedOutLeft),\n duration: LightSpeedOutData.LightSpeedOutLeft.duration\n }\n};\n//# sourceMappingURL=Lightspeed.web.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_PINWHEEL_TIME = 0.3;\nexport const PinwheelData = {\n PinwheelIn: {\n name: 'PinwheelIn',\n style: {\n 0: {\n transform: [{\n rotate: '5rad',\n scale: 0\n }],\n opacity: 0\n },\n 100: {\n transform: [{\n rotate: '0deg',\n scale: 1\n }],\n opacity: 1\n }\n },\n duration: DEFAULT_PINWHEEL_TIME\n },\n PinwheelOut: {\n name: 'PinwheelOut',\n style: {\n 100: {\n transform: [{\n rotate: '5rad',\n scale: 0\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_PINWHEEL_TIME\n }\n};\nexport const Pinwheel = {\n PinwheelIn: {\n style: convertAnimationObjectToKeyframes(PinwheelData.PinwheelIn),\n duration: PinwheelData.PinwheelIn.duration\n },\n PinwheelOut: {\n style: convertAnimationObjectToKeyframes(PinwheelData.PinwheelOut),\n duration: PinwheelData.PinwheelOut.duration\n }\n};\n//# sourceMappingURL=Pinwheel.web.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_ROLL_TIME = 0.3;\nexport const RollInData = {\n RollInLeft: {\n name: 'RollInLeft',\n style: {\n 0: {\n transform: [{\n translateX: '-100vw',\n rotate: '-180deg'\n }]\n }\n },\n duration: DEFAULT_ROLL_TIME\n },\n RollInRight: {\n name: 'RollInRight',\n style: {\n 0: {\n transform: [{\n translateX: '100vw',\n rotate: '180deg'\n }]\n }\n },\n duration: DEFAULT_ROLL_TIME\n }\n};\nexport const RollOutData = {\n RollOutLeft: {\n name: 'RollOutLeft',\n style: {\n 100: {\n transform: [{\n translateX: '-100vw',\n rotate: '-180deg'\n }]\n }\n },\n duration: DEFAULT_ROLL_TIME\n },\n RollOutRight: {\n name: 'RollOutRight',\n style: {\n 100: {\n transform: [{\n translateX: '100vw',\n rotate: '180deg'\n }]\n }\n },\n duration: DEFAULT_ROLL_TIME\n }\n};\nexport const RollIn = {\n RollInLeft: {\n style: convertAnimationObjectToKeyframes(RollInData.RollInLeft),\n duration: RollInData.RollInLeft.duration\n },\n RollInRight: {\n style: convertAnimationObjectToKeyframes(RollInData.RollInRight),\n duration: RollInData.RollInRight.duration\n }\n};\nexport const RollOut = {\n RollOutLeft: {\n style: convertAnimationObjectToKeyframes(RollOutData.RollOutLeft),\n duration: RollOutData.RollOutLeft.duration\n },\n RollOutRight: {\n style: convertAnimationObjectToKeyframes(RollOutData.RollOutRight),\n duration: RollOutData.RollOutRight.duration\n }\n};\n//# sourceMappingURL=Roll.web.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_ROTATE_TIME = 0.3;\nexport const RotateInData = {\n RotateInDownLeft: {\n name: 'RotateInDownLeft',\n style: {\n 0: {\n transform: [{\n translateX: '-50%',\n translateY: '-250%',\n rotate: '-90deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_ROTATE_TIME\n },\n RotateInDownRight: {\n name: 'RotateInDownRight',\n style: {\n 0: {\n transform: [{\n translateX: '40%',\n translateY: '-250%',\n rotate: '90deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_ROTATE_TIME\n },\n RotateInUpLeft: {\n name: 'RotateInUpLeft',\n style: {\n 0: {\n transform: [{\n translateX: '-40%',\n translateY: '250%',\n rotate: '90deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_ROTATE_TIME\n },\n RotateInUpRight: {\n name: 'RotateInUpRight',\n style: {\n 0: {\n transform: [{\n translateX: '40%',\n translateY: '250%',\n rotate: '-90deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_ROTATE_TIME\n }\n};\nexport const RotateOutData = {\n RotateOutDownLeft: {\n name: 'RotateOutDownLeft',\n style: {\n 100: {\n transform: [{\n translateX: '-40%',\n translateY: '250%',\n rotate: '90deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_ROTATE_TIME\n },\n RotateOutDownRight: {\n name: 'RotateOutDownRight',\n style: {\n 100: {\n transform: [{\n translateX: '40%',\n translateY: '250%',\n rotate: '-90deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_ROTATE_TIME\n },\n RotateOutUpLeft: {\n name: 'RotateOutUpLeft',\n style: {\n 100: {\n transform: [{\n translateX: '-40%',\n translateY: '-250%',\n rotate: '-90deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_ROTATE_TIME\n },\n RotateOutUpRight: {\n name: 'RotateOutUpRight',\n style: {\n 100: {\n transform: [{\n translateX: '40%',\n translateY: '-250%',\n rotate: '90deg'\n }],\n opacity: 0\n }\n },\n duration: DEFAULT_ROTATE_TIME\n }\n};\nexport const RotateIn = {\n RotateInDownLeft: {\n style: convertAnimationObjectToKeyframes(RotateInData.RotateInDownLeft),\n duration: RotateInData.RotateInDownLeft.duration\n },\n RotateInDownRight: {\n style: convertAnimationObjectToKeyframes(RotateInData.RotateInDownRight),\n duration: RotateInData.RotateInDownRight.duration\n },\n RotateInUpLeft: {\n style: convertAnimationObjectToKeyframes(RotateInData.RotateInUpLeft),\n duration: RotateInData.RotateInUpLeft.duration\n },\n RotateInUpRight: {\n style: convertAnimationObjectToKeyframes(RotateInData.RotateInUpRight),\n duration: RotateInData.RotateInUpRight.duration\n }\n};\nexport const RotateOut = {\n RotateOutDownLeft: {\n style: convertAnimationObjectToKeyframes(RotateOutData.RotateOutDownLeft),\n duration: RotateOutData.RotateOutDownLeft.duration\n },\n RotateOutDownRight: {\n style: convertAnimationObjectToKeyframes(RotateOutData.RotateOutDownRight),\n duration: RotateOutData.RotateOutDownRight.duration\n },\n RotateOutUpLeft: {\n style: convertAnimationObjectToKeyframes(RotateOutData.RotateOutUpLeft),\n duration: RotateOutData.RotateOutUpLeft.duration\n },\n RotateOutUpRight: {\n style: convertAnimationObjectToKeyframes(RotateOutData.RotateOutUpRight),\n duration: RotateOutData.RotateOutUpRight.duration\n }\n};\n//# sourceMappingURL=Rotate.web.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_SLIDE_TIME = 0.3;\nexport const SlideInData = {\n SlideInRight: {\n name: 'SlideInRight',\n style: {\n 0: {\n transform: [{\n translateX: '100vw'\n }]\n },\n 100: {\n transform: [{\n translateX: '0%'\n }]\n }\n },\n duration: DEFAULT_SLIDE_TIME\n },\n SlideInLeft: {\n name: 'SlideInLeft',\n style: {\n 0: {\n transform: [{\n translateX: '-100vw'\n }]\n },\n 100: {\n transform: [{\n translateX: '0%'\n }]\n }\n },\n duration: DEFAULT_SLIDE_TIME\n },\n SlideInUp: {\n name: 'SlideInUp',\n style: {\n 0: {\n transform: [{\n translateY: '-100vh'\n }]\n },\n 100: {\n transform: [{\n translateY: '0%'\n }]\n }\n },\n duration: DEFAULT_SLIDE_TIME\n },\n SlideInDown: {\n name: 'SlideInDown',\n style: {\n 0: {\n transform: [{\n translateY: '100vh'\n }]\n },\n 100: {\n transform: [{\n translateY: '0%'\n }]\n }\n },\n duration: DEFAULT_SLIDE_TIME\n }\n};\nexport const SlideOutData = {\n SlideOutRight: {\n name: 'SlideOutRight',\n style: {\n 0: {\n transform: [{\n translateX: '0%'\n }]\n },\n 100: {\n transform: [{\n translateX: '100vw'\n }]\n }\n },\n duration: DEFAULT_SLIDE_TIME\n },\n SlideOutLeft: {\n name: 'SlideOutLeft',\n style: {\n 0: {\n transform: [{\n translateX: '0%'\n }]\n },\n 100: {\n transform: [{\n translateX: '-100vw'\n }]\n }\n },\n duration: DEFAULT_SLIDE_TIME\n },\n SlideOutUp: {\n name: 'SlideOutUp',\n style: {\n 0: {\n transform: [{\n translateY: '0%'\n }]\n },\n 100: {\n transform: [{\n translateY: '-100vh'\n }]\n }\n },\n duration: DEFAULT_SLIDE_TIME\n },\n SlideOutDown: {\n name: 'SlideOutDown',\n style: {\n 0: {\n transform: [{\n translateY: '0%'\n }]\n },\n 100: {\n transform: [{\n translateY: '100vh'\n }]\n }\n },\n duration: DEFAULT_SLIDE_TIME\n }\n};\nexport const SlideIn = {\n SlideInRight: {\n style: convertAnimationObjectToKeyframes(SlideInData.SlideInRight),\n duration: SlideInData.SlideInRight.duration\n },\n SlideInLeft: {\n style: convertAnimationObjectToKeyframes(SlideInData.SlideInLeft),\n duration: SlideInData.SlideInLeft.duration\n },\n SlideInUp: {\n style: convertAnimationObjectToKeyframes(SlideInData.SlideInUp),\n duration: SlideInData.SlideInUp.duration\n },\n SlideInDown: {\n style: convertAnimationObjectToKeyframes(SlideInData.SlideInDown),\n duration: SlideInData.SlideInDown.duration\n }\n};\nexport const SlideOut = {\n SlideOutRight: {\n style: convertAnimationObjectToKeyframes(SlideOutData.SlideOutRight),\n duration: SlideOutData.SlideOutRight.duration\n },\n SlideOutLeft: {\n style: convertAnimationObjectToKeyframes(SlideOutData.SlideOutLeft),\n duration: SlideOutData.SlideOutLeft.duration\n },\n SlideOutUp: {\n style: convertAnimationObjectToKeyframes(SlideOutData.SlideOutUp),\n duration: SlideOutData.SlideOutUp.duration\n },\n SlideOutDown: {\n style: convertAnimationObjectToKeyframes(SlideOutData.SlideOutDown),\n duration: SlideOutData.SlideOutDown.duration\n }\n};\n//# sourceMappingURL=Slide.web.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_STRETCH_TIME = 0.3;\nexport const StretchInData = {\n StretchInX: {\n name: 'StretchInX',\n style: {\n 0: {\n transform: [{\n scaleX: 0\n }]\n },\n 100: {\n transform: [{\n scaleX: 1\n }]\n }\n },\n duration: DEFAULT_STRETCH_TIME\n },\n StretchInY: {\n name: 'StretchInY',\n style: {\n 0: {\n transform: [{\n scaleY: 0\n }]\n },\n 100: {\n transform: [{\n scaleY: 1\n }]\n }\n },\n duration: DEFAULT_STRETCH_TIME\n }\n};\nexport const StretchOutData = {\n StretchOutX: {\n name: 'StretchOutX',\n style: {\n 0: {\n transform: [{\n scaleX: 1\n }]\n },\n 100: {\n transform: [{\n scaleX: 0\n }]\n }\n },\n duration: DEFAULT_STRETCH_TIME\n },\n StretchOutY: {\n name: 'StretchOutY',\n style: {\n 0: {\n transform: [{\n scaleY: 1\n }]\n },\n 100: {\n transform: [{\n scaleY: 0\n }]\n }\n },\n duration: DEFAULT_STRETCH_TIME\n }\n};\nexport const StretchIn = {\n StretchInX: {\n style: convertAnimationObjectToKeyframes(StretchInData.StretchInX),\n duration: StretchInData.StretchInX.duration\n },\n StretchInY: {\n style: convertAnimationObjectToKeyframes(StretchInData.StretchInY),\n duration: StretchInData.StretchInY.duration\n }\n};\nexport const StretchOut = {\n StretchOutX: {\n style: convertAnimationObjectToKeyframes(StretchOutData.StretchOutX),\n duration: StretchOutData.StretchOutX.duration\n },\n StretchOutY: {\n style: convertAnimationObjectToKeyframes(StretchOutData.StretchOutY),\n duration: StretchOutData.StretchOutY.duration\n }\n};\n//# sourceMappingURL=Stretch.web.js.map","'use strict';\n\nimport { convertAnimationObjectToKeyframes } from '../animationParser';\nconst DEFAULT_ZOOM_TIME = 0.3;\nexport const ZoomInData = {\n ZoomIn: {\n name: 'ZoomIn',\n style: {\n 0: {\n transform: [{\n scale: 0\n }]\n },\n 100: {\n transform: [{\n scale: 1\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomInRotate: {\n name: 'ZoomInRotate',\n style: {\n 0: {\n transform: [{\n scale: 0,\n rotate: '0.3rad'\n }]\n },\n 100: {\n transform: [{\n scale: 1,\n rotate: '0deg'\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomInRight: {\n name: 'ZoomInRight',\n style: {\n 0: {\n transform: [{\n translateX: '100vw',\n scale: 0\n }]\n },\n 100: {\n transform: [{\n translateX: '0%',\n scale: 1\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomInLeft: {\n name: 'ZoomInLeft',\n style: {\n 0: {\n transform: [{\n translateX: '-100vw',\n scale: 0\n }]\n },\n 100: {\n transform: [{\n translateX: '0%',\n scale: 1\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomInUp: {\n name: 'ZoomInUp',\n style: {\n 0: {\n transform: [{\n translateY: '-100vh',\n scale: 0\n }]\n },\n 100: {\n transform: [{\n translateY: '0%',\n scale: 1\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomInDown: {\n name: 'ZoomInDown',\n style: {\n 0: {\n transform: [{\n translateY: '100vh',\n scale: 0\n }]\n },\n 100: {\n transform: [{\n translateY: '0%',\n scale: 1\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomInEasyUp: {\n name: 'ZoomInEasyUp',\n style: {\n 0: {\n transform: [{\n translateY: '-100%',\n scale: 0\n }]\n },\n 100: {\n transform: [{\n translateY: '0%',\n scale: 1\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomInEasyDown: {\n name: 'ZoomInEasyDown',\n style: {\n 0: {\n transform: [{\n translateY: '100%',\n scale: 0\n }]\n },\n 100: {\n transform: [{\n translateY: '0%',\n scale: 1\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n }\n};\nexport const ZoomOutData = {\n ZoomOut: {\n name: 'ZoomOut',\n style: {\n 100: {\n transform: [{\n scale: 0\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomOutRotate: {\n name: 'ZoomOutRotate',\n style: {\n 100: {\n transform: [{\n scale: 0,\n rotate: '0.3rad'\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomOutRight: {\n name: 'ZoomOutRight',\n style: {\n 100: {\n transform: [{\n translateX: '100vw',\n scale: 0\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomOutLeft: {\n name: 'ZoomOutLeft',\n style: {\n 100: {\n transform: [{\n translateX: '-100vw',\n scale: 1\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomOutUp: {\n name: 'ZoomOutUp',\n style: {\n 100: {\n transform: [{\n translateY: '-100vh',\n scale: 0\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomOutDown: {\n name: 'ZoomOutDown',\n style: {\n 100: {\n transform: [{\n translateY: '100vh',\n scale: 0\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomOutEasyUp: {\n name: 'ZoomOutEasyUp',\n style: {\n 100: {\n transform: [{\n translateY: '-100%',\n scale: 0\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n },\n ZoomOutEasyDown: {\n name: 'ZoomOutEasyDown',\n style: {\n 100: {\n transform: [{\n translateY: '100%',\n scale: 0\n }]\n }\n },\n duration: DEFAULT_ZOOM_TIME\n }\n};\nexport const ZoomIn = {\n ZoomIn: {\n style: convertAnimationObjectToKeyframes(ZoomInData.ZoomIn),\n duration: ZoomInData.ZoomIn.duration\n },\n ZoomInRotate: {\n style: convertAnimationObjectToKeyframes(ZoomInData.ZoomInRotate),\n duration: ZoomInData.ZoomInRotate.duration\n },\n ZoomInRight: {\n style: convertAnimationObjectToKeyframes(ZoomInData.ZoomInRight),\n duration: ZoomInData.ZoomInRight.duration\n },\n ZoomInLeft: {\n style: convertAnimationObjectToKeyframes(ZoomInData.ZoomInLeft),\n duration: ZoomInData.ZoomInLeft.duration\n },\n ZoomInUp: {\n style: convertAnimationObjectToKeyframes(ZoomInData.ZoomInUp),\n duration: ZoomInData.ZoomInUp.duration\n },\n ZoomInDown: {\n style: convertAnimationObjectToKeyframes(ZoomInData.ZoomInDown),\n duration: ZoomInData.ZoomInDown.duration\n },\n ZoomInEasyUp: {\n style: convertAnimationObjectToKeyframes(ZoomInData.ZoomInEasyUp),\n duration: ZoomInData.ZoomInEasyUp.duration\n },\n ZoomInEasyDown: {\n style: convertAnimationObjectToKeyframes(ZoomInData.ZoomInEasyDown),\n duration: ZoomInData.ZoomInEasyDown.duration\n }\n};\nexport const ZoomOut = {\n ZoomOut: {\n style: convertAnimationObjectToKeyframes(ZoomOutData.ZoomOut),\n duration: ZoomOutData.ZoomOut.duration\n },\n ZoomOutRotate: {\n style: convertAnimationObjectToKeyframes(ZoomOutData.ZoomOutRotate),\n duration: ZoomOutData.ZoomOutRotate.duration\n },\n ZoomOutRight: {\n style: convertAnimationObjectToKeyframes(ZoomOutData.ZoomOutRight),\n duration: ZoomOutData.ZoomOutRight.duration\n },\n ZoomOutLeft: {\n style: convertAnimationObjectToKeyframes(ZoomOutData.ZoomOutLeft),\n duration: ZoomOutData.ZoomOutLeft.duration\n },\n ZoomOutUp: {\n style: convertAnimationObjectToKeyframes(ZoomOutData.ZoomOutUp),\n duration: ZoomOutData.ZoomOutUp.duration\n },\n ZoomOutDown: {\n style: convertAnimationObjectToKeyframes(ZoomOutData.ZoomOutDown),\n duration: ZoomOutData.ZoomOutDown.duration\n },\n ZoomOutEasyUp: {\n style: convertAnimationObjectToKeyframes(ZoomOutData.ZoomOutEasyUp),\n duration: ZoomOutData.ZoomOutEasyUp.duration\n },\n ZoomOutEasyDown: {\n style: convertAnimationObjectToKeyframes(ZoomOutData.ZoomOutEasyDown),\n duration: ZoomOutData.ZoomOutEasyDown.duration\n }\n};\n//# sourceMappingURL=Zoom.web.js.map","'use strict';\n\nimport { Animations, AnimationsData, TransitionType } from './config';\nimport { convertAnimationObjectToKeyframes } from './animationParser';\nimport { LinearTransition } from './transition/Linear.web';\nimport { SequencedTransition } from './transition/Sequenced.web';\nimport { FadingTransition } from './transition/Fading.web';\nimport { insertWebAnimation } from './domUtils';\n\n// Translate values are passed as numbers. However, if `translate` property receives number, it will not automatically\n// convert it to `px`. Therefore if we want to keep existing transform we have to add 'px' suffix to each of translate values\n// that are present inside transform.\nfunction addPxToTranslate(existingTransform) {\n // @ts-ignore `existingTransform` cannot be string because in that case\n // we throw error in `extractTransformFromStyle`\n const newTransform = existingTransform.map(transformProp => {\n const newTransformProp = {};\n for (const [key, value] of Object.entries(transformProp)) {\n if (key.includes('translate')) {\n // @ts-ignore After many trials we decided to ignore this error - it says that we cannot use 'key' to index this object.\n // Sadly it doesn't go away after using cast `key as keyof TransformProperties`.\n newTransformProp[key] = `${value}px`;\n } else {\n // @ts-ignore same as above.\n newTransformProp[key] = value;\n }\n }\n return newTransformProp;\n });\n return newTransform;\n}\n\n// In order to keep existing transform throughout animation, we have to add it to each of keyframe step.\nfunction addExistingTransform(newAnimationData, newTransform) {\n for (const keyframeStepProperties of Object.values(newAnimationData.style)) {\n if (!keyframeStepProperties.transform) {\n // If transform doesn't exist, we add only transform that already exists\n keyframeStepProperties.transform = newTransform;\n } else {\n // We insert existing transformations before ours.\n Array.prototype.unshift.apply(keyframeStepProperties.transform, newTransform);\n }\n }\n}\n\n/**\n * Modifies default animation by preserving transformations that given element already contains.\n *\n * @param animationName - Name of the animation to be modified (e.g. `FadeIn`).\n * @param existingTransform - Transform values that element already contains.\n * @returns Animation parsed to keyframe string.\n */\nexport function createAnimationWithExistingTransform(animationName, existingTransform, layoutTransition) {\n let newAnimationData;\n if (layoutTransition) {\n newAnimationData = layoutTransition;\n } else {\n if (!(animationName in Animations)) {\n return '';\n }\n newAnimationData = structuredClone(AnimationsData[animationName]);\n }\n const keyframeName = generateNextCustomKeyframeName();\n newAnimationData.name = keyframeName;\n const newTransform = addPxToTranslate(existingTransform);\n addExistingTransform(newAnimationData, newTransform);\n const keyframe = convertAnimationObjectToKeyframes(newAnimationData);\n insertWebAnimation(keyframeName, keyframe);\n return keyframeName;\n}\nlet customKeyframeCounter = 0;\nfunction generateNextCustomKeyframeName() {\n return `REA${customKeyframeCounter++}`;\n}\n\n/**\n * Creates transition of given type, appends it to stylesheet and returns keyframe name.\n *\n * @param transitionType - Type of transition (e.g. LINEAR).\n * @param transitionData - Object containing data for transforms (translateX, scaleX,...).\n * @returns Keyframe name that represents transition.\n */\nexport function TransitionGenerator(transitionType, transitionData, existingTransform) {\n const transitionKeyframeName = generateNextCustomKeyframeName();\n let transitionObject;\n switch (transitionType) {\n case TransitionType.LINEAR:\n transitionObject = LinearTransition(transitionKeyframeName, transitionData);\n break;\n case TransitionType.SEQUENCED:\n transitionObject = SequencedTransition(transitionKeyframeName, transitionData);\n break;\n case TransitionType.FADING:\n transitionObject = FadingTransition(transitionKeyframeName, transitionData);\n break;\n }\n if (existingTransform) {\n return createAnimationWithExistingTransform('', existingTransform, transitionObject);\n }\n const transitionKeyframe = convertAnimationObjectToKeyframes(transitionObject);\n insertWebAnimation(transitionKeyframeName, transitionKeyframe);\n return transitionKeyframeName;\n}\n//# sourceMappingURL=createAnimation.js.map","'use strict';\n\nexport function LinearTransition(name, transitionData) {\n const {\n translateX,\n translateY,\n scaleX,\n scaleY\n } = transitionData;\n const linearTransition = {\n name,\n style: {\n 0: {\n transform: [{\n translateX: `${translateX}px`,\n translateY: `${translateY}px`,\n scale: `${scaleX},${scaleY}`\n }]\n }\n },\n duration: 300\n };\n return linearTransition;\n}\n//# sourceMappingURL=Linear.web.js.map","'use strict';\n\nexport function SequencedTransition(name, transitionData) {\n const {\n translateX,\n translateY,\n scaleX,\n scaleY,\n reversed\n } = transitionData;\n const scaleValue = reversed ? `1,${scaleX}` : `${scaleY},1`;\n const sequencedTransition = {\n name,\n style: {\n 0: {\n transform: [{\n translateX: `${translateX}px`,\n translateY: `${translateY}px`,\n scale: `${scaleX},${scaleY}`\n }]\n },\n 50: {\n transform: [{\n translateX: reversed ? `${translateX}px` : '0px',\n translateY: reversed ? '0px' : `${translateY}px`,\n scale: scaleValue\n }]\n },\n 100: {\n transform: [{\n translateX: '0px',\n translateY: '0px',\n scale: '1,1'\n }]\n }\n },\n duration: 300\n };\n return sequencedTransition;\n}\n//# sourceMappingURL=Sequenced.web.js.map","'use strict';\n\nexport function FadingTransition(name, transitionData) {\n const {\n translateX,\n translateY,\n scaleX,\n scaleY\n } = transitionData;\n const fadingTransition = {\n name,\n style: {\n 0: {\n opacity: 1,\n transform: [{\n translateX: `${translateX}px`,\n translateY: `${translateY}px`,\n scale: `${scaleX},${scaleY}`\n }]\n },\n 20: {\n opacity: 0,\n transform: [{\n translateX: `${translateX}px`,\n translateY: `${translateY}px`,\n scale: `${scaleX},${scaleY}`\n }]\n },\n 60: {\n opacity: 0,\n transform: [{\n translateX: '0px',\n translateY: '0px',\n scale: `1,1`\n }]\n },\n 100: {\n opacity: 1,\n transform: [{\n translateX: '0px',\n translateY: '0px',\n scale: `1,1`\n }]\n }\n },\n duration: 300\n };\n return fadingTransition;\n}\n//# sourceMappingURL=Fading.web.js.map","'use strict';\n\nimport { isWindowAvailable } from '../../PlatformChecker';\nimport { setDummyPosition, snapshots } from './componentStyle';\nimport { Animations } from './config';\nconst PREDEFINED_WEB_ANIMATIONS_ID = 'ReanimatedPredefinedWebAnimationsStyle';\nconst CUSTOM_WEB_ANIMATIONS_ID = 'ReanimatedCustomWebAnimationsStyle';\n\n// Since we cannot remove keyframe from DOM by its name, we have to store its id\nconst animationNameToIndex = new Map();\nconst animationNameList = [];\nlet isObserverSet = false;\n\n/**\n * Creates `HTMLStyleElement`, inserts it into DOM and then inserts CSS rules into the stylesheet.\n * If style element already exists, nothing happens.\n */\nexport function configureWebLayoutAnimations() {\n if (!isWindowAvailable() ||\n // Without this check SSR crashes because document is undefined (NextExample on CI)\n document.getElementById(PREDEFINED_WEB_ANIMATIONS_ID) !== null) {\n return;\n }\n const predefinedAnimationsStyleTag = document.createElement('style');\n predefinedAnimationsStyleTag.id = PREDEFINED_WEB_ANIMATIONS_ID;\n predefinedAnimationsStyleTag.onload = () => {\n if (!predefinedAnimationsStyleTag.sheet) {\n console.error('[Reanimated] Failed to create layout animations stylesheet.');\n return;\n }\n for (const animationName in Animations) {\n predefinedAnimationsStyleTag.sheet.insertRule(Animations[animationName].style);\n }\n };\n const customAnimationsStyleTag = document.createElement('style');\n customAnimationsStyleTag.id = CUSTOM_WEB_ANIMATIONS_ID;\n document.head.appendChild(predefinedAnimationsStyleTag);\n document.head.appendChild(customAnimationsStyleTag);\n}\nexport function insertWebAnimation(animationName, keyframe) {\n // Without this check SSR crashes because document is undefined (NextExample on CI)\n if (!isWindowAvailable()) {\n return;\n }\n const styleTag = document.getElementById(CUSTOM_WEB_ANIMATIONS_ID);\n if (!styleTag.sheet) {\n console.error('[Reanimated] Failed to create layout animations stylesheet.');\n return;\n }\n styleTag.sheet.insertRule(keyframe, 0);\n animationNameList.unshift(animationName);\n animationNameToIndex.set(animationName, 0);\n for (let i = 1; i < animationNameList.length; ++i) {\n const nextAnimationName = animationNameList[i];\n const nextAnimationIndex = animationNameToIndex.get(nextAnimationName);\n if (nextAnimationIndex === undefined) {\n throw new Error('[Reanimated] Failed to obtain animation index.');\n }\n animationNameToIndex.set(animationNameList[i], nextAnimationIndex + 1);\n }\n}\nfunction removeWebAnimation(animationName) {\n var _styleTag$sheet;\n // Without this check SSR crashes because document is undefined (NextExample on CI)\n if (!isWindowAvailable()) {\n return;\n }\n const styleTag = document.getElementById(CUSTOM_WEB_ANIMATIONS_ID);\n const currentAnimationIndex = animationNameToIndex.get(animationName);\n if (currentAnimationIndex === undefined) {\n throw new Error('[Reanimated] Failed to obtain animation index.');\n }\n (_styleTag$sheet = styleTag.sheet) === null || _styleTag$sheet === void 0 || _styleTag$sheet.deleteRule(currentAnimationIndex);\n animationNameList.splice(currentAnimationIndex, 1);\n animationNameToIndex.delete(animationName);\n for (let i = currentAnimationIndex; i < animationNameList.length; ++i) {\n const nextAnimationName = animationNameList[i];\n const nextAnimationIndex = animationNameToIndex.get(nextAnimationName);\n if (nextAnimationIndex === undefined) {\n throw new Error('[Reanimated] Failed to obtain animation index.');\n }\n animationNameToIndex.set(animationNameList[i], nextAnimationIndex - 1);\n }\n}\nconst timeoutScale = 1.25; // We use this value to enlarge timeout duration. It can prove useful if animation lags.\nconst frameDurationMs = 16; // Just an approximation.\nconst minimumFrames = 10;\nexport function scheduleAnimationCleanup(animationName, animationDuration) {\n // If duration is very short, we want to keep remove delay to at least 10 frames\n // In our case it is exactly 160/1099 s, which is approximately 0.15s\n const timeoutValue = Math.max(animationDuration * timeoutScale * 1000, animationDuration + frameDurationMs * minimumFrames);\n setTimeout(() => removeWebAnimation(animationName), timeoutValue);\n}\nfunction reattachElementToAncestor(child, parent) {\n const childSnapshot = snapshots.get(child);\n if (!childSnapshot) {\n console.error('[Reanimated] Failed to obtain snapshot.');\n return;\n }\n\n // We use that so we don't end up in infinite loop\n child.removedAfterAnimation = true;\n parent.appendChild(child);\n setDummyPosition(child, childSnapshot);\n const originalOnAnimationEnd = child.onanimationend;\n child.onanimationend = function (event) {\n parent.removeChild(child);\n\n // Given that this function overrides onAnimationEnd, it won't be null\n originalOnAnimationEnd === null || originalOnAnimationEnd === void 0 || originalOnAnimationEnd.call(this, event);\n };\n}\nfunction findDescendantWithExitingAnimation(node, root) {\n // Node could be something else than HTMLElement, for example TextNode (treated as plain text, not as HTML object),\n // therefore it won't have children prop and calling Array.from(node.children) will cause error.\n if (!(node instanceof HTMLElement)) {\n return;\n }\n if (node.reanimatedDummy && node.removedAfterAnimation === undefined) {\n reattachElementToAncestor(node, root);\n }\n const children = Array.from(node.children);\n for (let i = 0; i < children.length; ++i) {\n findDescendantWithExitingAnimation(children[i], root);\n }\n}\nfunction checkIfScreenWasChanged(mutationTarget) {\n var _mutationTarget$react;\n let reactFiberKey = '__reactFiber';\n for (const key of Object.keys(mutationTarget)) {\n if (key.startsWith('__reactFiber')) {\n reactFiberKey = key;\n break;\n }\n }\n return ((_mutationTarget$react = mutationTarget[reactFiberKey]) === null || _mutationTarget$react === void 0 || (_mutationTarget$react = _mutationTarget$react.child) === null || _mutationTarget$react === void 0 || (_mutationTarget$react = _mutationTarget$react.memoizedProps) === null || _mutationTarget$react === void 0 ? void 0 : _mutationTarget$react.navigation) !== undefined;\n}\nexport function addHTMLMutationObserver() {\n if (isObserverSet || !isWindowAvailable()) {\n return;\n }\n isObserverSet = true;\n const observer = new MutationObserver(mutationsList => {\n const rootMutation = mutationsList[mutationsList.length - 1];\n if (checkIfScreenWasChanged(rootMutation.target)) {\n return;\n }\n for (let i = 0; i < rootMutation.removedNodes.length; ++i) {\n findDescendantWithExitingAnimation(rootMutation.removedNodes[i], rootMutation.target);\n }\n });\n observer.observe(document.body, {\n childList: true,\n subtree: true\n });\n}\nexport function areDOMRectsEqual(r1, r2) {\n // There are 4 more fields, but checking these should suffice\n return r1.x === r2.x && r1.y === r2.y && r1.width === r2.width && r1.height === r2.height;\n}\n//# sourceMappingURL=domUtils.js.map","'use strict';\n\nimport { _updatePropsJS } from '../../js-reanimated';\nexport const snapshots = new WeakMap();\nexport function makeElementVisible(element, delay) {\n if (delay === 0) {\n _updatePropsJS({\n visibility: 'initial'\n }, {\n _component: element\n });\n } else {\n setTimeout(() => {\n _updatePropsJS({\n visibility: 'initial'\n }, {\n _component: element\n });\n }, delay * 1000);\n }\n}\nfunction fixElementPosition(element, parent, snapshot) {\n const parentRect = parent.getBoundingClientRect();\n const parentBorderTopValue = parseInt(getComputedStyle(parent).borderTopWidth);\n const parentBorderLeftValue = parseInt(getComputedStyle(parent).borderLeftWidth);\n const dummyRect = element.getBoundingClientRect();\n // getBoundingClientRect returns DOMRect with position of the element with respect to document body.\n // However, using position `absolute` doesn't guarantee, that the dummy will be placed relative to body element.\n // The trick below allows us to once again get position relative to body, by comparing snapshot with new position of the dummy.\n if (dummyRect.top !== snapshot.top) {\n element.style.top = `${snapshot.top - parentRect.top - parentBorderTopValue}px`;\n }\n if (dummyRect.left !== snapshot.left) {\n element.style.left = `${snapshot.left - parentRect.left - parentBorderLeftValue}px`;\n }\n}\nexport function setDummyPosition(dummy, snapshot) {\n dummy.style.transform = '';\n dummy.style.position = 'absolute';\n dummy.style.top = `${snapshot.top}px`;\n dummy.style.left = `${snapshot.left}px`;\n dummy.style.width = `${snapshot.width}px`;\n dummy.style.height = `${snapshot.height}px`;\n dummy.style.margin = '0px'; // tmpElement has absolute position, so margin is not necessary\n\n if (dummy.parentElement) {\n fixElementPosition(dummy, dummy.parentElement, snapshot);\n }\n}\n//# sourceMappingURL=componentStyle.js.map","'use strict';\n\nimport { Animations, TransitionType, WebEasings } from './config';\nimport { convertTransformToString } from './animationParser';\nimport { TransitionGenerator } from './createAnimation';\nimport { scheduleAnimationCleanup } from './domUtils';\nimport { _updatePropsJS } from '../../js-reanimated';\nimport { ReduceMotion } from '../../commonTypes';\nimport { isReducedMotion } from '../../PlatformChecker';\nimport { LayoutAnimationType } from '../animationBuilder/commonTypes';\nimport { setDummyPosition, snapshots } from './componentStyle';\nfunction getEasingFromConfig(config) {\n const easingName = config.easingV && config.easingV.name in WebEasings ? config.easingV.name : 'linear';\n return `cubic-bezier(${WebEasings[easingName].toString()})`;\n}\nfunction getRandomDelay(maxDelay = 1000) {\n return Math.floor(Math.random() * (maxDelay + 1)) / 1000;\n}\nfunction getDelayFromConfig(config) {\n const shouldRandomizeDelay = config.randomizeDelay;\n const delay = shouldRandomizeDelay ? getRandomDelay() : 0;\n if (!config.delayV) {\n return delay;\n }\n return shouldRandomizeDelay ? getRandomDelay(config.delayV) : config.delayV / 1000;\n}\nexport function getReducedMotionFromConfig(config) {\n if (!config.reduceMotionV) {\n return isReducedMotion();\n }\n switch (config.reduceMotionV) {\n case ReduceMotion.Never:\n return false;\n case ReduceMotion.Always:\n return true;\n default:\n return isReducedMotion();\n }\n}\nfunction getDurationFromConfig(config, isLayoutTransition, animationName) {\n const defaultDuration = isLayoutTransition ? 0.3 : Animations[animationName].duration;\n return config.durationV !== undefined ? config.durationV / 1000 : defaultDuration;\n}\nfunction getCallbackFromConfig(config) {\n return config.callbackV !== undefined ? config.callbackV : null;\n}\nfunction getReversedFromConfig(config) {\n return !!config.reversed;\n}\nexport function extractTransformFromStyle(style) {\n if (!style) {\n return;\n }\n if (typeof style.transform === 'string') {\n throw new Error('[Reanimated] String transform is currently unsupported.');\n }\n if (!Array.isArray(style)) {\n return style.transform;\n }\n\n // Only last transform should be considered\n for (let i = style.length - 1; i >= 0; --i) {\n var _style$i;\n if ((_style$i = style[i]) !== null && _style$i !== void 0 && _style$i.transform) {\n return style[i].transform;\n }\n }\n}\nexport function getProcessedConfig(animationName, animationType, config, initialAnimationName) {\n return {\n animationName,\n animationType,\n duration: getDurationFromConfig(config, animationType === LayoutAnimationType.LAYOUT, initialAnimationName),\n delay: getDelayFromConfig(config),\n easing: getEasingFromConfig(config),\n callback: getCallbackFromConfig(config),\n reversed: getReversedFromConfig(config)\n };\n}\nexport function saveSnapshot(element) {\n const rect = element.getBoundingClientRect();\n const snapshot = {\n top: rect.top,\n left: rect.left,\n width: rect.width,\n height: rect.height,\n scrollOffsets: getElementScrollValue(element)\n };\n snapshots.set(element, snapshot);\n}\nexport function setElementAnimation(element, animationConfig, existingTransform) {\n const {\n animationName,\n duration,\n delay,\n easing\n } = animationConfig;\n element.style.animationName = animationName;\n element.style.animationDuration = `${duration}s`;\n element.style.animationDelay = `${delay}s`;\n element.style.animationTimingFunction = easing;\n element.onanimationend = () => {\n var _animationConfig$call;\n (_animationConfig$call = animationConfig.callback) === null || _animationConfig$call === void 0 || _animationConfig$call.call(animationConfig, true);\n element.removeEventListener('animationcancel', animationCancelHandler);\n };\n const animationCancelHandler = () => {\n var _animationConfig$call2;\n (_animationConfig$call2 = animationConfig.callback) === null || _animationConfig$call2 === void 0 || _animationConfig$call2.call(animationConfig, false);\n element.removeEventListener('animationcancel', animationCancelHandler);\n };\n\n // Here we have to use `addEventListener` since element.onanimationcancel doesn't work on chrome\n element.onanimationstart = () => {\n if (animationConfig.animationType === LayoutAnimationType.ENTERING) {\n _updatePropsJS({\n visibility: 'initial'\n }, {\n _component: element\n });\n }\n element.addEventListener('animationcancel', animationCancelHandler);\n element.style.transform = convertTransformToString(existingTransform);\n };\n if (!(animationName in Animations)) {\n scheduleAnimationCleanup(animationName, duration + delay);\n }\n}\nexport function handleLayoutTransition(element, animationConfig, transitionData, existingTransform) {\n const {\n animationName\n } = animationConfig;\n let animationType;\n switch (animationName) {\n case 'LinearTransition':\n animationType = TransitionType.LINEAR;\n break;\n case 'SequencedTransition':\n animationType = TransitionType.SEQUENCED;\n break;\n case 'FadingTransition':\n animationType = TransitionType.FADING;\n break;\n default:\n animationType = TransitionType.LINEAR;\n break;\n }\n animationConfig.animationName = TransitionGenerator(animationType, transitionData, existingTransform);\n const transformCopy = existingTransform ? structuredClone(existingTransform) : [];\n\n // @ts-ignore `existingTransform` cannot be string because in that case\n // we throw error in `extractTransformFromStyle`\n transformCopy.push(transitionData);\n element.style.transform = convertTransformToString(transformCopy);\n setElementAnimation(element, animationConfig, existingTransform);\n}\nfunction getElementScrollValue(element) {\n let current = element;\n const scrollOffsets = {\n scrollTopOffset: 0,\n scrollLeftOffset: 0\n };\n while (current) {\n if (current.scrollTop !== 0 && scrollOffsets.scrollTopOffset === 0) {\n scrollOffsets.scrollTopOffset = current.scrollTop;\n }\n if (current.scrollLeft !== 0 && scrollOffsets.scrollLeftOffset === 0) {\n scrollOffsets.scrollLeftOffset = current.scrollLeft;\n }\n current = current.parentElement;\n }\n return scrollOffsets;\n}\nexport function handleExitingAnimation(element, animationConfig) {\n const parent = element.offsetParent;\n const dummy = element.cloneNode();\n dummy.reanimatedDummy = true;\n element.style.animationName = '';\n // We hide current element so only its copy with proper animation will be displayed\n element.style.visibility = 'hidden';\n\n // After cloning the element, we want to move all children from original element to its clone. This is because original element\n // will be unmounted, therefore when this code executes in child component, parent will be either empty or removed soon.\n // Using element.cloneNode(true) doesn't solve the problem, because it creates copy of children and we won't be able to set their animations\n //\n // This loop works because appendChild() moves element into its new parent instead of copying it\n while (element.firstChild) {\n dummy.appendChild(element.firstChild);\n }\n setElementAnimation(dummy, animationConfig);\n parent === null || parent === void 0 || parent.appendChild(dummy);\n const snapshot = snapshots.get(element);\n const scrollOffsets = getElementScrollValue(element);\n\n // Scroll does not trigger snapshotting, therefore if we start exiting animation after\n // scrolling through parent component, dummy will end up in wrong place. In order to fix that\n // we keep last known scroll position in snapshot and then adjust dummy position based on\n // last known scroll offset and current scroll offset\n\n const currentScrollTopOffset = scrollOffsets.scrollTopOffset;\n const lastScrollTopOffset = snapshot.scrollOffsets.scrollTopOffset;\n if (currentScrollTopOffset !== lastScrollTopOffset) {\n snapshot.top += lastScrollTopOffset - currentScrollTopOffset;\n }\n const currentScrollLeftOffset = scrollOffsets.scrollLeftOffset;\n const lastScrollLeftOffset = snapshot.scrollOffsets.scrollLeftOffset;\n if (currentScrollLeftOffset !== lastScrollLeftOffset) {\n snapshot.left += lastScrollLeftOffset - currentScrollLeftOffset;\n }\n snapshots.set(dummy, snapshot);\n setDummyPosition(dummy, snapshot);\n const originalOnAnimationEnd = dummy.onanimationend;\n dummy.onanimationend = function (event) {\n if (parent !== null && parent !== void 0 && parent.contains(dummy)) {\n dummy.removedAfterAnimation = true;\n parent.removeChild(dummy);\n }\n\n // Given that this function overrides onAnimationEnd, it won't be null\n originalOnAnimationEnd === null || originalOnAnimationEnd === void 0 || originalOnAnimationEnd.call(this, event);\n };\n dummy.addEventListener('animationcancel', () => {\n if (parent !== null && parent !== void 0 && parent.contains(dummy)) {\n dummy.removedAfterAnimation = true;\n parent.removeChild(dummy);\n }\n });\n}\n//# sourceMappingURL=componentUtils.js.map","'use strict';\n\nimport { shouldBeUseWeb } from './PlatformChecker';\nimport { configureLayoutAnimationBatch, makeShareableCloneRecursive } from './core';\nfunction createUpdateManager() {\n const animations = [];\n // When a stack is rerendered we reconfigure all the shared elements.\n // To do that we want them to appear in our batch in the correct order,\n // so we defer some of the updates to appear at the end of the batch.\n const deferredAnimations = [];\n return {\n update(batchItem, isUnmounting) {\n if (isUnmounting) {\n deferredAnimations.push(batchItem);\n } else {\n animations.push(batchItem);\n }\n if (animations.length + deferredAnimations.length === 1) {\n setImmediate(this.flush);\n }\n },\n flush() {\n configureLayoutAnimationBatch(animations.concat(deferredAnimations));\n animations.length = 0;\n deferredAnimations.length = 0;\n }\n };\n}\n\n/**\n * Lets you update the current configuration of the layout animation or shared element transition for a given component.\n * Configurations are batched and applied at the end of the current execution block, right before sending the response back to native.\n *\n * @param viewTag - The tag of the component you'd like to configure.\n * @param type - The type of the animation you'd like to configure - {@link LayoutAnimationType}.\n * @param config - The animation configuration - {@link LayoutAnimationFunction}, {@link SharedTransitionAnimationsFunction}, {@link ProgressAnimationCallback} or {@link Keyframe}. Passing `undefined` will remove the animation.\n * @param sharedTransitionTag - The tag of the shared element transition you'd like to configure. Passing `undefined` will remove the transition.\n * @param isUnmounting - Determines whether the configuration should be included at the end of the batch, after all the non-deferred configurations (even those that were updated later). This is used to retain the correct ordering of shared elements. Defaults to `false`.\n */\nexport let updateLayoutAnimations;\nif (shouldBeUseWeb()) {\n updateLayoutAnimations = () => {\n // no-op\n };\n} else {\n const updateLayoutAnimationsManager = createUpdateManager();\n updateLayoutAnimations = (viewTag, type, config, sharedTransitionTag, isUnmounting) => updateLayoutAnimationsManager.update({\n viewTag,\n type,\n config: config ? makeShareableCloneRecursive(config) : undefined,\n sharedTransitionTag\n }, isUnmounting);\n}\n//# sourceMappingURL=UpdateLayoutAnimations.js.map","'use strict';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\n// This is a makeshift solution to handle both 0.73 and 0.74 versions of React Native.\nexport let getViewInfo = element => {\n if (element._nativeTag !== undefined && element.__nativeTag !== null) {\n getViewInfo = getViewInfo73;\n return getViewInfo73(element);\n } else if (element.__nativeTag !== undefined && element.__nativeTag !== null) {\n getViewInfo = getViewInfoLatest;\n return getViewInfoLatest(element);\n }\n return getViewInfo73(element);\n};\nfunction getViewInfo73(element) {\n var _element$viewConfig;\n return {\n // we can access view tag in the same way it's accessed here https://github.com/facebook/react/blob/e3f4eb7272d4ca0ee49f27577156b57eeb07cf73/packages/react-native-renderer/src/ReactFabric.js#L146\n viewName: element === null || element === void 0 || (_element$viewConfig = element.viewConfig) === null || _element$viewConfig === void 0 ? void 0 : _element$viewConfig.uiViewClassName,\n /**\n * RN uses viewConfig for components for storing different properties of the component(example: https://github.com/facebook/react-native/blob/main/packages/react-native/Libraries/Components/ScrollView/ScrollViewNativeComponent.js#L24).\n * The name we're looking for is in the field named uiViewClassName.\n */\n viewTag: element === null || element === void 0 ? void 0 : element._nativeTag,\n viewConfig: element === null || element === void 0 ? void 0 : element.viewConfig\n };\n}\nfunction getViewInfoLatest(element) {\n var _element$_viewConfig;\n return {\n viewName: element === null || element === void 0 || (_element$_viewConfig = element._viewConfig) === null || _element$_viewConfig === void 0 ? void 0 : _element$_viewConfig.uiViewClassName,\n viewTag: element === null || element === void 0 ? void 0 : element.__nativeTag,\n viewConfig: element === null || element === void 0 ? void 0 : element._viewConfig\n };\n}\n//# sourceMappingURL=getViewInfo.js.map","'use strict';\n\nexport { startScreenTransition, finishScreenTransition } from './animationManager';\nexport { ScreenTransition } from './presets';\n//# sourceMappingURL=index.js.map","'use strict';\n\nimport { configureProps } from '../../ConfigHelper';\nimport { applyStyle } from './styleUpdater';\nimport { getSwipeSimulator } from './swipeSimulator';\nconfigureProps();\nexport function startScreenTransition(screenTransitionConfig) {\n 'worklet';\n\n const {\n stackTag,\n sharedEvent\n } = screenTransitionConfig;\n sharedEvent.addListener(stackTag, () => {\n applyStyle(screenTransitionConfig, sharedEvent.value);\n });\n}\nfunction getLockAxis(goBackGesture) {\n 'worklet';\n\n if (['swipeRight', 'swipeLeft', 'horizontalSwipe'].includes(goBackGesture)) {\n return 'x';\n } else if (['swipeUp', 'swipeDown', 'verticalSwipe'].includes(goBackGesture)) {\n return 'y';\n }\n return undefined;\n}\nexport function finishScreenTransition(screenTransitionConfig) {\n 'worklet';\n\n const {\n stackTag,\n sharedEvent,\n goBackGesture\n } = screenTransitionConfig;\n sharedEvent.removeListener(stackTag);\n const lockAxis = getLockAxis(goBackGesture);\n const step = getSwipeSimulator(sharedEvent.value, screenTransitionConfig, lockAxis);\n step();\n}\n//# sourceMappingURL=animationManager.js.map","'use strict';\n\nimport { isFabric } from '../PlatformChecker';\nimport updateProps from '../UpdateProps';\nconst IS_FABRIC = isFabric();\nfunction createViewDescriptorPaper(screenId) {\n 'worklet';\n\n return {\n tag: screenId,\n name: 'RCTView'\n };\n}\nfunction createViewDescriptorFabric(screenId) {\n 'worklet';\n\n return {\n shadowNodeWrapper: screenId\n };\n}\nconst createViewDescriptor = IS_FABRIC ? createViewDescriptorFabric : createViewDescriptorPaper;\nfunction applyStyleForTopScreen(screenTransitionConfig, event) {\n 'worklet';\n\n const {\n screenDimensions,\n topScreenId,\n screenTransition\n } = screenTransitionConfig;\n const {\n topScreenStyle: computeTopScreenStyle\n } = screenTransition;\n const topScreenStyle = computeTopScreenStyle(event, screenDimensions);\n const topScreenDescriptor = {\n value: [createViewDescriptor(topScreenId)]\n };\n updateProps(topScreenDescriptor, topScreenStyle, undefined);\n}\nexport function applyStyleForBelowTopScreen(screenTransitionConfig, event) {\n 'worklet';\n\n const {\n screenDimensions,\n belowTopScreenId,\n screenTransition\n } = screenTransitionConfig;\n const {\n belowTopScreenStyle: computeBelowTopScreenStyle\n } = screenTransition;\n const belowTopScreenStyle = computeBelowTopScreenStyle(event, screenDimensions);\n const belowTopScreenDescriptor = {\n value: [createViewDescriptor(belowTopScreenId)]\n };\n updateProps(belowTopScreenDescriptor, belowTopScreenStyle, undefined);\n}\nexport function applyStyle(screenTransitionConfig, event) {\n 'worklet';\n\n applyStyleForTopScreen(screenTransitionConfig, event);\n applyStyleForBelowTopScreen(screenTransitionConfig, event);\n}\n//# sourceMappingURL=styleUpdater.js.map","'use strict';\n\nimport { applyStyle, applyStyleForBelowTopScreen } from './styleUpdater';\nimport { RNScreensTurboModule } from './RNScreensTurboModule';\nconst BASE_VELOCITY = 400;\nconst ADDITIONAL_VELOCITY_FACTOR_X = 400;\nconst ADDITIONAL_VELOCITY_FACTOR_Y = 500;\nconst ADDITIONAL_VELOCITY_FACTOR_XY = 600;\nfunction computeEasingProgress(startingTimestamp, distance, velocity) {\n 'worklet';\n\n if (Math.abs(distance) < 1) {\n return 1;\n }\n const elapsedTime = (_getAnimationTimestamp() - startingTimestamp) / 1000;\n const currentPosition = velocity * elapsedTime;\n const progress = currentPosition / distance;\n return progress;\n}\nfunction easing(x) {\n 'worklet';\n\n // based on https://easings.net/#easeOutQuart\n return 1 - Math.pow(1 - x, 5);\n}\nfunction computeProgress(screenTransitionConfig, event, isTransitionCanceled) {\n 'worklet';\n\n const screenDimensions = screenTransitionConfig.screenDimensions;\n const progressX = Math.abs(event.translationX / screenDimensions.width);\n const progressY = Math.abs(event.translationY / screenDimensions.height);\n const maxProgress = Math.max(progressX, progressY);\n const progress = isTransitionCanceled ? maxProgress / 2 : maxProgress;\n return progress;\n}\nfunction maybeScheduleNextFrame(step, didScreenReachDestination, screenTransitionConfig, event, isTransitionCanceled) {\n 'worklet';\n\n if (!didScreenReachDestination) {\n const stackTag = screenTransitionConfig.stackTag;\n const progress = computeProgress(screenTransitionConfig, event, isTransitionCanceled);\n RNScreensTurboModule.updateTransition(stackTag, progress);\n requestAnimationFrame(step);\n } else {\n var _screenTransitionConf;\n (_screenTransitionConf = screenTransitionConfig.onFinishAnimation) === null || _screenTransitionConf === void 0 || _screenTransitionConf.call(screenTransitionConfig);\n }\n}\nexport function getSwipeSimulator(event, screenTransitionConfig, lockAxis) {\n 'worklet';\n\n const screenDimensions = screenTransitionConfig.screenDimensions;\n const startTimestamp = _getAnimationTimestamp();\n const {\n isTransitionCanceled\n } = screenTransitionConfig;\n const startingPosition = {\n x: event.translationX,\n y: event.translationY\n };\n const direction = {\n x: Math.sign(event.translationX),\n y: Math.sign(event.translationY)\n };\n const finalPosition = isTransitionCanceled ? {\n x: 0,\n y: 0\n } : {\n x: direction.x * screenDimensions.width,\n y: direction.y * screenDimensions.height\n };\n const distance = {\n x: Math.abs(finalPosition.x - startingPosition.x),\n y: Math.abs(finalPosition.y - startingPosition.y)\n };\n const didScreenReachDestination = {\n x: false,\n y: false\n };\n const velocity = {\n x: BASE_VELOCITY,\n y: BASE_VELOCITY\n };\n if (lockAxis === 'x') {\n velocity.y = 0;\n velocity.x += ADDITIONAL_VELOCITY_FACTOR_X * distance.x / screenDimensions.width;\n } else if (lockAxis === 'y') {\n velocity.x = 0;\n velocity.y += ADDITIONAL_VELOCITY_FACTOR_Y * distance.y / screenDimensions.height;\n } else {\n const euclideanDistance = Math.sqrt(distance.x ** 2 + distance.y ** 2);\n const screenDiagonal = Math.sqrt(screenDimensions.width ** 2 + screenDimensions.height ** 2);\n const velocityVectorLength = BASE_VELOCITY + ADDITIONAL_VELOCITY_FACTOR_XY * euclideanDistance / screenDiagonal;\n if (Math.abs(startingPosition.x) > Math.abs(startingPosition.y)) {\n velocity.x = velocityVectorLength;\n velocity.y = velocityVectorLength * Math.abs(startingPosition.y / startingPosition.x);\n } else {\n velocity.x = velocityVectorLength * Math.abs(startingPosition.x / startingPosition.y);\n velocity.y = velocityVectorLength;\n }\n }\n if (isTransitionCanceled) {\n function didScreenReachDestinationCheck() {\n if (lockAxis === 'x') {\n return didScreenReachDestination.x;\n } else if (lockAxis === 'y') {\n return didScreenReachDestination.y;\n } else {\n return didScreenReachDestination.x && didScreenReachDestination.y;\n }\n }\n function restoreOriginalStyleForBelowTopScreen() {\n event.translationX = direction.x * screenDimensions.width;\n event.translationY = direction.y * screenDimensions.height;\n applyStyleForBelowTopScreen(screenTransitionConfig, event);\n }\n const computeFrame = () => {\n const progress = {\n x: computeEasingProgress(startTimestamp, distance.x, velocity.x),\n y: computeEasingProgress(startTimestamp, distance.y, velocity.y)\n };\n event.translationX = startingPosition.x - direction.x * distance.x * easing(progress.x);\n event.translationY = startingPosition.y - direction.y * distance.y * easing(progress.y);\n if (direction.x > 0) {\n if (event.translationX <= 0) {\n didScreenReachDestination.x = true;\n event.translationX = 0;\n }\n } else {\n if (event.translationX >= 0) {\n didScreenReachDestination.x = true;\n event.translationX = 0;\n }\n }\n if (direction.y > 0) {\n if (event.translationY <= 0) {\n didScreenReachDestination.y = true;\n event.translationY = 0;\n }\n } else {\n if (event.translationY >= 0) {\n didScreenReachDestination.y = true;\n event.translationY = 0;\n }\n }\n applyStyle(screenTransitionConfig, event);\n const finished = didScreenReachDestinationCheck();\n if (finished) {\n restoreOriginalStyleForBelowTopScreen();\n }\n maybeScheduleNextFrame(computeFrame, finished, screenTransitionConfig, event, isTransitionCanceled);\n };\n return computeFrame;\n } else {\n const computeFrame = () => {\n const progress = {\n x: computeEasingProgress(startTimestamp, distance.x, velocity.x),\n y: computeEasingProgress(startTimestamp, distance.y, velocity.y)\n };\n event.translationX = startingPosition.x + direction.x * distance.x * easing(progress.x);\n event.translationY = startingPosition.y + direction.y * distance.y * easing(progress.y);\n if (direction.x > 0) {\n if (event.translationX >= screenDimensions.width) {\n didScreenReachDestination.x = true;\n event.translationX = screenDimensions.width;\n }\n } else {\n if (event.translationX <= -screenDimensions.width) {\n didScreenReachDestination.x = true;\n event.translationX = -screenDimensions.width;\n }\n }\n if (direction.y > 0) {\n if (event.translationY >= screenDimensions.height) {\n didScreenReachDestination.y = true;\n event.translationY = screenDimensions.height;\n }\n } else {\n if (event.translationY <= -screenDimensions.height) {\n didScreenReachDestination.y = true;\n event.translationY = -screenDimensions.height;\n }\n }\n applyStyle(screenTransitionConfig, event);\n maybeScheduleNextFrame(computeFrame, didScreenReachDestination.x || didScreenReachDestination.y, screenTransitionConfig, event, isTransitionCanceled);\n };\n return computeFrame;\n }\n}\n//# sourceMappingURL=swipeSimulator.js.map","'use strict';\n\nfunction noopFactory(defaultReturnValue) {\n return () => {\n 'worklet';\n\n console.warn('[Reanimated] RNScreensTurboModule has not been found. Check that you have installed `react-native-screens@3.30.0` or newer in your project and rebuilt your app.');\n return defaultReturnValue;\n };\n}\nexport const RNScreensTurboModule = global.RNScreensTurboModule || {\n startTransition: noopFactory({\n topScreenId: -1,\n belowTopScreenId: -1,\n canStartTransition: false\n }),\n updateTransition: noopFactory(),\n finishTransition: noopFactory()\n};\n//# sourceMappingURL=RNScreensTurboModule.js.map","'use strict';\n\nconst SwipeRight = {\n topScreenStyle: event => {\n 'worklet';\n\n return {\n transform: [{\n translateX: event.translationX\n }]\n };\n },\n belowTopScreenStyle: (event, screenSize) => {\n 'worklet';\n\n return {\n transform: [{\n translateX: (event.translationX - screenSize.width) * 0.3\n }]\n };\n }\n};\nconst SwipeLeft = {\n topScreenStyle: event => {\n 'worklet';\n\n return {\n transform: [{\n translateX: event.translationX\n }]\n };\n },\n belowTopScreenStyle: (event, screenSize) => {\n 'worklet';\n\n return {\n transform: [{\n translateX: (event.translationX + screenSize.width) * 0.3\n }]\n };\n }\n};\nconst SwipeDown = {\n topScreenStyle: event => {\n 'worklet';\n\n return {\n transform: [{\n translateY: event.translationY\n }]\n };\n },\n belowTopScreenStyle: (event, screenSize) => {\n 'worklet';\n\n return {\n transform: [{\n translateY: (event.translationY - screenSize.height) * 0.3\n }]\n };\n }\n};\nconst SwipeUp = {\n topScreenStyle: event => {\n 'worklet';\n\n return {\n transform: [{\n translateY: event.translationY\n }]\n };\n },\n belowTopScreenStyle: (event, screenSize) => {\n 'worklet';\n\n return {\n transform: [{\n translateY: (event.translationY + screenSize.height) * 0.3\n }]\n };\n }\n};\nconst TwoDimensional = {\n topScreenStyle: (event, _screenSize) => {\n 'worklet';\n\n return {\n transform: [{\n translateX: event.translationX\n }, {\n translateY: event.translationY\n }]\n };\n },\n belowTopScreenStyle: (_event, _screenSize) => {\n 'worklet';\n\n return {};\n }\n};\nconst Horizontal = {\n topScreenStyle: (event, _screenSize) => {\n 'worklet';\n\n return {\n transform: [{\n translateX: event.translationX\n }]\n };\n },\n belowTopScreenStyle: (_event, _screenSize) => {\n 'worklet';\n\n return {};\n }\n};\nconst Vertical = {\n topScreenStyle: (event, _screenSize) => {\n 'worklet';\n\n return {\n transform: [{\n translateY: event.translationY\n }]\n };\n },\n belowTopScreenStyle: (_event, _screenSize) => {\n 'worklet';\n\n return {};\n }\n};\nconst SwipeRightFade = {\n topScreenStyle: (event, screenSize) => {\n 'worklet';\n\n return {\n opacity: 1 - Math.abs(event.translationX / screenSize.width)\n };\n },\n belowTopScreenStyle: (_event, _screenSize) => {\n 'worklet';\n\n return {};\n }\n};\nexport const ScreenTransition = {\n SwipeRight,\n SwipeLeft,\n SwipeDown,\n SwipeUp,\n Horizontal,\n Vertical,\n TwoDimensional,\n SwipeRightFade\n};\n//# sourceMappingURL=presets.js.map","'use strict';\n\nexport { createAnimatedComponent } from './createAnimatedComponent';\nexport { AnimatedText as Text } from './reanimated2/component/Text';\nexport { AnimatedView as View } from './reanimated2/component/View';\nexport { AnimatedScrollView as ScrollView } from './reanimated2/component/ScrollView';\nexport { AnimatedImage as Image } from './reanimated2/component/Image';\nexport { ReanimatedFlatList as FlatList } from './reanimated2/component/FlatList';\nexport { addWhitelistedNativeProps, addWhitelistedUIProps } from './ConfigHelper';\n/**\n * @deprecated Please import `Extrapolate` directly from `react-native-reanimated` instead of `Animated` namespace.\n */\n\n/**\n * @deprecated Please import `SharedValue` directly from `react-native-reanimated` instead of `Animated` namespace.\n */\n\n/**\n * @deprecated Please import `DerivedValue` directly from `react-native-reanimated` instead of `Animated` namespace.\n */\n\n/**\n * @deprecated Please import `Adaptable` directly from `react-native-reanimated` instead of `Animated` namespace.\n */\n\n/**\n * @deprecated Please import `TransformStyleTypes` directly from `react-native-reanimated` instead of `Animated` namespace.\n * */\n\n/**\n * @deprecated Please import `AdaptTransforms` directly from `react-native-reanimated` instead of `Animated` namespace.\n * */\n\n/**\n * @deprecated Please import `AnimatedTransform` directly from `react-native-reanimated` instead of `Animated` namespace.\n */\n\n/**\n * @deprecated Please import `AnimateStyle` directly from `react-native-reanimated` instead of `Animated` namespace.\n * */\n\n/**\n * @deprecated Please import `StylesOrDefault` directly from `react-native-reanimated` instead of `Animated` namespace.\n * */\n\n/**\n * @deprecated Please import `AnimateProps` directly from `react-native-reanimated` instead of `Animated` namespace.\n * */\n\n/**\n * @deprecated Please import `EasingFunction` directly from `react-native-reanimated` instead of `Animated` namespace.\n * */\n\n/**\n * @deprecated Please import `AnimatedScrollViewProps` directly from `react-native-reanimated` instead of `Animated` namespace.\n * */\n\n/**\n * @deprecated Please import `FlatListPropsWithLayout` directly from `react-native-reanimated` instead of `Animated` namespace.\n * */\n//# sourceMappingURL=Animated.js.map","'use strict';\n\nimport { Text } from 'react-native';\nimport { createAnimatedComponent } from '../../createAnimatedComponent';\n\n// Since createAnimatedComponent return type is ComponentClass that has the props of the argument,\n// but not things like NativeMethods, etc. we need to add them manually by extending the type.\n\nexport const AnimatedText = createAnimatedComponent(Text);\n//# sourceMappingURL=Text.js.map","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"hrefAttrs\", \"numberOfLines\", \"onClick\", \"onLayout\", \"onPress\", \"onMoveShouldSetResponder\", \"onMoveShouldSetResponderCapture\", \"onResponderEnd\", \"onResponderGrant\", \"onResponderMove\", \"onResponderReject\", \"onResponderRelease\", \"onResponderStart\", \"onResponderTerminate\", \"onResponderTerminationRequest\", \"onScrollShouldSetResponder\", \"onScrollShouldSetResponderCapture\", \"onSelectionChangeShouldSetResponder\", \"onSelectionChangeShouldSetResponderCapture\", \"onStartShouldSetResponder\", \"onStartShouldSetResponderCapture\", \"selectable\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport createElement from '../createElement';\nimport * as forwardedProps from '../../modules/forwardedProps';\nimport pick from '../../modules/pick';\nimport useElementLayout from '../../modules/useElementLayout';\nimport useMergeRefs from '../../modules/useMergeRefs';\nimport usePlatformMethods from '../../modules/usePlatformMethods';\nimport useResponderEvents from '../../modules/useResponderEvents';\nimport StyleSheet from '../StyleSheet';\nimport TextAncestorContext from './TextAncestorContext';\nimport { useLocaleContext, getLocaleDirection } from '../../modules/useLocale';\nimport { warnOnce } from '../../modules/warnOnce';\nvar forwardPropsList = Object.assign({}, forwardedProps.defaultProps, forwardedProps.accessibilityProps, forwardedProps.clickProps, forwardedProps.focusProps, forwardedProps.keyboardProps, forwardedProps.mouseProps, forwardedProps.touchProps, forwardedProps.styleProps, {\n href: true,\n lang: true,\n pointerEvents: true\n});\nvar pickProps = props => pick(props, forwardPropsList);\nvar Text = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var hrefAttrs = props.hrefAttrs,\n numberOfLines = props.numberOfLines,\n onClick = props.onClick,\n onLayout = props.onLayout,\n onPress = props.onPress,\n onMoveShouldSetResponder = props.onMoveShouldSetResponder,\n onMoveShouldSetResponderCapture = props.onMoveShouldSetResponderCapture,\n onResponderEnd = props.onResponderEnd,\n onResponderGrant = props.onResponderGrant,\n onResponderMove = props.onResponderMove,\n onResponderReject = props.onResponderReject,\n onResponderRelease = props.onResponderRelease,\n onResponderStart = props.onResponderStart,\n onResponderTerminate = props.onResponderTerminate,\n onResponderTerminationRequest = props.onResponderTerminationRequest,\n onScrollShouldSetResponder = props.onScrollShouldSetResponder,\n onScrollShouldSetResponderCapture = props.onScrollShouldSetResponderCapture,\n onSelectionChangeShouldSetResponder = props.onSelectionChangeShouldSetResponder,\n onSelectionChangeShouldSetResponderCapture = props.onSelectionChangeShouldSetResponderCapture,\n onStartShouldSetResponder = props.onStartShouldSetResponder,\n onStartShouldSetResponderCapture = props.onStartShouldSetResponderCapture,\n selectable = props.selectable,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n if (selectable != null) {\n warnOnce('selectable', 'selectable prop is deprecated. Use styles.userSelect.');\n }\n var hasTextAncestor = React.useContext(TextAncestorContext);\n var hostRef = React.useRef(null);\n var _useLocaleContext = useLocaleContext(),\n contextDirection = _useLocaleContext.direction;\n useElementLayout(hostRef, onLayout);\n useResponderEvents(hostRef, {\n onMoveShouldSetResponder,\n onMoveShouldSetResponderCapture,\n onResponderEnd,\n onResponderGrant,\n onResponderMove,\n onResponderReject,\n onResponderRelease,\n onResponderStart,\n onResponderTerminate,\n onResponderTerminationRequest,\n onScrollShouldSetResponder,\n onScrollShouldSetResponderCapture,\n onSelectionChangeShouldSetResponder,\n onSelectionChangeShouldSetResponderCapture,\n onStartShouldSetResponder,\n onStartShouldSetResponderCapture\n });\n var handleClick = React.useCallback(e => {\n if (onClick != null) {\n onClick(e);\n } else if (onPress != null) {\n e.stopPropagation();\n onPress(e);\n }\n }, [onClick, onPress]);\n var component = hasTextAncestor ? 'span' : 'div';\n var langDirection = props.lang != null ? getLocaleDirection(props.lang) : null;\n var componentDirection = props.dir || langDirection;\n var writingDirection = componentDirection || contextDirection;\n var supportedProps = pickProps(rest);\n supportedProps.dir = componentDirection;\n // 'auto' by default allows browsers to infer writing direction (root elements only)\n if (!hasTextAncestor) {\n supportedProps.dir = componentDirection != null ? componentDirection : 'auto';\n }\n if (onClick || onPress) {\n supportedProps.onClick = handleClick;\n }\n supportedProps.style = [numberOfLines != null && numberOfLines > 1 && {\n WebkitLineClamp: numberOfLines\n }, hasTextAncestor === true ? styles.textHasAncestor$raw : styles.text$raw, numberOfLines === 1 && styles.textOneLine, numberOfLines != null && numberOfLines > 1 && styles.textMultiLine, props.style, selectable === true && styles.selectable, selectable === false && styles.notSelectable, onPress && styles.pressable];\n if (props.href != null) {\n component = 'a';\n if (hrefAttrs != null) {\n var download = hrefAttrs.download,\n rel = hrefAttrs.rel,\n target = hrefAttrs.target;\n if (download != null) {\n supportedProps.download = download;\n }\n if (rel != null) {\n supportedProps.rel = rel;\n }\n if (typeof target === 'string') {\n supportedProps.target = target.charAt(0) !== '_' ? '_' + target : target;\n }\n }\n }\n var platformMethodsRef = usePlatformMethods(supportedProps);\n var setRef = useMergeRefs(hostRef, platformMethodsRef, forwardedRef);\n supportedProps.ref = setRef;\n var element = createElement(component, supportedProps, {\n writingDirection\n });\n return hasTextAncestor ? element : /*#__PURE__*/React.createElement(TextAncestorContext.Provider, {\n value: true\n }, element);\n});\nText.displayName = 'Text';\nvar textStyle = {\n backgroundColor: 'transparent',\n border: '0 solid black',\n boxSizing: 'border-box',\n color: 'black',\n display: 'inline',\n font: '14px System',\n listStyle: 'none',\n margin: 0,\n padding: 0,\n position: 'relative',\n textAlign: 'start',\n textDecoration: 'none',\n whiteSpace: 'pre-wrap',\n wordWrap: 'break-word'\n};\nvar styles = StyleSheet.create({\n text$raw: textStyle,\n textHasAncestor$raw: _objectSpread(_objectSpread({}, textStyle), {}, {\n color: 'inherit',\n font: 'inherit',\n textAlign: 'inherit',\n whiteSpace: 'inherit'\n }),\n textOneLine: {\n maxWidth: '100%',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n wordWrap: 'normal'\n },\n // See #13\n textMultiLine: {\n display: '-webkit-box',\n maxWidth: '100%',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n WebkitBoxOrient: 'vertical'\n },\n notSelectable: {\n userSelect: 'none'\n },\n selectable: {\n userSelect: 'text'\n },\n pressable: {\n cursor: 'pointer'\n }\n});\nexport default Text;","'use strict';\n\nimport { View } from 'react-native';\nimport { createAnimatedComponent } from '../../createAnimatedComponent';\n\n// Since createAnimatedComponent return type is ComponentClass that has the props of the argument,\n// but not things like NativeMethods, etc. we need to add them manually by extending the type.\n\nexport const AnimatedView = createAnimatedComponent(View);\n//# sourceMappingURL=View.js.map","'use strict';\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport React, { forwardRef } from 'react';\nimport { ScrollView } from 'react-native';\nimport { createAnimatedComponent } from '../../createAnimatedComponent';\nimport { useAnimatedRef, useScrollViewOffset } from '../hook';\n\n// Since createAnimatedComponent return type is ComponentClass that has the props of the argument,\n// but not things like NativeMethods, etc. we need to add them manually by extending the type.\n\nconst AnimatedScrollViewComponent = createAnimatedComponent(ScrollView);\nexport const AnimatedScrollView = /*#__PURE__*/forwardRef((props, ref) => {\n const {\n scrollViewOffset,\n ...restProps\n } = props;\n const animatedRef = ref === null ?\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useAnimatedRef() : ref;\n if (scrollViewOffset) {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useScrollViewOffset(animatedRef, scrollViewOffset);\n }\n\n // Set default scrollEventThrottle, because user expects\n // to have continuous scroll events.\n // We set it to 1 so we have peace until\n // there are 960 fps screens.\n if (!('scrollEventThrottle' in restProps)) {\n restProps.scrollEventThrottle = 1;\n }\n return /*#__PURE__*/React.createElement(AnimatedScrollViewComponent, _extends({\n ref: animatedRef\n }, restProps));\n});\n//# sourceMappingURL=ScrollView.js.map","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"contentContainerStyle\", \"horizontal\", \"onContentSizeChange\", \"refreshControl\", \"stickyHeaderIndices\", \"pagingEnabled\", \"forwardedRef\", \"keyboardDismissMode\", \"onScroll\", \"centerContent\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport Dimensions from '../Dimensions';\nimport dismissKeyboard from '../../modules/dismissKeyboard';\nimport invariant from 'fbjs/lib/invariant';\nimport mergeRefs from '../../modules/mergeRefs';\nimport Platform from '../Platform';\nimport ScrollViewBase from './ScrollViewBase';\nimport StyleSheet from '../StyleSheet';\nimport TextInputState from '../../modules/TextInputState';\nimport UIManager from '../UIManager';\nimport View from '../View';\nimport React from 'react';\nimport warning from 'fbjs/lib/warning';\nvar emptyObject = {};\nvar IS_ANIMATING_TOUCH_START_THRESHOLD_MS = 16;\nclass ScrollView extends React.Component {\n constructor() {\n super(...arguments);\n this._scrollNodeRef = null;\n this._innerViewRef = null;\n this.isTouching = false;\n this.lastMomentumScrollBeginTime = 0;\n this.lastMomentumScrollEndTime = 0;\n this.observedScrollSinceBecomingResponder = false;\n this.becameResponderWhileAnimating = false;\n this.scrollResponderHandleScrollShouldSetResponder = () => {\n return this.isTouching;\n };\n this.scrollResponderHandleStartShouldSetResponderCapture = e => {\n // First see if we want to eat taps while the keyboard is up\n // var currentlyFocusedTextInput = TextInputState.currentlyFocusedField();\n // if (!this.props.keyboardShouldPersistTaps &&\n // currentlyFocusedTextInput != null &&\n // e.target !== currentlyFocusedTextInput) {\n // return true;\n // }\n return this.scrollResponderIsAnimating();\n };\n this.scrollResponderHandleTerminationRequest = () => {\n return !this.observedScrollSinceBecomingResponder;\n };\n this.scrollResponderHandleTouchEnd = e => {\n var nativeEvent = e.nativeEvent;\n this.isTouching = nativeEvent.touches.length !== 0;\n this.props.onTouchEnd && this.props.onTouchEnd(e);\n };\n this.scrollResponderHandleResponderRelease = e => {\n this.props.onResponderRelease && this.props.onResponderRelease(e);\n\n // By default scroll views will unfocus a textField\n // if another touch occurs outside of it\n var currentlyFocusedTextInput = TextInputState.currentlyFocusedField();\n if (!this.props.keyboardShouldPersistTaps && currentlyFocusedTextInput != null && e.target !== currentlyFocusedTextInput && !this.observedScrollSinceBecomingResponder && !this.becameResponderWhileAnimating) {\n this.props.onScrollResponderKeyboardDismissed && this.props.onScrollResponderKeyboardDismissed(e);\n TextInputState.blurTextInput(currentlyFocusedTextInput);\n }\n };\n this.scrollResponderHandleScroll = e => {\n this.observedScrollSinceBecomingResponder = true;\n this.props.onScroll && this.props.onScroll(e);\n };\n this.scrollResponderHandleResponderGrant = e => {\n this.observedScrollSinceBecomingResponder = false;\n this.props.onResponderGrant && this.props.onResponderGrant(e);\n this.becameResponderWhileAnimating = this.scrollResponderIsAnimating();\n };\n this.scrollResponderHandleScrollBeginDrag = e => {\n this.props.onScrollBeginDrag && this.props.onScrollBeginDrag(e);\n };\n this.scrollResponderHandleScrollEndDrag = e => {\n this.props.onScrollEndDrag && this.props.onScrollEndDrag(e);\n };\n this.scrollResponderHandleMomentumScrollBegin = e => {\n this.lastMomentumScrollBeginTime = Date.now();\n this.props.onMomentumScrollBegin && this.props.onMomentumScrollBegin(e);\n };\n this.scrollResponderHandleMomentumScrollEnd = e => {\n this.lastMomentumScrollEndTime = Date.now();\n this.props.onMomentumScrollEnd && this.props.onMomentumScrollEnd(e);\n };\n this.scrollResponderHandleTouchStart = e => {\n this.isTouching = true;\n this.props.onTouchStart && this.props.onTouchStart(e);\n };\n this.scrollResponderHandleTouchMove = e => {\n this.props.onTouchMove && this.props.onTouchMove(e);\n };\n this.scrollResponderIsAnimating = () => {\n var now = Date.now();\n var timeSinceLastMomentumScrollEnd = now - this.lastMomentumScrollEndTime;\n var isAnimating = timeSinceLastMomentumScrollEnd < IS_ANIMATING_TOUCH_START_THRESHOLD_MS || this.lastMomentumScrollEndTime < this.lastMomentumScrollBeginTime;\n return isAnimating;\n };\n this.scrollResponderScrollTo = (x, y, animated) => {\n if (typeof x === 'number') {\n console.warn('`scrollResponderScrollTo(x, y, animated)` is deprecated. Use `scrollResponderScrollTo({x: 5, y: 5, animated: true})` instead.');\n } else {\n var _ref = x || emptyObject;\n x = _ref.x;\n y = _ref.y;\n animated = _ref.animated;\n }\n var node = this.getScrollableNode();\n var left = x || 0;\n var top = y || 0;\n if (node != null) {\n if (typeof node.scroll === 'function') {\n node.scroll({\n top,\n left,\n behavior: !animated ? 'auto' : 'smooth'\n });\n } else {\n node.scrollLeft = left;\n node.scrollTop = top;\n }\n }\n };\n this.scrollResponderZoomTo = (rect, animated) => {\n if (Platform.OS !== 'ios') {\n invariant('zoomToRect is not implemented');\n }\n };\n this.scrollResponderScrollNativeHandleToKeyboard = (nodeHandle, additionalOffset, preventNegativeScrollOffset) => {\n this.additionalScrollOffset = additionalOffset || 0;\n this.preventNegativeScrollOffset = !!preventNegativeScrollOffset;\n UIManager.measureLayout(nodeHandle, this.getInnerViewNode(), this.scrollResponderTextInputFocusError, this.scrollResponderInputMeasureAndScrollToKeyboard);\n };\n this.scrollResponderInputMeasureAndScrollToKeyboard = (left, top, width, height) => {\n var keyboardScreenY = Dimensions.get('window').height;\n if (this.keyboardWillOpenTo) {\n keyboardScreenY = this.keyboardWillOpenTo.endCoordinates.screenY;\n }\n var scrollOffsetY = top - keyboardScreenY + height + this.additionalScrollOffset;\n\n // By default, this can scroll with negative offset, pulling the content\n // down so that the target component's bottom meets the keyboard's top.\n // If requested otherwise, cap the offset at 0 minimum to avoid content\n // shifting down.\n if (this.preventNegativeScrollOffset) {\n scrollOffsetY = Math.max(0, scrollOffsetY);\n }\n this.scrollResponderScrollTo({\n x: 0,\n y: scrollOffsetY,\n animated: true\n });\n this.additionalOffset = 0;\n this.preventNegativeScrollOffset = false;\n };\n this.scrollResponderKeyboardWillShow = e => {\n this.keyboardWillOpenTo = e;\n this.props.onKeyboardWillShow && this.props.onKeyboardWillShow(e);\n };\n this.scrollResponderKeyboardWillHide = e => {\n this.keyboardWillOpenTo = null;\n this.props.onKeyboardWillHide && this.props.onKeyboardWillHide(e);\n };\n this.scrollResponderKeyboardDidShow = e => {\n // TODO(7693961): The event for DidShow is not available on iOS yet.\n // Use the one from WillShow and do not assign.\n if (e) {\n this.keyboardWillOpenTo = e;\n }\n this.props.onKeyboardDidShow && this.props.onKeyboardDidShow(e);\n };\n this.scrollResponderKeyboardDidHide = e => {\n this.keyboardWillOpenTo = null;\n this.props.onKeyboardDidHide && this.props.onKeyboardDidHide(e);\n };\n this.flashScrollIndicators = () => {\n this.scrollResponderFlashScrollIndicators();\n };\n this.getScrollResponder = () => {\n return this;\n };\n this.getScrollableNode = () => {\n return this._scrollNodeRef;\n };\n this.getInnerViewRef = () => {\n return this._innerViewRef;\n };\n this.getInnerViewNode = () => {\n return this._innerViewRef;\n };\n this.getNativeScrollRef = () => {\n return this._scrollNodeRef;\n };\n this.scrollTo = (y, x, animated) => {\n if (typeof y === 'number') {\n console.warn('`scrollTo(y, x, animated)` is deprecated. Use `scrollTo({x: 5, y: 5, animated: true})` instead.');\n } else {\n var _ref2 = y || emptyObject;\n x = _ref2.x;\n y = _ref2.y;\n animated = _ref2.animated;\n }\n this.scrollResponderScrollTo({\n x: x || 0,\n y: y || 0,\n animated: animated !== false\n });\n };\n this.scrollToEnd = options => {\n // Default to true\n var animated = (options && options.animated) !== false;\n var horizontal = this.props.horizontal;\n var scrollResponderNode = this.getScrollableNode();\n var x = horizontal ? scrollResponderNode.scrollWidth : 0;\n var y = horizontal ? 0 : scrollResponderNode.scrollHeight;\n this.scrollResponderScrollTo({\n x,\n y,\n animated\n });\n };\n this._handleContentOnLayout = e => {\n var _e$nativeEvent$layout = e.nativeEvent.layout,\n width = _e$nativeEvent$layout.width,\n height = _e$nativeEvent$layout.height;\n this.props.onContentSizeChange(width, height);\n };\n this._handleScroll = e => {\n if (process.env.NODE_ENV !== 'production') {\n if (this.props.onScroll && this.props.scrollEventThrottle == null) {\n console.log('You specified `onScroll` on a but not ' + '`scrollEventThrottle`. You will only receive one event. ' + 'Using `16` you get all the events but be aware that it may ' + \"cause frame drops, use a bigger number if you don't need as \" + 'much precision.');\n }\n }\n if (this.props.keyboardDismissMode === 'on-drag') {\n dismissKeyboard();\n }\n this.scrollResponderHandleScroll(e);\n };\n this._setInnerViewRef = node => {\n this._innerViewRef = node;\n };\n this._setScrollNodeRef = node => {\n this._scrollNodeRef = node;\n // ScrollView needs to add more methods to the hostNode in addition to those\n // added by `usePlatformMethods`. This is temporarily until an API like\n // `ScrollView.scrollTo(hostNode, { x, y })` is added to React Native.\n if (node != null) {\n node.getScrollResponder = this.getScrollResponder;\n node.getInnerViewNode = this.getInnerViewNode;\n node.getInnerViewRef = this.getInnerViewRef;\n node.getNativeScrollRef = this.getNativeScrollRef;\n node.getScrollableNode = this.getScrollableNode;\n node.scrollTo = this.scrollTo;\n node.scrollToEnd = this.scrollToEnd;\n node.flashScrollIndicators = this.flashScrollIndicators;\n node.scrollResponderZoomTo = this.scrollResponderZoomTo;\n node.scrollResponderScrollNativeHandleToKeyboard = this.scrollResponderScrollNativeHandleToKeyboard;\n }\n var ref = mergeRefs(this.props.forwardedRef);\n ref(node);\n };\n }\n /**\n * ------------------------------------------------------\n * START SCROLLRESPONDER\n * ------------------------------------------------------\n */\n // Reset to false every time becomes responder. This is used to:\n // - Determine if the scroll view has been scrolled and therefore should\n // refuse to give up its responder lock.\n // - Determine if releasing should dismiss the keyboard when we are in\n // tap-to-dismiss mode (!this.props.keyboardShouldPersistTaps).\n /**\n * Invoke this from an `onScroll` event.\n */\n /**\n * Merely touch starting is not sufficient for a scroll view to become the\n * responder. Being the \"responder\" means that the very next touch move/end\n * event will result in an action/movement.\n *\n * Invoke this from an `onStartShouldSetResponder` event.\n *\n * `onStartShouldSetResponder` is used when the next move/end will trigger\n * some UI movement/action, but when you want to yield priority to views\n * nested inside of the view.\n *\n * There may be some cases where scroll views actually should return `true`\n * from `onStartShouldSetResponder`: Any time we are detecting a standard tap\n * that gives priority to nested views.\n *\n * - If a single tap on the scroll view triggers an action such as\n * recentering a map style view yet wants to give priority to interaction\n * views inside (such as dropped pins or labels), then we would return true\n * from this method when there is a single touch.\n *\n * - Similar to the previous case, if a two finger \"tap\" should trigger a\n * zoom, we would check the `touches` count, and if `>= 2`, we would return\n * true.\n *\n */\n scrollResponderHandleStartShouldSetResponder() {\n return false;\n }\n\n /**\n * There are times when the scroll view wants to become the responder\n * (meaning respond to the next immediate `touchStart/touchEnd`), in a way\n * that *doesn't* give priority to nested views (hence the capture phase):\n *\n * - Currently animating.\n * - Tapping anywhere that is not the focused input, while the keyboard is\n * up (which should dismiss the keyboard).\n *\n * Invoke this from an `onStartShouldSetResponderCapture` event.\n */\n\n /**\n * Invoke this from an `onResponderReject` event.\n *\n * Some other element is not yielding its role as responder. Normally, we'd\n * just disable the `UIScrollView`, but a touch has already began on it, the\n * `UIScrollView` will not accept being disabled after that. The easiest\n * solution for now is to accept the limitation of disallowing this\n * altogether. To improve this, find a way to disable the `UIScrollView` after\n * a touch has already started.\n */\n scrollResponderHandleResponderReject() {\n warning(false, \"ScrollView doesn't take rejection well - scrolls anyway\");\n }\n\n /**\n * We will allow the scroll view to give up its lock iff it acquired the lock\n * during an animation. This is a very useful default that happens to satisfy\n * many common user experiences.\n *\n * - Stop a scroll on the left edge, then turn that into an outer view's\n * backswipe.\n * - Stop a scroll mid-bounce at the top, continue pulling to have the outer\n * view dismiss.\n * - However, without catching the scroll view mid-bounce (while it is\n * motionless), if you drag far enough for the scroll view to become\n * responder (and therefore drag the scroll view a bit), any backswipe\n * navigation of a swipe gesture higher in the view hierarchy, should be\n * rejected.\n */\n\n /**\n * Invoke this from an `onTouchEnd` event.\n *\n * @param {SyntheticEvent} e Event.\n */\n\n /**\n * Invoke this from an `onResponderRelease` event.\n */\n\n /**\n * Invoke this from an `onResponderGrant` event.\n */\n\n /**\n * Unfortunately, `onScrollBeginDrag` also fires when *stopping* the scroll\n * animation, and there's not an easy way to distinguish a drag vs. stopping\n * momentum.\n *\n * Invoke this from an `onScrollBeginDrag` event.\n */\n\n /**\n * Invoke this from an `onScrollEndDrag` event.\n */\n\n /**\n * Invoke this from an `onMomentumScrollBegin` event.\n */\n\n /**\n * Invoke this from an `onMomentumScrollEnd` event.\n */\n\n /**\n * Invoke this from an `onTouchStart` event.\n *\n * Since we know that the `SimpleEventPlugin` occurs later in the plugin\n * order, after `ResponderEventPlugin`, we can detect that we were *not*\n * permitted to be the responder (presumably because a contained view became\n * responder). The `onResponderReject` won't fire in that case - it only\n * fires when a *current* responder rejects our request.\n *\n * @param {SyntheticEvent} e Touch Start event.\n */\n\n /**\n * Invoke this from an `onTouchMove` event.\n *\n * Since we know that the `SimpleEventPlugin` occurs later in the plugin\n * order, after `ResponderEventPlugin`, we can detect that we were *not*\n * permitted to be the responder (presumably because a contained view became\n * responder). The `onResponderReject` won't fire in that case - it only\n * fires when a *current* responder rejects our request.\n *\n * @param {SyntheticEvent} e Touch Start event.\n */\n\n /**\n * A helper function for this class that lets us quickly determine if the\n * view is currently animating. This is particularly useful to know when\n * a touch has just started or ended.\n */\n\n /**\n * A helper function to scroll to a specific point in the scrollview.\n * This is currently used to help focus on child textviews, but can also\n * be used to quickly scroll to any element we want to focus. Syntax:\n *\n * scrollResponderScrollTo(options: {x: number = 0; y: number = 0; animated: boolean = true})\n *\n * Note: The weird argument signature is due to the fact that, for historical reasons,\n * the function also accepts separate arguments as as alternative to the options object.\n * This is deprecated due to ambiguity (y before x), and SHOULD NOT BE USED.\n */\n\n /**\n * A helper function to zoom to a specific rect in the scrollview. The argument has the shape\n * {x: number; y: number; width: number; height: number; animated: boolean = true}\n *\n * @platform ios\n */\n\n /**\n * Displays the scroll indicators momentarily.\n */\n scrollResponderFlashScrollIndicators() {}\n\n /**\n * This method should be used as the callback to onFocus in a TextInputs'\n * parent view. Note that any module using this mixin needs to return\n * the parent view's ref in getScrollViewRef() in order to use this method.\n * @param {any} nodeHandle The TextInput node handle\n * @param {number} additionalOffset The scroll view's top \"contentInset\".\n * Default is 0.\n * @param {bool} preventNegativeScrolling Whether to allow pulling the content\n * down to make it meet the keyboard's top. Default is false.\n */\n\n /**\n * The calculations performed here assume the scroll view takes up the entire\n * screen - even if has some content inset. We then measure the offsets of the\n * keyboard, and compensate both for the scroll view's \"contentInset\".\n *\n * @param {number} left Position of input w.r.t. table view.\n * @param {number} top Position of input w.r.t. table view.\n * @param {number} width Width of the text input.\n * @param {number} height Height of the text input.\n */\n\n scrollResponderTextInputFocusError(e) {\n console.error('Error measuring text field: ', e);\n }\n\n /**\n * Warning, this may be called several times for a single keyboard opening.\n * It's best to store the information in this method and then take any action\n * at a later point (either in `keyboardDidShow` or other).\n *\n * Here's the order that events occur in:\n * - focus\n * - willShow {startCoordinates, endCoordinates} several times\n * - didShow several times\n * - blur\n * - willHide {startCoordinates, endCoordinates} several times\n * - didHide several times\n *\n * The `ScrollResponder` providesModule callbacks for each of these events.\n * Even though any user could have easily listened to keyboard events\n * themselves, using these `props` callbacks ensures that ordering of events\n * is consistent - and not dependent on the order that the keyboard events are\n * subscribed to. This matters when telling the scroll view to scroll to where\n * the keyboard is headed - the scroll responder better have been notified of\n * the keyboard destination before being instructed to scroll to where the\n * keyboard will be. Stick to the `ScrollResponder` callbacks, and everything\n * will work.\n *\n * WARNING: These callbacks will fire even if a keyboard is displayed in a\n * different navigation pane. Filter out the events to determine if they are\n * relevant to you. (For example, only if you receive these callbacks after\n * you had explicitly focused a node etc).\n */\n\n /**\n * ------------------------------------------------------\n * END SCROLLRESPONDER\n * ------------------------------------------------------\n */\n\n /**\n * Returns a reference to the underlying scroll responder, which supports\n * operations like `scrollTo`. All ScrollView-like components should\n * implement this method so that they can be composed while providing access\n * to the underlying scroll responder's methods.\n */\n\n /**\n * Scrolls to a given x, y offset, either immediately or with a smooth animation.\n * Syntax:\n *\n * scrollTo(options: {x: number = 0; y: number = 0; animated: boolean = true})\n *\n * Note: The weird argument signature is due to the fact that, for historical reasons,\n * the function also accepts separate arguments as as alternative to the options object.\n * This is deprecated due to ambiguity (y before x), and SHOULD NOT BE USED.\n */\n\n /**\n * If this is a vertical ScrollView scrolls to the bottom.\n * If this is a horizontal ScrollView scrolls to the right.\n *\n * Use `scrollToEnd({ animated: true })` for smooth animated scrolling,\n * `scrollToEnd({ animated: false })` for immediate scrolling.\n * If no options are passed, `animated` defaults to true.\n */\n\n render() {\n var _this$props = this.props,\n contentContainerStyle = _this$props.contentContainerStyle,\n horizontal = _this$props.horizontal,\n onContentSizeChange = _this$props.onContentSizeChange,\n refreshControl = _this$props.refreshControl,\n stickyHeaderIndices = _this$props.stickyHeaderIndices,\n pagingEnabled = _this$props.pagingEnabled,\n forwardedRef = _this$props.forwardedRef,\n keyboardDismissMode = _this$props.keyboardDismissMode,\n onScroll = _this$props.onScroll,\n centerContent = _this$props.centerContent,\n other = _objectWithoutPropertiesLoose(_this$props, _excluded);\n if (process.env.NODE_ENV !== 'production' && this.props.style) {\n var style = StyleSheet.flatten(this.props.style);\n var childLayoutProps = ['alignItems', 'justifyContent'].filter(prop => style && style[prop] !== undefined);\n invariant(childLayoutProps.length === 0, \"ScrollView child layout (\" + JSON.stringify(childLayoutProps) + \") \" + 'must be applied through the contentContainerStyle prop.');\n }\n var contentSizeChangeProps = {};\n if (onContentSizeChange) {\n contentSizeChangeProps = {\n onLayout: this._handleContentOnLayout\n };\n }\n var hasStickyHeaderIndices = !horizontal && Array.isArray(stickyHeaderIndices);\n var children = hasStickyHeaderIndices || pagingEnabled ? React.Children.map(this.props.children, (child, i) => {\n var isSticky = hasStickyHeaderIndices && stickyHeaderIndices.indexOf(i) > -1;\n if (child != null && (isSticky || pagingEnabled)) {\n return /*#__PURE__*/React.createElement(View, {\n style: [isSticky && styles.stickyHeader, pagingEnabled && styles.pagingEnabledChild]\n }, child);\n } else {\n return child;\n }\n }) : this.props.children;\n var contentContainer = /*#__PURE__*/React.createElement(View, _extends({}, contentSizeChangeProps, {\n children: children,\n collapsable: false,\n ref: this._setInnerViewRef,\n style: [horizontal && styles.contentContainerHorizontal, centerContent && styles.contentContainerCenterContent, contentContainerStyle]\n }));\n var baseStyle = horizontal ? styles.baseHorizontal : styles.baseVertical;\n var pagingEnabledStyle = horizontal ? styles.pagingEnabledHorizontal : styles.pagingEnabledVertical;\n var props = _objectSpread(_objectSpread({}, other), {}, {\n style: [baseStyle, pagingEnabled && pagingEnabledStyle, this.props.style],\n onTouchStart: this.scrollResponderHandleTouchStart,\n onTouchMove: this.scrollResponderHandleTouchMove,\n onTouchEnd: this.scrollResponderHandleTouchEnd,\n onScrollBeginDrag: this.scrollResponderHandleScrollBeginDrag,\n onScrollEndDrag: this.scrollResponderHandleScrollEndDrag,\n onMomentumScrollBegin: this.scrollResponderHandleMomentumScrollBegin,\n onMomentumScrollEnd: this.scrollResponderHandleMomentumScrollEnd,\n onStartShouldSetResponder: this.scrollResponderHandleStartShouldSetResponder,\n onStartShouldSetResponderCapture: this.scrollResponderHandleStartShouldSetResponderCapture,\n onScrollShouldSetResponder: this.scrollResponderHandleScrollShouldSetResponder,\n onScroll: this._handleScroll,\n onResponderGrant: this.scrollResponderHandleResponderGrant,\n onResponderTerminationRequest: this.scrollResponderHandleTerminationRequest,\n onResponderTerminate: this.scrollResponderHandleTerminate,\n onResponderRelease: this.scrollResponderHandleResponderRelease,\n onResponderReject: this.scrollResponderHandleResponderReject\n });\n var ScrollViewClass = ScrollViewBase;\n invariant(ScrollViewClass !== undefined, 'ScrollViewClass must not be undefined');\n var scrollView = /*#__PURE__*/React.createElement(ScrollViewClass, _extends({}, props, {\n ref: this._setScrollNodeRef\n }), contentContainer);\n if (refreshControl) {\n return /*#__PURE__*/React.cloneElement(refreshControl, {\n style: props.style\n }, scrollView);\n }\n return scrollView;\n }\n}\nvar commonStyle = {\n flexGrow: 1,\n flexShrink: 1,\n // Enable hardware compositing in modern browsers.\n // Creates a new layer with its own backing surface that can significantly\n // improve scroll performance.\n transform: 'translateZ(0)',\n // iOS native scrolling\n WebkitOverflowScrolling: 'touch'\n};\nvar styles = StyleSheet.create({\n baseVertical: _objectSpread(_objectSpread({}, commonStyle), {}, {\n flexDirection: 'column',\n overflowX: 'hidden',\n overflowY: 'auto'\n }),\n baseHorizontal: _objectSpread(_objectSpread({}, commonStyle), {}, {\n flexDirection: 'row',\n overflowX: 'auto',\n overflowY: 'hidden'\n }),\n contentContainerHorizontal: {\n flexDirection: 'row'\n },\n contentContainerCenterContent: {\n justifyContent: 'center',\n flexGrow: 1\n },\n stickyHeader: {\n position: 'sticky',\n top: 0,\n zIndex: 10\n },\n pagingEnabledHorizontal: {\n scrollSnapType: 'x mandatory'\n },\n pagingEnabledVertical: {\n scrollSnapType: 'y mandatory'\n },\n pagingEnabledChild: {\n scrollSnapAlign: 'start'\n }\n});\nvar ForwardedScrollView = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n return /*#__PURE__*/React.createElement(ScrollView, _extends({}, props, {\n forwardedRef: forwardedRef\n }));\n});\nForwardedScrollView.displayName = 'ScrollView';\nexport default ForwardedScrollView;","function _extends() {\n module.exports = _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _extends.apply(this, arguments);\n}\nmodule.exports = _extends, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport TextInputState from '../TextInputState';\nvar dismissKeyboard = () => {\n TextInputState.blurTextInput(TextInputState.currentlyFocusedField());\n};\nexport default dismissKeyboard;","import _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"onScroll\", \"onTouchMove\", \"onWheel\", \"scrollEnabled\", \"scrollEventThrottle\", \"showsHorizontalScrollIndicator\", \"showsVerticalScrollIndicator\", \"style\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport StyleSheet from '../StyleSheet';\nimport View from '../View';\nimport useMergeRefs from '../../modules/useMergeRefs';\nfunction normalizeScrollEvent(e) {\n return {\n nativeEvent: {\n contentOffset: {\n get x() {\n return e.target.scrollLeft;\n },\n get y() {\n return e.target.scrollTop;\n }\n },\n contentSize: {\n get height() {\n return e.target.scrollHeight;\n },\n get width() {\n return e.target.scrollWidth;\n }\n },\n layoutMeasurement: {\n get height() {\n return e.target.offsetHeight;\n },\n get width() {\n return e.target.offsetWidth;\n }\n }\n },\n timeStamp: Date.now()\n };\n}\nfunction shouldEmitScrollEvent(lastTick, eventThrottle) {\n var timeSinceLastTick = Date.now() - lastTick;\n return eventThrottle > 0 && timeSinceLastTick >= eventThrottle;\n}\n\n/**\n * Encapsulates the Web-specific scroll throttling and disabling logic\n */\nvar ScrollViewBase = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var onScroll = props.onScroll,\n onTouchMove = props.onTouchMove,\n onWheel = props.onWheel,\n _props$scrollEnabled = props.scrollEnabled,\n scrollEnabled = _props$scrollEnabled === void 0 ? true : _props$scrollEnabled,\n _props$scrollEventThr = props.scrollEventThrottle,\n scrollEventThrottle = _props$scrollEventThr === void 0 ? 0 : _props$scrollEventThr,\n showsHorizontalScrollIndicator = props.showsHorizontalScrollIndicator,\n showsVerticalScrollIndicator = props.showsVerticalScrollIndicator,\n style = props.style,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n var scrollState = React.useRef({\n isScrolling: false,\n scrollLastTick: 0\n });\n var scrollTimeout = React.useRef(null);\n var scrollRef = React.useRef(null);\n function createPreventableScrollHandler(handler) {\n return e => {\n if (scrollEnabled) {\n if (handler) {\n handler(e);\n }\n }\n };\n }\n function handleScroll(e) {\n e.stopPropagation();\n if (e.target === scrollRef.current) {\n e.persist();\n // A scroll happened, so the scroll resets the scrollend timeout.\n if (scrollTimeout.current != null) {\n clearTimeout(scrollTimeout.current);\n }\n scrollTimeout.current = setTimeout(() => {\n handleScrollEnd(e);\n }, 100);\n if (scrollState.current.isScrolling) {\n // Scroll last tick may have changed, check if we need to notify\n if (shouldEmitScrollEvent(scrollState.current.scrollLastTick, scrollEventThrottle)) {\n handleScrollTick(e);\n }\n } else {\n // Weren't scrolling, so we must have just started\n handleScrollStart(e);\n }\n }\n }\n function handleScrollStart(e) {\n scrollState.current.isScrolling = true;\n handleScrollTick(e);\n }\n function handleScrollTick(e) {\n scrollState.current.scrollLastTick = Date.now();\n if (onScroll) {\n onScroll(normalizeScrollEvent(e));\n }\n }\n function handleScrollEnd(e) {\n scrollState.current.isScrolling = false;\n if (onScroll) {\n onScroll(normalizeScrollEvent(e));\n }\n }\n var hideScrollbar = showsHorizontalScrollIndicator === false || showsVerticalScrollIndicator === false;\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, {\n onScroll: handleScroll,\n onTouchMove: createPreventableScrollHandler(onTouchMove),\n onWheel: createPreventableScrollHandler(onWheel),\n ref: useMergeRefs(scrollRef, forwardedRef),\n style: [style, !scrollEnabled && styles.scrollDisabled, hideScrollbar && styles.hideScrollbar]\n }));\n});\n\n// Chrome doesn't support e.preventDefault in this case; touch-action must be\n// used to disable scrolling.\n// https://developers.google.com/web/updates/2017/01/scrolling-intervention\nvar styles = StyleSheet.create({\n scrollDisabled: {\n overflowX: 'hidden',\n overflowY: 'hidden',\n touchAction: 'none'\n },\n hideScrollbar: {\n scrollbarWidth: 'none'\n }\n});\nexport default ScrollViewBase;","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n'use strict';\n\nvar emptyFunction = require(\"./emptyFunction\");\n/**\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\n\n\nfunction printWarning(format) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n var argIndex = 0;\n var message = 'Warning: ' + format.replace(/%s/g, function () {\n return args[argIndex++];\n });\n\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n}\n\nvar warning = process.env.NODE_ENV !== \"production\" ? function (condition, format) {\n if (format === undefined) {\n throw new Error('`warning(condition, format, ...args)` requires a warning ' + 'message argument');\n }\n\n if (!condition) {\n for (var _len2 = arguments.length, args = new Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) {\n args[_key2 - 2] = arguments[_key2];\n }\n\n printWarning.apply(void 0, [format].concat(args));\n }\n} : emptyFunction;\nmodule.exports = warning;","\"use strict\";\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\nfunction makeEmptyFunction(arg) {\n return function () {\n return arg;\n };\n}\n/**\n * This function accepts and discards inputs; it has no side effects. This is\n * primarily useful idiomatically for overridable function endpoints which\n * always need to be callable, since JS lacks a null-call idiom ala Cocoa.\n */\n\n\nvar emptyFunction = function emptyFunction() {};\n\nemptyFunction.thatReturns = makeEmptyFunction;\nemptyFunction.thatReturnsFalse = makeEmptyFunction(false);\nemptyFunction.thatReturnsTrue = makeEmptyFunction(true);\nemptyFunction.thatReturnsNull = makeEmptyFunction(null);\n\nemptyFunction.thatReturnsThis = function () {\n return this;\n};\n\nemptyFunction.thatReturnsArgument = function (arg) {\n return arg;\n};\n\nmodule.exports = emptyFunction;","'use strict';\n\nimport { Image } from 'react-native';\nimport { createAnimatedComponent } from '../../createAnimatedComponent';\n\n// Since createAnimatedComponent return type is ComponentClass that has the props of the argument,\n// but not things like NativeMethods, etc. we need to add them manually by extending the type.\n\nexport const AnimatedImage = createAnimatedComponent(Image);\n//# sourceMappingURL=Image.js.map","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"aria-label\", \"accessibilityLabel\", \"blurRadius\", \"defaultSource\", \"draggable\", \"onError\", \"onLayout\", \"onLoad\", \"onLoadEnd\", \"onLoadStart\", \"pointerEvents\", \"source\", \"style\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport createElement from '../createElement';\nimport { getAssetByID } from '../../modules/AssetRegistry';\nimport { createBoxShadowValue } from '../StyleSheet/preprocess';\nimport ImageLoader from '../../modules/ImageLoader';\nimport PixelRatio from '../PixelRatio';\nimport StyleSheet from '../StyleSheet';\nimport TextAncestorContext from '../Text/TextAncestorContext';\nimport View from '../View';\nimport { warnOnce } from '../../modules/warnOnce';\nvar ERRORED = 'ERRORED';\nvar LOADED = 'LOADED';\nvar LOADING = 'LOADING';\nvar IDLE = 'IDLE';\nvar _filterId = 0;\nvar svgDataUriPattern = /^(data:image\\/svg\\+xml;utf8,)(.*)/;\nfunction createTintColorSVG(tintColor, id) {\n return tintColor && id != null ? /*#__PURE__*/React.createElement(\"svg\", {\n style: {\n position: 'absolute',\n height: 0,\n visibility: 'hidden',\n width: 0\n }\n }, /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"filter\", {\n id: \"tint-\" + id,\n suppressHydrationWarning: true\n }, /*#__PURE__*/React.createElement(\"feFlood\", {\n floodColor: \"\" + tintColor,\n key: tintColor\n }), /*#__PURE__*/React.createElement(\"feComposite\", {\n in2: \"SourceAlpha\",\n operator: \"atop\"\n })))) : null;\n}\nfunction extractNonStandardStyleProps(style, blurRadius, filterId, tintColorProp) {\n var flatStyle = StyleSheet.flatten(style);\n var filter = flatStyle.filter,\n resizeMode = flatStyle.resizeMode,\n shadowOffset = flatStyle.shadowOffset,\n tintColor = flatStyle.tintColor;\n if (flatStyle.resizeMode) {\n warnOnce('Image.style.resizeMode', 'Image: style.resizeMode is deprecated. Please use props.resizeMode.');\n }\n if (flatStyle.tintColor) {\n warnOnce('Image.style.tintColor', 'Image: style.tintColor is deprecated. Please use props.tintColor.');\n }\n\n // Add CSS filters\n // React Native exposes these features as props and proprietary styles\n var filters = [];\n var _filter = null;\n if (filter) {\n filters.push(filter);\n }\n if (blurRadius) {\n filters.push(\"blur(\" + blurRadius + \"px)\");\n }\n if (shadowOffset) {\n var shadowString = createBoxShadowValue(flatStyle);\n if (shadowString) {\n filters.push(\"drop-shadow(\" + shadowString + \")\");\n }\n }\n if ((tintColorProp || tintColor) && filterId != null) {\n filters.push(\"url(#tint-\" + filterId + \")\");\n }\n if (filters.length > 0) {\n _filter = filters.join(' ');\n }\n return [resizeMode, _filter, tintColor];\n}\nfunction resolveAssetDimensions(source) {\n if (typeof source === 'number') {\n var _getAssetByID = getAssetByID(source),\n _height = _getAssetByID.height,\n _width = _getAssetByID.width;\n return {\n height: _height,\n width: _width\n };\n } else if (source != null && !Array.isArray(source) && typeof source === 'object') {\n var _height2 = source.height,\n _width2 = source.width;\n return {\n height: _height2,\n width: _width2\n };\n }\n}\nfunction resolveAssetUri(source) {\n var uri = null;\n if (typeof source === 'number') {\n // get the URI from the packager\n var asset = getAssetByID(source);\n if (asset == null) {\n throw new Error(\"Image: asset with ID \\\"\" + source + \"\\\" could not be found. Please check the image source or packager.\");\n }\n var scale = asset.scales[0];\n if (asset.scales.length > 1) {\n var preferredScale = PixelRatio.get();\n // Get the scale which is closest to the preferred scale\n scale = asset.scales.reduce((prev, curr) => Math.abs(curr - preferredScale) < Math.abs(prev - preferredScale) ? curr : prev);\n }\n var scaleSuffix = scale !== 1 ? \"@\" + scale + \"x\" : '';\n uri = asset ? asset.httpServerLocation + \"/\" + asset.name + scaleSuffix + \".\" + asset.type : '';\n } else if (typeof source === 'string') {\n uri = source;\n } else if (source && typeof source.uri === 'string') {\n uri = source.uri;\n }\n if (uri) {\n var match = uri.match(svgDataUriPattern);\n // inline SVG markup may contain characters (e.g., #, \") that need to be escaped\n if (match) {\n var prefix = match[1],\n svg = match[2];\n var encodedSvg = encodeURIComponent(svg);\n return \"\" + prefix + encodedSvg;\n }\n }\n return uri;\n}\nvar Image = /*#__PURE__*/React.forwardRef((props, ref) => {\n var _ariaLabel = props['aria-label'],\n accessibilityLabel = props.accessibilityLabel,\n blurRadius = props.blurRadius,\n defaultSource = props.defaultSource,\n draggable = props.draggable,\n onError = props.onError,\n onLayout = props.onLayout,\n onLoad = props.onLoad,\n onLoadEnd = props.onLoadEnd,\n onLoadStart = props.onLoadStart,\n pointerEvents = props.pointerEvents,\n source = props.source,\n style = props.style,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n var ariaLabel = _ariaLabel || accessibilityLabel;\n if (process.env.NODE_ENV !== 'production') {\n if (props.children) {\n throw new Error('The component cannot contain children. If you want to render content on top of the image, consider using the component or absolute positioning.');\n }\n }\n var _React$useState = React.useState(() => {\n var uri = resolveAssetUri(source);\n if (uri != null) {\n var isLoaded = ImageLoader.has(uri);\n if (isLoaded) {\n return LOADED;\n }\n }\n return IDLE;\n }),\n state = _React$useState[0],\n updateState = _React$useState[1];\n var _React$useState2 = React.useState({}),\n layout = _React$useState2[0],\n updateLayout = _React$useState2[1];\n var hasTextAncestor = React.useContext(TextAncestorContext);\n var hiddenImageRef = React.useRef(null);\n var filterRef = React.useRef(_filterId++);\n var requestRef = React.useRef(null);\n var shouldDisplaySource = state === LOADED || state === LOADING && defaultSource == null;\n var _extractNonStandardSt = extractNonStandardStyleProps(style, blurRadius, filterRef.current, props.tintColor),\n _resizeMode = _extractNonStandardSt[0],\n filter = _extractNonStandardSt[1],\n _tintColor = _extractNonStandardSt[2];\n var resizeMode = props.resizeMode || _resizeMode || 'cover';\n var tintColor = props.tintColor || _tintColor;\n var selectedSource = shouldDisplaySource ? source : defaultSource;\n var displayImageUri = resolveAssetUri(selectedSource);\n var imageSizeStyle = resolveAssetDimensions(selectedSource);\n var backgroundImage = displayImageUri ? \"url(\\\"\" + displayImageUri + \"\\\")\" : null;\n var backgroundSize = getBackgroundSize();\n\n // Accessibility image allows users to trigger the browser's image context menu\n var hiddenImage = displayImageUri ? createElement('img', {\n alt: ariaLabel || '',\n style: styles.accessibilityImage$raw,\n draggable: draggable || false,\n ref: hiddenImageRef,\n src: displayImageUri\n }) : null;\n function getBackgroundSize() {\n if (hiddenImageRef.current != null && (resizeMode === 'center' || resizeMode === 'repeat')) {\n var _hiddenImageRef$curre = hiddenImageRef.current,\n naturalHeight = _hiddenImageRef$curre.naturalHeight,\n naturalWidth = _hiddenImageRef$curre.naturalWidth;\n var _height3 = layout.height,\n _width3 = layout.width;\n if (naturalHeight && naturalWidth && _height3 && _width3) {\n var scaleFactor = Math.min(1, _width3 / naturalWidth, _height3 / naturalHeight);\n var x = Math.ceil(scaleFactor * naturalWidth);\n var y = Math.ceil(scaleFactor * naturalHeight);\n return x + \"px \" + y + \"px\";\n }\n }\n }\n function handleLayout(e) {\n if (resizeMode === 'center' || resizeMode === 'repeat' || onLayout) {\n var _layout = e.nativeEvent.layout;\n onLayout && onLayout(e);\n updateLayout(_layout);\n }\n }\n\n // Image loading\n var uri = resolveAssetUri(source);\n React.useEffect(() => {\n abortPendingRequest();\n if (uri != null) {\n updateState(LOADING);\n if (onLoadStart) {\n onLoadStart();\n }\n requestRef.current = ImageLoader.load(uri, function load(e) {\n updateState(LOADED);\n if (onLoad) {\n onLoad(e);\n }\n if (onLoadEnd) {\n onLoadEnd();\n }\n }, function error() {\n updateState(ERRORED);\n if (onError) {\n onError({\n nativeEvent: {\n error: \"Failed to load resource \" + uri + \" (404)\"\n }\n });\n }\n if (onLoadEnd) {\n onLoadEnd();\n }\n });\n }\n function abortPendingRequest() {\n if (requestRef.current != null) {\n ImageLoader.abort(requestRef.current);\n requestRef.current = null;\n }\n }\n return abortPendingRequest;\n }, [uri, requestRef, updateState, onError, onLoad, onLoadEnd, onLoadStart]);\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, {\n \"aria-label\": ariaLabel,\n onLayout: handleLayout,\n pointerEvents: pointerEvents,\n ref: ref,\n style: [styles.root, hasTextAncestor && styles.inline, imageSizeStyle, style, styles.undo,\n // TEMP: avoid deprecated shadow props regression\n // until Image refactored to use createElement.\n {\n boxShadow: null\n }]\n }), /*#__PURE__*/React.createElement(View, {\n style: [styles.image, resizeModeStyles[resizeMode], {\n backgroundImage,\n filter\n }, backgroundSize != null && {\n backgroundSize\n }],\n suppressHydrationWarning: true\n }), hiddenImage, createTintColorSVG(tintColor, filterRef.current));\n});\nImage.displayName = 'Image';\n\n// $FlowIgnore: This is the correct type, but casting makes it unhappy since the variables aren't defined yet\nvar ImageWithStatics = Image;\nImageWithStatics.getSize = function (uri, success, failure) {\n ImageLoader.getSize(uri, success, failure);\n};\nImageWithStatics.prefetch = function (uri) {\n return ImageLoader.prefetch(uri);\n};\nImageWithStatics.queryCache = function (uris) {\n return ImageLoader.queryCache(uris);\n};\nvar styles = StyleSheet.create({\n root: {\n flexBasis: 'auto',\n overflow: 'hidden',\n zIndex: 0\n },\n inline: {\n display: 'inline-flex'\n },\n undo: {\n // These styles are converted to CSS filters applied to the\n // element displaying the background image.\n blurRadius: null,\n shadowColor: null,\n shadowOpacity: null,\n shadowOffset: null,\n shadowRadius: null,\n tintColor: null,\n // These styles are not supported\n overlayColor: null,\n resizeMode: null\n },\n image: _objectSpread(_objectSpread({}, StyleSheet.absoluteFillObject), {}, {\n backgroundColor: 'transparent',\n backgroundPosition: 'center',\n backgroundRepeat: 'no-repeat',\n backgroundSize: 'cover',\n height: '100%',\n width: '100%',\n zIndex: -1\n }),\n accessibilityImage$raw: _objectSpread(_objectSpread({}, StyleSheet.absoluteFillObject), {}, {\n height: '100%',\n opacity: 0,\n width: '100%',\n zIndex: -1\n })\n});\nvar resizeModeStyles = StyleSheet.create({\n center: {\n backgroundSize: 'auto'\n },\n contain: {\n backgroundSize: 'contain'\n },\n cover: {\n backgroundSize: 'cover'\n },\n none: {\n backgroundPosition: '0',\n backgroundSize: 'auto'\n },\n repeat: {\n backgroundPosition: '0',\n backgroundRepeat: 'repeat',\n backgroundSize: 'auto'\n },\n stretch: {\n backgroundSize: '100% 100%'\n }\n});\nexport default ImageWithStatics;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @flow strict\n * @format\n */\n\n'use strict';\n\nexport type PackagerAsset = {\n +__packager_asset: boolean,\n +fileSystemLocation: string,\n +httpServerLocation: string,\n +width: ?number,\n +height: ?number,\n +scales: Array,\n +hash: string,\n +name: string,\n +type: string,\n ...\n};\n\nconst assets: Array = [];\n\nfunction registerAsset(asset: PackagerAsset): number {\n // `push` returns new array length, so the first asset will\n // get id 1 (not 0) to make the value truthy\n return assets.push(asset);\n}\n\nfunction getAssetByID(assetId: number): PackagerAsset {\n return assets[assetId - 1];\n}\n\nmodule.exports = {registerAsset, getAssetByID};\n","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar dataUriPattern = /^data:/;\nexport class ImageUriCache {\n static has(uri) {\n var entries = ImageUriCache._entries;\n var isDataUri = dataUriPattern.test(uri);\n return isDataUri || Boolean(entries[uri]);\n }\n static add(uri) {\n var entries = ImageUriCache._entries;\n var lastUsedTimestamp = Date.now();\n if (entries[uri]) {\n entries[uri].lastUsedTimestamp = lastUsedTimestamp;\n entries[uri].refCount += 1;\n } else {\n entries[uri] = {\n lastUsedTimestamp,\n refCount: 1\n };\n }\n }\n static remove(uri) {\n var entries = ImageUriCache._entries;\n if (entries[uri]) {\n entries[uri].refCount -= 1;\n }\n // Free up entries when the cache is \"full\"\n ImageUriCache._cleanUpIfNeeded();\n }\n static _cleanUpIfNeeded() {\n var entries = ImageUriCache._entries;\n var imageUris = Object.keys(entries);\n if (imageUris.length + 1 > ImageUriCache._maximumEntries) {\n var leastRecentlyUsedKey;\n var leastRecentlyUsedEntry;\n imageUris.forEach(uri => {\n var entry = entries[uri];\n if ((!leastRecentlyUsedEntry || entry.lastUsedTimestamp < leastRecentlyUsedEntry.lastUsedTimestamp) && entry.refCount === 0) {\n leastRecentlyUsedKey = uri;\n leastRecentlyUsedEntry = entry;\n }\n });\n if (leastRecentlyUsedKey) {\n delete entries[leastRecentlyUsedKey];\n }\n }\n }\n}\nImageUriCache._maximumEntries = 256;\nImageUriCache._entries = {};\nvar id = 0;\nvar requests = {};\nvar ImageLoader = {\n abort(requestId) {\n var image = requests[\"\" + requestId];\n if (image) {\n image.onerror = null;\n image.onload = null;\n image = null;\n delete requests[\"\" + requestId];\n }\n },\n getSize(uri, success, failure) {\n var complete = false;\n var interval = setInterval(callback, 16);\n var requestId = ImageLoader.load(uri, callback, errorCallback);\n function callback() {\n var image = requests[\"\" + requestId];\n if (image) {\n var naturalHeight = image.naturalHeight,\n naturalWidth = image.naturalWidth;\n if (naturalHeight && naturalWidth) {\n success(naturalWidth, naturalHeight);\n complete = true;\n }\n }\n if (complete) {\n ImageLoader.abort(requestId);\n clearInterval(interval);\n }\n }\n function errorCallback() {\n if (typeof failure === 'function') {\n failure();\n }\n ImageLoader.abort(requestId);\n clearInterval(interval);\n }\n },\n has(uri) {\n return ImageUriCache.has(uri);\n },\n load(uri, onLoad, onError) {\n id += 1;\n var image = new window.Image();\n image.onerror = onError;\n image.onload = e => {\n // avoid blocking the main thread\n var onDecode = () => onLoad({\n nativeEvent: e\n });\n if (typeof image.decode === 'function') {\n // Safari currently throws exceptions when decoding svgs.\n // We want to catch that error and allow the load handler\n // to be forwarded to the onLoad handler in this case\n image.decode().then(onDecode, onDecode);\n } else {\n setTimeout(onDecode, 0);\n }\n };\n image.src = uri;\n requests[\"\" + id] = image;\n return id;\n },\n prefetch(uri) {\n return new Promise((resolve, reject) => {\n ImageLoader.load(uri, () => {\n // Add the uri to the cache so it can be immediately displayed when used\n // but also immediately remove it to correctly reflect that it has no active references\n ImageUriCache.add(uri);\n ImageUriCache.remove(uri);\n resolve();\n }, reject);\n });\n },\n queryCache(uris) {\n var result = {};\n uris.forEach(u => {\n if (ImageUriCache.has(u)) {\n result[u] = 'disk/memory';\n }\n });\n return Promise.resolve(result);\n }\n};\nexport default ImageLoader;","'use strict';\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport React, { forwardRef, useRef } from 'react';\nimport { FlatList } from 'react-native';\nimport { AnimatedView } from './View';\nimport { createAnimatedComponent } from '../../createAnimatedComponent';\nimport { LayoutAnimationConfig } from './LayoutAnimationConfig';\nconst AnimatedFlatList = createAnimatedComponent(FlatList);\nconst createCellRendererComponent = itemLayoutAnimationRef => {\n const CellRendererComponent = props => {\n return /*#__PURE__*/React.createElement(AnimatedView\n // TODO TYPESCRIPT This is temporary cast is to get rid of .d.ts file.\n , {\n layout: itemLayoutAnimationRef === null || itemLayoutAnimationRef === void 0 ? void 0 : itemLayoutAnimationRef.current,\n onLayout: props.onLayout,\n style: props.style\n }, props.children);\n };\n return CellRendererComponent;\n};\n\n// Since createAnimatedComponent return type is ComponentClass that has the props of the argument,\n// but not things like NativeMethods, etc. we need to add them manually by extending the type.\n\n// We need explicit any here, because this is the exact same type that is used in React Native types.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst FlatListForwardRefRender = function (props, ref) {\n const {\n itemLayoutAnimation,\n skipEnteringExitingAnimations,\n ...restProps\n } = props;\n\n // Set default scrollEventThrottle, because user expects\n // to have continuous scroll events and\n // react-native defaults it to 50 for FlatLists.\n // We set it to 1, so we have peace until\n // there are 960 fps screens.\n if (!('scrollEventThrottle' in restProps)) {\n restProps.scrollEventThrottle = 1;\n }\n const itemLayoutAnimationRef = useRef(itemLayoutAnimation);\n itemLayoutAnimationRef.current = itemLayoutAnimation;\n const CellRendererComponent = React.useMemo(() => createCellRendererComponent(itemLayoutAnimationRef), [itemLayoutAnimationRef]);\n const animatedFlatList =\n /*#__PURE__*/\n // @ts-expect-error In its current type state, createAnimatedComponent cannot create generic components.\n React.createElement(AnimatedFlatList, _extends({\n ref: ref\n }, restProps, {\n CellRendererComponent: CellRendererComponent\n }));\n if (skipEnteringExitingAnimations === undefined) {\n return animatedFlatList;\n }\n return /*#__PURE__*/React.createElement(LayoutAnimationConfig, {\n skipEntering: true,\n skipExiting: true\n }, animatedFlatList);\n};\nexport const ReanimatedFlatList = /*#__PURE__*/forwardRef(FlatListForwardRefRender);\n//# sourceMappingURL=FlatList.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport FlatList from '../../vendor/react-native/FlatList';\nexport default FlatList;","import _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nvar _excluded = [\"numColumns\", \"columnWrapperStyle\", \"removeClippedSubviews\", \"strictMode\"];\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport View from '../../../exports/View';\nimport StyleSheet from '../../../exports/StyleSheet';\nimport deepDiffer from '../deepDiffer';\nimport Platform from '../../../exports/Platform';\nimport invariant from 'fbjs/lib/invariant';\nimport * as React from 'react';\nimport VirtualizedList from '../VirtualizedList';\nimport { keyExtractor as defaultKeyExtractor } from '../VirtualizeUtils';\nimport memoizeOne from 'memoize-one';\n/**\n * Default Props Helper Functions\n * Use the following helper functions for default values\n */ // removeClippedSubviewsOrDefault(this.props.removeClippedSubviews)\nfunction removeClippedSubviewsOrDefault(removeClippedSubviews) {\n return removeClippedSubviews !== null && removeClippedSubviews !== void 0 ? removeClippedSubviews : Platform.OS === 'android';\n}\n\n// numColumnsOrDefault(this.props.numColumns)\nfunction numColumnsOrDefault(numColumns) {\n return numColumns !== null && numColumns !== void 0 ? numColumns : 1;\n}\nfunction isArrayLike(data) {\n // $FlowExpectedError[incompatible-use]\n return typeof Object(data).length === 'number';\n}\n/**\n * A performant interface for rendering simple, flat lists, supporting the most handy features:\n *\n * - Fully cross-platform.\n * - Optional horizontal mode.\n * - Configurable viewability callbacks.\n * - Header support.\n * - Footer support.\n * - Separator support.\n * - Pull to Refresh.\n * - Scroll loading.\n * - ScrollToIndex support.\n *\n * If you need section support, use [``](docs/sectionlist.html).\n *\n * Minimal Example:\n *\n * {item.key}}\n * />\n *\n * More complex, multi-select example demonstrating `PureComponent` usage for perf optimization and avoiding bugs.\n *\n * - By binding the `onPressItem` handler, the props will remain `===` and `PureComponent` will\n * prevent wasteful re-renders unless the actual `id`, `selected`, or `title` props change, even\n * if the components rendered in `MyListItem` did not have such optimizations.\n * - By passing `extraData={this.state}` to `FlatList` we make sure `FlatList` itself will re-render\n * when the `state.selected` changes. Without setting this prop, `FlatList` would not know it\n * needs to re-render any items because it is also a `PureComponent` and the prop comparison will\n * not show any changes.\n * - `keyExtractor` tells the list to use the `id`s for the react keys instead of the default `key` property.\n *\n *\n * class MyListItem extends React.PureComponent {\n * _onPress = () => {\n * this.props.onPressItem(this.props.id);\n * };\n *\n * render() {\n * const textColor = this.props.selected ? \"red\" : \"black\";\n * return (\n * \n * \n * \n * {this.props.title}\n * \n * \n * \n * );\n * }\n * }\n *\n * class MultiSelectList extends React.PureComponent {\n * state = {selected: (new Map(): Map)};\n *\n * _keyExtractor = (item, index) => item.id;\n *\n * _onPressItem = (id: string) => {\n * // updater functions are preferred for transactional updates\n * this.setState((state) => {\n * // copy the map rather than modifying state.\n * const selected = new Map(state.selected);\n * selected.set(id, !selected.get(id)); // toggle\n * return {selected};\n * });\n * };\n *\n * _renderItem = ({item}) => (\n * \n * );\n *\n * render() {\n * return (\n * \n * );\n * }\n * }\n *\n * This is a convenience wrapper around [``](docs/virtualizedlist.html),\n * and thus inherits its props (as well as those of `ScrollView`) that aren't explicitly listed\n * here, along with the following caveats:\n *\n * - Internal state is not preserved when content scrolls out of the render window. Make sure all\n * your data is captured in the item data or external stores like Flux, Redux, or Relay.\n * - This is a `PureComponent` which means that it will not re-render if `props` remain shallow-\n * equal. Make sure that everything your `renderItem` function depends on is passed as a prop\n * (e.g. `extraData`) that is not `===` after updates, otherwise your UI may not update on\n * changes. This includes the `data` prop and parent component state.\n * - In order to constrain memory and enable smooth scrolling, content is rendered asynchronously\n * offscreen. This means it's possible to scroll faster than the fill rate ands momentarily see\n * blank content. This is a tradeoff that can be adjusted to suit the needs of each application,\n * and we are working on improving it behind the scenes.\n * - By default, the list looks for a `key` prop on each item and uses that for the React key.\n * Alternatively, you can provide a custom `keyExtractor` prop.\n *\n * Also inherits [ScrollView Props](docs/scrollview.html#props), unless it is nested in another FlatList of same orientation.\n */\nclass FlatList extends React.PureComponent {\n /**\n * Scrolls to the end of the content. May be janky without `getItemLayout` prop.\n */\n scrollToEnd(params) {\n if (this._listRef) {\n this._listRef.scrollToEnd(params);\n }\n }\n\n /**\n * Scrolls to the item at the specified index such that it is positioned in the viewable area\n * such that `viewPosition` 0 places it at the top, 1 at the bottom, and 0.5 centered in the\n * middle. `viewOffset` is a fixed number of pixels to offset the final target position.\n *\n * Note: cannot scroll to locations outside the render window without specifying the\n * `getItemLayout` prop.\n */\n scrollToIndex(params) {\n if (this._listRef) {\n this._listRef.scrollToIndex(params);\n }\n }\n\n /**\n * Requires linear scan through data - use `scrollToIndex` instead if possible.\n *\n * Note: cannot scroll to locations outside the render window without specifying the\n * `getItemLayout` prop.\n */\n scrollToItem(params) {\n if (this._listRef) {\n this._listRef.scrollToItem(params);\n }\n }\n\n /**\n * Scroll to a specific content pixel offset in the list.\n *\n * Check out [scrollToOffset](docs/virtualizedlist.html#scrolltooffset) of VirtualizedList\n */\n scrollToOffset(params) {\n if (this._listRef) {\n this._listRef.scrollToOffset(params);\n }\n }\n\n /**\n * Tells the list an interaction has occurred, which should trigger viewability calculations, e.g.\n * if `waitForInteractions` is true and the user has not scrolled. This is typically called by\n * taps on items or by navigation actions.\n */\n recordInteraction() {\n if (this._listRef) {\n this._listRef.recordInteraction();\n }\n }\n\n /**\n * Displays the scroll indicators momentarily.\n *\n * @platform ios\n */\n flashScrollIndicators() {\n if (this._listRef) {\n this._listRef.flashScrollIndicators();\n }\n }\n\n /**\n * Provides a handle to the underlying scroll responder.\n */\n getScrollResponder() {\n if (this._listRef) {\n return this._listRef.getScrollResponder();\n }\n }\n\n /**\n * Provides a reference to the underlying host component\n */\n getNativeScrollRef() {\n if (this._listRef) {\n /* $FlowFixMe[incompatible-return] Suppresses errors found when fixing\n * TextInput typing */\n return this._listRef.getScrollRef();\n }\n }\n getScrollableNode() {\n if (this._listRef) {\n return this._listRef.getScrollableNode();\n }\n }\n constructor(_props) {\n super(_props);\n this._virtualizedListPairs = [];\n this._captureRef = ref => {\n this._listRef = ref;\n };\n this._getItem = (data, index) => {\n var numColumns = numColumnsOrDefault(this.props.numColumns);\n if (numColumns > 1) {\n var ret = [];\n for (var kk = 0; kk < numColumns; kk++) {\n var itemIndex = index * numColumns + kk;\n if (itemIndex < data.length) {\n var _item = data[itemIndex];\n ret.push(_item);\n }\n }\n return ret;\n } else {\n return data[index];\n }\n };\n this._getItemCount = data => {\n // Legacy behavior of FlatList was to forward \"undefined\" length if invalid\n // data like a non-arraylike object is passed. VirtualizedList would then\n // coerce this, and the math would work out to no-op. For compatibility, if\n // invalid data is passed, we tell VirtualizedList there are zero items\n // available to prevent it from trying to read from the invalid data\n // (without propagating invalidly typed data).\n if (data != null && isArrayLike(data)) {\n var numColumns = numColumnsOrDefault(this.props.numColumns);\n return numColumns > 1 ? Math.ceil(data.length / numColumns) : data.length;\n } else {\n return 0;\n }\n };\n this._keyExtractor = (items, index) => {\n var _this$props$keyExtrac;\n var numColumns = numColumnsOrDefault(this.props.numColumns);\n var keyExtractor = (_this$props$keyExtrac = this.props.keyExtractor) !== null && _this$props$keyExtrac !== void 0 ? _this$props$keyExtrac : defaultKeyExtractor;\n if (numColumns > 1) {\n invariant(Array.isArray(items), 'FlatList: Encountered internal consistency error, expected each item to consist of an ' + 'array with 1-%s columns; instead, received a single item.', numColumns);\n return items.map((item, kk) => keyExtractor(item, index * numColumns + kk)).join(':');\n }\n\n // $FlowFixMe[incompatible-call] Can't call keyExtractor with an array\n return keyExtractor(items, index);\n };\n this._renderer = (ListItemComponent, renderItem, columnWrapperStyle, numColumns, extraData\n // $FlowFixMe[missing-local-annot]\n ) => {\n var cols = numColumnsOrDefault(numColumns);\n var render = props => {\n if (ListItemComponent) {\n // $FlowFixMe[not-a-component] Component isn't valid\n // $FlowFixMe[incompatible-type-arg] Component isn't valid\n // $FlowFixMe[incompatible-return] Component isn't valid\n return /*#__PURE__*/React.createElement(ListItemComponent, props);\n } else if (renderItem) {\n // $FlowFixMe[incompatible-call]\n return renderItem(props);\n } else {\n return null;\n }\n };\n var renderProp = info => {\n if (cols > 1) {\n var _item2 = info.item,\n _index = info.index;\n invariant(Array.isArray(_item2), 'Expected array of items with numColumns > 1');\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.row, columnWrapperStyle]\n }, _item2.map((it, kk) => {\n var element = render({\n // $FlowFixMe[incompatible-call]\n item: it,\n index: _index * cols + kk,\n separators: info.separators\n });\n return element != null ? /*#__PURE__*/React.createElement(React.Fragment, {\n key: kk\n }, element) : null;\n }));\n } else {\n return render(info);\n }\n };\n return ListItemComponent ? {\n ListItemComponent: renderProp\n } : {\n renderItem: renderProp\n };\n };\n this._memoizedRenderer = memoizeOne(this._renderer);\n this._checkProps(this.props);\n if (this.props.viewabilityConfigCallbackPairs) {\n this._virtualizedListPairs = this.props.viewabilityConfigCallbackPairs.map(pair => ({\n viewabilityConfig: pair.viewabilityConfig,\n onViewableItemsChanged: this._createOnViewableItemsChanged(pair.onViewableItemsChanged)\n }));\n } else if (this.props.onViewableItemsChanged) {\n this._virtualizedListPairs.push({\n /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.63 was deployed. To\n * see the error delete this comment and run Flow. */\n viewabilityConfig: this.props.viewabilityConfig,\n onViewableItemsChanged: this._createOnViewableItemsChanged(this.props.onViewableItemsChanged)\n });\n }\n }\n\n // $FlowFixMe[missing-local-annot]\n componentDidUpdate(prevProps) {\n invariant(prevProps.numColumns === this.props.numColumns, 'Changing numColumns on the fly is not supported. Change the key prop on FlatList when ' + 'changing the number of columns to force a fresh render of the component.');\n invariant(prevProps.onViewableItemsChanged === this.props.onViewableItemsChanged, 'Changing onViewableItemsChanged on the fly is not supported');\n invariant(!deepDiffer(prevProps.viewabilityConfig, this.props.viewabilityConfig), 'Changing viewabilityConfig on the fly is not supported');\n invariant(prevProps.viewabilityConfigCallbackPairs === this.props.viewabilityConfigCallbackPairs, 'Changing viewabilityConfigCallbackPairs on the fly is not supported');\n this._checkProps(this.props);\n }\n // $FlowFixMe[missing-local-annot]\n _checkProps(props) {\n var getItem = props.getItem,\n getItemCount = props.getItemCount,\n horizontal = props.horizontal,\n columnWrapperStyle = props.columnWrapperStyle,\n onViewableItemsChanged = props.onViewableItemsChanged,\n viewabilityConfigCallbackPairs = props.viewabilityConfigCallbackPairs;\n var numColumns = numColumnsOrDefault(this.props.numColumns);\n invariant(!getItem && !getItemCount, 'FlatList does not support custom data formats.');\n if (numColumns > 1) {\n invariant(!horizontal, 'numColumns does not support horizontal.');\n } else {\n invariant(!columnWrapperStyle, 'columnWrapperStyle not supported for single column lists');\n }\n invariant(!(onViewableItemsChanged && viewabilityConfigCallbackPairs), 'FlatList does not support setting both onViewableItemsChanged and ' + 'viewabilityConfigCallbackPairs.');\n }\n _pushMultiColumnViewable(arr, v) {\n var _this$props$keyExtrac2;\n var numColumns = numColumnsOrDefault(this.props.numColumns);\n var keyExtractor = (_this$props$keyExtrac2 = this.props.keyExtractor) !== null && _this$props$keyExtrac2 !== void 0 ? _this$props$keyExtrac2 : defaultKeyExtractor;\n v.item.forEach((item, ii) => {\n invariant(v.index != null, 'Missing index!');\n var index = v.index * numColumns + ii;\n arr.push(_objectSpread(_objectSpread({}, v), {}, {\n item,\n key: keyExtractor(item, index),\n index\n }));\n });\n }\n _createOnViewableItemsChanged(onViewableItemsChanged\n // $FlowFixMe[missing-local-annot]\n ) {\n return info => {\n var numColumns = numColumnsOrDefault(this.props.numColumns);\n if (onViewableItemsChanged) {\n if (numColumns > 1) {\n var changed = [];\n var viewableItems = [];\n info.viewableItems.forEach(v => this._pushMultiColumnViewable(viewableItems, v));\n info.changed.forEach(v => this._pushMultiColumnViewable(changed, v));\n onViewableItemsChanged({\n viewableItems,\n changed\n });\n } else {\n onViewableItemsChanged(info);\n }\n }\n };\n }\n\n // $FlowFixMe[missing-local-annot]\n\n render() {\n var _this$props = this.props,\n numColumns = _this$props.numColumns,\n columnWrapperStyle = _this$props.columnWrapperStyle,\n _removeClippedSubviews = _this$props.removeClippedSubviews,\n _this$props$strictMod = _this$props.strictMode,\n strictMode = _this$props$strictMod === void 0 ? false : _this$props$strictMod,\n restProps = _objectWithoutPropertiesLoose(_this$props, _excluded);\n var renderer = strictMode ? this._memoizedRenderer : this._renderer;\n return (\n /*#__PURE__*/\n // $FlowFixMe[incompatible-exact] - `restProps` (`Props`) is inexact.\n React.createElement(VirtualizedList, _extends({}, restProps, {\n getItem: this._getItem,\n getItemCount: this._getItemCount,\n keyExtractor: this._keyExtractor,\n ref: this._captureRef,\n viewabilityConfigCallbackPairs: this._virtualizedListPairs,\n removeClippedSubviews: removeClippedSubviewsOrDefault(_removeClippedSubviews)\n }, renderer(this.props.ListItemComponent, this.props.renderItem, columnWrapperStyle, numColumns, this.props.extraData)))\n );\n }\n}\nvar styles = StyleSheet.create({\n row: {\n flexDirection: 'row'\n }\n});\nexport default FlatList;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * \n */\n\n'use strict';\n\n/*\n * @returns {bool} true if different, false if equal\n */\nvar deepDiffer = function deepDiffer(one, two, maxDepth) {\n if (maxDepth === void 0) {\n maxDepth = -1;\n }\n if (maxDepth === 0) {\n return true;\n }\n if (one === two) {\n // Short circuit on identical object references instead of traversing them.\n return false;\n }\n if (typeof one === 'function' && typeof two === 'function') {\n // We consider all functions equal\n return false;\n }\n if (typeof one !== 'object' || one === null) {\n // Primitives can be directly compared\n return one !== two;\n }\n if (typeof two !== 'object' || two === null) {\n // We know they are different because the previous case would have triggered\n // otherwise.\n return true;\n }\n if (one.constructor !== two.constructor) {\n return true;\n }\n if (Array.isArray(one)) {\n // We know two is also an array because the constructors are equal\n var len = one.length;\n if (two.length !== len) {\n return true;\n }\n for (var ii = 0; ii < len; ii++) {\n if (deepDiffer(one[ii], two[ii], maxDepth - 1)) {\n return true;\n }\n }\n } else {\n for (var key in one) {\n if (deepDiffer(one[key], two[key], maxDepth - 1)) {\n return true;\n }\n }\n for (var twoKey in two) {\n // The only case we haven't checked yet is keys that are in two but aren't\n // in one, which means they are different.\n if (one[twoKey] === undefined && two[twoKey] !== undefined) {\n return true;\n }\n }\n }\n return false;\n};\nexport default deepDiffer;","import _createForOfIteratorHelperLoose from \"@babel/runtime/helpers/createForOfIteratorHelperLoose\";\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport RefreshControl from '../../../exports/RefreshControl';\nimport ScrollView from '../../../exports/ScrollView';\nimport View from '../../../exports/View';\nimport StyleSheet from '../../../exports/StyleSheet';\nimport findNodeHandle from '../../../exports/findNodeHandle';\nimport Batchinator from '../Batchinator';\nimport clamp from '../Utilities/clamp';\nimport infoLog from '../infoLog';\nimport { CellRenderMask } from './CellRenderMask';\nimport ChildListCollection from './ChildListCollection';\nimport FillRateHelper from '../FillRateHelper';\nimport StateSafePureComponent from './StateSafePureComponent';\nimport ViewabilityHelper from '../ViewabilityHelper';\nimport CellRenderer from './VirtualizedListCellRenderer';\nimport { VirtualizedListCellContextProvider, VirtualizedListContext, VirtualizedListContextProvider } from './VirtualizedListContext.js';\nimport { computeWindowedRenderLimits, keyExtractor as defaultKeyExtractor } from '../VirtualizeUtils';\nimport invariant from 'fbjs/lib/invariant';\nimport nullthrows from 'nullthrows';\nimport * as React from 'react';\nvar __DEV__ = process.env.NODE_ENV !== 'production';\nvar ON_EDGE_REACHED_EPSILON = 0.001;\nvar _usedIndexForKey = false;\nvar _keylessItemComponentName = '';\n/**\n * Default Props Helper Functions\n * Use the following helper functions for default values\n */ // horizontalOrDefault(this.props.horizontal)\nfunction horizontalOrDefault(horizontal) {\n return horizontal !== null && horizontal !== void 0 ? horizontal : false;\n}\n\n// initialNumToRenderOrDefault(this.props.initialNumToRender)\nfunction initialNumToRenderOrDefault(initialNumToRender) {\n return initialNumToRender !== null && initialNumToRender !== void 0 ? initialNumToRender : 10;\n}\n\n// maxToRenderPerBatchOrDefault(this.props.maxToRenderPerBatch)\nfunction maxToRenderPerBatchOrDefault(maxToRenderPerBatch) {\n return maxToRenderPerBatch !== null && maxToRenderPerBatch !== void 0 ? maxToRenderPerBatch : 10;\n}\n\n// onStartReachedThresholdOrDefault(this.props.onStartReachedThreshold)\nfunction onStartReachedThresholdOrDefault(onStartReachedThreshold) {\n return onStartReachedThreshold !== null && onStartReachedThreshold !== void 0 ? onStartReachedThreshold : 2;\n}\n\n// onEndReachedThresholdOrDefault(this.props.onEndReachedThreshold)\nfunction onEndReachedThresholdOrDefault(onEndReachedThreshold) {\n return onEndReachedThreshold !== null && onEndReachedThreshold !== void 0 ? onEndReachedThreshold : 2;\n}\n\n// getScrollingThreshold(visibleLength, onEndReachedThreshold)\nfunction getScrollingThreshold(threshold, visibleLength) {\n return threshold * visibleLength / 2;\n}\n\n// scrollEventThrottleOrDefault(this.props.scrollEventThrottle)\nfunction scrollEventThrottleOrDefault(scrollEventThrottle) {\n return scrollEventThrottle !== null && scrollEventThrottle !== void 0 ? scrollEventThrottle : 50;\n}\n\n// windowSizeOrDefault(this.props.windowSize)\nfunction windowSizeOrDefault(windowSize) {\n return windowSize !== null && windowSize !== void 0 ? windowSize : 21;\n}\nfunction findLastWhere(arr, predicate) {\n for (var i = arr.length - 1; i >= 0; i--) {\n if (predicate(arr[i])) {\n return arr[i];\n }\n }\n return null;\n}\n\n/**\n * Base implementation for the more convenient [``](https://reactnative.dev/docs/flatlist)\n * and [``](https://reactnative.dev/docs/sectionlist) components, which are also better\n * documented. In general, this should only really be used if you need more flexibility than\n * `FlatList` provides, e.g. for use with immutable data instead of plain arrays.\n *\n * Virtualization massively improves memory consumption and performance of large lists by\n * maintaining a finite render window of active items and replacing all items outside of the render\n * window with appropriately sized blank space. The window adapts to scrolling behavior, and items\n * are rendered incrementally with low-pri (after any running interactions) if they are far from the\n * visible area, or with hi-pri otherwise to minimize the potential of seeing blank space.\n *\n * Some caveats:\n *\n * - Internal state is not preserved when content scrolls out of the render window. Make sure all\n * your data is captured in the item data or external stores like Flux, Redux, or Relay.\n * - This is a `PureComponent` which means that it will not re-render if `props` remain shallow-\n * equal. Make sure that everything your `renderItem` function depends on is passed as a prop\n * (e.g. `extraData`) that is not `===` after updates, otherwise your UI may not update on\n * changes. This includes the `data` prop and parent component state.\n * - In order to constrain memory and enable smooth scrolling, content is rendered asynchronously\n * offscreen. This means it's possible to scroll faster than the fill rate ands momentarily see\n * blank content. This is a tradeoff that can be adjusted to suit the needs of each application,\n * and we are working on improving it behind the scenes.\n * - By default, the list looks for a `key` or `id` prop on each item and uses that for the React key.\n * Alternatively, you can provide a custom `keyExtractor` prop.\n * - As an effort to remove defaultProps, use helper functions when referencing certain props\n *\n */\nclass VirtualizedList extends StateSafePureComponent {\n // scrollToEnd may be janky without getItemLayout prop\n scrollToEnd(params) {\n var animated = params ? params.animated : true;\n var veryLast = this.props.getItemCount(this.props.data) - 1;\n if (veryLast < 0) {\n return;\n }\n var frame = this.__getFrameMetricsApprox(veryLast, this.props);\n var offset = Math.max(0, frame.offset + frame.length + this._footerLength - this._scrollMetrics.visibleLength);\n if (this._scrollRef == null) {\n return;\n }\n if (this._scrollRef.scrollTo == null) {\n console.warn('No scrollTo method provided. This may be because you have two nested ' + 'VirtualizedLists with the same orientation, or because you are ' + 'using a custom component that does not implement scrollTo.');\n return;\n }\n this._scrollRef.scrollTo(horizontalOrDefault(this.props.horizontal) ? {\n x: offset,\n animated\n } : {\n y: offset,\n animated\n });\n }\n\n // scrollToIndex may be janky without getItemLayout prop\n scrollToIndex(params) {\n var _this$props = this.props,\n data = _this$props.data,\n horizontal = _this$props.horizontal,\n getItemCount = _this$props.getItemCount,\n getItemLayout = _this$props.getItemLayout,\n onScrollToIndexFailed = _this$props.onScrollToIndexFailed;\n var animated = params.animated,\n index = params.index,\n viewOffset = params.viewOffset,\n viewPosition = params.viewPosition;\n invariant(index >= 0, \"scrollToIndex out of range: requested index \" + index + \" but minimum is 0\");\n invariant(getItemCount(data) >= 1, \"scrollToIndex out of range: item length \" + getItemCount(data) + \" but minimum is 1\");\n invariant(index < getItemCount(data), \"scrollToIndex out of range: requested index \" + index + \" is out of 0 to \" + (getItemCount(data) - 1));\n if (!getItemLayout && index > this._highestMeasuredFrameIndex) {\n invariant(!!onScrollToIndexFailed, 'scrollToIndex should be used in conjunction with getItemLayout or onScrollToIndexFailed, ' + 'otherwise there is no way to know the location of offscreen indices or handle failures.');\n onScrollToIndexFailed({\n averageItemLength: this._averageCellLength,\n highestMeasuredFrameIndex: this._highestMeasuredFrameIndex,\n index\n });\n return;\n }\n var frame = this.__getFrameMetricsApprox(Math.floor(index), this.props);\n var offset = Math.max(0, this._getOffsetApprox(index, this.props) - (viewPosition || 0) * (this._scrollMetrics.visibleLength - frame.length)) - (viewOffset || 0);\n if (this._scrollRef == null) {\n return;\n }\n if (this._scrollRef.scrollTo == null) {\n console.warn('No scrollTo method provided. This may be because you have two nested ' + 'VirtualizedLists with the same orientation, or because you are ' + 'using a custom component that does not implement scrollTo.');\n return;\n }\n this._scrollRef.scrollTo(horizontal ? {\n x: offset,\n animated\n } : {\n y: offset,\n animated\n });\n }\n\n // scrollToItem may be janky without getItemLayout prop. Required linear scan through items -\n // use scrollToIndex instead if possible.\n scrollToItem(params) {\n var item = params.item;\n var _this$props2 = this.props,\n data = _this$props2.data,\n getItem = _this$props2.getItem,\n getItemCount = _this$props2.getItemCount;\n var itemCount = getItemCount(data);\n for (var _index = 0; _index < itemCount; _index++) {\n if (getItem(data, _index) === item) {\n this.scrollToIndex(_objectSpread(_objectSpread({}, params), {}, {\n index: _index\n }));\n break;\n }\n }\n }\n\n /**\n * Scroll to a specific content pixel offset in the list.\n *\n * Param `offset` expects the offset to scroll to.\n * In case of `horizontal` is true, the offset is the x-value,\n * in any other case the offset is the y-value.\n *\n * Param `animated` (`true` by default) defines whether the list\n * should do an animation while scrolling.\n */\n scrollToOffset(params) {\n var animated = params.animated,\n offset = params.offset;\n if (this._scrollRef == null) {\n return;\n }\n if (this._scrollRef.scrollTo == null) {\n console.warn('No scrollTo method provided. This may be because you have two nested ' + 'VirtualizedLists with the same orientation, or because you are ' + 'using a custom component that does not implement scrollTo.');\n return;\n }\n this._scrollRef.scrollTo(horizontalOrDefault(this.props.horizontal) ? {\n x: offset,\n animated\n } : {\n y: offset,\n animated\n });\n }\n recordInteraction() {\n this._nestedChildLists.forEach(childList => {\n childList.recordInteraction();\n });\n this._viewabilityTuples.forEach(t => {\n t.viewabilityHelper.recordInteraction();\n });\n this._updateViewableItems(this.props, this.state.cellsAroundViewport);\n }\n flashScrollIndicators() {\n if (this._scrollRef == null) {\n return;\n }\n this._scrollRef.flashScrollIndicators();\n }\n\n /**\n * Provides a handle to the underlying scroll responder.\n * Note that `this._scrollRef` might not be a `ScrollView`, so we\n * need to check that it responds to `getScrollResponder` before calling it.\n */\n getScrollResponder() {\n if (this._scrollRef && this._scrollRef.getScrollResponder) {\n return this._scrollRef.getScrollResponder();\n }\n }\n getScrollableNode() {\n if (this._scrollRef && this._scrollRef.getScrollableNode) {\n return this._scrollRef.getScrollableNode();\n } else {\n return this._scrollRef;\n }\n }\n getScrollRef() {\n if (this._scrollRef && this._scrollRef.getScrollRef) {\n return this._scrollRef.getScrollRef();\n } else {\n return this._scrollRef;\n }\n }\n _getCellKey() {\n var _this$context;\n return ((_this$context = this.context) == null ? void 0 : _this$context.cellKey) || 'rootList';\n }\n\n // $FlowFixMe[missing-local-annot]\n\n hasMore() {\n return this._hasMore;\n }\n\n // $FlowFixMe[missing-local-annot]\n\n // REACT-NATIVE-WEB patch to preserve during future RN merges: Support inverted wheel scroller.\n\n constructor(_props) {\n var _this$props$updateCel;\n super(_props);\n this._getScrollMetrics = () => {\n return this._scrollMetrics;\n };\n this._getOutermostParentListRef = () => {\n if (this._isNestedWithSameOrientation()) {\n return this.context.getOutermostParentListRef();\n } else {\n return this;\n }\n };\n this._registerAsNestedChild = childList => {\n this._nestedChildLists.add(childList.ref, childList.cellKey);\n if (this._hasInteracted) {\n childList.ref.recordInteraction();\n }\n };\n this._unregisterAsNestedChild = childList => {\n this._nestedChildLists.remove(childList.ref);\n };\n this._onUpdateSeparators = (keys, newProps) => {\n keys.forEach(key => {\n var ref = key != null && this._cellRefs[key];\n ref && ref.updateSeparatorProps(newProps);\n });\n };\n this._getSpacerKey = isVertical => isVertical ? 'height' : 'width';\n this._averageCellLength = 0;\n this._cellRefs = {};\n this._frames = {};\n this._footerLength = 0;\n this._hasTriggeredInitialScrollToIndex = false;\n this._hasInteracted = false;\n this._hasMore = false;\n this._hasWarned = {};\n this._headerLength = 0;\n this._hiPriInProgress = false;\n this._highestMeasuredFrameIndex = 0;\n this._indicesToKeys = new Map();\n this._lastFocusedCellKey = null;\n this._nestedChildLists = new ChildListCollection();\n this._offsetFromParentVirtualizedList = 0;\n this._prevParentOffset = 0;\n this._scrollMetrics = {\n contentLength: 0,\n dOffset: 0,\n dt: 10,\n offset: 0,\n timestamp: 0,\n velocity: 0,\n visibleLength: 0,\n zoomScale: 1\n };\n this._scrollRef = null;\n this._sentStartForContentLength = 0;\n this._sentEndForContentLength = 0;\n this._totalCellLength = 0;\n this._totalCellsMeasured = 0;\n this._viewabilityTuples = [];\n this._captureScrollRef = ref => {\n this._scrollRef = ref;\n };\n this._defaultRenderScrollComponent = props => {\n var onRefresh = props.onRefresh;\n if (this._isNestedWithSameOrientation()) {\n // $FlowFixMe[prop-missing] - Typing ReactNativeComponent revealed errors\n return /*#__PURE__*/React.createElement(View, props);\n } else if (onRefresh) {\n var _props$refreshing;\n invariant(typeof props.refreshing === 'boolean', '`refreshing` prop must be set as a boolean in order to use `onRefresh`, but got `' + JSON.stringify((_props$refreshing = props.refreshing) !== null && _props$refreshing !== void 0 ? _props$refreshing : 'undefined') + '`');\n return (\n /*#__PURE__*/\n // $FlowFixMe[prop-missing] Invalid prop usage\n // $FlowFixMe[incompatible-use]\n React.createElement(ScrollView, _extends({}, props, {\n refreshControl: props.refreshControl == null ? /*#__PURE__*/React.createElement(RefreshControl\n // $FlowFixMe[incompatible-type]\n , {\n refreshing: props.refreshing,\n onRefresh: onRefresh,\n progressViewOffset: props.progressViewOffset\n }) : props.refreshControl\n }))\n );\n } else {\n // $FlowFixMe[prop-missing] Invalid prop usage\n // $FlowFixMe[incompatible-use]\n return /*#__PURE__*/React.createElement(ScrollView, props);\n }\n };\n this._onCellLayout = (e, cellKey, index) => {\n var layout = e.nativeEvent.layout;\n var next = {\n offset: this._selectOffset(layout),\n length: this._selectLength(layout),\n index,\n inLayout: true\n };\n var curr = this._frames[cellKey];\n if (!curr || next.offset !== curr.offset || next.length !== curr.length || index !== curr.index) {\n this._totalCellLength += next.length - (curr ? curr.length : 0);\n this._totalCellsMeasured += curr ? 0 : 1;\n this._averageCellLength = this._totalCellLength / this._totalCellsMeasured;\n this._frames[cellKey] = next;\n this._highestMeasuredFrameIndex = Math.max(this._highestMeasuredFrameIndex, index);\n this._scheduleCellsToRenderUpdate();\n } else {\n this._frames[cellKey].inLayout = true;\n }\n this._triggerRemeasureForChildListsInCell(cellKey);\n this._computeBlankness();\n this._updateViewableItems(this.props, this.state.cellsAroundViewport);\n };\n this._onCellUnmount = cellKey => {\n delete this._cellRefs[cellKey];\n var curr = this._frames[cellKey];\n if (curr) {\n this._frames[cellKey] = _objectSpread(_objectSpread({}, curr), {}, {\n inLayout: false\n });\n }\n };\n this._onLayout = e => {\n if (this._isNestedWithSameOrientation()) {\n // Need to adjust our scroll metrics to be relative to our containing\n // VirtualizedList before we can make claims about list item viewability\n this.measureLayoutRelativeToContainingList();\n } else {\n this._scrollMetrics.visibleLength = this._selectLength(e.nativeEvent.layout);\n }\n this.props.onLayout && this.props.onLayout(e);\n this._scheduleCellsToRenderUpdate();\n this._maybeCallOnEdgeReached();\n };\n this._onLayoutEmpty = e => {\n this.props.onLayout && this.props.onLayout(e);\n };\n this._onLayoutFooter = e => {\n this._triggerRemeasureForChildListsInCell(this._getFooterCellKey());\n this._footerLength = this._selectLength(e.nativeEvent.layout);\n };\n this._onLayoutHeader = e => {\n this._headerLength = this._selectLength(e.nativeEvent.layout);\n };\n this._onContentSizeChange = (width, height) => {\n if (width > 0 && height > 0 && this.props.initialScrollIndex != null && this.props.initialScrollIndex > 0 && !this._hasTriggeredInitialScrollToIndex) {\n if (this.props.contentOffset == null) {\n if (this.props.initialScrollIndex < this.props.getItemCount(this.props.data)) {\n this.scrollToIndex({\n animated: false,\n index: nullthrows(this.props.initialScrollIndex)\n });\n } else {\n this.scrollToEnd({\n animated: false\n });\n }\n }\n this._hasTriggeredInitialScrollToIndex = true;\n }\n if (this.props.onContentSizeChange) {\n this.props.onContentSizeChange(width, height);\n }\n this._scrollMetrics.contentLength = this._selectLength({\n height,\n width\n });\n this._scheduleCellsToRenderUpdate();\n this._maybeCallOnEdgeReached();\n };\n this._convertParentScrollMetrics = metrics => {\n // Offset of the top of the nested list relative to the top of its parent's viewport\n var offset = metrics.offset - this._offsetFromParentVirtualizedList;\n // Child's visible length is the same as its parent's\n var visibleLength = metrics.visibleLength;\n var dOffset = offset - this._scrollMetrics.offset;\n var contentLength = this._scrollMetrics.contentLength;\n return {\n visibleLength,\n contentLength,\n offset,\n dOffset\n };\n };\n this._onScroll = e => {\n this._nestedChildLists.forEach(childList => {\n childList._onScroll(e);\n });\n if (this.props.onScroll) {\n this.props.onScroll(e);\n }\n var timestamp = e.timeStamp;\n var visibleLength = this._selectLength(e.nativeEvent.layoutMeasurement);\n var contentLength = this._selectLength(e.nativeEvent.contentSize);\n var offset = this._selectOffset(e.nativeEvent.contentOffset);\n var dOffset = offset - this._scrollMetrics.offset;\n if (this._isNestedWithSameOrientation()) {\n if (this._scrollMetrics.contentLength === 0) {\n // Ignore scroll events until onLayout has been called and we\n // know our offset from our offset from our parent\n return;\n }\n var _this$_convertParentS = this._convertParentScrollMetrics({\n visibleLength,\n offset\n });\n visibleLength = _this$_convertParentS.visibleLength;\n contentLength = _this$_convertParentS.contentLength;\n offset = _this$_convertParentS.offset;\n dOffset = _this$_convertParentS.dOffset;\n }\n var dt = this._scrollMetrics.timestamp ? Math.max(1, timestamp - this._scrollMetrics.timestamp) : 1;\n var velocity = dOffset / dt;\n if (dt > 500 && this._scrollMetrics.dt > 500 && contentLength > 5 * visibleLength && !this._hasWarned.perf) {\n infoLog('VirtualizedList: You have a large list that is slow to update - make sure your ' + 'renderItem function renders components that follow React performance best practices ' + 'like PureComponent, shouldComponentUpdate, etc.', {\n dt,\n prevDt: this._scrollMetrics.dt,\n contentLength\n });\n this._hasWarned.perf = true;\n }\n\n // For invalid negative values (w/ RTL), set this to 1.\n var zoomScale = e.nativeEvent.zoomScale < 0 ? 1 : e.nativeEvent.zoomScale;\n this._scrollMetrics = {\n contentLength,\n dt,\n dOffset,\n offset,\n timestamp,\n velocity,\n visibleLength,\n zoomScale\n };\n this._updateViewableItems(this.props, this.state.cellsAroundViewport);\n if (!this.props) {\n return;\n }\n this._maybeCallOnEdgeReached();\n if (velocity !== 0) {\n this._fillRateHelper.activate();\n }\n this._computeBlankness();\n this._scheduleCellsToRenderUpdate();\n };\n this._onScrollBeginDrag = e => {\n this._nestedChildLists.forEach(childList => {\n childList._onScrollBeginDrag(e);\n });\n this._viewabilityTuples.forEach(tuple => {\n tuple.viewabilityHelper.recordInteraction();\n });\n this._hasInteracted = true;\n this.props.onScrollBeginDrag && this.props.onScrollBeginDrag(e);\n };\n this._onScrollEndDrag = e => {\n this._nestedChildLists.forEach(childList => {\n childList._onScrollEndDrag(e);\n });\n var velocity = e.nativeEvent.velocity;\n if (velocity) {\n this._scrollMetrics.velocity = this._selectOffset(velocity);\n }\n this._computeBlankness();\n this.props.onScrollEndDrag && this.props.onScrollEndDrag(e);\n };\n this._onMomentumScrollBegin = e => {\n this._nestedChildLists.forEach(childList => {\n childList._onMomentumScrollBegin(e);\n });\n this.props.onMomentumScrollBegin && this.props.onMomentumScrollBegin(e);\n };\n this._onMomentumScrollEnd = e => {\n this._nestedChildLists.forEach(childList => {\n childList._onMomentumScrollEnd(e);\n });\n this._scrollMetrics.velocity = 0;\n this._computeBlankness();\n this.props.onMomentumScrollEnd && this.props.onMomentumScrollEnd(e);\n };\n this._updateCellsToRender = () => {\n this._updateViewableItems(this.props, this.state.cellsAroundViewport);\n this.setState((state, props) => {\n var cellsAroundViewport = this._adjustCellsAroundViewport(props, state.cellsAroundViewport);\n var renderMask = VirtualizedList._createRenderMask(props, cellsAroundViewport, this._getNonViewportRenderRegions(props));\n if (cellsAroundViewport.first === state.cellsAroundViewport.first && cellsAroundViewport.last === state.cellsAroundViewport.last && renderMask.equals(state.renderMask)) {\n return null;\n }\n return {\n cellsAroundViewport,\n renderMask\n };\n });\n };\n this._createViewToken = (index, isViewable, props\n // $FlowFixMe[missing-local-annot]\n ) => {\n var data = props.data,\n getItem = props.getItem;\n var item = getItem(data, index);\n return {\n index,\n item,\n key: this._keyExtractor(item, index, props),\n isViewable\n };\n };\n this._getOffsetApprox = (index, props) => {\n if (Number.isInteger(index)) {\n return this.__getFrameMetricsApprox(index, props).offset;\n } else {\n var frameMetrics = this.__getFrameMetricsApprox(Math.floor(index), props);\n var remainder = index - Math.floor(index);\n return frameMetrics.offset + remainder * frameMetrics.length;\n }\n };\n this.__getFrameMetricsApprox = (index, props) => {\n var frame = this._getFrameMetrics(index, props);\n if (frame && frame.index === index) {\n // check for invalid frames due to row re-ordering\n return frame;\n } else {\n var data = props.data,\n getItemCount = props.getItemCount,\n getItemLayout = props.getItemLayout;\n invariant(index >= 0 && index < getItemCount(data), 'Tried to get frame for out of range index ' + index);\n invariant(!getItemLayout, 'Should not have to estimate frames when a measurement metrics function is provided');\n return {\n length: this._averageCellLength,\n offset: this._averageCellLength * index\n };\n }\n };\n this._getFrameMetrics = (index, props) => {\n var data = props.data,\n getItem = props.getItem,\n getItemCount = props.getItemCount,\n getItemLayout = props.getItemLayout;\n invariant(index >= 0 && index < getItemCount(data), 'Tried to get frame for out of range index ' + index);\n var item = getItem(data, index);\n var frame = this._frames[this._keyExtractor(item, index, props)];\n if (!frame || frame.index !== index) {\n if (getItemLayout) {\n /* $FlowFixMe[prop-missing] (>=0.63.0 site=react_native_fb) This comment\n * suppresses an error found when Flow v0.63 was deployed. To see the error\n * delete this comment and run Flow. */\n return getItemLayout(data, index);\n }\n }\n return frame;\n };\n this._getNonViewportRenderRegions = props => {\n // Keep a viewport's worth of content around the last focused cell to allow\n // random navigation around it without any blanking. E.g. tabbing from one\n // focused item out of viewport to another.\n if (!(this._lastFocusedCellKey && this._cellRefs[this._lastFocusedCellKey])) {\n return [];\n }\n var lastFocusedCellRenderer = this._cellRefs[this._lastFocusedCellKey];\n var focusedCellIndex = lastFocusedCellRenderer.props.index;\n var itemCount = props.getItemCount(props.data);\n\n // The last cell we rendered may be at a new index. Bail if we don't know\n // where it is.\n if (focusedCellIndex >= itemCount || this._keyExtractor(props.getItem(props.data, focusedCellIndex), focusedCellIndex, props) !== this._lastFocusedCellKey) {\n return [];\n }\n var first = focusedCellIndex;\n var heightOfCellsBeforeFocused = 0;\n for (var i = first - 1; i >= 0 && heightOfCellsBeforeFocused < this._scrollMetrics.visibleLength; i--) {\n first--;\n heightOfCellsBeforeFocused += this.__getFrameMetricsApprox(i, props).length;\n }\n var last = focusedCellIndex;\n var heightOfCellsAfterFocused = 0;\n for (var _i = last + 1; _i < itemCount && heightOfCellsAfterFocused < this._scrollMetrics.visibleLength; _i++) {\n last++;\n heightOfCellsAfterFocused += this.__getFrameMetricsApprox(_i, props).length;\n }\n return [{\n first,\n last\n }];\n };\n this._checkProps(_props);\n this._fillRateHelper = new FillRateHelper(this._getFrameMetrics);\n this._updateCellsToRenderBatcher = new Batchinator(this._updateCellsToRender, (_this$props$updateCel = this.props.updateCellsBatchingPeriod) !== null && _this$props$updateCel !== void 0 ? _this$props$updateCel : 50);\n if (this.props.viewabilityConfigCallbackPairs) {\n this._viewabilityTuples = this.props.viewabilityConfigCallbackPairs.map(pair => ({\n viewabilityHelper: new ViewabilityHelper(pair.viewabilityConfig),\n onViewableItemsChanged: pair.onViewableItemsChanged\n }));\n } else {\n var _this$props3 = this.props,\n onViewableItemsChanged = _this$props3.onViewableItemsChanged,\n viewabilityConfig = _this$props3.viewabilityConfig;\n if (onViewableItemsChanged) {\n this._viewabilityTuples.push({\n viewabilityHelper: new ViewabilityHelper(viewabilityConfig),\n onViewableItemsChanged: onViewableItemsChanged\n });\n }\n }\n var initialRenderRegion = VirtualizedList._initialRenderRegion(_props);\n this.state = {\n cellsAroundViewport: initialRenderRegion,\n renderMask: VirtualizedList._createRenderMask(_props, initialRenderRegion)\n };\n\n // REACT-NATIVE-WEB patch to preserve during future RN merges: Support inverted wheel scroller.\n // For issue https://github.com/necolas/react-native-web/issues/995\n this.invertedWheelEventHandler = ev => {\n var scrollOffset = this.props.horizontal ? ev.target.scrollLeft : ev.target.scrollTop;\n var scrollLength = this.props.horizontal ? ev.target.scrollWidth : ev.target.scrollHeight;\n var clientLength = this.props.horizontal ? ev.target.clientWidth : ev.target.clientHeight;\n var isEventTargetScrollable = scrollLength > clientLength;\n var delta = this.props.horizontal ? ev.deltaX || ev.wheelDeltaX : ev.deltaY || ev.wheelDeltaY;\n var leftoverDelta = delta;\n if (isEventTargetScrollable) {\n leftoverDelta = delta < 0 ? Math.min(delta + scrollOffset, 0) : Math.max(delta - (scrollLength - clientLength - scrollOffset), 0);\n }\n var targetDelta = delta - leftoverDelta;\n if (this.props.inverted && this._scrollRef && this._scrollRef.getScrollableNode) {\n var node = this._scrollRef.getScrollableNode();\n if (this.props.horizontal) {\n ev.target.scrollLeft += targetDelta;\n var nextScrollLeft = node.scrollLeft - leftoverDelta;\n node.scrollLeft = !this.props.getItemLayout ? Math.min(nextScrollLeft, this._totalCellLength) : nextScrollLeft;\n } else {\n ev.target.scrollTop += targetDelta;\n var nextScrollTop = node.scrollTop - leftoverDelta;\n node.scrollTop = !this.props.getItemLayout ? Math.min(nextScrollTop, this._totalCellLength) : nextScrollTop;\n }\n ev.preventDefault();\n }\n };\n }\n _checkProps(props) {\n var onScroll = props.onScroll,\n windowSize = props.windowSize,\n getItemCount = props.getItemCount,\n data = props.data,\n initialScrollIndex = props.initialScrollIndex;\n invariant(\n // $FlowFixMe[prop-missing]\n !onScroll || !onScroll.__isNative, 'Components based on VirtualizedList must be wrapped with Animated.createAnimatedComponent ' + 'to support native onScroll events with useNativeDriver');\n invariant(windowSizeOrDefault(windowSize) > 0, 'VirtualizedList: The windowSize prop must be present and set to a value greater than 0.');\n invariant(getItemCount, 'VirtualizedList: The \"getItemCount\" prop must be provided');\n var itemCount = getItemCount(data);\n if (initialScrollIndex != null && !this._hasTriggeredInitialScrollToIndex && (initialScrollIndex < 0 || itemCount > 0 && initialScrollIndex >= itemCount) && !this._hasWarned.initialScrollIndex) {\n console.warn(\"initialScrollIndex \\\"\" + initialScrollIndex + \"\\\" is not valid (list has \" + itemCount + \" items)\");\n this._hasWarned.initialScrollIndex = true;\n }\n if (__DEV__ && !this._hasWarned.flexWrap) {\n // $FlowFixMe[underconstrained-implicit-instantiation]\n var flatStyles = StyleSheet.flatten(this.props.contentContainerStyle);\n if (flatStyles != null && flatStyles.flexWrap === 'wrap') {\n console.warn('`flexWrap: `wrap`` is not supported with the `VirtualizedList` components.' + 'Consider using `numColumns` with `FlatList` instead.');\n this._hasWarned.flexWrap = true;\n }\n }\n }\n static _createRenderMask(props, cellsAroundViewport, additionalRegions) {\n var itemCount = props.getItemCount(props.data);\n invariant(cellsAroundViewport.first >= 0 && cellsAroundViewport.last >= cellsAroundViewport.first - 1 && cellsAroundViewport.last < itemCount, \"Invalid cells around viewport \\\"[\" + cellsAroundViewport.first + \", \" + cellsAroundViewport.last + \"]\\\" was passed to VirtualizedList._createRenderMask\");\n var renderMask = new CellRenderMask(itemCount);\n if (itemCount > 0) {\n var allRegions = [cellsAroundViewport, ...(additionalRegions !== null && additionalRegions !== void 0 ? additionalRegions : [])];\n for (var _i2 = 0, _allRegions = allRegions; _i2 < _allRegions.length; _i2++) {\n var region = _allRegions[_i2];\n renderMask.addCells(region);\n }\n\n // The initially rendered cells are retained as part of the\n // \"scroll-to-top\" optimization\n if (props.initialScrollIndex == null || props.initialScrollIndex <= 0) {\n var initialRegion = VirtualizedList._initialRenderRegion(props);\n renderMask.addCells(initialRegion);\n }\n\n // The layout coordinates of sticker headers may be off-screen while the\n // actual header is on-screen. Keep the most recent before the viewport\n // rendered, even if its layout coordinates are not in viewport.\n var stickyIndicesSet = new Set(props.stickyHeaderIndices);\n VirtualizedList._ensureClosestStickyHeader(props, stickyIndicesSet, renderMask, cellsAroundViewport.first);\n }\n return renderMask;\n }\n static _initialRenderRegion(props) {\n var _props$initialScrollI;\n var itemCount = props.getItemCount(props.data);\n var firstCellIndex = Math.max(0, Math.min(itemCount - 1, Math.floor((_props$initialScrollI = props.initialScrollIndex) !== null && _props$initialScrollI !== void 0 ? _props$initialScrollI : 0)));\n var lastCellIndex = Math.min(itemCount, firstCellIndex + initialNumToRenderOrDefault(props.initialNumToRender)) - 1;\n return {\n first: firstCellIndex,\n last: lastCellIndex\n };\n }\n static _ensureClosestStickyHeader(props, stickyIndicesSet, renderMask, cellIdx) {\n var stickyOffset = props.ListHeaderComponent ? 1 : 0;\n for (var itemIdx = cellIdx - 1; itemIdx >= 0; itemIdx--) {\n if (stickyIndicesSet.has(itemIdx + stickyOffset)) {\n renderMask.addCells({\n first: itemIdx,\n last: itemIdx\n });\n break;\n }\n }\n }\n _adjustCellsAroundViewport(props, cellsAroundViewport) {\n var data = props.data,\n getItemCount = props.getItemCount;\n var onEndReachedThreshold = onEndReachedThresholdOrDefault(props.onEndReachedThreshold);\n var _this$_scrollMetrics = this._scrollMetrics,\n contentLength = _this$_scrollMetrics.contentLength,\n offset = _this$_scrollMetrics.offset,\n visibleLength = _this$_scrollMetrics.visibleLength;\n var distanceFromEnd = contentLength - visibleLength - offset;\n\n // Wait until the scroll view metrics have been set up. And until then,\n // we will trust the initialNumToRender suggestion\n if (visibleLength <= 0 || contentLength <= 0) {\n return cellsAroundViewport.last >= getItemCount(data) ? VirtualizedList._constrainToItemCount(cellsAroundViewport, props) : cellsAroundViewport;\n }\n var newCellsAroundViewport;\n if (props.disableVirtualization) {\n var renderAhead = distanceFromEnd < onEndReachedThreshold * visibleLength ? maxToRenderPerBatchOrDefault(props.maxToRenderPerBatch) : 0;\n newCellsAroundViewport = {\n first: 0,\n last: Math.min(cellsAroundViewport.last + renderAhead, getItemCount(data) - 1)\n };\n } else {\n // If we have a non-zero initialScrollIndex and run this before we've scrolled,\n // we'll wipe out the initialNumToRender rendered elements starting at initialScrollIndex.\n // So let's wait until we've scrolled the view to the right place. And until then,\n // we will trust the initialScrollIndex suggestion.\n\n // Thus, we want to recalculate the windowed render limits if any of the following hold:\n // - initialScrollIndex is undefined or is 0\n // - initialScrollIndex > 0 AND scrolling is complete\n // - initialScrollIndex > 0 AND the end of the list is visible (this handles the case\n // where the list is shorter than the visible area)\n if (props.initialScrollIndex && !this._scrollMetrics.offset && Math.abs(distanceFromEnd) >= Number.EPSILON) {\n return cellsAroundViewport.last >= getItemCount(data) ? VirtualizedList._constrainToItemCount(cellsAroundViewport, props) : cellsAroundViewport;\n }\n newCellsAroundViewport = computeWindowedRenderLimits(props, maxToRenderPerBatchOrDefault(props.maxToRenderPerBatch), windowSizeOrDefault(props.windowSize), cellsAroundViewport, this.__getFrameMetricsApprox, this._scrollMetrics);\n invariant(newCellsAroundViewport.last < getItemCount(data), 'computeWindowedRenderLimits() should return range in-bounds');\n }\n if (this._nestedChildLists.size() > 0) {\n // If some cell in the new state has a child list in it, we should only render\n // up through that item, so that we give that list a chance to render.\n // Otherwise there's churn from multiple child lists mounting and un-mounting\n // their items.\n\n // Will this prevent rendering if the nested list doesn't realize the end?\n var childIdx = this._findFirstChildWithMore(newCellsAroundViewport.first, newCellsAroundViewport.last);\n newCellsAroundViewport.last = childIdx !== null && childIdx !== void 0 ? childIdx : newCellsAroundViewport.last;\n }\n return newCellsAroundViewport;\n }\n _findFirstChildWithMore(first, last) {\n for (var ii = first; ii <= last; ii++) {\n var cellKeyForIndex = this._indicesToKeys.get(ii);\n if (cellKeyForIndex != null && this._nestedChildLists.anyInCell(cellKeyForIndex, childList => childList.hasMore())) {\n return ii;\n }\n }\n return null;\n }\n componentDidMount() {\n if (this._isNestedWithSameOrientation()) {\n this.context.registerAsNestedChild({\n ref: this,\n cellKey: this.context.cellKey\n });\n }\n\n // REACT-NATIVE-WEB patch to preserve during future RN merges: Support inverted wheel scroller.\n this.setupWebWheelHandler();\n }\n componentWillUnmount() {\n if (this._isNestedWithSameOrientation()) {\n this.context.unregisterAsNestedChild({\n ref: this\n });\n }\n this._updateCellsToRenderBatcher.dispose({\n abort: true\n });\n this._viewabilityTuples.forEach(tuple => {\n tuple.viewabilityHelper.dispose();\n });\n this._fillRateHelper.deactivateAndFlush();\n\n // REACT-NATIVE-WEB patch to preserve during future RN merges: Support inverted wheel scroller.\n this.teardownWebWheelHandler();\n }\n\n // REACT-NATIVE-WEB patch to preserve during future RN merges: Support inverted wheel scroller.\n setupWebWheelHandler() {\n if (this._scrollRef && this._scrollRef.getScrollableNode) {\n this._scrollRef.getScrollableNode().addEventListener('wheel', this.invertedWheelEventHandler);\n } else {\n setTimeout(() => this.setupWebWheelHandler(), 50);\n return;\n }\n }\n\n // REACT-NATIVE-WEB patch to preserve during future RN merges: Support inverted wheel scroller.\n teardownWebWheelHandler() {\n if (this._scrollRef && this._scrollRef.getScrollableNode) {\n this._scrollRef.getScrollableNode().removeEventListener('wheel', this.invertedWheelEventHandler);\n }\n }\n static getDerivedStateFromProps(newProps, prevState) {\n // first and last could be stale (e.g. if a new, shorter items props is passed in), so we make\n // sure we're rendering a reasonable range here.\n var itemCount = newProps.getItemCount(newProps.data);\n if (itemCount === prevState.renderMask.numCells()) {\n return prevState;\n }\n var constrainedCells = VirtualizedList._constrainToItemCount(prevState.cellsAroundViewport, newProps);\n return {\n cellsAroundViewport: constrainedCells,\n renderMask: VirtualizedList._createRenderMask(newProps, constrainedCells)\n };\n }\n _pushCells(cells, stickyHeaderIndices, stickyIndicesFromProps, first, last, inversionStyle) {\n var _this = this;\n var _this$props4 = this.props,\n CellRendererComponent = _this$props4.CellRendererComponent,\n ItemSeparatorComponent = _this$props4.ItemSeparatorComponent,\n ListHeaderComponent = _this$props4.ListHeaderComponent,\n ListItemComponent = _this$props4.ListItemComponent,\n data = _this$props4.data,\n debug = _this$props4.debug,\n getItem = _this$props4.getItem,\n getItemCount = _this$props4.getItemCount,\n getItemLayout = _this$props4.getItemLayout,\n horizontal = _this$props4.horizontal,\n renderItem = _this$props4.renderItem;\n var stickyOffset = ListHeaderComponent ? 1 : 0;\n var end = getItemCount(data) - 1;\n var prevCellKey;\n last = Math.min(end, last);\n var _loop = function _loop() {\n var item = getItem(data, ii);\n var key = _this._keyExtractor(item, ii, _this.props);\n _this._indicesToKeys.set(ii, key);\n if (stickyIndicesFromProps.has(ii + stickyOffset)) {\n stickyHeaderIndices.push(cells.length);\n }\n var shouldListenForLayout = getItemLayout == null || debug || _this._fillRateHelper.enabled();\n cells.push( /*#__PURE__*/React.createElement(CellRenderer, _extends({\n CellRendererComponent: CellRendererComponent,\n ItemSeparatorComponent: ii < end ? ItemSeparatorComponent : undefined,\n ListItemComponent: ListItemComponent,\n cellKey: key,\n horizontal: horizontal,\n index: ii,\n inversionStyle: inversionStyle,\n item: item,\n key: key,\n prevCellKey: prevCellKey,\n onUpdateSeparators: _this._onUpdateSeparators,\n onCellFocusCapture: e => _this._onCellFocusCapture(key),\n onUnmount: _this._onCellUnmount,\n ref: _ref => {\n _this._cellRefs[key] = _ref;\n },\n renderItem: renderItem\n }, shouldListenForLayout && {\n onCellLayout: _this._onCellLayout\n })));\n prevCellKey = key;\n };\n for (var ii = first; ii <= last; ii++) {\n _loop();\n }\n }\n static _constrainToItemCount(cells, props) {\n var itemCount = props.getItemCount(props.data);\n var last = Math.min(itemCount - 1, cells.last);\n var maxToRenderPerBatch = maxToRenderPerBatchOrDefault(props.maxToRenderPerBatch);\n return {\n first: clamp(0, itemCount - 1 - maxToRenderPerBatch, cells.first),\n last\n };\n }\n _isNestedWithSameOrientation() {\n var nestedContext = this.context;\n return !!(nestedContext && !!nestedContext.horizontal === horizontalOrDefault(this.props.horizontal));\n }\n _keyExtractor(item, index, props\n // $FlowFixMe[missing-local-annot]\n ) {\n if (props.keyExtractor != null) {\n return props.keyExtractor(item, index);\n }\n var key = defaultKeyExtractor(item, index);\n if (key === String(index)) {\n _usedIndexForKey = true;\n if (item.type && item.type.displayName) {\n _keylessItemComponentName = item.type.displayName;\n }\n }\n return key;\n }\n render() {\n this._checkProps(this.props);\n var _this$props5 = this.props,\n ListEmptyComponent = _this$props5.ListEmptyComponent,\n ListFooterComponent = _this$props5.ListFooterComponent,\n ListHeaderComponent = _this$props5.ListHeaderComponent;\n var _this$props6 = this.props,\n data = _this$props6.data,\n horizontal = _this$props6.horizontal;\n var inversionStyle = this.props.inverted ? horizontalOrDefault(this.props.horizontal) ? styles.horizontallyInverted : styles.verticallyInverted : null;\n var cells = [];\n var stickyIndicesFromProps = new Set(this.props.stickyHeaderIndices);\n var stickyHeaderIndices = [];\n\n // 1. Add cell for ListHeaderComponent\n if (ListHeaderComponent) {\n if (stickyIndicesFromProps.has(0)) {\n stickyHeaderIndices.push(0);\n }\n var _element = /*#__PURE__*/React.isValidElement(ListHeaderComponent) ? ListHeaderComponent :\n /*#__PURE__*/\n // $FlowFixMe[not-a-component]\n // $FlowFixMe[incompatible-type-arg]\n React.createElement(ListHeaderComponent, null);\n cells.push( /*#__PURE__*/React.createElement(VirtualizedListCellContextProvider, {\n cellKey: this._getCellKey() + '-header',\n key: \"$header\"\n }, /*#__PURE__*/React.createElement(View, {\n onLayout: this._onLayoutHeader,\n style: [inversionStyle, this.props.ListHeaderComponentStyle]\n },\n // $FlowFixMe[incompatible-type] - Typing ReactNativeComponent revealed errors\n _element)));\n }\n\n // 2a. Add a cell for ListEmptyComponent if applicable\n var itemCount = this.props.getItemCount(data);\n if (itemCount === 0 && ListEmptyComponent) {\n var _element2 = /*#__PURE__*/React.isValidElement(ListEmptyComponent) ? ListEmptyComponent :\n /*#__PURE__*/\n // $FlowFixMe[not-a-component]\n // $FlowFixMe[incompatible-type-arg]\n React.createElement(ListEmptyComponent, null);\n cells.push( /*#__PURE__*/React.createElement(VirtualizedListCellContextProvider, {\n cellKey: this._getCellKey() + '-empty',\n key: \"$empty\"\n }, /*#__PURE__*/React.cloneElement(_element2, {\n onLayout: event => {\n this._onLayoutEmpty(event);\n if (_element2.props.onLayout) {\n _element2.props.onLayout(event);\n }\n },\n style: [inversionStyle, _element2.props.style]\n })));\n }\n\n // 2b. Add cells and spacers for each item\n if (itemCount > 0) {\n _usedIndexForKey = false;\n _keylessItemComponentName = '';\n var spacerKey = this._getSpacerKey(!horizontal);\n var renderRegions = this.state.renderMask.enumerateRegions();\n var lastSpacer = findLastWhere(renderRegions, r => r.isSpacer);\n for (var _iterator = _createForOfIteratorHelperLoose(renderRegions), _step; !(_step = _iterator()).done;) {\n var section = _step.value;\n if (section.isSpacer) {\n // Legacy behavior is to avoid spacers when virtualization is\n // disabled (including head spacers on initial render).\n if (this.props.disableVirtualization) {\n continue;\n }\n\n // Without getItemLayout, we limit our tail spacer to the _highestMeasuredFrameIndex to\n // prevent the user for hyperscrolling into un-measured area because otherwise content will\n // likely jump around as it renders in above the viewport.\n var isLastSpacer = section === lastSpacer;\n var constrainToMeasured = isLastSpacer && !this.props.getItemLayout;\n var last = constrainToMeasured ? clamp(section.first - 1, section.last, this._highestMeasuredFrameIndex) : section.last;\n var firstMetrics = this.__getFrameMetricsApprox(section.first, this.props);\n var lastMetrics = this.__getFrameMetricsApprox(last, this.props);\n var spacerSize = lastMetrics.offset + lastMetrics.length - firstMetrics.offset;\n cells.push( /*#__PURE__*/React.createElement(View, {\n key: \"$spacer-\" + section.first,\n style: {\n [spacerKey]: spacerSize\n }\n }));\n } else {\n this._pushCells(cells, stickyHeaderIndices, stickyIndicesFromProps, section.first, section.last, inversionStyle);\n }\n }\n if (!this._hasWarned.keys && _usedIndexForKey) {\n console.warn('VirtualizedList: missing keys for items, make sure to specify a key or id property on each ' + 'item or provide a custom keyExtractor.', _keylessItemComponentName);\n this._hasWarned.keys = true;\n }\n }\n\n // 3. Add cell for ListFooterComponent\n if (ListFooterComponent) {\n var _element3 = /*#__PURE__*/React.isValidElement(ListFooterComponent) ? ListFooterComponent :\n /*#__PURE__*/\n // $FlowFixMe[not-a-component]\n // $FlowFixMe[incompatible-type-arg]\n React.createElement(ListFooterComponent, null);\n cells.push( /*#__PURE__*/React.createElement(VirtualizedListCellContextProvider, {\n cellKey: this._getFooterCellKey(),\n key: \"$footer\"\n }, /*#__PURE__*/React.createElement(View, {\n onLayout: this._onLayoutFooter,\n style: [inversionStyle, this.props.ListFooterComponentStyle]\n },\n // $FlowFixMe[incompatible-type] - Typing ReactNativeComponent revealed errors\n _element3)));\n }\n\n // 4. Render the ScrollView\n var scrollProps = _objectSpread(_objectSpread({}, this.props), {}, {\n onContentSizeChange: this._onContentSizeChange,\n onLayout: this._onLayout,\n onScroll: this._onScroll,\n onScrollBeginDrag: this._onScrollBeginDrag,\n onScrollEndDrag: this._onScrollEndDrag,\n onMomentumScrollBegin: this._onMomentumScrollBegin,\n onMomentumScrollEnd: this._onMomentumScrollEnd,\n scrollEventThrottle: scrollEventThrottleOrDefault(this.props.scrollEventThrottle),\n // TODO: Android support\n invertStickyHeaders: this.props.invertStickyHeaders !== undefined ? this.props.invertStickyHeaders : this.props.inverted,\n stickyHeaderIndices,\n style: inversionStyle ? [inversionStyle, this.props.style] : this.props.style\n });\n this._hasMore = this.state.cellsAroundViewport.last < itemCount - 1;\n var innerRet = /*#__PURE__*/React.createElement(VirtualizedListContextProvider, {\n value: {\n cellKey: null,\n getScrollMetrics: this._getScrollMetrics,\n horizontal: horizontalOrDefault(this.props.horizontal),\n getOutermostParentListRef: this._getOutermostParentListRef,\n registerAsNestedChild: this._registerAsNestedChild,\n unregisterAsNestedChild: this._unregisterAsNestedChild\n }\n }, /*#__PURE__*/React.cloneElement((this.props.renderScrollComponent || this._defaultRenderScrollComponent)(scrollProps), {\n ref: this._captureScrollRef\n }, cells));\n var ret = innerRet;\n /* https://github.com/necolas/react-native-web/issues/2239: Re-enable when ScrollView.Context.Consumer is available.\n if (__DEV__) {\n ret = (\n \n {scrollContext => {\n if (\n scrollContext != null &&\n !scrollContext.horizontal ===\n !horizontalOrDefault(this.props.horizontal) &&\n !this._hasWarned.nesting &&\n this.context == null &&\n this.props.scrollEnabled !== false\n ) {\n // TODO (T46547044): use React.warn once 16.9 is sync'd: https://github.com/facebook/react/pull/15170\n console.error(\n 'VirtualizedLists should never be nested inside plain ScrollViews with the same ' +\n 'orientation because it can break windowing and other functionality - use another ' +\n 'VirtualizedList-backed container instead.',\n );\n this._hasWarned.nesting = true;\n }\n return innerRet;\n }}\n \n );\n }*/\n if (this.props.debug) {\n return /*#__PURE__*/React.createElement(View, {\n style: styles.debug\n }, ret, this._renderDebugOverlay());\n } else {\n return ret;\n }\n }\n componentDidUpdate(prevProps) {\n var _this$props7 = this.props,\n data = _this$props7.data,\n extraData = _this$props7.extraData;\n if (data !== prevProps.data || extraData !== prevProps.extraData) {\n // clear the viewableIndices cache to also trigger\n // the onViewableItemsChanged callback with the new data\n this._viewabilityTuples.forEach(tuple => {\n tuple.viewabilityHelper.resetViewableIndices();\n });\n }\n // The `this._hiPriInProgress` is guaranteeing a hiPri cell update will only happen\n // once per fiber update. The `_scheduleCellsToRenderUpdate` will set it to true\n // if a hiPri update needs to perform. If `componentDidUpdate` is triggered with\n // `this._hiPriInProgress=true`, means it's triggered by the hiPri update. The\n // `_scheduleCellsToRenderUpdate` will check this condition and not perform\n // another hiPri update.\n var hiPriInProgress = this._hiPriInProgress;\n this._scheduleCellsToRenderUpdate();\n // Make sure setting `this._hiPriInProgress` back to false after `componentDidUpdate`\n // is triggered with `this._hiPriInProgress = true`\n if (hiPriInProgress) {\n this._hiPriInProgress = false;\n }\n }\n\n // Used for preventing scrollToIndex from being called multiple times for initialScrollIndex\n\n // flag to prevent infinite hiPri cell limit update\n\n // $FlowFixMe[missing-local-annot]\n\n /* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\n\n _computeBlankness() {\n this._fillRateHelper.computeBlankness(this.props, this.state.cellsAroundViewport, this._scrollMetrics);\n }\n\n /* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\n\n _onCellFocusCapture(cellKey) {\n this._lastFocusedCellKey = cellKey;\n this._updateCellsToRender();\n }\n _triggerRemeasureForChildListsInCell(cellKey) {\n this._nestedChildLists.forEachInCell(cellKey, childList => {\n childList.measureLayoutRelativeToContainingList();\n });\n }\n measureLayoutRelativeToContainingList() {\n // TODO (T35574538): findNodeHandle sometimes crashes with \"Unable to find\n // node on an unmounted component\" during scrolling\n try {\n if (!this._scrollRef) {\n return;\n }\n // We are assuming that getOutermostParentListRef().getScrollRef()\n // is a non-null reference to a ScrollView\n this._scrollRef.measureLayout(this.context.getOutermostParentListRef().getScrollRef(), (x, y, width, height) => {\n this._offsetFromParentVirtualizedList = this._selectOffset({\n x,\n y\n });\n this._scrollMetrics.contentLength = this._selectLength({\n width,\n height\n });\n var scrollMetrics = this._convertParentScrollMetrics(this.context.getScrollMetrics());\n var metricsChanged = this._scrollMetrics.visibleLength !== scrollMetrics.visibleLength || this._scrollMetrics.offset !== scrollMetrics.offset;\n if (metricsChanged) {\n this._scrollMetrics.visibleLength = scrollMetrics.visibleLength;\n this._scrollMetrics.offset = scrollMetrics.offset;\n\n // If metrics of the scrollView changed, then we triggered remeasure for child list\n // to ensure VirtualizedList has the right information.\n this._nestedChildLists.forEach(childList => {\n childList.measureLayoutRelativeToContainingList();\n });\n }\n }, error => {\n console.warn(\"VirtualizedList: Encountered an error while measuring a list's\" + ' offset from its containing VirtualizedList.');\n });\n } catch (error) {\n console.warn('measureLayoutRelativeToContainingList threw an error', error.stack);\n }\n }\n _getFooterCellKey() {\n return this._getCellKey() + '-footer';\n }\n // $FlowFixMe[missing-local-annot]\n _renderDebugOverlay() {\n var normalize = this._scrollMetrics.visibleLength / (this._scrollMetrics.contentLength || 1);\n var framesInLayout = [];\n var itemCount = this.props.getItemCount(this.props.data);\n for (var ii = 0; ii < itemCount; ii++) {\n var frame = this.__getFrameMetricsApprox(ii, this.props);\n /* $FlowFixMe[prop-missing] (>=0.68.0 site=react_native_fb) This comment\n * suppresses an error found when Flow v0.68 was deployed. To see the\n * error delete this comment and run Flow. */\n if (frame.inLayout) {\n framesInLayout.push(frame);\n }\n }\n var windowTop = this.__getFrameMetricsApprox(this.state.cellsAroundViewport.first, this.props).offset;\n var frameLast = this.__getFrameMetricsApprox(this.state.cellsAroundViewport.last, this.props);\n var windowLen = frameLast.offset + frameLast.length - windowTop;\n var visTop = this._scrollMetrics.offset;\n var visLen = this._scrollMetrics.visibleLength;\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.debugOverlayBase, styles.debugOverlay]\n }, framesInLayout.map((f, ii) => /*#__PURE__*/React.createElement(View, {\n key: 'f' + ii,\n style: [styles.debugOverlayBase, styles.debugOverlayFrame, {\n top: f.offset * normalize,\n height: f.length * normalize\n }]\n })), /*#__PURE__*/React.createElement(View, {\n style: [styles.debugOverlayBase, styles.debugOverlayFrameLast, {\n top: windowTop * normalize,\n height: windowLen * normalize\n }]\n }), /*#__PURE__*/React.createElement(View, {\n style: [styles.debugOverlayBase, styles.debugOverlayFrameVis, {\n top: visTop * normalize,\n height: visLen * normalize\n }]\n }));\n }\n _selectLength(metrics) {\n return !horizontalOrDefault(this.props.horizontal) ? metrics.height : metrics.width;\n }\n _selectOffset(metrics) {\n return !horizontalOrDefault(this.props.horizontal) ? metrics.y : metrics.x;\n }\n _maybeCallOnEdgeReached() {\n var _this$props8 = this.props,\n data = _this$props8.data,\n getItemCount = _this$props8.getItemCount,\n onStartReached = _this$props8.onStartReached,\n onStartReachedThreshold = _this$props8.onStartReachedThreshold,\n onEndReached = _this$props8.onEndReached,\n onEndReachedThreshold = _this$props8.onEndReachedThreshold,\n initialScrollIndex = _this$props8.initialScrollIndex;\n var _this$_scrollMetrics2 = this._scrollMetrics,\n contentLength = _this$_scrollMetrics2.contentLength,\n visibleLength = _this$_scrollMetrics2.visibleLength,\n offset = _this$_scrollMetrics2.offset;\n var distanceFromStart = offset;\n var distanceFromEnd = contentLength - visibleLength - offset;\n\n // Especially when oERT is zero it's necessary to 'floor' very small distance values to be 0\n // since debouncing causes us to not fire this event for every single \"pixel\" we scroll and can thus\n // be at the edge of the list with a distance approximating 0 but not quite there.\n if (distanceFromStart < ON_EDGE_REACHED_EPSILON) {\n distanceFromStart = 0;\n }\n if (distanceFromEnd < ON_EDGE_REACHED_EPSILON) {\n distanceFromEnd = 0;\n }\n\n // TODO: T121172172 Look into why we're \"defaulting\" to a threshold of 2px\n // when oERT is not present (different from 2 viewports used elsewhere)\n var DEFAULT_THRESHOLD_PX = 2;\n var startThreshold = onStartReachedThreshold != null ? onStartReachedThreshold * visibleLength : DEFAULT_THRESHOLD_PX;\n var endThreshold = onEndReachedThreshold != null ? onEndReachedThreshold * visibleLength : DEFAULT_THRESHOLD_PX;\n var isWithinStartThreshold = distanceFromStart <= startThreshold;\n var isWithinEndThreshold = distanceFromEnd <= endThreshold;\n\n // First check if the user just scrolled within the end threshold\n // and call onEndReached only once for a given content length,\n // and only if onStartReached is not being executed\n if (onEndReached && this.state.cellsAroundViewport.last === getItemCount(data) - 1 && isWithinEndThreshold && this._scrollMetrics.contentLength !== this._sentEndForContentLength) {\n this._sentEndForContentLength = this._scrollMetrics.contentLength;\n onEndReached({\n distanceFromEnd\n });\n }\n\n // Next check if the user just scrolled within the start threshold\n // and call onStartReached only once for a given content length,\n // and only if onEndReached is not being executed\n else if (onStartReached != null && this.state.cellsAroundViewport.first === 0 && isWithinStartThreshold && this._scrollMetrics.contentLength !== this._sentStartForContentLength) {\n // On initial mount when using initialScrollIndex the offset will be 0 initially\n // and will trigger an unexpected onStartReached. To avoid this we can use\n // timestamp to differentiate between the initial scroll metrics and when we actually\n // received the first scroll event.\n if (!initialScrollIndex || this._scrollMetrics.timestamp !== 0) {\n this._sentStartForContentLength = this._scrollMetrics.contentLength;\n onStartReached({\n distanceFromStart\n });\n }\n }\n\n // If the user scrolls away from the start or end and back again,\n // cause onStartReached or onEndReached to be triggered again\n else {\n this._sentStartForContentLength = isWithinStartThreshold ? this._sentStartForContentLength : 0;\n this._sentEndForContentLength = isWithinEndThreshold ? this._sentEndForContentLength : 0;\n }\n }\n\n /* Translates metrics from a scroll event in a parent VirtualizedList into\n * coordinates relative to the child list.\n */\n\n _scheduleCellsToRenderUpdate() {\n var _this$state$cellsArou = this.state.cellsAroundViewport,\n first = _this$state$cellsArou.first,\n last = _this$state$cellsArou.last;\n var _this$_scrollMetrics3 = this._scrollMetrics,\n offset = _this$_scrollMetrics3.offset,\n visibleLength = _this$_scrollMetrics3.visibleLength,\n velocity = _this$_scrollMetrics3.velocity;\n var itemCount = this.props.getItemCount(this.props.data);\n var hiPri = false;\n var onStartReachedThreshold = onStartReachedThresholdOrDefault(this.props.onStartReachedThreshold);\n var onEndReachedThreshold = onEndReachedThresholdOrDefault(this.props.onEndReachedThreshold);\n // Mark as high priority if we're close to the start of the first item\n // But only if there are items before the first rendered item\n if (first > 0) {\n var distTop = offset - this.__getFrameMetricsApprox(first, this.props).offset;\n hiPri = distTop < 0 || velocity < -2 && distTop < getScrollingThreshold(onStartReachedThreshold, visibleLength);\n }\n // Mark as high priority if we're close to the end of the last item\n // But only if there are items after the last rendered item\n if (!hiPri && last >= 0 && last < itemCount - 1) {\n var distBottom = this.__getFrameMetricsApprox(last, this.props).offset - (offset + visibleLength);\n hiPri = distBottom < 0 || velocity > 2 && distBottom < getScrollingThreshold(onEndReachedThreshold, visibleLength);\n }\n // Only trigger high-priority updates if we've actually rendered cells,\n // and with that size estimate, accurately compute how many cells we should render.\n // Otherwise, it would just render as many cells as it can (of zero dimension),\n // each time through attempting to render more (limited by maxToRenderPerBatch),\n // starving the renderer from actually laying out the objects and computing _averageCellLength.\n // If this is triggered in an `componentDidUpdate` followed by a hiPri cellToRenderUpdate\n // We shouldn't do another hipri cellToRenderUpdate\n if (hiPri && (this._averageCellLength || this.props.getItemLayout) && !this._hiPriInProgress) {\n this._hiPriInProgress = true;\n // Don't worry about interactions when scrolling quickly; focus on filling content as fast\n // as possible.\n this._updateCellsToRenderBatcher.dispose({\n abort: true\n });\n this._updateCellsToRender();\n return;\n } else {\n this._updateCellsToRenderBatcher.schedule();\n }\n }\n\n /**\n * Gets an approximate offset to an item at a given index. Supports\n * fractional indices.\n */\n\n _updateViewableItems(props, cellsAroundViewport) {\n this._viewabilityTuples.forEach(tuple => {\n tuple.viewabilityHelper.onUpdate(props, this._scrollMetrics.offset, this._scrollMetrics.visibleLength, this._getFrameMetrics, this._createViewToken, tuple.onViewableItemsChanged, cellsAroundViewport);\n });\n }\n}\nVirtualizedList.contextType = VirtualizedListContext;\nvar styles = StyleSheet.create({\n verticallyInverted: {\n transform: 'scaleY(-1)'\n },\n horizontallyInverted: {\n transform: 'scaleX(-1)'\n },\n debug: {\n flex: 1\n },\n debugOverlayBase: {\n position: 'absolute',\n top: 0,\n right: 0\n },\n debugOverlay: {\n bottom: 0,\n width: 20,\n borderColor: 'blue',\n borderWidth: 1\n },\n debugOverlayFrame: {\n left: 0,\n backgroundColor: 'orange'\n },\n debugOverlayFrameLast: {\n left: 0,\n borderColor: 'green',\n borderWidth: 2\n },\n debugOverlayFrameVis: {\n left: 0,\n borderColor: 'red',\n borderWidth: 2\n }\n});\nexport default VirtualizedList;","var unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nfunction _createForOfIteratorHelperLoose(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (it) return (it = it.call(o)).next.bind(it);\n if (Array.isArray(o) || (it = unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n return function () {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _createForOfIteratorHelperLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n return arr2;\n}\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"colors\", \"enabled\", \"onRefresh\", \"progressBackgroundColor\", \"progressViewOffset\", \"refreshing\", \"size\", \"tintColor\", \"title\", \"titleColor\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport View from '../View';\nimport React from 'react';\nfunction RefreshControl(props) {\n var colors = props.colors,\n enabled = props.enabled,\n onRefresh = props.onRefresh,\n progressBackgroundColor = props.progressBackgroundColor,\n progressViewOffset = props.progressViewOffset,\n refreshing = props.refreshing,\n size = props.size,\n tintColor = props.tintColor,\n title = props.title,\n titleColor = props.titleColor,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n return /*#__PURE__*/React.createElement(View, rest);\n}\nexport default RefreshControl;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * \n */\n\n'use strict';\n\nimport InteractionManager from '../../../exports/InteractionManager';\n\n/**\n * A simple class for batching up invocations of a low-pri callback. A timeout is set to run the\n * callback once after a delay, no matter how many times it's scheduled. Once the delay is reached,\n * InteractionManager.runAfterInteractions is used to invoke the callback after any hi-pri\n * interactions are done running.\n *\n * Make sure to cleanup with dispose(). Example:\n *\n * class Widget extends React.Component {\n * _batchedSave: new Batchinator(() => this._saveState, 1000);\n * _saveSate() {\n * // save this.state to disk\n * }\n * componentDidUpdate() {\n * this._batchedSave.schedule();\n * }\n * componentWillUnmount() {\n * this._batchedSave.dispose();\n * }\n * ...\n * }\n */\nclass Batchinator {\n constructor(callback, delayMS) {\n this._delay = delayMS;\n this._callback = callback;\n }\n /*\n * Cleanup any pending tasks.\n *\n * By default, if there is a pending task the callback is run immediately. Set the option abort to\n * true to not call the callback if it was pending.\n */\n dispose(options) {\n if (options === void 0) {\n options = {\n abort: false\n };\n }\n if (this._taskHandle) {\n this._taskHandle.cancel();\n if (!options.abort) {\n this._callback();\n }\n this._taskHandle = null;\n }\n }\n schedule() {\n if (this._taskHandle) {\n return;\n }\n var timeoutHandle = setTimeout(() => {\n this._taskHandle = InteractionManager.runAfterInteractions(() => {\n // Note that we clear the handle before invoking the callback so that if the callback calls\n // schedule again, it will actually schedule another task.\n this._taskHandle = null;\n this._callback();\n });\n }, this._delay);\n this._taskHandle = {\n cancel: () => clearTimeout(timeoutHandle)\n };\n }\n}\nexport default Batchinator;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport invariant from 'fbjs/lib/invariant';\nimport TaskQueue from './TaskQueue';\nimport EventEmitter from '../../vendor/react-native/vendor/emitter/EventEmitter';\nimport requestIdleCallback from '../../modules/requestIdleCallback';\nvar _emitter = new EventEmitter();\nvar InteractionManager = {\n Events: {\n interactionStart: 'interactionStart',\n interactionComplete: 'interactionComplete'\n },\n /**\n * Schedule a function to run after all interactions have completed.\n */\n runAfterInteractions(task) {\n var tasks = [];\n var promise = new Promise(resolve => {\n _scheduleUpdate();\n if (task) {\n tasks.push(task);\n }\n tasks.push({\n run: resolve,\n name: 'resolve ' + (task && task.name || '?')\n });\n _taskQueue.enqueueTasks(tasks);\n });\n return {\n then: promise.then.bind(promise),\n done: promise.then.bind(promise),\n cancel: () => {\n _taskQueue.cancelTasks(tasks);\n }\n };\n },\n /**\n * Notify manager that an interaction has started.\n */\n createInteractionHandle() {\n _scheduleUpdate();\n var handle = ++_inc;\n _addInteractionSet.add(handle);\n return handle;\n },\n /**\n * Notify manager that an interaction has completed.\n */\n clearInteractionHandle(handle) {\n invariant(!!handle, 'Must provide a handle to clear.');\n _scheduleUpdate();\n _addInteractionSet.delete(handle);\n _deleteInteractionSet.add(handle);\n },\n addListener: _emitter.addListener.bind(_emitter),\n /**\n *\n * @param deadline\n */\n setDeadline(deadline) {\n _deadline = deadline;\n }\n};\nvar _interactionSet = new Set();\nvar _addInteractionSet = new Set();\nvar _deleteInteractionSet = new Set();\nvar _taskQueue = new TaskQueue({\n onMoreTasks: _scheduleUpdate\n});\nvar _nextUpdateHandle = 0;\nvar _inc = 0;\nvar _deadline = -1;\n\n/**\n * Schedule an asynchronous update to the interaction state.\n */\nfunction _scheduleUpdate() {\n if (!_nextUpdateHandle) {\n if (_deadline > 0) {\n _nextUpdateHandle = setTimeout(_processUpdate);\n } else {\n _nextUpdateHandle = requestIdleCallback(_processUpdate);\n }\n }\n}\n\n/**\n * Notify listeners, process queue, etc\n */\nfunction _processUpdate() {\n _nextUpdateHandle = 0;\n var interactionCount = _interactionSet.size;\n _addInteractionSet.forEach(handle => _interactionSet.add(handle));\n _deleteInteractionSet.forEach(handle => _interactionSet.delete(handle));\n var nextInteractionCount = _interactionSet.size;\n if (interactionCount !== 0 && nextInteractionCount === 0) {\n _emitter.emit(InteractionManager.Events.interactionComplete);\n } else if (interactionCount === 0 && nextInteractionCount !== 0) {\n _emitter.emit(InteractionManager.Events.interactionStart);\n }\n if (nextInteractionCount === 0) {\n // It seems that we can't know the running time of the current event loop,\n // we can only calculate the running time of the current task queue.\n var begin = Date.now();\n while (_taskQueue.hasTasksToProcess()) {\n _taskQueue.processNext();\n if (_deadline > 0 && Date.now() - begin >= _deadline) {\n _scheduleUpdate();\n break;\n }\n }\n }\n _addInteractionSet.clear();\n _deleteInteractionSet.clear();\n}\nexport default InteractionManager;","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport invariant from 'fbjs/lib/invariant';\nclass TaskQueue {\n constructor(_ref) {\n var onMoreTasks = _ref.onMoreTasks;\n this._onMoreTasks = onMoreTasks;\n this._queueStack = [{\n tasks: [],\n popable: true\n }];\n }\n enqueue(task) {\n this._getCurrentQueue().push(task);\n }\n enqueueTasks(tasks) {\n tasks.forEach(task => this.enqueue(task));\n }\n cancelTasks(tasksToCancel) {\n this._queueStack = this._queueStack.map(queue => _objectSpread(_objectSpread({}, queue), {}, {\n tasks: queue.tasks.filter(task => tasksToCancel.indexOf(task) === -1)\n })).filter((queue, idx) => queue.tasks.length > 0 || idx === 0);\n }\n hasTasksToProcess() {\n return this._getCurrentQueue().length > 0;\n }\n\n /**\n * Executes the next task in the queue.\n */\n processNext() {\n var queue = this._getCurrentQueue();\n if (queue.length) {\n var task = queue.shift();\n try {\n if (typeof task === 'object' && task.gen) {\n this._genPromise(task);\n } else if (typeof task === 'object' && task.run) {\n task.run();\n } else {\n invariant(typeof task === 'function', 'Expected Function, SimpleTask, or PromiseTask, but got:\\n' + JSON.stringify(task, null, 2));\n task();\n }\n } catch (e) {\n e.message = 'TaskQueue: Error with task ' + (task.name || '') + ': ' + e.message;\n throw e;\n }\n }\n }\n _getCurrentQueue() {\n var stackIdx = this._queueStack.length - 1;\n var queue = this._queueStack[stackIdx];\n if (queue.popable && queue.tasks.length === 0 && stackIdx > 0) {\n this._queueStack.pop();\n return this._getCurrentQueue();\n } else {\n return queue.tasks;\n }\n }\n _genPromise(task) {\n var length = this._queueStack.push({\n tasks: [],\n popable: false\n });\n var stackIdx = length - 1;\n var stackItem = this._queueStack[stackIdx];\n task.gen().then(() => {\n stackItem.popable = true;\n this.hasTasksToProcess() && this._onMoreTasks();\n }).catch(ex => {\n setTimeout(() => {\n ex.message = \"TaskQueue: Error resolving Promise in task \" + task.name + \": \" + ex.message;\n throw ex;\n }, 0);\n });\n }\n}\nexport default TaskQueue;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\nimport canUseDOM from '../canUseDom';\nvar _requestIdleCallback = function _requestIdleCallback(cb, options) {\n return setTimeout(() => {\n var start = Date.now();\n cb({\n didTimeout: false,\n timeRemaining() {\n return Math.max(0, 50 - (Date.now() - start));\n }\n });\n }, 1);\n};\nvar _cancelIdleCallback = function _cancelIdleCallback(id) {\n clearTimeout(id);\n};\nvar isSupported = canUseDOM && typeof window.requestIdleCallback !== 'undefined';\nvar requestIdleCallback = isSupported ? window.requestIdleCallback : _requestIdleCallback;\nvar cancelIdleCallback = isSupported ? window.cancelIdleCallback : _cancelIdleCallback;\nexport default requestIdleCallback;\nexport { cancelIdleCallback };","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * \n */\n\n'use strict';\n\nfunction clamp(min, value, max) {\n if (value < min) {\n return min;\n }\n if (value > max) {\n return max;\n }\n return value;\n}\nexport default clamp;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * \n */\n\n'use strict';\n\n/**\n * Intentional info-level logging for clear separation from ad-hoc console debug logging.\n */\nfunction infoLog() {\n return console.log(...arguments);\n}\nexport default infoLog;","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport invariant from 'fbjs/lib/invariant';\nexport class CellRenderMask {\n constructor(numCells) {\n invariant(numCells >= 0, 'CellRenderMask must contain a non-negative number os cells');\n this._numCells = numCells;\n if (numCells === 0) {\n this._regions = [];\n } else {\n this._regions = [{\n first: 0,\n last: numCells - 1,\n isSpacer: true\n }];\n }\n }\n enumerateRegions() {\n return this._regions;\n }\n addCells(cells) {\n invariant(cells.first >= 0 && cells.first < this._numCells && cells.last >= -1 && cells.last < this._numCells && cells.last >= cells.first - 1, 'CellRenderMask.addCells called with invalid cell range');\n\n // VirtualizedList uses inclusive ranges, where zero-count states are\n // possible. E.g. [0, -1] for no cells, starting at 0.\n if (cells.last < cells.first) {\n return;\n }\n var _this$_findRegion = this._findRegion(cells.first),\n firstIntersect = _this$_findRegion[0],\n firstIntersectIdx = _this$_findRegion[1];\n var _this$_findRegion2 = this._findRegion(cells.last),\n lastIntersect = _this$_findRegion2[0],\n lastIntersectIdx = _this$_findRegion2[1];\n\n // Fast-path if the cells to add are already all present in the mask. We\n // will otherwise need to do some mutation.\n if (firstIntersectIdx === lastIntersectIdx && !firstIntersect.isSpacer) {\n return;\n }\n\n // We need to replace the existing covered regions with 1-3 new regions\n // depending whether we need to split spacers out of overlapping regions.\n var newLeadRegion = [];\n var newTailRegion = [];\n var newMainRegion = _objectSpread(_objectSpread({}, cells), {}, {\n isSpacer: false\n });\n if (firstIntersect.first < newMainRegion.first) {\n if (firstIntersect.isSpacer) {\n newLeadRegion.push({\n first: firstIntersect.first,\n last: newMainRegion.first - 1,\n isSpacer: true\n });\n } else {\n newMainRegion.first = firstIntersect.first;\n }\n }\n if (lastIntersect.last > newMainRegion.last) {\n if (lastIntersect.isSpacer) {\n newTailRegion.push({\n first: newMainRegion.last + 1,\n last: lastIntersect.last,\n isSpacer: true\n });\n } else {\n newMainRegion.last = lastIntersect.last;\n }\n }\n var replacementRegions = [...newLeadRegion, newMainRegion, ...newTailRegion];\n var numRegionsToDelete = lastIntersectIdx - firstIntersectIdx + 1;\n this._regions.splice(firstIntersectIdx, numRegionsToDelete, ...replacementRegions);\n }\n numCells() {\n return this._numCells;\n }\n equals(other) {\n return this._numCells === other._numCells && this._regions.length === other._regions.length && this._regions.every((region, i) => region.first === other._regions[i].first && region.last === other._regions[i].last && region.isSpacer === other._regions[i].isSpacer);\n }\n _findRegion(cellIdx) {\n var firstIdx = 0;\n var lastIdx = this._regions.length - 1;\n while (firstIdx <= lastIdx) {\n var middleIdx = Math.floor((firstIdx + lastIdx) / 2);\n var middleRegion = this._regions[middleIdx];\n if (cellIdx >= middleRegion.first && cellIdx <= middleRegion.last) {\n return [middleRegion, middleIdx];\n } else if (cellIdx < middleRegion.first) {\n lastIdx = middleIdx - 1;\n } else if (cellIdx > middleRegion.last) {\n firstIdx = middleIdx + 1;\n }\n }\n invariant(false, \"A region was not found containing cellIdx \" + cellIdx);\n }\n}","import _createForOfIteratorHelperLoose from \"@babel/runtime/helpers/createForOfIteratorHelperLoose\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport invariant from 'fbjs/lib/invariant';\nexport default class ChildListCollection {\n constructor() {\n this._cellKeyToChildren = new Map();\n this._childrenToCellKey = new Map();\n }\n add(list, cellKey) {\n var _this$_cellKeyToChild;\n invariant(!this._childrenToCellKey.has(list), 'Trying to add already present child list');\n var cellLists = (_this$_cellKeyToChild = this._cellKeyToChildren.get(cellKey)) !== null && _this$_cellKeyToChild !== void 0 ? _this$_cellKeyToChild : new Set();\n cellLists.add(list);\n this._cellKeyToChildren.set(cellKey, cellLists);\n this._childrenToCellKey.set(list, cellKey);\n }\n remove(list) {\n var cellKey = this._childrenToCellKey.get(list);\n invariant(cellKey != null, 'Trying to remove non-present child list');\n this._childrenToCellKey.delete(list);\n var cellLists = this._cellKeyToChildren.get(cellKey);\n invariant(cellLists, '_cellKeyToChildren should contain cellKey');\n cellLists.delete(list);\n if (cellLists.size === 0) {\n this._cellKeyToChildren.delete(cellKey);\n }\n }\n forEach(fn) {\n for (var _iterator = _createForOfIteratorHelperLoose(this._cellKeyToChildren.values()), _step; !(_step = _iterator()).done;) {\n var listSet = _step.value;\n for (var _iterator2 = _createForOfIteratorHelperLoose(listSet), _step2; !(_step2 = _iterator2()).done;) {\n var list = _step2.value;\n fn(list);\n }\n }\n }\n forEachInCell(cellKey, fn) {\n var _this$_cellKeyToChild2;\n var listSet = (_this$_cellKeyToChild2 = this._cellKeyToChildren.get(cellKey)) !== null && _this$_cellKeyToChild2 !== void 0 ? _this$_cellKeyToChild2 : [];\n for (var _iterator3 = _createForOfIteratorHelperLoose(listSet), _step3; !(_step3 = _iterator3()).done;) {\n var list = _step3.value;\n fn(list);\n }\n }\n anyInCell(cellKey, fn) {\n var _this$_cellKeyToChild3;\n var listSet = (_this$_cellKeyToChild3 = this._cellKeyToChildren.get(cellKey)) !== null && _this$_cellKeyToChild3 !== void 0 ? _this$_cellKeyToChild3 : [];\n for (var _iterator4 = _createForOfIteratorHelperLoose(listSet), _step4; !(_step4 = _iterator4()).done;) {\n var list = _step4.value;\n if (fn(list)) {\n return true;\n }\n }\n return false;\n }\n size() {\n return this._childrenToCellKey.size;\n }\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nclass Info {\n constructor() {\n this.any_blank_count = 0;\n this.any_blank_ms = 0;\n this.any_blank_speed_sum = 0;\n this.mostly_blank_count = 0;\n this.mostly_blank_ms = 0;\n this.pixels_blank = 0;\n this.pixels_sampled = 0;\n this.pixels_scrolled = 0;\n this.total_time_spent = 0;\n this.sample_count = 0;\n }\n}\nvar DEBUG = false;\nvar _listeners = [];\nvar _minSampleCount = 10;\nvar _sampleRate = DEBUG ? 1 : null;\n\n/**\n * A helper class for detecting when the maximem fill rate of `VirtualizedList` is exceeded.\n * By default the sampling rate is set to zero and this will do nothing. If you want to collect\n * samples (e.g. to log them), make sure to call `FillRateHelper.setSampleRate(0.0-1.0)`.\n *\n * Listeners and sample rate are global for all `VirtualizedList`s - typical usage will combine with\n * `SceneTracker.getActiveScene` to determine the context of the events.\n */\nclass FillRateHelper {\n static addListener(callback) {\n if (_sampleRate === null) {\n console.warn('Call `FillRateHelper.setSampleRate` before `addListener`.');\n }\n _listeners.push(callback);\n return {\n remove: () => {\n _listeners = _listeners.filter(listener => callback !== listener);\n }\n };\n }\n static setSampleRate(sampleRate) {\n _sampleRate = sampleRate;\n }\n static setMinSampleCount(minSampleCount) {\n _minSampleCount = minSampleCount;\n }\n constructor(getFrameMetrics) {\n this._anyBlankStartTime = null;\n this._enabled = false;\n this._info = new Info();\n this._mostlyBlankStartTime = null;\n this._samplesStartTime = null;\n this._getFrameMetrics = getFrameMetrics;\n this._enabled = (_sampleRate || 0) > Math.random();\n this._resetData();\n }\n activate() {\n if (this._enabled && this._samplesStartTime == null) {\n DEBUG && console.debug('FillRateHelper: activate');\n this._samplesStartTime = global.performance.now();\n }\n }\n deactivateAndFlush() {\n if (!this._enabled) {\n return;\n }\n var start = this._samplesStartTime; // const for flow\n if (start == null) {\n DEBUG && console.debug('FillRateHelper: bail on deactivate with no start time');\n return;\n }\n if (this._info.sample_count < _minSampleCount) {\n // Don't bother with under-sampled events.\n this._resetData();\n return;\n }\n var total_time_spent = global.performance.now() - start;\n var info = _objectSpread(_objectSpread({}, this._info), {}, {\n total_time_spent\n });\n if (DEBUG) {\n var derived = {\n avg_blankness: this._info.pixels_blank / this._info.pixels_sampled,\n avg_speed: this._info.pixels_scrolled / (total_time_spent / 1000),\n avg_speed_when_any_blank: this._info.any_blank_speed_sum / this._info.any_blank_count,\n any_blank_per_min: this._info.any_blank_count / (total_time_spent / 1000 / 60),\n any_blank_time_frac: this._info.any_blank_ms / total_time_spent,\n mostly_blank_per_min: this._info.mostly_blank_count / (total_time_spent / 1000 / 60),\n mostly_blank_time_frac: this._info.mostly_blank_ms / total_time_spent\n };\n for (var key in derived) {\n // $FlowFixMe[prop-missing]\n derived[key] = Math.round(1000 * derived[key]) / 1000;\n }\n console.debug('FillRateHelper deactivateAndFlush: ', {\n derived,\n info\n });\n }\n _listeners.forEach(listener => listener(info));\n this._resetData();\n }\n computeBlankness(props, cellsAroundViewport, scrollMetrics) {\n if (!this._enabled || props.getItemCount(props.data) === 0 || cellsAroundViewport.last < cellsAroundViewport.first || this._samplesStartTime == null) {\n return 0;\n }\n var dOffset = scrollMetrics.dOffset,\n offset = scrollMetrics.offset,\n velocity = scrollMetrics.velocity,\n visibleLength = scrollMetrics.visibleLength;\n\n // Denominator metrics that we track for all events - most of the time there is no blankness and\n // we want to capture that.\n this._info.sample_count++;\n this._info.pixels_sampled += Math.round(visibleLength);\n this._info.pixels_scrolled += Math.round(Math.abs(dOffset));\n var scrollSpeed = Math.round(Math.abs(velocity) * 1000); // px / sec\n\n // Whether blank now or not, record the elapsed time blank if we were blank last time.\n var now = global.performance.now();\n if (this._anyBlankStartTime != null) {\n this._info.any_blank_ms += now - this._anyBlankStartTime;\n }\n this._anyBlankStartTime = null;\n if (this._mostlyBlankStartTime != null) {\n this._info.mostly_blank_ms += now - this._mostlyBlankStartTime;\n }\n this._mostlyBlankStartTime = null;\n var blankTop = 0;\n var first = cellsAroundViewport.first;\n var firstFrame = this._getFrameMetrics(first, props);\n while (first <= cellsAroundViewport.last && (!firstFrame || !firstFrame.inLayout)) {\n firstFrame = this._getFrameMetrics(first, props);\n first++;\n }\n // Only count blankTop if we aren't rendering the first item, otherwise we will count the header\n // as blank.\n if (firstFrame && first > 0) {\n blankTop = Math.min(visibleLength, Math.max(0, firstFrame.offset - offset));\n }\n var blankBottom = 0;\n var last = cellsAroundViewport.last;\n var lastFrame = this._getFrameMetrics(last, props);\n while (last >= cellsAroundViewport.first && (!lastFrame || !lastFrame.inLayout)) {\n lastFrame = this._getFrameMetrics(last, props);\n last--;\n }\n // Only count blankBottom if we aren't rendering the last item, otherwise we will count the\n // footer as blank.\n if (lastFrame && last < props.getItemCount(props.data) - 1) {\n var bottomEdge = lastFrame.offset + lastFrame.length;\n blankBottom = Math.min(visibleLength, Math.max(0, offset + visibleLength - bottomEdge));\n }\n var pixels_blank = Math.round(blankTop + blankBottom);\n var blankness = pixels_blank / visibleLength;\n if (blankness > 0) {\n this._anyBlankStartTime = now;\n this._info.any_blank_speed_sum += scrollSpeed;\n this._info.any_blank_count++;\n this._info.pixels_blank += pixels_blank;\n if (blankness > 0.5) {\n this._mostlyBlankStartTime = now;\n this._info.mostly_blank_count++;\n }\n } else if (scrollSpeed < 0.01 || Math.abs(dOffset) < 1) {\n this.deactivateAndFlush();\n }\n return blankness;\n }\n enabled() {\n return this._enabled;\n }\n _resetData() {\n this._anyBlankStartTime = null;\n this._info = new Info();\n this._mostlyBlankStartTime = null;\n this._samplesStartTime = null;\n }\n}\nexport default FillRateHelper;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport invariant from 'fbjs/lib/invariant';\nimport * as React from 'react';\n\n/**\n * `setState` is called asynchronously, and should not rely on the value of\n * `this.props` or `this.state`:\n * https://reactjs.org/docs/state-and-lifecycle.html#state-updates-may-be-asynchronous\n *\n * SafePureComponent adds runtime enforcement, to catch cases where these\n * variables are read in a state updater function, instead of the ones passed\n * in.\n */\nexport default class StateSafePureComponent extends React.PureComponent {\n constructor(props) {\n super(props);\n this._inAsyncStateUpdate = false;\n this._installSetStateHooks();\n }\n setState(partialState, callback) {\n if (typeof partialState === 'function') {\n super.setState((state, props) => {\n this._inAsyncStateUpdate = true;\n var ret;\n try {\n ret = partialState(state, props);\n } catch (err) {\n throw err;\n } finally {\n this._inAsyncStateUpdate = false;\n }\n return ret;\n }, callback);\n } else {\n super.setState(partialState, callback);\n }\n }\n _installSetStateHooks() {\n var that = this;\n var props = this.props,\n state = this.state;\n Object.defineProperty(this, 'props', {\n get() {\n invariant(!that._inAsyncStateUpdate, '\"this.props\" should not be accessed during state updates');\n return props;\n },\n set(newProps) {\n props = newProps;\n }\n });\n Object.defineProperty(this, 'state', {\n get() {\n invariant(!that._inAsyncStateUpdate, '\"this.state\" should not be acceessed during state updates');\n return state;\n },\n set(newState) {\n state = newState;\n }\n });\n }\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _createForOfIteratorHelperLoose from \"@babel/runtime/helpers/createForOfIteratorHelperLoose\";\nimport invariant from 'fbjs/lib/invariant';\n/**\n * A Utility class for calculating viewable items based on current metrics like scroll position and\n * layout.\n *\n * An item is said to be in a \"viewable\" state when any of the following\n * is true for longer than `minimumViewTime` milliseconds (after an interaction if `waitForInteraction`\n * is true):\n *\n * - Occupying >= `viewAreaCoveragePercentThreshold` of the view area XOR fraction of the item\n * visible in the view area >= `itemVisiblePercentThreshold`.\n * - Entirely visible on screen\n */\nclass ViewabilityHelper {\n constructor(config) {\n if (config === void 0) {\n config = {\n viewAreaCoveragePercentThreshold: 0\n };\n }\n this._hasInteracted = false;\n this._timers = new Set();\n this._viewableIndices = [];\n this._viewableItems = new Map();\n this._config = config;\n }\n\n /**\n * Cleanup, e.g. on unmount. Clears any pending timers.\n */\n dispose() {\n /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.63 was deployed. To see\n * the error delete this comment and run Flow. */\n this._timers.forEach(clearTimeout);\n }\n\n /**\n * Determines which items are viewable based on the current metrics and config.\n */\n computeViewableItems(props, scrollOffset, viewportHeight, getFrameMetrics,\n // Optional optimization to reduce the scan size\n renderRange) {\n var itemCount = props.getItemCount(props.data);\n var _this$_config = this._config,\n itemVisiblePercentThreshold = _this$_config.itemVisiblePercentThreshold,\n viewAreaCoveragePercentThreshold = _this$_config.viewAreaCoveragePercentThreshold;\n var viewAreaMode = viewAreaCoveragePercentThreshold != null;\n var viewablePercentThreshold = viewAreaMode ? viewAreaCoveragePercentThreshold : itemVisiblePercentThreshold;\n invariant(viewablePercentThreshold != null && itemVisiblePercentThreshold != null !== (viewAreaCoveragePercentThreshold != null), 'Must set exactly one of itemVisiblePercentThreshold or viewAreaCoveragePercentThreshold');\n var viewableIndices = [];\n if (itemCount === 0) {\n return viewableIndices;\n }\n var firstVisible = -1;\n var _ref = renderRange || {\n first: 0,\n last: itemCount - 1\n },\n first = _ref.first,\n last = _ref.last;\n if (last >= itemCount) {\n console.warn('Invalid render range computing viewability ' + JSON.stringify({\n renderRange,\n itemCount\n }));\n return [];\n }\n for (var idx = first; idx <= last; idx++) {\n var metrics = getFrameMetrics(idx, props);\n if (!metrics) {\n continue;\n }\n var top = metrics.offset - scrollOffset;\n var bottom = top + metrics.length;\n if (top < viewportHeight && bottom > 0) {\n firstVisible = idx;\n if (_isViewable(viewAreaMode, viewablePercentThreshold, top, bottom, viewportHeight, metrics.length)) {\n viewableIndices.push(idx);\n }\n } else if (firstVisible >= 0) {\n break;\n }\n }\n return viewableIndices;\n }\n\n /**\n * Figures out which items are viewable and how that has changed from before and calls\n * `onViewableItemsChanged` as appropriate.\n */\n onUpdate(props, scrollOffset, viewportHeight, getFrameMetrics, createViewToken, onViewableItemsChanged,\n // Optional optimization to reduce the scan size\n renderRange) {\n var itemCount = props.getItemCount(props.data);\n if (this._config.waitForInteraction && !this._hasInteracted || itemCount === 0 || !getFrameMetrics(0, props)) {\n return;\n }\n var viewableIndices = [];\n if (itemCount) {\n viewableIndices = this.computeViewableItems(props, scrollOffset, viewportHeight, getFrameMetrics, renderRange);\n }\n if (this._viewableIndices.length === viewableIndices.length && this._viewableIndices.every((v, ii) => v === viewableIndices[ii])) {\n // We might get a lot of scroll events where visibility doesn't change and we don't want to do\n // extra work in those cases.\n return;\n }\n this._viewableIndices = viewableIndices;\n if (this._config.minimumViewTime) {\n var handle = setTimeout(() => {\n /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.63 was deployed. To\n * see the error delete this comment and run Flow. */\n this._timers.delete(handle);\n this._onUpdateSync(props, viewableIndices, onViewableItemsChanged, createViewToken);\n }, this._config.minimumViewTime);\n /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.63 was deployed. To see\n * the error delete this comment and run Flow. */\n this._timers.add(handle);\n } else {\n this._onUpdateSync(props, viewableIndices, onViewableItemsChanged, createViewToken);\n }\n }\n\n /**\n * clean-up cached _viewableIndices to evaluate changed items on next update\n */\n resetViewableIndices() {\n this._viewableIndices = [];\n }\n\n /**\n * Records that an interaction has happened even if there has been no scroll.\n */\n recordInteraction() {\n this._hasInteracted = true;\n }\n _onUpdateSync(props, viewableIndicesToCheck, onViewableItemsChanged, createViewToken) {\n // Filter out indices that have gone out of view since this call was scheduled.\n viewableIndicesToCheck = viewableIndicesToCheck.filter(ii => this._viewableIndices.includes(ii));\n var prevItems = this._viewableItems;\n var nextItems = new Map(viewableIndicesToCheck.map(ii => {\n var viewable = createViewToken(ii, true, props);\n return [viewable.key, viewable];\n }));\n var changed = [];\n for (var _iterator = _createForOfIteratorHelperLoose(nextItems), _step; !(_step = _iterator()).done;) {\n var _step$value = _step.value,\n key = _step$value[0],\n viewable = _step$value[1];\n if (!prevItems.has(key)) {\n changed.push(viewable);\n }\n }\n for (var _iterator2 = _createForOfIteratorHelperLoose(prevItems), _step2; !(_step2 = _iterator2()).done;) {\n var _step2$value = _step2.value,\n _key = _step2$value[0],\n _viewable = _step2$value[1];\n if (!nextItems.has(_key)) {\n changed.push(_objectSpread(_objectSpread({}, _viewable), {}, {\n isViewable: false\n }));\n }\n }\n if (changed.length > 0) {\n this._viewableItems = nextItems;\n onViewableItemsChanged({\n viewableItems: Array.from(nextItems.values()),\n changed,\n viewabilityConfig: this._config\n });\n }\n }\n}\nfunction _isViewable(viewAreaMode, viewablePercentThreshold, top, bottom, viewportHeight, itemLength) {\n if (_isEntirelyVisible(top, bottom, viewportHeight)) {\n return true;\n } else {\n var pixels = _getPixelsVisible(top, bottom, viewportHeight);\n var percent = 100 * (viewAreaMode ? pixels / viewportHeight : pixels / itemLength);\n return percent >= viewablePercentThreshold;\n }\n}\nfunction _getPixelsVisible(top, bottom, viewportHeight) {\n var visibleHeight = Math.min(bottom, viewportHeight) - Math.max(top, 0);\n return Math.max(0, visibleHeight);\n}\nfunction _isEntirelyVisible(top, bottom, viewportHeight) {\n return top >= 0 && bottom <= viewportHeight && bottom > top;\n}\nexport default ViewabilityHelper;","import _extends from \"@babel/runtime/helpers/extends\";\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport View from '../../../exports/View';\nimport StyleSheet from '../../../exports/StyleSheet';\nimport { VirtualizedListCellContextProvider } from './VirtualizedListContext.js';\nimport invariant from 'fbjs/lib/invariant';\nimport * as React from 'react';\nexport default class CellRenderer extends React.Component {\n constructor() {\n super(...arguments);\n this.state = {\n separatorProps: {\n highlighted: false,\n leadingItem: this.props.item\n }\n };\n this._separators = {\n highlight: () => {\n var _this$props = this.props,\n cellKey = _this$props.cellKey,\n prevCellKey = _this$props.prevCellKey;\n this.props.onUpdateSeparators([cellKey, prevCellKey], {\n highlighted: true\n });\n },\n unhighlight: () => {\n var _this$props2 = this.props,\n cellKey = _this$props2.cellKey,\n prevCellKey = _this$props2.prevCellKey;\n this.props.onUpdateSeparators([cellKey, prevCellKey], {\n highlighted: false\n });\n },\n updateProps: (select, newProps) => {\n var _this$props3 = this.props,\n cellKey = _this$props3.cellKey,\n prevCellKey = _this$props3.prevCellKey;\n this.props.onUpdateSeparators([select === 'leading' ? prevCellKey : cellKey], newProps);\n }\n };\n this._onLayout = nativeEvent => {\n this.props.onCellLayout && this.props.onCellLayout(nativeEvent, this.props.cellKey, this.props.index);\n };\n }\n static getDerivedStateFromProps(props, prevState) {\n return {\n separatorProps: _objectSpread(_objectSpread({}, prevState.separatorProps), {}, {\n leadingItem: props.item\n })\n };\n }\n\n // TODO: consider factoring separator stuff out of VirtualizedList into FlatList since it's not\n // reused by SectionList and we can keep VirtualizedList simpler.\n // $FlowFixMe[missing-local-annot]\n updateSeparatorProps(newProps) {\n this.setState(state => ({\n separatorProps: _objectSpread(_objectSpread({}, state.separatorProps), newProps)\n }));\n }\n componentWillUnmount() {\n this.props.onUnmount(this.props.cellKey);\n }\n _renderElement(renderItem, ListItemComponent, item, index) {\n if (renderItem && ListItemComponent) {\n console.warn('VirtualizedList: Both ListItemComponent and renderItem props are present. ListItemComponent will take' + ' precedence over renderItem.');\n }\n if (ListItemComponent) {\n /* $FlowFixMe[not-a-component] (>=0.108.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.108 was deployed. To\n * see the error, delete this comment and run Flow. */\n /* $FlowFixMe[incompatible-type-arg] (>=0.108.0 site=react_native_fb)\n * This comment suppresses an error found when Flow v0.108 was deployed.\n * To see the error, delete this comment and run Flow. */\n return /*#__PURE__*/React.createElement(ListItemComponent, {\n item,\n index,\n separators: this._separators\n });\n }\n if (renderItem) {\n return renderItem({\n item,\n index,\n separators: this._separators\n });\n }\n invariant(false, 'VirtualizedList: Either ListItemComponent or renderItem props are required but none were found.');\n }\n render() {\n var _this$props4 = this.props,\n CellRendererComponent = _this$props4.CellRendererComponent,\n ItemSeparatorComponent = _this$props4.ItemSeparatorComponent,\n ListItemComponent = _this$props4.ListItemComponent,\n cellKey = _this$props4.cellKey,\n horizontal = _this$props4.horizontal,\n item = _this$props4.item,\n index = _this$props4.index,\n inversionStyle = _this$props4.inversionStyle,\n onCellFocusCapture = _this$props4.onCellFocusCapture,\n onCellLayout = _this$props4.onCellLayout,\n renderItem = _this$props4.renderItem;\n var element = this._renderElement(renderItem, ListItemComponent, item, index);\n\n // NOTE: that when this is a sticky header, `onLayout` will get automatically extracted and\n // called explicitly by `ScrollViewStickyHeader`.\n var itemSeparator = /*#__PURE__*/React.isValidElement(ItemSeparatorComponent) ?\n // $FlowFixMe[incompatible-type]\n ItemSeparatorComponent :\n // $FlowFixMe[incompatible-type]\n ItemSeparatorComponent && /*#__PURE__*/React.createElement(ItemSeparatorComponent, this.state.separatorProps);\n var cellStyle = inversionStyle ? horizontal ? [styles.rowReverse, inversionStyle] : [styles.columnReverse, inversionStyle] : horizontal ? [styles.row, inversionStyle] : inversionStyle;\n var result = !CellRendererComponent ? /*#__PURE__*/React.createElement(View, _extends({\n style: cellStyle,\n onFocusCapture: onCellFocusCapture\n }, onCellLayout && {\n onLayout: this._onLayout\n }), element, itemSeparator) : /*#__PURE__*/React.createElement(CellRendererComponent, _extends({\n cellKey: cellKey,\n index: index,\n item: item,\n style: cellStyle,\n onFocusCapture: onCellFocusCapture\n }, onCellLayout && {\n onLayout: this._onLayout\n }), element, itemSeparator);\n return /*#__PURE__*/React.createElement(VirtualizedListCellContextProvider, {\n cellKey: this.props.cellKey\n }, result);\n }\n}\nvar styles = StyleSheet.create({\n row: {\n flexDirection: 'row'\n },\n rowReverse: {\n flexDirection: 'row-reverse'\n },\n columnReverse: {\n flexDirection: 'column-reverse'\n }\n});","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as React from 'react';\nimport { useContext, useMemo } from 'react';\nvar __DEV__ = process.env.NODE_ENV !== 'production';\nexport var VirtualizedListContext = /*#__PURE__*/React.createContext(null);\nif (__DEV__) {\n VirtualizedListContext.displayName = 'VirtualizedListContext';\n}\n\n/**\n * Resets the context. Intended for use by portal-like components (e.g. Modal).\n */\nexport function VirtualizedListContextResetter(_ref) {\n var children = _ref.children;\n return /*#__PURE__*/React.createElement(VirtualizedListContext.Provider, {\n value: null\n }, children);\n}\n\n/**\n * Sets the context with memoization. Intended to be used by `VirtualizedList`.\n */\nexport function VirtualizedListContextProvider(_ref2) {\n var children = _ref2.children,\n value = _ref2.value;\n // Avoid setting a newly created context object if the values are identical.\n var context = useMemo(() => ({\n cellKey: null,\n getScrollMetrics: value.getScrollMetrics,\n horizontal: value.horizontal,\n getOutermostParentListRef: value.getOutermostParentListRef,\n registerAsNestedChild: value.registerAsNestedChild,\n unregisterAsNestedChild: value.unregisterAsNestedChild\n }), [value.getScrollMetrics, value.horizontal, value.getOutermostParentListRef, value.registerAsNestedChild, value.unregisterAsNestedChild]);\n return /*#__PURE__*/React.createElement(VirtualizedListContext.Provider, {\n value: context\n }, children);\n}\n\n/**\n * Sets the `cellKey`. Intended to be used by `VirtualizedList` for each cell.\n */\nexport function VirtualizedListCellContextProvider(_ref3) {\n var cellKey = _ref3.cellKey,\n children = _ref3.children;\n // Avoid setting a newly created context object if the values are identical.\n var currContext = useContext(VirtualizedListContext);\n var context = useMemo(() => currContext == null ? null : _objectSpread(_objectSpread({}, currContext), {}, {\n cellKey\n }), [currContext, cellKey]);\n return /*#__PURE__*/React.createElement(VirtualizedListContext.Provider, {\n value: context\n }, children);\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\n/**\n * Used to find the indices of the frames that overlap the given offsets. Useful for finding the\n * items that bound different windows of content, such as the visible area or the buffered overscan\n * area.\n */\nexport function elementsThatOverlapOffsets(offsets, props, getFrameMetrics, zoomScale) {\n if (zoomScale === void 0) {\n zoomScale = 1;\n }\n var itemCount = props.getItemCount(props.data);\n var result = [];\n for (var offsetIndex = 0; offsetIndex < offsets.length; offsetIndex++) {\n var currentOffset = offsets[offsetIndex];\n var left = 0;\n var right = itemCount - 1;\n while (left <= right) {\n // eslint-disable-next-line no-bitwise\n var mid = left + (right - left >>> 1);\n var frame = getFrameMetrics(mid, props);\n var scaledOffsetStart = frame.offset * zoomScale;\n var scaledOffsetEnd = (frame.offset + frame.length) * zoomScale;\n\n // We want the first frame that contains the offset, with inclusive bounds. Thus, for the\n // first frame the scaledOffsetStart is inclusive, while for other frames it is exclusive.\n if (mid === 0 && currentOffset < scaledOffsetStart || mid !== 0 && currentOffset <= scaledOffsetStart) {\n right = mid - 1;\n } else if (currentOffset > scaledOffsetEnd) {\n left = mid + 1;\n } else {\n result[offsetIndex] = mid;\n break;\n }\n }\n }\n return result;\n}\n\n/**\n * Computes the number of elements in the `next` range that are new compared to the `prev` range.\n * Handy for calculating how many new items will be rendered when the render window changes so we\n * can restrict the number of new items render at once so that content can appear on the screen\n * faster.\n */\nexport function newRangeCount(prev, next) {\n return next.last - next.first + 1 - Math.max(0, 1 + Math.min(next.last, prev.last) - Math.max(next.first, prev.first));\n}\n\n/**\n * Custom logic for determining which items should be rendered given the current frame and scroll\n * metrics, as well as the previous render state. The algorithm may evolve over time, but generally\n * prioritizes the visible area first, then expands that with overscan regions ahead and behind,\n * biased in the direction of scroll.\n */\nexport function computeWindowedRenderLimits(props, maxToRenderPerBatch, windowSize, prev, getFrameMetricsApprox, scrollMetrics) {\n var itemCount = props.getItemCount(props.data);\n if (itemCount === 0) {\n return {\n first: 0,\n last: -1\n };\n }\n var offset = scrollMetrics.offset,\n velocity = scrollMetrics.velocity,\n visibleLength = scrollMetrics.visibleLength,\n _scrollMetrics$zoomSc = scrollMetrics.zoomScale,\n zoomScale = _scrollMetrics$zoomSc === void 0 ? 1 : _scrollMetrics$zoomSc;\n\n // Start with visible area, then compute maximum overscan region by expanding from there, biased\n // in the direction of scroll. Total overscan area is capped, which should cap memory consumption\n // too.\n var visibleBegin = Math.max(0, offset);\n var visibleEnd = visibleBegin + visibleLength;\n var overscanLength = (windowSize - 1) * visibleLength;\n\n // Considering velocity seems to introduce more churn than it's worth.\n var leadFactor = 0.5; // Math.max(0, Math.min(1, velocity / 25 + 0.5));\n\n var fillPreference = velocity > 1 ? 'after' : velocity < -1 ? 'before' : 'none';\n var overscanBegin = Math.max(0, visibleBegin - (1 - leadFactor) * overscanLength);\n var overscanEnd = Math.max(0, visibleEnd + leadFactor * overscanLength);\n var lastItemOffset = getFrameMetricsApprox(itemCount - 1, props).offset * zoomScale;\n if (lastItemOffset < overscanBegin) {\n // Entire list is before our overscan window\n return {\n first: Math.max(0, itemCount - 1 - maxToRenderPerBatch),\n last: itemCount - 1\n };\n }\n\n // Find the indices that correspond to the items at the render boundaries we're targeting.\n var _elementsThatOverlapO = elementsThatOverlapOffsets([overscanBegin, visibleBegin, visibleEnd, overscanEnd], props, getFrameMetricsApprox, zoomScale),\n overscanFirst = _elementsThatOverlapO[0],\n first = _elementsThatOverlapO[1],\n last = _elementsThatOverlapO[2],\n overscanLast = _elementsThatOverlapO[3];\n overscanFirst = overscanFirst == null ? 0 : overscanFirst;\n first = first == null ? Math.max(0, overscanFirst) : first;\n overscanLast = overscanLast == null ? itemCount - 1 : overscanLast;\n last = last == null ? Math.min(overscanLast, first + maxToRenderPerBatch - 1) : last;\n var visible = {\n first,\n last\n };\n\n // We want to limit the number of new cells we're rendering per batch so that we can fill the\n // content on the screen quickly. If we rendered the entire overscan window at once, the user\n // could be staring at white space for a long time waiting for a bunch of offscreen content to\n // render.\n var newCellCount = newRangeCount(prev, visible);\n while (true) {\n if (first <= overscanFirst && last >= overscanLast) {\n // If we fill the entire overscan range, we're done.\n break;\n }\n var maxNewCells = newCellCount >= maxToRenderPerBatch;\n var firstWillAddMore = first <= prev.first || first > prev.last;\n var firstShouldIncrement = first > overscanFirst && (!maxNewCells || !firstWillAddMore);\n var lastWillAddMore = last >= prev.last || last < prev.first;\n var lastShouldIncrement = last < overscanLast && (!maxNewCells || !lastWillAddMore);\n if (maxNewCells && !firstShouldIncrement && !lastShouldIncrement) {\n // We only want to stop if we've hit maxNewCells AND we cannot increment first or last\n // without rendering new items. This let's us preserve as many already rendered items as\n // possible, reducing render churn and keeping the rendered overscan range as large as\n // possible.\n break;\n }\n if (firstShouldIncrement && !(fillPreference === 'after' && lastShouldIncrement && lastWillAddMore)) {\n if (firstWillAddMore) {\n newCellCount++;\n }\n first--;\n }\n if (lastShouldIncrement && !(fillPreference === 'before' && firstShouldIncrement && firstWillAddMore)) {\n if (lastWillAddMore) {\n newCellCount++;\n }\n last++;\n }\n }\n if (!(last >= first && first >= 0 && last < itemCount && first >= overscanFirst && last <= overscanLast && first <= visible.first && last >= visible.last)) {\n throw new Error('Bad window calculation ' + JSON.stringify({\n first,\n last,\n itemCount,\n overscanFirst,\n overscanLast,\n visible\n }));\n }\n return {\n first,\n last\n };\n}\nexport function keyExtractor(item, index) {\n if (typeof item === 'object' && (item == null ? void 0 : item.key) != null) {\n return item.key;\n }\n if (typeof item === 'object' && (item == null ? void 0 : item.id) != null) {\n return item.id;\n }\n return String(index);\n}","'use strict';\n\nfunction nullthrows(x, message) {\n if (x != null) {\n return x;\n }\n var error = new Error(message !== undefined ? message : 'Got unexpected ' + x);\n error.framesToPop = 1; // Skip nullthrows's own stack frame.\n throw error;\n}\n\nmodule.exports = nullthrows;\nmodule.exports.default = nullthrows;\n\nObject.defineProperty(module.exports, '__esModule', {value: true});\n","var safeIsNaN = Number.isNaN ||\n function ponyfill(value) {\n return typeof value === 'number' && value !== value;\n };\nfunction isEqual(first, second) {\n if (first === second) {\n return true;\n }\n if (safeIsNaN(first) && safeIsNaN(second)) {\n return true;\n }\n return false;\n}\nfunction areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n for (var i = 0; i < newInputs.length; i++) {\n if (!isEqual(newInputs[i], lastInputs[i])) {\n return false;\n }\n }\n return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n if (isEqual === void 0) { isEqual = areInputsEqual; }\n var cache = null;\n function memoized() {\n var newArgs = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\n }\n if (cache && cache.lastThis === this && isEqual(newArgs, cache.lastArgs)) {\n return cache.lastResult;\n }\n var lastResult = resultFn.apply(this, newArgs);\n cache = {\n lastResult: lastResult,\n lastArgs: newArgs,\n lastThis: this,\n };\n return lastResult;\n }\n memoized.clear = function clear() {\n cache = null;\n };\n return memoized;\n}\n\nexport { memoizeOne as default };\n","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { ContinousBaseGesture } from './gesture';\nexport let HoverEffect;\n\n(function (HoverEffect) {\n HoverEffect[HoverEffect[\"NONE\"] = 0] = \"NONE\";\n HoverEffect[HoverEffect[\"LIFT\"] = 1] = \"LIFT\";\n HoverEffect[HoverEffect[\"HIGHLIGHT\"] = 2] = \"HIGHLIGHT\";\n})(HoverEffect || (HoverEffect = {}));\n\nexport const hoverGestureHandlerProps = ['hoverEffect'];\n\nfunction changeEventCalculator(current, previous) {\n 'worklet';\n\n let changePayload;\n\n if (previous === undefined) {\n changePayload = {\n changeX: current.x,\n changeY: current.y\n };\n } else {\n changePayload = {\n changeX: current.x - previous.x,\n changeY: current.y - previous.y\n };\n }\n\n return { ...current,\n ...changePayload\n };\n}\n\nexport class HoverGesture extends ContinousBaseGesture {\n constructor() {\n super();\n\n _defineProperty(this, \"config\", {});\n\n this.handlerName = 'HoverGestureHandler';\n }\n /**\n * #### iOS only\n * Sets the visual hover effect.\n */\n\n\n effect(effect) {\n this.config.hoverEffect = effect;\n return this;\n }\n\n onChange(callback) {\n // @ts-ignore TS being overprotective, HoverGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n\n}\n//# sourceMappingURL=hoverGesture.js.map","export function getReactNativeVersion() {\n throw new Error('getReactNativeVersion is not supported on web');\n}\n//# sourceMappingURL=getReactNativeVersion.web.js.map","// Used by GestureDetector (unsupported on web at the moment) to check whether the\n// attached view may get flattened on Fabric. Original implementation causes errors\n// on web due to the static resolution of `require` statements by webpack breaking\n// the conditional importing.\nexport function getShadowNodeFromRef(_ref) {\n return null;\n}\n//# sourceMappingURL=getShadowNodeFromRef.web.js.map","export const RNRenderer = {\n findHostInstance_DEPRECATED: _ref => null\n};\n//# sourceMappingURL=RNRenderer.web.js.map","import { FlingGesture } from './flingGesture';\nimport { ForceTouchGesture } from './forceTouchGesture';\nimport { ComposedGesture, ExclusiveGesture, SimultaneousGesture } from './gestureComposition';\nimport { LongPressGesture } from './longPressGesture';\nimport { PanGesture } from './panGesture';\nimport { PinchGesture } from './pinchGesture';\nimport { RotationGesture } from './rotationGesture';\nimport { TapGesture } from './tapGesture';\nimport { NativeGesture } from './nativeGesture';\nimport { ManualGesture } from './manualGesture';\nimport { HoverGesture } from './hoverGesture';\n/**\n * `Gesture` is the object that allows you to create and compose gestures.\n *\n * ### Remarks\n * - Consider wrapping your gesture configurations with `useMemo`, as it will reduce the amount of work Gesture Handler has to do under the hood when updating gestures.\n *\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/gesture\n */\n\nexport const GestureObjects = {\n /**\n * A discrete gesture that recognizes one or many taps.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/tap-gesture\n */\n Tap: () => {\n return new TapGesture();\n },\n\n /**\n * A continuous gesture that can recognize a panning (dragging) gesture and track its movement.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture\n */\n Pan: () => {\n return new PanGesture();\n },\n\n /**\n * A continuous gesture that recognizes pinch gesture. It allows for tracking the distance between two fingers and use that information to scale or zoom your content.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pinch-gesture\n */\n Pinch: () => {\n return new PinchGesture();\n },\n\n /**\n * A continuous gesture that can recognize rotation and track its movement.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/rotation-gesture\n */\n Rotation: () => {\n return new RotationGesture();\n },\n\n /**\n * A discrete gesture that activates when the movement is sufficiently fast.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/fling-gesture\n */\n Fling: () => {\n return new FlingGesture();\n },\n\n /**\n * A discrete gesture that activates when the corresponding view is pressed for a sufficiently long time.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/long-press-gesture\n */\n LongPress: () => {\n return new LongPressGesture();\n },\n\n /**\n * #### iOS only\n * A continuous gesture that recognizes force of a touch. It allows for tracking pressure of touch on some iOS devices.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/force-touch-gesture\n */\n ForceTouch: () => {\n return new ForceTouchGesture();\n },\n\n /**\n * A gesture that allows other touch handling components to participate in RNGH's gesture system.\n * When used, the other component should be the direct child of a `GestureDetector`.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/native-gesture\n */\n Native: () => {\n return new NativeGesture();\n },\n\n /**\n * A plain gesture that has no specific activation criteria nor event data set.\n * Its state has to be controlled manually using a state manager.\n * It will not fail when all the pointers are lifted from the screen.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/manual-gesture\n */\n Manual: () => {\n return new ManualGesture();\n },\n\n /**\n * A continuous gesture that can recognize hovering above the view it's attached to.\n * The hover effect may be activated by moving a mouse or a stylus over the view.\n *\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/hover-gesture\n */\n Hover: () => {\n return new HoverGesture();\n },\n\n /**\n * Builds a composed gesture consisting of gestures provided as parameters.\n * The first one that becomes active cancels the rest of gestures.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/fundamentals/gesture-composition/#race\n */\n Race: (...gestures) => {\n return new ComposedGesture(...gestures);\n },\n\n /**\n * Builds a composed gesture that allows all base gestures to run simultaneously.\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/fundamentals/gesture-composition/#simultaneous\n */\n Simultaneous(...gestures) {\n return new SimultaneousGesture(...gestures);\n },\n\n /**\n * Builds a composed gesture where only one of the provided gestures can become active.\n * Priority is decided through the order of gestures: the first one has higher priority\n * than the second one, second one has higher priority than the third one, and so on.\n * For example, to make a gesture that recognizes both single and double tap you need\n * to call Exclusive(doubleTap, singleTap).\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/fundamentals/gesture-composition/#exclusive\n */\n Exclusive(...gestures) {\n return new ExclusiveGesture(...gestures);\n }\n\n};\n//# sourceMappingURL=gestureObjects.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { BaseGesture } from './gesture';\nexport class FlingGesture extends BaseGesture {\n constructor() {\n super();\n\n _defineProperty(this, \"config\", {});\n\n this.handlerName = 'FlingGestureHandler';\n }\n /**\n * Determine exact number of points required to handle the fling gesture.\n * @param pointers\n */\n\n\n numberOfPointers(pointers) {\n this.config.numberOfPointers = pointers;\n return this;\n }\n /**\n * Expressed allowed direction of movement.\n * Expected values are exported as constants in the Directions object.\n * Arguments can be combined using `|` operator. Default value is set to `MouseButton.LEFT`.\n * @param direction\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/fling-gesture/#directionvalue-directions\n */\n\n\n direction(direction) {\n this.config.direction = direction;\n return this;\n }\n\n}\n//# sourceMappingURL=flingGesture.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { ContinousBaseGesture } from './gesture';\n\nfunction changeEventCalculator(current, previous) {\n 'worklet';\n\n let changePayload;\n\n if (previous === undefined) {\n changePayload = {\n forceChange: current.force\n };\n } else {\n changePayload = {\n forceChange: current.force - previous.force\n };\n }\n\n return { ...current,\n ...changePayload\n };\n}\n\nexport class ForceTouchGesture extends ContinousBaseGesture {\n constructor() {\n super();\n\n _defineProperty(this, \"config\", {});\n\n this.handlerName = 'ForceTouchGestureHandler';\n }\n /**\n * A minimal pressure that is required before gesture can activate.\n * Should be a value from range [0.0, 1.0]. Default is 0.2.\n * @param force\n */\n\n\n minForce(force) {\n this.config.minForce = force;\n return this;\n }\n /**\n * A maximal pressure that could be applied for gesture.\n * If the pressure is greater, gesture fails. Should be a value from range [0.0, 1.0].\n * @param force\n */\n\n\n maxForce(force) {\n this.config.maxForce = force;\n return this;\n }\n /**\n * Value defining if haptic feedback has to be performed on activation.\n * @param value\n */\n\n\n feedbackOnActivation(value) {\n this.config.feedbackOnActivation = value;\n return this;\n }\n\n onChange(callback) {\n // @ts-ignore TS being overprotective, ForceTouchGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n\n}\n//# sourceMappingURL=forceTouchGesture.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { BaseGesture, Gesture } from './gesture';\n\nfunction extendRelation(currentRelation, extendWith) {\n if (currentRelation === undefined) {\n return [...extendWith];\n } else {\n return [...currentRelation, ...extendWith];\n }\n}\n\nexport class ComposedGesture extends Gesture {\n constructor(...gestures) {\n super();\n\n _defineProperty(this, \"gestures\", []);\n\n _defineProperty(this, \"simultaneousGestures\", []);\n\n _defineProperty(this, \"requireGesturesToFail\", []);\n\n this.gestures = gestures;\n }\n\n prepareSingleGesture(gesture, simultaneousGestures, requireGesturesToFail) {\n if (gesture instanceof BaseGesture) {\n const newConfig = { ...gesture.config\n };\n newConfig.simultaneousWith = extendRelation(newConfig.simultaneousWith, simultaneousGestures);\n newConfig.requireToFail = extendRelation(newConfig.requireToFail, requireGesturesToFail);\n gesture.config = newConfig;\n } else if (gesture instanceof ComposedGesture) {\n gesture.simultaneousGestures = simultaneousGestures;\n gesture.requireGesturesToFail = requireGesturesToFail;\n gesture.prepare();\n }\n }\n\n prepare() {\n for (const gesture of this.gestures) {\n this.prepareSingleGesture(gesture, this.simultaneousGestures, this.requireGesturesToFail);\n }\n }\n\n initialize() {\n for (const gesture of this.gestures) {\n gesture.initialize();\n }\n }\n\n toGestureArray() {\n return this.gestures.flatMap(gesture => gesture.toGestureArray());\n }\n\n}\nexport class SimultaneousGesture extends ComposedGesture {\n prepare() {\n // this piece of magic works something like this:\n // for every gesture in the array\n const simultaneousArrays = this.gestures.map(gesture => // we take the array it's in\n this.gestures // and make a copy without it\n .filter(x => x !== gesture) // then we flatmap the result to get list of raw (not composed) gestures\n // this way we don't make the gestures simultaneous with themselves, which is\n // important when the gesture is `ExclusiveGesture` - we don't want to make\n // exclusive gestures simultaneous\n .flatMap(x => x.toGestureArray()));\n\n for (let i = 0; i < this.gestures.length; i++) {\n this.prepareSingleGesture(this.gestures[i], simultaneousArrays[i], this.requireGesturesToFail);\n }\n }\n\n}\nexport class ExclusiveGesture extends ComposedGesture {\n prepare() {\n // transforms the array of gestures into array of grouped raw (not composed) gestures\n // i.e. [gesture1, gesture2, ComposedGesture(gesture3, gesture4)] -> [[gesture1], [gesture2], [gesture3, gesture4]]\n const gestureArrays = this.gestures.map(gesture => gesture.toGestureArray());\n let requireToFail = [];\n\n for (let i = 0; i < this.gestures.length; i++) {\n this.prepareSingleGesture(this.gestures[i], this.simultaneousGestures, this.requireGesturesToFail.concat(requireToFail)); // every group gets to wait for all groups before it\n\n requireToFail = requireToFail.concat(gestureArrays[i]);\n }\n }\n\n}\n//# sourceMappingURL=gestureComposition.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { BaseGesture } from './gesture';\nexport class LongPressGesture extends BaseGesture {\n constructor() {\n super();\n\n _defineProperty(this, \"config\", {});\n\n this.handlerName = 'LongPressGestureHandler';\n this.shouldCancelWhenOutside(true);\n }\n /**\n * Minimum time, expressed in milliseconds, that a finger must remain pressed on the corresponding view.\n * The default value is 500.\n * @param duration\n */\n\n\n minDuration(duration) {\n this.config.minDurationMs = duration;\n return this;\n }\n /**\n * Maximum distance, expressed in points, that defines how far the finger is allowed to travel during a long press gesture.\n * @param distance\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/long-press-gesture#maxdistancevalue-number\n */\n\n\n maxDistance(distance) {\n this.config.maxDist = distance;\n return this;\n }\n\n}\n//# sourceMappingURL=longPressGesture.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { ContinousBaseGesture } from './gesture';\n\nfunction changeEventCalculator(current, previous) {\n 'worklet';\n\n let changePayload;\n\n if (previous === undefined) {\n changePayload = {\n changeX: current.translationX,\n changeY: current.translationY\n };\n } else {\n changePayload = {\n changeX: current.translationX - previous.translationX,\n changeY: current.translationY - previous.translationY\n };\n }\n\n return { ...current,\n ...changePayload\n };\n}\n\nexport class PanGesture extends ContinousBaseGesture {\n constructor() {\n super();\n\n _defineProperty(this, \"config\", {});\n\n this.handlerName = 'PanGestureHandler';\n }\n /**\n * Range along Y axis (in points) where fingers travels without activation of gesture.\n * @param offset\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture#activeoffsetyvalue-number--number\n */\n\n\n activeOffsetY(offset) {\n if (Array.isArray(offset)) {\n this.config.activeOffsetYStart = offset[0];\n this.config.activeOffsetYEnd = offset[1];\n } else if (offset < 0) {\n this.config.activeOffsetYStart = offset;\n } else {\n this.config.activeOffsetYEnd = offset;\n }\n\n return this;\n }\n /**\n * Range along X axis (in points) where fingers travels without activation of gesture.\n * @param offset\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture#activeoffsetxvalue-number--number\n */\n\n\n activeOffsetX(offset) {\n if (Array.isArray(offset)) {\n this.config.activeOffsetXStart = offset[0];\n this.config.activeOffsetXEnd = offset[1];\n } else if (offset < 0) {\n this.config.activeOffsetXStart = offset;\n } else {\n this.config.activeOffsetXEnd = offset;\n }\n\n return this;\n }\n /**\n * When the finger moves outside this range (in points) along Y axis and gesture hasn't yet activated it will fail recognizing the gesture.\n * @param offset\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture#failoffsetyvalue-number--number\n */\n\n\n failOffsetY(offset) {\n if (Array.isArray(offset)) {\n this.config.failOffsetYStart = offset[0];\n this.config.failOffsetYEnd = offset[1];\n } else if (offset < 0) {\n this.config.failOffsetYStart = offset;\n } else {\n this.config.failOffsetYEnd = offset;\n }\n\n return this;\n }\n /**\n * When the finger moves outside this range (in points) along X axis and gesture hasn't yet activated it will fail recognizing the gesture.\n * @param offset\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture#failoffsetxvalue-number--number\n */\n\n\n failOffsetX(offset) {\n if (Array.isArray(offset)) {\n this.config.failOffsetXStart = offset[0];\n this.config.failOffsetXEnd = offset[1];\n } else if (offset < 0) {\n this.config.failOffsetXStart = offset;\n } else {\n this.config.failOffsetXEnd = offset;\n }\n\n return this;\n }\n /**\n * A number of fingers that is required to be placed before gesture can activate. Should be a higher or equal to 0 integer.\n * @param minPointers\n */\n\n\n minPointers(minPointers) {\n this.config.minPointers = minPointers;\n return this;\n }\n /**\n * When the given number of fingers is placed on the screen and gesture hasn't yet activated it will fail recognizing the gesture.\n * Should be a higher or equal to 0 integer.\n * @param maxPointers\n */\n\n\n maxPointers(maxPointers) {\n this.config.maxPointers = maxPointers;\n return this;\n }\n /**\n * Minimum distance the finger (or multiple finger) need to travel before the gesture activates.\n * Expressed in points.\n * @param distance\n */\n\n\n minDistance(distance) {\n this.config.minDist = distance;\n return this;\n }\n /**\n * Minimum velocity the finger has to reach in order to activate handler.\n * @param velocity\n */\n\n\n minVelocity(velocity) {\n this.config.minVelocity = velocity;\n return this;\n }\n /**\n * Minimum velocity along X axis the finger has to reach in order to activate handler.\n * @param velocity\n */\n\n\n minVelocityX(velocity) {\n this.config.minVelocityX = velocity;\n return this;\n }\n /**\n * Minimum velocity along Y axis the finger has to reach in order to activate handler.\n * @param velocity\n */\n\n\n minVelocityY(velocity) {\n this.config.minVelocityY = velocity;\n return this;\n }\n /**\n * #### Android only\n * Android, by default, will calculate translation values based on the position of the leading pointer (the first one that was placed on the screen).\n * This modifier allows that behavior to be changed to the one that is default on iOS - the averaged position of all active pointers will be used to calculate the translation values.\n * @param value\n */\n\n\n averageTouches(value) {\n this.config.avgTouches = value;\n return this;\n }\n /**\n * #### iOS only\n * Enables two-finger gestures on supported devices, for example iPads with trackpads.\n * @param value\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture/#enabletrackpadtwofingergesturevalue-boolean-ios-only\n */\n\n\n enableTrackpadTwoFingerGesture(value) {\n this.config.enableTrackpadTwoFingerGesture = value;\n return this;\n }\n /**\n * Duration in milliseconds of the LongPress gesture before Pan is allowed to activate.\n * @param duration\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/pan-gesture/#activateafterlongpressduration-number\n */\n\n\n activateAfterLongPress(duration) {\n this.config.activateAfterLongPress = duration;\n return this;\n }\n\n onChange(callback) {\n // @ts-ignore TS being overprotective, PanGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n\n}\n//# sourceMappingURL=panGesture.js.map","import { ContinousBaseGesture } from './gesture';\n\nfunction changeEventCalculator(current, previous) {\n 'worklet';\n\n let changePayload;\n\n if (previous === undefined) {\n changePayload = {\n scaleChange: current.scale\n };\n } else {\n changePayload = {\n scaleChange: current.scale / previous.scale\n };\n }\n\n return { ...current,\n ...changePayload\n };\n}\n\nexport class PinchGesture extends ContinousBaseGesture {\n constructor() {\n super();\n this.handlerName = 'PinchGestureHandler';\n }\n\n onChange(callback) {\n // @ts-ignore TS being overprotective, PinchGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n\n}\n//# sourceMappingURL=pinchGesture.js.map","import { ContinousBaseGesture } from './gesture';\n\nfunction changeEventCalculator(current, previous) {\n 'worklet';\n\n let changePayload;\n\n if (previous === undefined) {\n changePayload = {\n rotationChange: current.rotation\n };\n } else {\n changePayload = {\n rotationChange: current.rotation - previous.rotation\n };\n }\n\n return { ...current,\n ...changePayload\n };\n}\n\nexport class RotationGesture extends ContinousBaseGesture {\n constructor() {\n super();\n this.handlerName = 'RotationGestureHandler';\n }\n\n onChange(callback) {\n // @ts-ignore TS being overprotective, RotationGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n\n}\n//# sourceMappingURL=rotationGesture.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { BaseGesture } from './gesture';\nexport class TapGesture extends BaseGesture {\n constructor() {\n super();\n\n _defineProperty(this, \"config\", {});\n\n this.handlerName = 'TapGestureHandler';\n this.shouldCancelWhenOutside(true);\n }\n /**\n * Minimum number of pointers (fingers) required to be placed before the gesture activates.\n * Should be a positive integer. The default value is 1.\n * @param minPointers\n */\n\n\n minPointers(minPointers) {\n this.config.minPointers = minPointers;\n return this;\n }\n /**\n * Number of tap gestures required to activate the gesture.\n * The default value is 1.\n * @param count\n */\n\n\n numberOfTaps(count) {\n this.config.numberOfTaps = count;\n return this;\n }\n /**\n * Maximum distance, expressed in points, that defines how far the finger is allowed to travel during a tap gesture.\n * @param maxDist\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/tap-gesture#maxdistancevalue-number\n */\n\n\n maxDistance(maxDist) {\n this.config.maxDist = maxDist;\n return this;\n }\n /**\n * Maximum time, expressed in milliseconds, that defines how fast a finger must be released after a touch.\n * The default value is 500.\n * @param duration\n */\n\n\n maxDuration(duration) {\n this.config.maxDurationMs = duration;\n return this;\n }\n /**\n * Maximum time, expressed in milliseconds, that can pass before the next tap — if many taps are required.\n * The default value is 500.\n * @param delay\n */\n\n\n maxDelay(delay) {\n this.config.maxDelayMs = delay;\n return this;\n }\n /**\n * Maximum distance, expressed in points, that defines how far the finger is allowed to travel along the X axis during a tap gesture.\n * @param delta\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/tap-gesture#maxdeltaxvalue-number\n */\n\n\n maxDeltaX(delta) {\n this.config.maxDeltaX = delta;\n return this;\n }\n /**\n * Maximum distance, expressed in points, that defines how far the finger is allowed to travel along the Y axis during a tap gesture.\n * @param delta\n * @see https://docs.swmansion.com/react-native-gesture-handler/docs/gestures/tap-gesture#maxdeltayvalue-number\n */\n\n\n maxDeltaY(delta) {\n this.config.maxDeltaY = delta;\n return this;\n }\n\n}\n//# sourceMappingURL=tapGesture.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { BaseGesture } from './gesture';\nexport class NativeGesture extends BaseGesture {\n constructor() {\n super();\n\n _defineProperty(this, \"config\", {});\n\n this.handlerName = 'NativeViewGestureHandler';\n }\n /**\n * When true, underlying handler will activate unconditionally when in `BEGAN` or `UNDETERMINED` state.\n * @param value\n */\n\n\n shouldActivateOnStart(value) {\n this.config.shouldActivateOnStart = value;\n return this;\n }\n /**\n * When true, cancels all other gesture handlers when this `NativeViewGestureHandler` receives an `ACTIVE` state event.\n * @param value\n */\n\n\n disallowInterruption(value) {\n this.config.disallowInterruption = value;\n return this;\n }\n\n}\n//# sourceMappingURL=nativeGesture.js.map","import { ContinousBaseGesture } from './gesture';\n\nfunction changeEventCalculator(current, _previous) {\n 'worklet';\n\n return current;\n}\n\nexport class ManualGesture extends ContinousBaseGesture {\n constructor() {\n super();\n this.handlerName = 'ManualGestureHandler';\n }\n\n onChange(callback) {\n // @ts-ignore TS being overprotective, Record is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n\n}\n//# sourceMappingURL=manualGesture.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport * as React from 'react';\nimport { Animated, Platform, processColor, StyleSheet } from 'react-native';\nimport createNativeWrapper from '../handlers/createNativeWrapper';\nimport GestureHandlerButton from './GestureHandlerButton';\nimport { State } from '../State';\nexport const RawButton = createNativeWrapper(GestureHandlerButton, {\n shouldCancelWhenOutside: false,\n shouldActivateOnStart: false\n});\nexport class BaseButton extends React.Component {\n constructor(props) {\n super(props);\n\n _defineProperty(this, \"lastActive\", void 0);\n\n _defineProperty(this, \"longPressTimeout\", void 0);\n\n _defineProperty(this, \"longPressDetected\", void 0);\n\n _defineProperty(this, \"handleEvent\", ({\n nativeEvent\n }) => {\n const {\n state,\n oldState,\n pointerInside\n } = nativeEvent;\n const active = pointerInside && state === State.ACTIVE;\n\n if (active !== this.lastActive && this.props.onActiveStateChange) {\n this.props.onActiveStateChange(active);\n }\n\n if (!this.longPressDetected && oldState === State.ACTIVE && state !== State.CANCELLED && this.lastActive && this.props.onPress) {\n this.props.onPress(active);\n }\n\n if (!this.lastActive && // NativeViewGestureHandler sends different events based on platform\n state === (Platform.OS !== 'android' ? State.ACTIVE : State.BEGAN) && pointerInside) {\n this.longPressDetected = false;\n\n if (this.props.onLongPress) {\n this.longPressTimeout = setTimeout(this.onLongPress, this.props.delayLongPress);\n }\n } else if ( // cancel longpress timeout if it's set and the finger moved out of the view\n state === State.ACTIVE && !pointerInside && this.longPressTimeout !== undefined) {\n clearTimeout(this.longPressTimeout);\n this.longPressTimeout = undefined;\n } else if ( // cancel longpress timeout if it's set and the gesture has finished\n this.longPressTimeout !== undefined && (state === State.END || state === State.CANCELLED || state === State.FAILED)) {\n clearTimeout(this.longPressTimeout);\n this.longPressTimeout = undefined;\n }\n\n this.lastActive = active;\n });\n\n _defineProperty(this, \"onLongPress\", () => {\n var _this$props$onLongPre, _this$props;\n\n this.longPressDetected = true;\n (_this$props$onLongPre = (_this$props = this.props).onLongPress) === null || _this$props$onLongPre === void 0 ? void 0 : _this$props$onLongPre.call(_this$props);\n });\n\n _defineProperty(this, \"onHandlerStateChange\", e => {\n var _this$props$onHandler, _this$props2;\n\n (_this$props$onHandler = (_this$props2 = this.props).onHandlerStateChange) === null || _this$props$onHandler === void 0 ? void 0 : _this$props$onHandler.call(_this$props2, e);\n this.handleEvent(e);\n });\n\n _defineProperty(this, \"onGestureEvent\", e => {\n var _this$props$onGesture, _this$props3;\n\n (_this$props$onGesture = (_this$props3 = this.props).onGestureEvent) === null || _this$props$onGesture === void 0 ? void 0 : _this$props$onGesture.call(_this$props3, e);\n this.handleEvent(e); // TODO: maybe it is not correct\n });\n\n this.lastActive = false;\n this.longPressDetected = false;\n }\n\n render() {\n const {\n rippleColor,\n ...rest\n } = this.props;\n return /*#__PURE__*/React.createElement(RawButton, _extends({\n rippleColor: processColor(rippleColor)\n }, rest, {\n onGestureEvent: this.onGestureEvent,\n onHandlerStateChange: this.onHandlerStateChange\n }));\n }\n\n}\n\n_defineProperty(BaseButton, \"defaultProps\", {\n delayLongPress: 600\n});\n\nconst AnimatedBaseButton = Animated.createAnimatedComponent(BaseButton);\nconst btnStyles = StyleSheet.create({\n underlay: {\n position: 'absolute',\n left: 0,\n right: 0,\n bottom: 0,\n top: 0\n }\n});\nexport class RectButton extends React.Component {\n constructor(props) {\n super(props);\n\n _defineProperty(this, \"opacity\", void 0);\n\n _defineProperty(this, \"onActiveStateChange\", active => {\n var _this$props$onActiveS, _this$props4;\n\n if (Platform.OS !== 'android') {\n this.opacity.setValue(active ? this.props.activeOpacity : 0);\n }\n\n (_this$props$onActiveS = (_this$props4 = this.props).onActiveStateChange) === null || _this$props$onActiveS === void 0 ? void 0 : _this$props$onActiveS.call(_this$props4, active);\n });\n\n this.opacity = new Animated.Value(0);\n }\n\n render() {\n const {\n children,\n style,\n ...rest\n } = this.props;\n const resolvedStyle = StyleSheet.flatten(style !== null && style !== void 0 ? style : {});\n return /*#__PURE__*/React.createElement(BaseButton, _extends({}, rest, {\n style: resolvedStyle,\n onActiveStateChange: this.onActiveStateChange\n }), /*#__PURE__*/React.createElement(Animated.View, {\n style: [btnStyles.underlay, {\n opacity: this.opacity,\n backgroundColor: this.props.underlayColor,\n borderRadius: resolvedStyle.borderRadius,\n borderTopLeftRadius: resolvedStyle.borderTopLeftRadius,\n borderTopRightRadius: resolvedStyle.borderTopRightRadius,\n borderBottomLeftRadius: resolvedStyle.borderBottomLeftRadius,\n borderBottomRightRadius: resolvedStyle.borderBottomRightRadius\n }]\n }), children);\n }\n\n}\n\n_defineProperty(RectButton, \"defaultProps\", {\n activeOpacity: 0.105,\n underlayColor: 'black'\n});\n\nexport class BorderlessButton extends React.Component {\n constructor(props) {\n super(props);\n\n _defineProperty(this, \"opacity\", void 0);\n\n _defineProperty(this, \"onActiveStateChange\", active => {\n var _this$props$onActiveS2, _this$props5;\n\n if (Platform.OS !== 'android') {\n this.opacity.setValue(active ? this.props.activeOpacity : 1);\n }\n\n (_this$props$onActiveS2 = (_this$props5 = this.props).onActiveStateChange) === null || _this$props$onActiveS2 === void 0 ? void 0 : _this$props$onActiveS2.call(_this$props5, active);\n });\n\n this.opacity = new Animated.Value(1);\n }\n\n render() {\n const {\n children,\n style,\n ...rest\n } = this.props;\n return /*#__PURE__*/React.createElement(AnimatedBaseButton, _extends({}, rest, {\n onActiveStateChange: this.onActiveStateChange,\n style: [style, Platform.OS === 'ios' && {\n opacity: this.opacity\n }]\n }), children);\n }\n\n}\n\n_defineProperty(BorderlessButton, \"defaultProps\", {\n activeOpacity: 0.3,\n borderless: true\n});\n\nexport { default as PureNativeButton } from './GestureHandlerButton';\n//# sourceMappingURL=GestureButtons.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport Animated from '../../vendor/react-native/Animated/Animated';\nexport default Animated;","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport Platform from '../../../exports/Platform';\nimport FlatList from './components/AnimatedFlatList';\nimport Image from './components/AnimatedImage';\nimport ScrollView from './components/AnimatedScrollView';\nimport SectionList from './components/AnimatedSectionList';\nimport Text from './components/AnimatedText';\nimport View from './components/AnimatedView';\nimport AnimatedMock from './AnimatedMock';\nimport AnimatedImplementation from './AnimatedImplementation';\nvar Animated = Platform.isTesting ? AnimatedMock : AnimatedImplementation;\nexport default _objectSpread({\n FlatList,\n Image,\n ScrollView,\n SectionList,\n Text,\n View\n}, Animated);","import _extends from \"@babel/runtime/helpers/extends\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as React from 'react';\nimport FlatList from '../../../../exports/FlatList';\nimport createAnimatedComponent from '../createAnimatedComponent';\n/**\n * @see https://github.com/facebook/react-native/commit/b8c8562\n */\nvar FlatListWithEventThrottle = /*#__PURE__*/React.forwardRef((props, ref) => /*#__PURE__*/React.createElement(FlatList, _extends({\n scrollEventThrottle: 0.0001\n}, props, {\n ref: ref\n})));\nexport default createAnimatedComponent(FlatListWithEventThrottle);","import _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"style\"];\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport useAnimatedProps from './useAnimatedProps';\nimport useMergeRefs from '../Utilities/useMergeRefs';\nimport StyleSheet from '../../../exports/StyleSheet';\nimport View from '../../../exports/View';\nimport * as React from 'react';\n/**\n * Experimental implementation of `createAnimatedComponent` that is intended to\n * be compatible with concurrent rendering.\n */\nexport default function createAnimatedComponent(Component) {\n return /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var _useAnimatedProps = useAnimatedProps(props),\n reducedProps = _useAnimatedProps[0],\n callbackRef = _useAnimatedProps[1];\n var ref = useMergeRefs(callbackRef, forwardedRef);\n\n // Some components require explicit passthrough values for animation\n // to work properly. For example, if an animated component is\n // transformed and Pressable, onPress will not work after transform\n // without these passthrough values.\n // $FlowFixMe[prop-missing]\n var passthroughAnimatedPropExplicitValues = reducedProps.passthroughAnimatedPropExplicitValues,\n style = reducedProps.style;\n var _ref = passthroughAnimatedPropExplicitValues !== null && passthroughAnimatedPropExplicitValues !== void 0 ? passthroughAnimatedPropExplicitValues : {},\n passthroughStyle = _ref.style,\n passthroughProps = _objectWithoutPropertiesLoose(_ref, _excluded);\n var mergedStyle = [style, passthroughStyle];\n return /*#__PURE__*/React.createElement(Component, _extends({}, reducedProps, passthroughProps, {\n style: mergedStyle,\n ref: ref\n }));\n });\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport AnimatedProps from './nodes/AnimatedProps';\nimport { AnimatedEvent } from './AnimatedEvent';\nimport useRefEffect from '../Utilities/useRefEffect';\nimport NativeAnimatedHelper from './NativeAnimatedHelper';\nimport { useCallback, useEffect, useMemo, useReducer, useRef } from 'react';\nimport useLayoutEffect from '../../../modules/useLayoutEffect';\nexport default function useAnimatedProps(props) {\n var _useReducer = useReducer(count => count + 1, 0),\n scheduleUpdate = _useReducer[1];\n var onUpdateRef = useRef(null);\n\n // TODO: Only invalidate `node` if animated props or `style` change. In the\n // previous implementation, we permitted `style` to override props with the\n // same name property name as styles, so we can probably continue doing that.\n // The ordering of other props *should* not matter.\n var node = useMemo(() => new AnimatedProps(props, () => onUpdateRef.current == null ? void 0 : onUpdateRef.current()), [props]);\n useAnimatedPropsLifecycle(node);\n\n // TODO: This \"effect\" does three things:\n //\n // 1) Call `setNativeView`.\n // 2) Update `onUpdateRef`.\n // 3) Update listeners for `AnimatedEvent` props.\n //\n // Ideally, each of these would be separat \"effects\" so that they are not\n // unnecessarily re-run when irrelevant dependencies change. For example, we\n // should be able to hoist all `AnimatedEvent` props and only do #3 if either\n // the `AnimatedEvent` props change or `instance` changes.\n //\n // But there is no way to transparently compose three separate callback refs,\n // so we just combine them all into one for now.\n var refEffect = useCallback(instance => {\n // NOTE: This may be called more often than necessary (e.g. when `props`\n // changes), but `setNativeView` already optimizes for that.\n node.setNativeView(instance);\n\n // NOTE: This callback is only used by the JavaScript animation driver.\n onUpdateRef.current = () => {\n // Schedule an update for this component to update `reducedProps`,\n // but do not compute it immediately. If a parent also updated, we\n // need to merge those new props in before updating.\n scheduleUpdate();\n };\n var target = getEventTarget(instance);\n var events = [];\n for (var propName in props) {\n var propValue = props[propName];\n if (propValue instanceof AnimatedEvent && propValue.__isNative) {\n propValue.__attach(target, propName);\n events.push([propName, propValue]);\n }\n }\n return () => {\n onUpdateRef.current = null;\n for (var _i = 0, _events = events; _i < _events.length; _i++) {\n var _events$_i = _events[_i],\n _propName = _events$_i[0],\n _propValue = _events$_i[1];\n _propValue.__detach(target, _propName);\n }\n };\n }, [props, node]);\n var callbackRef = useRefEffect(refEffect);\n return [reduceAnimatedProps(node), callbackRef];\n}\nfunction reduceAnimatedProps(node) {\n // Force `collapsable` to be false so that the native view is not flattened.\n // Flattened views cannot be accurately referenced by the native driver.\n return _objectSpread(_objectSpread({}, node.__getValue()), {}, {\n collapsable: false\n });\n}\n\n/**\n * Manages the lifecycle of the supplied `AnimatedProps` by invoking `__attach`\n * and `__detach`. However, this is more complicated because `AnimatedProps`\n * uses reference counting to determine when to recursively detach its children\n * nodes. So in order to optimize this, we avoid detaching until the next attach\n * unless we are unmounting.\n */\nfunction useAnimatedPropsLifecycle(node) {\n var prevNodeRef = useRef(null);\n var isUnmountingRef = useRef(false);\n useEffect(() => {\n // It is ok for multiple components to call `flushQueue` because it noops\n // if the queue is empty. When multiple animated components are mounted at\n // the same time. Only first component flushes the queue and the others will noop.\n NativeAnimatedHelper.API.flushQueue();\n });\n useLayoutEffect(() => {\n isUnmountingRef.current = false;\n return () => {\n isUnmountingRef.current = true;\n };\n }, []);\n useLayoutEffect(() => {\n node.__attach();\n if (prevNodeRef.current != null) {\n var prevNode = prevNodeRef.current;\n // TODO: Stop restoring default values (unless `reset` is called).\n prevNode.__restoreDefaultValues();\n prevNode.__detach();\n prevNodeRef.current = null;\n }\n return () => {\n if (isUnmountingRef.current) {\n // NOTE: Do not restore default values on unmount, see D18197735.\n node.__detach();\n } else {\n prevNodeRef.current = node;\n }\n };\n }, [node]);\n}\nfunction getEventTarget(instance) {\n return typeof instance === 'object' && typeof (instance == null ? void 0 : instance.getScrollableNode) === 'function' ?\n // $FlowFixMe[incompatible-use] - Legacy instance assumptions.\n instance.getScrollableNode() : instance;\n}\n\n// $FlowFixMe[unclear-type] - Legacy instance assumptions.\nfunction isFabricInstance(instance) {\n var _instance$getScrollRe;\n return hasFabricHandle(instance) ||\n // Some components have a setNativeProps function but aren't a host component\n // such as lists like FlatList and SectionList. These should also use\n // forceUpdate in Fabric since setNativeProps doesn't exist on the underlying\n // host component. This crazy hack is essentially special casing those lists and\n // ScrollView itself to use forceUpdate in Fabric.\n // If these components end up using forwardRef then these hacks can go away\n // as instance would actually be the underlying host component and the above check\n // would be sufficient.\n hasFabricHandle(instance == null ? void 0 : instance.getNativeScrollRef == null ? void 0 : instance.getNativeScrollRef()) || hasFabricHandle(instance == null ? void 0 : instance.getScrollResponder == null ? void 0 : (_instance$getScrollRe = instance.getScrollResponder()) == null ? void 0 : _instance$getScrollRe.getNativeScrollRef == null ? void 0 : _instance$getScrollRe.getNativeScrollRef());\n}\n\n// $FlowFixMe[unclear-type] - Legacy instance assumptions.\nfunction hasFabricHandle(instance) {\n var _instance$_internalIn, _instance$_internalIn2;\n // eslint-disable-next-line dot-notation\n return (instance == null ? void 0 : (_instance$_internalIn = instance['_internalInstanceHandle']) == null ? void 0 : (_instance$_internalIn2 = _instance$_internalIn.stateNode) == null ? void 0 : _instance$_internalIn2.canonical) != null;\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport { AnimatedEvent } from '../AnimatedEvent';\nimport AnimatedNode from './AnimatedNode';\nimport AnimatedStyle from './AnimatedStyle';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport invariant from 'fbjs/lib/invariant';\nclass AnimatedProps extends AnimatedNode {\n constructor(props, callback) {\n super();\n if (props.style) {\n props = _objectSpread(_objectSpread({}, props), {}, {\n style: new AnimatedStyle(props.style)\n });\n }\n this._props = props;\n this._callback = callback;\n this.__attach();\n }\n __getValue() {\n var props = {};\n for (var key in this._props) {\n var value = this._props[key];\n if (value instanceof AnimatedNode) {\n if (!value.__isNative || value instanceof AnimatedStyle) {\n // We cannot use value of natively driven nodes this way as the value we have access from\n // JS may not be up to date.\n props[key] = value.__getValue();\n }\n } else if (value instanceof AnimatedEvent) {\n props[key] = value.__getHandler();\n } else {\n props[key] = value;\n }\n }\n return props;\n }\n __getAnimatedValue() {\n var props = {};\n for (var key in this._props) {\n var value = this._props[key];\n if (value instanceof AnimatedNode) {\n props[key] = value.__getAnimatedValue();\n }\n }\n return props;\n }\n __attach() {\n for (var key in this._props) {\n var value = this._props[key];\n if (value instanceof AnimatedNode) {\n value.__addChild(this);\n }\n }\n }\n __detach() {\n if (this.__isNative && this._animatedView) {\n this.__disconnectAnimatedView();\n }\n for (var key in this._props) {\n var value = this._props[key];\n if (value instanceof AnimatedNode) {\n value.__removeChild(this);\n }\n }\n super.__detach();\n }\n update() {\n this._callback();\n }\n __makeNative() {\n if (!this.__isNative) {\n this.__isNative = true;\n for (var key in this._props) {\n var value = this._props[key];\n if (value instanceof AnimatedNode) {\n value.__makeNative();\n }\n }\n if (this._animatedView) {\n this.__connectAnimatedView();\n }\n }\n }\n setNativeView(animatedView) {\n if (this._animatedView === animatedView) {\n return;\n }\n this._animatedView = animatedView;\n if (this.__isNative) {\n this.__connectAnimatedView();\n }\n }\n __connectAnimatedView() {\n invariant(this.__isNative, 'Expected node to be marked as \"native\"');\n var nativeViewTag = this._animatedView;\n invariant(nativeViewTag != null, 'Unable to locate attached view in the native tree');\n NativeAnimatedHelper.API.connectAnimatedNodeToView(this.__getNativeTag(), nativeViewTag);\n }\n __disconnectAnimatedView() {\n invariant(this.__isNative, 'Expected node to be marked as \"native\"');\n var nativeViewTag = this._animatedView;\n invariant(nativeViewTag != null, 'Unable to locate attached view in the native tree');\n NativeAnimatedHelper.API.disconnectAnimatedNodeFromView(this.__getNativeTag(), nativeViewTag);\n }\n __restoreDefaultValues() {\n // When using the native driver, view properties need to be restored to\n // their default values manually since react no longer tracks them. This\n // is needed to handle cases where a prop driven by native animated is removed\n // after having been changed natively by an animation.\n if (this.__isNative) {\n NativeAnimatedHelper.API.restoreDefaultValues(this.__getNativeTag());\n }\n }\n __getNativeConfig() {\n var propsConfig = {};\n for (var propKey in this._props) {\n var value = this._props[propKey];\n if (value instanceof AnimatedNode) {\n value.__makeNative();\n propsConfig[propKey] = value.__getNativeTag();\n }\n }\n return {\n type: 'props',\n props: propsConfig\n };\n }\n}\nexport default AnimatedProps;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedValue from './nodes/AnimatedValue';\nimport NativeAnimatedHelper from './NativeAnimatedHelper';\nimport invariant from 'fbjs/lib/invariant';\nimport { shouldUseNativeDriver } from './NativeAnimatedHelper';\nvar __DEV__ = process.env.NODE_ENV !== 'production';\nexport function attachNativeEvent(viewRef, eventName, argMapping) {\n // Find animated values in `argMapping` and create an array representing their\n // key path inside the `nativeEvent` object. Ex.: ['contentOffset', 'x'].\n var eventMappings = [];\n var traverse = (value, path) => {\n if (value instanceof AnimatedValue) {\n value.__makeNative();\n eventMappings.push({\n nativeEventPath: path,\n animatedValueTag: value.__getNativeTag()\n });\n } else if (typeof value === 'object') {\n for (var _key in value) {\n traverse(value[_key], path.concat(_key));\n }\n }\n };\n invariant(argMapping[0] && argMapping[0].nativeEvent, 'Native driven events only support animated values contained inside `nativeEvent`.');\n\n // Assume that the event containing `nativeEvent` is always the first argument.\n traverse(argMapping[0].nativeEvent, []);\n if (viewRef != null) {\n eventMappings.forEach(mapping => {\n NativeAnimatedHelper.API.addAnimatedEventToView(viewRef, eventName, mapping);\n });\n }\n return {\n detach() {\n if (viewRef != null) {\n eventMappings.forEach(mapping => {\n NativeAnimatedHelper.API.removeAnimatedEventFromView(viewRef, eventName,\n // $FlowFixMe[incompatible-call]\n mapping.animatedValueTag);\n });\n }\n }\n };\n}\nfunction validateMapping(argMapping, args) {\n var validate = (recMapping, recEvt, key) => {\n if (recMapping instanceof AnimatedValue) {\n invariant(typeof recEvt === 'number', 'Bad mapping of event key ' + key + ', should be number but got ' + typeof recEvt);\n return;\n }\n if (typeof recEvt === 'number') {\n invariant(recMapping instanceof AnimatedValue, 'Bad mapping of type ' + typeof recMapping + ' for key ' + key + ', event value must map to AnimatedValue');\n return;\n }\n invariant(typeof recMapping === 'object', 'Bad mapping of type ' + typeof recMapping + ' for key ' + key);\n invariant(typeof recEvt === 'object', 'Bad event of type ' + typeof recEvt + ' for key ' + key);\n for (var mappingKey in recMapping) {\n validate(recMapping[mappingKey], recEvt[mappingKey], mappingKey);\n }\n };\n invariant(args.length >= argMapping.length, 'Event has less arguments than mapping');\n argMapping.forEach((mapping, idx) => {\n validate(mapping, args[idx], 'arg' + idx);\n });\n}\nexport class AnimatedEvent {\n constructor(argMapping, config) {\n this._listeners = [];\n this._argMapping = argMapping;\n if (config == null) {\n console.warn('Animated.event now requires a second argument for options');\n config = {\n useNativeDriver: false\n };\n }\n if (config.listener) {\n this.__addListener(config.listener);\n }\n this._callListeners = this._callListeners.bind(this);\n this._attachedEvent = null;\n this.__isNative = shouldUseNativeDriver(config);\n }\n __addListener(callback) {\n this._listeners.push(callback);\n }\n __removeListener(callback) {\n this._listeners = this._listeners.filter(listener => listener !== callback);\n }\n __attach(viewRef, eventName) {\n invariant(this.__isNative, 'Only native driven events need to be attached.');\n this._attachedEvent = attachNativeEvent(viewRef, eventName, this._argMapping);\n }\n __detach(viewTag, eventName) {\n invariant(this.__isNative, 'Only native driven events need to be detached.');\n this._attachedEvent && this._attachedEvent.detach();\n }\n __getHandler() {\n var _this = this;\n if (this.__isNative) {\n if (__DEV__) {\n var _validatedMapping = false;\n return function () {\n for (var _len = arguments.length, args = new Array(_len), _key2 = 0; _key2 < _len; _key2++) {\n args[_key2] = arguments[_key2];\n }\n if (!_validatedMapping) {\n validateMapping(_this._argMapping, args);\n _validatedMapping = true;\n }\n _this._callListeners(...args);\n };\n } else {\n return this._callListeners;\n }\n }\n var validatedMapping = false;\n return function () {\n for (var _len2 = arguments.length, args = new Array(_len2), _key3 = 0; _key3 < _len2; _key3++) {\n args[_key3] = arguments[_key3];\n }\n if (__DEV__ && !validatedMapping) {\n validateMapping(_this._argMapping, args);\n validatedMapping = true;\n }\n var traverse = (recMapping, recEvt, key) => {\n if (recMapping instanceof AnimatedValue) {\n if (typeof recEvt === 'number') {\n recMapping.setValue(recEvt);\n }\n } else if (typeof recMapping === 'object') {\n for (var mappingKey in recMapping) {\n /* $FlowFixMe(>=0.120.0) This comment suppresses an error found\n * when Flow v0.120 was deployed. To see the error, delete this\n * comment and run Flow. */\n traverse(recMapping[mappingKey], recEvt[mappingKey], mappingKey);\n }\n }\n };\n _this._argMapping.forEach((mapping, idx) => {\n traverse(mapping, args[idx], 'arg' + idx);\n });\n _this._callListeners(...args);\n };\n }\n _callListeners() {\n for (var _len3 = arguments.length, args = new Array(_len3), _key4 = 0; _key4 < _len3; _key4++) {\n args[_key4] = arguments[_key4];\n }\n this._listeners.forEach(listener => listener(...args));\n }\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nimport InteractionManager from '../../../../exports/InteractionManager';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nvar NativeAnimatedAPI = NativeAnimatedHelper.API;\n\n/**\n * Animated works by building a directed acyclic graph of dependencies\n * transparently when you render your Animated components.\n *\n * new Animated.Value(0)\n * .interpolate() .interpolate() new Animated.Value(1)\n * opacity translateY scale\n * style transform\n * View#234 style\n * View#123\n *\n * A) Top Down phase\n * When an Animated.Value is updated, we recursively go down through this\n * graph in order to find leaf nodes: the views that we flag as needing\n * an update.\n *\n * B) Bottom Up phase\n * When a view is flagged as needing an update, we recursively go back up\n * in order to build the new value that it needs. The reason why we need\n * this two-phases process is to deal with composite props such as\n * transform which can receive values from multiple parents.\n */\nfunction _flush(rootNode) {\n var animatedStyles = new Set();\n function findAnimatedStyles(node) {\n /* $FlowFixMe[prop-missing] (>=0.68.0 site=react_native_fb) This comment\n * suppresses an error found when Flow v0.68 was deployed. To see the error\n * delete this comment and run Flow. */\n if (typeof node.update === 'function') {\n animatedStyles.add(node);\n } else {\n node.__getChildren().forEach(findAnimatedStyles);\n }\n }\n findAnimatedStyles(rootNode);\n // $FlowFixMe[prop-missing]\n animatedStyles.forEach(animatedStyle => animatedStyle.update());\n}\n\n/**\n * Some operations are executed only on batch end, which is _mostly_ scheduled when\n * Animated component props change. For some of the changes which require immediate execution\n * (e.g. setValue), we create a separate batch in case none is scheduled.\n */\nfunction _executeAsAnimatedBatch(id, operation) {\n NativeAnimatedAPI.setWaitingForIdentifier(id);\n operation();\n NativeAnimatedAPI.unsetWaitingForIdentifier(id);\n}\n\n/**\n * Standard value for driving animations. One `Animated.Value` can drive\n * multiple properties in a synchronized fashion, but can only be driven by one\n * mechanism at a time. Using a new mechanism (e.g. starting a new animation,\n * or calling `setValue`) will stop any previous ones.\n *\n * See https://reactnative.dev/docs/animatedvalue\n */\nclass AnimatedValue extends AnimatedWithChildren {\n constructor(value, config) {\n super();\n if (typeof value !== 'number') {\n throw new Error('AnimatedValue: Attempting to set value to undefined');\n }\n this._startingValue = this._value = value;\n this._offset = 0;\n this._animation = null;\n if (config && config.useNativeDriver) {\n this.__makeNative();\n }\n }\n __detach() {\n if (this.__isNative) {\n NativeAnimatedAPI.getValue(this.__getNativeTag(), value => {\n this._value = value - this._offset;\n });\n }\n this.stopAnimation();\n super.__detach();\n }\n __getValue() {\n return this._value + this._offset;\n }\n\n /**\n * Directly set the value. This will stop any animations running on the value\n * and update all the bound properties.\n *\n * See https://reactnative.dev/docs/animatedvalue#setvalue\n */\n setValue(value) {\n if (this._animation) {\n this._animation.stop();\n this._animation = null;\n }\n this._updateValue(value, !this.__isNative /* don't perform a flush for natively driven values */);\n\n if (this.__isNative) {\n _executeAsAnimatedBatch(this.__getNativeTag().toString(), () => NativeAnimatedAPI.setAnimatedNodeValue(this.__getNativeTag(), value));\n }\n }\n\n /**\n * Sets an offset that is applied on top of whatever value is set, whether via\n * `setValue`, an animation, or `Animated.event`. Useful for compensating\n * things like the start of a pan gesture.\n *\n * See https://reactnative.dev/docs/animatedvalue#setoffset\n */\n setOffset(offset) {\n this._offset = offset;\n if (this.__isNative) {\n NativeAnimatedAPI.setAnimatedNodeOffset(this.__getNativeTag(), offset);\n }\n }\n\n /**\n * Merges the offset value into the base value and resets the offset to zero.\n * The final output of the value is unchanged.\n *\n * See https://reactnative.dev/docs/animatedvalue#flattenoffset\n */\n flattenOffset() {\n this._value += this._offset;\n this._offset = 0;\n if (this.__isNative) {\n NativeAnimatedAPI.flattenAnimatedNodeOffset(this.__getNativeTag());\n }\n }\n\n /**\n * Sets the offset value to the base value, and resets the base value to zero.\n * The final output of the value is unchanged.\n *\n * See https://reactnative.dev/docs/animatedvalue#extractoffset\n */\n extractOffset() {\n this._offset += this._value;\n this._value = 0;\n if (this.__isNative) {\n NativeAnimatedAPI.extractAnimatedNodeOffset(this.__getNativeTag());\n }\n }\n\n /**\n * Stops any running animation or tracking. `callback` is invoked with the\n * final value after stopping the animation, which is useful for updating\n * state to match the animation position with layout.\n *\n * See https://reactnative.dev/docs/animatedvalue#stopanimation\n */\n stopAnimation(callback) {\n this.stopTracking();\n this._animation && this._animation.stop();\n this._animation = null;\n if (callback) {\n if (this.__isNative) {\n NativeAnimatedAPI.getValue(this.__getNativeTag(), callback);\n } else {\n callback(this.__getValue());\n }\n }\n }\n\n /**\n * Stops any animation and resets the value to its original.\n *\n * See https://reactnative.dev/docs/animatedvalue#resetanimation\n */\n resetAnimation(callback) {\n this.stopAnimation(callback);\n this._value = this._startingValue;\n if (this.__isNative) {\n NativeAnimatedAPI.setAnimatedNodeValue(this.__getNativeTag(), this._startingValue);\n }\n }\n __onAnimatedValueUpdateReceived(value) {\n this._updateValue(value, false /*flush*/);\n }\n\n /**\n * Interpolates the value before updating the property, e.g. mapping 0-1 to\n * 0-10.\n */\n interpolate(config) {\n return new AnimatedInterpolation(this, config);\n }\n\n /**\n * Typically only used internally, but could be used by a custom Animation\n * class.\n *\n * See https://reactnative.dev/docs/animatedvalue#animate\n */\n animate(animation, callback) {\n var handle = null;\n if (animation.__isInteraction) {\n handle = InteractionManager.createInteractionHandle();\n }\n var previousAnimation = this._animation;\n this._animation && this._animation.stop();\n this._animation = animation;\n animation.start(this._value, value => {\n // Natively driven animations will never call into that callback\n this._updateValue(value, true /* flush */);\n }, result => {\n this._animation = null;\n if (handle !== null) {\n InteractionManager.clearInteractionHandle(handle);\n }\n callback && callback(result);\n }, previousAnimation, this);\n }\n\n /**\n * Typically only used internally.\n */\n stopTracking() {\n this._tracking && this._tracking.__detach();\n this._tracking = null;\n }\n\n /**\n * Typically only used internally.\n */\n track(tracking) {\n this.stopTracking();\n this._tracking = tracking;\n // Make sure that the tracking animation starts executing\n this._tracking && this._tracking.update();\n }\n _updateValue(value, flush) {\n if (value === undefined) {\n throw new Error('AnimatedValue: Attempting to set value to undefined');\n }\n this._value = value;\n if (flush) {\n _flush(this);\n }\n super.__callListeners(this.__getValue());\n }\n __getNativeConfig() {\n return {\n type: 'value',\n value: this._value,\n offset: this._offset\n };\n }\n}\nexport default AnimatedValue;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n/* eslint no-bitwise: 0 */\n\n'use strict';\n\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport AnimatedWithChildren from './AnimatedWithChildren';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport invariant from 'fbjs/lib/invariant';\nimport normalizeColor from '@react-native/normalize-colors';\nvar __DEV__ = process.env.NODE_ENV !== 'production';\nvar linear = t => t;\n\n/**\n * Very handy helper to map input ranges to output ranges with an easing\n * function and custom behavior outside of the ranges.\n */\nfunction createInterpolation(config) {\n if (config.outputRange && typeof config.outputRange[0] === 'string') {\n return createInterpolationFromStringOutputRange(config);\n }\n var outputRange = config.outputRange;\n var inputRange = config.inputRange;\n if (__DEV__) {\n checkInfiniteRange('outputRange', outputRange);\n checkInfiniteRange('inputRange', inputRange);\n checkValidInputRange(inputRange);\n invariant(inputRange.length === outputRange.length, 'inputRange (' + inputRange.length + ') and outputRange (' + outputRange.length + ') must have the same length');\n }\n var easing = config.easing || linear;\n var extrapolateLeft = 'extend';\n if (config.extrapolateLeft !== undefined) {\n extrapolateLeft = config.extrapolateLeft;\n } else if (config.extrapolate !== undefined) {\n extrapolateLeft = config.extrapolate;\n }\n var extrapolateRight = 'extend';\n if (config.extrapolateRight !== undefined) {\n extrapolateRight = config.extrapolateRight;\n } else if (config.extrapolate !== undefined) {\n extrapolateRight = config.extrapolate;\n }\n return input => {\n invariant(typeof input === 'number', 'Cannot interpolation an input which is not a number');\n var range = findRange(input, inputRange);\n return interpolate(input, inputRange[range], inputRange[range + 1], outputRange[range], outputRange[range + 1], easing, extrapolateLeft, extrapolateRight);\n };\n}\nfunction interpolate(input, inputMin, inputMax, outputMin, outputMax, easing, extrapolateLeft, extrapolateRight) {\n var result = input;\n\n // Extrapolate\n if (result < inputMin) {\n if (extrapolateLeft === 'identity') {\n return result;\n } else if (extrapolateLeft === 'clamp') {\n result = inputMin;\n } else if (extrapolateLeft === 'extend') {\n // noop\n }\n }\n if (result > inputMax) {\n if (extrapolateRight === 'identity') {\n return result;\n } else if (extrapolateRight === 'clamp') {\n result = inputMax;\n } else if (extrapolateRight === 'extend') {\n // noop\n }\n }\n if (outputMin === outputMax) {\n return outputMin;\n }\n if (inputMin === inputMax) {\n if (input <= inputMin) {\n return outputMin;\n }\n return outputMax;\n }\n\n // Input Range\n if (inputMin === -Infinity) {\n result = -result;\n } else if (inputMax === Infinity) {\n result = result - inputMin;\n } else {\n result = (result - inputMin) / (inputMax - inputMin);\n }\n\n // Easing\n result = easing(result);\n\n // Output Range\n if (outputMin === -Infinity) {\n result = -result;\n } else if (outputMax === Infinity) {\n result = result + outputMin;\n } else {\n result = result * (outputMax - outputMin) + outputMin;\n }\n return result;\n}\nfunction colorToRgba(input) {\n var normalizedColor = normalizeColor(input);\n if (normalizedColor === null || typeof normalizedColor !== 'number') {\n return input;\n }\n normalizedColor = normalizedColor || 0;\n var r = (normalizedColor & 0xff000000) >>> 24;\n var g = (normalizedColor & 0x00ff0000) >>> 16;\n var b = (normalizedColor & 0x0000ff00) >>> 8;\n var a = (normalizedColor & 0x000000ff) / 255;\n return \"rgba(\" + r + \", \" + g + \", \" + b + \", \" + a + \")\";\n}\nvar stringShapeRegex = /[+-]?(?:\\d+\\.?\\d*|\\.\\d+)(?:[eE][+-]?\\d+)?/g;\n\n/**\n * Supports string shapes by extracting numbers so new values can be computed,\n * and recombines those values into new strings of the same shape. Supports\n * things like:\n *\n * rgba(123, 42, 99, 0.36) // colors\n * -45deg // values with units\n */\nfunction createInterpolationFromStringOutputRange(config) {\n var outputRange = config.outputRange;\n invariant(outputRange.length >= 2, 'Bad output range');\n outputRange = outputRange.map(colorToRgba);\n checkPattern(outputRange);\n\n // ['rgba(0, 100, 200, 0)', 'rgba(50, 150, 250, 0.5)']\n // ->\n // [\n // [0, 50],\n // [100, 150],\n // [200, 250],\n // [0, 0.5],\n // ]\n /* $FlowFixMe[incompatible-use] (>=0.18.0): `outputRange[0].match()` can\n * return `null`. Need to guard against this possibility. */\n var outputRanges = outputRange[0].match(stringShapeRegex).map(() => []);\n outputRange.forEach(value => {\n /* $FlowFixMe[incompatible-use] (>=0.18.0): `value.match()` can return\n * `null`. Need to guard against this possibility. */\n value.match(stringShapeRegex).forEach((number, i) => {\n outputRanges[i].push(+number);\n });\n });\n var interpolations = outputRange[0].match(stringShapeRegex)\n /* $FlowFixMe[incompatible-use] (>=0.18.0): `outputRange[0].match()` can\n * return `null`. Need to guard against this possibility. */\n /* $FlowFixMe[incompatible-call] (>=0.18.0): `outputRange[0].match()` can\n * return `null`. Need to guard against this possibility. */.map((value, i) => {\n return createInterpolation(_objectSpread(_objectSpread({}, config), {}, {\n outputRange: outputRanges[i]\n }));\n });\n\n // rgba requires that the r,g,b are integers.... so we want to round them, but we *dont* want to\n // round the opacity (4th column).\n var shouldRound = isRgbOrRgba(outputRange[0]);\n return input => {\n var i = 0;\n // 'rgba(0, 100, 200, 0)'\n // ->\n // 'rgba(${interpolations[0](input)}, ${interpolations[1](input)}, ...'\n return outputRange[0].replace(stringShapeRegex, () => {\n var val = +interpolations[i++](input);\n if (shouldRound) {\n val = i < 4 ? Math.round(val) : Math.round(val * 1000) / 1000;\n }\n return String(val);\n });\n };\n}\nfunction isRgbOrRgba(range) {\n return typeof range === 'string' && range.startsWith('rgb');\n}\nfunction checkPattern(arr) {\n var pattern = arr[0].replace(stringShapeRegex, '');\n for (var i = 1; i < arr.length; ++i) {\n invariant(pattern === arr[i].replace(stringShapeRegex, ''), 'invalid pattern ' + arr[0] + ' and ' + arr[i]);\n }\n}\nfunction findRange(input, inputRange) {\n var i;\n for (i = 1; i < inputRange.length - 1; ++i) {\n if (inputRange[i] >= input) {\n break;\n }\n }\n return i - 1;\n}\nfunction checkValidInputRange(arr) {\n invariant(arr.length >= 2, 'inputRange must have at least 2 elements');\n var message = 'inputRange must be monotonically non-decreasing ' + String(arr);\n for (var i = 1; i < arr.length; ++i) {\n invariant(arr[i] >= arr[i - 1], message);\n }\n}\nfunction checkInfiniteRange(name, arr) {\n invariant(arr.length >= 2, name + ' must have at least 2 elements');\n invariant(arr.length !== 2 || arr[0] !== -Infinity || arr[1] !== Infinity,\n /* $FlowFixMe[incompatible-type] (>=0.13.0) - In the addition expression\n * below this comment, one or both of the operands may be something that\n * doesn't cleanly convert to a string, like undefined, null, and object,\n * etc. If you really mean this implicit string conversion, you can do\n * something like String(myThing) */\n name + 'cannot be ]-infinity;+infinity[ ' + arr);\n}\nclass AnimatedInterpolation extends AnimatedWithChildren {\n // Export for testing.\n\n constructor(parent, config) {\n super();\n this._parent = parent;\n this._config = config;\n this._interpolation = createInterpolation(config);\n }\n __makeNative(platformConfig) {\n this._parent.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n __getValue() {\n var parentValue = this._parent.__getValue();\n invariant(typeof parentValue === 'number', 'Cannot interpolate an input which is not a number.');\n return this._interpolation(parentValue);\n }\n interpolate(config) {\n return new AnimatedInterpolation(this, config);\n }\n __attach() {\n this._parent.__addChild(this);\n }\n __detach() {\n this._parent.__removeChild(this);\n super.__detach();\n }\n __transformDataType(range) {\n return range.map(NativeAnimatedHelper.transformDataType);\n }\n __getNativeConfig() {\n if (__DEV__) {\n NativeAnimatedHelper.validateInterpolation(this._config);\n }\n return {\n inputRange: this._config.inputRange,\n // Only the `outputRange` can contain strings so we don't need to transform `inputRange` here\n outputRange: this.__transformDataType(this._config.outputRange),\n extrapolateLeft: this._config.extrapolateLeft || this._config.extrapolate || 'extend',\n extrapolateRight: this._config.extrapolateRight || this._config.extrapolate || 'extend',\n type: 'interpolation'\n };\n }\n}\nAnimatedInterpolation.__createInterpolation = createInterpolation;\nexport default AnimatedInterpolation;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _createForOfIteratorHelperLoose from \"@babel/runtime/helpers/createForOfIteratorHelperLoose\";\nimport AnimatedNode from './AnimatedNode';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nclass AnimatedWithChildren extends AnimatedNode {\n constructor() {\n super();\n this._children = [];\n }\n __makeNative(platformConfig) {\n if (!this.__isNative) {\n this.__isNative = true;\n for (var _iterator = _createForOfIteratorHelperLoose(this._children), _step; !(_step = _iterator()).done;) {\n var child = _step.value;\n child.__makeNative(platformConfig);\n NativeAnimatedHelper.API.connectAnimatedNodes(this.__getNativeTag(), child.__getNativeTag());\n }\n }\n super.__makeNative(platformConfig);\n }\n __addChild(child) {\n if (this._children.length === 0) {\n this.__attach();\n }\n this._children.push(child);\n if (this.__isNative) {\n // Only accept \"native\" animated nodes as children\n child.__makeNative(this.__getPlatformConfig());\n NativeAnimatedHelper.API.connectAnimatedNodes(this.__getNativeTag(), child.__getNativeTag());\n }\n }\n __removeChild(child) {\n var index = this._children.indexOf(child);\n if (index === -1) {\n console.warn(\"Trying to remove a child that doesn't exist\");\n return;\n }\n if (this.__isNative && child.__isNative) {\n NativeAnimatedHelper.API.disconnectAnimatedNodes(this.__getNativeTag(), child.__getNativeTag());\n }\n this._children.splice(index, 1);\n if (this._children.length === 0) {\n this.__detach();\n }\n }\n __getChildren() {\n return this._children;\n }\n __callListeners(value) {\n super.__callListeners(value);\n if (!this.__isNative) {\n for (var _iterator2 = _createForOfIteratorHelperLoose(this._children), _step2; !(_step2 = _iterator2()).done;) {\n var child = _step2.value;\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n if (child.__getValue) {\n child.__callListeners(child.__getValue());\n }\n }\n }\n }\n}\nexport default AnimatedWithChildren;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nvar NativeAnimatedAPI = NativeAnimatedHelper.API;\nimport invariant from 'fbjs/lib/invariant';\nvar _uniqueId = 1;\n\n// Note(vjeux): this would be better as an interface but flow doesn't\n// support them yet\nclass AnimatedNode {\n __attach() {}\n __detach() {\n if (this.__isNative && this.__nativeTag != null) {\n NativeAnimatedHelper.API.dropAnimatedNode(this.__nativeTag);\n this.__nativeTag = undefined;\n }\n }\n __getValue() {}\n __getAnimatedValue() {\n return this.__getValue();\n }\n __addChild(child) {}\n __removeChild(child) {}\n __getChildren() {\n return [];\n }\n\n /* Methods and props used by native Animated impl */\n\n constructor() {\n this._listeners = {};\n }\n __makeNative(platformConfig) {\n if (!this.__isNative) {\n throw new Error('This node cannot be made a \"native\" animated node');\n }\n this._platformConfig = platformConfig;\n if (this.hasListeners()) {\n this._startListeningToNativeValueUpdates();\n }\n }\n\n /**\n * Adds an asynchronous listener to the value so you can observe updates from\n * animations. This is useful because there is no way to\n * synchronously read the value because it might be driven natively.\n *\n * See https://reactnative.dev/docs/animatedvalue#addlistener\n */\n addListener(callback) {\n var id = String(_uniqueId++);\n this._listeners[id] = callback;\n if (this.__isNative) {\n this._startListeningToNativeValueUpdates();\n }\n return id;\n }\n\n /**\n * Unregister a listener. The `id` param shall match the identifier\n * previously returned by `addListener()`.\n *\n * See https://reactnative.dev/docs/animatedvalue#removelistener\n */\n removeListener(id) {\n delete this._listeners[id];\n if (this.__isNative && !this.hasListeners()) {\n this._stopListeningForNativeValueUpdates();\n }\n }\n\n /**\n * Remove all registered listeners.\n *\n * See https://reactnative.dev/docs/animatedvalue#removealllisteners\n */\n removeAllListeners() {\n this._listeners = {};\n if (this.__isNative) {\n this._stopListeningForNativeValueUpdates();\n }\n }\n hasListeners() {\n return !!Object.keys(this._listeners).length;\n }\n _startListeningToNativeValueUpdates() {\n if (this.__nativeAnimatedValueListener && !this.__shouldUpdateListenersForNewNativeTag) {\n return;\n }\n if (this.__shouldUpdateListenersForNewNativeTag) {\n this.__shouldUpdateListenersForNewNativeTag = false;\n this._stopListeningForNativeValueUpdates();\n }\n NativeAnimatedAPI.startListeningToAnimatedNodeValue(this.__getNativeTag());\n this.__nativeAnimatedValueListener = NativeAnimatedHelper.nativeEventEmitter.addListener('onAnimatedValueUpdate', data => {\n if (data.tag !== this.__getNativeTag()) {\n return;\n }\n this.__onAnimatedValueUpdateReceived(data.value);\n });\n }\n __onAnimatedValueUpdateReceived(value) {\n this.__callListeners(value);\n }\n __callListeners(value) {\n for (var _key in this._listeners) {\n this._listeners[_key]({\n value\n });\n }\n }\n _stopListeningForNativeValueUpdates() {\n if (!this.__nativeAnimatedValueListener) {\n return;\n }\n this.__nativeAnimatedValueListener.remove();\n this.__nativeAnimatedValueListener = null;\n NativeAnimatedAPI.stopListeningToAnimatedNodeValue(this.__getNativeTag());\n }\n __getNativeTag() {\n var _this$__nativeTag;\n NativeAnimatedHelper.assertNativeAnimatedModule();\n invariant(this.__isNative, 'Attempt to get native tag from node not marked as \"native\"');\n var nativeTag = (_this$__nativeTag = this.__nativeTag) !== null && _this$__nativeTag !== void 0 ? _this$__nativeTag : NativeAnimatedHelper.generateNewNodeTag();\n if (this.__nativeTag == null) {\n this.__nativeTag = nativeTag;\n var config = this.__getNativeConfig();\n if (this._platformConfig) {\n config.platformConfig = this._platformConfig;\n }\n NativeAnimatedHelper.API.createAnimatedNode(nativeTag, config);\n this.__shouldUpdateListenersForNewNativeTag = true;\n }\n return nativeTag;\n }\n __getNativeConfig() {\n throw new Error('This JS animated node type cannot be used as native animated node');\n }\n toJSON() {\n return this.__getValue();\n }\n __getPlatformConfig() {\n return this._platformConfig;\n }\n __setPlatformConfig(platformConfig) {\n this._platformConfig = platformConfig;\n }\n}\nexport default AnimatedNode;","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport NativeAnimatedNonTurboModule from './NativeAnimatedModule';\nimport NativeAnimatedTurboModule from './NativeAnimatedTurboModule';\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport Platform from '../Utilities/Platform';\nimport ReactNativeFeatureFlags from '../ReactNative/ReactNativeFeatureFlags';\nimport invariant from 'fbjs/lib/invariant';\nimport RCTDeviceEventEmitter from '../EventEmitter/RCTDeviceEventEmitter';\n// TODO T69437152 @petetheheat - Delete this fork when Fabric ships to 100%.\nvar NativeAnimatedModule = Platform.OS === 'ios' && global.RN$Bridgeless === true ? NativeAnimatedTurboModule : NativeAnimatedNonTurboModule;\nvar __nativeAnimatedNodeTagCount = 1; /* used for animated nodes */\nvar __nativeAnimationIdCount = 1; /* used for started animations */\n\nvar nativeEventEmitter;\nvar waitingForQueuedOperations = new Set();\nvar queueOperations = false;\nvar queue = [];\n// $FlowFixMe\nvar singleOpQueue = [];\nvar useSingleOpBatching = false;\nPlatform.OS === 'android' && !!(NativeAnimatedModule != null && NativeAnimatedModule.queueAndExecuteBatchedOperations) && ReactNativeFeatureFlags.animatedShouldUseSingleOp();\nvar flushQueueTimeout = null;\nvar eventListenerGetValueCallbacks = {};\nvar eventListenerAnimationFinishedCallbacks = {};\nvar globalEventEmitterGetValueListener = null;\nvar globalEventEmitterAnimationFinishedListener = null;\nvar nativeOps = useSingleOpBatching ? function () {\n var apis = ['createAnimatedNode',\n // 1\n 'updateAnimatedNodeConfig',\n // 2\n 'getValue',\n // 3\n 'startListeningToAnimatedNodeValue',\n // 4\n 'stopListeningToAnimatedNodeValue',\n // 5\n 'connectAnimatedNodes',\n // 6\n 'disconnectAnimatedNodes',\n // 7\n 'startAnimatingNode',\n // 8\n 'stopAnimation',\n // 9\n 'setAnimatedNodeValue',\n // 10\n 'setAnimatedNodeOffset',\n // 11\n 'flattenAnimatedNodeOffset',\n // 12\n 'extractAnimatedNodeOffset',\n // 13\n 'connectAnimatedNodeToView',\n // 14\n 'disconnectAnimatedNodeFromView',\n // 15\n 'restoreDefaultValues',\n // 16\n 'dropAnimatedNode',\n // 17\n 'addAnimatedEventToView',\n // 18\n 'removeAnimatedEventFromView',\n // 19\n 'addListener',\n // 20\n 'removeListener' // 21\n ];\n\n return apis.reduce((acc, functionName, i) => {\n // These indices need to be kept in sync with the indices in native (see NativeAnimatedModule in Java, or the equivalent for any other native platform).\n // $FlowFixMe[prop-missing]\n acc[functionName] = i + 1;\n return acc;\n }, {});\n}() : NativeAnimatedModule;\n\n/**\n * Wrappers around NativeAnimatedModule to provide flow and autocomplete support for\n * the native module methods, and automatic queue management on Android\n */\nvar API = {\n getValue: function getValue(tag, saveValueCallback) {\n invariant(nativeOps, 'Native animated module is not available');\n if (useSingleOpBatching) {\n if (saveValueCallback) {\n eventListenerGetValueCallbacks[tag] = saveValueCallback;\n }\n // $FlowFixMe\n API.queueOperation(nativeOps.getValue, tag);\n } else {\n API.queueOperation(nativeOps.getValue, tag, saveValueCallback);\n }\n },\n setWaitingForIdentifier: function setWaitingForIdentifier(id) {\n waitingForQueuedOperations.add(id);\n queueOperations = true;\n if (ReactNativeFeatureFlags.animatedShouldDebounceQueueFlush() && flushQueueTimeout) {\n clearTimeout(flushQueueTimeout);\n }\n },\n unsetWaitingForIdentifier: function unsetWaitingForIdentifier(id) {\n waitingForQueuedOperations.delete(id);\n if (waitingForQueuedOperations.size === 0) {\n queueOperations = false;\n API.disableQueue();\n }\n },\n disableQueue: function disableQueue() {\n invariant(nativeOps, 'Native animated module is not available');\n if (ReactNativeFeatureFlags.animatedShouldDebounceQueueFlush()) {\n var prevTimeout = flushQueueTimeout;\n clearImmediate(prevTimeout);\n flushQueueTimeout = setImmediate(API.flushQueue);\n } else {\n API.flushQueue();\n }\n },\n flushQueue: function flushQueue() {\n /*\n invariant(NativeAnimatedModule, 'Native animated module is not available');\n flushQueueTimeout = null;\n // Early returns before calling any APIs\n if (useSingleOpBatching && singleOpQueue.length === 0) {\n return;\n }\n if (!useSingleOpBatching && queue.length === 0) {\n return;\n }\n if (useSingleOpBatching) {\n // Set up event listener for callbacks if it's not set up\n if (\n !globalEventEmitterGetValueListener ||\n !globalEventEmitterAnimationFinishedListener\n ) {\n setupGlobalEventEmitterListeners();\n }\n // Single op batching doesn't use callback functions, instead we\n // use RCTDeviceEventEmitter. This reduces overhead of sending lots of\n // JSI functions across to native code; but also, TM infrastructure currently\n // does not support packing a function into native arrays.\n NativeAnimatedModule.queueAndExecuteBatchedOperations?.(singleOpQueue);\n singleOpQueue.length = 0;\n } else {\n Platform.OS === 'android' && NativeAnimatedModule.startOperationBatch?.();\n for (let q = 0, l = queue.length; q < l; q++) {\n queue[q]();\n }\n queue.length = 0;\n Platform.OS === 'android' &&\n NativeAnimatedModule.finishOperationBatch?.();\n }\n */\n },\n queueOperation: function queueOperation(fn) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n if (useSingleOpBatching) {\n // Get the command ID from the queued function, and push that ID and any arguments needed to execute the operation\n // $FlowFixMe: surprise, fn is actually a number\n singleOpQueue.push(fn, ...args);\n return;\n }\n\n // If queueing is explicitly on, *or* the queue has not yet\n // been flushed, use the queue. This is to prevent operations\n // from being executed out of order.\n if (queueOperations || queue.length !== 0) {\n queue.push(() => fn(...args));\n } else {\n fn(...args);\n }\n },\n createAnimatedNode: function createAnimatedNode(tag, config) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.createAnimatedNode, tag, config);\n },\n updateAnimatedNodeConfig: function updateAnimatedNodeConfig(tag, config) {\n invariant(nativeOps, 'Native animated module is not available');\n //if (nativeOps.updateAnimatedNodeConfig) {\n // API.queueOperation(nativeOps.updateAnimatedNodeConfig, tag, config);\n //}\n },\n\n startListeningToAnimatedNodeValue: function startListeningToAnimatedNodeValue(tag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.startListeningToAnimatedNodeValue, tag);\n },\n stopListeningToAnimatedNodeValue: function stopListeningToAnimatedNodeValue(tag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.stopListeningToAnimatedNodeValue, tag);\n },\n connectAnimatedNodes: function connectAnimatedNodes(parentTag, childTag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.connectAnimatedNodes, parentTag, childTag);\n },\n disconnectAnimatedNodes: function disconnectAnimatedNodes(parentTag, childTag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.disconnectAnimatedNodes, parentTag, childTag);\n },\n startAnimatingNode: function startAnimatingNode(animationId, nodeTag, config, endCallback) {\n invariant(nativeOps, 'Native animated module is not available');\n if (useSingleOpBatching) {\n if (endCallback) {\n eventListenerAnimationFinishedCallbacks[animationId] = endCallback;\n }\n // $FlowFixMe\n API.queueOperation(nativeOps.startAnimatingNode, animationId, nodeTag, config);\n } else {\n API.queueOperation(nativeOps.startAnimatingNode, animationId, nodeTag, config, endCallback);\n }\n },\n stopAnimation: function stopAnimation(animationId) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.stopAnimation, animationId);\n },\n setAnimatedNodeValue: function setAnimatedNodeValue(nodeTag, value) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.setAnimatedNodeValue, nodeTag, value);\n },\n setAnimatedNodeOffset: function setAnimatedNodeOffset(nodeTag, offset) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.setAnimatedNodeOffset, nodeTag, offset);\n },\n flattenAnimatedNodeOffset: function flattenAnimatedNodeOffset(nodeTag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.flattenAnimatedNodeOffset, nodeTag);\n },\n extractAnimatedNodeOffset: function extractAnimatedNodeOffset(nodeTag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.extractAnimatedNodeOffset, nodeTag);\n },\n connectAnimatedNodeToView: function connectAnimatedNodeToView(nodeTag, viewTag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.connectAnimatedNodeToView, nodeTag, viewTag);\n },\n disconnectAnimatedNodeFromView: function disconnectAnimatedNodeFromView(nodeTag, viewTag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.disconnectAnimatedNodeFromView, nodeTag, viewTag);\n },\n restoreDefaultValues: function restoreDefaultValues(nodeTag) {\n invariant(nativeOps, 'Native animated module is not available');\n // Backwards compat with older native runtimes, can be removed later.\n if (nativeOps.restoreDefaultValues != null) {\n API.queueOperation(nativeOps.restoreDefaultValues, nodeTag);\n }\n },\n dropAnimatedNode: function dropAnimatedNode(tag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.dropAnimatedNode, tag);\n },\n addAnimatedEventToView: function addAnimatedEventToView(viewTag, eventName, eventMapping) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.addAnimatedEventToView, viewTag, eventName, eventMapping);\n },\n removeAnimatedEventFromView(viewTag, eventName, animatedNodeTag) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.removeAnimatedEventFromView, viewTag, eventName, animatedNodeTag);\n }\n};\nfunction setupGlobalEventEmitterListeners() {\n globalEventEmitterGetValueListener = RCTDeviceEventEmitter.addListener('onNativeAnimatedModuleGetValue', function (params) {\n var tag = params.tag;\n var callback = eventListenerGetValueCallbacks[tag];\n if (!callback) {\n return;\n }\n callback(params.value);\n delete eventListenerGetValueCallbacks[tag];\n });\n globalEventEmitterAnimationFinishedListener = RCTDeviceEventEmitter.addListener('onNativeAnimatedModuleAnimationFinished', function (params) {\n var animationId = params.animationId;\n var callback = eventListenerAnimationFinishedCallbacks[animationId];\n if (!callback) {\n return;\n }\n callback(params);\n delete eventListenerAnimationFinishedCallbacks[animationId];\n });\n}\n\n/**\n * Styles allowed by the native animated implementation.\n *\n * In general native animated implementation should support any numeric or color property that\n * doesn't need to be updated through the shadow view hierarchy (all non-layout properties).\n */\nvar SUPPORTED_COLOR_STYLES = {\n backgroundColor: true,\n borderBottomColor: true,\n borderColor: true,\n borderEndColor: true,\n borderLeftColor: true,\n borderRightColor: true,\n borderStartColor: true,\n borderTopColor: true,\n color: true,\n tintColor: true\n};\nvar SUPPORTED_STYLES = _objectSpread(_objectSpread({}, SUPPORTED_COLOR_STYLES), {}, {\n borderBottomEndRadius: true,\n borderBottomLeftRadius: true,\n borderBottomRightRadius: true,\n borderBottomStartRadius: true,\n borderRadius: true,\n borderTopEndRadius: true,\n borderTopLeftRadius: true,\n borderTopRightRadius: true,\n borderTopStartRadius: true,\n elevation: true,\n opacity: true,\n transform: true,\n zIndex: true,\n /* ios styles */\n shadowOpacity: true,\n shadowRadius: true,\n /* legacy android transform properties */\n scaleX: true,\n scaleY: true,\n translateX: true,\n translateY: true\n});\nvar SUPPORTED_TRANSFORMS = {\n translateX: true,\n translateY: true,\n scale: true,\n scaleX: true,\n scaleY: true,\n rotate: true,\n rotateX: true,\n rotateY: true,\n rotateZ: true,\n perspective: true\n};\nvar SUPPORTED_INTERPOLATION_PARAMS = {\n inputRange: true,\n outputRange: true,\n extrapolate: true,\n extrapolateRight: true,\n extrapolateLeft: true\n};\nfunction addWhitelistedStyleProp(prop) {\n SUPPORTED_STYLES[prop] = true;\n}\nfunction addWhitelistedTransformProp(prop) {\n SUPPORTED_TRANSFORMS[prop] = true;\n}\nfunction addWhitelistedInterpolationParam(param) {\n SUPPORTED_INTERPOLATION_PARAMS[param] = true;\n}\nfunction isSupportedColorStyleProp(prop) {\n return SUPPORTED_COLOR_STYLES.hasOwnProperty(prop);\n}\nfunction isSupportedStyleProp(prop) {\n return SUPPORTED_STYLES.hasOwnProperty(prop);\n}\nfunction isSupportedTransformProp(prop) {\n return SUPPORTED_TRANSFORMS.hasOwnProperty(prop);\n}\nfunction isSupportedInterpolationParam(param) {\n return SUPPORTED_INTERPOLATION_PARAMS.hasOwnProperty(param);\n}\nfunction validateTransform(configs) {\n configs.forEach(config => {\n if (!isSupportedTransformProp(config.property)) {\n throw new Error(\"Property '\" + config.property + \"' is not supported by native animated module\");\n }\n });\n}\nfunction validateStyles(styles) {\n for (var _key2 in styles) {\n if (!isSupportedStyleProp(_key2)) {\n throw new Error(\"Style property '\" + _key2 + \"' is not supported by native animated module\");\n }\n }\n}\nfunction validateInterpolation(config) {\n for (var _key3 in config) {\n if (!isSupportedInterpolationParam(_key3)) {\n throw new Error(\"Interpolation property '\" + _key3 + \"' is not supported by native animated module\");\n }\n }\n}\nfunction generateNewNodeTag() {\n return __nativeAnimatedNodeTagCount++;\n}\nfunction generateNewAnimationId() {\n return __nativeAnimationIdCount++;\n}\nfunction assertNativeAnimatedModule() {\n invariant(NativeAnimatedModule, 'Native animated module is not available');\n}\nvar _warnedMissingNativeAnimated = false;\nfunction shouldUseNativeDriver(config) {\n if (config.useNativeDriver == null) {\n console.warn('Animated: `useNativeDriver` was not specified. This is a required ' + 'option and must be explicitly set to `true` or `false`');\n }\n if (config.useNativeDriver === true && !NativeAnimatedModule) {\n if (!_warnedMissingNativeAnimated) {\n console.warn('Animated: `useNativeDriver` is not supported because the native ' + 'animated module is missing. Falling back to JS-based animation. To ' + 'resolve this, add `RCTAnimation` module to this app, or remove ' + '`useNativeDriver`. ' + 'Make sure to run `bundle exec pod install` first. Read more about autolinking: https://github.com/react-native-community/cli/blob/master/docs/autolinking.md');\n _warnedMissingNativeAnimated = true;\n }\n return false;\n }\n return config.useNativeDriver || false;\n}\nfunction transformDataType(value) {\n // Change the string type to number type so we can reuse the same logic in\n // iOS and Android platform\n if (typeof value !== 'string') {\n return value;\n }\n if (/deg$/.test(value)) {\n var degrees = parseFloat(value) || 0;\n var radians = degrees * Math.PI / 180.0;\n return radians;\n } else {\n return value;\n }\n}\nexport { API, isSupportedColorStyleProp, isSupportedStyleProp, isSupportedTransformProp, isSupportedInterpolationParam, addWhitelistedStyleProp, addWhitelistedTransformProp, addWhitelistedInterpolationParam, validateStyles, validateTransform, validateInterpolation, generateNewNodeTag, generateNewAnimationId, assertNativeAnimatedModule, shouldUseNativeDriver, transformDataType };\nexport default {\n API,\n isSupportedColorStyleProp,\n isSupportedStyleProp,\n isSupportedTransformProp,\n isSupportedInterpolationParam,\n addWhitelistedStyleProp,\n addWhitelistedTransformProp,\n addWhitelistedInterpolationParam,\n validateStyles,\n validateTransform,\n validateInterpolation,\n generateNewNodeTag,\n generateNewAnimationId,\n assertNativeAnimatedModule,\n shouldUseNativeDriver,\n transformDataType,\n // $FlowExpectedError[unsafe-getters-setters] - unsafe getter lint suppresion\n // $FlowExpectedError[missing-type-arg] - unsafe getter lint suppresion\n get nativeEventEmitter() {\n if (!nativeEventEmitter) {\n nativeEventEmitter = new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativeAnimatedModule);\n }\n return nativeEventEmitter;\n }\n};","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\n// The config has different keys depending on the type of the Node\n// TODO(T54896888): Make these types strict\nexport default TurboModuleRegistry.get('NativeAnimatedModule');","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport invariant from 'fbjs/lib/invariant';\nexport function get(name) {\n return null;\n}\nexport function getEnforcing(name) {\n var module = get(name);\n invariant(module != null, \"TurboModuleRegistry.getEnforcing(...): '\" + name + \"' could not be found. \" + 'Verify that a module by this name is registered in the native binary.');\n return module;\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\n// The config has different keys depending on the type of the Node\n// TODO(T54896888): Make these types strict\nexport default TurboModuleRegistry.get('NativeAnimatedTurboModule');","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport Platform from '../../../exports/Platform';\nimport RCTDeviceEventEmitter from './RCTDeviceEventEmitter';\nimport invariant from 'fbjs/lib/invariant';\n/**\n * `NativeEventEmitter` is intended for use by Native Modules to emit events to\n * JavaScript listeners. If a `NativeModule` is supplied to the constructor, it\n * will be notified (via `addListener` and `removeListeners`) when the listener\n * count changes to manage \"native memory\".\n *\n * Currently, all native events are fired via a global `RCTDeviceEventEmitter`.\n * This means event names must be globally unique, and it means that call sites\n * can theoretically listen to `RCTDeviceEventEmitter` (although discouraged).\n */\nexport default class NativeEventEmitter {\n constructor(nativeModule) {\n if (Platform.OS === 'ios') {\n invariant(nativeModule != null, '`new NativeEventEmitter()` requires a non-null argument.');\n this._nativeModule = nativeModule;\n }\n }\n addListener(eventType, listener, context) {\n var _this$_nativeModule;\n (_this$_nativeModule = this._nativeModule) == null ? void 0 : _this$_nativeModule.addListener(eventType);\n var subscription = RCTDeviceEventEmitter.addListener(eventType, listener, context);\n return {\n remove: () => {\n if (subscription != null) {\n var _this$_nativeModule2;\n (_this$_nativeModule2 = this._nativeModule) == null ? void 0 : _this$_nativeModule2.removeListeners(1);\n // $FlowFixMe[incompatible-use]\n subscription.remove();\n subscription = null;\n }\n }\n };\n }\n\n /**\n * @deprecated Use `remove` on the EventSubscription from `addListener`.\n */\n removeListener(eventType, listener) {\n var _this$_nativeModule3;\n (_this$_nativeModule3 = this._nativeModule) == null ? void 0 : _this$_nativeModule3.removeListeners(1);\n // NOTE: This will report a deprecation notice via `console.error`.\n // $FlowFixMe[prop-missing] - `removeListener` exists but is deprecated.\n RCTDeviceEventEmitter.removeListener(eventType, listener);\n }\n emit(eventType) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n // Generally, `RCTDeviceEventEmitter` is directly invoked. But this is\n // included for completeness.\n RCTDeviceEventEmitter.emit(eventType, ...args);\n }\n removeAllListeners(eventType) {\n var _this$_nativeModule4;\n invariant(eventType != null, '`NativeEventEmitter.removeAllListener()` requires a non-null argument.');\n (_this$_nativeModule4 = this._nativeModule) == null ? void 0 : _this$_nativeModule4.removeListeners(this.listenerCount(eventType));\n RCTDeviceEventEmitter.removeAllListeners(eventType);\n }\n listenerCount(eventType) {\n return RCTDeviceEventEmitter.listenerCount(eventType);\n }\n}","import Platform from '../../../exports/Platform';\nexport default Platform;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nvar ReactNativeFeatureFlags = {\n isLayoutAnimationEnabled: () => true,\n shouldEmitW3CPointerEvents: () => false,\n shouldPressibilityUseW3CPointerEventsForHover: () => false,\n animatedShouldDebounceQueueFlush: () => false,\n animatedShouldUseSingleOp: () => false\n};\nexport default ReactNativeFeatureFlags;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedNode from './AnimatedNode';\nimport AnimatedTransform from './AnimatedTransform';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport StyleSheet from '../../../../exports/StyleSheet';\nvar flattenStyle = StyleSheet.flatten;\nfunction createAnimatedStyle(inputStyle) {\n var style = flattenStyle(inputStyle);\n var animatedStyles = {};\n for (var key in style) {\n var value = style[key];\n if (key === 'transform' && Array.isArray(value)) {\n animatedStyles[key] = new AnimatedTransform(value);\n } else if (value instanceof AnimatedNode) {\n animatedStyles[key] = value;\n } else if (value && !Array.isArray(value) && typeof value === 'object') {\n animatedStyles[key] = createAnimatedStyle(value);\n }\n }\n return animatedStyles;\n}\nclass AnimatedStyle extends AnimatedWithChildren {\n constructor(style) {\n super();\n this._inputStyle = style;\n this._style = createAnimatedStyle(style);\n }\n\n // Recursively get values for nested styles (like iOS's shadowOffset)\n _walkStyleAndGetValues(style) {\n var updatedStyle = {};\n for (var key in style) {\n var value = style[key];\n if (value instanceof AnimatedNode) {\n if (!value.__isNative) {\n // We cannot use value of natively driven nodes this way as the value we have access from\n // JS may not be up to date.\n updatedStyle[key] = value.__getValue();\n }\n } else if (value && !Array.isArray(value) && typeof value === 'object') {\n // Support animating nested values (for example: shadowOffset.height)\n updatedStyle[key] = this._walkStyleAndGetValues(value);\n } else {\n updatedStyle[key] = value;\n }\n }\n return updatedStyle;\n }\n __getValue() {\n return [this._inputStyle, this._walkStyleAndGetValues(this._style)];\n }\n\n // Recursively get animated values for nested styles (like iOS's shadowOffset)\n _walkStyleAndGetAnimatedValues(style) {\n var updatedStyle = {};\n for (var key in style) {\n var value = style[key];\n if (value instanceof AnimatedNode) {\n updatedStyle[key] = value.__getAnimatedValue();\n } else if (value && !Array.isArray(value) && typeof value === 'object') {\n // Support animating nested values (for example: shadowOffset.height)\n updatedStyle[key] = this._walkStyleAndGetAnimatedValues(value);\n }\n }\n return updatedStyle;\n }\n __getAnimatedValue() {\n return this._walkStyleAndGetAnimatedValues(this._style);\n }\n __attach() {\n for (var key in this._style) {\n var value = this._style[key];\n if (value instanceof AnimatedNode) {\n value.__addChild(this);\n }\n }\n }\n __detach() {\n for (var key in this._style) {\n var value = this._style[key];\n if (value instanceof AnimatedNode) {\n value.__removeChild(this);\n }\n }\n super.__detach();\n }\n __makeNative() {\n for (var key in this._style) {\n var value = this._style[key];\n if (value instanceof AnimatedNode) {\n value.__makeNative();\n }\n }\n super.__makeNative();\n }\n __getNativeConfig() {\n var styleConfig = {};\n for (var styleKey in this._style) {\n if (this._style[styleKey] instanceof AnimatedNode) {\n var style = this._style[styleKey];\n style.__makeNative();\n styleConfig[styleKey] = style.__getNativeTag();\n }\n }\n NativeAnimatedHelper.validateStyles(styleConfig);\n return {\n type: 'style',\n style: styleConfig\n };\n }\n}\nexport default AnimatedStyle;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedNode from './AnimatedNode';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nclass AnimatedTransform extends AnimatedWithChildren {\n constructor(transforms) {\n super();\n this._transforms = transforms;\n }\n __makeNative() {\n this._transforms.forEach(transform => {\n for (var key in transform) {\n var value = transform[key];\n if (value instanceof AnimatedNode) {\n value.__makeNative();\n }\n }\n });\n super.__makeNative();\n }\n __getValue() {\n return this._transforms.map(transform => {\n var result = {};\n for (var key in transform) {\n var value = transform[key];\n if (value instanceof AnimatedNode) {\n result[key] = value.__getValue();\n } else {\n result[key] = value;\n }\n }\n return result;\n });\n }\n __getAnimatedValue() {\n return this._transforms.map(transform => {\n var result = {};\n for (var key in transform) {\n var value = transform[key];\n if (value instanceof AnimatedNode) {\n result[key] = value.__getAnimatedValue();\n } else {\n // All transform components needed to recompose matrix\n result[key] = value;\n }\n }\n return result;\n });\n }\n __attach() {\n this._transforms.forEach(transform => {\n for (var key in transform) {\n var value = transform[key];\n if (value instanceof AnimatedNode) {\n value.__addChild(this);\n }\n }\n });\n }\n __detach() {\n this._transforms.forEach(transform => {\n for (var key in transform) {\n var value = transform[key];\n if (value instanceof AnimatedNode) {\n value.__removeChild(this);\n }\n }\n });\n super.__detach();\n }\n __getNativeConfig() {\n var transConfigs = [];\n this._transforms.forEach(transform => {\n for (var key in transform) {\n var value = transform[key];\n if (value instanceof AnimatedNode) {\n transConfigs.push({\n type: 'animated',\n property: key,\n nodeTag: value.__getNativeTag()\n });\n } else {\n transConfigs.push({\n type: 'static',\n property: key,\n value: NativeAnimatedHelper.transformDataType(value)\n });\n }\n }\n });\n NativeAnimatedHelper.validateTransform(transConfigs);\n return {\n type: 'transform',\n transforms: transConfigs\n };\n }\n}\nexport default AnimatedTransform;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport { useCallback, useRef } from 'react';\n/**\n * Constructs a callback ref that provides similar semantics as `useEffect`. The\n * supplied `effect` callback will be called with non-null component instances.\n * The `effect` callback can also optionally return a cleanup function.\n *\n * When a component is updated or unmounted, the cleanup function is called. The\n * `effect` callback will then be called again, if applicable.\n *\n * When a new `effect` callback is supplied, the previously returned cleanup\n * function will be called before the new `effect` callback is called with the\n * same instance.\n *\n * WARNING: The `effect` callback should be stable (e.g. using `useCallback`).\n */\nexport default function useRefEffect(effect) {\n var cleanupRef = useRef(undefined);\n return useCallback(instance => {\n if (cleanupRef.current) {\n cleanupRef.current();\n cleanupRef.current = undefined;\n }\n if (instance != null) {\n cleanupRef.current = effect(instance);\n }\n }, [effect]);\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport { useCallback } from 'react';\n/**\n * Constructs a new ref that forwards new values to each of the given refs. The\n * given refs will always be invoked in the order that they are supplied.\n *\n * WARNING: A known problem of merging refs using this approach is that if any\n * of the given refs change, the returned callback ref will also be changed. If\n * the returned callback ref is supplied as a `ref` to a React element, this may\n * lead to problems with the given refs being invoked more times than desired.\n */\nexport default function useMergeRefs() {\n for (var _len = arguments.length, refs = new Array(_len), _key = 0; _key < _len; _key++) {\n refs[_key] = arguments[_key];\n }\n return useCallback(current => {\n for (var _i = 0, _refs = refs; _i < _refs.length; _i++) {\n var ref = _refs[_i];\n if (ref != null) {\n if (typeof ref === 'function') {\n ref(current);\n } else {\n ref.current = current;\n }\n }\n }\n }, [...refs] // eslint-disable-line react-hooks/exhaustive-deps\n );\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as React from 'react';\nimport Image from '../../../../exports/Image';\nimport createAnimatedComponent from '../createAnimatedComponent';\nexport default createAnimatedComponent(Image);","import _extends from \"@babel/runtime/helpers/extends\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as React from 'react';\nimport ScrollView from '../../../../exports/ScrollView';\nimport createAnimatedComponent from '../createAnimatedComponent';\n/**\n * @see https://github.com/facebook/react-native/commit/b8c8562\n */\nvar ScrollViewWithEventThrottle = /*#__PURE__*/React.forwardRef((props, ref) => /*#__PURE__*/React.createElement(ScrollView, _extends({\n scrollEventThrottle: 0.0001\n}, props, {\n ref: ref\n})));\nexport default createAnimatedComponent(ScrollViewWithEventThrottle);","import _extends from \"@babel/runtime/helpers/extends\";\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as React from 'react';\nimport SectionList from '../../../../exports/SectionList';\nimport createAnimatedComponent from '../createAnimatedComponent';\n/**\n * @see https://github.com/facebook/react-native/commit/b8c8562\n */\nvar SectionListWithEventThrottle = /*#__PURE__*/React.forwardRef((props, ref) => /*#__PURE__*/React.createElement(SectionList, _extends({\n scrollEventThrottle: 0.0001\n}, props, {\n ref: ref\n})));\nexport default createAnimatedComponent(SectionListWithEventThrottle);","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport SectionList from '../../vendor/react-native/SectionList';\nexport default SectionList;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"stickySectionHeadersEnabled\"];\nimport Platform from '../../../exports/Platform';\nimport * as React from 'react';\nimport VirtualizedSectionList from '../VirtualizedSectionList';\n/**\n * A performant interface for rendering sectioned lists, supporting the most handy features:\n *\n * - Fully cross-platform.\n * - Configurable viewability callbacks.\n * - List header support.\n * - List footer support.\n * - Item separator support.\n * - Section header support.\n * - Section separator support.\n * - Heterogeneous data and item rendering support.\n * - Pull to Refresh.\n * - Scroll loading.\n *\n * If you don't need section support and want a simpler interface, use\n * [``](https://reactnative.dev/docs/flatlist).\n *\n * Simple Examples:\n *\n * }\n * renderSectionHeader={({section}) =>
}\n * sections={[ // homogeneous rendering between sections\n * {data: [...], title: ...},\n * {data: [...], title: ...},\n * {data: [...], title: ...},\n * ]}\n * />\n *\n * \n *\n * This is a convenience wrapper around [``](docs/virtualizedlist),\n * and thus inherits its props (as well as those of `ScrollView`) that aren't explicitly listed\n * here, along with the following caveats:\n *\n * - Internal state is not preserved when content scrolls out of the render window. Make sure all\n * your data is captured in the item data or external stores like Flux, Redux, or Relay.\n * - This is a `PureComponent` which means that it will not re-render if `props` remain shallow-\n * equal. Make sure that everything your `renderItem` function depends on is passed as a prop\n * (e.g. `extraData`) that is not `===` after updates, otherwise your UI may not update on\n * changes. This includes the `data` prop and parent component state.\n * - In order to constrain memory and enable smooth scrolling, content is rendered asynchronously\n * offscreen. This means it's possible to scroll faster than the fill rate and momentarily see\n * blank content. This is a tradeoff that can be adjusted to suit the needs of each application,\n * and we are working on improving it behind the scenes.\n * - By default, the list looks for a `key` prop on each item and uses that for the React key.\n * Alternatively, you can provide a custom `keyExtractor` prop.\n *\n */\nexport default class SectionList extends React.PureComponent {\n constructor() {\n super(...arguments);\n this._captureRef = ref => {\n this._wrapperListRef = ref;\n };\n }\n /**\n * Scrolls to the item at the specified `sectionIndex` and `itemIndex` (within the section)\n * positioned in the viewable area such that `viewPosition` 0 places it at the top (and may be\n * covered by a sticky header), 1 at the bottom, and 0.5 centered in the middle. `viewOffset` is a\n * fixed number of pixels to offset the final target position, e.g. to compensate for sticky\n * headers.\n *\n * Note: cannot scroll to locations outside the render window without specifying the\n * `getItemLayout` prop.\n */\n scrollToLocation(params) {\n if (this._wrapperListRef != null) {\n this._wrapperListRef.scrollToLocation(params);\n }\n }\n\n /**\n * Tells the list an interaction has occurred, which should trigger viewability calculations, e.g.\n * if `waitForInteractions` is true and the user has not scrolled. This is typically called by\n * taps on items or by navigation actions.\n */\n recordInteraction() {\n var listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n listRef && listRef.recordInteraction();\n }\n\n /**\n * Displays the scroll indicators momentarily.\n *\n * @platform ios\n */\n flashScrollIndicators() {\n var listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n listRef && listRef.flashScrollIndicators();\n }\n\n /**\n * Provides a handle to the underlying scroll responder.\n */\n getScrollResponder() {\n var listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n if (listRef) {\n return listRef.getScrollResponder();\n }\n }\n getScrollableNode() {\n var listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n if (listRef) {\n return listRef.getScrollableNode();\n }\n }\n render() {\n var _this$props = this.props,\n _stickySectionHeadersEnabled = _this$props.stickySectionHeadersEnabled,\n restProps = _objectWithoutPropertiesLoose(_this$props, _excluded);\n var stickySectionHeadersEnabled = _stickySectionHeadersEnabled !== null && _stickySectionHeadersEnabled !== void 0 ? _stickySectionHeadersEnabled : Platform.OS === 'ios';\n return /*#__PURE__*/React.createElement(VirtualizedSectionList, _extends({}, restProps, {\n stickySectionHeadersEnabled: stickySectionHeadersEnabled,\n ref: this._captureRef,\n getItemCount: items => items.length,\n getItem: (items, index) => items[index]\n }));\n }\n}","import _extends from \"@babel/runtime/helpers/extends\";\nimport _createForOfIteratorHelperLoose from \"@babel/runtime/helpers/createForOfIteratorHelperLoose\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nvar _excluded = [\"ItemSeparatorComponent\", \"SectionSeparatorComponent\", \"renderItem\", \"renderSectionFooter\", \"renderSectionHeader\", \"sections\", \"stickySectionHeadersEnabled\"];\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport View from '../../../exports/View';\nimport VirtualizedList from '../VirtualizedList';\nimport { keyExtractor as defaultKeyExtractor } from '../VirtualizeUtils';\nimport invariant from 'fbjs/lib/invariant';\nimport * as React from 'react';\n/**\n * Right now this just flattens everything into one list and uses VirtualizedList under the\n * hood. The only operation that might not scale well is concatting the data arrays of all the\n * sections when new props are received, which should be plenty fast for up to ~10,000 items.\n */\nclass VirtualizedSectionList extends React.PureComponent {\n constructor() {\n super(...arguments);\n this._keyExtractor = (item, index) => {\n var info = this._subExtractor(index);\n return info && info.key || String(index);\n };\n this._convertViewable = viewable => {\n var _info$index;\n invariant(viewable.index != null, 'Received a broken ViewToken');\n var info = this._subExtractor(viewable.index);\n if (!info) {\n return null;\n }\n var keyExtractorWithNullableIndex = info.section.keyExtractor;\n var keyExtractorWithNonNullableIndex = this.props.keyExtractor || defaultKeyExtractor;\n var key = keyExtractorWithNullableIndex != null ? keyExtractorWithNullableIndex(viewable.item, info.index) : keyExtractorWithNonNullableIndex(viewable.item, (_info$index = info.index) !== null && _info$index !== void 0 ? _info$index : 0);\n return _objectSpread(_objectSpread({}, viewable), {}, {\n index: info.index,\n key,\n section: info.section\n });\n };\n this._onViewableItemsChanged = _ref => {\n var viewableItems = _ref.viewableItems,\n changed = _ref.changed;\n var onViewableItemsChanged = this.props.onViewableItemsChanged;\n if (onViewableItemsChanged != null) {\n onViewableItemsChanged({\n viewableItems: viewableItems.map(this._convertViewable, this).filter(Boolean),\n changed: changed.map(this._convertViewable, this).filter(Boolean)\n });\n }\n };\n this._renderItem = listItemCount =>\n // eslint-disable-next-line react/no-unstable-nested-components\n _ref2 => {\n var item = _ref2.item,\n index = _ref2.index;\n var info = this._subExtractor(index);\n if (!info) {\n return null;\n }\n var infoIndex = info.index;\n if (infoIndex == null) {\n var section = info.section;\n if (info.header === true) {\n var renderSectionHeader = this.props.renderSectionHeader;\n return renderSectionHeader ? renderSectionHeader({\n section\n }) : null;\n } else {\n var renderSectionFooter = this.props.renderSectionFooter;\n return renderSectionFooter ? renderSectionFooter({\n section\n }) : null;\n }\n } else {\n var renderItem = info.section.renderItem || this.props.renderItem;\n var SeparatorComponent = this._getSeparatorComponent(index, info, listItemCount);\n invariant(renderItem, 'no renderItem!');\n return /*#__PURE__*/React.createElement(ItemWithSeparator, {\n SeparatorComponent: SeparatorComponent,\n LeadingSeparatorComponent: infoIndex === 0 ? this.props.SectionSeparatorComponent : undefined,\n cellKey: info.key,\n index: infoIndex,\n item: item,\n leadingItem: info.leadingItem,\n leadingSection: info.leadingSection,\n prevCellKey: (this._subExtractor(index - 1) || {}).key\n // Callback to provide updateHighlight for this item\n ,\n setSelfHighlightCallback: this._setUpdateHighlightFor,\n setSelfUpdatePropsCallback: this._setUpdatePropsFor\n // Provide child ability to set highlight/updateProps for previous item using prevCellKey\n ,\n updateHighlightFor: this._updateHighlightFor,\n updatePropsFor: this._updatePropsFor,\n renderItem: renderItem,\n section: info.section,\n trailingItem: info.trailingItem,\n trailingSection: info.trailingSection,\n inverted: !!this.props.inverted\n });\n }\n };\n this._updatePropsFor = (cellKey, value) => {\n var updateProps = this._updatePropsMap[cellKey];\n if (updateProps != null) {\n updateProps(value);\n }\n };\n this._updateHighlightFor = (cellKey, value) => {\n var updateHighlight = this._updateHighlightMap[cellKey];\n if (updateHighlight != null) {\n updateHighlight(value);\n }\n };\n this._setUpdateHighlightFor = (cellKey, updateHighlightFn) => {\n if (updateHighlightFn != null) {\n this._updateHighlightMap[cellKey] = updateHighlightFn;\n } else {\n // $FlowFixMe[prop-missing]\n delete this._updateHighlightFor[cellKey];\n }\n };\n this._setUpdatePropsFor = (cellKey, updatePropsFn) => {\n if (updatePropsFn != null) {\n this._updatePropsMap[cellKey] = updatePropsFn;\n } else {\n delete this._updatePropsMap[cellKey];\n }\n };\n this._updateHighlightMap = {};\n this._updatePropsMap = {};\n this._captureRef = ref => {\n this._listRef = ref;\n };\n }\n scrollToLocation(params) {\n var index = params.itemIndex;\n for (var i = 0; i < params.sectionIndex; i++) {\n index += this.props.getItemCount(this.props.sections[i].data) + 2;\n }\n var viewOffset = params.viewOffset || 0;\n if (this._listRef == null) {\n return;\n }\n if (params.itemIndex > 0 && this.props.stickySectionHeadersEnabled) {\n var frame = this._listRef.__getFrameMetricsApprox(index - params.itemIndex, this._listRef.props);\n viewOffset += frame.length;\n }\n var toIndexParams = _objectSpread(_objectSpread({}, params), {}, {\n viewOffset,\n index\n });\n // $FlowFixMe[incompatible-use]\n this._listRef.scrollToIndex(toIndexParams);\n }\n getListRef() {\n return this._listRef;\n }\n render() {\n var _this$props = this.props,\n ItemSeparatorComponent = _this$props.ItemSeparatorComponent,\n SectionSeparatorComponent = _this$props.SectionSeparatorComponent,\n _renderItem = _this$props.renderItem,\n renderSectionFooter = _this$props.renderSectionFooter,\n renderSectionHeader = _this$props.renderSectionHeader,\n _sections = _this$props.sections,\n stickySectionHeadersEnabled = _this$props.stickySectionHeadersEnabled,\n passThroughProps = _objectWithoutPropertiesLoose(_this$props, _excluded);\n var listHeaderOffset = this.props.ListHeaderComponent ? 1 : 0;\n var stickyHeaderIndices = this.props.stickySectionHeadersEnabled ? [] : undefined;\n var itemCount = 0;\n for (var _iterator = _createForOfIteratorHelperLoose(this.props.sections), _step; !(_step = _iterator()).done;) {\n var section = _step.value;\n // Track the section header indices\n if (stickyHeaderIndices != null) {\n stickyHeaderIndices.push(itemCount + listHeaderOffset);\n }\n\n // Add two for the section header and footer.\n itemCount += 2;\n itemCount += this.props.getItemCount(section.data);\n }\n var renderItem = this._renderItem(itemCount);\n return /*#__PURE__*/React.createElement(VirtualizedList, _extends({}, passThroughProps, {\n keyExtractor: this._keyExtractor,\n stickyHeaderIndices: stickyHeaderIndices,\n renderItem: renderItem,\n data: this.props.sections,\n getItem: (sections, index) => this._getItem(this.props, sections, index),\n getItemCount: () => itemCount,\n onViewableItemsChanged: this.props.onViewableItemsChanged ? this._onViewableItemsChanged : undefined,\n ref: this._captureRef\n }));\n }\n _getItem(props, sections, index) {\n if (!sections) {\n return null;\n }\n var itemIdx = index - 1;\n for (var i = 0; i < sections.length; i++) {\n var section = sections[i];\n var sectionData = section.data;\n var itemCount = props.getItemCount(sectionData);\n if (itemIdx === -1 || itemIdx === itemCount) {\n // We intend for there to be overflow by one on both ends of the list.\n // This will be for headers and footers. When returning a header or footer\n // item the section itself is the item.\n return section;\n } else if (itemIdx < itemCount) {\n // If we are in the bounds of the list's data then return the item.\n return props.getItem(sectionData, itemIdx);\n } else {\n itemIdx -= itemCount + 2; // Add two for the header and footer\n }\n }\n\n return null;\n }\n\n // $FlowFixMe[missing-local-annot]\n\n _subExtractor(index) {\n var itemIndex = index;\n var _this$props2 = this.props,\n getItem = _this$props2.getItem,\n getItemCount = _this$props2.getItemCount,\n keyExtractor = _this$props2.keyExtractor,\n sections = _this$props2.sections;\n for (var i = 0; i < sections.length; i++) {\n var section = sections[i];\n var sectionData = section.data;\n var key = section.key || String(i);\n itemIndex -= 1; // The section adds an item for the header\n if (itemIndex >= getItemCount(sectionData) + 1) {\n itemIndex -= getItemCount(sectionData) + 1; // The section adds an item for the footer.\n } else if (itemIndex === -1) {\n return {\n section,\n key: key + ':header',\n index: null,\n header: true,\n trailingSection: sections[i + 1]\n };\n } else if (itemIndex === getItemCount(sectionData)) {\n return {\n section,\n key: key + ':footer',\n index: null,\n header: false,\n trailingSection: sections[i + 1]\n };\n } else {\n var extractor = section.keyExtractor || keyExtractor || defaultKeyExtractor;\n return {\n section,\n key: key + ':' + extractor(getItem(sectionData, itemIndex), itemIndex),\n index: itemIndex,\n leadingItem: getItem(sectionData, itemIndex - 1),\n leadingSection: sections[i - 1],\n trailingItem: getItem(sectionData, itemIndex + 1),\n trailingSection: sections[i + 1]\n };\n }\n }\n }\n _getSeparatorComponent(index, info, listItemCount) {\n info = info || this._subExtractor(index);\n if (!info) {\n return null;\n }\n var ItemSeparatorComponent = info.section.ItemSeparatorComponent || this.props.ItemSeparatorComponent;\n var SectionSeparatorComponent = this.props.SectionSeparatorComponent;\n var isLastItemInList = index === listItemCount - 1;\n var isLastItemInSection = info.index === this.props.getItemCount(info.section.data) - 1;\n if (SectionSeparatorComponent && isLastItemInSection) {\n return SectionSeparatorComponent;\n }\n if (ItemSeparatorComponent && !isLastItemInSection && !isLastItemInList) {\n return ItemSeparatorComponent;\n }\n return null;\n }\n}\nfunction ItemWithSeparator(props) {\n var LeadingSeparatorComponent = props.LeadingSeparatorComponent,\n SeparatorComponent = props.SeparatorComponent,\n cellKey = props.cellKey,\n prevCellKey = props.prevCellKey,\n setSelfHighlightCallback = props.setSelfHighlightCallback,\n updateHighlightFor = props.updateHighlightFor,\n setSelfUpdatePropsCallback = props.setSelfUpdatePropsCallback,\n updatePropsFor = props.updatePropsFor,\n item = props.item,\n index = props.index,\n section = props.section,\n inverted = props.inverted;\n var _React$useState = React.useState(false),\n leadingSeparatorHiglighted = _React$useState[0],\n setLeadingSeparatorHighlighted = _React$useState[1];\n var _React$useState2 = React.useState(false),\n separatorHighlighted = _React$useState2[0],\n setSeparatorHighlighted = _React$useState2[1];\n var _React$useState3 = React.useState({\n leadingItem: props.leadingItem,\n leadingSection: props.leadingSection,\n section: props.section,\n trailingItem: props.item,\n trailingSection: props.trailingSection\n }),\n leadingSeparatorProps = _React$useState3[0],\n setLeadingSeparatorProps = _React$useState3[1];\n var _React$useState4 = React.useState({\n leadingItem: props.item,\n leadingSection: props.leadingSection,\n section: props.section,\n trailingItem: props.trailingItem,\n trailingSection: props.trailingSection\n }),\n separatorProps = _React$useState4[0],\n setSeparatorProps = _React$useState4[1];\n React.useEffect(() => {\n setSelfHighlightCallback(cellKey, setSeparatorHighlighted);\n // $FlowFixMe[incompatible-call]\n setSelfUpdatePropsCallback(cellKey, setSeparatorProps);\n return () => {\n setSelfUpdatePropsCallback(cellKey, null);\n setSelfHighlightCallback(cellKey, null);\n };\n }, [cellKey, setSelfHighlightCallback, setSeparatorProps, setSelfUpdatePropsCallback]);\n var separators = {\n highlight: () => {\n setLeadingSeparatorHighlighted(true);\n setSeparatorHighlighted(true);\n if (prevCellKey != null) {\n updateHighlightFor(prevCellKey, true);\n }\n },\n unhighlight: () => {\n setLeadingSeparatorHighlighted(false);\n setSeparatorHighlighted(false);\n if (prevCellKey != null) {\n updateHighlightFor(prevCellKey, false);\n }\n },\n updateProps: (select, newProps) => {\n if (select === 'leading') {\n if (LeadingSeparatorComponent != null) {\n setLeadingSeparatorProps(_objectSpread(_objectSpread({}, leadingSeparatorProps), newProps));\n } else if (prevCellKey != null) {\n // update the previous item's separator\n updatePropsFor(prevCellKey, _objectSpread(_objectSpread({}, leadingSeparatorProps), newProps));\n }\n } else if (select === 'trailing' && SeparatorComponent != null) {\n setSeparatorProps(_objectSpread(_objectSpread({}, separatorProps), newProps));\n }\n }\n };\n var element = props.renderItem({\n item,\n index,\n section,\n separators\n });\n var leadingSeparator = LeadingSeparatorComponent != null && /*#__PURE__*/React.createElement(LeadingSeparatorComponent, _extends({\n highlighted: leadingSeparatorHiglighted\n }, leadingSeparatorProps));\n var separator = SeparatorComponent != null && /*#__PURE__*/React.createElement(SeparatorComponent, _extends({\n highlighted: separatorHighlighted\n }, separatorProps));\n return leadingSeparator || separator ? /*#__PURE__*/React.createElement(View, null, inverted === false ? leadingSeparator : separator, element, inverted === false ? separator : leadingSeparator) : element;\n}\n\n/* $FlowFixMe[class-object-subtyping] added when improving typing for this\n * parameters */\n// $FlowFixMe[method-unbinding]\nexport default VirtualizedSectionList;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as React from 'react';\nimport Text from '../../../../exports/Text';\nimport createAnimatedComponent from '../createAnimatedComponent';\nexport default createAnimatedComponent(Text);","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\nimport * as React from 'react';\nimport View from '../../../../exports/View';\nimport createAnimatedComponent from '../createAnimatedComponent';\nexport default createAnimatedComponent(View);","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport { AnimatedEvent, attachNativeEvent } from './AnimatedEvent';\nimport AnimatedImplementation from './AnimatedImplementation';\nimport AnimatedInterpolation from './nodes/AnimatedInterpolation';\nimport AnimatedNode from './nodes/AnimatedNode';\nimport AnimatedValue from './nodes/AnimatedValue';\nimport AnimatedValueXY from './nodes/AnimatedValueXY';\nimport createAnimatedComponent from './createAnimatedComponent';\nimport AnimatedColor from './nodes/AnimatedColor';\n\n/**\n * Animations are a source of flakiness in snapshot testing. This mock replaces\n * animation functions from AnimatedImplementation with empty animations for\n * predictability in tests. When possible the animation will run immediately\n * to the final state.\n */\n\n// Prevent any callback invocation from recursively triggering another\n// callback, which may trigger another animation\nvar inAnimationCallback = false;\nfunction mockAnimationStart(start) {\n return callback => {\n var guardedCallback = callback == null ? callback : function () {\n if (inAnimationCallback) {\n console.warn('Ignoring recursive animation callback when running mock animations');\n return;\n }\n inAnimationCallback = true;\n try {\n callback(...arguments);\n } finally {\n inAnimationCallback = false;\n }\n };\n start(guardedCallback);\n };\n}\nvar emptyAnimation = {\n start: () => {},\n stop: () => {},\n reset: () => {},\n _startNativeLoop: () => {},\n _isUsingNativeDriver: () => {\n return false;\n }\n};\nvar mockCompositeAnimation = animations => _objectSpread(_objectSpread({}, emptyAnimation), {}, {\n start: mockAnimationStart(callback => {\n animations.forEach(animation => animation.start());\n callback == null ? void 0 : callback({\n finished: true\n });\n })\n});\nvar spring = function spring(value, config) {\n var anyValue = value;\n return _objectSpread(_objectSpread({}, emptyAnimation), {}, {\n start: mockAnimationStart(callback => {\n anyValue.setValue(config.toValue);\n callback == null ? void 0 : callback({\n finished: true\n });\n })\n });\n};\nvar timing = function timing(value, config) {\n var anyValue = value;\n return _objectSpread(_objectSpread({}, emptyAnimation), {}, {\n start: mockAnimationStart(callback => {\n anyValue.setValue(config.toValue);\n callback == null ? void 0 : callback({\n finished: true\n });\n })\n });\n};\nvar decay = function decay(value, config) {\n return emptyAnimation;\n};\nvar sequence = function sequence(animations) {\n return mockCompositeAnimation(animations);\n};\nvar parallel = function parallel(animations, config) {\n return mockCompositeAnimation(animations);\n};\nvar delay = function delay(time) {\n return emptyAnimation;\n};\nvar stagger = function stagger(time, animations) {\n return mockCompositeAnimation(animations);\n};\nvar loop = function loop(animation, // $FlowFixMe[prop-missing]\n_temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n _ref$iterations = _ref.iterations,\n iterations = _ref$iterations === void 0 ? -1 : _ref$iterations;\n return emptyAnimation;\n};\nexport default {\n Value: AnimatedValue,\n ValueXY: AnimatedValueXY,\n Color: AnimatedColor,\n Interpolation: AnimatedInterpolation,\n Node: AnimatedNode,\n decay,\n timing,\n spring,\n add: AnimatedImplementation.add,\n subtract: AnimatedImplementation.subtract,\n divide: AnimatedImplementation.divide,\n multiply: AnimatedImplementation.multiply,\n modulo: AnimatedImplementation.modulo,\n diffClamp: AnimatedImplementation.diffClamp,\n delay,\n sequence,\n parallel,\n stagger,\n loop,\n event: AnimatedImplementation.event,\n createAnimatedComponent,\n attachNativeEvent,\n forkEvent: AnimatedImplementation.forkEvent,\n unforkEvent: AnimatedImplementation.unforkEvent,\n Event: AnimatedEvent\n};","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport { AnimatedEvent, attachNativeEvent } from './AnimatedEvent';\nimport AnimatedAddition from './nodes/AnimatedAddition';\nimport AnimatedDiffClamp from './nodes/AnimatedDiffClamp';\nimport AnimatedDivision from './nodes/AnimatedDivision';\nimport AnimatedInterpolation from './nodes/AnimatedInterpolation';\nimport AnimatedModulo from './nodes/AnimatedModulo';\nimport AnimatedMultiplication from './nodes/AnimatedMultiplication';\nimport AnimatedNode from './nodes/AnimatedNode';\nimport AnimatedProps from './nodes/AnimatedProps';\nimport AnimatedSubtraction from './nodes/AnimatedSubtraction';\nimport AnimatedTracking from './nodes/AnimatedTracking';\nimport AnimatedValue from './nodes/AnimatedValue';\nimport AnimatedValueXY from './nodes/AnimatedValueXY';\nimport DecayAnimation from './animations/DecayAnimation';\nimport SpringAnimation from './animations/SpringAnimation';\nimport TimingAnimation from './animations/TimingAnimation';\nimport createAnimatedComponent from './createAnimatedComponent';\nimport AnimatedColor from './nodes/AnimatedColor';\nvar add = function add(a, b) {\n return new AnimatedAddition(a, b);\n};\nvar subtract = function subtract(a, b) {\n return new AnimatedSubtraction(a, b);\n};\nvar divide = function divide(a, b) {\n return new AnimatedDivision(a, b);\n};\nvar multiply = function multiply(a, b) {\n return new AnimatedMultiplication(a, b);\n};\nvar modulo = function modulo(a, modulus) {\n return new AnimatedModulo(a, modulus);\n};\nvar diffClamp = function diffClamp(a, min, max) {\n return new AnimatedDiffClamp(a, min, max);\n};\nvar _combineCallbacks = function _combineCallbacks(callback, config) {\n if (callback && config.onComplete) {\n return function () {\n config.onComplete && config.onComplete(...arguments);\n callback && callback(...arguments);\n };\n } else {\n return callback || config.onComplete;\n }\n};\nvar maybeVectorAnim = function maybeVectorAnim(value, config, anim) {\n if (value instanceof AnimatedValueXY) {\n var configX = _objectSpread({}, config);\n var configY = _objectSpread({}, config);\n for (var key in config) {\n var _config$key = config[key],\n x = _config$key.x,\n y = _config$key.y;\n if (x !== undefined && y !== undefined) {\n configX[key] = x;\n configY[key] = y;\n }\n }\n var aX = anim(value.x, configX);\n var aY = anim(value.y, configY);\n // We use `stopTogether: false` here because otherwise tracking will break\n // because the second animation will get stopped before it can update.\n return parallel([aX, aY], {\n stopTogether: false\n });\n } else if (value instanceof AnimatedColor) {\n var configR = _objectSpread({}, config);\n var configG = _objectSpread({}, config);\n var configB = _objectSpread({}, config);\n var configA = _objectSpread({}, config);\n for (var _key in config) {\n var _config$_key = config[_key],\n r = _config$_key.r,\n g = _config$_key.g,\n b = _config$_key.b,\n a = _config$_key.a;\n if (r !== undefined && g !== undefined && b !== undefined && a !== undefined) {\n configR[_key] = r;\n configG[_key] = g;\n configB[_key] = b;\n configA[_key] = a;\n }\n }\n var aR = anim(value.r, configR);\n var aG = anim(value.g, configG);\n var aB = anim(value.b, configB);\n var aA = anim(value.a, configA);\n // We use `stopTogether: false` here because otherwise tracking will break\n // because the second animation will get stopped before it can update.\n return parallel([aR, aG, aB, aA], {\n stopTogether: false\n });\n }\n return null;\n};\nvar spring = function spring(value, config) {\n var _start = function start(animatedValue, configuration, callback) {\n callback = _combineCallbacks(callback, configuration);\n var singleValue = animatedValue;\n var singleConfig = configuration;\n singleValue.stopTracking();\n if (configuration.toValue instanceof AnimatedNode) {\n singleValue.track(new AnimatedTracking(singleValue, configuration.toValue, SpringAnimation, singleConfig, callback));\n } else {\n singleValue.animate(new SpringAnimation(singleConfig), callback);\n }\n };\n return maybeVectorAnim(value, config, spring) || {\n start: function start(callback) {\n _start(value, config, callback);\n },\n stop: function stop() {\n value.stopAnimation();\n },\n reset: function reset() {\n value.resetAnimation();\n },\n _startNativeLoop: function _startNativeLoop(iterations) {\n var singleConfig = _objectSpread(_objectSpread({}, config), {}, {\n iterations\n });\n _start(value, singleConfig);\n },\n _isUsingNativeDriver: function _isUsingNativeDriver() {\n return config.useNativeDriver || false;\n }\n };\n};\nvar timing = function timing(value, config) {\n var _start2 = function start(animatedValue, configuration, callback) {\n callback = _combineCallbacks(callback, configuration);\n var singleValue = animatedValue;\n var singleConfig = configuration;\n singleValue.stopTracking();\n if (configuration.toValue instanceof AnimatedNode) {\n singleValue.track(new AnimatedTracking(singleValue, configuration.toValue, TimingAnimation, singleConfig, callback));\n } else {\n singleValue.animate(new TimingAnimation(singleConfig), callback);\n }\n };\n return maybeVectorAnim(value, config, timing) || {\n start: function start(callback) {\n _start2(value, config, callback);\n },\n stop: function stop() {\n value.stopAnimation();\n },\n reset: function reset() {\n value.resetAnimation();\n },\n _startNativeLoop: function _startNativeLoop(iterations) {\n var singleConfig = _objectSpread(_objectSpread({}, config), {}, {\n iterations\n });\n _start2(value, singleConfig);\n },\n _isUsingNativeDriver: function _isUsingNativeDriver() {\n return config.useNativeDriver || false;\n }\n };\n};\nvar decay = function decay(value, config) {\n var _start3 = function start(animatedValue, configuration, callback) {\n callback = _combineCallbacks(callback, configuration);\n var singleValue = animatedValue;\n var singleConfig = configuration;\n singleValue.stopTracking();\n singleValue.animate(new DecayAnimation(singleConfig), callback);\n };\n return maybeVectorAnim(value, config, decay) || {\n start: function start(callback) {\n _start3(value, config, callback);\n },\n stop: function stop() {\n value.stopAnimation();\n },\n reset: function reset() {\n value.resetAnimation();\n },\n _startNativeLoop: function _startNativeLoop(iterations) {\n var singleConfig = _objectSpread(_objectSpread({}, config), {}, {\n iterations\n });\n _start3(value, singleConfig);\n },\n _isUsingNativeDriver: function _isUsingNativeDriver() {\n return config.useNativeDriver || false;\n }\n };\n};\nvar sequence = function sequence(animations) {\n var current = 0;\n return {\n start: function start(callback) {\n var onComplete = function onComplete(result) {\n if (!result.finished) {\n callback && callback(result);\n return;\n }\n current++;\n if (current === animations.length) {\n callback && callback(result);\n return;\n }\n animations[current].start(onComplete);\n };\n if (animations.length === 0) {\n callback && callback({\n finished: true\n });\n } else {\n animations[current].start(onComplete);\n }\n },\n stop: function stop() {\n if (current < animations.length) {\n animations[current].stop();\n }\n },\n reset: function reset() {\n animations.forEach((animation, idx) => {\n if (idx <= current) {\n animation.reset();\n }\n });\n current = 0;\n },\n _startNativeLoop: function _startNativeLoop() {\n throw new Error('Loops run using the native driver cannot contain Animated.sequence animations');\n },\n _isUsingNativeDriver: function _isUsingNativeDriver() {\n return false;\n }\n };\n};\nvar parallel = function parallel(animations, config) {\n var doneCount = 0;\n // Make sure we only call stop() at most once for each animation\n var hasEnded = {};\n var stopTogether = !(config && config.stopTogether === false);\n var result = {\n start: function start(callback) {\n if (doneCount === animations.length) {\n callback && callback({\n finished: true\n });\n return;\n }\n animations.forEach((animation, idx) => {\n var cb = function cb(endResult) {\n hasEnded[idx] = true;\n doneCount++;\n if (doneCount === animations.length) {\n doneCount = 0;\n callback && callback(endResult);\n return;\n }\n if (!endResult.finished && stopTogether) {\n result.stop();\n }\n };\n if (!animation) {\n cb({\n finished: true\n });\n } else {\n animation.start(cb);\n }\n });\n },\n stop: function stop() {\n animations.forEach((animation, idx) => {\n !hasEnded[idx] && animation.stop();\n hasEnded[idx] = true;\n });\n },\n reset: function reset() {\n animations.forEach((animation, idx) => {\n animation.reset();\n hasEnded[idx] = false;\n doneCount = 0;\n });\n },\n _startNativeLoop: function _startNativeLoop() {\n throw new Error('Loops run using the native driver cannot contain Animated.parallel animations');\n },\n _isUsingNativeDriver: function _isUsingNativeDriver() {\n return false;\n }\n };\n return result;\n};\nvar delay = function delay(time) {\n // Would be nice to make a specialized implementation\n return timing(new AnimatedValue(0), {\n toValue: 0,\n delay: time,\n duration: 0,\n useNativeDriver: false\n });\n};\nvar stagger = function stagger(time, animations) {\n return parallel(animations.map((animation, i) => {\n return sequence([delay(time * i), animation]);\n }));\n};\nvar loop = function loop(animation, // $FlowFixMe[prop-missing]\n_temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n _ref$iterations = _ref.iterations,\n iterations = _ref$iterations === void 0 ? -1 : _ref$iterations,\n _ref$resetBeforeItera = _ref.resetBeforeIteration,\n resetBeforeIteration = _ref$resetBeforeItera === void 0 ? true : _ref$resetBeforeItera;\n var isFinished = false;\n var iterationsSoFar = 0;\n return {\n start: function start(callback) {\n var restart = function restart(result) {\n if (result === void 0) {\n result = {\n finished: true\n };\n }\n if (isFinished || iterationsSoFar === iterations || result.finished === false) {\n callback && callback(result);\n } else {\n iterationsSoFar++;\n resetBeforeIteration && animation.reset();\n animation.start(restart);\n }\n };\n if (!animation || iterations === 0) {\n callback && callback({\n finished: true\n });\n } else {\n if (animation._isUsingNativeDriver()) {\n animation._startNativeLoop(iterations);\n } else {\n restart(); // Start looping recursively on the js thread\n }\n }\n },\n\n stop: function stop() {\n isFinished = true;\n animation.stop();\n },\n reset: function reset() {\n iterationsSoFar = 0;\n isFinished = false;\n animation.reset();\n },\n _startNativeLoop: function _startNativeLoop() {\n throw new Error('Loops run using the native driver cannot contain Animated.loop animations');\n },\n _isUsingNativeDriver: function _isUsingNativeDriver() {\n return animation._isUsingNativeDriver();\n }\n };\n};\nfunction forkEvent(event, listener) {\n if (!event) {\n return listener;\n } else if (event instanceof AnimatedEvent) {\n event.__addListener(listener);\n return event;\n } else {\n return function () {\n typeof event === 'function' && event(...arguments);\n listener(...arguments);\n };\n }\n}\nfunction unforkEvent(event, listener) {\n if (event && event instanceof AnimatedEvent) {\n event.__removeListener(listener);\n }\n}\nvar event = function event(argMapping, config) {\n var animatedEvent = new AnimatedEvent(argMapping, config);\n if (animatedEvent.__isNative) {\n return animatedEvent;\n } else {\n return animatedEvent.__getHandler();\n }\n};\n\n// All types of animated nodes that represent scalar numbers and can be interpolated (etc)\n\n/**\n * The `Animated` library is designed to make animations fluid, powerful, and\n * easy to build and maintain. `Animated` focuses on declarative relationships\n * between inputs and outputs, with configurable transforms in between, and\n * simple `start`/`stop` methods to control time-based animation execution.\n * If additional transforms are added, be sure to include them in\n * AnimatedMock.js as well.\n *\n * See https://reactnative.dev/docs/animated\n */\nexport default {\n /**\n * Standard value class for driving animations. Typically initialized with\n * `new Animated.Value(0);`\n *\n * See https://reactnative.dev/docs/animated#value\n */\n Value: AnimatedValue,\n /**\n * 2D value class for driving 2D animations, such as pan gestures.\n *\n * See https://reactnative.dev/docs/animatedvaluexy\n */\n ValueXY: AnimatedValueXY,\n /**\n * Value class for driving color animations.\n */\n Color: AnimatedColor,\n /**\n * Exported to use the Interpolation type in flow.\n *\n * See https://reactnative.dev/docs/animated#interpolation\n */\n Interpolation: AnimatedInterpolation,\n /**\n * Exported for ease of type checking. All animated values derive from this\n * class.\n *\n * See https://reactnative.dev/docs/animated#node\n */\n Node: AnimatedNode,\n /**\n * Animates a value from an initial velocity to zero based on a decay\n * coefficient.\n *\n * See https://reactnative.dev/docs/animated#decay\n */\n decay,\n /**\n * Animates a value along a timed easing curve. The Easing module has tons of\n * predefined curves, or you can use your own function.\n *\n * See https://reactnative.dev/docs/animated#timing\n */\n timing,\n /**\n * Animates a value according to an analytical spring model based on\n * damped harmonic oscillation.\n *\n * See https://reactnative.dev/docs/animated#spring\n */\n spring,\n /**\n * Creates a new Animated value composed from two Animated values added\n * together.\n *\n * See https://reactnative.dev/docs/animated#add\n */\n add,\n /**\n * Creates a new Animated value composed by subtracting the second Animated\n * value from the first Animated value.\n *\n * See https://reactnative.dev/docs/animated#subtract\n */\n subtract,\n /**\n * Creates a new Animated value composed by dividing the first Animated value\n * by the second Animated value.\n *\n * See https://reactnative.dev/docs/animated#divide\n */\n divide,\n /**\n * Creates a new Animated value composed from two Animated values multiplied\n * together.\n *\n * See https://reactnative.dev/docs/animated#multiply\n */\n multiply,\n /**\n * Creates a new Animated value that is the (non-negative) modulo of the\n * provided Animated value.\n *\n * See https://reactnative.dev/docs/animated#modulo\n */\n modulo,\n /**\n * Create a new Animated value that is limited between 2 values. It uses the\n * difference between the last value so even if the value is far from the\n * bounds it will start changing when the value starts getting closer again.\n *\n * See https://reactnative.dev/docs/animated#diffclamp\n */\n diffClamp,\n /**\n * Starts an animation after the given delay.\n *\n * See https://reactnative.dev/docs/animated#delay\n */\n delay,\n /**\n * Starts an array of animations in order, waiting for each to complete\n * before starting the next. If the current running animation is stopped, no\n * following animations will be started.\n *\n * See https://reactnative.dev/docs/animated#sequence\n */\n sequence,\n /**\n * Starts an array of animations all at the same time. By default, if one\n * of the animations is stopped, they will all be stopped. You can override\n * this with the `stopTogether` flag.\n *\n * See https://reactnative.dev/docs/animated#parallel\n */\n parallel,\n /**\n * Array of animations may run in parallel (overlap), but are started in\n * sequence with successive delays. Nice for doing trailing effects.\n *\n * See https://reactnative.dev/docs/animated#stagger\n */\n stagger,\n /**\n * Loops a given animation continuously, so that each time it reaches the\n * end, it resets and begins again from the start.\n *\n * See https://reactnative.dev/docs/animated#loop\n */\n loop,\n /**\n * Takes an array of mappings and extracts values from each arg accordingly,\n * then calls `setValue` on the mapped outputs.\n *\n * See https://reactnative.dev/docs/animated#event\n */\n event,\n /**\n * Make any React component Animatable. Used to create `Animated.View`, etc.\n *\n * See https://reactnative.dev/docs/animated#createanimatedcomponent\n */\n createAnimatedComponent,\n /**\n * Imperative API to attach an animated value to an event on a view. Prefer\n * using `Animated.event` with `useNativeDrive: true` if possible.\n *\n * See https://reactnative.dev/docs/animated#attachnativeevent\n */\n attachNativeEvent,\n /**\n * Advanced imperative API for snooping on animated events that are passed in\n * through props. Use values directly where possible.\n *\n * See https://reactnative.dev/docs/animated#forkevent\n */\n forkEvent,\n unforkEvent,\n /**\n * Expose Event class, so it can be used as a type for type checkers.\n */\n Event: AnimatedEvent\n};","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nclass AnimatedAddition extends AnimatedWithChildren {\n constructor(a, b) {\n super();\n this._a = typeof a === 'number' ? new AnimatedValue(a) : a;\n this._b = typeof b === 'number' ? new AnimatedValue(b) : b;\n }\n __makeNative(platformConfig) {\n this._a.__makeNative(platformConfig);\n this._b.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n __getValue() {\n return this._a.__getValue() + this._b.__getValue();\n }\n interpolate(config) {\n return new AnimatedInterpolation(this, config);\n }\n __attach() {\n this._a.__addChild(this);\n this._b.__addChild(this);\n }\n __detach() {\n this._a.__removeChild(this);\n this._b.__removeChild(this);\n super.__detach();\n }\n __getNativeConfig() {\n return {\n type: 'addition',\n input: [this._a.__getNativeTag(), this._b.__getNativeTag()]\n };\n }\n}\nexport default AnimatedAddition;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nclass AnimatedDiffClamp extends AnimatedWithChildren {\n constructor(a, min, max) {\n super();\n this._a = a;\n this._min = min;\n this._max = max;\n this._value = this._lastValue = this._a.__getValue();\n }\n __makeNative(platformConfig) {\n this._a.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n interpolate(config) {\n return new AnimatedInterpolation(this, config);\n }\n __getValue() {\n var value = this._a.__getValue();\n var diff = value - this._lastValue;\n this._lastValue = value;\n this._value = Math.min(Math.max(this._value + diff, this._min), this._max);\n return this._value;\n }\n __attach() {\n this._a.__addChild(this);\n }\n __detach() {\n this._a.__removeChild(this);\n super.__detach();\n }\n __getNativeConfig() {\n return {\n type: 'diffclamp',\n input: this._a.__getNativeTag(),\n min: this._min,\n max: this._max\n };\n }\n}\nexport default AnimatedDiffClamp;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedNode from './AnimatedNode';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nclass AnimatedDivision extends AnimatedWithChildren {\n constructor(a, b) {\n super();\n this._warnedAboutDivideByZero = false;\n if (b === 0 || b instanceof AnimatedNode && b.__getValue() === 0) {\n console.error('Detected potential division by zero in AnimatedDivision');\n }\n this._a = typeof a === 'number' ? new AnimatedValue(a) : a;\n this._b = typeof b === 'number' ? new AnimatedValue(b) : b;\n }\n __makeNative(platformConfig) {\n this._a.__makeNative(platformConfig);\n this._b.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n __getValue() {\n var a = this._a.__getValue();\n var b = this._b.__getValue();\n if (b === 0) {\n // Prevent spamming the console/LogBox\n if (!this._warnedAboutDivideByZero) {\n console.error('Detected division by zero in AnimatedDivision');\n this._warnedAboutDivideByZero = true;\n }\n // Passing infinity/NaN to Fabric will cause a native crash\n return 0;\n }\n this._warnedAboutDivideByZero = false;\n return a / b;\n }\n interpolate(config) {\n return new AnimatedInterpolation(this, config);\n }\n __attach() {\n this._a.__addChild(this);\n this._b.__addChild(this);\n }\n __detach() {\n this._a.__removeChild(this);\n this._b.__removeChild(this);\n super.__detach();\n }\n __getNativeConfig() {\n return {\n type: 'division',\n input: [this._a.__getNativeTag(), this._b.__getNativeTag()]\n };\n }\n}\nexport default AnimatedDivision;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nclass AnimatedModulo extends AnimatedWithChildren {\n constructor(a, modulus) {\n super();\n this._a = a;\n this._modulus = modulus;\n }\n __makeNative(platformConfig) {\n this._a.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n __getValue() {\n return (this._a.__getValue() % this._modulus + this._modulus) % this._modulus;\n }\n interpolate(config) {\n return new AnimatedInterpolation(this, config);\n }\n __attach() {\n this._a.__addChild(this);\n }\n __detach() {\n this._a.__removeChild(this);\n super.__detach();\n }\n __getNativeConfig() {\n return {\n type: 'modulus',\n input: this._a.__getNativeTag(),\n modulus: this._modulus\n };\n }\n}\nexport default AnimatedModulo;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nclass AnimatedMultiplication extends AnimatedWithChildren {\n constructor(a, b) {\n super();\n this._a = typeof a === 'number' ? new AnimatedValue(a) : a;\n this._b = typeof b === 'number' ? new AnimatedValue(b) : b;\n }\n __makeNative(platformConfig) {\n this._a.__makeNative(platformConfig);\n this._b.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n __getValue() {\n return this._a.__getValue() * this._b.__getValue();\n }\n interpolate(config) {\n return new AnimatedInterpolation(this, config);\n }\n __attach() {\n this._a.__addChild(this);\n this._b.__addChild(this);\n }\n __detach() {\n this._a.__removeChild(this);\n this._b.__removeChild(this);\n super.__detach();\n }\n __getNativeConfig() {\n return {\n type: 'multiplication',\n input: [this._a.__getNativeTag(), this._b.__getNativeTag()]\n };\n }\n}\nexport default AnimatedMultiplication;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nclass AnimatedSubtraction extends AnimatedWithChildren {\n constructor(a, b) {\n super();\n this._a = typeof a === 'number' ? new AnimatedValue(a) : a;\n this._b = typeof b === 'number' ? new AnimatedValue(b) : b;\n }\n __makeNative(platformConfig) {\n this._a.__makeNative(platformConfig);\n this._b.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n __getValue() {\n return this._a.__getValue() - this._b.__getValue();\n }\n interpolate(config) {\n return new AnimatedInterpolation(this, config);\n }\n __attach() {\n this._a.__addChild(this);\n this._b.__addChild(this);\n }\n __detach() {\n this._a.__removeChild(this);\n this._b.__removeChild(this);\n super.__detach();\n }\n __getNativeConfig() {\n return {\n type: 'subtraction',\n input: [this._a.__getNativeTag(), this._b.__getNativeTag()]\n };\n }\n}\nexport default AnimatedSubtraction;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedNode from './AnimatedNode';\nimport { generateNewAnimationId, shouldUseNativeDriver } from '../NativeAnimatedHelper';\nclass AnimatedTracking extends AnimatedNode {\n constructor(value, parent, animationClass, animationConfig, callback) {\n super();\n this._value = value;\n this._parent = parent;\n this._animationClass = animationClass;\n this._animationConfig = animationConfig;\n this._useNativeDriver = shouldUseNativeDriver(animationConfig);\n this._callback = callback;\n this.__attach();\n }\n __makeNative() {\n this.__isNative = true;\n this._parent.__makeNative();\n super.__makeNative();\n this._value.__makeNative();\n }\n __getValue() {\n return this._parent.__getValue();\n }\n __attach() {\n this._parent.__addChild(this);\n if (this._useNativeDriver) {\n // when the tracking starts we need to convert this node to a \"native node\"\n // so that the parent node will be made \"native\" too. This is necessary as\n // if we don't do this `update` method will get called. At that point it\n // may be too late as it would mean the JS driver has already started\n // updating node values\n this.__makeNative();\n }\n }\n __detach() {\n this._parent.__removeChild(this);\n super.__detach();\n }\n update() {\n this._value.animate(new this._animationClass(_objectSpread(_objectSpread({}, this._animationConfig), {}, {\n toValue: this._animationConfig.toValue.__getValue()\n })), this._callback);\n }\n __getNativeConfig() {\n var animation = new this._animationClass(_objectSpread(_objectSpread({}, this._animationConfig), {}, {\n // remove toValue from the config as it's a ref to Animated.Value\n toValue: undefined\n }));\n var animationConfig = animation.__getNativeAnimationConfig();\n return {\n type: 'tracking',\n animationId: generateNewAnimationId(),\n animationConfig,\n toValue: this._parent.__getNativeTag(),\n value: this._value.__getNativeTag()\n };\n }\n}\nexport default AnimatedTracking;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nimport invariant from 'fbjs/lib/invariant';\nvar _uniqueId = 1;\n\n/**\n * 2D Value for driving 2D animations, such as pan gestures. Almost identical\n * API to normal `Animated.Value`, but multiplexed.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html\n */\nclass AnimatedValueXY extends AnimatedWithChildren {\n constructor(valueIn) {\n super();\n var value = valueIn || {\n x: 0,\n y: 0\n }; // fixme: shouldn't need `: any`\n if (typeof value.x === 'number' && typeof value.y === 'number') {\n this.x = new AnimatedValue(value.x);\n this.y = new AnimatedValue(value.y);\n } else {\n invariant(value.x instanceof AnimatedValue && value.y instanceof AnimatedValue, 'AnimatedValueXY must be initialized with an object of numbers or ' + 'AnimatedValues.');\n this.x = value.x;\n this.y = value.y;\n }\n this._listeners = {};\n }\n\n /**\n * Directly set the value. This will stop any animations running on the value\n * and update all the bound properties.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#setvalue\n */\n setValue(value) {\n this.x.setValue(value.x);\n this.y.setValue(value.y);\n }\n\n /**\n * Sets an offset that is applied on top of whatever value is set, whether\n * via `setValue`, an animation, or `Animated.event`. Useful for compensating\n * things like the start of a pan gesture.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#setoffset\n */\n setOffset(offset) {\n this.x.setOffset(offset.x);\n this.y.setOffset(offset.y);\n }\n\n /**\n * Merges the offset value into the base value and resets the offset to zero.\n * The final output of the value is unchanged.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#flattenoffset\n */\n flattenOffset() {\n this.x.flattenOffset();\n this.y.flattenOffset();\n }\n\n /**\n * Sets the offset value to the base value, and resets the base value to\n * zero. The final output of the value is unchanged.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#extractoffset\n */\n extractOffset() {\n this.x.extractOffset();\n this.y.extractOffset();\n }\n __getValue() {\n return {\n x: this.x.__getValue(),\n y: this.y.__getValue()\n };\n }\n\n /**\n * Stops any animation and resets the value to its original.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#resetanimation\n */\n resetAnimation(callback) {\n this.x.resetAnimation();\n this.y.resetAnimation();\n callback && callback(this.__getValue());\n }\n\n /**\n * Stops any running animation or tracking. `callback` is invoked with the\n * final value after stopping the animation, which is useful for updating\n * state to match the animation position with layout.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#stopanimation\n */\n stopAnimation(callback) {\n this.x.stopAnimation();\n this.y.stopAnimation();\n callback && callback(this.__getValue());\n }\n\n /**\n * Adds an asynchronous listener to the value so you can observe updates from\n * animations. This is useful because there is no way to synchronously read\n * the value because it might be driven natively.\n *\n * Returns a string that serves as an identifier for the listener.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#addlistener\n */\n addListener(callback) {\n var id = String(_uniqueId++);\n var jointCallback = _ref => {\n var number = _ref.value;\n callback(this.__getValue());\n };\n this._listeners[id] = {\n x: this.x.addListener(jointCallback),\n y: this.y.addListener(jointCallback)\n };\n return id;\n }\n\n /**\n * Unregister a listener. The `id` param shall match the identifier\n * previously returned by `addListener()`.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#removelistener\n */\n removeListener(id) {\n this.x.removeListener(this._listeners[id].x);\n this.y.removeListener(this._listeners[id].y);\n delete this._listeners[id];\n }\n\n /**\n * Remove all registered listeners.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#removealllisteners\n */\n removeAllListeners() {\n this.x.removeAllListeners();\n this.y.removeAllListeners();\n this._listeners = {};\n }\n\n /**\n * Converts `{x, y}` into `{left, top}` for use in style.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#getlayout\n */\n getLayout() {\n return {\n left: this.x,\n top: this.y\n };\n }\n\n /**\n * Converts `{x, y}` into a useable translation transform.\n *\n * See https://reactnative.dev/docs/animatedvaluexy.html#gettranslatetransform\n */\n getTranslateTransform() {\n return [{\n translateX: this.x\n }, {\n translateY: this.y\n }];\n }\n}\nexport default AnimatedValueXY;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport Animation from './Animation';\nimport { shouldUseNativeDriver } from '../NativeAnimatedHelper';\nclass DecayAnimation extends Animation {\n constructor(config) {\n var _config$deceleration, _config$isInteraction, _config$iterations;\n super();\n this._deceleration = (_config$deceleration = config.deceleration) !== null && _config$deceleration !== void 0 ? _config$deceleration : 0.998;\n this._velocity = config.velocity;\n this._useNativeDriver = shouldUseNativeDriver(config);\n this.__isInteraction = (_config$isInteraction = config.isInteraction) !== null && _config$isInteraction !== void 0 ? _config$isInteraction : !this._useNativeDriver;\n this.__iterations = (_config$iterations = config.iterations) !== null && _config$iterations !== void 0 ? _config$iterations : 1;\n }\n __getNativeAnimationConfig() {\n return {\n type: 'decay',\n deceleration: this._deceleration,\n velocity: this._velocity,\n iterations: this.__iterations\n };\n }\n start(fromValue, onUpdate, onEnd, previousAnimation, animatedValue) {\n this.__active = true;\n this._lastValue = fromValue;\n this._fromValue = fromValue;\n this._onUpdate = onUpdate;\n this.__onEnd = onEnd;\n this._startTime = Date.now();\n if (this._useNativeDriver) {\n this.__startNativeAnimation(animatedValue);\n } else {\n this._animationFrame = requestAnimationFrame(this.onUpdate.bind(this));\n }\n }\n onUpdate() {\n var now = Date.now();\n var value = this._fromValue + this._velocity / (1 - this._deceleration) * (1 - Math.exp(-(1 - this._deceleration) * (now - this._startTime)));\n this._onUpdate(value);\n if (Math.abs(this._lastValue - value) < 0.1) {\n this.__debouncedOnEnd({\n finished: true\n });\n return;\n }\n this._lastValue = value;\n if (this.__active) {\n this._animationFrame = requestAnimationFrame(this.onUpdate.bind(this));\n }\n }\n stop() {\n super.stop();\n this.__active = false;\n global.cancelAnimationFrame(this._animationFrame);\n this.__debouncedOnEnd({\n finished: false\n });\n }\n}\nexport default DecayAnimation;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nvar startNativeAnimationNextId = 1;\n\n// Important note: start() and stop() will only be called at most once.\n// Once an animation has been stopped or finished its course, it will\n// not be reused.\nclass Animation {\n start(fromValue, onUpdate, onEnd, previousAnimation, animatedValue) {}\n stop() {\n if (this.__nativeId) {\n NativeAnimatedHelper.API.stopAnimation(this.__nativeId);\n }\n }\n __getNativeAnimationConfig() {\n // Subclasses that have corresponding animation implementation done in native\n // should override this method\n throw new Error('This animation type cannot be offloaded to native');\n }\n // Helper function for subclasses to make sure onEnd is only called once.\n __debouncedOnEnd(result) {\n var onEnd = this.__onEnd;\n this.__onEnd = null;\n onEnd && onEnd(result);\n }\n __startNativeAnimation(animatedValue) {\n var startNativeAnimationWaitId = startNativeAnimationNextId + \":startAnimation\";\n startNativeAnimationNextId += 1;\n NativeAnimatedHelper.API.setWaitingForIdentifier(startNativeAnimationWaitId);\n try {\n var config = this.__getNativeAnimationConfig();\n animatedValue.__makeNative(config.platformConfig);\n this.__nativeId = NativeAnimatedHelper.generateNewAnimationId();\n NativeAnimatedHelper.API.startAnimatingNode(this.__nativeId, animatedValue.__getNativeTag(), config,\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this.__debouncedOnEnd.bind(this));\n } catch (e) {\n throw e;\n } finally {\n NativeAnimatedHelper.API.unsetWaitingForIdentifier(startNativeAnimationWaitId);\n }\n }\n}\nexport default Animation;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport Animation from './Animation';\nimport SpringConfig from '../SpringConfig';\nimport invariant from 'fbjs/lib/invariant';\nimport { shouldUseNativeDriver } from '../NativeAnimatedHelper';\nimport AnimatedColor from '../nodes/AnimatedColor';\nclass SpringAnimation extends Animation {\n constructor(config) {\n var _config$overshootClam, _config$restDisplacem, _config$restSpeedThre, _config$velocity, _config$velocity2, _config$delay, _config$isInteraction, _config$iterations;\n super();\n this._overshootClamping = (_config$overshootClam = config.overshootClamping) !== null && _config$overshootClam !== void 0 ? _config$overshootClam : false;\n this._restDisplacementThreshold = (_config$restDisplacem = config.restDisplacementThreshold) !== null && _config$restDisplacem !== void 0 ? _config$restDisplacem : 0.001;\n this._restSpeedThreshold = (_config$restSpeedThre = config.restSpeedThreshold) !== null && _config$restSpeedThre !== void 0 ? _config$restSpeedThre : 0.001;\n this._initialVelocity = (_config$velocity = config.velocity) !== null && _config$velocity !== void 0 ? _config$velocity : 0;\n this._lastVelocity = (_config$velocity2 = config.velocity) !== null && _config$velocity2 !== void 0 ? _config$velocity2 : 0;\n this._toValue = config.toValue;\n this._delay = (_config$delay = config.delay) !== null && _config$delay !== void 0 ? _config$delay : 0;\n this._useNativeDriver = shouldUseNativeDriver(config);\n this._platformConfig = config.platformConfig;\n this.__isInteraction = (_config$isInteraction = config.isInteraction) !== null && _config$isInteraction !== void 0 ? _config$isInteraction : !this._useNativeDriver;\n this.__iterations = (_config$iterations = config.iterations) !== null && _config$iterations !== void 0 ? _config$iterations : 1;\n if (config.stiffness !== undefined || config.damping !== undefined || config.mass !== undefined) {\n var _config$stiffness, _config$damping, _config$mass;\n invariant(config.bounciness === undefined && config.speed === undefined && config.tension === undefined && config.friction === undefined, 'You can define one of bounciness/speed, tension/friction, or stiffness/damping/mass, but not more than one');\n this._stiffness = (_config$stiffness = config.stiffness) !== null && _config$stiffness !== void 0 ? _config$stiffness : 100;\n this._damping = (_config$damping = config.damping) !== null && _config$damping !== void 0 ? _config$damping : 10;\n this._mass = (_config$mass = config.mass) !== null && _config$mass !== void 0 ? _config$mass : 1;\n } else if (config.bounciness !== undefined || config.speed !== undefined) {\n var _config$bounciness, _config$speed;\n // Convert the origami bounciness/speed values to stiffness/damping\n // We assume mass is 1.\n invariant(config.tension === undefined && config.friction === undefined && config.stiffness === undefined && config.damping === undefined && config.mass === undefined, 'You can define one of bounciness/speed, tension/friction, or stiffness/damping/mass, but not more than one');\n var springConfig = SpringConfig.fromBouncinessAndSpeed((_config$bounciness = config.bounciness) !== null && _config$bounciness !== void 0 ? _config$bounciness : 8, (_config$speed = config.speed) !== null && _config$speed !== void 0 ? _config$speed : 12);\n this._stiffness = springConfig.stiffness;\n this._damping = springConfig.damping;\n this._mass = 1;\n } else {\n var _config$tension, _config$friction;\n // Convert the origami tension/friction values to stiffness/damping\n // We assume mass is 1.\n var _springConfig = SpringConfig.fromOrigamiTensionAndFriction((_config$tension = config.tension) !== null && _config$tension !== void 0 ? _config$tension : 40, (_config$friction = config.friction) !== null && _config$friction !== void 0 ? _config$friction : 7);\n this._stiffness = _springConfig.stiffness;\n this._damping = _springConfig.damping;\n this._mass = 1;\n }\n invariant(this._stiffness > 0, 'Stiffness value must be greater than 0');\n invariant(this._damping > 0, 'Damping value must be greater than 0');\n invariant(this._mass > 0, 'Mass value must be greater than 0');\n }\n __getNativeAnimationConfig() {\n var _this$_initialVelocit;\n return {\n type: 'spring',\n overshootClamping: this._overshootClamping,\n restDisplacementThreshold: this._restDisplacementThreshold,\n restSpeedThreshold: this._restSpeedThreshold,\n stiffness: this._stiffness,\n damping: this._damping,\n mass: this._mass,\n initialVelocity: (_this$_initialVelocit = this._initialVelocity) !== null && _this$_initialVelocit !== void 0 ? _this$_initialVelocit : this._lastVelocity,\n toValue: this._toValue,\n iterations: this.__iterations,\n platformConfig: this._platformConfig\n };\n }\n start(fromValue, onUpdate, onEnd, previousAnimation, animatedValue) {\n this.__active = true;\n this._startPosition = fromValue;\n this._lastPosition = this._startPosition;\n this._onUpdate = onUpdate;\n this.__onEnd = onEnd;\n this._lastTime = Date.now();\n this._frameTime = 0.0;\n if (previousAnimation instanceof SpringAnimation) {\n var internalState = previousAnimation.getInternalState();\n this._lastPosition = internalState.lastPosition;\n this._lastVelocity = internalState.lastVelocity;\n // Set the initial velocity to the last velocity\n this._initialVelocity = this._lastVelocity;\n this._lastTime = internalState.lastTime;\n }\n var start = () => {\n if (this._useNativeDriver) {\n this.__startNativeAnimation(animatedValue);\n } else {\n this.onUpdate();\n }\n };\n\n // If this._delay is more than 0, we start after the timeout.\n if (this._delay) {\n this._timeout = setTimeout(start, this._delay);\n } else {\n start();\n }\n }\n getInternalState() {\n return {\n lastPosition: this._lastPosition,\n lastVelocity: this._lastVelocity,\n lastTime: this._lastTime\n };\n }\n\n /**\n * This spring model is based off of a damped harmonic oscillator\n * (https://en.wikipedia.org/wiki/Harmonic_oscillator#Damped_harmonic_oscillator).\n *\n * We use the closed form of the second order differential equation:\n *\n * x'' + (2ζ⍵_0)x' + ⍵^2x = 0\n *\n * where\n * ⍵_0 = √(k / m) (undamped angular frequency of the oscillator),\n * ζ = c / 2√mk (damping ratio),\n * c = damping constant\n * k = stiffness\n * m = mass\n *\n * The derivation of the closed form is described in detail here:\n * http://planetmath.org/sites/default/files/texpdf/39745.pdf\n *\n * This algorithm happens to match the algorithm used by CASpringAnimation,\n * a QuartzCore (iOS) API that creates spring animations.\n */\n onUpdate() {\n // If for some reason we lost a lot of frames (e.g. process large payload or\n // stopped in the debugger), we only advance by 4 frames worth of\n // computation and will continue on the next frame. It's better to have it\n // running at faster speed than jumping to the end.\n var MAX_STEPS = 64;\n var now = Date.now();\n if (now > this._lastTime + MAX_STEPS) {\n now = this._lastTime + MAX_STEPS;\n }\n var deltaTime = (now - this._lastTime) / 1000;\n this._frameTime += deltaTime;\n var c = this._damping;\n var m = this._mass;\n var k = this._stiffness;\n var v0 = -this._initialVelocity;\n var zeta = c / (2 * Math.sqrt(k * m)); // damping ratio\n var omega0 = Math.sqrt(k / m); // undamped angular frequency of the oscillator (rad/ms)\n var omega1 = omega0 * Math.sqrt(1.0 - zeta * zeta); // exponential decay\n var x0 = this._toValue - this._startPosition; // calculate the oscillation from x0 = 1 to x = 0\n\n var position = 0.0;\n var velocity = 0.0;\n var t = this._frameTime;\n if (zeta < 1) {\n // Under damped\n var envelope = Math.exp(-zeta * omega0 * t);\n position = this._toValue - envelope * ((v0 + zeta * omega0 * x0) / omega1 * Math.sin(omega1 * t) + x0 * Math.cos(omega1 * t));\n // This looks crazy -- it's actually just the derivative of the\n // oscillation function\n velocity = zeta * omega0 * envelope * (Math.sin(omega1 * t) * (v0 + zeta * omega0 * x0) / omega1 + x0 * Math.cos(omega1 * t)) - envelope * (Math.cos(omega1 * t) * (v0 + zeta * omega0 * x0) - omega1 * x0 * Math.sin(omega1 * t));\n } else {\n // Critically damped\n var _envelope = Math.exp(-omega0 * t);\n position = this._toValue - _envelope * (x0 + (v0 + omega0 * x0) * t);\n velocity = _envelope * (v0 * (t * omega0 - 1) + t * x0 * (omega0 * omega0));\n }\n this._lastTime = now;\n this._lastPosition = position;\n this._lastVelocity = velocity;\n this._onUpdate(position);\n if (!this.__active) {\n // a listener might have stopped us in _onUpdate\n return;\n }\n\n // Conditions for stopping the spring animation\n var isOvershooting = false;\n if (this._overshootClamping && this._stiffness !== 0) {\n if (this._startPosition < this._toValue) {\n isOvershooting = position > this._toValue;\n } else {\n isOvershooting = position < this._toValue;\n }\n }\n var isVelocity = Math.abs(velocity) <= this._restSpeedThreshold;\n var isDisplacement = true;\n if (this._stiffness !== 0) {\n isDisplacement = Math.abs(this._toValue - position) <= this._restDisplacementThreshold;\n }\n if (isOvershooting || isVelocity && isDisplacement) {\n if (this._stiffness !== 0) {\n // Ensure that we end up with a round value\n this._lastPosition = this._toValue;\n this._lastVelocity = 0;\n this._onUpdate(this._toValue);\n }\n this.__debouncedOnEnd({\n finished: true\n });\n return;\n }\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this._animationFrame = requestAnimationFrame(this.onUpdate.bind(this));\n }\n stop() {\n super.stop();\n this.__active = false;\n clearTimeout(this._timeout);\n global.cancelAnimationFrame(this._animationFrame);\n this.__debouncedOnEnd({\n finished: false\n });\n }\n}\nexport default SpringAnimation;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * \n */\n\n'use strict';\n\nfunction stiffnessFromOrigamiValue(oValue) {\n return (oValue - 30) * 3.62 + 194;\n}\nfunction dampingFromOrigamiValue(oValue) {\n return (oValue - 8) * 3 + 25;\n}\nfunction fromOrigamiTensionAndFriction(tension, friction) {\n return {\n stiffness: stiffnessFromOrigamiValue(tension),\n damping: dampingFromOrigamiValue(friction)\n };\n}\nfunction fromBouncinessAndSpeed(bounciness, speed) {\n function normalize(value, startValue, endValue) {\n return (value - startValue) / (endValue - startValue);\n }\n function projectNormal(n, start, end) {\n return start + n * (end - start);\n }\n function linearInterpolation(t, start, end) {\n return t * end + (1 - t) * start;\n }\n function quadraticOutInterpolation(t, start, end) {\n return linearInterpolation(2 * t - t * t, start, end);\n }\n function b3Friction1(x) {\n return 0.0007 * Math.pow(x, 3) - 0.031 * Math.pow(x, 2) + 0.64 * x + 1.28;\n }\n function b3Friction2(x) {\n return 0.000044 * Math.pow(x, 3) - 0.006 * Math.pow(x, 2) + 0.36 * x + 2;\n }\n function b3Friction3(x) {\n return 0.00000045 * Math.pow(x, 3) - 0.000332 * Math.pow(x, 2) + 0.1078 * x + 5.84;\n }\n function b3Nobounce(tension) {\n if (tension <= 18) {\n return b3Friction1(tension);\n } else if (tension > 18 && tension <= 44) {\n return b3Friction2(tension);\n } else {\n return b3Friction3(tension);\n }\n }\n var b = normalize(bounciness / 1.7, 0, 20);\n b = projectNormal(b, 0, 0.8);\n var s = normalize(speed / 1.7, 0, 20);\n var bouncyTension = projectNormal(s, 0.5, 200);\n var bouncyFriction = quadraticOutInterpolation(b, b3Nobounce(bouncyTension), 0.01);\n return {\n stiffness: stiffnessFromOrigamiValue(bouncyTension),\n damping: dampingFromOrigamiValue(bouncyFriction)\n };\n}\nexport default {\n fromOrigamiTensionAndFriction,\n fromBouncinessAndSpeed\n};","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nimport normalizeColor from '@react-native/normalize-colors';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nvar NativeAnimatedAPI = NativeAnimatedHelper.API;\nvar defaultColor = {\n r: 0,\n g: 0,\n b: 0,\n a: 1.0\n};\nvar _uniqueId = 1;\nvar processColorObject = color => {\n return color;\n};\n\n/* eslint no-bitwise: 0 */\nfunction processColor(color) {\n if (color === undefined || color === null) {\n return null;\n }\n if (isRgbaValue(color)) {\n // $FlowIgnore[incompatible-cast] - Type is verified above\n return color;\n }\n var normalizedColor = normalizeColor(\n // $FlowIgnore[incompatible-cast] - Type is verified above\n color);\n if (normalizedColor === undefined || normalizedColor === null) {\n return null;\n }\n if (typeof normalizedColor === 'object') {\n var processedColorObj = processColorObject(normalizedColor);\n if (processedColorObj != null) {\n return processedColorObj;\n }\n } else if (typeof normalizedColor === 'number') {\n var r = (normalizedColor & 0xff000000) >>> 24;\n var g = (normalizedColor & 0x00ff0000) >>> 16;\n var b = (normalizedColor & 0x0000ff00) >>> 8;\n var a = (normalizedColor & 0x000000ff) / 255;\n return {\n r,\n g,\n b,\n a\n };\n }\n return null;\n}\nfunction isRgbaValue(value) {\n return value && typeof value.r === 'number' && typeof value.g === 'number' && typeof value.b === 'number' && typeof value.a === 'number';\n}\nfunction isRgbaAnimatedValue(value) {\n return value && value.r instanceof AnimatedValue && value.g instanceof AnimatedValue && value.b instanceof AnimatedValue && value.a instanceof AnimatedValue;\n}\nexport default class AnimatedColor extends AnimatedWithChildren {\n constructor(valueIn, config) {\n super();\n this._listeners = {};\n var value = valueIn !== null && valueIn !== void 0 ? valueIn : defaultColor;\n if (isRgbaAnimatedValue(value)) {\n // $FlowIgnore[incompatible-cast] - Type is verified above\n var rgbaAnimatedValue = value;\n this.r = rgbaAnimatedValue.r;\n this.g = rgbaAnimatedValue.g;\n this.b = rgbaAnimatedValue.b;\n this.a = rgbaAnimatedValue.a;\n } else {\n var _processColor;\n var processedColor = // $FlowIgnore[incompatible-cast] - Type is verified above\n (_processColor = processColor(value)) !== null && _processColor !== void 0 ? _processColor : defaultColor;\n var initColor = defaultColor;\n if (isRgbaValue(processedColor)) {\n // $FlowIgnore[incompatible-cast] - Type is verified above\n initColor = processedColor;\n } else {\n // $FlowIgnore[incompatible-cast] - Type is verified above\n this.nativeColor = processedColor;\n }\n this.r = new AnimatedValue(initColor.r);\n this.g = new AnimatedValue(initColor.g);\n this.b = new AnimatedValue(initColor.b);\n this.a = new AnimatedValue(initColor.a);\n }\n if (this.nativeColor || config && config.useNativeDriver) {\n this.__makeNative();\n }\n }\n\n /**\n * Directly set the value. This will stop any animations running on the value\n * and update all the bound properties.\n */\n setValue(value) {\n var _processColor2;\n var shouldUpdateNodeConfig = false;\n if (this.__isNative) {\n var nativeTag = this.__getNativeTag();\n NativeAnimatedAPI.setWaitingForIdentifier(nativeTag.toString());\n }\n var processedColor = (_processColor2 = processColor(value)) !== null && _processColor2 !== void 0 ? _processColor2 : defaultColor;\n if (isRgbaValue(processedColor)) {\n // $FlowIgnore[incompatible-type] - Type is verified above\n var rgbaValue = processedColor;\n this.r.setValue(rgbaValue.r);\n this.g.setValue(rgbaValue.g);\n this.b.setValue(rgbaValue.b);\n this.a.setValue(rgbaValue.a);\n if (this.nativeColor != null) {\n this.nativeColor = null;\n shouldUpdateNodeConfig = true;\n }\n } else {\n // $FlowIgnore[incompatible-type] - Type is verified above\n var nativeColor = processedColor;\n if (this.nativeColor !== nativeColor) {\n this.nativeColor = nativeColor;\n shouldUpdateNodeConfig = true;\n }\n }\n if (this.__isNative) {\n var _nativeTag = this.__getNativeTag();\n if (shouldUpdateNodeConfig) {\n NativeAnimatedAPI.updateAnimatedNodeConfig(_nativeTag, this.__getNativeConfig());\n }\n NativeAnimatedAPI.unsetWaitingForIdentifier(_nativeTag.toString());\n }\n }\n\n /**\n * Sets an offset that is applied on top of whatever value is set, whether\n * via `setValue`, an animation, or `Animated.event`. Useful for compensating\n * things like the start of a pan gesture.\n */\n setOffset(offset) {\n this.r.setOffset(offset.r);\n this.g.setOffset(offset.g);\n this.b.setOffset(offset.b);\n this.a.setOffset(offset.a);\n }\n\n /**\n * Merges the offset value into the base value and resets the offset to zero.\n * The final output of the value is unchanged.\n */\n flattenOffset() {\n this.r.flattenOffset();\n this.g.flattenOffset();\n this.b.flattenOffset();\n this.a.flattenOffset();\n }\n\n /**\n * Sets the offset value to the base value, and resets the base value to\n * zero. The final output of the value is unchanged.\n */\n extractOffset() {\n this.r.extractOffset();\n this.g.extractOffset();\n this.b.extractOffset();\n this.a.extractOffset();\n }\n\n /**\n * Adds an asynchronous listener to the value so you can observe updates from\n * animations. This is useful because there is no way to synchronously read\n * the value because it might be driven natively.\n *\n * Returns a string that serves as an identifier for the listener.\n */\n addListener(callback) {\n var id = String(_uniqueId++);\n var jointCallback = _ref => {\n var number = _ref.value;\n callback(this.__getValue());\n };\n this._listeners[id] = {\n r: this.r.addListener(jointCallback),\n g: this.g.addListener(jointCallback),\n b: this.b.addListener(jointCallback),\n a: this.a.addListener(jointCallback)\n };\n return id;\n }\n\n /**\n * Unregister a listener. The `id` param shall match the identifier\n * previously returned by `addListener()`.\n */\n removeListener(id) {\n this.r.removeListener(this._listeners[id].r);\n this.g.removeListener(this._listeners[id].g);\n this.b.removeListener(this._listeners[id].b);\n this.a.removeListener(this._listeners[id].a);\n delete this._listeners[id];\n }\n\n /**\n * Remove all registered listeners.\n */\n removeAllListeners() {\n this.r.removeAllListeners();\n this.g.removeAllListeners();\n this.b.removeAllListeners();\n this.a.removeAllListeners();\n this._listeners = {};\n }\n\n /**\n * Stops any running animation or tracking. `callback` is invoked with the\n * final value after stopping the animation, which is useful for updating\n * state to match the animation position with layout.\n */\n stopAnimation(callback) {\n this.r.stopAnimation();\n this.g.stopAnimation();\n this.b.stopAnimation();\n this.a.stopAnimation();\n callback && callback(this.__getValue());\n }\n\n /**\n * Stops any animation and resets the value to its original.\n */\n resetAnimation(callback) {\n this.r.resetAnimation();\n this.g.resetAnimation();\n this.b.resetAnimation();\n this.a.resetAnimation();\n callback && callback(this.__getValue());\n }\n __getValue() {\n if (this.nativeColor != null) {\n return this.nativeColor;\n } else {\n return \"rgba(\" + this.r.__getValue() + \", \" + this.g.__getValue() + \", \" + this.b.__getValue() + \", \" + this.a.__getValue() + \")\";\n }\n }\n __attach() {\n this.r.__addChild(this);\n this.g.__addChild(this);\n this.b.__addChild(this);\n this.a.__addChild(this);\n super.__attach();\n }\n __detach() {\n this.r.__removeChild(this);\n this.g.__removeChild(this);\n this.b.__removeChild(this);\n this.a.__removeChild(this);\n super.__detach();\n }\n __makeNative(platformConfig) {\n this.r.__makeNative(platformConfig);\n this.g.__makeNative(platformConfig);\n this.b.__makeNative(platformConfig);\n this.a.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n __getNativeConfig() {\n return {\n type: 'color',\n r: this.r.__getNativeTag(),\n g: this.g.__getNativeTag(),\n b: this.b.__getNativeTag(),\n a: this.a.__getNativeTag(),\n nativeColor: this.nativeColor\n };\n }\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport AnimatedValue from '../nodes/AnimatedValue';\nimport AnimatedValueXY from '../nodes/AnimatedValueXY';\nimport AnimatedInterpolation from '../nodes/AnimatedInterpolation';\nimport Easing from '../../../../exports/Easing';\nimport Animation from './Animation';\nimport { shouldUseNativeDriver } from '../NativeAnimatedHelper';\nimport AnimatedColor from '../nodes/AnimatedColor';\nvar _easeInOut;\nfunction easeInOut() {\n if (!_easeInOut) {\n _easeInOut = Easing.inOut(Easing.ease);\n }\n return _easeInOut;\n}\nclass TimingAnimation extends Animation {\n constructor(config) {\n var _config$easing, _config$duration, _config$delay, _config$iterations, _config$isInteraction;\n super();\n this._toValue = config.toValue;\n this._easing = (_config$easing = config.easing) !== null && _config$easing !== void 0 ? _config$easing : easeInOut();\n this._duration = (_config$duration = config.duration) !== null && _config$duration !== void 0 ? _config$duration : 500;\n this._delay = (_config$delay = config.delay) !== null && _config$delay !== void 0 ? _config$delay : 0;\n this.__iterations = (_config$iterations = config.iterations) !== null && _config$iterations !== void 0 ? _config$iterations : 1;\n this._useNativeDriver = shouldUseNativeDriver(config);\n this._platformConfig = config.platformConfig;\n this.__isInteraction = (_config$isInteraction = config.isInteraction) !== null && _config$isInteraction !== void 0 ? _config$isInteraction : !this._useNativeDriver;\n }\n __getNativeAnimationConfig() {\n var frameDuration = 1000.0 / 60.0;\n var frames = [];\n var numFrames = Math.round(this._duration / frameDuration);\n for (var frame = 0; frame < numFrames; frame++) {\n frames.push(this._easing(frame / numFrames));\n }\n frames.push(this._easing(1));\n return {\n type: 'frames',\n frames,\n toValue: this._toValue,\n iterations: this.__iterations,\n platformConfig: this._platformConfig\n };\n }\n start(fromValue, onUpdate, onEnd, previousAnimation, animatedValue) {\n this.__active = true;\n this._fromValue = fromValue;\n this._onUpdate = onUpdate;\n this.__onEnd = onEnd;\n var start = () => {\n // Animations that sometimes have 0 duration and sometimes do not\n // still need to use the native driver when duration is 0 so as to\n // not cause intermixed JS and native animations.\n if (this._duration === 0 && !this._useNativeDriver) {\n this._onUpdate(this._toValue);\n this.__debouncedOnEnd({\n finished: true\n });\n } else {\n this._startTime = Date.now();\n if (this._useNativeDriver) {\n this.__startNativeAnimation(animatedValue);\n } else {\n this._animationFrame = requestAnimationFrame(\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this.onUpdate.bind(this));\n }\n }\n };\n if (this._delay) {\n this._timeout = setTimeout(start, this._delay);\n } else {\n start();\n }\n }\n onUpdate() {\n var now = Date.now();\n if (now >= this._startTime + this._duration) {\n if (this._duration === 0) {\n this._onUpdate(this._toValue);\n } else {\n this._onUpdate(this._fromValue + this._easing(1) * (this._toValue - this._fromValue));\n }\n this.__debouncedOnEnd({\n finished: true\n });\n return;\n }\n this._onUpdate(this._fromValue + this._easing((now - this._startTime) / this._duration) * (this._toValue - this._fromValue));\n if (this.__active) {\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this._animationFrame = requestAnimationFrame(this.onUpdate.bind(this));\n }\n }\n stop() {\n super.stop();\n this.__active = false;\n clearTimeout(this._timeout);\n global.cancelAnimationFrame(this._animationFrame);\n this.__debouncedOnEnd({\n finished: false\n });\n }\n}\nexport default TimingAnimation;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport Easing from '../../vendor/react-native/Animated/Easing';\nexport default Easing;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * \n */\n\n'use strict';\n\nimport _bezier from './bezier';\nvar ease;\n\n/**\n * The `Easing` module implements common easing functions. This module is used\n * by [Animate.timing()](docs/animate.html#timing) to convey physically\n * believable motion in animations.\n *\n * You can find a visualization of some common easing functions at\n * http://easings.net/\n *\n * ### Predefined animations\n *\n * The `Easing` module provides several predefined animations through the\n * following methods:\n *\n * - [`back`](docs/easing.html#back) provides a simple animation where the\n * object goes slightly back before moving forward\n * - [`bounce`](docs/easing.html#bounce) provides a bouncing animation\n * - [`ease`](docs/easing.html#ease) provides a simple inertial animation\n * - [`elastic`](docs/easing.html#elastic) provides a simple spring interaction\n *\n * ### Standard functions\n *\n * Three standard easing functions are provided:\n *\n * - [`linear`](docs/easing.html#linear)\n * - [`quad`](docs/easing.html#quad)\n * - [`cubic`](docs/easing.html#cubic)\n *\n * The [`poly`](docs/easing.html#poly) function can be used to implement\n * quartic, quintic, and other higher power functions.\n *\n * ### Additional functions\n *\n * Additional mathematical functions are provided by the following methods:\n *\n * - [`bezier`](docs/easing.html#bezier) provides a cubic bezier curve\n * - [`circle`](docs/easing.html#circle) provides a circular function\n * - [`sin`](docs/easing.html#sin) provides a sinusoidal function\n * - [`exp`](docs/easing.html#exp) provides an exponential function\n *\n * The following helpers are used to modify other easing functions.\n *\n * - [`in`](docs/easing.html#in) runs an easing function forwards\n * - [`inOut`](docs/easing.html#inout) makes any easing function symmetrical\n * - [`out`](docs/easing.html#out) runs an easing function backwards\n */\nclass Easing {\n /**\n * A stepping function, returns 1 for any positive value of `n`.\n */\n static step0(n) {\n return n > 0 ? 1 : 0;\n }\n\n /**\n * A stepping function, returns 1 if `n` is greater than or equal to 1.\n */\n static step1(n) {\n return n >= 1 ? 1 : 0;\n }\n\n /**\n * A linear function, `f(t) = t`. Position correlates to elapsed time one to\n * one.\n *\n * http://cubic-bezier.com/#0,0,1,1\n */\n static linear(t) {\n return t;\n }\n\n /**\n * A simple inertial interaction, similar to an object slowly accelerating to\n * speed.\n *\n * http://cubic-bezier.com/#.42,0,1,1\n */\n static ease(t) {\n if (!ease) {\n ease = Easing.bezier(0.42, 0, 1, 1);\n }\n return ease(t);\n }\n\n /**\n * A quadratic function, `f(t) = t * t`. Position equals the square of elapsed\n * time.\n *\n * http://easings.net/#easeInQuad\n */\n static quad(t) {\n return t * t;\n }\n\n /**\n * A cubic function, `f(t) = t * t * t`. Position equals the cube of elapsed\n * time.\n *\n * http://easings.net/#easeInCubic\n */\n static cubic(t) {\n return t * t * t;\n }\n\n /**\n * A power function. Position is equal to the Nth power of elapsed time.\n *\n * n = 4: http://easings.net/#easeInQuart\n * n = 5: http://easings.net/#easeInQuint\n */\n static poly(n) {\n return t => Math.pow(t, n);\n }\n\n /**\n * A sinusoidal function.\n *\n * http://easings.net/#easeInSine\n */\n static sin(t) {\n return 1 - Math.cos(t * Math.PI / 2);\n }\n\n /**\n * A circular function.\n *\n * http://easings.net/#easeInCirc\n */\n static circle(t) {\n return 1 - Math.sqrt(1 - t * t);\n }\n\n /**\n * An exponential function.\n *\n * http://easings.net/#easeInExpo\n */\n static exp(t) {\n return Math.pow(2, 10 * (t - 1));\n }\n\n /**\n * A simple elastic interaction, similar to a spring oscillating back and\n * forth.\n *\n * Default bounciness is 1, which overshoots a little bit once. 0 bounciness\n * doesn't overshoot at all, and bounciness of N > 1 will overshoot about N\n * times.\n *\n * http://easings.net/#easeInElastic\n */\n static elastic(bounciness) {\n if (bounciness === void 0) {\n bounciness = 1;\n }\n var p = bounciness * Math.PI;\n return t => 1 - Math.pow(Math.cos(t * Math.PI / 2), 3) * Math.cos(t * p);\n }\n\n /**\n * Use with `Animated.parallel()` to create a simple effect where the object\n * animates back slightly as the animation starts.\n *\n * Wolfram Plot:\n *\n * - http://tiny.cc/back_default (s = 1.70158, default)\n */\n static back(s) {\n if (s === void 0) {\n s = 1.70158;\n }\n return t => t * t * ((s + 1) * t - s);\n }\n\n /**\n * Provides a simple bouncing effect.\n *\n * http://easings.net/#easeInBounce\n */\n static bounce(t) {\n if (t < 1 / 2.75) {\n return 7.5625 * t * t;\n }\n if (t < 2 / 2.75) {\n var _t = t - 1.5 / 2.75;\n return 7.5625 * _t * _t + 0.75;\n }\n if (t < 2.5 / 2.75) {\n var _t2 = t - 2.25 / 2.75;\n return 7.5625 * _t2 * _t2 + 0.9375;\n }\n var t2 = t - 2.625 / 2.75;\n return 7.5625 * t2 * t2 + 0.984375;\n }\n\n /**\n * Provides a cubic bezier curve, equivalent to CSS Transitions'\n * `transition-timing-function`.\n *\n * A useful tool to visualize cubic bezier curves can be found at\n * http://cubic-bezier.com/\n */\n static bezier(x1, y1, x2, y2) {\n return _bezier(x1, y1, x2, y2);\n }\n\n /**\n * Runs an easing function forwards.\n */\n static in(easing) {\n return easing;\n }\n\n /**\n * Runs an easing function backwards.\n */\n static out(easing) {\n return t => 1 - easing(1 - t);\n }\n\n /**\n * Makes any easing function symmetrical. The easing function will run\n * forwards for half of the duration, then backwards for the rest of the\n * duration.\n */\n static inOut(easing) {\n return t => {\n if (t < 0.5) {\n return easing(t * 2) / 2;\n }\n return 1 - easing((1 - t) * 2) / 2;\n };\n }\n}\nexport default Easing;","/**\n * Portions Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n/**\n * BezierEasing - use bezier curve for transition easing function\n * https://github.com/gre/bezier-easing\n * @copyright 2014-2015 Gaëtan Renaudeau. MIT License.\n */\n\n'use strict';\n\n// These values are established by empiricism with tests (tradeoff: performance VS precision)\nvar NEWTON_ITERATIONS = 4;\nvar NEWTON_MIN_SLOPE = 0.001;\nvar SUBDIVISION_PRECISION = 0.0000001;\nvar SUBDIVISION_MAX_ITERATIONS = 10;\nvar kSplineTableSize = 11;\nvar kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\nvar float32ArraySupported = typeof Float32Array === 'function';\nfunction A(aA1, aA2) {\n return 1.0 - 3.0 * aA2 + 3.0 * aA1;\n}\nfunction B(aA1, aA2) {\n return 3.0 * aA2 - 6.0 * aA1;\n}\nfunction C(aA1) {\n return 3.0 * aA1;\n}\n\n// Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.\nfunction calcBezier(aT, aA1, aA2) {\n return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT;\n}\n\n// Returns dx/dt given t, x1, and x2, or dy/dt given t, y1, and y2.\nfunction getSlope(aT, aA1, aA2) {\n return 3.0 * A(aA1, aA2) * aT * aT + 2.0 * B(aA1, aA2) * aT + C(aA1);\n}\nfunction binarySubdivide(aX, _aA, _aB, mX1, mX2) {\n var currentX,\n currentT,\n i = 0,\n aA = _aA,\n aB = _aB;\n do {\n currentT = aA + (aB - aA) / 2.0;\n currentX = calcBezier(currentT, mX1, mX2) - aX;\n if (currentX > 0.0) {\n aB = currentT;\n } else {\n aA = currentT;\n }\n } while (Math.abs(currentX) > SUBDIVISION_PRECISION && ++i < SUBDIVISION_MAX_ITERATIONS);\n return currentT;\n}\nfunction newtonRaphsonIterate(aX, _aGuessT, mX1, mX2) {\n var aGuessT = _aGuessT;\n for (var i = 0; i < NEWTON_ITERATIONS; ++i) {\n var currentSlope = getSlope(aGuessT, mX1, mX2);\n if (currentSlope === 0.0) {\n return aGuessT;\n }\n var currentX = calcBezier(aGuessT, mX1, mX2) - aX;\n aGuessT -= currentX / currentSlope;\n }\n return aGuessT;\n}\nexport default function bezier(mX1, mY1, mX2, mY2) {\n if (!(mX1 >= 0 && mX1 <= 1 && mX2 >= 0 && mX2 <= 1)) {\n throw new Error('bezier x values must be in [0, 1] range');\n }\n\n // Precompute samples table\n var sampleValues = float32ArraySupported ? new Float32Array(kSplineTableSize) : new Array(kSplineTableSize);\n if (mX1 !== mY1 || mX2 !== mY2) {\n for (var i = 0; i < kSplineTableSize; ++i) {\n sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n }\n }\n function getTForX(aX) {\n var intervalStart = 0.0;\n var currentSample = 1;\n var lastSample = kSplineTableSize - 1;\n for (; currentSample !== lastSample && sampleValues[currentSample] <= aX; ++currentSample) {\n intervalStart += kSampleStepSize;\n }\n --currentSample;\n\n // Interpolate to provide an initial guess for t\n var dist = (aX - sampleValues[currentSample]) / (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n var guessForT = intervalStart + dist * kSampleStepSize;\n var initialSlope = getSlope(guessForT, mX1, mX2);\n if (initialSlope >= NEWTON_MIN_SLOPE) {\n return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n } else if (initialSlope === 0.0) {\n return guessForT;\n } else {\n return binarySubdivide(aX, intervalStart, intervalStart + kSampleStepSize, mX1, mX2);\n }\n }\n return function BezierEasing(x) {\n if (mX1 === mY1 && mX2 === mY2) {\n return x; // linear\n }\n // Because JavaScript number are imprecise, we should guarantee the extremes are right.\n if (x === 0) {\n return 0;\n }\n if (x === 1) {\n return 1;\n }\n return calcBezier(getTForX(x), mY1, mY2);\n };\n}\n;","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from 'react';\nimport { View } from 'react-native';\nexport default /*#__PURE__*/React.forwardRef((props, ref) => /*#__PURE__*/React.createElement(View, _extends({\n ref: ref,\n accessibilityRole: \"button\"\n}, props)));\n//# sourceMappingURL=GestureHandlerButton.web.js.map","export { default as TouchableNativeFeedback } from './TouchableNativeFeedback';\nexport { default as TouchableWithoutFeedback } from './TouchableWithoutFeedback';\nexport { default as TouchableOpacity } from './TouchableOpacity';\nexport { default as TouchableHighlight } from './TouchableHighlight';\n//# sourceMappingURL=index.js.map","import { TouchableNativeFeedback } from 'react-native';\nexport default TouchableNativeFeedback;\n//# sourceMappingURL=TouchableNativeFeedback.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport UnimplementedView from '../../modules/UnimplementedView';\nexport default UnimplementedView;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport View from '../../exports/View';\nimport React from 'react';\n\n/**\n * Common implementation for a simple stubbed view.\n */\nclass UnimplementedView extends React.Component {\n render() {\n return /*#__PURE__*/React.createElement(View, {\n style: [unimplementedViewStyles, this.props.style]\n }, this.props.children);\n }\n}\nvar unimplementedViewStyles = process.env.NODE_ENV !== 'production' ? {\n alignSelf: 'flex-start',\n borderColor: 'red',\n borderWidth: 1\n} : {};\nexport default UnimplementedView;","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from 'react';\nimport GenericTouchable from './GenericTouchable';\nconst TouchableWithoutFeedback = /*#__PURE__*/React.forwardRef((props, ref) => /*#__PURE__*/React.createElement(GenericTouchable, _extends({\n ref: ref\n}, props)));\nTouchableWithoutFeedback.defaultProps = GenericTouchable.defaultProps;\nexport default TouchableWithoutFeedback;\n//# sourceMappingURL=TouchableWithoutFeedback.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport * as React from 'react';\nimport { Component } from 'react';\nimport { Animated, Platform } from 'react-native';\nimport { State } from '../../State';\nimport { BaseButton } from '../GestureButtons';\n\n/**\n * Each touchable is a states' machine which preforms transitions.\n * On very beginning (and on the very end or recognition) touchable is\n * UNDETERMINED. Then it moves to BEGAN. If touchable recognizes that finger\n * travel outside it transits to special MOVED_OUTSIDE state. Gesture recognition\n * finishes in UNDETERMINED state.\n */\nexport const TOUCHABLE_STATE = {\n UNDETERMINED: 0,\n BEGAN: 1,\n MOVED_OUTSIDE: 2\n};\n\n/**\n * GenericTouchable is not intented to be used as it is.\n * Should be treated as a source for the rest of touchables\n */\nexport default class GenericTouchable extends Component {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"pressInTimeout\", void 0);\n\n _defineProperty(this, \"pressOutTimeout\", void 0);\n\n _defineProperty(this, \"longPressTimeout\", void 0);\n\n _defineProperty(this, \"longPressDetected\", false);\n\n _defineProperty(this, \"pointerInside\", true);\n\n _defineProperty(this, \"STATE\", TOUCHABLE_STATE.UNDETERMINED);\n\n _defineProperty(this, \"onGestureEvent\", ({\n nativeEvent: {\n pointerInside\n }\n }) => {\n if (this.pointerInside !== pointerInside) {\n if (pointerInside) {\n this.onMoveIn();\n } else {\n this.onMoveOut();\n }\n }\n\n this.pointerInside = pointerInside;\n });\n\n _defineProperty(this, \"onHandlerStateChange\", ({\n nativeEvent\n }) => {\n const {\n state\n } = nativeEvent;\n\n if (state === State.CANCELLED || state === State.FAILED) {\n // Need to handle case with external cancellation (e.g. by ScrollView)\n this.moveToState(TOUCHABLE_STATE.UNDETERMINED);\n } else if ( // This platform check is an implication of slightly different behavior of handlers on different platform.\n // And Android \"Active\" state is achieving on first move of a finger, not on press in.\n // On iOS event on \"Began\" is not delivered.\n state === (Platform.OS !== 'android' ? State.ACTIVE : State.BEGAN) && this.STATE === TOUCHABLE_STATE.UNDETERMINED) {\n // Moving inside requires\n this.handlePressIn();\n } else if (state === State.END) {\n const shouldCallOnPress = !this.longPressDetected && this.STATE !== TOUCHABLE_STATE.MOVED_OUTSIDE && this.pressOutTimeout === null;\n this.handleGoToUndetermined();\n\n if (shouldCallOnPress) {\n var _this$props$onPress, _this$props;\n\n // Calls only inside component whether no long press was called previously\n (_this$props$onPress = (_this$props = this.props).onPress) === null || _this$props$onPress === void 0 ? void 0 : _this$props$onPress.call(_this$props);\n }\n }\n });\n\n _defineProperty(this, \"onLongPressDetected\", () => {\n var _this$props$onLongPre, _this$props2;\n\n this.longPressDetected = true; // checked for in the caller of `onLongPressDetected`, but better to check twice\n\n (_this$props$onLongPre = (_this$props2 = this.props).onLongPress) === null || _this$props$onLongPre === void 0 ? void 0 : _this$props$onLongPre.call(_this$props2);\n });\n }\n\n // handlePressIn in called on first touch on traveling inside component.\n // Handles state transition with delay.\n handlePressIn() {\n if (this.props.delayPressIn) {\n this.pressInTimeout = setTimeout(() => {\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n this.pressInTimeout = null;\n }, this.props.delayPressIn);\n } else {\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n }\n\n if (this.props.onLongPress) {\n const time = (this.props.delayPressIn || 0) + (this.props.delayLongPress || 0);\n this.longPressTimeout = setTimeout(this.onLongPressDetected, time);\n }\n } // handleMoveOutside in called on traveling outside component.\n // Handles state transition with delay.\n\n\n handleMoveOutside() {\n if (this.props.delayPressOut) {\n this.pressOutTimeout = this.pressOutTimeout || setTimeout(() => {\n this.moveToState(TOUCHABLE_STATE.MOVED_OUTSIDE);\n this.pressOutTimeout = null;\n }, this.props.delayPressOut);\n } else {\n this.moveToState(TOUCHABLE_STATE.MOVED_OUTSIDE);\n }\n } // handleGoToUndetermined transits to UNDETERMINED state with proper delay\n\n\n handleGoToUndetermined() {\n clearTimeout(this.pressOutTimeout); // TODO: maybe it can be undefined\n\n if (this.props.delayPressOut) {\n this.pressOutTimeout = setTimeout(() => {\n if (this.STATE === TOUCHABLE_STATE.UNDETERMINED) {\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n }\n\n this.moveToState(TOUCHABLE_STATE.UNDETERMINED);\n this.pressOutTimeout = null;\n }, this.props.delayPressOut);\n } else {\n if (this.STATE === TOUCHABLE_STATE.UNDETERMINED) {\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n }\n\n this.moveToState(TOUCHABLE_STATE.UNDETERMINED);\n }\n }\n\n componentDidMount() {\n this.reset();\n } // reset timeout to prevent memory leaks.\n\n\n reset() {\n this.longPressDetected = false;\n this.pointerInside = true;\n clearTimeout(this.pressInTimeout);\n clearTimeout(this.pressOutTimeout);\n clearTimeout(this.longPressTimeout);\n this.pressOutTimeout = null;\n this.longPressTimeout = null;\n this.pressInTimeout = null;\n } // All states' transitions are defined here.\n\n\n moveToState(newState) {\n var _this$props$onStateCh, _this$props6;\n\n if (newState === this.STATE) {\n // Ignore dummy transitions\n return;\n }\n\n if (newState === TOUCHABLE_STATE.BEGAN) {\n var _this$props$onPressIn, _this$props3;\n\n // First touch and moving inside\n (_this$props$onPressIn = (_this$props3 = this.props).onPressIn) === null || _this$props$onPressIn === void 0 ? void 0 : _this$props$onPressIn.call(_this$props3);\n } else if (newState === TOUCHABLE_STATE.MOVED_OUTSIDE) {\n var _this$props$onPressOu, _this$props4;\n\n // Moving outside\n (_this$props$onPressOu = (_this$props4 = this.props).onPressOut) === null || _this$props$onPressOu === void 0 ? void 0 : _this$props$onPressOu.call(_this$props4);\n } else if (newState === TOUCHABLE_STATE.UNDETERMINED) {\n // Need to reset each time on transition to UNDETERMINED\n this.reset();\n\n if (this.STATE === TOUCHABLE_STATE.BEGAN) {\n var _this$props$onPressOu2, _this$props5;\n\n // ... and if it happens inside button.\n (_this$props$onPressOu2 = (_this$props5 = this.props).onPressOut) === null || _this$props$onPressOu2 === void 0 ? void 0 : _this$props$onPressOu2.call(_this$props5);\n }\n } // Finally call lister (used by subclasses)\n\n\n (_this$props$onStateCh = (_this$props6 = this.props).onStateChange) === null || _this$props$onStateCh === void 0 ? void 0 : _this$props$onStateCh.call(_this$props6, this.STATE, newState); // ... and make transition.\n\n this.STATE = newState;\n }\n\n componentWillUnmount() {\n // to prevent memory leaks\n this.reset();\n }\n\n onMoveIn() {\n if (this.STATE === TOUCHABLE_STATE.MOVED_OUTSIDE) {\n // This call is not throttled with delays (like in RN's implementation).\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n }\n }\n\n onMoveOut() {\n // long press should no longer be detected\n clearTimeout(this.longPressTimeout);\n this.longPressTimeout = null;\n\n if (this.STATE === TOUCHABLE_STATE.BEGAN) {\n this.handleMoveOutside();\n }\n }\n\n render() {\n var _ref, _this$props$touchSoun;\n\n const hitSlop = (_ref = typeof this.props.hitSlop === 'number' ? {\n top: this.props.hitSlop,\n left: this.props.hitSlop,\n bottom: this.props.hitSlop,\n right: this.props.hitSlop\n } : this.props.hitSlop) !== null && _ref !== void 0 ? _ref : undefined;\n const coreProps = {\n accessible: this.props.accessible !== false,\n accessibilityLabel: this.props.accessibilityLabel,\n accessibilityHint: this.props.accessibilityHint,\n accessibilityRole: this.props.accessibilityRole,\n // TODO: check if changed to no 's' correctly, also removed 2 props that are no longer available: `accessibilityComponentType` and `accessibilityTraits`,\n // would be good to check if it is ok for sure, see: https://github.com/facebook/react-native/issues/24016\n accessibilityState: this.props.accessibilityState,\n accessibilityActions: this.props.accessibilityActions,\n onAccessibilityAction: this.props.onAccessibilityAction,\n nativeID: this.props.nativeID,\n onLayout: this.props.onLayout\n };\n return /*#__PURE__*/React.createElement(BaseButton, _extends({\n style: this.props.containerStyle,\n onHandlerStateChange: // TODO: not sure if it can be undefined instead of null\n this.props.disabled ? undefined : this.onHandlerStateChange,\n onGestureEvent: this.onGestureEvent,\n hitSlop: hitSlop,\n userSelect: this.props.userSelect,\n shouldActivateOnStart: this.props.shouldActivateOnStart,\n disallowInterruption: this.props.disallowInterruption,\n testID: this.props.testID,\n touchSoundDisabled: (_this$props$touchSoun = this.props.touchSoundDisabled) !== null && _this$props$touchSoun !== void 0 ? _this$props$touchSoun : false,\n enabled: !this.props.disabled\n }, this.props.extraButtonProps), /*#__PURE__*/React.createElement(Animated.View, _extends({}, coreProps, {\n style: this.props.style\n }), this.props.children));\n }\n\n}\n\n_defineProperty(GenericTouchable, \"defaultProps\", {\n delayLongPress: 600,\n extraButtonProps: {\n rippleColor: 'transparent',\n exclusive: true\n }\n});\n//# sourceMappingURL=GenericTouchable.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { Animated, Easing, StyleSheet, View } from 'react-native';\nimport GenericTouchable, { TOUCHABLE_STATE } from './GenericTouchable';\nimport * as React from 'react';\nimport { Component } from 'react';\n\n/**\n * TouchableOpacity bases on timing animation which has been used in RN's core\n */\nexport default class TouchableOpacity extends Component {\n constructor(...args) {\n super(...args);\n\n _defineProperty(this, \"getChildStyleOpacityWithDefault\", () => {\n const childStyle = StyleSheet.flatten(this.props.style) || {};\n return childStyle.opacity == null ? 1 : childStyle.opacity.valueOf();\n });\n\n _defineProperty(this, \"opacity\", new Animated.Value(this.getChildStyleOpacityWithDefault()));\n\n _defineProperty(this, \"setOpacityTo\", (value, duration) => {\n var _this$props$useNative;\n\n Animated.timing(this.opacity, {\n toValue: value,\n duration: duration,\n easing: Easing.inOut(Easing.quad),\n useNativeDriver: (_this$props$useNative = this.props.useNativeAnimations) !== null && _this$props$useNative !== void 0 ? _this$props$useNative : true\n }).start();\n });\n\n _defineProperty(this, \"onStateChange\", (_from, to) => {\n if (to === TOUCHABLE_STATE.BEGAN) {\n this.setOpacityTo(this.props.activeOpacity, 0);\n } else if (to === TOUCHABLE_STATE.UNDETERMINED || to === TOUCHABLE_STATE.MOVED_OUTSIDE) {\n this.setOpacityTo(this.getChildStyleOpacityWithDefault(), 150);\n }\n });\n }\n\n render() {\n const {\n style = {},\n ...rest\n } = this.props;\n return /*#__PURE__*/React.createElement(GenericTouchable, _extends({}, rest, {\n style: [style, {\n opacity: this.opacity // TODO: fix this\n\n }],\n onStateChange: this.onStateChange\n }), this.props.children ? this.props.children : /*#__PURE__*/React.createElement(View, null));\n }\n\n}\n\n_defineProperty(TouchableOpacity, \"defaultProps\", { ...GenericTouchable.defaultProps,\n activeOpacity: 0.2\n});\n//# sourceMappingURL=TouchableOpacity.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport * as React from 'react';\nimport { Component } from 'react';\nimport GenericTouchable, { TOUCHABLE_STATE } from './GenericTouchable';\nimport { StyleSheet, View } from 'react-native';\n\n/**\n * TouchableHighlight follows RN's implementation\n */\nexport default class TouchableHighlight extends Component {\n constructor(props) {\n super(props);\n\n _defineProperty(this, \"showUnderlay\", () => {\n var _this$props$onShowUnd, _this$props;\n\n if (!this.hasPressHandler()) {\n return;\n }\n\n this.setState({\n extraChildStyle: {\n opacity: this.props.activeOpacity\n },\n extraUnderlayStyle: {\n backgroundColor: this.props.underlayColor\n }\n });\n (_this$props$onShowUnd = (_this$props = this.props).onShowUnderlay) === null || _this$props$onShowUnd === void 0 ? void 0 : _this$props$onShowUnd.call(_this$props);\n });\n\n _defineProperty(this, \"hasPressHandler\", () => this.props.onPress || this.props.onPressIn || this.props.onPressOut || this.props.onLongPress);\n\n _defineProperty(this, \"hideUnderlay\", () => {\n var _this$props$onHideUnd, _this$props2;\n\n this.setState({\n extraChildStyle: null,\n extraUnderlayStyle: null\n });\n (_this$props$onHideUnd = (_this$props2 = this.props).onHideUnderlay) === null || _this$props$onHideUnd === void 0 ? void 0 : _this$props$onHideUnd.call(_this$props2);\n });\n\n _defineProperty(this, \"onStateChange\", (_from, to) => {\n if (to === TOUCHABLE_STATE.BEGAN) {\n this.showUnderlay();\n } else if (to === TOUCHABLE_STATE.UNDETERMINED || to === TOUCHABLE_STATE.MOVED_OUTSIDE) {\n this.hideUnderlay();\n }\n });\n\n this.state = {\n extraChildStyle: null,\n extraUnderlayStyle: null\n };\n } // Copied from RN\n\n\n renderChildren() {\n if (!this.props.children) {\n return /*#__PURE__*/React.createElement(View, null);\n }\n\n const child = React.Children.only(this.props.children); // TODO: not sure if OK but fixes error\n\n return /*#__PURE__*/React.cloneElement(child, {\n style: StyleSheet.compose(child.props.style, this.state.extraChildStyle)\n });\n }\n\n render() {\n const {\n style = {},\n ...rest\n } = this.props;\n const {\n extraUnderlayStyle\n } = this.state;\n return /*#__PURE__*/React.createElement(GenericTouchable, _extends({}, rest, {\n style: [style, extraUnderlayStyle],\n onStateChange: this.onStateChange\n }), this.renderChildren());\n }\n\n}\n\n_defineProperty(TouchableHighlight, \"defaultProps\", { ...GenericTouchable.defaultProps,\n activeOpacity: 0.85,\n delayPressOut: 100,\n underlayColor: 'black'\n});\n//# sourceMappingURL=TouchableHighlight.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport * as React from 'react';\nimport { FlatList as RNFlatList, Switch as RNSwitch, TextInput as RNTextInput, ScrollView as RNScrollView, View } from 'react-native';\nimport createNativeWrapper from '../handlers/createNativeWrapper';\nexport const ScrollView = createNativeWrapper(RNScrollView, {\n disallowInterruption: false\n});\nexport const Switch = createNativeWrapper(RNSwitch, {\n shouldCancelWhenOutside: false,\n shouldActivateOnStart: true,\n disallowInterruption: true\n});\nexport const TextInput = createNativeWrapper(RNTextInput);\nexport const DrawerLayoutAndroid = () => {\n console.warn('DrawerLayoutAndroid is not supported on web!');\n return /*#__PURE__*/React.createElement(View, null);\n}; // RefreshControl is implemented as a functional component, rendering a View\n// NativeViewGestureHandler needs to set a ref on its child, which cannot be done\n// on functional components\n\nexport const RefreshControl = createNativeWrapper(View);\nexport const FlatList = /*#__PURE__*/React.forwardRef((props, ref) => /*#__PURE__*/React.createElement(RNFlatList, _extends({\n ref: ref\n}, props, {\n renderScrollComponent: scrollProps => /*#__PURE__*/React.createElement(ScrollView, scrollProps)\n})));\n//# sourceMappingURL=GestureComponents.web.js.map","import _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"aria-label\", \"accessibilityLabel\", \"activeThumbColor\", \"activeTrackColor\", \"disabled\", \"onValueChange\", \"style\", \"thumbColor\", \"trackColor\", \"value\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport createElement from '../createElement';\nimport multiplyStyleLengthValue from '../../modules/multiplyStyleLengthValue';\nimport StyleSheet from '../StyleSheet';\nimport View from '../View';\nvar emptyObject = {};\nvar thumbDefaultBoxShadow = '0px 1px 3px rgba(0,0,0,0.5)';\nvar thumbFocusedBoxShadow = thumbDefaultBoxShadow + \", 0 0 0 10px rgba(0,0,0,0.1)\";\nvar defaultActiveTrackColor = '#A3D3CF';\nvar defaultTrackColor = '#939393';\nvar defaultDisabledTrackColor = '#D5D5D5';\nvar defaultActiveThumbColor = '#009688';\nvar defaultThumbColor = '#FAFAFA';\nvar defaultDisabledThumbColor = '#BDBDBD';\nvar Switch = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var ariaLabel = props['aria-label'],\n accessibilityLabel = props.accessibilityLabel,\n activeThumbColor = props.activeThumbColor,\n activeTrackColor = props.activeTrackColor,\n _props$disabled = props.disabled,\n disabled = _props$disabled === void 0 ? false : _props$disabled,\n onValueChange = props.onValueChange,\n _props$style = props.style,\n style = _props$style === void 0 ? emptyObject : _props$style,\n thumbColor = props.thumbColor,\n trackColor = props.trackColor,\n _props$value = props.value,\n value = _props$value === void 0 ? false : _props$value,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n var thumbRef = React.useRef(null);\n function handleChange(event) {\n if (onValueChange != null) {\n onValueChange(event.nativeEvent.target.checked);\n }\n }\n function handleFocusState(event) {\n var isFocused = event.nativeEvent.type === 'focus';\n var boxShadow = isFocused ? thumbFocusedBoxShadow : thumbDefaultBoxShadow;\n if (thumbRef.current != null) {\n thumbRef.current.style.boxShadow = boxShadow;\n }\n }\n var _StyleSheet$flatten = StyleSheet.flatten(style),\n styleHeight = _StyleSheet$flatten.height,\n styleWidth = _StyleSheet$flatten.width;\n var height = styleHeight || '20px';\n var minWidth = multiplyStyleLengthValue(height, 2);\n var width = styleWidth > minWidth ? styleWidth : minWidth;\n var trackBorderRadius = multiplyStyleLengthValue(height, 0.5);\n var trackCurrentColor = function () {\n if (value === true) {\n if (trackColor != null && typeof trackColor === 'object') {\n return trackColor.true;\n } else {\n return activeTrackColor !== null && activeTrackColor !== void 0 ? activeTrackColor : defaultActiveTrackColor;\n }\n } else {\n if (trackColor != null && typeof trackColor === 'object') {\n return trackColor.false;\n } else {\n return trackColor !== null && trackColor !== void 0 ? trackColor : defaultTrackColor;\n }\n }\n }();\n var thumbCurrentColor = value ? activeThumbColor !== null && activeThumbColor !== void 0 ? activeThumbColor : defaultActiveThumbColor : thumbColor !== null && thumbColor !== void 0 ? thumbColor : defaultThumbColor;\n var thumbHeight = height;\n var thumbWidth = thumbHeight;\n var rootStyle = [styles.root, style, disabled && styles.cursorDefault, {\n height,\n width\n }];\n var disabledTrackColor = function () {\n if (value === true) {\n if (typeof activeTrackColor === 'string' && activeTrackColor != null || typeof trackColor === 'object' && trackColor != null && trackColor.true) {\n return trackCurrentColor;\n } else {\n return defaultDisabledTrackColor;\n }\n } else {\n if (typeof trackColor === 'string' && trackColor != null || typeof trackColor === 'object' && trackColor != null && trackColor.false) {\n return trackCurrentColor;\n } else {\n return defaultDisabledTrackColor;\n }\n }\n }();\n var disabledThumbColor = function () {\n if (value === true) {\n if (activeThumbColor == null) {\n return defaultDisabledThumbColor;\n } else {\n return thumbCurrentColor;\n }\n } else {\n if (thumbColor == null) {\n return defaultDisabledThumbColor;\n } else {\n return thumbCurrentColor;\n }\n }\n }();\n var trackStyle = [styles.track, {\n backgroundColor: disabled ? disabledTrackColor : trackCurrentColor,\n borderRadius: trackBorderRadius\n }];\n var thumbStyle = [styles.thumb, value && styles.thumbActive, {\n backgroundColor: disabled ? disabledThumbColor : thumbCurrentColor,\n height: thumbHeight,\n marginStart: value ? multiplyStyleLengthValue(thumbWidth, -1) : 0,\n width: thumbWidth\n }];\n var nativeControl = createElement('input', {\n 'aria-label': ariaLabel || accessibilityLabel,\n checked: value,\n disabled: disabled,\n onBlur: handleFocusState,\n onChange: handleChange,\n onFocus: handleFocusState,\n ref: forwardedRef,\n style: [styles.nativeControl, styles.cursorInherit],\n type: 'checkbox',\n role: 'switch'\n });\n return /*#__PURE__*/React.createElement(View, _extends({}, other, {\n style: rootStyle\n }), /*#__PURE__*/React.createElement(View, {\n style: trackStyle\n }), /*#__PURE__*/React.createElement(View, {\n ref: thumbRef,\n style: thumbStyle\n }), nativeControl);\n});\nSwitch.displayName = 'Switch';\nvar styles = StyleSheet.create({\n root: {\n cursor: 'pointer',\n userSelect: 'none'\n },\n cursorDefault: {\n cursor: 'default'\n },\n cursorInherit: {\n cursor: 'inherit'\n },\n track: _objectSpread(_objectSpread({\n forcedColorAdjust: 'none'\n }, StyleSheet.absoluteFillObject), {}, {\n height: '70%',\n margin: 'auto',\n transitionDuration: '0.1s',\n width: '100%'\n }),\n thumb: {\n forcedColorAdjust: 'none',\n alignSelf: 'flex-start',\n borderRadius: '100%',\n boxShadow: thumbDefaultBoxShadow,\n start: '0%',\n transform: 'translateZ(0)',\n transitionDuration: '0.1s'\n },\n thumbActive: {\n insetInlineStart: '100%'\n },\n nativeControl: _objectSpread(_objectSpread({}, StyleSheet.absoluteFillObject), {}, {\n height: '100%',\n margin: 0,\n appearance: 'none',\n padding: 0,\n width: '100%'\n })\n});\nexport default Switch;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar CSS_UNIT_RE = /^[+-]?\\d*(?:\\.\\d+)?(?:[Ee][+-]?\\d+)?(%|\\w*)/;\nvar getUnit = str => str.match(CSS_UNIT_RE)[1];\nvar isNumeric = n => {\n return !isNaN(parseFloat(n)) && isFinite(n);\n};\nvar multiplyStyleLengthValue = (value, multiple) => {\n if (typeof value === 'string') {\n var number = parseFloat(value) * multiple;\n var unit = getUnit(value);\n return \"\" + number + unit;\n } else if (isNumeric(value)) {\n return value * multiple;\n }\n};\nexport default multiplyStyleLengthValue;","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// Similarily to the DrawerLayout component this deserves to be put in a\n// separate repo. Although, keeping it here for the time being will allow us to\n// move faster and fix possible issues quicker\nimport * as React from 'react';\nimport { Component } from 'react';\nimport { Animated, StyleSheet, View, I18nManager } from 'react-native';\nimport { PanGestureHandler } from '../handlers/PanGestureHandler';\nimport { TapGestureHandler } from '../handlers/TapGestureHandler';\nimport { State } from '../State';\nconst DRAG_TOSS = 0.05;\nexport default class Swipeable extends Component {\n constructor(_props) {\n super(_props);\n\n _defineProperty(this, \"onGestureEvent\", void 0);\n\n _defineProperty(this, \"transX\", void 0);\n\n _defineProperty(this, \"showLeftAction\", void 0);\n\n _defineProperty(this, \"leftActionTranslate\", void 0);\n\n _defineProperty(this, \"showRightAction\", void 0);\n\n _defineProperty(this, \"rightActionTranslate\", void 0);\n\n _defineProperty(this, \"updateAnimatedEvent\", (props, state) => {\n const {\n friction,\n overshootFriction\n } = props;\n const {\n dragX,\n rowTranslation,\n leftWidth = 0,\n rowWidth = 0\n } = state;\n const {\n rightOffset = rowWidth\n } = state;\n const rightWidth = Math.max(0, rowWidth - rightOffset);\n const {\n overshootLeft = leftWidth > 0,\n overshootRight = rightWidth > 0\n } = props;\n const transX = Animated.add(rowTranslation, dragX.interpolate({\n inputRange: [0, friction],\n outputRange: [0, 1]\n })).interpolate({\n inputRange: [-rightWidth - 1, -rightWidth, leftWidth, leftWidth + 1],\n outputRange: [-rightWidth - (overshootRight ? 1 / overshootFriction : 0), -rightWidth, leftWidth, leftWidth + (overshootLeft ? 1 / overshootFriction : 0)]\n });\n this.transX = transX;\n this.showLeftAction = leftWidth > 0 ? transX.interpolate({\n inputRange: [-1, 0, leftWidth],\n outputRange: [0, 0, 1]\n }) : new Animated.Value(0);\n this.leftActionTranslate = this.showLeftAction.interpolate({\n inputRange: [0, Number.MIN_VALUE],\n outputRange: [-10000, 0],\n extrapolate: 'clamp'\n });\n this.showRightAction = rightWidth > 0 ? transX.interpolate({\n inputRange: [-rightWidth, 0, 1],\n outputRange: [1, 0, 0]\n }) : new Animated.Value(0);\n this.rightActionTranslate = this.showRightAction.interpolate({\n inputRange: [0, Number.MIN_VALUE],\n outputRange: [-10000, 0],\n extrapolate: 'clamp'\n });\n });\n\n _defineProperty(this, \"onTapHandlerStateChange\", ({\n nativeEvent\n }) => {\n if (nativeEvent.oldState === State.ACTIVE) {\n this.close();\n }\n });\n\n _defineProperty(this, \"onHandlerStateChange\", ev => {\n if (ev.nativeEvent.oldState === State.ACTIVE) {\n this.handleRelease(ev);\n }\n\n if (ev.nativeEvent.state === State.ACTIVE) {\n const {\n velocityX,\n translationX: dragX\n } = ev.nativeEvent;\n const {\n rowState\n } = this.state;\n const {\n friction\n } = this.props;\n const translationX = (dragX + DRAG_TOSS * velocityX) / friction;\n const direction = rowState === -1 ? 'right' : rowState === 1 ? 'left' : translationX > 0 ? 'left' : 'right';\n\n if (rowState === 0) {\n var _this$props$onSwipeab, _this$props;\n\n (_this$props$onSwipeab = (_this$props = this.props).onSwipeableOpenStartDrag) === null || _this$props$onSwipeab === void 0 ? void 0 : _this$props$onSwipeab.call(_this$props, direction);\n } else {\n var _this$props$onSwipeab2, _this$props2;\n\n (_this$props$onSwipeab2 = (_this$props2 = this.props).onSwipeableCloseStartDrag) === null || _this$props$onSwipeab2 === void 0 ? void 0 : _this$props$onSwipeab2.call(_this$props2, direction);\n }\n }\n });\n\n _defineProperty(this, \"handleRelease\", ev => {\n const {\n velocityX,\n translationX: dragX\n } = ev.nativeEvent;\n const {\n leftWidth = 0,\n rowWidth = 0,\n rowState\n } = this.state;\n const {\n rightOffset = rowWidth\n } = this.state;\n const rightWidth = rowWidth - rightOffset;\n const {\n friction,\n leftThreshold = leftWidth / 2,\n rightThreshold = rightWidth / 2\n } = this.props;\n const startOffsetX = this.currentOffset() + dragX / friction;\n const translationX = (dragX + DRAG_TOSS * velocityX) / friction;\n let toValue = 0;\n\n if (rowState === 0) {\n if (translationX > leftThreshold) {\n toValue = leftWidth;\n } else if (translationX < -rightThreshold) {\n toValue = -rightWidth;\n }\n } else if (rowState === 1) {\n // swiped to left\n if (translationX > -leftThreshold) {\n toValue = leftWidth;\n }\n } else {\n // swiped to right\n if (translationX < rightThreshold) {\n toValue = -rightWidth;\n }\n }\n\n this.animateRow(startOffsetX, toValue, velocityX / friction);\n });\n\n _defineProperty(this, \"animateRow\", (fromValue, toValue, velocityX) => {\n const {\n dragX,\n rowTranslation\n } = this.state;\n dragX.setValue(0);\n rowTranslation.setValue(fromValue);\n this.setState({\n rowState: Math.sign(toValue)\n });\n Animated.spring(rowTranslation, {\n restSpeedThreshold: 1.7,\n restDisplacementThreshold: 0.4,\n velocity: velocityX,\n bounciness: 0,\n toValue,\n useNativeDriver: this.props.useNativeAnimations,\n ...this.props.animationOptions\n }).start(({\n finished\n }) => {\n if (finished) {\n if (toValue > 0) {\n var _this$props$onSwipeab3, _this$props3, _this$props$onSwipeab4, _this$props4;\n\n (_this$props$onSwipeab3 = (_this$props3 = this.props).onSwipeableLeftOpen) === null || _this$props$onSwipeab3 === void 0 ? void 0 : _this$props$onSwipeab3.call(_this$props3);\n (_this$props$onSwipeab4 = (_this$props4 = this.props).onSwipeableOpen) === null || _this$props$onSwipeab4 === void 0 ? void 0 : _this$props$onSwipeab4.call(_this$props4, 'left', this);\n } else if (toValue < 0) {\n var _this$props$onSwipeab5, _this$props5, _this$props$onSwipeab6, _this$props6;\n\n (_this$props$onSwipeab5 = (_this$props5 = this.props).onSwipeableRightOpen) === null || _this$props$onSwipeab5 === void 0 ? void 0 : _this$props$onSwipeab5.call(_this$props5);\n (_this$props$onSwipeab6 = (_this$props6 = this.props).onSwipeableOpen) === null || _this$props$onSwipeab6 === void 0 ? void 0 : _this$props$onSwipeab6.call(_this$props6, 'right', this);\n } else {\n var _this$props$onSwipeab7, _this$props7;\n\n const closingDirection = fromValue > 0 ? 'left' : 'right';\n (_this$props$onSwipeab7 = (_this$props7 = this.props).onSwipeableClose) === null || _this$props$onSwipeab7 === void 0 ? void 0 : _this$props$onSwipeab7.call(_this$props7, closingDirection, this);\n }\n }\n });\n\n if (toValue > 0) {\n var _this$props$onSwipeab8, _this$props8, _this$props$onSwipeab9, _this$props9;\n\n (_this$props$onSwipeab8 = (_this$props8 = this.props).onSwipeableLeftWillOpen) === null || _this$props$onSwipeab8 === void 0 ? void 0 : _this$props$onSwipeab8.call(_this$props8);\n (_this$props$onSwipeab9 = (_this$props9 = this.props).onSwipeableWillOpen) === null || _this$props$onSwipeab9 === void 0 ? void 0 : _this$props$onSwipeab9.call(_this$props9, 'left');\n } else if (toValue < 0) {\n var _this$props$onSwipeab10, _this$props10, _this$props$onSwipeab11, _this$props11;\n\n (_this$props$onSwipeab10 = (_this$props10 = this.props).onSwipeableRightWillOpen) === null || _this$props$onSwipeab10 === void 0 ? void 0 : _this$props$onSwipeab10.call(_this$props10);\n (_this$props$onSwipeab11 = (_this$props11 = this.props).onSwipeableWillOpen) === null || _this$props$onSwipeab11 === void 0 ? void 0 : _this$props$onSwipeab11.call(_this$props11, 'right');\n } else {\n var _this$props$onSwipeab12, _this$props12;\n\n const closingDirection = fromValue > 0 ? 'left' : 'right';\n (_this$props$onSwipeab12 = (_this$props12 = this.props).onSwipeableWillClose) === null || _this$props$onSwipeab12 === void 0 ? void 0 : _this$props$onSwipeab12.call(_this$props12, closingDirection);\n }\n });\n\n _defineProperty(this, \"onRowLayout\", ({\n nativeEvent\n }) => {\n this.setState({\n rowWidth: nativeEvent.layout.width\n });\n });\n\n _defineProperty(this, \"currentOffset\", () => {\n const {\n leftWidth = 0,\n rowWidth = 0,\n rowState\n } = this.state;\n const {\n rightOffset = rowWidth\n } = this.state;\n const rightWidth = rowWidth - rightOffset;\n\n if (rowState === 1) {\n return leftWidth;\n } else if (rowState === -1) {\n return -rightWidth;\n }\n\n return 0;\n });\n\n _defineProperty(this, \"close\", () => {\n this.animateRow(this.currentOffset(), 0);\n });\n\n _defineProperty(this, \"openLeft\", () => {\n const {\n leftWidth = 0\n } = this.state;\n this.animateRow(this.currentOffset(), leftWidth);\n });\n\n _defineProperty(this, \"openRight\", () => {\n const {\n rowWidth = 0\n } = this.state;\n const {\n rightOffset = rowWidth\n } = this.state;\n const rightWidth = rowWidth - rightOffset;\n this.animateRow(this.currentOffset(), -rightWidth);\n });\n\n _defineProperty(this, \"reset\", () => {\n const {\n dragX,\n rowTranslation\n } = this.state;\n dragX.setValue(0);\n rowTranslation.setValue(0);\n this.setState({\n rowState: 0\n });\n });\n\n const _dragX = new Animated.Value(0);\n\n this.state = {\n dragX: _dragX,\n rowTranslation: new Animated.Value(0),\n rowState: 0,\n leftWidth: undefined,\n rightOffset: undefined,\n rowWidth: undefined\n };\n this.updateAnimatedEvent(_props, this.state);\n this.onGestureEvent = Animated.event([{\n nativeEvent: {\n translationX: _dragX\n }\n }], {\n useNativeDriver: _props.useNativeAnimations\n });\n }\n\n shouldComponentUpdate(props, state) {\n if (this.props.friction !== props.friction || this.props.overshootLeft !== props.overshootLeft || this.props.overshootRight !== props.overshootRight || this.props.overshootFriction !== props.overshootFriction || this.state.leftWidth !== state.leftWidth || this.state.rightOffset !== state.rightOffset || this.state.rowWidth !== state.rowWidth) {\n this.updateAnimatedEvent(props, state);\n }\n\n return true;\n }\n\n render() {\n const {\n rowState\n } = this.state;\n const {\n children,\n renderLeftActions,\n renderRightActions,\n dragOffsetFromLeftEdge = 10,\n dragOffsetFromRightEdge = 10\n } = this.props;\n const left = renderLeftActions && /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.leftActions, // all those and below parameters can have ! since they are all\n // asigned in constructor in `updateAnimatedEvent` but TS cannot spot\n // it for some reason\n {\n transform: [{\n translateX: this.leftActionTranslate\n }]\n }]\n }, renderLeftActions(this.showLeftAction, this.transX, this), /*#__PURE__*/React.createElement(View, {\n onLayout: ({\n nativeEvent\n }) => this.setState({\n leftWidth: nativeEvent.layout.x\n })\n }));\n const right = renderRightActions && /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.rightActions, {\n transform: [{\n translateX: this.rightActionTranslate\n }]\n }]\n }, renderRightActions(this.showRightAction, this.transX, this), /*#__PURE__*/React.createElement(View, {\n onLayout: ({\n nativeEvent\n }) => this.setState({\n rightOffset: nativeEvent.layout.x\n })\n }));\n return /*#__PURE__*/React.createElement(PanGestureHandler, _extends({\n activeOffsetX: [-dragOffsetFromRightEdge, dragOffsetFromLeftEdge],\n touchAction: \"pan-y\"\n }, this.props, {\n onGestureEvent: this.onGestureEvent,\n onHandlerStateChange: this.onHandlerStateChange\n }), /*#__PURE__*/React.createElement(Animated.View, {\n onLayout: this.onRowLayout,\n style: [styles.container, this.props.containerStyle]\n }, left, right, /*#__PURE__*/React.createElement(TapGestureHandler, {\n enabled: rowState !== 0,\n touchAction: \"pan-y\",\n onHandlerStateChange: this.onTapHandlerStateChange\n }, /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: rowState === 0 ? 'auto' : 'box-only',\n style: [{\n transform: [{\n translateX: this.transX\n }]\n }, this.props.childrenContainerStyle]\n }, children))));\n }\n\n}\n\n_defineProperty(Swipeable, \"defaultProps\", {\n friction: 1,\n overshootFriction: 1,\n useNativeAnimations: true\n});\n\nconst styles = StyleSheet.create({\n container: {\n overflow: 'hidden'\n },\n leftActions: { ...StyleSheet.absoluteFillObject,\n flexDirection: I18nManager.isRTL ? 'row-reverse' : 'row'\n },\n rightActions: { ...StyleSheet.absoluteFillObject,\n flexDirection: I18nManager.isRTL ? 'row' : 'row-reverse'\n }\n});\n//# sourceMappingURL=Swipeable.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar I18nManager = {\n allowRTL() {\n return;\n },\n forceRTL() {\n return;\n },\n getConstants() {\n return {\n isRTL: false\n };\n }\n};\nexport default I18nManager;","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// This component is based on RN's DrawerLayoutAndroid API\n//\n// It perhaps deserves to be put in a separate repo, but since it relies on\n// react-native-gesture-handler library which isn't very popular at the moment I\n// decided to keep it here for the time being. It will allow us to move faster\n// and fix issues that may arise in gesture handler library that could be found\n// when using the drawer component\nimport * as React from 'react';\nimport { Component } from 'react';\nimport invariant from 'invariant';\nimport { Animated, StyleSheet, View, Keyboard, StatusBar, I18nManager } from 'react-native';\nimport { PanGestureHandler } from '../handlers/PanGestureHandler';\nimport { TapGestureHandler } from '../handlers/TapGestureHandler';\nimport { State } from '../State';\nconst DRAG_TOSS = 0.05;\nconst IDLE = 'Idle';\nconst DRAGGING = 'Dragging';\nconst SETTLING = 'Settling';\nexport default class DrawerLayout extends Component {\n constructor(_props) {\n super(_props);\n\n _defineProperty(this, \"openValue\", void 0);\n\n _defineProperty(this, \"onGestureEvent\", void 0);\n\n _defineProperty(this, \"accessibilityIsModalView\", /*#__PURE__*/React.createRef());\n\n _defineProperty(this, \"pointerEventsView\", /*#__PURE__*/React.createRef());\n\n _defineProperty(this, \"panGestureHandler\", /*#__PURE__*/React.createRef());\n\n _defineProperty(this, \"drawerShown\", false);\n\n _defineProperty(this, \"updateAnimatedEvent\", (props, state) => {\n // Event definition is based on\n const {\n drawerPosition,\n drawerWidth,\n drawerType\n } = props;\n const {\n dragX: dragXValue,\n touchX: touchXValue,\n drawerTranslation,\n containerWidth\n } = state;\n let dragX = dragXValue;\n let touchX = touchXValue;\n\n if (drawerPosition !== 'left') {\n // Most of the code is written in a way to handle left-side drawer. In\n // order to handle right-side drawer the only thing we need to do is to\n // reverse events coming from gesture handler in a way they emulate\n // left-side drawer gestures. E.g. dragX is simply -dragX, and touchX is\n // calulcated by subtracing real touchX from the width of the container\n // (such that when touch happens at the right edge the value is simply 0)\n dragX = Animated.multiply(new Animated.Value(-1), dragXValue); // TODO(TS): (for all \"as\" in this file) make sure we can map this\n\n touchX = Animated.add(new Animated.Value(containerWidth), Animated.multiply(new Animated.Value(-1), touchXValue)); // TODO(TS): make sure we can map this;\n\n touchXValue.setValue(containerWidth);\n } else {\n touchXValue.setValue(0);\n } // While closing the drawer when user starts gesture outside of its area (in greyed\n // out part of the window), we want the drawer to follow only once finger reaches the\n // edge of the drawer.\n // E.g. on the diagram below drawer is illustrate by X signs and the greyed out area by\n // dots. The touch gesture starts at '*' and moves left, touch path is indicated by\n // an arrow pointing left\n // 1) +---------------+ 2) +---------------+ 3) +---------------+ 4) +---------------+\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|.<-*..| |XXXXXXXX|<--*..| |XXXXX|<-----*..|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // +---------------+ +---------------+ +---------------+ +---------------+\n //\n // For the above to work properly we define animated value that will keep\n // start position of the gesture. Then we use that value to calculate how\n // much we need to subtract from the dragX. If the gesture started on the\n // greyed out area we take the distance from the edge of the drawer to the\n // start position. Otherwise we don't subtract at all and the drawer be\n // pulled back as soon as you start the pan.\n //\n // This is used only when drawerType is \"front\"\n //\n\n\n let translationX = dragX;\n\n if (drawerType === 'front') {\n const startPositionX = Animated.add(touchX, Animated.multiply(new Animated.Value(-1), dragX));\n const dragOffsetFromOnStartPosition = startPositionX.interpolate({\n inputRange: [drawerWidth - 1, drawerWidth, drawerWidth + 1],\n outputRange: [0, 0, 1]\n });\n translationX = Animated.add(dragX, dragOffsetFromOnStartPosition); // TODO: as above\n }\n\n this.openValue = Animated.add(translationX, drawerTranslation).interpolate({\n inputRange: [0, drawerWidth],\n outputRange: [0, 1],\n extrapolate: 'clamp'\n });\n const gestureOptions = {\n useNativeDriver: props.useNativeAnimations\n };\n\n if (this.props.onDrawerSlide) {\n gestureOptions.listener = ev => {\n var _this$props$onDrawerS, _this$props;\n\n const translationX = Math.floor(Math.abs(ev.nativeEvent.translationX));\n const position = translationX / this.state.containerWidth;\n (_this$props$onDrawerS = (_this$props = this.props).onDrawerSlide) === null || _this$props$onDrawerS === void 0 ? void 0 : _this$props$onDrawerS.call(_this$props, position);\n };\n }\n\n this.onGestureEvent = Animated.event([{\n nativeEvent: {\n translationX: dragXValue,\n x: touchXValue\n }\n }], gestureOptions);\n });\n\n _defineProperty(this, \"handleContainerLayout\", ({\n nativeEvent\n }) => {\n this.setState({\n containerWidth: nativeEvent.layout.width\n });\n });\n\n _defineProperty(this, \"emitStateChanged\", (newState, drawerWillShow) => {\n var _this$props$onDrawerS2, _this$props2;\n\n (_this$props$onDrawerS2 = (_this$props2 = this.props).onDrawerStateChanged) === null || _this$props$onDrawerS2 === void 0 ? void 0 : _this$props$onDrawerS2.call(_this$props2, newState, drawerWillShow);\n });\n\n _defineProperty(this, \"openingHandlerStateChange\", ({\n nativeEvent\n }) => {\n if (nativeEvent.oldState === State.ACTIVE) {\n this.handleRelease({\n nativeEvent\n });\n } else if (nativeEvent.state === State.ACTIVE) {\n this.emitStateChanged(DRAGGING, false);\n this.setState({\n drawerState: DRAGGING\n });\n\n if (this.props.keyboardDismissMode === 'on-drag') {\n Keyboard.dismiss();\n }\n\n if (this.props.hideStatusBar) {\n StatusBar.setHidden(true, this.props.statusBarAnimation || 'slide');\n }\n }\n });\n\n _defineProperty(this, \"onTapHandlerStateChange\", ({\n nativeEvent\n }) => {\n if (this.drawerShown && nativeEvent.oldState === State.ACTIVE && this.props.drawerLockMode !== 'locked-open') {\n this.closeDrawer();\n }\n });\n\n _defineProperty(this, \"handleRelease\", ({\n nativeEvent\n }) => {\n const {\n drawerWidth,\n drawerPosition,\n drawerType\n } = this.props;\n const {\n containerWidth\n } = this.state;\n let {\n translationX: dragX,\n velocityX,\n x: touchX\n } = nativeEvent;\n\n if (drawerPosition !== 'left') {\n // See description in _updateAnimatedEvent about why events are flipped\n // for right-side drawer\n dragX = -dragX;\n touchX = containerWidth - touchX;\n velocityX = -velocityX;\n }\n\n const gestureStartX = touchX - dragX;\n let dragOffsetBasedOnStart = 0;\n\n if (drawerType === 'front') {\n dragOffsetBasedOnStart = gestureStartX > drawerWidth ? gestureStartX - drawerWidth : 0;\n }\n\n const startOffsetX = dragX + dragOffsetBasedOnStart + (this.drawerShown ? drawerWidth : 0);\n const projOffsetX = startOffsetX + DRAG_TOSS * velocityX;\n const shouldOpen = projOffsetX > drawerWidth / 2;\n\n if (shouldOpen) {\n this.animateDrawer(startOffsetX, drawerWidth, velocityX);\n } else {\n this.animateDrawer(startOffsetX, 0, velocityX);\n }\n });\n\n _defineProperty(this, \"updateShowing\", showing => {\n var _this$accessibilityIs, _this$pointerEventsVi, _this$panGestureHandl;\n\n this.drawerShown = showing;\n (_this$accessibilityIs = this.accessibilityIsModalView.current) === null || _this$accessibilityIs === void 0 ? void 0 : _this$accessibilityIs.setNativeProps({\n accessibilityViewIsModal: showing\n });\n (_this$pointerEventsVi = this.pointerEventsView.current) === null || _this$pointerEventsVi === void 0 ? void 0 : _this$pointerEventsVi.setNativeProps({\n pointerEvents: showing ? 'auto' : 'none'\n });\n const {\n drawerPosition,\n minSwipeDistance,\n edgeWidth\n } = this.props;\n const fromLeft = drawerPosition === 'left'; // gestureOrientation is 1 if the expected gesture is from left to right and\n // -1 otherwise e.g. when drawer is on the left and is closed we expect left\n // to right gesture, thus orientation will be 1.\n\n const gestureOrientation = (fromLeft ? 1 : -1) * (this.drawerShown ? -1 : 1); // When drawer is closed we want the hitSlop to be horizontally shorter than\n // the container size by the value of SLOP. This will make it only activate\n // when gesture happens not further than SLOP away from the edge\n\n const hitSlop = fromLeft ? {\n left: 0,\n width: showing ? undefined : edgeWidth\n } : {\n right: 0,\n width: showing ? undefined : edgeWidth\n }; // @ts-ignore internal API, maybe could be fixed in handler types\n\n (_this$panGestureHandl = this.panGestureHandler.current) === null || _this$panGestureHandl === void 0 ? void 0 : _this$panGestureHandl.setNativeProps({\n hitSlop,\n activeOffsetX: gestureOrientation * minSwipeDistance\n });\n });\n\n _defineProperty(this, \"animateDrawer\", (fromValue, toValue, velocity, speed) => {\n this.state.dragX.setValue(0);\n this.state.touchX.setValue(this.props.drawerPosition === 'left' ? 0 : this.state.containerWidth);\n\n if (fromValue != null) {\n let nextFramePosition = fromValue;\n\n if (this.props.useNativeAnimations) {\n // When using native driver, we predict the next position of the\n // animation because it takes one frame of a roundtrip to pass RELEASE\n // event from native driver to JS before we can start animating. Without\n // it, it is more noticable that the frame is dropped.\n if (fromValue < toValue && velocity > 0) {\n nextFramePosition = Math.min(fromValue + velocity / 60.0, toValue);\n } else if (fromValue > toValue && velocity < 0) {\n nextFramePosition = Math.max(fromValue + velocity / 60.0, toValue);\n }\n }\n\n this.state.drawerTranslation.setValue(nextFramePosition);\n }\n\n const willShow = toValue !== 0;\n this.updateShowing(willShow);\n this.emitStateChanged(SETTLING, willShow);\n this.setState({\n drawerState: SETTLING\n });\n\n if (this.props.hideStatusBar) {\n StatusBar.setHidden(willShow, this.props.statusBarAnimation || 'slide');\n }\n\n Animated.spring(this.state.drawerTranslation, {\n velocity,\n bounciness: 0,\n toValue,\n useNativeDriver: this.props.useNativeAnimations,\n speed: speed !== null && speed !== void 0 ? speed : undefined\n }).start(({\n finished\n }) => {\n if (finished) {\n this.emitStateChanged(IDLE, willShow);\n this.setState({\n drawerOpened: willShow\n });\n\n if (this.state.drawerState !== DRAGGING) {\n // it's possilbe that user started drag while the drawer\n // was settling, don't override state in this case\n this.setState({\n drawerState: IDLE\n });\n }\n\n if (willShow) {\n var _this$props$onDrawerO, _this$props3;\n\n (_this$props$onDrawerO = (_this$props3 = this.props).onDrawerOpen) === null || _this$props$onDrawerO === void 0 ? void 0 : _this$props$onDrawerO.call(_this$props3);\n } else {\n var _this$props$onDrawerC, _this$props4;\n\n (_this$props$onDrawerC = (_this$props4 = this.props).onDrawerClose) === null || _this$props$onDrawerC === void 0 ? void 0 : _this$props$onDrawerC.call(_this$props4);\n }\n }\n });\n });\n\n _defineProperty(this, \"openDrawer\", (options = {}) => {\n this.animateDrawer( // TODO: decide if it should be null or undefined is the proper value\n undefined, this.props.drawerWidth, options.velocity ? options.velocity : 0, options.speed); // We need to force the update, otherwise the overlay is not rerendered and\n // it would not be clickable\n\n this.forceUpdate();\n });\n\n _defineProperty(this, \"closeDrawer\", (options = {}) => {\n // TODO: decide if it should be null or undefined is the proper value\n this.animateDrawer(undefined, 0, options.velocity ? options.velocity : 0, options.speed); // We need to force the update, otherwise the overlay is not rerendered and\n // it would be still clickable\n\n this.forceUpdate();\n });\n\n _defineProperty(this, \"renderOverlay\", () => {\n /* Overlay styles */\n invariant(this.openValue, 'should be set');\n let overlayOpacity;\n\n if (this.state.drawerState !== IDLE) {\n overlayOpacity = this.openValue;\n } else {\n overlayOpacity = this.state.drawerOpened ? 1 : 0;\n }\n\n const dynamicOverlayStyles = {\n opacity: overlayOpacity,\n backgroundColor: this.props.overlayColor\n };\n return /*#__PURE__*/React.createElement(TapGestureHandler, {\n onHandlerStateChange: this.onTapHandlerStateChange\n }, /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: this.drawerShown ? 'auto' : 'none',\n ref: this.pointerEventsView,\n style: [styles.overlay, dynamicOverlayStyles]\n }));\n });\n\n _defineProperty(this, \"renderDrawer\", () => {\n const {\n drawerBackgroundColor,\n drawerWidth,\n drawerPosition,\n drawerType,\n drawerContainerStyle,\n contentContainerStyle\n } = this.props;\n const fromLeft = drawerPosition === 'left';\n const drawerSlide = drawerType !== 'back';\n const containerSlide = drawerType !== 'front'; // we rely on row and row-reverse flex directions to position the drawer\n // properly. Apparently for RTL these are flipped which requires us to use\n // the opposite setting for the drawer to appear from left or right\n // according to the drawerPosition prop\n\n const reverseContentDirection = I18nManager.isRTL ? fromLeft : !fromLeft;\n const dynamicDrawerStyles = {\n backgroundColor: drawerBackgroundColor,\n width: drawerWidth\n };\n const openValue = this.openValue;\n invariant(openValue, 'should be set');\n let containerStyles;\n\n if (containerSlide) {\n const containerTranslateX = openValue.interpolate({\n inputRange: [0, 1],\n outputRange: fromLeft ? [0, drawerWidth] : [0, -drawerWidth],\n extrapolate: 'clamp'\n });\n containerStyles = {\n transform: [{\n translateX: containerTranslateX\n }]\n };\n }\n\n let drawerTranslateX = 0;\n\n if (drawerSlide) {\n const closedDrawerOffset = fromLeft ? -drawerWidth : drawerWidth;\n\n if (this.state.drawerState !== IDLE) {\n drawerTranslateX = openValue.interpolate({\n inputRange: [0, 1],\n outputRange: [closedDrawerOffset, 0],\n extrapolate: 'clamp'\n });\n } else {\n drawerTranslateX = this.state.drawerOpened ? 0 : closedDrawerOffset;\n }\n }\n\n const drawerStyles = {\n transform: [{\n translateX: drawerTranslateX\n }],\n flexDirection: reverseContentDirection ? 'row-reverse' : 'row'\n };\n return /*#__PURE__*/React.createElement(Animated.View, {\n style: styles.main,\n onLayout: this.handleContainerLayout\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: [drawerType === 'front' ? styles.containerOnBack : styles.containerInFront, containerStyles, contentContainerStyle],\n importantForAccessibility: this.drawerShown ? 'no-hide-descendants' : 'yes'\n }, typeof this.props.children === 'function' ? this.props.children(this.openValue) : this.props.children, this.renderOverlay()), /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: \"box-none\",\n ref: this.accessibilityIsModalView,\n accessibilityViewIsModal: this.drawerShown,\n style: [styles.drawerContainer, drawerStyles, drawerContainerStyle]\n }, /*#__PURE__*/React.createElement(View, {\n style: dynamicDrawerStyles\n }, this.props.renderNavigationView(this.openValue))));\n });\n\n _defineProperty(this, \"setPanGestureRef\", ref => {\n var _this$props$onGesture, _this$props5;\n\n // TODO(TS): make sure it is OK taken from\n // https://github.com/DefinitelyTyped/DefinitelyTyped/issues/31065#issuecomment-596081842\n this.panGestureHandler.current = ref;\n (_this$props$onGesture = (_this$props5 = this.props).onGestureRef) === null || _this$props$onGesture === void 0 ? void 0 : _this$props$onGesture.call(_this$props5, ref);\n });\n\n const _dragX = new Animated.Value(0);\n\n const _touchX = new Animated.Value(0);\n\n const _drawerTranslation = new Animated.Value(0);\n\n this.state = {\n dragX: _dragX,\n touchX: _touchX,\n drawerTranslation: _drawerTranslation,\n containerWidth: 0,\n drawerState: IDLE,\n drawerOpened: false\n };\n this.updateAnimatedEvent(_props, this.state);\n }\n\n shouldComponentUpdate(props, state) {\n if (this.props.drawerPosition !== props.drawerPosition || this.props.drawerWidth !== props.drawerWidth || this.props.drawerType !== props.drawerType || this.state.containerWidth !== state.containerWidth) {\n this.updateAnimatedEvent(props, state);\n }\n\n return true;\n }\n\n render() {\n const {\n drawerPosition,\n drawerLockMode,\n edgeWidth,\n minSwipeDistance\n } = this.props;\n const fromLeft = drawerPosition === 'left'; // gestureOrientation is 1 if the expected gesture is from left to right and\n // -1 otherwise e.g. when drawer is on the left and is closed we expect left\n // to right gesture, thus orientation will be 1.\n\n const gestureOrientation = (fromLeft ? 1 : -1) * (this.drawerShown ? -1 : 1); // When drawer is closed we want the hitSlop to be horizontally shorter than\n // the container size by the value of SLOP. This will make it only activate\n // when gesture happens not further than SLOP away from the edge\n\n const hitSlop = fromLeft ? {\n left: 0,\n width: this.drawerShown ? undefined : edgeWidth\n } : {\n right: 0,\n width: this.drawerShown ? undefined : edgeWidth\n };\n return /*#__PURE__*/React.createElement(PanGestureHandler // @ts-ignore could be fixed in handler types\n , {\n userSelect: this.props.userSelect,\n activeCursor: this.props.activeCursor,\n mouseButton: this.props.mouseButton,\n enableContextMenu: this.props.enableContextMenu,\n ref: this.setPanGestureRef,\n hitSlop: hitSlop,\n activeOffsetX: gestureOrientation * minSwipeDistance,\n failOffsetY: [-15, 15],\n onGestureEvent: this.onGestureEvent,\n onHandlerStateChange: this.openingHandlerStateChange,\n enableTrackpadTwoFingerGesture: this.props.enableTrackpadTwoFingerGesture,\n enabled: drawerLockMode !== 'locked-closed' && drawerLockMode !== 'locked-open'\n }, this.renderDrawer());\n }\n\n}\n\n_defineProperty(DrawerLayout, \"defaultProps\", {\n drawerWidth: 200,\n drawerPosition: 'left',\n useNativeAnimations: true,\n drawerType: 'front',\n edgeWidth: 20,\n minSwipeDistance: 3,\n overlayColor: 'rgba(0, 0, 0, 0.7)',\n drawerLockMode: 'unlocked',\n enableTrackpadTwoFingerGesture: false\n});\n\n_defineProperty(DrawerLayout, \"positions\", {\n Left: 'left',\n Right: 'right'\n});\n\nconst styles = StyleSheet.create({\n drawerContainer: { ...StyleSheet.absoluteFillObject,\n zIndex: 1001,\n flexDirection: 'row'\n },\n containerInFront: { ...StyleSheet.absoluteFillObject,\n zIndex: 1002\n },\n containerOnBack: { ...StyleSheet.absoluteFillObject\n },\n main: {\n flex: 1,\n zIndex: 0,\n overflow: 'hidden'\n },\n overlay: { ...StyleSheet.absoluteFillObject,\n zIndex: 1000\n }\n});\n//# sourceMappingURL=DrawerLayout.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport dismissKeyboard from '../../modules/dismissKeyboard';\n\n// in the future we can use https://github.com/w3c/virtual-keyboard\nvar Keyboard = {\n isVisible() {\n return false;\n },\n addListener() {\n return {\n remove: () => {}\n };\n },\n dismiss() {\n dismissKeyboard();\n },\n removeAllListeners() {},\n removeListener() {}\n};\nexport default Keyboard;","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar emptyFunction = () => {};\nfunction StatusBar() {\n return null;\n}\nStatusBar.setBackgroundColor = emptyFunction;\nStatusBar.setBarStyle = emptyFunction;\nStatusBar.setHidden = emptyFunction;\nStatusBar.setNetworkActivityIndicatorVisible = emptyFunction;\nStatusBar.setTranslucent = emptyFunction;\nexport default StatusBar;","import * as React from 'react';\nimport { AccessibilityInfo, Appearance } from 'react-native';\nimport SafeAreaProviderCompat from './SafeAreaProviderCompat';\nimport { Provider as SettingsProvider } from './settings';\nimport { defaultThemesByVersion, ThemeProvider } from './theming';\nimport MaterialCommunityIcon from '../components/MaterialCommunityIcon';\nimport PortalHost from '../components/Portal/PortalHost';\nimport { addEventListener } from '../utils/addEventListener';\nconst PaperProvider = props => {\n const isOnlyVersionInTheme = props.theme && Object.keys(props.theme).length === 1 && props.theme.version;\n const colorSchemeName = (!props.theme || isOnlyVersionInTheme) && (Appearance === null || Appearance === void 0 ? void 0 : Appearance.getColorScheme()) || 'light';\n const [reduceMotionEnabled, setReduceMotionEnabled] = React.useState(false);\n const [colorScheme, setColorScheme] = React.useState(colorSchemeName);\n const handleAppearanceChange = preferences => {\n const {\n colorScheme\n } = preferences;\n setColorScheme(colorScheme);\n };\n React.useEffect(() => {\n let subscription;\n if (!props.theme) {\n subscription = addEventListener(AccessibilityInfo, 'reduceMotionChanged', setReduceMotionEnabled);\n }\n return () => {\n if (!props.theme) {\n var _subscription;\n (_subscription = subscription) === null || _subscription === void 0 ? void 0 : _subscription.remove();\n }\n };\n }, [props.theme]);\n React.useEffect(() => {\n let appearanceSubscription;\n if (!props.theme || isOnlyVersionInTheme) {\n appearanceSubscription = Appearance === null || Appearance === void 0 ? void 0 : Appearance.addChangeListener(handleAppearanceChange);\n }\n return () => {\n if (!props.theme || isOnlyVersionInTheme) {\n if (appearanceSubscription) {\n appearanceSubscription.remove();\n } else {\n // @ts-expect-error: We keep deprecated listener remove method for backwards compat with old RN versions\n Appearance === null || Appearance === void 0 ? void 0 : Appearance.removeChangeListener(handleAppearanceChange);\n }\n }\n };\n }, [props.theme, isOnlyVersionInTheme]);\n const getTheme = () => {\n var _props$theme, _props$theme2;\n const themeVersion = ((_props$theme = props.theme) === null || _props$theme === void 0 ? void 0 : _props$theme.version) || 3;\n const scheme = colorScheme || 'light';\n const defaultThemeBase = defaultThemesByVersion[themeVersion][scheme];\n const extendedThemeBase = {\n ...defaultThemeBase,\n ...props.theme,\n version: themeVersion,\n animation: {\n ...((_props$theme2 = props.theme) === null || _props$theme2 === void 0 ? void 0 : _props$theme2.animation),\n scale: reduceMotionEnabled ? 0 : 1\n }\n };\n return {\n ...extendedThemeBase,\n isV3: extendedThemeBase.version === 3\n };\n };\n const {\n children,\n settings\n } = props;\n return /*#__PURE__*/React.createElement(SafeAreaProviderCompat, null, /*#__PURE__*/React.createElement(PortalHost, null, /*#__PURE__*/React.createElement(SettingsProvider, {\n value: {\n icon: MaterialCommunityIcon,\n rippleEffectEnabled: true,\n ...settings\n }\n }, /*#__PURE__*/React.createElement(ThemeProvider, {\n theme: getTheme()\n }, children))));\n};\nexport default PaperProvider;\n//# sourceMappingURL=PaperProvider.js.map","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\nimport canUseDOM from '../../modules/canUseDom';\nfunction isScreenReaderEnabled() {\n return new Promise((resolve, reject) => {\n resolve(true);\n });\n}\nvar prefersReducedMotionMedia = canUseDOM && typeof window.matchMedia === 'function' ? window.matchMedia('(prefers-reduced-motion: reduce)') : null;\nfunction isReduceMotionEnabled() {\n return new Promise((resolve, reject) => {\n resolve(prefersReducedMotionMedia ? prefersReducedMotionMedia.matches : true);\n });\n}\nfunction addChangeListener(fn) {\n if (prefersReducedMotionMedia != null) {\n prefersReducedMotionMedia.addEventListener != null ? prefersReducedMotionMedia.addEventListener('change', fn) : prefersReducedMotionMedia.addListener(fn);\n }\n}\nfunction removeChangeListener(fn) {\n if (prefersReducedMotionMedia != null) {\n prefersReducedMotionMedia.removeEventListener != null ? prefersReducedMotionMedia.removeEventListener('change', fn) : prefersReducedMotionMedia.removeListener(fn);\n }\n}\nvar handlers = {};\nvar AccessibilityInfo = {\n /**\n * Query whether a screen reader is currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when a screen reader is enabled and `false` otherwise.\n */\n isScreenReaderEnabled,\n /**\n * Query whether the user prefers reduced motion.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when a screen reader is enabled and `false` otherwise.\n */\n isReduceMotionEnabled,\n /**\n * Deprecated\n */\n fetch: isScreenReaderEnabled,\n /**\n * Add an event handler. Supported events: reduceMotionChanged\n */\n addEventListener: function addEventListener(eventName, handler) {\n if (eventName === 'reduceMotionChanged') {\n if (!prefersReducedMotionMedia) {\n return;\n }\n var listener = event => {\n handler(event.matches);\n };\n addChangeListener(listener);\n handlers[handler] = listener;\n }\n return {\n remove: () => AccessibilityInfo.removeEventListener(eventName, handler)\n };\n },\n /**\n * Set accessibility focus to a react component.\n */\n setAccessibilityFocus: function setAccessibilityFocus(reactTag) {},\n /**\n * Post a string to be announced by the screen reader.\n */\n announceForAccessibility: function announceForAccessibility(announcement) {},\n /**\n * Remove an event handler.\n */\n removeEventListener: function removeEventListener(eventName, handler) {\n if (eventName === 'reduceMotionChanged') {\n var listener = handlers[handler];\n if (!listener || !prefersReducedMotionMedia) {\n return;\n }\n removeChangeListener(listener);\n }\n return;\n }\n};\nexport default AccessibilityInfo;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\nimport canUseDOM from '../../modules/canUseDom';\nfunction getQuery() {\n return canUseDOM && window.matchMedia != null ? window.matchMedia('(prefers-color-scheme: dark)') : null;\n}\nvar query = getQuery();\nvar listenerMapping = new WeakMap();\nvar Appearance = {\n getColorScheme() {\n return query && query.matches ? 'dark' : 'light';\n },\n addChangeListener(listener) {\n var mappedListener = listenerMapping.get(listener);\n if (!mappedListener) {\n mappedListener = _ref => {\n var matches = _ref.matches;\n listener({\n colorScheme: matches ? 'dark' : 'light'\n });\n };\n listenerMapping.set(listener, mappedListener);\n }\n if (query) {\n query.addListener(mappedListener);\n }\n function remove() {\n var mappedListener = listenerMapping.get(listener);\n if (query && mappedListener) {\n query.removeListener(mappedListener);\n }\n listenerMapping.delete(listener);\n }\n return {\n remove\n };\n }\n};\nexport default Appearance;","/**\n * Ported from @react-navigation https://github.com/react-navigation/react-navigation/blob/main/packages/elements/src/SafeAreaProviderCompat.tsx\n */\nimport * as React from 'react';\nimport { Dimensions, Platform, StyleSheet, View } from 'react-native';\nimport { initialWindowMetrics, SafeAreaInsetsContext, SafeAreaProvider } from 'react-native-safe-area-context';\nconst {\n width = 0,\n height = 0\n} = Dimensions.get('window');\n\n// To support SSR on web, we need to have empty insets for initial values\n// Otherwise there can be mismatch between SSR and client output\n// We also need to specify empty values to support tests environments\nconst initialMetrics = Platform.OS === 'web' || initialWindowMetrics == null ? {\n frame: {\n x: 0,\n y: 0,\n width,\n height\n },\n insets: {\n top: 0,\n left: 0,\n right: 0,\n bottom: 0\n }\n} : initialWindowMetrics;\nexport default function SafeAreaProviderCompat(_ref) {\n let {\n children,\n style\n } = _ref;\n return /*#__PURE__*/React.createElement(SafeAreaInsetsContext.Consumer, null, insets => {\n if (insets) {\n // If we already have insets, don't wrap the stack in another safe area provider\n // This avoids an issue with updates at the cost of potentially incorrect values\n // https://github.com/react-navigation/react-navigation/issues/174\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.container, style]\n }, children);\n }\n return /*#__PURE__*/React.createElement(SafeAreaProvider, {\n initialMetrics: initialMetrics,\n style: style\n }, children);\n });\n}\nSafeAreaProviderCompat.initialMetrics = initialMetrics;\nconst styles = StyleSheet.create({\n container: {\n flex: 1\n }\n});\n//# sourceMappingURL=SafeAreaProviderCompat.js.map","'use client';\n\nexport * from './SafeAreaContext';\nexport * from './SafeAreaView';\nexport * from './InitialWindow';\nexport * from './SafeArea.types';\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Dimensions, StyleSheet } from 'react-native';\nimport { NativeSafeAreaProvider } from './NativeSafeAreaProvider';\nconst isDev = process.env.NODE_ENV !== 'production';\nexport const SafeAreaInsetsContext = /*#__PURE__*/React.createContext(null);\nif (isDev) {\n SafeAreaInsetsContext.displayName = 'SafeAreaInsetsContext';\n}\nexport const SafeAreaFrameContext = /*#__PURE__*/React.createContext(null);\nif (isDev) {\n SafeAreaFrameContext.displayName = 'SafeAreaFrameContext';\n}\nexport function SafeAreaProvider({\n children,\n initialMetrics,\n initialSafeAreaInsets,\n style,\n ...others\n}) {\n const parentInsets = useParentSafeAreaInsets();\n const parentFrame = useParentSafeAreaFrame();\n const [insets, setInsets] = React.useState(initialMetrics?.insets ?? initialSafeAreaInsets ?? parentInsets ?? null);\n const [frame, setFrame] = React.useState(initialMetrics?.frame ?? parentFrame ?? {\n // Backwards compat so we render anyway if we don't have frame.\n x: 0,\n y: 0,\n width: Dimensions.get('window').width,\n height: Dimensions.get('window').height\n });\n const onInsetsChange = React.useCallback(event => {\n const {\n nativeEvent: {\n frame: nextFrame,\n insets: nextInsets\n }\n } = event;\n setFrame(curFrame => {\n if (\n // Backwards compat with old native code that won't send frame.\n nextFrame && (nextFrame.height !== curFrame.height || nextFrame.width !== curFrame.width || nextFrame.x !== curFrame.x || nextFrame.y !== curFrame.y)) {\n return nextFrame;\n } else {\n return curFrame;\n }\n });\n setInsets(curInsets => {\n if (!curInsets || nextInsets.bottom !== curInsets.bottom || nextInsets.left !== curInsets.left || nextInsets.right !== curInsets.right || nextInsets.top !== curInsets.top) {\n return nextInsets;\n } else {\n return curInsets;\n }\n });\n }, []);\n return /*#__PURE__*/React.createElement(NativeSafeAreaProvider, _extends({\n style: [styles.fill, style],\n onInsetsChange: onInsetsChange\n }, others), insets != null ? /*#__PURE__*/React.createElement(SafeAreaFrameContext.Provider, {\n value: frame\n }, /*#__PURE__*/React.createElement(SafeAreaInsetsContext.Provider, {\n value: insets\n }, children)) : null);\n}\nconst styles = StyleSheet.create({\n fill: {\n flex: 1\n }\n});\nfunction useParentSafeAreaInsets() {\n return React.useContext(SafeAreaInsetsContext);\n}\nfunction useParentSafeAreaFrame() {\n return React.useContext(SafeAreaFrameContext);\n}\nconst NO_INSETS_ERROR = 'No safe area value available. Make sure you are rendering `` at the top of your app.';\nexport function useSafeAreaInsets() {\n const insets = React.useContext(SafeAreaInsetsContext);\n if (insets == null) {\n throw new Error(NO_INSETS_ERROR);\n }\n return insets;\n}\nexport function useSafeAreaFrame() {\n const frame = React.useContext(SafeAreaFrameContext);\n if (frame == null) {\n throw new Error(NO_INSETS_ERROR);\n }\n return frame;\n}\nexport function withSafeAreaInsets(WrappedComponent) {\n return /*#__PURE__*/React.forwardRef((props, ref) => {\n const insets = useSafeAreaInsets();\n return /*#__PURE__*/React.createElement(WrappedComponent, _extends({}, props, {\n insets: insets,\n ref: ref\n }));\n });\n}\n\n/**\n * @deprecated\n */\nexport function useSafeArea() {\n return useSafeAreaInsets();\n}\n\n/**\n * @deprecated\n */\nexport const SafeAreaConsumer = SafeAreaInsetsContext.Consumer;\n\n/**\n * @deprecated\n */\nexport const SafeAreaContext = SafeAreaInsetsContext;\n//# sourceMappingURL=SafeAreaContext.js.map","/* eslint-env browser */\n\nimport * as React from 'react';\nimport { View } from 'react-native';\n/**\n * TODO:\n * Currently insets and frame are based on the window and are not\n * relative to the provider view. This is inconsistent with iOS and Android.\n * However in most cases if the provider view covers the screen this is not\n * an issue.\n */\n\nconst CSSTransitions = {\n WebkitTransition: 'webkitTransitionEnd',\n Transition: 'transitionEnd',\n MozTransition: 'transitionend',\n MSTransition: 'msTransitionEnd',\n OTransition: 'oTransitionEnd'\n};\nexport function NativeSafeAreaProvider({\n children,\n style,\n onInsetsChange\n}) {\n React.useEffect(() => {\n // Skip for SSR.\n if (typeof document === 'undefined') {\n return;\n }\n const element = createContextElement();\n document.body.appendChild(element);\n const onEnd = () => {\n const {\n paddingTop,\n paddingBottom,\n paddingLeft,\n paddingRight\n } = window.getComputedStyle(element);\n const insets = {\n top: paddingTop ? parseInt(paddingTop, 10) : 0,\n bottom: paddingBottom ? parseInt(paddingBottom, 10) : 0,\n left: paddingLeft ? parseInt(paddingLeft, 10) : 0,\n right: paddingRight ? parseInt(paddingRight, 10) : 0\n };\n const frame = {\n x: 0,\n y: 0,\n width: document.documentElement.offsetWidth,\n height: document.documentElement.offsetHeight\n };\n // @ts-ignore: missing properties\n onInsetsChange({\n nativeEvent: {\n insets,\n frame\n }\n });\n };\n element.addEventListener(getSupportedTransitionEvent(), onEnd);\n onEnd();\n return () => {\n document.body.removeChild(element);\n element.removeEventListener(getSupportedTransitionEvent(), onEnd);\n };\n }, [onInsetsChange]);\n return /*#__PURE__*/React.createElement(View, {\n style: style\n }, children);\n}\nlet _supportedTransitionEvent = null;\nfunction getSupportedTransitionEvent() {\n if (_supportedTransitionEvent != null) {\n return _supportedTransitionEvent;\n }\n const element = document.createElement('invalidtype');\n _supportedTransitionEvent = CSSTransitions.Transition;\n for (const key in CSSTransitions) {\n if (element.style[key] !== undefined) {\n _supportedTransitionEvent = CSSTransitions[key];\n break;\n }\n }\n return _supportedTransitionEvent;\n}\nlet _supportedEnv = null;\nfunction getSupportedEnv() {\n if (_supportedEnv !== null) {\n return _supportedEnv;\n }\n const {\n CSS\n } = window;\n if (CSS && CSS.supports && CSS.supports('top: constant(safe-area-inset-top)')) {\n _supportedEnv = 'constant';\n } else {\n _supportedEnv = 'env';\n }\n return _supportedEnv;\n}\nfunction getInset(side) {\n return `${getSupportedEnv()}(safe-area-inset-${side})`;\n}\nfunction createContextElement() {\n const element = document.createElement('div');\n const {\n style\n } = element;\n style.position = 'fixed';\n style.left = '0';\n style.top = '0';\n style.width = '0';\n style.height = '0';\n style.zIndex = '-1';\n style.overflow = 'hidden';\n style.visibility = 'hidden';\n // Bacon: Anything faster than this and the callback will be invoked too early with the wrong insets\n style.transitionDuration = '0.05s';\n style.transitionProperty = 'padding';\n style.transitionDelay = '0s';\n style.paddingTop = getInset('top');\n style.paddingBottom = getInset('bottom');\n style.paddingLeft = getInset('left');\n style.paddingRight = getInset('right');\n return element;\n}\n//# sourceMappingURL=NativeSafeAreaProvider.web.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { useSafeAreaInsets } from './SafeAreaContext';\nconst defaultEdges = {\n top: 'additive',\n left: 'additive',\n bottom: 'additive',\n right: 'additive'\n};\nfunction getEdgeValue(inset, current, mode) {\n switch (mode) {\n case 'off':\n return current;\n case 'maximum':\n return Math.max(current, inset);\n case 'additive':\n default:\n return current + inset;\n }\n}\nexport const SafeAreaView = /*#__PURE__*/React.forwardRef(({\n style = {},\n mode,\n edges,\n ...rest\n}, ref) => {\n const insets = useSafeAreaInsets();\n const edgesRecord = React.useMemo(() => {\n if (edges == null) {\n return defaultEdges;\n }\n return Array.isArray(edges) ? edges.reduce((acc, edge) => {\n acc[edge] = 'additive';\n return acc;\n }, {}) :\n // ts has trouble with refining readonly arrays.\n edges;\n }, [edges]);\n const appliedStyle = React.useMemo(() => {\n const flatStyle = StyleSheet.flatten(style);\n if (mode === 'margin') {\n const {\n margin = 0,\n marginVertical = margin,\n marginHorizontal = margin,\n marginTop = marginVertical,\n marginRight = marginHorizontal,\n marginBottom = marginVertical,\n marginLeft = marginHorizontal\n } = flatStyle;\n const marginStyle = {\n marginTop: getEdgeValue(insets.top, marginTop, edgesRecord.top),\n marginRight: getEdgeValue(insets.right, marginRight, edgesRecord.right),\n marginBottom: getEdgeValue(insets.bottom, marginBottom, edgesRecord.bottom),\n marginLeft: getEdgeValue(insets.left, marginLeft, edgesRecord.left)\n };\n return [style, marginStyle];\n } else {\n const {\n padding = 0,\n paddingVertical = padding,\n paddingHorizontal = padding,\n paddingTop = paddingVertical,\n paddingRight = paddingHorizontal,\n paddingBottom = paddingVertical,\n paddingLeft = paddingHorizontal\n } = flatStyle;\n const paddingStyle = {\n paddingTop: getEdgeValue(insets.top, paddingTop, edgesRecord.top),\n paddingRight: getEdgeValue(insets.right, paddingRight, edgesRecord.right),\n paddingBottom: getEdgeValue(insets.bottom, paddingBottom, edgesRecord.bottom),\n paddingLeft: getEdgeValue(insets.left, paddingLeft, edgesRecord.left)\n };\n return [style, paddingStyle];\n }\n }, [edgesRecord.bottom, edgesRecord.left, edgesRecord.right, edgesRecord.top, insets.bottom, insets.left, insets.right, insets.top, mode, style]);\n return /*#__PURE__*/React.createElement(View, _extends({\n style: appliedStyle\n }, rest, {\n ref: ref\n }));\n});\n//# sourceMappingURL=SafeAreaView.web.js.map","export const initialWindowMetrics = null;\n\n/**\n * @deprecated\n */\nexport const initialWindowSafeAreaInsets = null;\n//# sourceMappingURL=InitialWindow.js.map","export {};\n//# sourceMappingURL=SafeArea.types.js.map","import * as React from 'react';\nimport MaterialCommunityIcon from '../components/MaterialCommunityIcon';\nexport const SettingsContext = /*#__PURE__*/React.createContext({\n icon: MaterialCommunityIcon,\n rippleEffectEnabled: true\n});\nexport const {\n Provider,\n Consumer\n} = SettingsContext;\n//# sourceMappingURL=settings.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, Text, Platform } from 'react-native';\nimport { black } from '../styles/themes/v2/colors';\nlet MaterialCommunityIcons;\ntry {\n // Optionally require vector-icons\n MaterialCommunityIcons = require('react-native-vector-icons/MaterialCommunityIcons').default;\n} catch (e) {\n let isErrorLogged = false;\n\n // Fallback component for icons\n MaterialCommunityIcons = _ref => {\n let {\n name,\n color,\n size,\n ...rest\n } = _ref;\n /* eslint-disable no-console */\n if (!isErrorLogged) {\n if (!/(Cannot find module|Module not found|Cannot resolve module)/.test(e.message)) {\n console.error(e);\n }\n console.warn(`Tried to use the icon '${name}' in a component from 'react-native-paper', but 'react-native-vector-icons/MaterialCommunityIcons' could not be loaded.`, `To remove this warning, try installing 'react-native-vector-icons' or use another method to specify icon: https://callstack.github.io/react-native-paper/docs/guides/icons`);\n isErrorLogged = true;\n }\n return /*#__PURE__*/React.createElement(Text, _extends({}, rest, {\n style: [styles.icon, {\n color,\n fontSize: size\n }]\n // @ts-expect-error: Text doesn't support this, but it seems to affect TouchableNativeFeedback\n ,\n pointerEvents: \"none\",\n selectable: false\n }), \"\\u25A1\");\n };\n}\nexport const accessibilityProps = Platform.OS === 'web' ? {\n role: 'img',\n focusable: false\n} : {\n accessibilityElementsHidden: true,\n importantForAccessibility: 'no-hide-descendants'\n};\nconst defaultIcon = _ref2 => {\n let {\n name,\n color = black,\n size,\n direction,\n allowFontScaling,\n testID\n } = _ref2;\n return /*#__PURE__*/React.createElement(MaterialCommunityIcons, _extends({\n allowFontScaling: allowFontScaling,\n name: name,\n color: color,\n size: size,\n style: [{\n transform: [{\n scaleX: direction === 'rtl' ? -1 : 1\n }],\n lineHeight: size\n }, styles.icon],\n pointerEvents: \"none\",\n selectable: false,\n testID: testID\n }, accessibilityProps));\n};\nconst styles = StyleSheet.create({\n // eslint-disable-next-line react-native/no-color-literals\n icon: {\n backgroundColor: 'transparent'\n }\n});\nexport default defaultIcon;\n//# sourceMappingURL=MaterialCommunityIcon.js.map","export const transparent = 'rgba(255, 255, 255, 0)';\nexport const red50 = '#ffebee';\nexport const red100 = '#ffcdd2';\nexport const red200 = '#ef9a9a';\nexport const red300 = '#e57373';\nexport const red400 = '#ef5350';\nexport const red500 = '#f44336';\nexport const red600 = '#e53935';\nexport const red700 = '#d32f2f';\nexport const red800 = '#c62828';\nexport const red900 = '#b71c1c';\nexport const redA100 = '#ff8a80';\nexport const redA200 = '#ff5252';\nexport const redA400 = '#ff1744';\nexport const redA700 = '#d50000';\nexport const pink50 = '#fce4ec';\nexport const pink100 = '#f8bbd0';\nexport const pink200 = '#f48fb1';\nexport const pink300 = '#f06292';\nexport const pink400 = '#ec407a';\nexport const pink500 = '#e91e63';\nexport const pink600 = '#d81b60';\nexport const pink700 = '#c2185b';\nexport const pink800 = '#ad1457';\nexport const pink900 = '#880e4f';\nexport const pinkA100 = '#ff80ab';\nexport const pinkA200 = '#ff4081';\nexport const pinkA400 = '#f50057';\nexport const pinkA700 = '#c51162';\nexport const purple50 = '#f3e5f5';\nexport const purple100 = '#e1bee7';\nexport const purple200 = '#ce93d8';\nexport const purple300 = '#ba68c8';\nexport const purple400 = '#ab47bc';\nexport const purple500 = '#9c27b0';\nexport const purple600 = '#8e24aa';\nexport const purple700 = '#7b1fa2';\nexport const purple800 = '#6a1b9a';\nexport const purple900 = '#4a148c';\nexport const purpleA100 = '#ea80fc';\nexport const purpleA200 = '#e040fb';\nexport const purpleA400 = '#d500f9';\nexport const purpleA700 = '#aa00ff';\nexport const deepPurple50 = '#ede7f6';\nexport const deepPurple100 = '#d1c4e9';\nexport const deepPurple200 = '#b39ddb';\nexport const deepPurple300 = '#9575cd';\nexport const deepPurple400 = '#7e57c2';\nexport const deepPurple500 = '#673ab7';\nexport const deepPurple600 = '#5e35b1';\nexport const deepPurple700 = '#512da8';\nexport const deepPurple800 = '#4527a0';\nexport const deepPurple900 = '#311b92';\nexport const deepPurpleA100 = '#b388ff';\nexport const deepPurpleA200 = '#7c4dff';\nexport const deepPurpleA400 = '#651fff';\nexport const deepPurpleA700 = '#6200ea';\nexport const indigo50 = '#e8eaf6';\nexport const indigo100 = '#c5cae9';\nexport const indigo200 = '#9fa8da';\nexport const indigo300 = '#7986cb';\nexport const indigo400 = '#5c6bc0';\nexport const indigo500 = '#3f51b5';\nexport const indigo600 = '#3949ab';\nexport const indigo700 = '#303f9f';\nexport const indigo800 = '#283593';\nexport const indigo900 = '#1a237e';\nexport const indigoA100 = '#8c9eff';\nexport const indigoA200 = '#536dfe';\nexport const indigoA400 = '#3d5afe';\nexport const indigoA700 = '#304ffe';\nexport const blue50 = '#e3f2fd';\nexport const blue100 = '#bbdefb';\nexport const blue200 = '#90caf9';\nexport const blue300 = '#64b5f6';\nexport const blue400 = '#42a5f5';\nexport const blue500 = '#2196f3';\nexport const blue600 = '#1e88e5';\nexport const blue700 = '#1976d2';\nexport const blue800 = '#1565c0';\nexport const blue900 = '#0d47a1';\nexport const blueA100 = '#82b1ff';\nexport const blueA200 = '#448aff';\nexport const blueA400 = '#2979ff';\nexport const blueA700 = '#2962ff';\nexport const lightBlue50 = '#e1f5fe';\nexport const lightBlue100 = '#b3e5fc';\nexport const lightBlue200 = '#81d4fa';\nexport const lightBlue300 = '#4fc3f7';\nexport const lightBlue400 = '#29b6f6';\nexport const lightBlue500 = '#03a9f4';\nexport const lightBlue600 = '#039be5';\nexport const lightBlue700 = '#0288d1';\nexport const lightBlue800 = '#0277bd';\nexport const lightBlue900 = '#01579b';\nexport const lightBlueA100 = '#80d8ff';\nexport const lightBlueA200 = '#40c4ff';\nexport const lightBlueA400 = '#00b0ff';\nexport const lightBlueA700 = '#0091ea';\nexport const cyan50 = '#e0f7fa';\nexport const cyan100 = '#b2ebf2';\nexport const cyan200 = '#80deea';\nexport const cyan300 = '#4dd0e1';\nexport const cyan400 = '#26c6da';\nexport const cyan500 = '#00bcd4';\nexport const cyan600 = '#00acc1';\nexport const cyan700 = '#0097a7';\nexport const cyan800 = '#00838f';\nexport const cyan900 = '#006064';\nexport const cyanA100 = '#84ffff';\nexport const cyanA200 = '#18ffff';\nexport const cyanA400 = '#00e5ff';\nexport const cyanA700 = '#00b8d4';\nexport const teal50 = '#e0f2f1';\nexport const teal100 = '#b2dfdb';\nexport const teal200 = '#80cbc4';\nexport const teal300 = '#4db6ac';\nexport const teal400 = '#26a69a';\nexport const teal500 = '#009688';\nexport const teal600 = '#00897b';\nexport const teal700 = '#00796b';\nexport const teal800 = '#00695c';\nexport const teal900 = '#004d40';\nexport const tealA100 = '#a7ffeb';\nexport const tealA200 = '#64ffda';\nexport const tealA400 = '#1de9b6';\nexport const tealA700 = '#00bfa5';\nexport const green50 = '#e8f5e9';\nexport const green100 = '#c8e6c9';\nexport const green200 = '#a5d6a7';\nexport const green300 = '#81c784';\nexport const green400 = '#66bb6a';\nexport const green500 = '#4caf50';\nexport const green600 = '#43a047';\nexport const green700 = '#388e3c';\nexport const green800 = '#2e7d32';\nexport const green900 = '#1b5e20';\nexport const greenA100 = '#b9f6ca';\nexport const greenA200 = '#69f0ae';\nexport const greenA400 = '#00e676';\nexport const greenA700 = '#00c853';\nexport const lightGreen50 = '#f1f8e9';\nexport const lightGreen100 = '#dcedc8';\nexport const lightGreen200 = '#c5e1a5';\nexport const lightGreen300 = '#aed581';\nexport const lightGreen400 = '#9ccc65';\nexport const lightGreen500 = '#8bc34a';\nexport const lightGreen600 = '#7cb342';\nexport const lightGreen700 = '#689f38';\nexport const lightGreen800 = '#558b2f';\nexport const lightGreen900 = '#33691e';\nexport const lightGreenA100 = '#ccff90';\nexport const lightGreenA200 = '#b2ff59';\nexport const lightGreenA400 = '#76ff03';\nexport const lightGreenA700 = '#64dd17';\nexport const lime50 = '#f9fbe7';\nexport const lime100 = '#f0f4c3';\nexport const lime200 = '#e6ee9c';\nexport const lime300 = '#dce775';\nexport const lime400 = '#d4e157';\nexport const lime500 = '#cddc39';\nexport const lime600 = '#c0ca33';\nexport const lime700 = '#afb42b';\nexport const lime800 = '#9e9d24';\nexport const lime900 = '#827717';\nexport const limeA100 = '#f4ff81';\nexport const limeA200 = '#eeff41';\nexport const limeA400 = '#c6ff00';\nexport const limeA700 = '#aeea00';\nexport const yellow50 = '#fffde7';\nexport const yellow100 = '#fff9c4';\nexport const yellow200 = '#fff59d';\nexport const yellow300 = '#fff176';\nexport const yellow400 = '#ffee58';\nexport const yellow500 = '#ffeb3b';\nexport const yellow600 = '#fdd835';\nexport const yellow700 = '#fbc02d';\nexport const yellow800 = '#f9a825';\nexport const yellow900 = '#f57f17';\nexport const yellowA100 = '#ffff8d';\nexport const yellowA200 = '#ffff00';\nexport const yellowA400 = '#ffea00';\nexport const yellowA700 = '#ffd600';\nexport const amber50 = '#fff8e1';\nexport const amber100 = '#ffecb3';\nexport const amber200 = '#ffe082';\nexport const amber300 = '#ffd54f';\nexport const amber400 = '#ffca28';\nexport const amber500 = '#ffc107';\nexport const amber600 = '#ffb300';\nexport const amber700 = '#ffa000';\nexport const amber800 = '#ff8f00';\nexport const amber900 = '#ff6f00';\nexport const amberA100 = '#ffe57f';\nexport const amberA200 = '#ffd740';\nexport const amberA400 = '#ffc400';\nexport const amberA700 = '#ffab00';\nexport const orange50 = '#fff3e0';\nexport const orange100 = '#ffe0b2';\nexport const orange200 = '#ffcc80';\nexport const orange300 = '#ffb74d';\nexport const orange400 = '#ffa726';\nexport const orange500 = '#ff9800';\nexport const orange600 = '#fb8c00';\nexport const orange700 = '#f57c00';\nexport const orange800 = '#ef6c00';\nexport const orange900 = '#e65100';\nexport const orangeA100 = '#ffd180';\nexport const orangeA200 = '#ffab40';\nexport const orangeA400 = '#ff9100';\nexport const orangeA700 = '#ff6d00';\nexport const deepOrange50 = '#fbe9e7';\nexport const deepOrange100 = '#ffccbc';\nexport const deepOrange200 = '#ffab91';\nexport const deepOrange300 = '#ff8a65';\nexport const deepOrange400 = '#ff7043';\nexport const deepOrange500 = '#ff5722';\nexport const deepOrange600 = '#f4511e';\nexport const deepOrange700 = '#e64a19';\nexport const deepOrange800 = '#d84315';\nexport const deepOrange900 = '#bf360c';\nexport const deepOrangeA100 = '#ff9e80';\nexport const deepOrangeA200 = '#ff6e40';\nexport const deepOrangeA400 = '#ff3d00';\nexport const deepOrangeA700 = '#dd2c00';\nexport const brown50 = '#efebe9';\nexport const brown100 = '#d7ccc8';\nexport const brown200 = '#bcaaa4';\nexport const brown300 = '#a1887f';\nexport const brown400 = '#8d6e63';\nexport const brown500 = '#795548';\nexport const brown600 = '#6d4c41';\nexport const brown700 = '#5d4037';\nexport const brown800 = '#4e342e';\nexport const brown900 = '#3e2723';\nexport const blueGrey50 = '#eceff1';\nexport const blueGrey100 = '#cfd8dc';\nexport const blueGrey200 = '#b0bec5';\nexport const blueGrey300 = '#90a4ae';\nexport const blueGrey400 = '#78909c';\nexport const blueGrey500 = '#607d8b';\nexport const blueGrey600 = '#546e7a';\nexport const blueGrey700 = '#455a64';\nexport const blueGrey800 = '#37474f';\nexport const blueGrey900 = '#263238';\nexport const grey50 = '#fafafa';\nexport const grey100 = '#f5f5f5';\nexport const grey200 = '#eeeeee';\nexport const grey300 = '#e0e0e0';\nexport const grey400 = '#bdbdbd';\nexport const grey500 = '#9e9e9e';\nexport const grey600 = '#757575';\nexport const grey700 = '#616161';\nexport const grey800 = '#424242';\nexport const grey900 = '#212121';\nexport const black = '#000000';\nexport const white = '#ffffff';\n//# sourceMappingURL=colors.js.map","import MaterialCommunityIcons from './build/MaterialCommunityIcons';\nexport default MaterialCommunityIcons;\n","import createIconSet from './createIconSet';\nimport font from './vendor/react-native-vector-icons/Fonts/MaterialCommunityIcons.ttf';\nimport glyphMap from './vendor/react-native-vector-icons/glyphmaps/MaterialCommunityIcons.json';\nexport default createIconSet(glyphMap, 'material-community', font);\n//# sourceMappingURL=MaterialCommunityIcons.js.map","import * as Font from 'expo-font';\nimport React from 'react';\nimport { Text, } from 'react-native';\nimport createIconSet from './vendor/react-native-vector-icons/lib/create-icon-set';\nimport createIconButtonComponent from './vendor/react-native-vector-icons/lib/icon-button';\nexport { DEFAULT_ICON_COLOR, DEFAULT_ICON_SIZE, } from './vendor/react-native-vector-icons/lib/create-icon-set';\nexport default function (glyphMap, fontName, expoAssetId, fontStyle) {\n const font = { [fontName]: expoAssetId };\n const RNVIconComponent = createIconSet(glyphMap, fontName, null, fontStyle);\n return class Icon extends React.Component {\n static defaultProps = RNVIconComponent.defaultProps;\n static Button = createIconButtonComponent(Icon);\n static glyphMap = glyphMap;\n static getRawGlyphMap = () => glyphMap;\n static getFontFamily = () => fontName;\n static loadFont = () => Font.loadAsync(font);\n static font = font;\n _mounted = false;\n _icon;\n state = {\n fontIsLoaded: Font.isLoaded(fontName),\n };\n async componentDidMount() {\n this._mounted = true;\n if (!this.state.fontIsLoaded) {\n await Font.loadAsync(font);\n /* eslint-disable react/no-did-mount-set-state */\n this._mounted && this.setState({ fontIsLoaded: true });\n }\n }\n componentWillUnmount() {\n this._mounted = false;\n }\n setNativeProps(props) {\n if (this._icon) {\n this._icon.setNativeProps(props);\n }\n }\n render() {\n if (__DEV__ && this.props.name && !(this.props.name in glyphMap)) {\n console.warn(`\"${this.props.name}\" is not a valid icon name for family \"${fontName}\"`);\n }\n if (!this.state.fontIsLoaded) {\n return ;\n }\n return ( {\n this._icon = view;\n }} {...this.props}/>);\n }\n };\n}\n//# sourceMappingURL=createIconSet.js.map","export * from './Font';\nexport { useFonts } from './FontHooks';\n//# sourceMappingURL=index.js.map","import { CodedError, Platform, UnavailabilityError } from 'expo-modules-core';\nimport ExpoFontLoader from './ExpoFontLoader';\nimport { FontDisplay } from './Font.types';\nimport { getAssetForSource, loadSingleFontAsync, fontFamilyNeedsScoping, getNativeFontName, } from './FontLoader';\nimport { loaded, loadPromises } from './memory';\nimport { registerStaticFont } from './server';\n// @needsAudit\n// note(brentvatne): at some point we may want to warn if this is called outside of a managed app.\n/**\n * Used to transform font family names to the scoped name. This does not need to\n * be called in standalone or bare apps but it will return unscoped font family\n * names if it is called in those contexts.\n *\n * @param fontFamily Name of font to process.\n * @returns Returns a name processed for use with the [current workflow](https://docs.expo.dev/archive/managed-vs-bare/).\n */\nexport function processFontFamily(fontFamily) {\n if (!fontFamily || !fontFamilyNeedsScoping(fontFamily)) {\n return fontFamily;\n }\n if (!isLoaded(fontFamily)) {\n if (__DEV__) {\n if (isLoading(fontFamily)) {\n console.warn(`You started loading the font \"${fontFamily}\", but used it before it finished loading. You need to wait for Font.loadAsync to complete before using the font.`);\n }\n else {\n console.warn(`fontFamily \"${fontFamily}\" is not a system font and has not been loaded through expo-font.`);\n }\n }\n }\n return `ExpoFont-${getNativeFontName(fontFamily)}`;\n}\n// @needsAudit\n/**\n * Synchronously detect if the font for `fontFamily` has finished loading.\n *\n * @param fontFamily The name used to load the `FontResource`.\n * @return Returns `true` if the font has fully loaded.\n */\nexport function isLoaded(fontFamily) {\n if (Platform.OS === 'web') {\n return fontFamily in loaded || !!ExpoFontLoader.isLoaded(fontFamily);\n }\n return fontFamily in loaded || ExpoFontLoader.customNativeFonts?.includes(fontFamily);\n}\n// @needsAudit\n/**\n * Synchronously detect if the font for `fontFamily` is still being loaded.\n *\n * @param fontFamily The name used to load the `FontResource`.\n * @returns Returns `true` if the font is still loading.\n */\nexport function isLoading(fontFamily) {\n return fontFamily in loadPromises;\n}\n// @needsAudit\n/**\n * Highly efficient method for loading fonts from static or remote resources which can then be used\n * with the platform's native text elements. In the browser this generates a `@font-face` block in\n * a shared style sheet for fonts. No CSS is needed to use this method.\n *\n * @param fontFamilyOrFontMap string or map of values that can be used as the [`fontFamily`](https://reactnative.dev/docs/text#style)\n * style prop with React Native Text elements.\n * @param source the font asset that should be loaded into the `fontFamily` namespace.\n *\n * @return Returns a promise that fulfils when the font has loaded. Often you may want to wrap the\n * method in a `try/catch/finally` to ensure the app continues if the font fails to load.\n */\nexport function loadAsync(fontFamilyOrFontMap, source) {\n // NOTE(EvanBacon): Static render pass on web must be synchronous to collect all fonts.\n // Because of this, `loadAsync` doesn't use the `async` keyword and deviates from the\n // standard Expo SDK style guide.\n const isServer = Platform.OS === 'web' && typeof window === 'undefined';\n if (typeof fontFamilyOrFontMap === 'object') {\n if (source) {\n return Promise.reject(new CodedError(`ERR_FONT_API`, `No fontFamily can be used for the provided source: ${source}. The second argument of \\`loadAsync()\\` can only be used with a \\`string\\` value as the first argument.`));\n }\n const fontMap = fontFamilyOrFontMap;\n const names = Object.keys(fontMap);\n if (isServer) {\n names.map((name) => registerStaticFont(name, fontMap[name]));\n return Promise.resolve();\n }\n return Promise.all(names.map((name) => loadFontInNamespaceAsync(name, fontMap[name]))).then(() => { });\n }\n if (isServer) {\n registerStaticFont(fontFamilyOrFontMap, source);\n return Promise.resolve();\n }\n return loadFontInNamespaceAsync(fontFamilyOrFontMap, source);\n}\nasync function loadFontInNamespaceAsync(fontFamily, source) {\n if (!source) {\n throw new CodedError(`ERR_FONT_SOURCE`, `Cannot load null or undefined font source: { \"${fontFamily}\": ${source} }. Expected asset of type \\`FontSource\\` for fontFamily of name: \"${fontFamily}\"`);\n }\n if (loaded[fontFamily]) {\n return;\n }\n if (loadPromises.hasOwnProperty(fontFamily)) {\n return loadPromises[fontFamily];\n }\n // Important: we want all callers that concurrently try to load the same font to await the same\n // promise. If we're here, we haven't created the promise yet. To ensure we create only one\n // promise in the program, we need to create the promise synchronously without yielding the event\n // loop from this point.\n const asset = getAssetForSource(source);\n loadPromises[fontFamily] = (async () => {\n try {\n await loadSingleFontAsync(fontFamily, asset);\n loaded[fontFamily] = true;\n }\n finally {\n delete loadPromises[fontFamily];\n }\n })();\n await loadPromises[fontFamily];\n}\n// @needsAudit\n/**\n * Unloads all the custom fonts. This is used for testing.\n */\nexport async function unloadAllAsync() {\n if (!ExpoFontLoader.unloadAllAsync) {\n throw new UnavailabilityError('expo-font', 'unloadAllAsync');\n }\n if (Object.keys(loadPromises).length) {\n throw new CodedError(`ERR_UNLOAD`, `Cannot unload fonts while they're still loading: ${Object.keys(loadPromises).join(', ')}`);\n }\n for (const fontFamily of Object.keys(loaded)) {\n delete loaded[fontFamily];\n }\n await ExpoFontLoader.unloadAllAsync();\n}\n// @needsAudit\n/**\n * Unload custom fonts matching the `fontFamily`s and display values provided.\n * Because fonts are automatically unloaded on every platform this is mostly used for testing.\n *\n * @param fontFamilyOrFontMap The name or names of the custom fonts that will be unloaded.\n * @param options When `fontFamilyOrFontMap` is a string, this should be the font source used to load\n * the custom font originally.\n */\nexport async function unloadAsync(fontFamilyOrFontMap, options) {\n if (!ExpoFontLoader.unloadAsync) {\n throw new UnavailabilityError('expo-font', 'unloadAsync');\n }\n if (typeof fontFamilyOrFontMap === 'object') {\n if (options) {\n throw new CodedError(`ERR_FONT_API`, `No fontFamily can be used for the provided options: ${options}. The second argument of \\`unloadAsync()\\` can only be used with a \\`string\\` value as the first argument.`);\n }\n const fontMap = fontFamilyOrFontMap;\n const names = Object.keys(fontMap);\n await Promise.all(names.map((name) => unloadFontInNamespaceAsync(name, fontMap[name])));\n return;\n }\n return await unloadFontInNamespaceAsync(fontFamilyOrFontMap, options);\n}\nasync function unloadFontInNamespaceAsync(fontFamily, options) {\n if (!loaded[fontFamily]) {\n return;\n }\n else {\n delete loaded[fontFamily];\n }\n // Important: we want all callers that concurrently try to load the same font to await the same\n // promise. If we're here, we haven't created the promise yet. To ensure we create only one\n // promise in the program, we need to create the promise synchronously without yielding the event\n // loop from this point.\n const nativeFontName = getNativeFontName(fontFamily);\n if (!nativeFontName) {\n throw new CodedError(`ERR_FONT_FAMILY`, `Cannot unload an empty name`);\n }\n await ExpoFontLoader.unloadAsync(nativeFontName, options);\n}\nexport { FontDisplay };\n//# sourceMappingURL=Font.js.map","import { DeviceEventEmitter } from 'react-native';\nimport { EventEmitter } from './EventEmitter';\nimport NativeModule from './NativeModule';\nimport NativeModulesProxy from './NativeModulesProxy';\nimport { requireNativeViewManager } from './NativeViewManagerAdapter';\nimport Platform from './Platform';\nimport SharedObject from './SharedObject';\nimport { CodedError } from './errors/CodedError';\nimport { UnavailabilityError } from './errors/UnavailabilityError';\nimport './sweet/setUpErrorManager.fx';\nimport './web/index';\nexport { default as uuid } from './uuid';\nexport { DeviceEventEmitter, EventEmitter, NativeModulesProxy, Platform, requireNativeViewManager, \n// Globals\nSharedObject, NativeModule, \n// Errors\nCodedError, UnavailabilityError, };\nexport * from './requireNativeModule';\nexport * from './createWebModule';\nexport * from './TypedArrays.types';\n/**\n * @deprecated renamed to `DeviceEventEmitter`\n */\nexport const SyntheticPlatformEmitter = DeviceEventEmitter;\nexport * from './PermissionsInterface';\nexport * from './PermissionsHook';\nexport * from './Refs';\nexport * from './hooks/useReleasingSharedObject';\nexport * from './reload';\n//# sourceMappingURL=index.js.map","import invariant from 'invariant';\nimport { NativeEventEmitter, Platform } from 'react-native';\nconst nativeEmitterSubscriptionKey = '@@nativeEmitterSubscription@@';\nexport class EventEmitter {\n _listenerCount = 0;\n // @ts-expect-error\n _nativeModule;\n // @ts-expect-error\n _eventEmitter;\n constructor(nativeModule) {\n // If the native module is a new module, just return it back as it's already an event emitter.\n // This is for backwards compatibility until we stop using this legacy class in other packages.\n if (nativeModule.__expo_module_name__) {\n // @ts-expect-error\n return nativeModule;\n }\n this._nativeModule = nativeModule;\n this._eventEmitter = new NativeEventEmitter(nativeModule);\n }\n addListener(eventName, listener) {\n if (!this._listenerCount && Platform.OS !== 'ios' && this._nativeModule.startObserving) {\n this._nativeModule.startObserving();\n }\n this._listenerCount++;\n const nativeEmitterSubscription = this._eventEmitter.addListener(eventName, listener);\n const subscription = {\n [nativeEmitterSubscriptionKey]: nativeEmitterSubscription,\n remove: () => {\n this.removeSubscription(subscription);\n },\n };\n return subscription;\n }\n removeAllListeners(eventName) {\n // @ts-ignore: the EventEmitter interface has been changed in react-native@0.64.0\n const removedListenerCount = this._eventEmitter.listenerCount\n ? // @ts-ignore: this is available since 0.64\n this._eventEmitter.listenerCount(eventName)\n : // @ts-ignore: this is available in older versions\n this._eventEmitter.listeners(eventName).length;\n this._eventEmitter.removeAllListeners(eventName);\n this._listenerCount -= removedListenerCount;\n invariant(this._listenerCount >= 0, `EventEmitter must have a non-negative number of listeners`);\n if (!this._listenerCount && Platform.OS !== 'ios' && this._nativeModule.stopObserving) {\n this._nativeModule.stopObserving();\n }\n }\n removeSubscription(subscription) {\n const nativeEmitterSubscription = subscription[nativeEmitterSubscriptionKey];\n if (!nativeEmitterSubscription) {\n return;\n }\n if ('remove' in nativeEmitterSubscription) {\n nativeEmitterSubscription.remove();\n }\n this._listenerCount--;\n // Ensure that the emitter's internal state remains correct even if `removeSubscription` is\n // called again with the same subscription\n delete subscription[nativeEmitterSubscriptionKey];\n // Release closed-over references to the emitter\n subscription.remove = () => { };\n if (!this._listenerCount && Platform.OS !== 'ios' && this._nativeModule.stopObserving) {\n this._nativeModule.stopObserving();\n }\n }\n emit(eventName, ...params) {\n this._eventEmitter.emit(eventName, ...params);\n }\n}\n//# sourceMappingURL=EventEmitter.js.map","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport NativeEventEmitter from '../../vendor/react-native/EventEmitter/NativeEventEmitter';\nexport default NativeEventEmitter;","import { ensureNativeModulesAreInstalled } from './ensureNativeModulesAreInstalled';\nensureNativeModulesAreInstalled();\nexport default globalThis.expo.NativeModule;\n//# sourceMappingURL=NativeModule.js.map","import { NativeModules, Platform } from 'react-native';\n/**\n * Ensures that the native modules are installed in the current runtime.\n * Otherwise, it synchronously calls a native function that installs them.\n */\nexport function ensureNativeModulesAreInstalled() {\n if (globalThis.expo) {\n return;\n }\n try {\n if (Platform.OS === 'web') {\n // Requiring web folder sets up the `globalThis.expo` object.\n require('./web');\n }\n else {\n // TODO: ExpoModulesCore shouldn't be optional here,\n // but to keep backwards compatibility let's just ignore it in SDK 50.\n // In most cases the modules were already installed from the native side.\n NativeModules.ExpoModulesCore?.installModules();\n }\n }\n catch (error) {\n console.error(`Unable to install Expo modules: ${error}`);\n }\n}\n//# sourceMappingURL=ensureNativeModulesAreInstalled.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport UIManager from '../UIManager';\n\n// NativeModules shim\nvar NativeModules = {\n UIManager\n};\nexport default NativeModules;","export * from './CoreModule';\n//# sourceMappingURL=index.web.js.map","import uuid from '../uuid';\nclass EventEmitter {\n listeners;\n addListener(eventName, listener) {\n if (!this.listeners) {\n this.listeners = new Map();\n }\n if (!this.listeners?.has(eventName)) {\n this.listeners?.set(eventName, new Set());\n }\n this.listeners?.get(eventName)?.add(listener);\n return {\n remove: () => {\n this.removeListener(eventName, listener);\n },\n };\n }\n removeListener(eventName, listener) {\n this.listeners?.get(eventName)?.delete(listener);\n }\n removeAllListeners(eventName) {\n this.listeners?.get(eventName)?.clear();\n }\n emit(eventName, ...args) {\n this.listeners?.get(eventName)?.forEach((listener) => listener(...args));\n }\n listenerCount(eventName) {\n return this.listeners?.get(eventName)?.size ?? 0;\n }\n}\nexport class NativeModule extends EventEmitter {\n ViewPrototype;\n __expo_module_name__;\n}\nclass SharedObject extends EventEmitter {\n release() {\n throw new Error('Method not implemented.');\n }\n}\nglobalThis.expo = {\n EventEmitter,\n NativeModule,\n SharedObject,\n modules: {},\n uuidv4: uuid.v4,\n uuidv5: uuid.v5,\n getViewConfig: () => {\n throw new Error('Method not implemented.');\n },\n reloadAppAsync: async () => {\n window.location.reload();\n },\n};\n//# sourceMappingURL=CoreModule.js.map","export { default } from './uuid';\n//# sourceMappingURL=index.js.map","import sha1 from './lib/sha1';\nimport v35 from './lib/v35';\nimport { Uuidv5Namespace } from './uuid.types';\nfunction uuidv4() {\n // Crypto needs to be required when run in Node.js environment.\n const cryptoObject = typeof crypto === 'undefined' || typeof crypto.randomUUID === 'undefined'\n ? require('crypto')\n : crypto;\n if (!cryptoObject?.randomUUID) {\n throw Error(\"The browser doesn't support `crypto.randomUUID` function\");\n }\n return cryptoObject.randomUUID();\n}\nconst uuid = {\n v4: uuidv4,\n v5: v35('v5', 0x50, sha1),\n namespace: Uuidv5Namespace,\n};\nexport default uuid;\n//# sourceMappingURL=uuid.web.js.map","// Adapted from Chris Veness' SHA1 code at\n// http://www.movable-type.co.uk/scripts/sha1.html\n'use strict';\nfunction f(s, x, y, z) {\n switch (s) {\n case 0:\n return (x & y) ^ (~x & z);\n case 1:\n return x ^ y ^ z;\n case 2:\n return (x & y) ^ (x & z) ^ (y & z);\n case 3:\n return x ^ y ^ z;\n default:\n return 0;\n }\n}\nfunction ROTL(x, n) {\n return (x << n) | (x >>> (32 - n));\n}\nfunction sha1(bytes) {\n const K = [0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6];\n const H = [0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0];\n if (typeof bytes == 'string') {\n const msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n bytes = new Array(msg.length);\n for (let i = 0; i < msg.length; i++)\n bytes[i] = msg.charCodeAt(i);\n }\n bytes.push(0x80);\n const l = bytes.length / 4 + 2;\n const N = Math.ceil(l / 16);\n const M = new Array(N);\n for (let i = 0; i < N; i++) {\n M[i] = new Array(16);\n for (let j = 0; j < 16; j++) {\n M[i][j] =\n (bytes[i * 64 + j * 4] << 24) |\n (bytes[i * 64 + j * 4 + 1] << 16) |\n (bytes[i * 64 + j * 4 + 2] << 8) |\n bytes[i * 64 + j * 4 + 3];\n }\n }\n M[N - 1][14] = ((bytes.length - 1) * 8) / Math.pow(2, 32);\n M[N - 1][14] = Math.floor(M[N - 1][14]);\n M[N - 1][15] = ((bytes.length - 1) * 8) & 0xffffffff;\n for (let i = 0; i < N; i++) {\n const W = new Array(80);\n for (let t = 0; t < 16; t++)\n W[t] = M[i][t];\n for (let t = 16; t < 80; t++) {\n W[t] = ROTL(W[t - 3] ^ W[t - 8] ^ W[t - 14] ^ W[t - 16], 1);\n }\n let a = H[0];\n let b = H[1];\n let c = H[2];\n let d = H[3];\n let e = H[4];\n for (let t = 0; t < 80; t++) {\n const s = Math.floor(t / 20);\n const T = (ROTL(a, 5) + f(s, b, c, d) + e + K[s] + W[t]) >>> 0;\n e = d;\n d = c;\n c = ROTL(b, 30) >>> 0;\n b = a;\n a = T;\n }\n H[0] = (H[0] + a) >>> 0;\n H[1] = (H[1] + b) >>> 0;\n H[2] = (H[2] + c) >>> 0;\n H[3] = (H[3] + d) >>> 0;\n H[4] = (H[4] + e) >>> 0;\n }\n return [\n (H[0] >> 24) & 0xff,\n (H[0] >> 16) & 0xff,\n (H[0] >> 8) & 0xff,\n H[0] & 0xff,\n (H[1] >> 24) & 0xff,\n (H[1] >> 16) & 0xff,\n (H[1] >> 8) & 0xff,\n H[1] & 0xff,\n (H[2] >> 24) & 0xff,\n (H[2] >> 16) & 0xff,\n (H[2] >> 8) & 0xff,\n H[2] & 0xff,\n (H[3] >> 24) & 0xff,\n (H[3] >> 16) & 0xff,\n (H[3] >> 8) & 0xff,\n H[3] & 0xff,\n (H[4] >> 24) & 0xff,\n (H[4] >> 16) & 0xff,\n (H[4] >> 8) & 0xff,\n H[4] & 0xff,\n ];\n}\nexport default sha1;\n//# sourceMappingURL=sha1.js.map","import bytesToUuid from './bytesToUuid';\nfunction uuidToBytes(uuid) {\n // Note: We assume we're being passed a valid uuid string\n const bytes = [];\n uuid.replace(/[a-fA-F0-9]{2}/g, (hex) => {\n bytes.push(parseInt(hex, 16));\n return '';\n });\n return bytes;\n}\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n const bytes = new Array(str.length);\n for (let i = 0; i < str.length; i++) {\n bytes[i] = str.charCodeAt(i);\n }\n return bytes;\n}\nexport default function (name, version, hashfunc) {\n const generateUUID = function (value, namespace, buf, offset) {\n const off = (buf && offset) || 0;\n if (typeof value == 'string')\n value = stringToBytes(value);\n if (typeof namespace == 'string')\n namespace = uuidToBytes(namespace);\n if (!Array.isArray(value))\n throw TypeError('value must be an array of bytes');\n if (!Array.isArray(namespace) || namespace.length !== 16)\n throw TypeError('namespace must be uuid string or an Array of 16 byte values');\n // Per 4.3\n const bytes = hashfunc(namespace.concat(value));\n bytes[6] = (bytes[6] & 0x0f) | version;\n bytes[8] = (bytes[8] & 0x3f) | 0x80;\n if (buf) {\n for (let idx = 0; idx < 16; ++idx) {\n buf[off + idx] = bytes[idx];\n }\n }\n return bytesToUuid(bytes);\n };\n // Function#name is not settable on some platforms (#270)\n try {\n generateUUID.name = name;\n }\n catch { }\n // Pre-defined namespaces, per Appendix C\n generateUUID.DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\n generateUUID.URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\n return generateUUID;\n}\n//# sourceMappingURL=v35.js.map","/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\nconst byteToHex = [];\nfor (let i = 0; i < 256; ++i) {\n byteToHex[i] = (i + 0x100).toString(16).substr(1);\n}\nfunction bytesToUuid(buf, offset) {\n let i = offset || 0;\n const bth = byteToHex;\n // join used to fix memory issue caused by concatenation: https://bugs.chromium.org/p/v8/issues/detail?id=3175#c4\n return [\n bth[buf[i++]],\n bth[buf[i++]],\n bth[buf[i++]],\n bth[buf[i++]],\n '-',\n bth[buf[i++]],\n bth[buf[i++]],\n '-',\n bth[buf[i++]],\n bth[buf[i++]],\n '-',\n bth[buf[i++]],\n bth[buf[i++]],\n '-',\n bth[buf[i++]],\n bth[buf[i++]],\n bth[buf[i++]],\n bth[buf[i++]],\n bth[buf[i++]],\n bth[buf[i++]],\n ].join('');\n}\nexport default bytesToUuid;\n//# sourceMappingURL=bytesToUuid.js.map","/**\n * Default namespaces for UUID v5 defined in RFC 4122\n */\nexport var Uuidv5Namespace;\n(function (Uuidv5Namespace) {\n // Source of the UUIDs: https://datatracker.ietf.org/doc/html/rfc4122\n Uuidv5Namespace[\"dns\"] = \"6ba7b810-9dad-11d1-80b4-00c04fd430c8\";\n Uuidv5Namespace[\"url\"] = \"6ba7b811-9dad-11d1-80b4-00c04fd430c8\";\n Uuidv5Namespace[\"oid\"] = \"6ba7b812-9dad-11d1-80b4-00c04fd430c8\";\n Uuidv5Namespace[\"x500\"] = \"6ba7b814-9dad-11d1-80b4-00c04fd430c8\";\n})(Uuidv5Namespace || (Uuidv5Namespace = {}));\n//# sourceMappingURL=uuid.types.js.map","\"use strict\";\n","// We default to an empty object shim wherever we don't have an environment-specific implementation\n/**\n * @deprecated `NativeModulesProxy` is deprecated and might be removed in the future releases.\n * Use `requireNativeModule` or `requireOptionalNativeModule` instead.\n */\nexport default {};\n//# sourceMappingURL=NativeModulesProxy.js.map","import { UnavailabilityError } from './errors/UnavailabilityError';\n/**\n * A drop-in replacement for `requireNativeComponent`.\n */\nexport function requireNativeViewManager(viewName) {\n throw new UnavailabilityError('expo-modules-core', 'requireNativeViewManager');\n}\n//# sourceMappingURL=NativeViewManagerAdapter.js.map","import { CodedError } from './CodedError';\nimport Platform from '../Platform';\n/**\n * A class for errors to be thrown when a property is accessed which is\n * unavailable, unsupported, or not currently implemented on the running\n * platform.\n */\nexport class UnavailabilityError extends CodedError {\n constructor(moduleName, propertyName) {\n super('ERR_UNAVAILABLE', `The method or property ${moduleName}.${propertyName} is not available on ${Platform.OS}, are you sure you've linked all the native dependencies properly?`);\n }\n}\n//# sourceMappingURL=UnavailabilityError.js.map","/**\n * A general error class that should be used for all errors in Expo modules.\n * Guarantees a `code` field that can be used to differentiate between different\n * types of errors without further subclassing Error.\n */\nexport class CodedError extends Error {\n code;\n info;\n constructor(code, message) {\n super(message);\n this.code = code;\n }\n}\n//# sourceMappingURL=CodedError.js.map","import { Platform as ReactNativePlatform } from 'react-native';\nimport { isDOMAvailable, canUseEventListeners, canUseViewport, isAsyncDebugging, } from './environment/browser';\nconst Platform = {\n /**\n * Denotes the currently running platform.\n * Can be one of ios, android, web.\n */\n OS: ReactNativePlatform.OS,\n /**\n * Returns the value with the matching platform.\n * Object keys can be any of ios, android, native, web, default.\n *\n * @ios ios, native, default\n * @android android, native, default\n * @web web, default\n */\n select: ReactNativePlatform.select,\n /**\n * Denotes if the DOM API is available in the current environment.\n * The DOM is not available in native React runtimes and Node.js.\n */\n isDOMAvailable,\n /**\n * Denotes if the current environment can attach event listeners\n * to the window. This will return false in native React\n * runtimes and Node.js.\n */\n canUseEventListeners,\n /**\n * Denotes if the current environment can inspect properties of the\n * screen on which the current window is being rendered. This will\n * return false in native React runtimes and Node.js.\n */\n canUseViewport,\n /**\n * If the JavaScript is being executed in a remote JavaScript environment.\n * When `true`, synchronous native invocations cannot be executed.\n */\n isAsyncDebugging,\n};\nexport default Platform;\n//# sourceMappingURL=Platform.js.map","// Used for delegating node actions when browser APIs aren't available\n// like in SSR websites.\nexport const isDOMAvailable = typeof window !== 'undefined' && !!window.document?.createElement;\nexport const canUseEventListeners = isDOMAvailable && !!(window.addEventListener || window.attachEvent);\nexport const canUseViewport = isDOMAvailable && !!window.screen;\nexport const isAsyncDebugging = false;\n//# sourceMappingURL=browser.web.js.map","import { ensureNativeModulesAreInstalled } from './ensureNativeModulesAreInstalled';\nensureNativeModulesAreInstalled();\nexport default globalThis.expo.SharedObject;\n//# sourceMappingURL=SharedObject.js.map","//# sourceMappingURL=setUpErrorManager.fx.web.js.map","export function requireNativeModule(moduleName) {\n throw new Error(`Cannot find native module '${moduleName}'`);\n}\nexport function requireOptionalNativeModule() {\n return null;\n}\n//# sourceMappingURL=requireNativeModule.web.js.map","import { NativeModule } from './web/CoreModule';\nexport function createWebModule(moduleImplementation) {\n const module = new NativeModule();\n return Object.assign(module, moduleImplementation);\n}\n//# sourceMappingURL=createWebModule.web.js.map","export {};\n//# sourceMappingURL=TypedArrays.types.js.map","export var PermissionStatus;\n(function (PermissionStatus) {\n /**\n * User has granted the permission.\n */\n PermissionStatus[\"GRANTED\"] = \"granted\";\n /**\n * User hasn't granted or denied the permission yet.\n */\n PermissionStatus[\"UNDETERMINED\"] = \"undetermined\";\n /**\n * User has denied the permission.\n */\n PermissionStatus[\"DENIED\"] = \"denied\";\n})(PermissionStatus || (PermissionStatus = {}));\n//# sourceMappingURL=PermissionsInterface.js.map","// Copyright © 2024 650 Industries.\n'use client';\nimport { useCallback, useEffect, useRef, useState } from 'react';\n/**\n * Get or request permission for protected functionality within the app.\n * It uses separate permission requesters to interact with a single permission.\n * By default, the hook will only retrieve the permission status.\n */\nfunction usePermission(methods, options) {\n const isMounted = useRef(true);\n const [status, setStatus] = useState(null);\n const { get = true, request = false, ...permissionOptions } = options || {};\n const getPermission = useCallback(async () => {\n const response = await methods.getMethod(Object.keys(permissionOptions).length > 0 ? permissionOptions : undefined);\n if (isMounted.current)\n setStatus(response);\n return response;\n }, [methods.getMethod]);\n const requestPermission = useCallback(async () => {\n const response = await methods.requestMethod(Object.keys(permissionOptions).length > 0 ? permissionOptions : undefined);\n if (isMounted.current)\n setStatus(response);\n return response;\n }, [methods.requestMethod]);\n useEffect(function runMethods() {\n if (request)\n requestPermission();\n if (!request && get)\n getPermission();\n }, [get, request, requestPermission, getPermission]);\n // Workaround for unmounting components receiving state updates\n useEffect(function didMount() {\n isMounted.current = true;\n return () => {\n isMounted.current = false;\n };\n }, []);\n return [status, requestPermission, getPermission];\n}\n/**\n * Create a new permission hook with the permission methods built-in.\n * This can be used to quickly create specific permission hooks in every module.\n */\nexport function createPermissionHook(methods) {\n return (options) => usePermission(methods, options);\n}\n//# sourceMappingURL=PermissionsHook.js.map","import React from 'react';\n/**\n * Create a React ref object that is friendly for snapshots.\n * It will be represented as `[React.ref]` in snapshots.\n * @returns a React ref object.\n */\nexport function createSnapshotFriendlyRef() {\n return React.createRef();\n}\n//# sourceMappingURL=Refs.js.map","import { useRef, useMemo, useEffect } from 'react';\n/**\n * Returns a shared object, which is automatically cleaned up when the component is unmounted.\n */\nexport function useReleasingSharedObject(factory, dependencies) {\n const objectRef = useRef(null);\n const isFastRefresh = useRef(false);\n const previousDependencies = useRef(dependencies);\n if (objectRef.current == null) {\n objectRef.current = factory();\n }\n const object = useMemo(() => {\n let newObject = objectRef.current;\n const dependenciesAreEqual = previousDependencies.current?.length === dependencies.length &&\n dependencies.every((value, index) => value === previousDependencies.current[index]);\n // If the dependencies have changed, release the previous object and create a new one, otherwise this has been called\n // because of a fast refresh, and we don't want to release the object.\n if (!newObject || !dependenciesAreEqual) {\n objectRef.current?.release();\n newObject = factory();\n objectRef.current = newObject;\n previousDependencies.current = dependencies;\n }\n else {\n isFastRefresh.current = true;\n }\n return newObject;\n }, dependencies);\n useEffect(() => {\n isFastRefresh.current = false;\n return () => {\n // This will be called on every fast refresh and on unmount, but we only want to release the object on unmount.\n if (!isFastRefresh.current && objectRef.current) {\n objectRef.current.release();\n }\n };\n }, []);\n return object;\n}\n//# sourceMappingURL=useReleasingSharedObject.js.map","/**\n * Reloads the app.\n *\n * This function works for both release and debug builds.\n *\n * Unlike [`Updates.reloadAsync()`](https://docs.expo.dev/versions/latest/sdk/updates/#updatesreloadasync),\n * this function does not use a new update even if one is available. It only reloads the app using the same JavaScript bundle that is currently running.\n *\n * @param reason The reason for reloading the app. This is used only for some platforms.\n */\nexport async function reloadAppAsync(reason = 'Reloaded from JS call') {\n await globalThis.expo?.reloadAppAsync(reason);\n}\n//# sourceMappingURL=reload.js.map","import { CodedError, Platform } from 'expo-modules-core';\nimport FontObserver from 'fontfaceobserver';\nimport { FontDisplay } from './Font.types';\nfunction getFontFaceStyleSheet() {\n if (!Platform.isDOMAvailable) {\n return null;\n }\n const styleSheet = getStyleElement();\n return styleSheet.sheet ? styleSheet.sheet : null;\n}\nfunction getFontFaceRules() {\n const sheet = getFontFaceStyleSheet();\n if (sheet) {\n // @ts-ignore: rule iterator\n const rules = [...sheet.cssRules];\n const items = [];\n for (let i = 0; i < rules.length; i++) {\n const rule = rules[i];\n if (rule instanceof CSSFontFaceRule) {\n items.push({ rule, index: i });\n }\n }\n return items;\n }\n return [];\n}\nfunction getFontFaceRulesMatchingResource(fontFamilyName, options) {\n const rules = getFontFaceRules();\n return rules.filter(({ rule }) => {\n return (rule.style.fontFamily === fontFamilyName &&\n (options && options.display ? options.display === rule.style.fontDisplay : true));\n });\n}\nconst serverContext = new Set();\nfunction getHeadElements() {\n const entries = [...serverContext.entries()];\n if (!entries.length) {\n return [];\n }\n const css = entries.map(([{ css }]) => css).join('\\n');\n const links = entries.map(([{ resourceId }]) => resourceId);\n // TODO: Maybe return nothing if no fonts were loaded.\n return [\n {\n $$type: 'style',\n children: css,\n id: ID,\n type: 'text/css',\n },\n ...links.map((resourceId) => ({\n $$type: 'link',\n rel: 'preload',\n href: resourceId,\n as: 'font',\n crossorigin: '',\n })),\n ];\n}\nexport default {\n async unloadAllAsync() {\n if (!Platform.isDOMAvailable)\n return;\n const element = document.getElementById(ID);\n if (element && element instanceof HTMLStyleElement) {\n document.removeChild(element);\n }\n },\n async unloadAsync(fontFamilyName, options) {\n const sheet = getFontFaceStyleSheet();\n if (!sheet)\n return;\n const items = getFontFaceRulesMatchingResource(fontFamilyName, options);\n for (const item of items) {\n sheet.deleteRule(item.index);\n }\n },\n getServerResources() {\n const elements = getHeadElements();\n return elements\n .map((element) => {\n switch (element.$$type) {\n case 'style':\n return ``;\n case 'link':\n return ``;\n default:\n return '';\n }\n })\n .filter(Boolean);\n },\n resetServerContext() {\n serverContext.clear();\n },\n isLoaded(fontFamilyName, resource = {}) {\n if (typeof window === 'undefined') {\n return !![...serverContext.values()].find((asset) => {\n return asset.name === fontFamilyName;\n });\n }\n return getFontFaceRulesMatchingResource(fontFamilyName, resource)?.length > 0;\n },\n // NOTE(EvanBacon): No async keyword! This cannot return a promise in Node environments.\n loadAsync(fontFamilyName, resource) {\n if (typeof window === 'undefined') {\n serverContext.add({\n name: fontFamilyName,\n css: _createWebFontTemplate(fontFamilyName, resource),\n // @ts-expect-error: typeof string\n resourceId: resource.uri,\n });\n return Promise.resolve();\n }\n const canInjectStyle = document.head && typeof document.head.appendChild === 'function';\n if (!canInjectStyle) {\n throw new CodedError('ERR_WEB_ENVIRONMENT', `The browser's \\`document.head\\` element doesn't support injecting fonts.`);\n }\n const style = getStyleElement();\n document.head.appendChild(style);\n const res = getFontFaceRulesMatchingResource(fontFamilyName, resource);\n if (!res.length) {\n _createWebStyle(fontFamilyName, resource);\n }\n if (!isFontLoadingListenerSupported()) {\n return Promise.resolve();\n }\n return new FontObserver(fontFamilyName, { display: resource.display }).load(null, 6000);\n },\n};\nconst ID = 'expo-generated-fonts';\nfunction getStyleElement() {\n const element = document.getElementById(ID);\n if (element && element instanceof HTMLStyleElement) {\n return element;\n }\n const styleElement = document.createElement('style');\n styleElement.id = ID;\n styleElement.type = 'text/css';\n return styleElement;\n}\nexport function _createWebFontTemplate(fontFamily, resource) {\n return `@font-face{font-family:${fontFamily};src:url(${resource.uri});font-display:${resource.display || FontDisplay.AUTO}}`;\n}\nfunction _createWebStyle(fontFamily, resource) {\n const fontStyle = _createWebFontTemplate(fontFamily, resource);\n const styleElement = getStyleElement();\n // @ts-ignore: TypeScript does not define HTMLStyleElement::styleSheet. This is just for IE and\n // possibly can be removed if it's unnecessary on IE 11.\n if (styleElement.styleSheet) {\n const styleElementIE = styleElement;\n styleElementIE.styleSheet.cssText = styleElementIE.styleSheet.cssText\n ? styleElementIE.styleSheet.cssText + fontStyle\n : fontStyle;\n }\n else {\n const textNode = document.createTextNode(fontStyle);\n styleElement.appendChild(textNode);\n }\n return styleElement;\n}\nfunction isFontLoadingListenerSupported() {\n const { userAgent } = window.navigator;\n // WebKit is broken https://github.com/bramstein/fontfaceobserver/issues/95\n const isIOS = !!userAgent.match(/iPad|iPhone/i);\n const isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\n // Edge is broken https://github.com/bramstein/fontfaceobserver/issues/109#issuecomment-333356795\n const isEdge = userAgent.includes('Edge');\n // Internet Explorer\n const isIE = userAgent.includes('Trident');\n // Firefox\n const isFirefox = userAgent.includes('Firefox');\n return !isSafari && !isIOS && !isEdge && !isIE && !isFirefox;\n}\n//# sourceMappingURL=ExpoFontLoader.web.js.map","/* Font Face Observer v2.3.0 - © Bram Stein. License: BSD-3-Clause */(function(){function p(a,c){document.addEventListener?a.addEventListener(\"scroll\",c,!1):a.attachEvent(\"scroll\",c)}function u(a){document.body?a():document.addEventListener?document.addEventListener(\"DOMContentLoaded\",function b(){document.removeEventListener(\"DOMContentLoaded\",b);a()}):document.attachEvent(\"onreadystatechange\",function g(){if(\"interactive\"==document.readyState||\"complete\"==document.readyState)document.detachEvent(\"onreadystatechange\",g),a()})};function w(a){this.g=document.createElement(\"div\");this.g.setAttribute(\"aria-hidden\",\"true\");this.g.appendChild(document.createTextNode(a));this.h=document.createElement(\"span\");this.i=document.createElement(\"span\");this.m=document.createElement(\"span\");this.j=document.createElement(\"span\");this.l=-1;this.h.style.cssText=\"max-width:none;display:inline-block;position:absolute;height:100%;width:100%;overflow:scroll;font-size:16px;\";this.i.style.cssText=\"max-width:none;display:inline-block;position:absolute;height:100%;width:100%;overflow:scroll;font-size:16px;\";\nthis.j.style.cssText=\"max-width:none;display:inline-block;position:absolute;height:100%;width:100%;overflow:scroll;font-size:16px;\";this.m.style.cssText=\"display:inline-block;width:200%;height:200%;font-size:16px;max-width:none;\";this.h.appendChild(this.m);this.i.appendChild(this.j);this.g.appendChild(this.h);this.g.appendChild(this.i)}\nfunction x(a,c){a.g.style.cssText=\"max-width:none;min-width:20px;min-height:20px;display:inline-block;overflow:hidden;position:absolute;width:auto;margin:0;padding:0;top:-999px;white-space:nowrap;font-synthesis:none;font:\"+c+\";\"}function B(a){var c=a.g.offsetWidth,b=c+100;a.j.style.width=b+\"px\";a.i.scrollLeft=b;a.h.scrollLeft=a.h.scrollWidth+100;return a.l!==c?(a.l=c,!0):!1}function C(a,c){function b(){var e=g;B(e)&&null!==e.g.parentNode&&c(e.l)}var g=a;p(a.h,b);p(a.i,b);B(a)};function D(a,c,b){c=c||{};b=b||window;this.family=a;this.style=c.style||\"normal\";this.weight=c.weight||\"normal\";this.stretch=c.stretch||\"normal\";this.context=b}var E=null,F=null,G=null,H=null;function I(a){null===F&&(M(a)&&/Apple/.test(window.navigator.vendor)?(a=/AppleWebKit\\/([0-9]+)(?:\\.([0-9]+))(?:\\.([0-9]+))/.exec(window.navigator.userAgent),F=!!a&&603>parseInt(a[1],10)):F=!1);return F}function M(a){null===H&&(H=!!a.document.fonts);return H}\nfunction N(a,c){var b=a.style,g=a.weight;if(null===G){var e=document.createElement(\"div\");try{e.style.font=\"condensed 100px sans-serif\"}catch(q){}G=\"\"!==e.style.font}return[b,g,G?a.stretch:\"\",\"100px\",c].join(\" \")}\nD.prototype.load=function(a,c){var b=this,g=a||\"BESbswy\",e=0,q=c||3E3,J=(new Date).getTime();return new Promise(function(K,L){if(M(b.context)&&!I(b.context)){var O=new Promise(function(r,t){function h(){(new Date).getTime()-J>=q?t(Error(\"\"+q+\"ms timeout exceeded\")):b.context.document.fonts.load(N(b,'\"'+b.family+'\"'),g).then(function(n){1<=n.length?r():setTimeout(h,25)},t)}h()}),P=new Promise(function(r,t){e=setTimeout(function(){t(Error(\"\"+q+\"ms timeout exceeded\"))},q)});Promise.race([P,O]).then(function(){clearTimeout(e);\nK(b)},L)}else u(function(){function r(){var d;if(d=-1!=k&&-1!=l||-1!=k&&-1!=m||-1!=l&&-1!=m)(d=k!=l&&k!=m&&l!=m)||(null===E&&(d=/AppleWebKit\\/([0-9]+)(?:\\.([0-9]+))/.exec(window.navigator.userAgent),E=!!d&&(536>parseInt(d[1],10)||536===parseInt(d[1],10)&&11>=parseInt(d[2],10))),d=E&&(k==y&&l==y&&m==y||k==z&&l==z&&m==z||k==A&&l==A&&m==A)),d=!d;d&&(null!==f.parentNode&&f.parentNode.removeChild(f),clearTimeout(e),K(b))}function t(){if((new Date).getTime()-J>=q)null!==f.parentNode&&f.parentNode.removeChild(f),\nL(Error(\"\"+q+\"ms timeout exceeded\"));else{var d=b.context.document.hidden;if(!0===d||void 0===d)k=h.g.offsetWidth,l=n.g.offsetWidth,m=v.g.offsetWidth,r();e=setTimeout(t,50)}}var h=new w(g),n=new w(g),v=new w(g),k=-1,l=-1,m=-1,y=-1,z=-1,A=-1,f=document.createElement(\"div\");f.dir=\"ltr\";x(h,N(b,\"sans-serif\"));x(n,N(b,\"serif\"));x(v,N(b,\"monospace\"));f.appendChild(h.g);f.appendChild(n.g);f.appendChild(v.g);b.context.document.body.appendChild(f);y=h.g.offsetWidth;z=n.g.offsetWidth;A=v.g.offsetWidth;t();\nC(h,function(d){k=d;r()});x(h,N(b,'\"'+b.family+'\",sans-serif'));C(n,function(d){l=d;r()});x(n,N(b,'\"'+b.family+'\",serif'));C(v,function(d){m=d;r()});x(v,N(b,'\"'+b.family+'\",monospace'))})})};\"object\"===typeof module?module.exports=D:(window.FontFaceObserver=D,window.FontFaceObserver.prototype.load=D.prototype.load);}());\n","// @needsAudit\n/**\n * Sets the [font-display](https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display)\n * for a given typeface. The default font value on web is `FontDisplay.AUTO`.\n * Even though setting the `fontDisplay` does nothing on native platforms, the default behavior\n * emulates `FontDisplay.SWAP` on flagship devices like iOS, Samsung, Pixel, etc. Default\n * functionality varies on One Plus devices. In the browser this value is set in the generated\n * `@font-face` CSS block and not as a style property meaning you cannot dynamically change this\n * value based on the element it's used in.\n * @platform web\n */\nexport var FontDisplay;\n(function (FontDisplay) {\n /**\n * __(Default)__ The font display strategy is defined by the user agent or platform.\n * This generally defaults to the text being invisible until the font is loaded.\n * Good for buttons or banners that require a specific treatment.\n */\n FontDisplay[\"AUTO\"] = \"auto\";\n /**\n * Fallback text is rendered immediately with a default font while the desired font is loaded.\n * This is good for making the content appear to load instantly and is usually preferred.\n */\n FontDisplay[\"SWAP\"] = \"swap\";\n /**\n * The text will be invisible until the font has loaded. If the font fails to load then nothing\n * will appear - it's best to turn this off when debugging missing text.\n */\n FontDisplay[\"BLOCK\"] = \"block\";\n /**\n * Splits the behavior between `SWAP` and `BLOCK`.\n * There will be a [100ms timeout](https://developers.google.com/web/updates/2016/02/font-display?hl=en)\n * where the text with a custom font is invisible, after that the text will either swap to the\n * styled text or it'll show the unstyled text and continue to load the custom font. This is good\n * for buttons that need a custom font but should also be quickly available to screen-readers.\n */\n FontDisplay[\"FALLBACK\"] = \"fallback\";\n /**\n * This works almost identically to `FALLBACK`, the only difference is that the browser will\n * decide to load the font based on slow connection speed or critical resource demand.\n */\n FontDisplay[\"OPTIONAL\"] = \"optional\";\n})(FontDisplay || (FontDisplay = {}));\n//# sourceMappingURL=Font.types.js.map","import { Asset } from 'expo-asset';\nimport { CodedError } from 'expo-modules-core';\nimport ExpoFontLoader from './ExpoFontLoader';\nimport { FontDisplay } from './Font.types';\nfunction uriFromFontSource(asset) {\n if (typeof asset === 'string') {\n return asset || null;\n }\n else if (typeof asset === 'object') {\n return asset.uri || asset.localUri || asset.default || null;\n }\n else if (typeof asset === 'number') {\n return uriFromFontSource(Asset.fromModule(asset));\n }\n return null;\n}\nfunction displayFromFontSource(asset) {\n return asset.display || FontDisplay.AUTO;\n}\nexport function fontFamilyNeedsScoping(name) {\n return false;\n}\nexport function getAssetForSource(source) {\n const uri = uriFromFontSource(source);\n const display = displayFromFontSource(source);\n if (!uri || typeof uri !== 'string') {\n throwInvalidSourceError(uri);\n }\n return {\n uri: uri,\n display,\n };\n}\nfunction throwInvalidSourceError(source) {\n let type = typeof source;\n if (type === 'object')\n type = JSON.stringify(source, null, 2);\n throw new CodedError(`ERR_FONT_SOURCE`, `Expected font asset of type \\`string | FontResource | Asset\\` instead got: ${type}`);\n}\n// NOTE(EvanBacon): No async keyword!\nexport function loadSingleFontAsync(name, input) {\n if (typeof input !== 'object' || typeof input.uri !== 'string' || input.downloadAsync) {\n throwInvalidSourceError(input);\n }\n try {\n return ExpoFontLoader.loadAsync(name, input);\n }\n catch {\n // No-op.\n }\n return Promise.resolve();\n}\nexport function getNativeFontName(name) {\n return name;\n}\n//# sourceMappingURL=FontLoader.web.js.map","import './Asset.fx';\nexport * from './Asset';\nexport * from './AssetHooks';\n//# sourceMappingURL=index.js.map","import { Asset } from './Asset';\nimport { IS_ENV_WITH_LOCAL_ASSETS } from './PlatformUtils';\nimport { setCustomSourceTransformer } from './resolveAssetSource';\n// Override React Native's asset resolution for `Image` components in contexts where it matters\nif (IS_ENV_WITH_LOCAL_ASSETS) {\n setCustomSourceTransformer((resolver) => {\n try {\n // Bundler is using the hashAssetFiles plugin if and only if the fileHashes property exists\n if (resolver.asset.fileHashes) {\n const asset = Asset.fromMetadata(resolver.asset);\n return resolver.fromSource(asset.downloaded ? asset.localUri : asset.uri);\n }\n else {\n return resolver.defaultAsset();\n }\n }\n catch {\n return resolver.defaultAsset();\n }\n });\n}\n//# sourceMappingURL=Asset.fx.js.map","import { getAssetByID } from '@react-native/assets-registry/registry';\nimport { Platform } from 'expo-modules-core';\nimport { selectAssetSource } from './AssetSources';\nimport * as AssetUris from './AssetUris';\nimport { downloadAsync } from './ExpoAsset';\nimport * as ImageAssets from './ImageAssets';\nimport { getLocalAssetUri } from './LocalAssets';\nimport { IS_ENV_WITH_LOCAL_ASSETS } from './PlatformUtils';\nimport resolveAssetSource from './resolveAssetSource';\n/**\n * The `Asset` class represents an asset in your app. It gives metadata about the asset (such as its\n * name and type) and provides facilities to load the asset data.\n */\nexport class Asset {\n static byHash = {};\n static byUri = {};\n /**\n * The name of the asset file without the extension. Also without the part from `@` onward in the\n * filename (used to specify scale factor for images).\n */\n name;\n /**\n * The extension of the asset filename.\n */\n type;\n /**\n * The MD5 hash of the asset's data.\n */\n hash = null;\n /**\n * A URI that points to the asset's data on the remote server. When running the published version\n * of your app, this refers to the location on Expo's asset server where Expo has stored your\n * asset. When running the app from Expo CLI during development, this URI points to Expo CLI's\n * server running on your computer and the asset is served directly from your computer. If you\n * are not using Classic Updates (legacy), this field should be ignored as we ensure your assets\n * are on device before before running your application logic.\n */\n uri;\n /**\n * If the asset has been downloaded (by calling [`downloadAsync()`](#downloadasync)), the\n * `file://` URI pointing to the local file on the device that contains the asset data.\n */\n localUri = null;\n /**\n * If the asset is an image, the width of the image data divided by the scale factor. The scale\n * factor is the number after `@` in the filename, or `1` if not present.\n */\n width = null;\n /**\n * If the asset is an image, the height of the image data divided by the scale factor. The scale factor is the number after `@` in the filename, or `1` if not present.\n */\n height = null;\n downloading = false;\n /**\n * Whether the asset has finished downloading from a call to [`downloadAsync()`](#downloadasync).\n */\n downloaded = false;\n _downloadCallbacks = [];\n constructor({ name, type, hash = null, uri, width, height }) {\n this.name = name;\n this.type = type;\n this.hash = hash;\n this.uri = uri;\n if (typeof width === 'number') {\n this.width = width;\n }\n if (typeof height === 'number') {\n this.height = height;\n }\n if (hash) {\n this.localUri = getLocalAssetUri(hash, type);\n if (this.localUri) {\n this.downloaded = true;\n }\n }\n if (Platform.OS === 'web') {\n if (!name) {\n this.name = AssetUris.getFilename(uri);\n }\n if (!type) {\n this.type = AssetUris.getFileExtension(uri);\n }\n }\n }\n // @needsAudit\n /**\n * A helper that wraps `Asset.fromModule(module).downloadAsync` for convenience.\n * @param moduleId An array of `require('path/to/file')` or external network URLs. Can also be\n * just one module or URL without an Array.\n * @return Returns a Promise that fulfills with an array of `Asset`s when the asset(s) has been\n * saved to disk.\n * @example\n * ```ts\n * const [{ localUri }] = await Asset.loadAsync(require('./assets/snack-icon.png'));\n * ```\n */\n static loadAsync(moduleId) {\n const moduleIds = Array.isArray(moduleId) ? moduleId : [moduleId];\n return Promise.all(moduleIds.map((moduleId) => Asset.fromModule(moduleId).downloadAsync()));\n }\n // @needsAudit\n /**\n * Returns the [`Asset`](#asset) instance representing an asset given its module or URL.\n * @param virtualAssetModule The value of `require('path/to/file')` for the asset or external\n * network URL\n * @return The [`Asset`](#asset) instance for the asset.\n */\n static fromModule(virtualAssetModule) {\n if (typeof virtualAssetModule === 'string') {\n return Asset.fromURI(virtualAssetModule);\n }\n const meta = getAssetByID(virtualAssetModule);\n if (!meta) {\n throw new Error(`Module \"${virtualAssetModule}\" is missing from the asset registry`);\n }\n // Outside of the managed env we need the moduleId to initialize the asset\n // because resolveAssetSource depends on it\n if (!IS_ENV_WITH_LOCAL_ASSETS) {\n // null-check is performed above with `getAssetByID`.\n const { uri } = resolveAssetSource(virtualAssetModule);\n const asset = new Asset({\n name: meta.name,\n type: meta.type,\n hash: meta.hash,\n uri,\n width: meta.width,\n height: meta.height,\n });\n // For images backward compatibility,\n // keeps localUri the same as uri for React Native's Image that\n // works fine with drawable resource names.\n if (Platform.OS === 'android' && !uri.includes(':') && (meta.width || meta.height)) {\n asset.localUri = asset.uri;\n asset.downloaded = true;\n }\n Asset.byHash[meta.hash] = asset;\n return asset;\n }\n return Asset.fromMetadata(meta);\n }\n // @docsMissing\n static fromMetadata(meta) {\n // The hash of the whole asset, not to be confused with the hash of a specific file returned\n // from `selectAssetSource`\n const metaHash = meta.hash;\n if (Asset.byHash[metaHash]) {\n return Asset.byHash[metaHash];\n }\n const { uri, hash } = selectAssetSource(meta);\n const asset = new Asset({\n name: meta.name,\n type: meta.type,\n hash,\n uri,\n width: meta.width,\n height: meta.height,\n });\n Asset.byHash[metaHash] = asset;\n return asset;\n }\n // @docsMissing\n static fromURI(uri) {\n if (Asset.byUri[uri]) {\n return Asset.byUri[uri];\n }\n // Possibly a Base64-encoded URI\n let type = '';\n if (uri.indexOf(';base64') > -1) {\n type = uri.split(';')[0].split('/')[1];\n }\n else {\n const extension = AssetUris.getFileExtension(uri);\n type = extension.startsWith('.') ? extension.substring(1) : extension;\n }\n const asset = new Asset({\n name: '',\n type,\n hash: null,\n uri,\n });\n Asset.byUri[uri] = asset;\n return asset;\n }\n // @needsAudit\n /**\n * Downloads the asset data to a local file in the device's cache directory. Once the returned\n * promise is fulfilled without error, the [`localUri`](#localuri) field of this asset points\n * to a local file containing the asset data. The asset is only downloaded if an up-to-date local\n * file for the asset isn't already present due to an earlier download. The downloaded `Asset`\n * will be returned when the promise is resolved.\n * @return Returns a Promise which fulfills with an `Asset` instance.\n */\n async downloadAsync() {\n if (this.downloaded) {\n return this;\n }\n if (this.downloading) {\n await new Promise((resolve, reject) => {\n this._downloadCallbacks.push({ resolve, reject });\n });\n return this;\n }\n this.downloading = true;\n try {\n if (Platform.OS === 'web') {\n if (ImageAssets.isImageType(this.type)) {\n const { width, height, name } = await ImageAssets.getImageInfoAsync(this.uri);\n this.width = width;\n this.height = height;\n this.name = name;\n }\n else {\n this.name = AssetUris.getFilename(this.uri);\n }\n }\n this.localUri = await downloadAsync(this.uri, this.hash, this.type);\n this.downloaded = true;\n this._downloadCallbacks.forEach(({ resolve }) => resolve());\n }\n catch (e) {\n this._downloadCallbacks.forEach(({ reject }) => reject(e));\n throw e;\n }\n finally {\n this.downloading = false;\n this._downloadCallbacks = [];\n }\n return this;\n }\n}\n//# sourceMappingURL=Asset.js.map","import { Platform } from 'expo-modules-core';\nimport { PixelRatio, NativeModules } from 'react-native';\nimport AssetSourceResolver from './AssetSourceResolver';\nimport { getManifest2, manifestBaseUrl } from './PlatformUtils';\n/**\n * Selects the best file for the given asset (ex: choosing the best scale for images) and returns\n * a { uri, hash } pair for the specific asset file.\n *\n * If the asset isn't an image with multiple scales, the first file is selected.\n */\nexport function selectAssetSource(meta) {\n // This logic is based on that of AssetSourceResolver, with additional support for file hashes and\n // explicitly provided URIs\n const scale = AssetSourceResolver.pickScale(meta.scales, PixelRatio.get());\n const index = meta.scales.findIndex((s) => s === scale);\n const hash = meta.fileHashes ? meta.fileHashes[index] ?? meta.fileHashes[0] : meta.hash;\n // Allow asset processors to directly provide the URL to load\n const uri = meta.fileUris ? meta.fileUris[index] ?? meta.fileUris[0] : meta.uri;\n if (uri) {\n return { uri: resolveUri(uri), hash };\n }\n const fileScale = scale === 1 ? '' : `@${scale}x`;\n const fileExtension = meta.type ? `.${encodeURIComponent(meta.type)}` : '';\n const suffix = `/${encodeURIComponent(meta.name)}${fileScale}${fileExtension}`;\n const params = new URLSearchParams({\n platform: Platform.OS,\n hash: meta.hash,\n });\n // For assets with a specified absolute URL, we use the existing origin instead of prepending the\n // development server or production CDN URL origin\n if (/^https?:\\/\\//.test(meta.httpServerLocation)) {\n const uri = meta.httpServerLocation + suffix + '?' + params;\n return { uri, hash };\n }\n // For assets during development using manifest2, we use the development server's URL origin\n const manifest2 = getManifest2();\n const devServerUrl = manifest2?.extra?.expoGo?.developer\n ? 'http://' + manifest2.extra.expoGo.debuggerHost\n : null;\n if (devServerUrl) {\n const baseUrl = new URL(meta.httpServerLocation + suffix, devServerUrl);\n baseUrl.searchParams.set('platform', Platform.OS);\n baseUrl.searchParams.set('hash', meta.hash);\n return {\n uri: baseUrl.href,\n hash,\n };\n }\n // Temporary fallback for loading assets in Expo Go home\n if (NativeModules.ExponentKernel) {\n return { uri: `https://classic-assets.eascdn.net/~assets/${encodeURIComponent(hash)}`, hash };\n }\n // In correctly configured apps, we arrive here if the asset is locally available on disk due to\n // being managed by expo-updates, and `getLocalAssetUri(hash)` must return a local URI for this\n // hash. Since the asset is local, we don't have a remote URL and specify an invalid URL (an empty\n // string) as a placeholder.\n return { uri: '', hash };\n}\n/**\n * Resolves the given URI to an absolute URI. If the given URI is already an absolute URI, it is\n * simply returned. Otherwise, if it is a relative URI, it is resolved relative to the manifest's\n * base URI.\n */\nexport function resolveUri(uri) {\n // `manifestBaseUrl` is always an absolute URL or `null`.\n return manifestBaseUrl ? new URL(uri, manifestBaseUrl).href : uri;\n}\n// A very cheap path canonicalization like path.join but without depending on a `path` polyfill.\nexport function pathJoin(...paths) {\n // Start by simply combining paths, without worrying about \"..\" or \".\"\n const combined = paths\n .map((part, index) => {\n if (index === 0) {\n return part.trim().replace(/\\/*$/, '');\n }\n return part.trim().replace(/(^\\/*|\\/*$)/g, '');\n })\n .filter((part) => part.length > 0)\n .join('/')\n .split('/');\n // Handle \"..\" and \".\" in paths\n const resolved = [];\n for (const part of combined) {\n if (part === '..') {\n resolved.pop(); // Remove the last element from the result\n }\n else if (part !== '.') {\n resolved.push(part);\n }\n }\n return resolved.join('/');\n}\n//# sourceMappingURL=AssetSources.js.map","import { Platform } from 'expo-modules-core';\nimport { PixelRatio } from 'react-native';\n// Returns the Metro dev server-specific asset location.\nfunction getScaledAssetPath(asset) {\n const scale = AssetSourceResolver.pickScale(asset.scales, PixelRatio.get());\n const scaleSuffix = scale === 1 ? '' : '@' + scale + 'x';\n const type = !asset.type ? '' : `.${asset.type}`;\n if (__DEV__) {\n return asset.httpServerLocation + '/' + asset.name + scaleSuffix + type;\n }\n else {\n return asset.httpServerLocation.replace(/\\.\\.\\//g, '_') + '/' + asset.name + scaleSuffix + type;\n }\n}\nexport default class AssetSourceResolver {\n serverUrl;\n // where the jsbundle is being run from\n // NOTE(EvanBacon): Never defined on web.\n jsbundleUrl;\n // the asset to resolve\n asset;\n constructor(serverUrl, jsbundleUrl, asset) {\n this.serverUrl = serverUrl || 'https://expo.dev';\n this.jsbundleUrl = null;\n this.asset = asset;\n }\n // Always true for web runtimes\n isLoadedFromServer() {\n return true;\n }\n // Always false for web runtimes\n isLoadedFromFileSystem() {\n return false;\n }\n defaultAsset() {\n return this.assetServerURL();\n }\n /**\n * @returns absolute remote URL for the hosted asset.\n */\n assetServerURL() {\n const fromUrl = new URL(getScaledAssetPath(this.asset), this.serverUrl);\n fromUrl.searchParams.set('platform', Platform.OS);\n fromUrl.searchParams.set('hash', this.asset.hash);\n return this.fromSource(\n // Relative on web\n fromUrl.toString().replace(fromUrl.origin, ''));\n }\n fromSource(source) {\n return {\n __packager_asset: true,\n width: this.asset.width ?? undefined,\n height: this.asset.height ?? undefined,\n uri: source,\n scale: AssetSourceResolver.pickScale(this.asset.scales, PixelRatio.get()),\n };\n }\n static pickScale(scales, deviceScale) {\n for (let i = 0; i < scales.length; i++) {\n if (scales[i] >= deviceScale) {\n return scales[i];\n }\n }\n return scales[scales.length - 1] || 1;\n }\n}\n//# sourceMappingURL=AssetSourceResolver.js.map","export const IS_ENV_WITH_LOCAL_ASSETS = false;\nexport function getLocalAssets() {\n return {};\n}\nexport function getManifest2() {\n return {};\n}\n// Compute manifest base URL if available\nexport const manifestBaseUrl = null;\n//# sourceMappingURL=PlatformUtils.web.js.map","export function getFilename(url) {\n const { pathname, searchParams } = new URL(url, 'https://e');\n // When attached to a dev server, we use `unstable_path` to represent the file path. This ensures\n // the file name is not canonicalized by the browser.\n // NOTE(EvanBacon): This is technically not tied to `__DEV__` as it's possible to use this while bundling in production\n // mode.\n if (__DEV__) {\n if (searchParams.has('unstable_path')) {\n const encodedFilePath = decodeURIComponent(searchParams.get('unstable_path'));\n return getBasename(encodedFilePath);\n }\n }\n return getBasename(pathname);\n}\nfunction getBasename(pathname) {\n return pathname.substring(pathname.lastIndexOf('/') + 1);\n}\nexport function getFileExtension(url) {\n const filename = getFilename(url);\n const dotIndex = filename.lastIndexOf('.');\n // Ignore leading dots for hidden files\n return dotIndex > 0 ? filename.substring(dotIndex) : '';\n}\n/**\n * Returns the base URL from a manifest's URL. For example, given a manifest hosted at\n * https://example.com/app/manifest.json, the base URL would be https://example.com/app/. Query\n * parameters and fragments also are removed.\n *\n * For an Expo-hosted project with a manifest hosted at https://exp.host/@user/project/index.exp, the\n * base URL would be https://exp.host/@user/project.\n *\n * We also normalize the \"exp\" protocol to \"http\" to handle internal URLs with the Expo schemes used\n * to tell the OS to open the URLs in the the Expo client.\n */\nexport function getManifestBaseUrl(manifestUrl) {\n const urlObject = new URL(manifestUrl);\n let nextProtocol = urlObject.protocol;\n // Change the scheme to http(s) if it is exp(s)\n if (nextProtocol === 'exp:') {\n nextProtocol = 'http:';\n }\n else if (nextProtocol === 'exps:') {\n nextProtocol = 'https:';\n }\n urlObject.protocol = nextProtocol;\n // Trim filename, query parameters, and fragment, if any\n const directory = urlObject.pathname.substring(0, urlObject.pathname.lastIndexOf('/') + 1);\n urlObject.pathname = directory;\n urlObject.search = '';\n urlObject.hash = '';\n // The URL spec doesn't allow for changing the protocol to `http` or `https`\n // without a port set so instead, we'll just swap the protocol manually.\n return urlObject.protocol !== nextProtocol\n ? urlObject.href.replace(urlObject.protocol, nextProtocol)\n : urlObject.href;\n}\n//# sourceMappingURL=AssetUris.js.map","export async function downloadAsync(url, _hash, _type) {\n return url;\n}\n//# sourceMappingURL=ExpoAsset.web.js.map","/* eslint-env browser */\nimport { Platform } from 'expo-modules-core';\nimport { getFilename } from './AssetUris';\nexport function isImageType(type) {\n return /^(jpeg|jpg|gif|png|bmp|webp|heic)$/i.test(type);\n}\nexport function getImageInfoAsync(url) {\n if (!Platform.isDOMAvailable) {\n return Promise.resolve({ name: getFilename(url), width: 0, height: 0 });\n }\n return new Promise((resolve, reject) => {\n const img = new Image();\n img.onerror = reject;\n img.onload = () => {\n resolve({\n name: getFilename(url),\n width: img.naturalWidth,\n height: img.naturalHeight,\n });\n };\n img.src = url;\n });\n}\n//# sourceMappingURL=ImageAssets.js.map","export function getLocalAssetUri(hash, type) {\n // noop on web\n return null;\n}\n//# sourceMappingURL=LocalAssets.web.js.map","import { getAssetByID } from '@react-native/assets-registry/registry';\nimport AssetSourceResolver from './AssetSourceResolver';\nlet _customSourceTransformer;\nexport function setCustomSourceTransformer(transformer) {\n _customSourceTransformer = transformer;\n}\n/**\n * `source` is either a number (opaque type returned by require('./foo.png'))\n * or an `ImageSource` like { uri: '' }\n */\nexport default function resolveAssetSource(source) {\n if (typeof source === 'object') {\n return source;\n }\n const asset = getAssetByID(source);\n if (!asset) {\n return null;\n }\n const resolver = new AssetSourceResolver(\n // Doesn't matter since this is removed on web\n 'https://expo.dev', null, asset);\n if (_customSourceTransformer) {\n return _customSourceTransformer(resolver);\n }\n return resolver.defaultAsset();\n}\nObject.defineProperty(resolveAssetSource, 'setCustomSourceTransformer', {\n get() {\n return setCustomSourceTransformer;\n },\n});\nexport const { pickScale } = AssetSourceResolver;\n//# sourceMappingURL=resolveAssetSource.js.map","import { useEffect, useState } from 'react';\nimport { Asset } from './Asset';\n// @needsAudit\n/**\n * Downloads and stores one or more assets locally.\n * After the assets are loaded, this hook returns a list of asset instances.\n * If something went wrong when loading the assets, an error is returned.\n *\n * > Note, the assets are not \"reloaded\" when you dynamically change the asset list.\n *\n * @return Returns an array containing:\n * - on the first position, a list of all loaded assets. If they aren't loaded yet, this value is\n * `undefined`.\n * - on the second position, an error which encountered when loading the assets. If there was no\n * error, this value is `undefined`.\n *\n * @example\n * ```tsx\n * const [assets, error] = useAssets([require('path/to/asset.jpg'), require('path/to/other.png')]);\n *\n * return assets ? : null;\n * ```\n */\nexport function useAssets(moduleIds) {\n const [assets, setAssets] = useState();\n const [error, setError] = useState();\n useEffect(() => {\n Asset.loadAsync(moduleIds).then(setAssets).catch(setError);\n }, []);\n return [assets, error];\n}\n//# sourceMappingURL=AssetHooks.js.map","export const loaded = {};\nexport const loadPromises = {};\n//# sourceMappingURL=memory.js.map","import { CodedError } from 'expo-modules-core';\nimport ExpoFontLoader from './ExpoFontLoader';\nimport { getAssetForSource, loadSingleFontAsync } from './FontLoader';\n/**\n * @returns the server resources that should be statically extracted.\n * @private\n */\nexport function getServerResources() {\n return ExpoFontLoader.getServerResources();\n}\n/**\n * @returns clear the server resources from the global scope.\n * @private\n */\nexport function resetServerContext() {\n return ExpoFontLoader.resetServerContext();\n}\nexport function registerStaticFont(fontFamily, source) {\n // MUST BE A SYNC FUNCTION!\n if (!source) {\n throw new CodedError(`ERR_FONT_SOURCE`, `Cannot load null or undefined font source: { \"${fontFamily}\": ${source} }. Expected asset of type \\`FontSource\\` for fontFamily of name: \"${fontFamily}\"`);\n }\n const asset = getAssetForSource(source);\n loadSingleFontAsync(fontFamily, asset);\n}\n//# sourceMappingURL=server.js.map","import { useEffect, useState } from 'react';\nimport { loadAsync, isLoaded } from './Font';\nfunction isMapLoaded(map) {\n if (typeof map === 'string') {\n return isLoaded(map);\n }\n else {\n return Object.keys(map).every((fontFamily) => isLoaded(fontFamily));\n }\n}\nfunction useRuntimeFonts(map) {\n const [loaded, setLoaded] = useState(\n // For web rehydration, we need to check if the fonts are already loaded during the static render.\n // Native will also benefit from this optimization.\n isMapLoaded(map));\n const [error, setError] = useState(null);\n useEffect(() => {\n loadAsync(map)\n .then(() => setLoaded(true))\n .catch(setError);\n }, []);\n return [loaded, error];\n}\nfunction useStaticFonts(map) {\n loadAsync(map);\n return [true, null];\n}\n// @needsAudit\n/**\n * ```ts\n * const [loaded, error] = useFonts({ ... });\n * ```\n * Load a map of fonts with [`loadAsync`](#loadasyncfontfamilyorfontmap-source). This returns a `boolean` if the fonts are\n * loaded and ready to use. It also returns an error if something went wrong, to use in development.\n *\n * > Note, the fonts are not \"reloaded\" when you dynamically change the font map.\n *\n * @param map A map of `fontFamily`s to [`FontSource`](#fontsource)s. After loading the font you can\n * use the key in the `fontFamily` style prop of a `Text` element.\n *\n * @return\n * - __loaded__ (`boolean`) - A boolean to detect if the font for `fontFamily` has finished\n * loading.\n * - __error__ (`Error | null`) - An error encountered when loading the fonts.\n */\nexport const useFonts = typeof window === 'undefined' ? useStaticFonts : useRuntimeFonts;\n//# sourceMappingURL=FontHooks.js.map","import React, { PureComponent } from 'react';\nimport {Platform, PixelRatio, processColor, Text, NativeModules} from 'react-native';\n\nimport ensureNativeModuleAvailable from './ensure-native-module-available';\nimport createIconSourceCache from './create-icon-source-cache';\nimport createIconButtonComponent from './icon-button';\n\nexport const NativeIconAPI =\n NativeModules.RNVectorIconsManager || NativeModules.RNVectorIconsModule;\n\nexport const DEFAULT_ICON_SIZE = 12;\nexport const DEFAULT_ICON_COLOR = 'black';\n\nexport default function createIconSet(\n glyphMap,\n fontFamily,\n fontFile,\n fontStyle\n) {\n // Android doesn't care about actual fontFamily name, it will only look in fonts folder.\n const fontBasename = fontFile\n ? fontFile.replace(/\\.(otf|ttf)$/, '')\n : fontFamily;\n\n const fontReference = Platform.select({\n windows: `/Assets/${fontFile}#${fontFamily}`,\n android: fontBasename,\n web: fontBasename,\n default: fontFamily,\n });\n\n class Icon extends PureComponent {\n root = null;\n\n static defaultProps = {\n size: DEFAULT_ICON_SIZE,\n allowFontScaling: false,\n };\n\n render() {\n const { name, size, color, style, children, ...props } = this.props;\n\n let glyph = name ? glyphMap[name] || '?' : '';\n if (typeof glyph === 'number') {\n glyph = String.fromCodePoint(glyph);\n }\n\n const styleDefaults = {\n fontSize: size,\n color,\n };\n\n const styleOverrides = {\n fontFamily: fontReference,\n fontWeight: 'normal',\n fontStyle: 'normal',\n };\n\n props.style = [styleDefaults, style, styleOverrides, fontStyle || {}];\n\n return (\n \n {glyph}\n {children}\n \n );\n }\n }\n\n const imageSourceCache = createIconSourceCache();\n\n function resolveGlyph(name) {\n const glyph = glyphMap[name] || '?';\n if (typeof glyph === 'number') {\n return String.fromCodePoint(glyph);\n }\n return glyph;\n }\n\n function getImageSourceSync(\n name,\n size = DEFAULT_ICON_SIZE,\n color = DEFAULT_ICON_COLOR\n ) {\n ensureNativeModuleAvailable();\n\n const glyph = resolveGlyph(name);\n const processedColor = processColor(color);\n const cacheKey = `${glyph}:${size}:${processedColor}`;\n\n if (imageSourceCache.has(cacheKey)) {\n return imageSourceCache.get(cacheKey);\n }\n try {\n const imagePath = NativeIconAPI.getImageForFontSync(\n fontReference,\n glyph,\n size,\n processedColor\n );\n const value = { uri: imagePath, scale: PixelRatio.get() };\n imageSourceCache.setValue(cacheKey, value);\n return value;\n } catch (error) {\n imageSourceCache.setError(cacheKey, error);\n throw error;\n }\n }\n\n async function getImageSource(\n name,\n size = DEFAULT_ICON_SIZE,\n color = DEFAULT_ICON_COLOR\n ) {\n ensureNativeModuleAvailable();\n\n const glyph = resolveGlyph(name);\n const processedColor = processColor(color);\n const cacheKey = `${glyph}:${size}:${processedColor}`;\n\n if (imageSourceCache.has(cacheKey)) {\n return imageSourceCache.get(cacheKey);\n }\n try {\n const imagePath = await NativeIconAPI.getImageForFont(\n fontReference,\n glyph,\n size,\n processedColor\n );\n const value = { uri: imagePath, scale: PixelRatio.get() };\n imageSourceCache.setValue(cacheKey, value);\n return value;\n } catch (error) {\n imageSourceCache.setError(cacheKey, error);\n throw error;\n }\n }\n\n async function loadFont(file = fontFile) {\n if (Platform.OS === 'ios') {\n ensureNativeModuleAvailable();\n if (!file) {\n throw new Error('Unable to load font, because no file was specified. ');\n }\n await NativeIconAPI.loadFontWithFileName(...file.split('.'));\n }\n }\n\n function hasIcon(name) {\n return Object.prototype.hasOwnProperty.call(glyphMap, name);\n }\n\n function getRawGlyphMap() {\n return glyphMap;\n }\n\n function getFontFamily() {\n return fontReference;\n }\n\n Icon.Button = createIconButtonComponent(Icon);\n Icon.getImageSource = getImageSource;\n Icon.getImageSourceSync = getImageSourceSync;\n Icon.loadFont = loadFont;\n Icon.hasIcon = hasIcon;\n Icon.getRawGlyphMap = getRawGlyphMap;\n Icon.getFontFamily = getFontFamily;\n\n return Icon;\n}\n","import {NativeModules} from \"react-native\";\n\nconst NativeIconAPI =\n NativeModules.RNVectorIconsManager || NativeModules.RNVectorIconsModule;\n\nexport default function ensureNativeModuleAvailable() {\n if (!NativeIconAPI) {\n throw new Error(\n 'The native RNVectorIcons API is not available, did you properly integrate the module? Please verify your autolinking setup and recompile.'\n );\n }\n}\n","const TYPE_VALUE = 'value';\nconst TYPE_ERROR = 'error';\n\nexport default function createIconSourceCache() {\n const cache = new Map();\n\n const setValue = (key, value) =>\n cache.set(key, { type: TYPE_VALUE, data: value });\n\n const setError = (key, error) =>\n cache.set(key, { type: TYPE_ERROR, data: error });\n\n const has = key => cache.has(key);\n\n const get = key => {\n if (!cache.has(key)) {\n return undefined;\n }\n const { type, data } = cache.get(key);\n if (type === TYPE_ERROR) {\n throw data;\n }\n return data;\n };\n\n return { setValue, setError, has, get };\n}\n","import React, { PureComponent } from 'react';\nimport PropTypes from 'prop-types';\nimport { StyleSheet, Text, TouchableHighlight, View } from 'react-native';\nimport { pick, omit } from './object-utils';\n\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n justifyContent: 'flex-start',\n alignItems: 'center',\n padding: 8,\n },\n touchable: {\n overflow: 'hidden',\n },\n icon: {\n marginRight: 10,\n },\n text: {\n fontWeight: '600',\n backgroundColor: 'transparent',\n },\n});\n\nconst IOS7_BLUE = '#007AFF';\n\nconst TEXT_PROP_NAMES = [\n 'ellipsizeMode',\n 'numberOfLines',\n 'textBreakStrategy',\n 'selectable',\n 'suppressHighlighting',\n 'allowFontScaling',\n 'adjustsFontSizeToFit',\n 'minimumFontScale',\n];\n\nconst TOUCHABLE_PROP_NAMES = [\n 'accessible',\n 'accessibilityLabel',\n 'accessibilityHint',\n 'accessibilityComponentType',\n 'accessibilityRole',\n 'accessibilityStates',\n 'accessibilityTraits',\n 'onFocus',\n 'onBlur',\n 'disabled',\n 'onPress',\n 'onPressIn',\n 'onPressOut',\n 'onLayout',\n 'onLongPress',\n 'nativeID',\n 'testID',\n 'delayPressIn',\n 'delayPressOut',\n 'delayLongPress',\n 'activeOpacity',\n 'underlayColor',\n 'selectionColor',\n 'onShowUnderlay',\n 'onHideUnderlay',\n 'hasTVPreferredFocus',\n 'tvParallaxProperties',\n];\n\nexport default function createIconButtonComponent(Icon) {\n return class IconButton extends PureComponent {\n static propTypes = {\n backgroundColor: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number,\n ]),\n borderRadius: PropTypes.number,\n color: PropTypes.any, // eslint-disable-line react/forbid-prop-types\n size: PropTypes.number,\n iconStyle: PropTypes.any, // eslint-disable-line react/forbid-prop-types\n style: PropTypes.any, // eslint-disable-line react/forbid-prop-types\n children: PropTypes.node,\n };\n\n static defaultProps = {\n backgroundColor: IOS7_BLUE,\n borderRadius: 5,\n color: 'white',\n size: 20,\n };\n\n render() {\n const { style, iconStyle, children, ...restProps } = this.props;\n\n const iconProps = pick(\n restProps,\n TEXT_PROP_NAMES,\n 'style',\n 'name',\n 'size',\n 'color'\n );\n const touchableProps = pick(restProps, TOUCHABLE_PROP_NAMES);\n const props = omit(\n restProps,\n Object.keys(iconProps),\n Object.keys(touchableProps),\n 'iconStyle',\n 'borderRadius',\n 'backgroundColor'\n );\n iconProps.style = iconStyle ? [styles.icon, iconStyle] : styles.icon;\n\n const colorStyle = pick(this.props, 'color');\n const blockStyle = pick(this.props, 'backgroundColor', 'borderRadius');\n\n return (\n \n \n \n {typeof children === 'string' ? (\n \n {children}\n \n ) : (\n children\n )}\n \n \n );\n }\n };\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"activeOpacity\", \"children\", \"delayPressIn\", \"delayPressOut\", \"delayLongPress\", \"disabled\", \"focusable\", \"onHideUnderlay\", \"onLongPress\", \"onPress\", \"onPressIn\", \"onPressOut\", \"onShowUnderlay\", \"rejectResponderTermination\", \"style\", \"testOnly_pressed\", \"underlayColor\"];\nimport * as React from 'react';\nimport { useCallback, useMemo, useState, useRef } from 'react';\nimport useMergeRefs from '../../modules/useMergeRefs';\nimport usePressEvents from '../../modules/usePressEvents';\nimport StyleSheet from '../StyleSheet';\nimport View from '../View';\nimport { warnOnce } from '../../modules/warnOnce';\nfunction createExtraStyles(activeOpacity, underlayColor) {\n return {\n child: {\n opacity: activeOpacity !== null && activeOpacity !== void 0 ? activeOpacity : 0.85\n },\n underlay: {\n backgroundColor: underlayColor === undefined ? 'black' : underlayColor\n }\n };\n}\nfunction hasPressHandler(props) {\n return props.onPress != null || props.onPressIn != null || props.onPressOut != null || props.onLongPress != null;\n}\n\n/**\n * A wrapper for making views respond properly to touches.\n * On press down, the opacity of the wrapped view is decreased, which allows\n * the underlay color to show through, darkening or tinting the view.\n *\n * The underlay comes from wrapping the child in a new View, which can affect\n * layout, and sometimes cause unwanted visual artifacts if not used correctly,\n * for example if the backgroundColor of the wrapped view isn't explicitly set\n * to an opaque color.\n *\n * TouchableHighlight must have one child (not zero or more than one).\n * If you wish to have several child components, wrap them in a View.\n */\nfunction TouchableHighlight(props, forwardedRef) {\n warnOnce('TouchableHighlight', 'TouchableHighlight is deprecated. Please use Pressable.');\n var activeOpacity = props.activeOpacity,\n children = props.children,\n delayPressIn = props.delayPressIn,\n delayPressOut = props.delayPressOut,\n delayLongPress = props.delayLongPress,\n disabled = props.disabled,\n focusable = props.focusable,\n onHideUnderlay = props.onHideUnderlay,\n onLongPress = props.onLongPress,\n onPress = props.onPress,\n onPressIn = props.onPressIn,\n onPressOut = props.onPressOut,\n onShowUnderlay = props.onShowUnderlay,\n rejectResponderTermination = props.rejectResponderTermination,\n style = props.style,\n testOnly_pressed = props.testOnly_pressed,\n underlayColor = props.underlayColor,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n var hostRef = useRef(null);\n var setRef = useMergeRefs(forwardedRef, hostRef);\n var _useState = useState(testOnly_pressed === true ? createExtraStyles(activeOpacity, underlayColor) : null),\n extraStyles = _useState[0],\n setExtraStyles = _useState[1];\n var showUnderlay = useCallback(() => {\n if (!hasPressHandler(props)) {\n return;\n }\n setExtraStyles(createExtraStyles(activeOpacity, underlayColor));\n if (onShowUnderlay != null) {\n onShowUnderlay();\n }\n }, [activeOpacity, onShowUnderlay, props, underlayColor]);\n var hideUnderlay = useCallback(() => {\n if (testOnly_pressed === true) {\n return;\n }\n if (hasPressHandler(props)) {\n setExtraStyles(null);\n if (onHideUnderlay != null) {\n onHideUnderlay();\n }\n }\n }, [onHideUnderlay, props, testOnly_pressed]);\n var pressConfig = useMemo(() => ({\n cancelable: !rejectResponderTermination,\n disabled,\n delayLongPress,\n delayPressStart: delayPressIn,\n delayPressEnd: delayPressOut,\n onLongPress,\n onPress,\n onPressStart(event) {\n showUnderlay();\n if (onPressIn != null) {\n onPressIn(event);\n }\n },\n onPressEnd(event) {\n hideUnderlay();\n if (onPressOut != null) {\n onPressOut(event);\n }\n }\n }), [delayLongPress, delayPressIn, delayPressOut, disabled, onLongPress, onPress, onPressIn, onPressOut, rejectResponderTermination, showUnderlay, hideUnderlay]);\n var pressEventHandlers = usePressEvents(hostRef, pressConfig);\n var child = React.Children.only(children);\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, pressEventHandlers, {\n accessibilityDisabled: disabled,\n focusable: !disabled && focusable !== false,\n pointerEvents: disabled ? 'box-none' : undefined,\n ref: setRef,\n style: [styles.root, style, !disabled && styles.actionable, extraStyles && extraStyles.underlay]\n }), /*#__PURE__*/React.cloneElement(child, {\n style: [child.props.style, extraStyles && extraStyles.child]\n }));\n}\nvar styles = StyleSheet.create({\n root: {\n userSelect: 'none'\n },\n actionable: {\n cursor: 'pointer',\n touchAction: 'manipulation'\n }\n});\nvar MemoedTouchableHighlight = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(TouchableHighlight));\nMemoedTouchableHighlight.displayName = 'TouchableHighlight';\nexport default MemoedTouchableHighlight;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport PressResponder from './PressResponder';\nimport { useDebugValue, useEffect, useRef } from 'react';\nexport default function usePressEvents(hostRef, config) {\n var pressResponderRef = useRef(null);\n if (pressResponderRef.current == null) {\n pressResponderRef.current = new PressResponder(config);\n }\n var pressResponder = pressResponderRef.current;\n\n // Re-configure to use the current node and configuration.\n useEffect(() => {\n pressResponder.configure(config);\n }, [config, pressResponder]);\n\n // Reset the `pressResponder` when cleanup needs to occur. This is\n // a separate effect because we do not want to rest the responder when `config` changes.\n useEffect(() => {\n return () => {\n pressResponder.reset();\n };\n }, [pressResponder]);\n useDebugValue(config);\n return pressResponder.getEventHandlers();\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nvar DELAY = 'DELAY';\nvar ERROR = 'ERROR';\nvar LONG_PRESS_DETECTED = 'LONG_PRESS_DETECTED';\nvar NOT_RESPONDER = 'NOT_RESPONDER';\nvar RESPONDER_ACTIVE_LONG_PRESS_START = 'RESPONDER_ACTIVE_LONG_PRESS_START';\nvar RESPONDER_ACTIVE_PRESS_START = 'RESPONDER_ACTIVE_PRESS_START';\nvar RESPONDER_INACTIVE_PRESS_START = 'RESPONDER_INACTIVE_PRESS_START';\nvar RESPONDER_GRANT = 'RESPONDER_GRANT';\nvar RESPONDER_RELEASE = 'RESPONDER_RELEASE';\nvar RESPONDER_TERMINATED = 'RESPONDER_TERMINATED';\nvar Transitions = Object.freeze({\n NOT_RESPONDER: {\n DELAY: ERROR,\n RESPONDER_GRANT: RESPONDER_INACTIVE_PRESS_START,\n RESPONDER_RELEASE: ERROR,\n RESPONDER_TERMINATED: ERROR,\n LONG_PRESS_DETECTED: ERROR\n },\n RESPONDER_INACTIVE_PRESS_START: {\n DELAY: RESPONDER_ACTIVE_PRESS_START,\n RESPONDER_GRANT: ERROR,\n RESPONDER_RELEASE: NOT_RESPONDER,\n RESPONDER_TERMINATED: NOT_RESPONDER,\n LONG_PRESS_DETECTED: ERROR\n },\n RESPONDER_ACTIVE_PRESS_START: {\n DELAY: ERROR,\n RESPONDER_GRANT: ERROR,\n RESPONDER_RELEASE: NOT_RESPONDER,\n RESPONDER_TERMINATED: NOT_RESPONDER,\n LONG_PRESS_DETECTED: RESPONDER_ACTIVE_LONG_PRESS_START\n },\n RESPONDER_ACTIVE_LONG_PRESS_START: {\n DELAY: ERROR,\n RESPONDER_GRANT: ERROR,\n RESPONDER_RELEASE: NOT_RESPONDER,\n RESPONDER_TERMINATED: NOT_RESPONDER,\n LONG_PRESS_DETECTED: RESPONDER_ACTIVE_LONG_PRESS_START\n },\n ERROR: {\n DELAY: NOT_RESPONDER,\n RESPONDER_GRANT: RESPONDER_INACTIVE_PRESS_START,\n RESPONDER_RELEASE: NOT_RESPONDER,\n RESPONDER_TERMINATED: NOT_RESPONDER,\n LONG_PRESS_DETECTED: NOT_RESPONDER\n }\n});\nvar getElementRole = element => element.getAttribute('role');\nvar getElementType = element => element.tagName.toLowerCase();\nvar isActiveSignal = signal => signal === RESPONDER_ACTIVE_PRESS_START || signal === RESPONDER_ACTIVE_LONG_PRESS_START;\nvar isButtonRole = element => getElementRole(element) === 'button';\nvar isPressStartSignal = signal => signal === RESPONDER_INACTIVE_PRESS_START || signal === RESPONDER_ACTIVE_PRESS_START || signal === RESPONDER_ACTIVE_LONG_PRESS_START;\nvar isTerminalSignal = signal => signal === RESPONDER_TERMINATED || signal === RESPONDER_RELEASE;\nvar isValidKeyPress = event => {\n var key = event.key,\n target = event.target;\n var isSpacebar = key === ' ' || key === 'Spacebar';\n var isButtonish = getElementType(target) === 'button' || isButtonRole(target);\n return key === 'Enter' || isSpacebar && isButtonish;\n};\nvar DEFAULT_LONG_PRESS_DELAY_MS = 450; // 500 - 50\nvar DEFAULT_PRESS_DELAY_MS = 50;\n\n/**\n * =========================== PressResponder Tutorial ===========================\n *\n * The `PressResponder` class helps you create press interactions by analyzing the\n * geometry of elements and observing when another responder (e.g. ScrollView)\n * has stolen the touch lock. It offers hooks for your component to provide\n * interaction feedback to the user:\n *\n * - When a press has activated (e.g. highlight an element)\n * - When a press has deactivated (e.g. un-highlight an element)\n * - When a press sould trigger an action, meaning it activated and deactivated\n * while within the geometry of the element without the lock being stolen.\n *\n * A high quality interaction isn't as simple as you might think. There should\n * be a slight delay before activation. Moving your finger beyond an element's\n * bounds should trigger deactivation, but moving the same finger back within an\n * element's bounds should trigger reactivation.\n *\n * In order to use `PressResponder`, do the following:\n *\n * const pressResponder = new PressResponder(config);\n *\n * 2. Choose the rendered component who should collect the press events. On that\n * element, spread `pressability.getEventHandlers()` into its props.\n *\n * return (\n * \n * );\n *\n * 3. Reset `PressResponder` when your component unmounts.\n *\n * componentWillUnmount() {\n * this.state.pressResponder.reset();\n * }\n *\n * ==================== Implementation Details ====================\n *\n * `PressResponder` only assumes that there exists a `HitRect` node. The `PressRect`\n * is an abstract box that is extended beyond the `HitRect`.\n *\n * # Geometry\n *\n * ┌────────────────────────┐\n * │ ┌──────────────────┐ │ - Presses start anywhere within `HitRect`.\n * │ │ ┌────────────┐ │ │\n * │ │ │ VisualRect │ │ │\n * │ │ └────────────┘ │ │ - When pressed down for sufficient amount of time\n * │ │ HitRect │ │ before letting up, `VisualRect` activates.\n * │ └──────────────────┘ │\n * │ Out Region o │\n * └────────────────────│───┘\n * └────── When the press is released outside the `HitRect`,\n * the responder is NOT eligible for a \"press\".\n *\n * # State Machine\n *\n * ┌───────────────┐ ◀──── RESPONDER_RELEASE\n * │ NOT_RESPONDER │\n * └───┬───────────┘ ◀──── RESPONDER_TERMINATED\n * │\n * │ RESPONDER_GRANT (HitRect)\n * │\n * ▼\n * ┌─────────────────────┐ ┌───────────────────┐ ┌───────────────────┐\n * │ RESPONDER_INACTIVE_ │ DELAY │ RESPONDER_ACTIVE_ │ T + DELAY │ RESPONDER_ACTIVE_ │\n * │ PRESS_START ├────────▶ │ PRESS_START ├────────────▶ │ LONG_PRESS_START │\n * └─────────────────────┘ └───────────────────┘ └───────────────────┘\n *\n * T + DELAY => LONG_PRESS_DELAY + DELAY\n *\n * Not drawn are the side effects of each transition. The most important side\n * effect is the invocation of `onLongPress`. Only when the browser produces a\n * `click` event is `onPress` invoked.\n */\nexport default class PressResponder {\n constructor(config) {\n this._eventHandlers = null;\n this._isPointerTouch = false;\n this._longPressDelayTimeout = null;\n this._longPressDispatched = false;\n this._pressDelayTimeout = null;\n this._pressOutDelayTimeout = null;\n this._touchState = NOT_RESPONDER;\n this._responderElement = null;\n this.configure(config);\n }\n configure(config) {\n this._config = config;\n }\n\n /**\n * Resets any pending timers. This should be called on unmount.\n */\n reset() {\n this._cancelLongPressDelayTimeout();\n this._cancelPressDelayTimeout();\n this._cancelPressOutDelayTimeout();\n }\n\n /**\n * Returns a set of props to spread into the interactive element.\n */\n getEventHandlers() {\n if (this._eventHandlers == null) {\n this._eventHandlers = this._createEventHandlers();\n }\n return this._eventHandlers;\n }\n _createEventHandlers() {\n var start = (event, shouldDelay) => {\n event.persist();\n this._cancelPressOutDelayTimeout();\n this._longPressDispatched = false;\n this._selectionTerminated = false;\n this._touchState = NOT_RESPONDER;\n this._isPointerTouch = event.nativeEvent.type === 'touchstart';\n this._receiveSignal(RESPONDER_GRANT, event);\n var delayPressStart = normalizeDelay(this._config.delayPressStart, 0, DEFAULT_PRESS_DELAY_MS);\n if (shouldDelay !== false && delayPressStart > 0) {\n this._pressDelayTimeout = setTimeout(() => {\n this._receiveSignal(DELAY, event);\n }, delayPressStart);\n } else {\n this._receiveSignal(DELAY, event);\n }\n var delayLongPress = normalizeDelay(this._config.delayLongPress, 10, DEFAULT_LONG_PRESS_DELAY_MS);\n this._longPressDelayTimeout = setTimeout(() => {\n this._handleLongPress(event);\n }, delayLongPress + delayPressStart);\n };\n var end = event => {\n this._receiveSignal(RESPONDER_RELEASE, event);\n };\n var keyupHandler = event => {\n var onPress = this._config.onPress;\n var target = event.target;\n if (this._touchState !== NOT_RESPONDER && isValidKeyPress(event)) {\n end(event);\n document.removeEventListener('keyup', keyupHandler);\n var role = target.getAttribute('role');\n var elementType = getElementType(target);\n var isNativeInteractiveElement = role === 'link' || elementType === 'a' || elementType === 'button' || elementType === 'input' || elementType === 'select' || elementType === 'textarea';\n var isActiveElement = this._responderElement === target;\n if (onPress != null && !isNativeInteractiveElement && isActiveElement) {\n onPress(event);\n }\n this._responderElement = null;\n }\n };\n return {\n onStartShouldSetResponder: event => {\n var disabled = this._config.disabled;\n if (disabled && isButtonRole(event.currentTarget)) {\n event.stopPropagation();\n }\n if (disabled == null) {\n return true;\n }\n return !disabled;\n },\n onKeyDown: event => {\n var disabled = this._config.disabled;\n var key = event.key,\n target = event.target;\n if (!disabled && isValidKeyPress(event)) {\n if (this._touchState === NOT_RESPONDER) {\n start(event, false);\n this._responderElement = target;\n // Listen to 'keyup' on document to account for situations where\n // focus is moved to another element during 'keydown'.\n document.addEventListener('keyup', keyupHandler);\n }\n var isSpacebarKey = key === ' ' || key === 'Spacebar';\n var role = getElementRole(target);\n var isButtonLikeRole = role === 'button' || role === 'menuitem';\n if (isSpacebarKey && isButtonLikeRole && getElementType(target) !== 'button') {\n // Prevent spacebar scrolling the window if using non-native button\n event.preventDefault();\n }\n event.stopPropagation();\n }\n },\n onResponderGrant: event => start(event),\n onResponderMove: event => {\n if (this._config.onPressMove != null) {\n this._config.onPressMove(event);\n }\n var touch = getTouchFromResponderEvent(event);\n if (this._touchActivatePosition != null) {\n var deltaX = this._touchActivatePosition.pageX - touch.pageX;\n var deltaY = this._touchActivatePosition.pageY - touch.pageY;\n if (Math.hypot(deltaX, deltaY) > 10) {\n this._cancelLongPressDelayTimeout();\n }\n }\n },\n onResponderRelease: event => end(event),\n onResponderTerminate: event => {\n if (event.nativeEvent.type === 'selectionchange') {\n this._selectionTerminated = true;\n }\n this._receiveSignal(RESPONDER_TERMINATED, event);\n },\n onResponderTerminationRequest: event => {\n var _this$_config = this._config,\n cancelable = _this$_config.cancelable,\n disabled = _this$_config.disabled,\n onLongPress = _this$_config.onLongPress;\n // If `onLongPress` is provided, don't terminate on `contextmenu` as default\n // behavior will be prevented for non-mouse pointers.\n if (!disabled && onLongPress != null && this._isPointerTouch && event.nativeEvent.type === 'contextmenu') {\n return false;\n }\n if (cancelable == null) {\n return true;\n }\n return cancelable;\n },\n // NOTE: this diverges from react-native in 3 significant ways:\n // * The `onPress` callback is not connected to the responder system (the native\n // `click` event must be used but is dispatched in many scenarios where no pointers\n // are on the screen.) Therefore, it's possible for `onPress` to be called without\n // `onPress{Start,End}` being called first.\n // * The `onPress` callback is only be called on the first ancestor of the native\n // `click` target that is using the PressResponder.\n // * The event's `nativeEvent` is a `MouseEvent` not a `TouchEvent`.\n onClick: event => {\n var _this$_config2 = this._config,\n disabled = _this$_config2.disabled,\n onPress = _this$_config2.onPress;\n if (!disabled) {\n // If long press dispatched, cancel default click behavior.\n // If the responder terminated because text was selected during the gesture,\n // cancel the default click behavior.\n event.stopPropagation();\n if (this._longPressDispatched || this._selectionTerminated) {\n event.preventDefault();\n } else if (onPress != null && event.altKey === false) {\n onPress(event);\n }\n } else {\n if (isButtonRole(event.currentTarget)) {\n event.stopPropagation();\n }\n }\n },\n // If `onLongPress` is provided and a touch pointer is being used, prevent the\n // default context menu from opening.\n onContextMenu: event => {\n var _this$_config3 = this._config,\n disabled = _this$_config3.disabled,\n onLongPress = _this$_config3.onLongPress;\n if (!disabled) {\n if (onLongPress != null && this._isPointerTouch && !event.defaultPrevented) {\n event.preventDefault();\n event.stopPropagation();\n }\n } else {\n if (isButtonRole(event.currentTarget)) {\n event.stopPropagation();\n }\n }\n }\n };\n }\n\n /**\n * Receives a state machine signal, performs side effects of the transition\n * and stores the new state. Validates the transition as well.\n */\n _receiveSignal(signal, event) {\n var prevState = this._touchState;\n var nextState = null;\n if (Transitions[prevState] != null) {\n nextState = Transitions[prevState][signal];\n }\n if (this._touchState === NOT_RESPONDER && signal === RESPONDER_RELEASE) {\n return;\n }\n if (nextState == null || nextState === ERROR) {\n console.error(\"PressResponder: Invalid signal \" + signal + \" for state \" + prevState + \" on responder\");\n } else if (prevState !== nextState) {\n this._performTransitionSideEffects(prevState, nextState, signal, event);\n this._touchState = nextState;\n }\n }\n\n /**\n * Performs a transition between touchable states and identify any activations\n * or deactivations (and callback invocations).\n */\n _performTransitionSideEffects(prevState, nextState, signal, event) {\n if (isTerminalSignal(signal)) {\n // Pressable suppression of contextmenu on windows.\n // On Windows, the contextmenu is displayed after pointerup.\n // https://github.com/necolas/react-native-web/issues/2296\n setTimeout(() => {\n this._isPointerTouch = false;\n }, 0);\n this._touchActivatePosition = null;\n this._cancelLongPressDelayTimeout();\n }\n if (isPressStartSignal(prevState) && signal === LONG_PRESS_DETECTED) {\n var onLongPress = this._config.onLongPress;\n // Long press is not supported for keyboards because 'click' can be dispatched\n // immediately (and multiple times) after 'keydown'.\n if (onLongPress != null && event.nativeEvent.key == null) {\n onLongPress(event);\n this._longPressDispatched = true;\n }\n }\n var isPrevActive = isActiveSignal(prevState);\n var isNextActive = isActiveSignal(nextState);\n if (!isPrevActive && isNextActive) {\n this._activate(event);\n } else if (isPrevActive && !isNextActive) {\n this._deactivate(event);\n }\n if (isPressStartSignal(prevState) && signal === RESPONDER_RELEASE) {\n var _this$_config4 = this._config,\n _onLongPress = _this$_config4.onLongPress,\n onPress = _this$_config4.onPress;\n if (onPress != null) {\n var isPressCanceledByLongPress = _onLongPress != null && prevState === RESPONDER_ACTIVE_LONG_PRESS_START;\n if (!isPressCanceledByLongPress) {\n // If we never activated (due to delays), activate and deactivate now.\n if (!isNextActive && !isPrevActive) {\n this._activate(event);\n this._deactivate(event);\n }\n }\n }\n }\n this._cancelPressDelayTimeout();\n }\n _activate(event) {\n var _this$_config5 = this._config,\n onPressChange = _this$_config5.onPressChange,\n onPressStart = _this$_config5.onPressStart;\n var touch = getTouchFromResponderEvent(event);\n this._touchActivatePosition = {\n pageX: touch.pageX,\n pageY: touch.pageY\n };\n if (onPressStart != null) {\n onPressStart(event);\n }\n if (onPressChange != null) {\n onPressChange(true);\n }\n }\n _deactivate(event) {\n var _this$_config6 = this._config,\n onPressChange = _this$_config6.onPressChange,\n onPressEnd = _this$_config6.onPressEnd;\n function end() {\n if (onPressEnd != null) {\n onPressEnd(event);\n }\n if (onPressChange != null) {\n onPressChange(false);\n }\n }\n var delayPressEnd = normalizeDelay(this._config.delayPressEnd);\n if (delayPressEnd > 0) {\n this._pressOutDelayTimeout = setTimeout(() => {\n end();\n }, delayPressEnd);\n } else {\n end();\n }\n }\n _handleLongPress(event) {\n if (this._touchState === RESPONDER_ACTIVE_PRESS_START || this._touchState === RESPONDER_ACTIVE_LONG_PRESS_START) {\n this._receiveSignal(LONG_PRESS_DETECTED, event);\n }\n }\n _cancelLongPressDelayTimeout() {\n if (this._longPressDelayTimeout != null) {\n clearTimeout(this._longPressDelayTimeout);\n this._longPressDelayTimeout = null;\n }\n }\n _cancelPressDelayTimeout() {\n if (this._pressDelayTimeout != null) {\n clearTimeout(this._pressDelayTimeout);\n this._pressDelayTimeout = null;\n }\n }\n _cancelPressOutDelayTimeout() {\n if (this._pressOutDelayTimeout != null) {\n clearTimeout(this._pressOutDelayTimeout);\n this._pressOutDelayTimeout = null;\n }\n }\n}\nfunction normalizeDelay(delay, min, fallback) {\n if (min === void 0) {\n min = 0;\n }\n if (fallback === void 0) {\n fallback = 0;\n }\n return Math.max(min, delay !== null && delay !== void 0 ? delay : fallback);\n}\nfunction getTouchFromResponderEvent(event) {\n var _event$nativeEvent = event.nativeEvent,\n changedTouches = _event$nativeEvent.changedTouches,\n touches = _event$nativeEvent.touches;\n if (touches != null && touches.length > 0) {\n return touches[0];\n }\n if (changedTouches != null && changedTouches.length > 0) {\n return changedTouches[0];\n }\n return event.nativeEvent;\n}","const pick = (obj, ...keys) =>\n keys\n .flat()\n .filter(key => Object.prototype.hasOwnProperty.call(obj, key))\n .reduce((acc, key) => {\n acc[key] = obj[key];\n return acc;\n }, {});\n\nconst omit = (obj, ...keysToOmit) => {\n const keysToOmitSet = new Set(keysToOmit.flat());\n return Object.getOwnPropertyNames(obj)\n .filter(key => !keysToOmitSet.has(key))\n .reduce((acc, key) => {\n acc[key] = obj[key];\n return acc;\n }, {});\n};\n\nmodule.exports = { pick, omit };\n","","{\n \"ab-testing\": 983497,\n \"abacus\": 988896,\n \"abjad-arabic\": 987944,\n \"abjad-hebrew\": 987945,\n \"abugida-devanagari\": 987946,\n \"abugida-thai\": 987947,\n \"access-point\": 983043,\n \"access-point-check\": 988472,\n \"access-point-minus\": 988473,\n \"access-point-network\": 983042,\n \"access-point-network-off\": 986081,\n \"access-point-off\": 988433,\n \"access-point-plus\": 988474,\n \"access-point-remove\": 988475,\n \"account\": 983044,\n \"account-alert\": 983045,\n \"account-alert-outline\": 985936,\n \"account-arrow-down\": 989288,\n \"account-arrow-down-outline\": 989289,\n \"account-arrow-left\": 985937,\n \"account-arrow-left-outline\": 985938,\n \"account-arrow-right\": 985939,\n \"account-arrow-right-outline\": 985940,\n \"account-arrow-up\": 989287,\n \"account-arrow-up-outline\": 989290,\n \"account-box\": 983046,\n \"account-box-multiple\": 985396,\n \"account-box-multiple-outline\": 987146,\n \"account-box-outline\": 983047,\n \"account-cancel\": 987871,\n \"account-cancel-outline\": 987872,\n \"account-cash\": 987287,\n \"account-cash-outline\": 987288,\n \"account-check\": 983048,\n \"account-check-outline\": 986082,\n \"account-child\": 985737,\n \"account-child-circle\": 985738,\n \"account-child-outline\": 987336,\n \"account-circle\": 983049,\n \"account-circle-outline\": 985941,\n \"account-clock\": 985942,\n \"account-clock-outline\": 985943,\n \"account-cog\": 988016,\n \"account-cog-outline\": 988017,\n \"account-convert\": 983050,\n \"account-convert-outline\": 987905,\n \"account-cowboy-hat\": 986779,\n \"account-cowboy-hat-outline\": 989171,\n \"account-details\": 984625,\n \"account-details-outline\": 988018,\n \"account-edit\": 984764,\n \"account-edit-outline\": 987131,\n \"account-eye\": 984096,\n \"account-eye-outline\": 987771,\n \"account-filter\": 985398,\n \"account-filter-outline\": 987037,\n \"account-group\": 985161,\n \"account-group-outline\": 985944,\n \"account-hard-hat\": 984501,\n \"account-heart\": 985241,\n \"account-heart-outline\": 986083,\n \"account-injury\": 989205,\n \"account-injury-outline\": 989206,\n \"account-key\": 983051,\n \"account-key-outline\": 986084,\n \"account-lock\": 987486,\n \"account-lock-open\": 989536,\n \"account-lock-open-outline\": 989537,\n \"account-lock-outline\": 987487,\n \"account-minus\": 983053,\n \"account-minus-outline\": 985836,\n \"account-multiple\": 983054,\n \"account-multiple-check\": 985285,\n \"account-multiple-check-outline\": 987646,\n \"account-multiple-minus\": 984531,\n \"account-multiple-minus-outline\": 986085,\n \"account-multiple-outline\": 983055,\n \"account-multiple-plus\": 983056,\n \"account-multiple-plus-outline\": 985088,\n \"account-multiple-remove\": 987658,\n \"account-multiple-remove-outline\": 987659,\n \"account-music\": 985091,\n \"account-music-outline\": 986345,\n \"account-network\": 983057,\n \"account-network-outline\": 986086,\n \"account-off\": 983058,\n \"account-off-outline\": 986087,\n \"account-outline\": 983059,\n \"account-plus\": 983060,\n \"account-plus-outline\": 985089,\n \"account-question\": 985945,\n \"account-question-outline\": 985946,\n \"account-reactivate\": 988459,\n \"account-reactivate-outline\": 988460,\n \"account-remove\": 983061,\n \"account-remove-outline\": 985837,\n \"account-search\": 983062,\n \"account-search-outline\": 985397,\n \"account-settings\": 984624,\n \"account-settings-outline\": 987337,\n \"account-star\": 983063,\n \"account-star-outline\": 986088,\n \"account-supervisor\": 985739,\n \"account-supervisor-circle\": 985740,\n \"account-supervisor-circle-outline\": 988396,\n \"account-supervisor-outline\": 987437,\n \"account-switch\": 983065,\n \"account-switch-outline\": 984267,\n \"account-sync\": 989467,\n \"account-sync-outline\": 989468,\n \"account-tie\": 986339,\n \"account-tie-hat\": 989336,\n \"account-tie-hat-outline\": 989337,\n \"account-tie-outline\": 987338,\n \"account-tie-voice\": 987912,\n \"account-tie-voice-off\": 987914,\n \"account-tie-voice-off-outline\": 987915,\n \"account-tie-voice-outline\": 987913,\n \"account-voice\": 984523,\n \"account-voice-off\": 986836,\n \"account-wrench\": 989338,\n \"account-wrench-outline\": 989339,\n \"adjust\": 983066,\n \"advertisements\": 989482,\n \"advertisements-off\": 989483,\n \"air-conditioner\": 983067,\n \"air-filter\": 986435,\n \"air-horn\": 986540,\n \"air-humidifier\": 987289,\n \"air-humidifier-off\": 988262,\n \"air-purifier\": 986436,\n \"airbag\": 986089,\n \"airballoon\": 983068,\n \"airballoon-outline\": 987147,\n \"airplane\": 983069,\n \"airplane-alert\": 989306,\n \"airplane-check\": 989307,\n \"airplane-clock\": 989308,\n \"airplane-cog\": 989309,\n \"airplane-edit\": 989310,\n \"airplane-landing\": 984532,\n \"airplane-marker\": 989311,\n \"airplane-minus\": 989312,\n \"airplane-off\": 983070,\n \"airplane-plus\": 989313,\n \"airplane-remove\": 989314,\n \"airplane-search\": 989315,\n \"airplane-settings\": 989316,\n \"airplane-takeoff\": 984533,\n \"airport\": 985163,\n \"alarm\": 983072,\n \"alarm-bell\": 984974,\n \"alarm-check\": 983073,\n \"alarm-light\": 984975,\n \"alarm-light-off\": 988958,\n \"alarm-light-off-outline\": 988959,\n \"alarm-light-outline\": 986090,\n \"alarm-multiple\": 983074,\n \"alarm-note\": 986737,\n \"alarm-note-off\": 986738,\n \"alarm-off\": 983075,\n \"alarm-panel\": 988612,\n \"alarm-panel-outline\": 988613,\n \"alarm-plus\": 983076,\n \"alarm-snooze\": 984718,\n \"album\": 983077,\n \"alert\": 983078,\n \"alert-box\": 983079,\n \"alert-box-outline\": 986340,\n \"alert-circle\": 983080,\n \"alert-circle-check\": 987629,\n \"alert-circle-check-outline\": 987630,\n \"alert-circle-outline\": 984534,\n \"alert-decagram\": 984765,\n \"alert-decagram-outline\": 986341,\n \"alert-minus\": 988347,\n \"alert-minus-outline\": 988350,\n \"alert-octagon\": 983081,\n \"alert-octagon-outline\": 986342,\n \"alert-octagram\": 984935,\n \"alert-octagram-outline\": 986343,\n \"alert-outline\": 983082,\n \"alert-plus\": 988346,\n \"alert-plus-outline\": 988349,\n \"alert-remove\": 988348,\n \"alert-remove-outline\": 988351,\n \"alert-rhombus\": 987598,\n \"alert-rhombus-outline\": 987599,\n \"alien\": 985242,\n \"alien-outline\": 987339,\n \"align-horizontal-center\": 987587,\n \"align-horizontal-distribute\": 989538,\n \"align-horizontal-left\": 987586,\n \"align-horizontal-right\": 987588,\n \"align-vertical-bottom\": 987589,\n \"align-vertical-center\": 987590,\n \"align-vertical-distribute\": 989539,\n \"align-vertical-top\": 987591,\n \"all-inclusive\": 984766,\n \"all-inclusive-box\": 989325,\n \"all-inclusive-box-outline\": 989326,\n \"allergy\": 987736,\n \"alpha\": 983083,\n \"alpha-a\": 985838,\n \"alpha-a-box\": 985864,\n \"alpha-a-box-outline\": 986091,\n \"alpha-a-circle\": 986092,\n \"alpha-a-circle-outline\": 986093,\n \"alpha-b\": 985839,\n \"alpha-b-box\": 985865,\n \"alpha-b-box-outline\": 986094,\n \"alpha-b-circle\": 986095,\n \"alpha-b-circle-outline\": 986096,\n \"alpha-c\": 985840,\n \"alpha-c-box\": 985866,\n \"alpha-c-box-outline\": 986097,\n \"alpha-c-circle\": 986098,\n \"alpha-c-circle-outline\": 986099,\n \"alpha-d\": 985841,\n \"alpha-d-box\": 985867,\n \"alpha-d-box-outline\": 986100,\n \"alpha-d-circle\": 986101,\n \"alpha-d-circle-outline\": 986102,\n \"alpha-e\": 985842,\n \"alpha-e-box\": 985868,\n \"alpha-e-box-outline\": 986103,\n \"alpha-e-circle\": 986104,\n \"alpha-e-circle-outline\": 986105,\n \"alpha-f\": 985843,\n \"alpha-f-box\": 985869,\n \"alpha-f-box-outline\": 986106,\n \"alpha-f-circle\": 986107,\n \"alpha-f-circle-outline\": 986108,\n \"alpha-g\": 985844,\n \"alpha-g-box\": 985870,\n \"alpha-g-box-outline\": 986109,\n \"alpha-g-circle\": 986110,\n \"alpha-g-circle-outline\": 986111,\n \"alpha-h\": 985845,\n \"alpha-h-box\": 985871,\n \"alpha-h-box-outline\": 986112,\n \"alpha-h-circle\": 986113,\n \"alpha-h-circle-outline\": 986114,\n \"alpha-i\": 985846,\n \"alpha-i-box\": 985872,\n \"alpha-i-box-outline\": 986115,\n \"alpha-i-circle\": 986116,\n \"alpha-i-circle-outline\": 986117,\n \"alpha-j\": 985847,\n \"alpha-j-box\": 985873,\n \"alpha-j-box-outline\": 986118,\n \"alpha-j-circle\": 986119,\n \"alpha-j-circle-outline\": 986120,\n \"alpha-k\": 985848,\n \"alpha-k-box\": 985874,\n \"alpha-k-box-outline\": 986121,\n \"alpha-k-circle\": 986122,\n \"alpha-k-circle-outline\": 986123,\n \"alpha-l\": 985849,\n \"alpha-l-box\": 985875,\n \"alpha-l-box-outline\": 986124,\n \"alpha-l-circle\": 986125,\n \"alpha-l-circle-outline\": 986126,\n \"alpha-m\": 985850,\n \"alpha-m-box\": 985876,\n \"alpha-m-box-outline\": 986127,\n \"alpha-m-circle\": 986128,\n \"alpha-m-circle-outline\": 986129,\n \"alpha-n\": 985851,\n \"alpha-n-box\": 985877,\n \"alpha-n-box-outline\": 986130,\n \"alpha-n-circle\": 986131,\n \"alpha-n-circle-outline\": 986132,\n \"alpha-o\": 985852,\n \"alpha-o-box\": 985878,\n \"alpha-o-box-outline\": 986133,\n \"alpha-o-circle\": 986134,\n \"alpha-o-circle-outline\": 986135,\n \"alpha-p\": 985853,\n \"alpha-p-box\": 985879,\n \"alpha-p-box-outline\": 986136,\n \"alpha-p-circle\": 986137,\n \"alpha-p-circle-outline\": 986138,\n \"alpha-q\": 985854,\n \"alpha-q-box\": 985880,\n \"alpha-q-box-outline\": 986139,\n \"alpha-q-circle\": 986140,\n \"alpha-q-circle-outline\": 986141,\n \"alpha-r\": 985855,\n \"alpha-r-box\": 985881,\n \"alpha-r-box-outline\": 986142,\n \"alpha-r-circle\": 986143,\n \"alpha-r-circle-outline\": 986144,\n \"alpha-s\": 985856,\n \"alpha-s-box\": 985882,\n \"alpha-s-box-outline\": 986145,\n \"alpha-s-circle\": 986146,\n \"alpha-s-circle-outline\": 986147,\n \"alpha-t\": 985857,\n \"alpha-t-box\": 985883,\n \"alpha-t-box-outline\": 986148,\n \"alpha-t-circle\": 986149,\n \"alpha-t-circle-outline\": 986150,\n \"alpha-u\": 985858,\n \"alpha-u-box\": 985884,\n \"alpha-u-box-outline\": 986151,\n \"alpha-u-circle\": 986152,\n \"alpha-u-circle-outline\": 986153,\n \"alpha-v\": 985859,\n \"alpha-v-box\": 985885,\n \"alpha-v-box-outline\": 986154,\n \"alpha-v-circle\": 986155,\n \"alpha-v-circle-outline\": 986156,\n \"alpha-w\": 985860,\n \"alpha-w-box\": 985886,\n \"alpha-w-box-outline\": 986157,\n \"alpha-w-circle\": 986158,\n \"alpha-w-circle-outline\": 986159,\n \"alpha-x\": 985861,\n \"alpha-x-box\": 985887,\n \"alpha-x-box-outline\": 986160,\n \"alpha-x-circle\": 986161,\n \"alpha-x-circle-outline\": 986162,\n \"alpha-y\": 985862,\n \"alpha-y-box\": 985888,\n \"alpha-y-box-outline\": 986163,\n \"alpha-y-circle\": 986164,\n \"alpha-y-circle-outline\": 986165,\n \"alpha-z\": 985863,\n \"alpha-z-box\": 985889,\n \"alpha-z-box-outline\": 986166,\n \"alpha-z-circle\": 986167,\n \"alpha-z-circle-outline\": 986168,\n \"alphabet-aurebesh\": 987948,\n \"alphabet-cyrillic\": 987949,\n \"alphabet-greek\": 987950,\n \"alphabet-latin\": 987951,\n \"alphabet-piqad\": 987952,\n \"alphabet-tengwar\": 987959,\n \"alphabetical\": 983084,\n \"alphabetical-off\": 987148,\n \"alphabetical-variant\": 987149,\n \"alphabetical-variant-off\": 987150,\n \"altimeter\": 984535,\n \"ambulance\": 983087,\n \"ammunition\": 986344,\n \"ampersand\": 985741,\n \"amplifier\": 983088,\n \"amplifier-off\": 987573,\n \"anchor\": 983089,\n \"android\": 983090,\n \"android-messages\": 986437,\n \"android-studio\": 983092,\n \"angle-acute\": 985399,\n \"angle-obtuse\": 985400,\n \"angle-right\": 985401,\n \"angular\": 984754,\n \"angularjs\": 984767,\n \"animation\": 984536,\n \"animation-outline\": 985743,\n \"animation-play\": 985402,\n \"animation-play-outline\": 985744,\n \"ansible\": 987290,\n \"antenna\": 987417,\n \"anvil\": 985243,\n \"apache-kafka\": 987151,\n \"api\": 987291,\n \"api-off\": 987735,\n \"apple\": 983093,\n \"apple-finder\": 983094,\n \"apple-icloud\": 983096,\n \"apple-ios\": 983095,\n \"apple-keyboard-caps\": 984626,\n \"apple-keyboard-command\": 984627,\n \"apple-keyboard-control\": 984628,\n \"apple-keyboard-option\": 984629,\n \"apple-keyboard-shift\": 984630,\n \"apple-safari\": 983097,\n \"application\": 985286,\n \"application-array\": 987381,\n \"application-array-outline\": 987382,\n \"application-braces\": 987383,\n \"application-braces-outline\": 987384,\n \"application-brackets\": 986251,\n \"application-brackets-outline\": 986252,\n \"application-cog\": 984693,\n \"application-cog-outline\": 988535,\n \"application-edit\": 983214,\n \"application-edit-outline\": 984601,\n \"application-export\": 986541,\n \"application-import\": 986542,\n \"application-outline\": 984596,\n \"application-parentheses\": 987385,\n \"application-parentheses-outline\": 987386,\n \"application-settings\": 985952,\n \"application-settings-outline\": 988501,\n \"application-variable\": 987387,\n \"application-variable-outline\": 987388,\n \"approximately-equal\": 987038,\n \"approximately-equal-box\": 987039,\n \"apps\": 983099,\n \"apps-box\": 986438,\n \"arch\": 985287,\n \"archive\": 983100,\n \"archive-alert\": 988413,\n \"archive-alert-outline\": 988414,\n \"archive-arrow-down\": 987737,\n \"archive-arrow-down-outline\": 987738,\n \"archive-arrow-up\": 987739,\n \"archive-arrow-up-outline\": 987740,\n \"archive-cancel\": 989003,\n \"archive-cancel-outline\": 989004,\n \"archive-check\": 989005,\n \"archive-check-outline\": 989006,\n \"archive-clock\": 989007,\n \"archive-clock-outline\": 989008,\n \"archive-cog\": 989009,\n \"archive-cog-outline\": 989010,\n \"archive-edit\": 989011,\n \"archive-edit-outline\": 989012,\n \"archive-eye\": 989013,\n \"archive-eye-outline\": 989014,\n \"archive-lock\": 989015,\n \"archive-lock-open\": 989016,\n \"archive-lock-open-outline\": 989017,\n \"archive-lock-outline\": 989018,\n \"archive-marker\": 989019,\n \"archive-marker-outline\": 989020,\n \"archive-minus\": 989021,\n \"archive-minus-outline\": 989022,\n \"archive-music\": 989023,\n \"archive-music-outline\": 989024,\n \"archive-off\": 989025,\n \"archive-off-outline\": 989026,\n \"archive-outline\": 987662,\n \"archive-plus\": 989027,\n \"archive-plus-outline\": 989028,\n \"archive-refresh\": 989029,\n \"archive-refresh-outline\": 989030,\n \"archive-remove\": 989031,\n \"archive-remove-outline\": 989032,\n \"archive-search\": 989033,\n \"archive-search-outline\": 989034,\n \"archive-settings\": 989035,\n \"archive-settings-outline\": 989036,\n \"archive-star\": 989037,\n \"archive-star-outline\": 989038,\n \"archive-sync\": 989039,\n \"archive-sync-outline\": 989040,\n \"arm-flex\": 987095,\n \"arm-flex-outline\": 987094,\n \"arrange-bring-forward\": 983101,\n \"arrange-bring-to-front\": 983102,\n \"arrange-send-backward\": 983103,\n \"arrange-send-to-back\": 983104,\n \"arrow-all\": 983105,\n \"arrow-bottom-left\": 983106,\n \"arrow-bottom-left-bold-box\": 989540,\n \"arrow-bottom-left-bold-box-outline\": 989541,\n \"arrow-bottom-left-bold-outline\": 985527,\n \"arrow-bottom-left-thick\": 985528,\n \"arrow-bottom-left-thin\": 989622,\n \"arrow-bottom-left-thin-circle-outline\": 988566,\n \"arrow-bottom-right\": 983107,\n \"arrow-bottom-right-bold-box\": 989542,\n \"arrow-bottom-right-bold-box-outline\": 989543,\n \"arrow-bottom-right-bold-outline\": 985529,\n \"arrow-bottom-right-thick\": 985530,\n \"arrow-bottom-right-thin\": 989623,\n \"arrow-bottom-right-thin-circle-outline\": 988565,\n \"arrow-collapse\": 984597,\n \"arrow-collapse-all\": 983108,\n \"arrow-collapse-down\": 984978,\n \"arrow-collapse-horizontal\": 985164,\n \"arrow-collapse-left\": 984979,\n \"arrow-collapse-right\": 984980,\n \"arrow-collapse-up\": 984981,\n \"arrow-collapse-vertical\": 985165,\n \"arrow-decision\": 985531,\n \"arrow-decision-auto\": 985532,\n \"arrow-decision-auto-outline\": 985533,\n \"arrow-decision-outline\": 985534,\n \"arrow-down\": 983109,\n \"arrow-down-bold\": 984878,\n \"arrow-down-bold-box\": 984879,\n \"arrow-down-bold-box-outline\": 984880,\n \"arrow-down-bold-circle\": 983111,\n \"arrow-down-bold-circle-outline\": 983112,\n \"arrow-down-bold-hexagon-outline\": 983113,\n \"arrow-down-bold-outline\": 985535,\n \"arrow-down-box\": 984768,\n \"arrow-down-circle\": 986331,\n \"arrow-down-circle-outline\": 986332,\n \"arrow-down-drop-circle\": 983114,\n \"arrow-down-drop-circle-outline\": 983115,\n \"arrow-down-left\": 989089,\n \"arrow-down-left-bold\": 989090,\n \"arrow-down-right\": 989091,\n \"arrow-down-right-bold\": 989092,\n \"arrow-down-thick\": 983110,\n \"arrow-down-thin\": 989619,\n \"arrow-down-thin-circle-outline\": 988569,\n \"arrow-expand\": 984598,\n \"arrow-expand-all\": 983116,\n \"arrow-expand-down\": 984982,\n \"arrow-expand-horizontal\": 985166,\n \"arrow-expand-left\": 984983,\n \"arrow-expand-right\": 984984,\n \"arrow-expand-up\": 984985,\n \"arrow-expand-vertical\": 985167,\n \"arrow-horizontal-lock\": 987483,\n \"arrow-left\": 983117,\n \"arrow-left-bold\": 984881,\n \"arrow-left-bold-box\": 984882,\n \"arrow-left-bold-box-outline\": 984883,\n \"arrow-left-bold-circle\": 983119,\n \"arrow-left-bold-circle-outline\": 983120,\n \"arrow-left-bold-hexagon-outline\": 983121,\n \"arrow-left-bold-outline\": 985536,\n \"arrow-left-bottom\": 989093,\n \"arrow-left-bottom-bold\": 989094,\n \"arrow-left-box\": 984769,\n \"arrow-left-circle\": 986333,\n \"arrow-left-circle-outline\": 986334,\n \"arrow-left-drop-circle\": 983122,\n \"arrow-left-drop-circle-outline\": 983123,\n \"arrow-left-right\": 986739,\n \"arrow-left-right-bold\": 986740,\n \"arrow-left-right-bold-outline\": 985537,\n \"arrow-left-thick\": 983118,\n \"arrow-left-thin\": 989617,\n \"arrow-left-thin-circle-outline\": 988570,\n \"arrow-left-top\": 989095,\n \"arrow-left-top-bold\": 989096,\n \"arrow-projectile\": 989248,\n \"arrow-projectile-multiple\": 989247,\n \"arrow-right\": 983124,\n \"arrow-right-bold\": 984884,\n \"arrow-right-bold-box\": 984885,\n \"arrow-right-bold-box-outline\": 984886,\n \"arrow-right-bold-circle\": 983126,\n \"arrow-right-bold-circle-outline\": 983127,\n \"arrow-right-bold-hexagon-outline\": 983128,\n \"arrow-right-bold-outline\": 985538,\n \"arrow-right-bottom\": 989097,\n \"arrow-right-bottom-bold\": 989098,\n \"arrow-right-box\": 984770,\n \"arrow-right-circle\": 986335,\n \"arrow-right-circle-outline\": 986336,\n \"arrow-right-drop-circle\": 983129,\n \"arrow-right-drop-circle-outline\": 983130,\n \"arrow-right-thick\": 983125,\n \"arrow-right-thin\": 989616,\n \"arrow-right-thin-circle-outline\": 988568,\n \"arrow-right-top\": 989099,\n \"arrow-right-top-bold\": 989100,\n \"arrow-split-horizontal\": 985403,\n \"arrow-split-vertical\": 985404,\n \"arrow-top-left\": 983131,\n \"arrow-top-left-bold-box\": 989544,\n \"arrow-top-left-bold-box-outline\": 989545,\n \"arrow-top-left-bold-outline\": 985539,\n \"arrow-top-left-bottom-right\": 986741,\n \"arrow-top-left-bottom-right-bold\": 986742,\n \"arrow-top-left-thick\": 985540,\n \"arrow-top-left-thin\": 989621,\n \"arrow-top-left-thin-circle-outline\": 988563,\n \"arrow-top-right\": 983132,\n \"arrow-top-right-bold-box\": 989546,\n \"arrow-top-right-bold-box-outline\": 989547,\n \"arrow-top-right-bold-outline\": 985541,\n \"arrow-top-right-bottom-left\": 986743,\n \"arrow-top-right-bottom-left-bold\": 986744,\n \"arrow-top-right-thick\": 985542,\n \"arrow-top-right-thin\": 989620,\n \"arrow-top-right-thin-circle-outline\": 988564,\n \"arrow-u-down-left\": 989101,\n \"arrow-u-down-left-bold\": 989102,\n \"arrow-u-down-right\": 989103,\n \"arrow-u-down-right-bold\": 989104,\n \"arrow-u-left-bottom\": 989105,\n \"arrow-u-left-bottom-bold\": 989106,\n \"arrow-u-left-top\": 989107,\n \"arrow-u-left-top-bold\": 989108,\n \"arrow-u-right-bottom\": 989109,\n \"arrow-u-right-bottom-bold\": 989110,\n \"arrow-u-right-top\": 989111,\n \"arrow-u-right-top-bold\": 989112,\n \"arrow-u-up-left\": 989113,\n \"arrow-u-up-left-bold\": 989114,\n \"arrow-u-up-right\": 989115,\n \"arrow-u-up-right-bold\": 989116,\n \"arrow-up\": 983133,\n \"arrow-up-bold\": 984887,\n \"arrow-up-bold-box\": 984888,\n \"arrow-up-bold-box-outline\": 984889,\n \"arrow-up-bold-circle\": 983135,\n \"arrow-up-bold-circle-outline\": 983136,\n \"arrow-up-bold-hexagon-outline\": 983137,\n \"arrow-up-bold-outline\": 985543,\n \"arrow-up-box\": 984771,\n \"arrow-up-circle\": 986337,\n \"arrow-up-circle-outline\": 986338,\n \"arrow-up-down\": 986745,\n \"arrow-up-down-bold\": 986746,\n \"arrow-up-down-bold-outline\": 985544,\n \"arrow-up-drop-circle\": 983138,\n \"arrow-up-drop-circle-outline\": 983139,\n \"arrow-up-left\": 989117,\n \"arrow-up-left-bold\": 989118,\n \"arrow-up-right\": 989119,\n \"arrow-up-right-bold\": 989120,\n \"arrow-up-thick\": 983134,\n \"arrow-up-thin\": 989618,\n \"arrow-up-thin-circle-outline\": 988567,\n \"arrow-vertical-lock\": 987484,\n \"artstation\": 985947,\n \"aspect-ratio\": 985636,\n \"assistant\": 983140,\n \"asterisk\": 984772,\n \"at\": 983141,\n \"atlassian\": 985092,\n \"atm\": 986439,\n \"atom\": 984936,\n \"atom-variant\": 986747,\n \"attachment\": 983142,\n \"audio-input-rca\": 989291,\n \"audio-input-stereo-minijack\": 989292,\n \"audio-input-xlr\": 989293,\n \"audio-video\": 985405,\n \"audio-video-off\": 987574,\n \"augmented-reality\": 985168,\n \"auto-download\": 988030,\n \"auto-fix\": 983144,\n \"auto-upload\": 983145,\n \"autorenew\": 983146,\n \"av-timer\": 983147,\n \"aws\": 986639,\n \"axe\": 985288,\n \"axe-battle\": 989250,\n \"axis\": 986440,\n \"axis-arrow\": 986441,\n \"axis-arrow-info\": 988174,\n \"axis-arrow-lock\": 986442,\n \"axis-lock\": 986443,\n \"axis-x-arrow\": 986444,\n \"axis-x-arrow-lock\": 986445,\n \"axis-x-rotate-clockwise\": 986446,\n \"axis-x-rotate-counterclockwise\": 986447,\n \"axis-x-y-arrow-lock\": 986448,\n \"axis-y-arrow\": 986449,\n \"axis-y-arrow-lock\": 986450,\n \"axis-y-rotate-clockwise\": 986451,\n \"axis-y-rotate-counterclockwise\": 986452,\n \"axis-z-arrow\": 986453,\n \"axis-z-arrow-lock\": 986454,\n \"axis-z-rotate-clockwise\": 986455,\n \"axis-z-rotate-counterclockwise\": 986456,\n \"babel\": 985637,\n \"baby\": 983148,\n \"baby-bottle\": 986937,\n \"baby-bottle-outline\": 986938,\n \"baby-buggy\": 988128,\n \"baby-carriage\": 984719,\n \"baby-carriage-off\": 987040,\n \"baby-face\": 986748,\n \"baby-face-outline\": 986749,\n \"backburger\": 983149,\n \"backspace\": 983150,\n \"backspace-outline\": 985948,\n \"backspace-reverse\": 986750,\n \"backspace-reverse-outline\": 986751,\n \"backup-restore\": 983151,\n \"bacteria\": 986837,\n \"bacteria-outline\": 986838,\n \"badge-account\": 986535,\n \"badge-account-alert\": 986536,\n \"badge-account-alert-outline\": 986537,\n \"badge-account-horizontal\": 986637,\n \"badge-account-horizontal-outline\": 986638,\n \"badge-account-outline\": 986538,\n \"badminton\": 985169,\n \"bag-carry-on\": 986939,\n \"bag-carry-on-check\": 986469,\n \"bag-carry-on-off\": 986940,\n \"bag-checked\": 986941,\n \"bag-personal\": 986640,\n \"bag-personal-off\": 986641,\n \"bag-personal-off-outline\": 986642,\n \"bag-personal-outline\": 986643,\n \"bag-suitcase\": 988555,\n \"bag-suitcase-off\": 988557,\n \"bag-suitcase-off-outline\": 988558,\n \"bag-suitcase-outline\": 988556,\n \"baguette\": 986942,\n \"balcony\": 989207,\n \"balloon\": 985638,\n \"ballot\": 985545,\n \"ballot-outline\": 985546,\n \"ballot-recount\": 986169,\n \"ballot-recount-outline\": 986170,\n \"bandage\": 986543,\n \"bank\": 983152,\n \"bank-check\": 988757,\n \"bank-minus\": 986544,\n \"bank-off\": 988758,\n \"bank-off-outline\": 988759,\n \"bank-outline\": 986752,\n \"bank-plus\": 986545,\n \"bank-remove\": 986546,\n \"bank-transfer\": 985639,\n \"bank-transfer-in\": 985640,\n \"bank-transfer-out\": 985641,\n \"barcode\": 983153,\n \"barcode-off\": 987702,\n \"barcode-scan\": 983154,\n \"barley\": 983155,\n \"barley-off\": 985949,\n \"barn\": 985950,\n \"barrel\": 983156,\n \"baseball\": 985170,\n \"baseball-bat\": 985171,\n \"baseball-diamond\": 988652,\n \"baseball-diamond-outline\": 988653,\n \"bash\": 987523,\n \"basket\": 983158,\n \"basket-check\": 989413,\n \"basket-check-outline\": 989414,\n \"basket-fill\": 983159,\n \"basket-minus\": 988451,\n \"basket-minus-outline\": 988452,\n \"basket-off\": 988453,\n \"basket-off-outline\": 988454,\n \"basket-outline\": 987521,\n \"basket-plus\": 988455,\n \"basket-plus-outline\": 988456,\n \"basket-remove\": 988457,\n \"basket-remove-outline\": 988458,\n \"basket-unfill\": 983160,\n \"basketball\": 985094,\n \"basketball-hoop\": 986171,\n \"basketball-hoop-outline\": 986172,\n \"bat\": 985951,\n \"bathtub\": 989208,\n \"bathtub-outline\": 989209,\n \"battery\": 983161,\n \"battery-10\": 983162,\n \"battery-10-bluetooth\": 985406,\n \"battery-20\": 983163,\n \"battery-20-bluetooth\": 985407,\n \"battery-30\": 983164,\n \"battery-30-bluetooth\": 985408,\n \"battery-40\": 983165,\n \"battery-40-bluetooth\": 985409,\n \"battery-50\": 983166,\n \"battery-50-bluetooth\": 985410,\n \"battery-60\": 983167,\n \"battery-60-bluetooth\": 985411,\n \"battery-70\": 983168,\n \"battery-70-bluetooth\": 985412,\n \"battery-80\": 983169,\n \"battery-80-bluetooth\": 985413,\n \"battery-90\": 983170,\n \"battery-90-bluetooth\": 985414,\n \"battery-alert\": 983171,\n \"battery-alert-bluetooth\": 985415,\n \"battery-alert-variant\": 987340,\n \"battery-alert-variant-outline\": 987341,\n \"battery-arrow-down\": 989150,\n \"battery-arrow-down-outline\": 989151,\n \"battery-arrow-up\": 989152,\n \"battery-arrow-up-outline\": 989153,\n \"battery-bluetooth\": 985416,\n \"battery-bluetooth-variant\": 985417,\n \"battery-charging\": 983172,\n \"battery-charging-10\": 985244,\n \"battery-charging-100\": 983173,\n \"battery-charging-20\": 983174,\n \"battery-charging-30\": 983175,\n \"battery-charging-40\": 983176,\n \"battery-charging-50\": 985245,\n \"battery-charging-60\": 983177,\n \"battery-charging-70\": 985246,\n \"battery-charging-80\": 983178,\n \"battery-charging-90\": 983179,\n \"battery-charging-high\": 987814,\n \"battery-charging-low\": 987812,\n \"battery-charging-medium\": 987813,\n \"battery-charging-outline\": 985247,\n \"battery-charging-wireless\": 985095,\n \"battery-charging-wireless-10\": 985096,\n \"battery-charging-wireless-20\": 985097,\n \"battery-charging-wireless-30\": 985098,\n \"battery-charging-wireless-40\": 985099,\n \"battery-charging-wireless-50\": 985100,\n \"battery-charging-wireless-60\": 985101,\n \"battery-charging-wireless-70\": 985102,\n \"battery-charging-wireless-80\": 985103,\n \"battery-charging-wireless-90\": 985104,\n \"battery-charging-wireless-alert\": 985105,\n \"battery-charging-wireless-outline\": 985106,\n \"battery-check\": 989154,\n \"battery-check-outline\": 989155,\n \"battery-heart\": 987663,\n \"battery-heart-outline\": 987664,\n \"battery-heart-variant\": 987665,\n \"battery-high\": 987811,\n \"battery-lock\": 989084,\n \"battery-lock-open\": 989085,\n \"battery-low\": 987809,\n \"battery-medium\": 987810,\n \"battery-minus\": 989156,\n \"battery-minus-outline\": 989157,\n \"battery-minus-variant\": 983180,\n \"battery-negative\": 983181,\n \"battery-off\": 987741,\n \"battery-off-outline\": 987742,\n \"battery-outline\": 983182,\n \"battery-plus\": 989158,\n \"battery-plus-outline\": 989159,\n \"battery-plus-variant\": 983183,\n \"battery-positive\": 983184,\n \"battery-remove\": 989160,\n \"battery-remove-outline\": 989161,\n \"battery-sync\": 989236,\n \"battery-sync-outline\": 989237,\n \"battery-unknown\": 983185,\n \"battery-unknown-bluetooth\": 985418,\n \"beach\": 983186,\n \"beaker\": 986346,\n \"beaker-alert\": 987689,\n \"beaker-alert-outline\": 987690,\n \"beaker-check\": 987691,\n \"beaker-check-outline\": 987692,\n \"beaker-minus\": 987693,\n \"beaker-minus-outline\": 987694,\n \"beaker-outline\": 984720,\n \"beaker-plus\": 987695,\n \"beaker-plus-outline\": 987696,\n \"beaker-question\": 987697,\n \"beaker-question-outline\": 987698,\n \"beaker-remove\": 987699,\n \"beaker-remove-outline\": 987700,\n \"bed\": 983779,\n \"bed-double\": 987092,\n \"bed-double-outline\": 987091,\n \"bed-empty\": 985248,\n \"bed-king\": 987090,\n \"bed-king-outline\": 987089,\n \"bed-outline\": 983193,\n \"bed-queen\": 987088,\n \"bed-queen-outline\": 987099,\n \"bed-single\": 987245,\n \"bed-single-outline\": 987246,\n \"bee\": 987041,\n \"bee-flower\": 987042,\n \"beehive-off-outline\": 988141,\n \"beehive-outline\": 987342,\n \"beekeeper\": 988386,\n \"beer\": 983192,\n \"beer-outline\": 987916,\n \"bell\": 983194,\n \"bell-alert\": 986457,\n \"bell-alert-outline\": 986753,\n \"bell-badge\": 987499,\n \"bell-badge-outline\": 983416,\n \"bell-cancel\": 988135,\n \"bell-cancel-outline\": 988136,\n \"bell-check\": 987621,\n \"bell-check-outline\": 987622,\n \"bell-circle\": 986458,\n \"bell-circle-outline\": 986459,\n \"bell-minus\": 988137,\n \"bell-minus-outline\": 988138,\n \"bell-off\": 983195,\n \"bell-off-outline\": 985745,\n \"bell-outline\": 983196,\n \"bell-plus\": 983197,\n \"bell-plus-outline\": 985746,\n \"bell-remove\": 988139,\n \"bell-remove-outline\": 988140,\n \"bell-ring\": 983198,\n \"bell-ring-outline\": 983199,\n \"bell-sleep\": 983200,\n \"bell-sleep-outline\": 985747,\n \"beta\": 983201,\n \"betamax\": 985547,\n \"biathlon\": 986644,\n \"bicycle\": 987292,\n \"bicycle-basket\": 987701,\n \"bicycle-cargo\": 989340,\n \"bicycle-electric\": 988596,\n \"bicycle-penny-farthing\": 988649,\n \"bike\": 983203,\n \"bike-fast\": 987423,\n \"billboard\": 987152,\n \"billiards\": 985953,\n \"billiards-rack\": 985954,\n \"binoculars\": 983205,\n \"bio\": 983206,\n \"biohazard\": 983207,\n \"bird\": 988614,\n \"bitbucket\": 983208,\n \"bitcoin\": 985107,\n \"black-mesa\": 983209,\n \"blender\": 986347,\n \"blender-outline\": 989210,\n \"blender-software\": 983211,\n \"blinds\": 983212,\n \"blinds-open\": 987153,\n \"block-helper\": 983213,\n \"blood-bag\": 986348,\n \"bluetooth\": 983215,\n \"bluetooth-audio\": 983216,\n \"bluetooth-connect\": 983217,\n \"bluetooth-off\": 983218,\n \"bluetooth-settings\": 983219,\n \"bluetooth-transfer\": 983220,\n \"blur\": 983221,\n \"blur-linear\": 983222,\n \"blur-off\": 983223,\n \"blur-radial\": 983224,\n \"bolt\": 986547,\n \"bomb\": 984721,\n \"bomb-off\": 984773,\n \"bone\": 983225,\n \"book\": 983226,\n \"book-account\": 988077,\n \"book-account-outline\": 988078,\n \"book-alert\": 988796,\n \"book-alert-outline\": 988797,\n \"book-alphabet\": 984605,\n \"book-arrow-down\": 988798,\n \"book-arrow-down-outline\": 988799,\n \"book-arrow-left\": 988800,\n \"book-arrow-left-outline\": 988801,\n \"book-arrow-right\": 988802,\n \"book-arrow-right-outline\": 988803,\n \"book-arrow-up\": 988804,\n \"book-arrow-up-outline\": 988805,\n \"book-cancel\": 988806,\n \"book-cancel-outline\": 988807,\n \"book-check\": 988403,\n \"book-check-outline\": 988404,\n \"book-clock\": 988808,\n \"book-clock-outline\": 988809,\n \"book-cog\": 988810,\n \"book-cog-outline\": 988811,\n \"book-cross\": 983202,\n \"book-edit\": 988812,\n \"book-edit-outline\": 988813,\n \"book-education\": 988873,\n \"book-education-outline\": 988874,\n \"book-information-variant\": 987247,\n \"book-lock\": 984986,\n \"book-lock-open\": 984987,\n \"book-lock-open-outline\": 988814,\n \"book-lock-outline\": 988815,\n \"book-marker\": 988816,\n \"book-marker-outline\": 988817,\n \"book-minus\": 984537,\n \"book-minus-multiple\": 985748,\n \"book-minus-multiple-outline\": 985355,\n \"book-minus-outline\": 988818,\n \"book-multiple\": 983227,\n \"book-multiple-outline\": 984118,\n \"book-music\": 983143,\n \"book-music-outline\": 988819,\n \"book-off\": 988820,\n \"book-off-outline\": 988821,\n \"book-open\": 983229,\n \"book-open-blank-variant\": 983230,\n \"book-open-outline\": 985955,\n \"book-open-page-variant\": 984538,\n \"book-open-page-variant-outline\": 988630,\n \"book-open-variant\": 988407,\n \"book-outline\": 985956,\n \"book-play\": 986754,\n \"book-play-outline\": 986755,\n \"book-plus\": 984539,\n \"book-plus-multiple\": 985749,\n \"book-plus-multiple-outline\": 985822,\n \"book-plus-outline\": 988822,\n \"book-refresh\": 988823,\n \"book-refresh-outline\": 988824,\n \"book-remove\": 985751,\n \"book-remove-multiple\": 985750,\n \"book-remove-multiple-outline\": 984266,\n \"book-remove-outline\": 988825,\n \"book-search\": 986756,\n \"book-search-outline\": 986757,\n \"book-settings\": 988826,\n \"book-settings-outline\": 988827,\n \"book-sync\": 988828,\n \"book-sync-outline\": 988872,\n \"book-variant\": 983231,\n \"book-variant-multiple\": 983228,\n \"bookmark\": 983232,\n \"bookmark-box-multiple\": 989548,\n \"bookmark-box-multiple-outline\": 989549,\n \"bookmark-check\": 983233,\n \"bookmark-check-outline\": 988027,\n \"bookmark-minus\": 985548,\n \"bookmark-minus-outline\": 985549,\n \"bookmark-multiple\": 986645,\n \"bookmark-multiple-outline\": 986646,\n \"bookmark-music\": 983234,\n \"bookmark-music-outline\": 988025,\n \"bookmark-off\": 985550,\n \"bookmark-off-outline\": 985551,\n \"bookmark-outline\": 983235,\n \"bookmark-plus\": 983237,\n \"bookmark-plus-outline\": 983236,\n \"bookmark-remove\": 983238,\n \"bookmark-remove-outline\": 988026,\n \"bookshelf\": 987743,\n \"boom-gate\": 986758,\n \"boom-gate-alert\": 986759,\n \"boom-gate-alert-outline\": 986760,\n \"boom-gate-arrow-down\": 986761,\n \"boom-gate-arrow-down-outline\": 986762,\n \"boom-gate-arrow-up\": 986764,\n \"boom-gate-arrow-up-outline\": 986765,\n \"boom-gate-outline\": 986763,\n \"boom-gate-up\": 989177,\n \"boom-gate-up-outline\": 989178,\n \"boombox\": 984540,\n \"boomerang\": 987343,\n \"bootstrap\": 984774,\n \"border-all\": 983239,\n \"border-all-variant\": 985249,\n \"border-bottom\": 983240,\n \"border-bottom-variant\": 985250,\n \"border-color\": 983241,\n \"border-horizontal\": 983242,\n \"border-inside\": 983243,\n \"border-left\": 983244,\n \"border-left-variant\": 985251,\n \"border-none\": 983245,\n \"border-none-variant\": 985252,\n \"border-outside\": 983246,\n \"border-right\": 983247,\n \"border-right-variant\": 985253,\n \"border-style\": 983248,\n \"border-top\": 983249,\n \"border-top-variant\": 985254,\n \"border-vertical\": 983250,\n \"bottle-soda\": 987248,\n \"bottle-soda-classic\": 987249,\n \"bottle-soda-classic-outline\": 988003,\n \"bottle-soda-outline\": 987250,\n \"bottle-tonic\": 987438,\n \"bottle-tonic-outline\": 987439,\n \"bottle-tonic-plus\": 987440,\n \"bottle-tonic-plus-outline\": 987441,\n \"bottle-tonic-skull\": 987442,\n \"bottle-tonic-skull-outline\": 987443,\n \"bottle-wine\": 985172,\n \"bottle-wine-outline\": 987920,\n \"bow-arrow\": 989249,\n \"bow-tie\": 984696,\n \"bowl\": 983694,\n \"bowl-mix\": 984599,\n \"bowl-mix-outline\": 983780,\n \"bowl-outline\": 983721,\n \"bowling\": 983251,\n \"box\": 983252,\n \"box-cutter\": 983253,\n \"box-cutter-off\": 985930,\n \"box-shadow\": 984631,\n \"boxing-glove\": 985957,\n \"braille\": 985552,\n \"brain\": 985553,\n \"bread-slice\": 986350,\n \"bread-slice-outline\": 986351,\n \"bridge\": 984600,\n \"briefcase\": 983254,\n \"briefcase-account\": 986352,\n \"briefcase-account-outline\": 986353,\n \"briefcase-check\": 983255,\n \"briefcase-check-outline\": 987934,\n \"briefcase-clock\": 987344,\n \"briefcase-clock-outline\": 987345,\n \"briefcase-download\": 983256,\n \"briefcase-download-outline\": 986173,\n \"briefcase-edit\": 985752,\n \"briefcase-edit-outline\": 986174,\n \"briefcase-eye\": 989145,\n \"briefcase-eye-outline\": 989146,\n \"briefcase-minus\": 985642,\n \"briefcase-minus-outline\": 986175,\n \"briefcase-off\": 988760,\n \"briefcase-off-outline\": 988761,\n \"briefcase-outline\": 985108,\n \"briefcase-plus\": 985643,\n \"briefcase-plus-outline\": 986176,\n \"briefcase-remove\": 985644,\n \"briefcase-remove-outline\": 986177,\n \"briefcase-search\": 985645,\n \"briefcase-search-outline\": 986178,\n \"briefcase-upload\": 983257,\n \"briefcase-upload-outline\": 986179,\n \"briefcase-variant\": 988308,\n \"briefcase-variant-off\": 988762,\n \"briefcase-variant-off-outline\": 988763,\n \"briefcase-variant-outline\": 988309,\n \"brightness-1\": 983258,\n \"brightness-2\": 983259,\n \"brightness-3\": 983260,\n \"brightness-4\": 983261,\n \"brightness-5\": 983262,\n \"brightness-6\": 983263,\n \"brightness-7\": 983264,\n \"brightness-auto\": 983265,\n \"brightness-percent\": 986354,\n \"broadcast\": 988960,\n \"broadcast-off\": 988961,\n \"broom\": 983266,\n \"brush\": 983267,\n \"brush-off\": 989041,\n \"brush-variant\": 989203,\n \"bucket\": 988181,\n \"bucket-outline\": 988182,\n \"buffet\": 984440,\n \"bug\": 983268,\n \"bug-check\": 985646,\n \"bug-check-outline\": 985647,\n \"bug-outline\": 985648,\n \"bugle\": 986548,\n \"bulldozer\": 985890,\n \"bullet\": 986355,\n \"bulletin-board\": 983269,\n \"bullhorn\": 983270,\n \"bullhorn-outline\": 985891,\n \"bullhorn-variant\": 989550,\n \"bullhorn-variant-outline\": 989551,\n \"bullseye\": 984541,\n \"bullseye-arrow\": 985289,\n \"bulma\": 987879,\n \"bunk-bed\": 987906,\n \"bunk-bed-outline\": 983191,\n \"bus\": 983271,\n \"bus-alert\": 985753,\n \"bus-articulated-end\": 984988,\n \"bus-articulated-front\": 984989,\n \"bus-clock\": 985290,\n \"bus-double-decker\": 984990,\n \"bus-electric\": 989469,\n \"bus-marker\": 987666,\n \"bus-multiple\": 986943,\n \"bus-school\": 984991,\n \"bus-side\": 984992,\n \"bus-stop\": 987154,\n \"bus-stop-covered\": 987155,\n \"bus-stop-uncovered\": 987156,\n \"butterfly\": 988553,\n \"butterfly-outline\": 988554,\n \"cabin-a-frame\": 989324,\n \"cable-data\": 988052,\n \"cached\": 983272,\n \"cactus\": 986549,\n \"cake\": 983273,\n \"cake-layered\": 983274,\n \"cake-variant\": 983275,\n \"cake-variant-outline\": 989168,\n \"calculator\": 983276,\n \"calculator-variant\": 985754,\n \"calculator-variant-outline\": 988582,\n \"calendar\": 983277,\n \"calendar-account\": 986839,\n \"calendar-account-outline\": 986840,\n \"calendar-alert\": 985649,\n \"calendar-arrow-left\": 987444,\n \"calendar-arrow-right\": 987445,\n \"calendar-blank\": 983278,\n \"calendar-blank-multiple\": 987251,\n \"calendar-blank-outline\": 985958,\n \"calendar-check\": 983279,\n \"calendar-check-outline\": 986180,\n \"calendar-clock\": 983280,\n \"calendar-clock-outline\": 988897,\n \"calendar-collapse-horizontal\": 989341,\n \"calendar-cursor\": 988539,\n \"calendar-edit\": 985255,\n \"calendar-end\": 988780,\n \"calendar-expand-horizontal\": 989342,\n \"calendar-export\": 985892,\n \"calendar-heart\": 985554,\n \"calendar-import\": 985893,\n \"calendar-lock\": 988737,\n \"calendar-lock-outline\": 988738,\n \"calendar-minus\": 986460,\n \"calendar-month\": 986647,\n \"calendar-month-outline\": 986648,\n \"calendar-multiple\": 983281,\n \"calendar-multiple-check\": 983282,\n \"calendar-multiselect\": 985650,\n \"calendar-outline\": 985959,\n \"calendar-plus\": 983283,\n \"calendar-question\": 984722,\n \"calendar-range\": 984697,\n \"calendar-range-outline\": 985960,\n \"calendar-refresh\": 983521,\n \"calendar-refresh-outline\": 983555,\n \"calendar-remove\": 983284,\n \"calendar-remove-outline\": 986181,\n \"calendar-search\": 985420,\n \"calendar-star\": 985555,\n \"calendar-start\": 988781,\n \"calendar-sync\": 986766,\n \"calendar-sync-outline\": 986767,\n \"calendar-text\": 983285,\n \"calendar-text-outline\": 986182,\n \"calendar-today\": 983286,\n \"calendar-week\": 985651,\n \"calendar-week-begin\": 985652,\n \"calendar-weekend\": 986841,\n \"calendar-weekend-outline\": 986842,\n \"call-made\": 983287,\n \"call-merge\": 983288,\n \"call-missed\": 983289,\n \"call-received\": 983290,\n \"call-split\": 983291,\n \"camcorder\": 983292,\n \"camcorder-off\": 983295,\n \"camera\": 983296,\n \"camera-account\": 985291,\n \"camera-burst\": 984723,\n \"camera-control\": 985961,\n \"camera-document\": 989297,\n \"camera-document-off\": 989298,\n \"camera-enhance\": 983297,\n \"camera-enhance-outline\": 985962,\n \"camera-flip\": 988633,\n \"camera-flip-outline\": 988634,\n \"camera-front\": 983298,\n \"camera-front-variant\": 983299,\n \"camera-gopro\": 984993,\n \"camera-image\": 985292,\n \"camera-iris\": 983300,\n \"camera-marker\": 989607,\n \"camera-marker-outline\": 989608,\n \"camera-metering-center\": 984994,\n \"camera-metering-matrix\": 984995,\n \"camera-metering-partial\": 984996,\n \"camera-metering-spot\": 984997,\n \"camera-off\": 984543,\n \"camera-off-outline\": 989631,\n \"camera-outline\": 986461,\n \"camera-party-mode\": 983301,\n \"camera-plus\": 986843,\n \"camera-plus-outline\": 986844,\n \"camera-rear\": 983302,\n \"camera-rear-variant\": 983303,\n \"camera-retake\": 986649,\n \"camera-retake-outline\": 986650,\n \"camera-switch\": 983304,\n \"camera-switch-outline\": 985162,\n \"camera-timer\": 983305,\n \"camera-wireless\": 986550,\n \"camera-wireless-outline\": 986551,\n \"campfire\": 986845,\n \"cancel\": 984890,\n \"candelabra\": 989138,\n \"candelabra-fire\": 989139,\n \"candle\": 984546,\n \"candy\": 989552,\n \"candy-off\": 989553,\n \"candy-off-outline\": 989554,\n \"candy-outline\": 989555,\n \"candycane\": 983306,\n \"cannabis\": 984998,\n \"cannabis-off\": 988782,\n \"caps-lock\": 985755,\n \"car\": 983307,\n \"car-2-plus\": 987157,\n \"car-3-plus\": 987158,\n \"car-arrow-left\": 988082,\n \"car-arrow-right\": 988083,\n \"car-back\": 986651,\n \"car-battery\": 983308,\n \"car-brake-abs\": 986183,\n \"car-brake-alert\": 986184,\n \"car-brake-fluid-level\": 989449,\n \"car-brake-hold\": 986462,\n \"car-brake-low-pressure\": 989450,\n \"car-brake-parking\": 986463,\n \"car-brake-retarder\": 987159,\n \"car-brake-temperature\": 989451,\n \"car-brake-worn-linings\": 989452,\n \"car-child-seat\": 987043,\n \"car-clock\": 989556,\n \"car-clutch\": 987160,\n \"car-cog\": 988108,\n \"car-connected\": 983309,\n \"car-convertible\": 984999,\n \"car-coolant-level\": 987161,\n \"car-cruise-control\": 986464,\n \"car-defrost-front\": 986465,\n \"car-defrost-rear\": 986466,\n \"car-door\": 985963,\n \"car-door-lock\": 987293,\n \"car-electric\": 985964,\n \"car-electric-outline\": 988597,\n \"car-emergency\": 988687,\n \"car-esp\": 986185,\n \"car-estate\": 985000,\n \"car-hatchback\": 985001,\n \"car-info\": 987582,\n \"car-key\": 985965,\n \"car-lifted-pickup\": 988461,\n \"car-light-alert\": 989453,\n \"car-light-dimmed\": 986186,\n \"car-light-fog\": 986187,\n \"car-light-high\": 986188,\n \"car-limousine\": 985293,\n \"car-multiple\": 985966,\n \"car-off\": 986652,\n \"car-outline\": 988397,\n \"car-parking-lights\": 986467,\n \"car-pickup\": 985002,\n \"car-seat\": 987044,\n \"car-seat-cooler\": 987045,\n \"car-seat-heater\": 987046,\n \"car-select\": 989305,\n \"car-settings\": 988109,\n \"car-shift-pattern\": 986944,\n \"car-side\": 985003,\n \"car-speed-limiter\": 989454,\n \"car-sports\": 985004,\n \"car-tire-alert\": 986189,\n \"car-traction-control\": 986468,\n \"car-turbocharger\": 987162,\n \"car-wash\": 983310,\n \"car-windshield\": 987163,\n \"car-windshield-outline\": 987164,\n \"car-wireless\": 989304,\n \"car-wrench\": 989204,\n \"carabiner\": 988352,\n \"caravan\": 985005,\n \"card\": 985967,\n \"card-account-details\": 984530,\n \"card-account-details-outline\": 986539,\n \"card-account-details-star\": 983715,\n \"card-account-details-star-outline\": 984795,\n \"card-account-mail\": 983438,\n \"card-account-mail-outline\": 986776,\n \"card-account-phone\": 986777,\n \"card-account-phone-outline\": 986778,\n \"card-bulleted\": 985968,\n \"card-bulleted-off\": 985969,\n \"card-bulleted-off-outline\": 985970,\n \"card-bulleted-outline\": 985971,\n \"card-bulleted-settings\": 985972,\n \"card-bulleted-settings-outline\": 985973,\n \"card-minus\": 988672,\n \"card-minus-outline\": 988673,\n \"card-multiple\": 989169,\n \"card-multiple-outline\": 989170,\n \"card-off\": 988674,\n \"card-off-outline\": 988675,\n \"card-outline\": 985974,\n \"card-plus\": 987647,\n \"card-plus-outline\": 987648,\n \"card-remove\": 988676,\n \"card-remove-outline\": 988677,\n \"card-search\": 987252,\n \"card-search-outline\": 987253,\n \"card-text\": 985975,\n \"card-text-outline\": 985976,\n \"cards\": 984632,\n \"cards-club\": 985294,\n \"cards-club-outline\": 989343,\n \"cards-diamond\": 985295,\n \"cards-diamond-outline\": 987165,\n \"cards-heart\": 985296,\n \"cards-heart-outline\": 989344,\n \"cards-outline\": 984633,\n \"cards-playing\": 989345,\n \"cards-playing-club\": 989346,\n \"cards-playing-club-multiple\": 989347,\n \"cards-playing-club-multiple-outline\": 989348,\n \"cards-playing-club-outline\": 989349,\n \"cards-playing-diamond\": 989350,\n \"cards-playing-diamond-multiple\": 989351,\n \"cards-playing-diamond-multiple-outline\": 989352,\n \"cards-playing-diamond-outline\": 989353,\n \"cards-playing-heart\": 989354,\n \"cards-playing-heart-multiple\": 989355,\n \"cards-playing-heart-multiple-outline\": 989356,\n \"cards-playing-heart-outline\": 989357,\n \"cards-playing-outline\": 984634,\n \"cards-playing-spade\": 989358,\n \"cards-playing-spade-multiple\": 989359,\n \"cards-playing-spade-multiple-outline\": 989360,\n \"cards-playing-spade-outline\": 989361,\n \"cards-spade\": 985297,\n \"cards-spade-outline\": 989362,\n \"cards-variant\": 984775,\n \"carrot\": 983311,\n \"cart\": 983312,\n \"cart-arrow-down\": 986470,\n \"cart-arrow-right\": 986190,\n \"cart-arrow-up\": 986471,\n \"cart-check\": 988650,\n \"cart-heart\": 989408,\n \"cart-minus\": 986472,\n \"cart-off\": 984683,\n \"cart-outline\": 983313,\n \"cart-plus\": 983314,\n \"cart-remove\": 986473,\n \"cart-variant\": 988651,\n \"case-sensitive-alt\": 983315,\n \"cash\": 983316,\n \"cash-100\": 983317,\n \"cash-check\": 988398,\n \"cash-fast\": 989276,\n \"cash-lock\": 988394,\n \"cash-lock-open\": 988395,\n \"cash-marker\": 986552,\n \"cash-minus\": 987744,\n \"cash-multiple\": 983318,\n \"cash-plus\": 987745,\n \"cash-refund\": 985756,\n \"cash-register\": 986356,\n \"cash-remove\": 987746,\n \"cassette\": 985556,\n \"cast\": 983320,\n \"cast-audio\": 987166,\n \"cast-audio-variant\": 989001,\n \"cast-connected\": 983321,\n \"cast-education\": 986653,\n \"cast-off\": 984970,\n \"cast-variant\": 983071,\n \"castle\": 983322,\n \"cat\": 983323,\n \"cctv\": 985006,\n \"cctv-off\": 989279,\n \"ceiling-fan\": 989079,\n \"ceiling-fan-light\": 989080,\n \"ceiling-light\": 984937,\n \"ceiling-light-multiple\": 989405,\n \"ceiling-light-multiple-outline\": 989406,\n \"ceiling-light-outline\": 989127,\n \"cellphone\": 983324,\n \"cellphone-arrow-down\": 985557,\n \"cellphone-basic\": 983326,\n \"cellphone-charging\": 988055,\n \"cellphone-check\": 989181,\n \"cellphone-cog\": 985425,\n \"cellphone-dock\": 983327,\n \"cellphone-information\": 986945,\n \"cellphone-key\": 985422,\n \"cellphone-link\": 983329,\n \"cellphone-link-off\": 983330,\n \"cellphone-lock\": 985423,\n \"cellphone-marker\": 989242,\n \"cellphone-message\": 985299,\n \"cellphone-message-off\": 987346,\n \"cellphone-nfc\": 986768,\n \"cellphone-nfc-off\": 987864,\n \"cellphone-off\": 985424,\n \"cellphone-play\": 987167,\n \"cellphone-remove\": 985421,\n \"cellphone-screenshot\": 985653,\n \"cellphone-settings\": 983331,\n \"cellphone-sound\": 985426,\n \"cellphone-text\": 985298,\n \"cellphone-wireless\": 985109,\n \"centos\": 987418,\n \"certificate\": 983332,\n \"certificate-outline\": 987528,\n \"chair-rolling\": 986952,\n \"chair-school\": 983333,\n \"chandelier\": 989075,\n \"charity\": 986191,\n \"chart-arc\": 983334,\n \"chart-areaspline\": 983335,\n \"chart-areaspline-variant\": 986769,\n \"chart-bar\": 983336,\n \"chart-bar-stacked\": 984938,\n \"chart-bell-curve\": 986192,\n \"chart-bell-curve-cumulative\": 987047,\n \"chart-box\": 988493,\n \"chart-box-outline\": 988494,\n \"chart-box-plus-outline\": 988495,\n \"chart-bubble\": 984547,\n \"chart-donut\": 985007,\n \"chart-donut-variant\": 985008,\n \"chart-gantt\": 984684,\n \"chart-histogram\": 983337,\n \"chart-line\": 983338,\n \"chart-line-stacked\": 984939,\n \"chart-line-variant\": 985009,\n \"chart-multiline\": 985300,\n \"chart-multiple\": 987667,\n \"chart-pie\": 983339,\n \"chart-ppf\": 988032,\n \"chart-sankey\": 987615,\n \"chart-sankey-variant\": 987616,\n \"chart-scatter-plot\": 986770,\n \"chart-scatter-plot-hexbin\": 984685,\n \"chart-timeline\": 984686,\n \"chart-timeline-variant\": 986771,\n \"chart-timeline-variant-shimmer\": 988598,\n \"chart-tree\": 986772,\n \"chart-waterfall\": 989464,\n \"chat\": 985977,\n \"chat-alert\": 985978,\n \"chat-alert-outline\": 987849,\n \"chat-minus\": 988176,\n \"chat-minus-outline\": 988179,\n \"chat-outline\": 986846,\n \"chat-plus\": 988175,\n \"chat-plus-outline\": 988178,\n \"chat-processing\": 985979,\n \"chat-processing-outline\": 987850,\n \"chat-question\": 988984,\n \"chat-question-outline\": 988985,\n \"chat-remove\": 988177,\n \"chat-remove-outline\": 988180,\n \"chat-sleep\": 987857,\n \"chat-sleep-outline\": 987858,\n \"check\": 983340,\n \"check-all\": 983341,\n \"check-bold\": 986654,\n \"check-circle\": 984544,\n \"check-circle-outline\": 984545,\n \"check-decagram\": 984977,\n \"check-decagram-outline\": 988992,\n \"check-network\": 986195,\n \"check-network-outline\": 986196,\n \"check-outline\": 985173,\n \"check-underline\": 986655,\n \"check-underline-circle\": 986656,\n \"check-underline-circle-outline\": 986657,\n \"checkbook\": 985757,\n \"checkbox-blank\": 983342,\n \"checkbox-blank-badge\": 987510,\n \"checkbox-blank-badge-outline\": 983319,\n \"checkbox-blank-circle\": 983343,\n \"checkbox-blank-circle-outline\": 983344,\n \"checkbox-blank-off\": 987884,\n \"checkbox-blank-off-outline\": 987885,\n \"checkbox-blank-outline\": 983345,\n \"checkbox-intermediate\": 985174,\n \"checkbox-marked\": 983346,\n \"checkbox-marked-circle\": 983347,\n \"checkbox-marked-circle-outline\": 983348,\n \"checkbox-marked-circle-plus-outline\": 989479,\n \"checkbox-marked-outline\": 983349,\n \"checkbox-multiple-blank\": 983350,\n \"checkbox-multiple-blank-circle\": 984635,\n \"checkbox-multiple-blank-circle-outline\": 984636,\n \"checkbox-multiple-blank-outline\": 983351,\n \"checkbox-multiple-marked\": 983352,\n \"checkbox-multiple-marked-circle\": 984637,\n \"checkbox-multiple-marked-circle-outline\": 984638,\n \"checkbox-multiple-marked-outline\": 983353,\n \"checkbox-multiple-outline\": 986193,\n \"checkbox-outline\": 986194,\n \"checkerboard\": 983354,\n \"checkerboard-minus\": 987650,\n \"checkerboard-plus\": 987649,\n \"checkerboard-remove\": 987651,\n \"cheese\": 987833,\n \"cheese-off\": 988142,\n \"chef-hat\": 985980,\n \"chemical-weapon\": 983355,\n \"chess-bishop\": 985180,\n \"chess-king\": 985175,\n \"chess-knight\": 985176,\n \"chess-pawn\": 985177,\n \"chess-queen\": 985178,\n \"chess-rook\": 985179,\n \"chevron-double-down\": 983356,\n \"chevron-double-left\": 983357,\n \"chevron-double-right\": 983358,\n \"chevron-double-up\": 983359,\n \"chevron-down\": 983360,\n \"chevron-down-box\": 985558,\n \"chevron-down-box-outline\": 985559,\n \"chevron-down-circle\": 985894,\n \"chevron-down-circle-outline\": 985895,\n \"chevron-left\": 983361,\n \"chevron-left-box\": 985560,\n \"chevron-left-box-outline\": 985561,\n \"chevron-left-circle\": 985896,\n \"chevron-left-circle-outline\": 985897,\n \"chevron-right\": 983362,\n \"chevron-right-box\": 985562,\n \"chevron-right-box-outline\": 985563,\n \"chevron-right-circle\": 985898,\n \"chevron-right-circle-outline\": 985899,\n \"chevron-triple-down\": 986553,\n \"chevron-triple-left\": 986554,\n \"chevron-triple-right\": 986555,\n \"chevron-triple-up\": 986556,\n \"chevron-up\": 983363,\n \"chevron-up-box\": 985564,\n \"chevron-up-box-outline\": 985565,\n \"chevron-up-circle\": 985900,\n \"chevron-up-circle-outline\": 985901,\n \"chili-alert\": 989162,\n \"chili-alert-outline\": 989163,\n \"chili-hot\": 985010,\n \"chili-hot-outline\": 989164,\n \"chili-medium\": 985011,\n \"chili-medium-outline\": 989165,\n \"chili-mild\": 985012,\n \"chili-mild-outline\": 989166,\n \"chili-off\": 988263,\n \"chili-off-outline\": 989167,\n \"chip\": 984602,\n \"church\": 983364,\n \"cigar\": 987529,\n \"cigar-off\": 988187,\n \"circle\": 984933,\n \"circle-box\": 988636,\n \"circle-box-outline\": 988637,\n \"circle-double\": 986773,\n \"circle-edit-outline\": 985301,\n \"circle-expand\": 986774,\n \"circle-half\": 988053,\n \"circle-half-full\": 988054,\n \"circle-medium\": 985566,\n \"circle-multiple\": 985912,\n \"circle-multiple-outline\": 984725,\n \"circle-off-outline\": 987347,\n \"circle-opacity\": 989267,\n \"circle-outline\": 984934,\n \"circle-slice-1\": 985758,\n \"circle-slice-2\": 985759,\n \"circle-slice-3\": 985760,\n \"circle-slice-4\": 985761,\n \"circle-slice-5\": 985762,\n \"circle-slice-6\": 985763,\n \"circle-slice-7\": 985764,\n \"circle-slice-8\": 985765,\n \"circle-small\": 985567,\n \"circular-saw\": 986658,\n \"city\": 983366,\n \"city-variant\": 985654,\n \"city-variant-outline\": 985655,\n \"clipboard\": 983367,\n \"clipboard-account\": 983368,\n \"clipboard-account-outline\": 986197,\n \"clipboard-alert\": 983369,\n \"clipboard-alert-outline\": 986359,\n \"clipboard-arrow-down\": 983370,\n \"clipboard-arrow-down-outline\": 986198,\n \"clipboard-arrow-left\": 983371,\n \"clipboard-arrow-left-outline\": 986360,\n \"clipboard-arrow-right\": 986361,\n \"clipboard-arrow-right-outline\": 986362,\n \"clipboard-arrow-up\": 986199,\n \"clipboard-arrow-up-outline\": 986200,\n \"clipboard-check\": 983374,\n \"clipboard-check-multiple\": 987747,\n \"clipboard-check-multiple-outline\": 987748,\n \"clipboard-check-outline\": 985256,\n \"clipboard-clock\": 988898,\n \"clipboard-clock-outline\": 988899,\n \"clipboard-edit\": 988389,\n \"clipboard-edit-outline\": 988390,\n \"clipboard-file\": 987749,\n \"clipboard-file-outline\": 987750,\n \"clipboard-flow\": 984776,\n \"clipboard-flow-outline\": 987415,\n \"clipboard-list\": 987348,\n \"clipboard-list-outline\": 987349,\n \"clipboard-minus\": 988696,\n \"clipboard-minus-outline\": 988697,\n \"clipboard-multiple\": 987751,\n \"clipboard-multiple-outline\": 987752,\n \"clipboard-off\": 988698,\n \"clipboard-off-outline\": 988699,\n \"clipboard-outline\": 983372,\n \"clipboard-play\": 986201,\n \"clipboard-play-multiple\": 987753,\n \"clipboard-play-multiple-outline\": 987754,\n \"clipboard-play-outline\": 986202,\n \"clipboard-plus\": 984913,\n \"clipboard-plus-outline\": 987935,\n \"clipboard-pulse\": 985181,\n \"clipboard-pulse-outline\": 985182,\n \"clipboard-remove\": 988700,\n \"clipboard-remove-outline\": 988701,\n \"clipboard-search\": 988702,\n \"clipboard-search-outline\": 988703,\n \"clipboard-text\": 983373,\n \"clipboard-text-clock\": 989433,\n \"clipboard-text-clock-outline\": 989434,\n \"clipboard-text-multiple\": 987755,\n \"clipboard-text-multiple-outline\": 987756,\n \"clipboard-text-off\": 988704,\n \"clipboard-text-off-outline\": 988705,\n \"clipboard-text-outline\": 985656,\n \"clipboard-text-play\": 986203,\n \"clipboard-text-play-outline\": 986204,\n \"clipboard-text-search\": 988706,\n \"clipboard-text-search-outline\": 988707,\n \"clippy\": 983375,\n \"clock\": 985428,\n \"clock-alert\": 985429,\n \"clock-alert-outline\": 984526,\n \"clock-check\": 987048,\n \"clock-check-outline\": 987049,\n \"clock-digital\": 986775,\n \"clock-edit\": 989626,\n \"clock-edit-outline\": 989627,\n \"clock-end\": 983377,\n \"clock-fast\": 983378,\n \"clock-in\": 983379,\n \"clock-minus\": 989283,\n \"clock-minus-outline\": 989284,\n \"clock-out\": 983380,\n \"clock-outline\": 983376,\n \"clock-plus\": 989281,\n \"clock-plus-outline\": 989282,\n \"clock-remove\": 989285,\n \"clock-remove-outline\": 989286,\n \"clock-start\": 983381,\n \"clock-time-eight\": 988230,\n \"clock-time-eight-outline\": 988242,\n \"clock-time-eleven\": 988233,\n \"clock-time-eleven-outline\": 988245,\n \"clock-time-five\": 988227,\n \"clock-time-five-outline\": 988239,\n \"clock-time-four\": 988226,\n \"clock-time-four-outline\": 988238,\n \"clock-time-nine\": 988231,\n \"clock-time-nine-outline\": 988243,\n \"clock-time-one\": 988223,\n \"clock-time-one-outline\": 988235,\n \"clock-time-seven\": 988229,\n \"clock-time-seven-outline\": 988241,\n \"clock-time-six\": 988228,\n \"clock-time-six-outline\": 988240,\n \"clock-time-ten\": 988232,\n \"clock-time-ten-outline\": 988244,\n \"clock-time-three\": 988225,\n \"clock-time-three-outline\": 988237,\n \"clock-time-twelve\": 988234,\n \"clock-time-twelve-outline\": 988246,\n \"clock-time-two\": 988224,\n \"clock-time-two-outline\": 988236,\n \"close\": 983382,\n \"close-box\": 983383,\n \"close-box-multiple\": 986205,\n \"close-box-multiple-outline\": 986206,\n \"close-box-outline\": 983384,\n \"close-circle\": 983385,\n \"close-circle-multiple\": 984618,\n \"close-circle-multiple-outline\": 985219,\n \"close-circle-outline\": 983386,\n \"close-network\": 983387,\n \"close-network-outline\": 986207,\n \"close-octagon\": 983388,\n \"close-octagon-outline\": 983389,\n \"close-outline\": 984777,\n \"close-thick\": 988056,\n \"closed-caption\": 983390,\n \"closed-caption-outline\": 986557,\n \"cloud\": 983391,\n \"cloud-alert\": 985568,\n \"cloud-braces\": 985013,\n \"cloud-check\": 983392,\n \"cloud-check-outline\": 987852,\n \"cloud-circle\": 983393,\n \"cloud-download\": 983394,\n \"cloud-download-outline\": 985981,\n \"cloud-lock\": 987633,\n \"cloud-lock-outline\": 987634,\n \"cloud-off-outline\": 983396,\n \"cloud-outline\": 983395,\n \"cloud-print\": 983397,\n \"cloud-print-outline\": 983398,\n \"cloud-question\": 985657,\n \"cloud-refresh\": 984362,\n \"cloud-search\": 985430,\n \"cloud-search-outline\": 985431,\n \"cloud-sync\": 984639,\n \"cloud-sync-outline\": 987862,\n \"cloud-tags\": 985014,\n \"cloud-upload\": 983399,\n \"cloud-upload-outline\": 985982,\n \"clover\": 985110,\n \"coach-lamp\": 987168,\n \"coat-rack\": 987294,\n \"code-array\": 983400,\n \"code-braces\": 983401,\n \"code-braces-box\": 987350,\n \"code-brackets\": 983402,\n \"code-equal\": 983403,\n \"code-greater-than\": 983404,\n \"code-greater-than-or-equal\": 983405,\n \"code-json\": 984614,\n \"code-less-than\": 983406,\n \"code-less-than-or-equal\": 983407,\n \"code-not-equal\": 983408,\n \"code-not-equal-variant\": 983409,\n \"code-parentheses\": 983410,\n \"code-parentheses-box\": 987351,\n \"code-string\": 983411,\n \"code-tags\": 983412,\n \"code-tags-check\": 984724,\n \"codepen\": 983413,\n \"coffee\": 983414,\n \"coffee-maker\": 987295,\n \"coffee-maker-check\": 989489,\n \"coffee-maker-check-outline\": 989490,\n \"coffee-maker-outline\": 989211,\n \"coffee-off\": 987050,\n \"coffee-off-outline\": 987051,\n \"coffee-outline\": 984778,\n \"coffee-to-go\": 983415,\n \"coffee-to-go-outline\": 987918,\n \"coffin\": 985983,\n \"cog\": 984211,\n \"cog-box\": 984212,\n \"cog-clockwise\": 987613,\n \"cog-counterclockwise\": 987614,\n \"cog-off\": 988110,\n \"cog-off-outline\": 988111,\n \"cog-outline\": 985275,\n \"cog-pause\": 989491,\n \"cog-pause-outline\": 989492,\n \"cog-play\": 989493,\n \"cog-play-outline\": 989494,\n \"cog-refresh\": 988254,\n \"cog-refresh-outline\": 988255,\n \"cog-stop\": 989495,\n \"cog-stop-outline\": 989496,\n \"cog-sync\": 988256,\n \"cog-sync-outline\": 988257,\n \"cog-transfer\": 987227,\n \"cog-transfer-outline\": 987228,\n \"cogs\": 985302,\n \"collage\": 984640,\n \"collapse-all\": 985766,\n \"collapse-all-outline\": 985767,\n \"color-helper\": 983417,\n \"comma\": 986659,\n \"comma-box\": 986667,\n \"comma-box-outline\": 986660,\n \"comma-circle\": 986661,\n \"comma-circle-outline\": 986662,\n \"comment\": 983418,\n \"comment-account\": 983419,\n \"comment-account-outline\": 983420,\n \"comment-alert\": 983421,\n \"comment-alert-outline\": 983422,\n \"comment-arrow-left\": 985569,\n \"comment-arrow-left-outline\": 985570,\n \"comment-arrow-right\": 985571,\n \"comment-arrow-right-outline\": 985572,\n \"comment-bookmark\": 988590,\n \"comment-bookmark-outline\": 988591,\n \"comment-check\": 983423,\n \"comment-check-outline\": 983424,\n \"comment-edit\": 987583,\n \"comment-edit-outline\": 987844,\n \"comment-eye\": 985658,\n \"comment-eye-outline\": 985659,\n \"comment-flash\": 988592,\n \"comment-flash-outline\": 988593,\n \"comment-minus\": 988639,\n \"comment-minus-outline\": 988640,\n \"comment-multiple\": 985183,\n \"comment-multiple-outline\": 983425,\n \"comment-off\": 988641,\n \"comment-off-outline\": 988642,\n \"comment-outline\": 983426,\n \"comment-plus\": 985573,\n \"comment-plus-outline\": 983427,\n \"comment-processing\": 983428,\n \"comment-processing-outline\": 983429,\n \"comment-question\": 985111,\n \"comment-question-outline\": 983430,\n \"comment-quote\": 987169,\n \"comment-quote-outline\": 987170,\n \"comment-remove\": 984542,\n \"comment-remove-outline\": 983431,\n \"comment-search\": 985660,\n \"comment-search-outline\": 985661,\n \"comment-text\": 983432,\n \"comment-text-multiple\": 985184,\n \"comment-text-multiple-outline\": 985185,\n \"comment-text-outline\": 983433,\n \"compare\": 983434,\n \"compare-horizontal\": 988306,\n \"compare-remove\": 989363,\n \"compare-vertical\": 988307,\n \"compass\": 983435,\n \"compass-off\": 985984,\n \"compass-off-outline\": 985985,\n \"compass-outline\": 983436,\n \"compass-rose\": 988034,\n \"cone\": 989516,\n \"cone-off\": 989517,\n \"connection\": 988694,\n \"console\": 983437,\n \"console-line\": 985015,\n \"console-network\": 985257,\n \"console-network-outline\": 986208,\n \"consolidate\": 987352,\n \"contactless-payment\": 986474,\n \"contactless-payment-circle\": 983841,\n \"contactless-payment-circle-outline\": 984072,\n \"contacts\": 984779,\n \"contacts-outline\": 984504,\n \"contain\": 985662,\n \"contain-end\": 985663,\n \"contain-start\": 985664,\n \"content-copy\": 983439,\n \"content-cut\": 983440,\n \"content-duplicate\": 983441,\n \"content-paste\": 983442,\n \"content-save\": 983443,\n \"content-save-alert\": 986946,\n \"content-save-alert-outline\": 986947,\n \"content-save-all\": 983444,\n \"content-save-all-outline\": 986948,\n \"content-save-check\": 989418,\n \"content-save-check-outline\": 989419,\n \"content-save-cog\": 988251,\n \"content-save-cog-outline\": 988252,\n \"content-save-edit\": 986363,\n \"content-save-edit-outline\": 986364,\n \"content-save-move\": 986663,\n \"content-save-move-outline\": 986664,\n \"content-save-off\": 988739,\n \"content-save-off-outline\": 988740,\n \"content-save-outline\": 985112,\n \"content-save-settings\": 984603,\n \"content-save-settings-outline\": 985902,\n \"contrast\": 983445,\n \"contrast-box\": 983446,\n \"contrast-circle\": 983447,\n \"controller-classic\": 985986,\n \"controller-classic-outline\": 985987,\n \"cookie\": 983448,\n \"cookie-alert\": 988880,\n \"cookie-alert-outline\": 988881,\n \"cookie-check\": 988882,\n \"cookie-check-outline\": 988883,\n \"cookie-clock\": 988900,\n \"cookie-clock-outline\": 988901,\n \"cookie-cog\": 988884,\n \"cookie-cog-outline\": 988885,\n \"cookie-edit\": 988902,\n \"cookie-edit-outline\": 988903,\n \"cookie-lock\": 988904,\n \"cookie-lock-outline\": 988905,\n \"cookie-minus\": 988890,\n \"cookie-minus-outline\": 988891,\n \"cookie-off\": 988906,\n \"cookie-off-outline\": 988907,\n \"cookie-outline\": 988894,\n \"cookie-plus\": 988886,\n \"cookie-plus-outline\": 988887,\n \"cookie-refresh\": 988908,\n \"cookie-refresh-outline\": 988909,\n \"cookie-remove\": 988888,\n \"cookie-remove-outline\": 988889,\n \"cookie-settings\": 988892,\n \"cookie-settings-outline\": 988893,\n \"coolant-temperature\": 984008,\n \"copyleft\": 989497,\n \"copyright\": 984550,\n \"cordova\": 985432,\n \"corn\": 985016,\n \"corn-off\": 988143,\n \"cosine-wave\": 988281,\n \"counter\": 983449,\n \"countertop\": 989212,\n \"countertop-outline\": 989213,\n \"cow\": 983450,\n \"cow-off\": 989436,\n \"cpu-32-bit\": 986847,\n \"cpu-64-bit\": 986848,\n \"cradle\": 989579,\n \"cradle-outline\": 989585,\n \"crane\": 985186,\n \"creation\": 984692,\n \"creative-commons\": 986475,\n \"credit-card\": 987119,\n \"credit-card-check\": 988112,\n \"credit-card-check-outline\": 988113,\n \"credit-card-chip\": 989455,\n \"credit-card-chip-outline\": 989456,\n \"credit-card-clock\": 986849,\n \"credit-card-clock-outline\": 986850,\n \"credit-card-edit\": 989143,\n \"credit-card-edit-outline\": 989144,\n \"credit-card-fast\": 989457,\n \"credit-card-fast-outline\": 989458,\n \"credit-card-lock\": 989415,\n \"credit-card-lock-outline\": 989416,\n \"credit-card-marker\": 984744,\n \"credit-card-marker-outline\": 986558,\n \"credit-card-minus\": 987052,\n \"credit-card-minus-outline\": 987053,\n \"credit-card-multiple\": 987120,\n \"credit-card-multiple-outline\": 983452,\n \"credit-card-off\": 987121,\n \"credit-card-off-outline\": 984548,\n \"credit-card-outline\": 983451,\n \"credit-card-plus\": 987122,\n \"credit-card-plus-outline\": 984694,\n \"credit-card-refresh\": 988741,\n \"credit-card-refresh-outline\": 988742,\n \"credit-card-refund\": 987123,\n \"credit-card-refund-outline\": 985768,\n \"credit-card-remove\": 987054,\n \"credit-card-remove-outline\": 987055,\n \"credit-card-scan\": 987124,\n \"credit-card-scan-outline\": 983453,\n \"credit-card-search\": 988743,\n \"credit-card-search-outline\": 988744,\n \"credit-card-settings\": 987125,\n \"credit-card-settings-outline\": 985303,\n \"credit-card-sync\": 988745,\n \"credit-card-sync-outline\": 988746,\n \"credit-card-wireless\": 985090,\n \"credit-card-wireless-off\": 984442,\n \"credit-card-wireless-off-outline\": 984443,\n \"credit-card-wireless-outline\": 986476,\n \"cricket\": 986477,\n \"crop\": 983454,\n \"crop-free\": 983455,\n \"crop-landscape\": 983456,\n \"crop-portrait\": 983457,\n \"crop-rotate\": 984726,\n \"crop-square\": 983458,\n \"cross\": 985427,\n \"cross-bolnisi\": 986349,\n \"cross-celtic\": 986357,\n \"cross-outline\": 986358,\n \"crosshairs\": 983459,\n \"crosshairs-gps\": 983460,\n \"crosshairs-off\": 986949,\n \"crosshairs-question\": 987446,\n \"crowd\": 989557,\n \"crown\": 983461,\n \"crown-circle\": 989148,\n \"crown-circle-outline\": 989149,\n \"crown-outline\": 987600,\n \"cryengine\": 985433,\n \"crystal-ball\": 985903,\n \"cube\": 983462,\n \"cube-off\": 988188,\n \"cube-off-outline\": 988189,\n \"cube-outline\": 983463,\n \"cube-scan\": 985988,\n \"cube-send\": 983464,\n \"cube-unfolded\": 983465,\n \"cup\": 983466,\n \"cup-off\": 984549,\n \"cup-off-outline\": 988029,\n \"cup-outline\": 987919,\n \"cup-water\": 983467,\n \"cupboard\": 986950,\n \"cupboard-outline\": 986951,\n \"cupcake\": 985434,\n \"curling\": 985187,\n \"currency-bdt\": 985188,\n \"currency-brl\": 985989,\n \"currency-btc\": 983468,\n \"currency-cny\": 985018,\n \"currency-eth\": 985019,\n \"currency-eur\": 983469,\n \"currency-eur-off\": 987925,\n \"currency-gbp\": 983470,\n \"currency-ils\": 986209,\n \"currency-inr\": 983471,\n \"currency-jpy\": 985020,\n \"currency-krw\": 985021,\n \"currency-kzt\": 985189,\n \"currency-mnt\": 988434,\n \"currency-ngn\": 983472,\n \"currency-php\": 985574,\n \"currency-rial\": 986780,\n \"currency-rub\": 983473,\n \"currency-rupee\": 989558,\n \"currency-sign\": 985022,\n \"currency-try\": 983474,\n \"currency-twd\": 985023,\n \"currency-usd\": 983489,\n \"currency-usd-off\": 984698,\n \"current-ac\": 988288,\n \"current-dc\": 985436,\n \"cursor-default\": 983488,\n \"cursor-default-click\": 986365,\n \"cursor-default-click-outline\": 986366,\n \"cursor-default-gesture\": 987431,\n \"cursor-default-gesture-outline\": 987432,\n \"cursor-default-outline\": 983487,\n \"cursor-move\": 983486,\n \"cursor-pointer\": 983485,\n \"cursor-text\": 984551,\n \"curtains\": 989254,\n \"curtains-closed\": 989255,\n \"cylinder\": 989518,\n \"cylinder-off\": 989519,\n \"dance-ballroom\": 988667,\n \"dance-pole\": 988536,\n \"data-matrix\": 988476,\n \"data-matrix-edit\": 988477,\n \"data-matrix-minus\": 988478,\n \"data-matrix-plus\": 988479,\n \"data-matrix-remove\": 988480,\n \"data-matrix-scan\": 988481,\n \"database\": 983484,\n \"database-alert\": 988730,\n \"database-alert-outline\": 988708,\n \"database-arrow-down\": 988731,\n \"database-arrow-down-outline\": 988709,\n \"database-arrow-left\": 988732,\n \"database-arrow-left-outline\": 988710,\n \"database-arrow-right\": 988733,\n \"database-arrow-right-outline\": 988711,\n \"database-arrow-up\": 988734,\n \"database-arrow-up-outline\": 988712,\n \"database-check\": 985769,\n \"database-check-outline\": 988713,\n \"database-clock\": 988735,\n \"database-clock-outline\": 988714,\n \"database-cog\": 988747,\n \"database-cog-outline\": 988748,\n \"database-edit\": 985990,\n \"database-edit-outline\": 988715,\n \"database-export\": 985438,\n \"database-export-outline\": 988716,\n \"database-eye\": 989471,\n \"database-eye-off\": 989472,\n \"database-eye-off-outline\": 989473,\n \"database-eye-outline\": 989474,\n \"database-import\": 985437,\n \"database-import-outline\": 988717,\n \"database-lock\": 985770,\n \"database-lock-outline\": 988718,\n \"database-marker\": 987894,\n \"database-marker-outline\": 988719,\n \"database-minus\": 983483,\n \"database-minus-outline\": 988720,\n \"database-off\": 988736,\n \"database-off-outline\": 988721,\n \"database-outline\": 988722,\n \"database-plus\": 983482,\n \"database-plus-outline\": 988723,\n \"database-refresh\": 984514,\n \"database-refresh-outline\": 988724,\n \"database-remove\": 986368,\n \"database-remove-outline\": 988725,\n \"database-search\": 985190,\n \"database-search-outline\": 988726,\n \"database-settings\": 986369,\n \"database-settings-outline\": 988727,\n \"database-sync\": 986367,\n \"database-sync-outline\": 988728,\n \"death-star\": 985304,\n \"death-star-variant\": 985305,\n \"deathly-hallows\": 985991,\n \"debian\": 985306,\n \"debug-step-into\": 983481,\n \"debug-step-out\": 983480,\n \"debug-step-over\": 983479,\n \"decagram\": 984940,\n \"decagram-outline\": 984941,\n \"decimal\": 987297,\n \"decimal-comma\": 987298,\n \"decimal-comma-decrease\": 987299,\n \"decimal-comma-increase\": 987300,\n \"decimal-decrease\": 983478,\n \"decimal-increase\": 983477,\n \"delete\": 983476,\n \"delete-alert\": 987301,\n \"delete-alert-outline\": 987302,\n \"delete-circle\": 984707,\n \"delete-circle-outline\": 985992,\n \"delete-clock\": 988502,\n \"delete-clock-outline\": 988503,\n \"delete-empty\": 984780,\n \"delete-empty-outline\": 986781,\n \"delete-forever\": 984552,\n \"delete-forever-outline\": 985993,\n \"delete-off\": 987303,\n \"delete-off-outline\": 987304,\n \"delete-outline\": 985575,\n \"delete-restore\": 985113,\n \"delete-sweep\": 984553,\n \"delete-sweep-outline\": 986210,\n \"delete-variant\": 983475,\n \"delta\": 983490,\n \"desk\": 987705,\n \"desk-lamp\": 985439,\n \"deskphone\": 983491,\n \"desktop-classic\": 985024,\n \"desktop-mac\": 983492,\n \"desktop-mac-dashboard\": 985576,\n \"desktop-tower\": 983493,\n \"desktop-tower-monitor\": 985771,\n \"details\": 983494,\n \"dev-to\": 986478,\n \"developer-board\": 984727,\n \"deviantart\": 983495,\n \"devices\": 987056,\n \"dharmachakra\": 985419,\n \"diabetes\": 987430,\n \"dialpad\": 984604,\n \"diameter\": 986211,\n \"diameter-outline\": 986212,\n \"diameter-variant\": 986213,\n \"diamond\": 985994,\n \"diamond-outline\": 985995,\n \"diamond-stone\": 983496,\n \"dice-1\": 983498,\n \"dice-1-outline\": 987466,\n \"dice-2\": 983499,\n \"dice-2-outline\": 987467,\n \"dice-3\": 983500,\n \"dice-3-outline\": 987468,\n \"dice-4\": 983501,\n \"dice-4-outline\": 987469,\n \"dice-5\": 983502,\n \"dice-5-outline\": 987470,\n \"dice-6\": 983503,\n \"dice-6-outline\": 987471,\n \"dice-d10\": 987475,\n \"dice-d10-outline\": 984943,\n \"dice-d12\": 987476,\n \"dice-d12-outline\": 985191,\n \"dice-d20\": 987477,\n \"dice-d20-outline\": 984554,\n \"dice-d4\": 987472,\n \"dice-d4-outline\": 984555,\n \"dice-d6\": 987473,\n \"dice-d6-outline\": 984557,\n \"dice-d8\": 987474,\n \"dice-d8-outline\": 984556,\n \"dice-multiple\": 984942,\n \"dice-multiple-outline\": 987478,\n \"digital-ocean\": 987703,\n \"dip-switch\": 985025,\n \"directions\": 983504,\n \"directions-fork\": 984641,\n \"disc\": 984558,\n \"disc-alert\": 983505,\n \"disc-player\": 985440,\n \"discord\": 984687,\n \"dishwasher\": 985772,\n \"dishwasher-alert\": 987576,\n \"dishwasher-off\": 987577,\n \"disqus\": 983506,\n \"distribute-horizontal-center\": 987593,\n \"distribute-horizontal-left\": 987592,\n \"distribute-horizontal-right\": 987594,\n \"distribute-vertical-bottom\": 987595,\n \"distribute-vertical-center\": 987596,\n \"distribute-vertical-top\": 987597,\n \"diversify\": 989303,\n \"diving\": 989559,\n \"diving-flippers\": 986559,\n \"diving-helmet\": 986560,\n \"diving-scuba\": 986561,\n \"diving-scuba-flag\": 986562,\n \"diving-scuba-tank\": 986563,\n \"diving-scuba-tank-multiple\": 986564,\n \"diving-snorkel\": 986565,\n \"division\": 983508,\n \"division-box\": 983509,\n \"dlna\": 985665,\n \"dna\": 984708,\n \"dns\": 983510,\n \"dns-outline\": 985996,\n \"dock-bottom\": 987305,\n \"dock-left\": 987306,\n \"dock-right\": 987307,\n \"dock-top\": 988435,\n \"dock-window\": 987308,\n \"docker\": 985192,\n \"doctor\": 985666,\n \"dog\": 985667,\n \"dog-service\": 985773,\n \"dog-side\": 985668,\n \"dog-side-off\": 988910,\n \"dolby\": 984755,\n \"dolly\": 986782,\n \"dolphin\": 989364,\n \"domain\": 983511,\n \"domain-off\": 986479,\n \"domain-plus\": 987309,\n \"domain-remove\": 987310,\n \"dome-light\": 988190,\n \"domino-mask\": 987171,\n \"donkey\": 985026,\n \"door\": 985114,\n \"door-closed\": 985115,\n \"door-closed-lock\": 987311,\n \"door-open\": 985116,\n \"door-sliding\": 989214,\n \"door-sliding-lock\": 989215,\n \"door-sliding-open\": 989216,\n \"doorbell\": 987878,\n \"doorbell-video\": 985193,\n \"dot-net\": 985774,\n \"dots-circle\": 989560,\n \"dots-grid\": 988668,\n \"dots-hexagon\": 988671,\n \"dots-horizontal\": 983512,\n \"dots-horizontal-circle\": 985027,\n \"dots-horizontal-circle-outline\": 985997,\n \"dots-square\": 988669,\n \"dots-triangle\": 988670,\n \"dots-vertical\": 983513,\n \"dots-vertical-circle\": 985028,\n \"dots-vertical-circle-outline\": 985998,\n \"download\": 983514,\n \"download-box\": 988258,\n \"download-box-outline\": 988259,\n \"download-circle\": 988260,\n \"download-circle-outline\": 988261,\n \"download-lock\": 987936,\n \"download-lock-outline\": 987937,\n \"download-multiple\": 985577,\n \"download-network\": 984820,\n \"download-network-outline\": 986214,\n \"download-off\": 987312,\n \"download-off-outline\": 987313,\n \"download-outline\": 985999,\n \"drag\": 983515,\n \"drag-horizontal\": 983516,\n \"drag-horizontal-variant\": 987888,\n \"drag-variant\": 986000,\n \"drag-vertical\": 983517,\n \"drag-vertical-variant\": 987889,\n \"drama-masks\": 986370,\n \"draw\": 986953,\n \"draw-pen\": 989625,\n \"drawing\": 983518,\n \"drawing-box\": 983519,\n \"dresser\": 986954,\n \"dresser-outline\": 986955,\n \"drone\": 983522,\n \"dropbox\": 983523,\n \"drupal\": 983524,\n \"duck\": 983525,\n \"dumbbell\": 983526,\n \"dump-truck\": 986215,\n \"ear-hearing\": 985029,\n \"ear-hearing-off\": 985669,\n \"earbuds\": 989263,\n \"earbuds-off\": 989264,\n \"earbuds-off-outline\": 989265,\n \"earbuds-outline\": 989266,\n \"earth\": 983527,\n \"earth-arrow-right\": 987921,\n \"earth-box\": 984781,\n \"earth-box-minus\": 988167,\n \"earth-box-off\": 984782,\n \"earth-box-plus\": 988166,\n \"earth-box-remove\": 988168,\n \"earth-minus\": 988164,\n \"earth-off\": 983528,\n \"earth-plus\": 988163,\n \"earth-remove\": 988165,\n \"egg\": 985775,\n \"egg-easter\": 985776,\n \"egg-fried\": 989258,\n \"egg-off\": 988144,\n \"egg-off-outline\": 988145,\n \"egg-outline\": 988146,\n \"eiffel-tower\": 988523,\n \"eight-track\": 985578,\n \"eject\": 983530,\n \"eject-outline\": 986001,\n \"electric-switch\": 986783,\n \"electric-switch-closed\": 987353,\n \"electron-framework\": 987172,\n \"elephant\": 985030,\n \"elevation-decline\": 983531,\n \"elevation-rise\": 983532,\n \"elevator\": 983533,\n \"elevator-down\": 987842,\n \"elevator-passenger\": 988033,\n \"elevator-passenger-off\": 989561,\n \"elevator-passenger-off-outline\": 989562,\n \"elevator-passenger-outline\": 989563,\n \"elevator-up\": 987841,\n \"ellipse\": 986784,\n \"ellipse-outline\": 986785,\n \"email\": 983534,\n \"email-alert\": 984783,\n \"email-alert-outline\": 986434,\n \"email-box\": 986371,\n \"email-check\": 985777,\n \"email-check-outline\": 985778,\n \"email-edit\": 986851,\n \"email-edit-outline\": 986852,\n \"email-fast\": 989295,\n \"email-fast-outline\": 989296,\n \"email-lock\": 983537,\n \"email-mark-as-unread\": 986002,\n \"email-minus\": 986853,\n \"email-minus-outline\": 986854,\n \"email-multiple\": 986855,\n \"email-multiple-outline\": 986856,\n \"email-newsletter\": 987057,\n \"email-off\": 988131,\n \"email-off-outline\": 988132,\n \"email-open\": 983535,\n \"email-open-multiple\": 986857,\n \"email-open-multiple-outline\": 986858,\n \"email-open-outline\": 984559,\n \"email-outline\": 983536,\n \"email-plus\": 985579,\n \"email-plus-outline\": 985580,\n \"email-receive\": 987354,\n \"email-receive-outline\": 987355,\n \"email-remove\": 988769,\n \"email-remove-outline\": 988770,\n \"email-seal\": 989531,\n \"email-seal-outline\": 989532,\n \"email-search\": 985441,\n \"email-search-outline\": 985442,\n \"email-send\": 987356,\n \"email-send-outline\": 987357,\n \"email-sync\": 987847,\n \"email-sync-outline\": 987848,\n \"email-variant\": 984560,\n \"ember\": 985904,\n \"emby\": 984756,\n \"emoticon\": 986216,\n \"emoticon-angry\": 986217,\n \"emoticon-angry-outline\": 986218,\n \"emoticon-confused\": 987358,\n \"emoticon-confused-outline\": 987359,\n \"emoticon-cool\": 986219,\n \"emoticon-cool-outline\": 983539,\n \"emoticon-cry\": 986220,\n \"emoticon-cry-outline\": 986221,\n \"emoticon-dead\": 986222,\n \"emoticon-dead-outline\": 984731,\n \"emoticon-devil\": 986223,\n \"emoticon-devil-outline\": 983540,\n \"emoticon-excited\": 986224,\n \"emoticon-excited-outline\": 984732,\n \"emoticon-frown\": 986956,\n \"emoticon-frown-outline\": 986957,\n \"emoticon-happy\": 986225,\n \"emoticon-happy-outline\": 983541,\n \"emoticon-kiss\": 986226,\n \"emoticon-kiss-outline\": 986227,\n \"emoticon-lol\": 987668,\n \"emoticon-lol-outline\": 987669,\n \"emoticon-neutral\": 986228,\n \"emoticon-neutral-outline\": 983542,\n \"emoticon-outline\": 983538,\n \"emoticon-poop\": 983543,\n \"emoticon-poop-outline\": 986229,\n \"emoticon-sad\": 986230,\n \"emoticon-sad-outline\": 983544,\n \"emoticon-sick\": 988540,\n \"emoticon-sick-outline\": 988541,\n \"emoticon-tongue\": 983545,\n \"emoticon-tongue-outline\": 986231,\n \"emoticon-wink\": 986232,\n \"emoticon-wink-outline\": 986233,\n \"engine\": 983546,\n \"engine-off\": 985670,\n \"engine-off-outline\": 985671,\n \"engine-outline\": 983547,\n \"epsilon\": 987360,\n \"equal\": 983548,\n \"equal-box\": 983549,\n \"equalizer\": 986786,\n \"equalizer-outline\": 986787,\n \"eraser\": 983550,\n \"eraser-variant\": 984642,\n \"escalator\": 983551,\n \"escalator-box\": 988057,\n \"escalator-down\": 987840,\n \"escalator-up\": 987839,\n \"eslint\": 986234,\n \"et\": 985779,\n \"ethereum\": 985194,\n \"ethernet\": 983552,\n \"ethernet-cable\": 983553,\n \"ethernet-cable-off\": 983554,\n \"ev-plug-ccs1\": 988441,\n \"ev-plug-ccs2\": 988442,\n \"ev-plug-chademo\": 988443,\n \"ev-plug-tesla\": 988444,\n \"ev-plug-type1\": 988445,\n \"ev-plug-type2\": 988446,\n \"ev-station\": 984561,\n \"evernote\": 983556,\n \"excavator\": 987173,\n \"exclamation\": 983557,\n \"exclamation-thick\": 987704,\n \"exit-run\": 985672,\n \"exit-to-app\": 983558,\n \"expand-all\": 985780,\n \"expand-all-outline\": 985781,\n \"expansion-card\": 985262,\n \"expansion-card-variant\": 987058,\n \"exponent\": 985443,\n \"exponent-box\": 985444,\n \"export\": 983559,\n \"export-variant\": 986003,\n \"eye\": 983560,\n \"eye-arrow-left\": 989437,\n \"eye-arrow-left-outline\": 989438,\n \"eye-arrow-right\": 989439,\n \"eye-arrow-right-outline\": 989440,\n \"eye-check\": 986372,\n \"eye-check-outline\": 986373,\n \"eye-circle\": 986004,\n \"eye-circle-outline\": 986005,\n \"eye-minus\": 987174,\n \"eye-minus-outline\": 987175,\n \"eye-off\": 983561,\n \"eye-off-outline\": 984785,\n \"eye-outline\": 984784,\n \"eye-plus\": 985195,\n \"eye-plus-outline\": 985196,\n \"eye-refresh\": 989564,\n \"eye-refresh-outline\": 989565,\n \"eye-remove\": 988643,\n \"eye-remove-outline\": 988644,\n \"eye-settings\": 985197,\n \"eye-settings-outline\": 985198,\n \"eyedropper\": 983562,\n \"eyedropper-minus\": 988125,\n \"eyedropper-off\": 988127,\n \"eyedropper-plus\": 988124,\n \"eyedropper-remove\": 988126,\n \"eyedropper-variant\": 983563,\n \"face-agent\": 986480,\n \"face-man\": 984643,\n \"face-man-outline\": 986006,\n \"face-man-profile\": 984644,\n \"face-man-shimmer\": 988620,\n \"face-man-shimmer-outline\": 988621,\n \"face-mask\": 988550,\n \"face-mask-outline\": 988551,\n \"face-recognition\": 986235,\n \"face-woman\": 987255,\n \"face-woman-outline\": 987256,\n \"face-woman-profile\": 987254,\n \"face-woman-shimmer\": 988622,\n \"face-woman-shimmer-outline\": 988623,\n \"facebook\": 983564,\n \"facebook-gaming\": 985053,\n \"facebook-messenger\": 983566,\n \"facebook-workplace\": 985905,\n \"factory\": 983567,\n \"family-tree\": 988686,\n \"fan\": 983568,\n \"fan-alert\": 988268,\n \"fan-auto\": 988957,\n \"fan-chevron-down\": 988269,\n \"fan-chevron-up\": 988270,\n \"fan-minus\": 988272,\n \"fan-off\": 985117,\n \"fan-plus\": 988271,\n \"fan-remove\": 988273,\n \"fan-speed-1\": 988274,\n \"fan-speed-2\": 988275,\n \"fan-speed-3\": 988276,\n \"fast-forward\": 983569,\n \"fast-forward-10\": 986481,\n \"fast-forward-15\": 989498,\n \"fast-forward-30\": 986374,\n \"fast-forward-5\": 987640,\n \"fast-forward-60\": 988683,\n \"fast-forward-outline\": 984786,\n \"fax\": 983570,\n \"feather\": 984787,\n \"feature-search\": 985673,\n \"feature-search-outline\": 985674,\n \"fedora\": 985307,\n \"fence\": 989082,\n \"fence-electric\": 989174,\n \"fencing\": 988353,\n \"ferris-wheel\": 986788,\n \"ferry\": 983571,\n \"file\": 983572,\n \"file-account\": 984891,\n \"file-account-outline\": 987176,\n \"file-alert\": 985675,\n \"file-alert-outline\": 985676,\n \"file-cabinet\": 985782,\n \"file-cad\": 986859,\n \"file-cad-box\": 986860,\n \"file-cancel\": 986566,\n \"file-cancel-outline\": 986567,\n \"file-certificate\": 987526,\n \"file-certificate-outline\": 987527,\n \"file-chart\": 983573,\n \"file-chart-outline\": 987177,\n \"file-check\": 983574,\n \"file-check-outline\": 986665,\n \"file-clock\": 987873,\n \"file-clock-outline\": 987874,\n \"file-cloud\": 983575,\n \"file-cloud-outline\": 987178,\n \"file-code\": 983598,\n \"file-code-outline\": 987179,\n \"file-cog\": 987259,\n \"file-cog-outline\": 987260,\n \"file-compare\": 985258,\n \"file-delimited\": 983576,\n \"file-delimited-outline\": 986789,\n \"file-document\": 983577,\n \"file-document-edit\": 986568,\n \"file-document-edit-outline\": 986569,\n \"file-document-multiple\": 988439,\n \"file-document-multiple-outline\": 988440,\n \"file-document-outline\": 985582,\n \"file-download\": 985445,\n \"file-download-outline\": 985446,\n \"file-edit\": 987623,\n \"file-edit-outline\": 987624,\n \"file-excel\": 983579,\n \"file-excel-box\": 983580,\n \"file-excel-box-outline\": 987180,\n \"file-excel-outline\": 987181,\n \"file-export\": 983581,\n \"file-export-outline\": 987182,\n \"file-eye\": 986570,\n \"file-eye-outline\": 986571,\n \"file-find\": 983582,\n \"file-find-outline\": 986007,\n \"file-gif-box\": 986488,\n \"file-hidden\": 984595,\n \"file-image\": 983583,\n \"file-image-marker\": 989042,\n \"file-image-marker-outline\": 989043,\n \"file-image-minus\": 989499,\n \"file-image-minus-outline\": 989500,\n \"file-image-outline\": 986800,\n \"file-image-plus\": 989501,\n \"file-image-plus-outline\": 989502,\n \"file-image-remove\": 989503,\n \"file-image-remove-outline\": 989504,\n \"file-import\": 983584,\n \"file-import-outline\": 987183,\n \"file-jpg-box\": 983589,\n \"file-key\": 987524,\n \"file-key-outline\": 987525,\n \"file-link\": 987511,\n \"file-link-outline\": 987512,\n \"file-lock\": 983585,\n \"file-lock-outline\": 987184,\n \"file-marker\": 989044,\n \"file-marker-outline\": 989045,\n \"file-move\": 985785,\n \"file-move-outline\": 987185,\n \"file-multiple\": 983586,\n \"file-multiple-outline\": 987186,\n \"file-music\": 983587,\n \"file-music-outline\": 986666,\n \"file-outline\": 983588,\n \"file-pdf-box\": 983590,\n \"file-percent\": 985118,\n \"file-percent-outline\": 987187,\n \"file-phone\": 987513,\n \"file-phone-outline\": 987514,\n \"file-plus\": 984914,\n \"file-plus-outline\": 986861,\n \"file-png-box\": 986669,\n \"file-powerpoint\": 983591,\n \"file-powerpoint-box\": 983592,\n \"file-powerpoint-box-outline\": 987188,\n \"file-powerpoint-outline\": 987189,\n \"file-presentation-box\": 983593,\n \"file-question\": 985199,\n \"file-question-outline\": 987190,\n \"file-refresh\": 985368,\n \"file-refresh-outline\": 984385,\n \"file-remove\": 986008,\n \"file-remove-outline\": 987191,\n \"file-replace\": 985906,\n \"file-replace-outline\": 985907,\n \"file-restore\": 984688,\n \"file-restore-outline\": 987192,\n \"file-search\": 986236,\n \"file-search-outline\": 986237,\n \"file-send\": 983594,\n \"file-send-outline\": 987193,\n \"file-settings\": 987257,\n \"file-settings-outline\": 987258,\n \"file-sign\": 989635,\n \"file-star\": 987194,\n \"file-star-outline\": 987195,\n \"file-swap\": 987060,\n \"file-swap-outline\": 987061,\n \"file-sync\": 987670,\n \"file-sync-outline\": 987671,\n \"file-table\": 986238,\n \"file-table-box\": 987361,\n \"file-table-box-multiple\": 987362,\n \"file-table-box-multiple-outline\": 987363,\n \"file-table-box-outline\": 987364,\n \"file-table-outline\": 986239,\n \"file-tree\": 984645,\n \"file-tree-outline\": 988114,\n \"file-undo\": 985308,\n \"file-undo-outline\": 987196,\n \"file-upload\": 985677,\n \"file-upload-outline\": 985678,\n \"file-video\": 983595,\n \"file-video-outline\": 986668,\n \"file-word\": 983596,\n \"file-word-box\": 983597,\n \"file-word-box-outline\": 987197,\n \"file-word-outline\": 987198,\n \"film\": 983599,\n \"filmstrip\": 983600,\n \"filmstrip-box\": 983858,\n \"filmstrip-box-multiple\": 986392,\n \"filmstrip-off\": 983601,\n \"filter\": 983602,\n \"filter-check\": 989420,\n \"filter-check-outline\": 989421,\n \"filter-menu\": 987365,\n \"filter-menu-outline\": 987366,\n \"filter-minus\": 986862,\n \"filter-minus-outline\": 986863,\n \"filter-off\": 988399,\n \"filter-off-outline\": 988400,\n \"filter-outline\": 983603,\n \"filter-plus\": 986864,\n \"filter-plus-outline\": 986865,\n \"filter-remove\": 983604,\n \"filter-remove-outline\": 983605,\n \"filter-variant\": 983606,\n \"filter-variant-minus\": 987410,\n \"filter-variant-plus\": 987411,\n \"filter-variant-remove\": 987199,\n \"finance\": 985119,\n \"find-replace\": 984788,\n \"fingerprint\": 983607,\n \"fingerprint-off\": 986801,\n \"fire\": 983608,\n \"fire-alert\": 988631,\n \"fire-circle\": 989191,\n \"fire-extinguisher\": 986866,\n \"fire-hydrant\": 987447,\n \"fire-hydrant-alert\": 987448,\n \"fire-hydrant-off\": 987449,\n \"fire-off\": 988962,\n \"fire-truck\": 985259,\n \"firebase\": 985447,\n \"firefox\": 983609,\n \"fireplace\": 986670,\n \"fireplace-off\": 986671,\n \"firewire\": 984510,\n \"firework\": 986672,\n \"firework-off\": 988963,\n \"fish\": 983610,\n \"fish-off\": 988147,\n \"fishbowl\": 986867,\n \"fishbowl-outline\": 986868,\n \"fit-to-page\": 986869,\n \"fit-to-page-outline\": 986870,\n \"fit-to-screen\": 989428,\n \"fit-to-screen-outline\": 989429,\n \"flag\": 983611,\n \"flag-checkered\": 983612,\n \"flag-minus\": 986009,\n \"flag-minus-outline\": 987314,\n \"flag-off\": 989422,\n \"flag-off-outline\": 989423,\n \"flag-outline\": 983613,\n \"flag-plus\": 986010,\n \"flag-plus-outline\": 987315,\n \"flag-remove\": 986011,\n \"flag-remove-outline\": 987316,\n \"flag-triangle\": 983615,\n \"flag-variant\": 983616,\n \"flag-variant-outline\": 983614,\n \"flare\": 986482,\n \"flash\": 983617,\n \"flash-alert\": 986871,\n \"flash-alert-outline\": 986872,\n \"flash-auto\": 983618,\n \"flash-off\": 983619,\n \"flash-outline\": 984789,\n \"flash-red-eye\": 984699,\n \"flashlight\": 983620,\n \"flashlight-off\": 983621,\n \"flask\": 983187,\n \"flask-empty\": 983188,\n \"flask-empty-minus\": 987706,\n \"flask-empty-minus-outline\": 987707,\n \"flask-empty-off\": 988148,\n \"flask-empty-off-outline\": 988149,\n \"flask-empty-outline\": 983189,\n \"flask-empty-plus\": 987708,\n \"flask-empty-plus-outline\": 987709,\n \"flask-empty-remove\": 987710,\n \"flask-empty-remove-outline\": 987711,\n \"flask-minus\": 987712,\n \"flask-minus-outline\": 987713,\n \"flask-off\": 988150,\n \"flask-off-outline\": 988151,\n \"flask-outline\": 983190,\n \"flask-plus\": 987714,\n \"flask-plus-outline\": 987715,\n \"flask-remove\": 987716,\n \"flask-remove-outline\": 987717,\n \"flask-round-bottom\": 987723,\n \"flask-round-bottom-empty\": 987724,\n \"flask-round-bottom-empty-outline\": 987725,\n \"flask-round-bottom-outline\": 987726,\n \"fleur-de-lis\": 987907,\n \"flip-horizontal\": 987367,\n \"flip-to-back\": 983623,\n \"flip-to-front\": 983624,\n \"flip-vertical\": 987368,\n \"floor-lamp\": 985309,\n \"floor-lamp-dual\": 987200,\n \"floor-lamp-dual-outline\": 989134,\n \"floor-lamp-outline\": 989128,\n \"floor-lamp-torchiere\": 988999,\n \"floor-lamp-torchiere-outline\": 989142,\n \"floor-lamp-torchiere-variant\": 987201,\n \"floor-lamp-torchiere-variant-outline\": 989135,\n \"floor-plan\": 985121,\n \"floppy\": 983625,\n \"floppy-variant\": 985583,\n \"flower\": 983626,\n \"flower-outline\": 985584,\n \"flower-pollen\": 989317,\n \"flower-pollen-outline\": 989318,\n \"flower-poppy\": 986376,\n \"flower-tulip\": 985585,\n \"flower-tulip-outline\": 985586,\n \"focus-auto\": 986958,\n \"focus-field\": 986959,\n \"focus-field-horizontal\": 986960,\n \"focus-field-vertical\": 986961,\n \"folder\": 983627,\n \"folder-account\": 983628,\n \"folder-account-outline\": 986012,\n \"folder-alert\": 986572,\n \"folder-alert-outline\": 986573,\n \"folder-check\": 989566,\n \"folder-check-outline\": 989567,\n \"folder-clock\": 985786,\n \"folder-clock-outline\": 985787,\n \"folder-cog\": 987263,\n \"folder-cog-outline\": 987264,\n \"folder-download\": 983629,\n \"folder-download-outline\": 987369,\n \"folder-edit\": 985310,\n \"folder-edit-outline\": 986574,\n \"folder-eye\": 989066,\n \"folder-eye-outline\": 989067,\n \"folder-google-drive\": 983630,\n \"folder-heart\": 987370,\n \"folder-heart-outline\": 987371,\n \"folder-hidden\": 989086,\n \"folder-home\": 987317,\n \"folder-home-outline\": 987318,\n \"folder-image\": 983631,\n \"folder-information\": 987319,\n \"folder-information-outline\": 987320,\n \"folder-key\": 985260,\n \"folder-key-network\": 985261,\n \"folder-key-network-outline\": 986240,\n \"folder-key-outline\": 987372,\n \"folder-lock\": 983632,\n \"folder-lock-open\": 983633,\n \"folder-marker\": 987757,\n \"folder-marker-outline\": 987758,\n \"folder-move\": 983634,\n \"folder-move-outline\": 987718,\n \"folder-multiple\": 983635,\n \"folder-multiple-image\": 983636,\n \"folder-multiple-outline\": 983637,\n \"folder-multiple-plus\": 988286,\n \"folder-multiple-plus-outline\": 988287,\n \"folder-music\": 987993,\n \"folder-music-outline\": 987994,\n \"folder-network\": 985200,\n \"folder-network-outline\": 986241,\n \"folder-open\": 984944,\n \"folder-open-outline\": 986575,\n \"folder-outline\": 983638,\n \"folder-plus\": 983639,\n \"folder-plus-outline\": 986013,\n \"folder-pound\": 986377,\n \"folder-pound-outline\": 986378,\n \"folder-refresh\": 984905,\n \"folder-refresh-outline\": 984386,\n \"folder-remove\": 983640,\n \"folder-remove-outline\": 986014,\n \"folder-search\": 985448,\n \"folder-search-outline\": 985449,\n \"folder-settings\": 987261,\n \"folder-settings-outline\": 987262,\n \"folder-star\": 984733,\n \"folder-star-multiple\": 988115,\n \"folder-star-multiple-outline\": 988116,\n \"folder-star-outline\": 986015,\n \"folder-swap\": 987062,\n \"folder-swap-outline\": 987063,\n \"folder-sync\": 986379,\n \"folder-sync-outline\": 986380,\n \"folder-table\": 987875,\n \"folder-table-outline\": 987876,\n \"folder-text\": 986242,\n \"folder-text-outline\": 986243,\n \"folder-upload\": 983641,\n \"folder-upload-outline\": 987373,\n \"folder-zip\": 984811,\n \"folder-zip-outline\": 985017,\n \"font-awesome\": 983098,\n \"food\": 983642,\n \"food-apple\": 983643,\n \"food-apple-outline\": 986244,\n \"food-croissant\": 985032,\n \"food-drumstick\": 988191,\n \"food-drumstick-off\": 988264,\n \"food-drumstick-off-outline\": 988265,\n \"food-drumstick-outline\": 988192,\n \"food-fork-drink\": 984562,\n \"food-halal\": 988530,\n \"food-hot-dog\": 989259,\n \"food-kosher\": 988531,\n \"food-off\": 984563,\n \"food-off-outline\": 989461,\n \"food-outline\": 989462,\n \"food-steak\": 988266,\n \"food-steak-off\": 988267,\n \"food-takeout-box\": 989238,\n \"food-takeout-box-outline\": 989239,\n \"food-turkey\": 988956,\n \"food-variant\": 983644,\n \"food-variant-off\": 988133,\n \"foot-print\": 986962,\n \"football\": 983645,\n \"football-australian\": 983646,\n \"football-helmet\": 983647,\n \"forest\": 989335,\n \"forklift\": 985033,\n \"form-dropdown\": 988160,\n \"form-select\": 988161,\n \"form-textarea\": 987285,\n \"form-textbox\": 984590,\n \"form-textbox-lock\": 987997,\n \"form-textbox-password\": 985077,\n \"format-align-bottom\": 984915,\n \"format-align-center\": 983648,\n \"format-align-justify\": 983649,\n \"format-align-left\": 983650,\n \"format-align-middle\": 984916,\n \"format-align-right\": 983651,\n \"format-align-top\": 984917,\n \"format-annotation-minus\": 985788,\n \"format-annotation-plus\": 984646,\n \"format-bold\": 983652,\n \"format-clear\": 983653,\n \"format-color-fill\": 983654,\n \"format-color-highlight\": 986673,\n \"format-color-marker-cancel\": 987923,\n \"format-color-text\": 984734,\n \"format-columns\": 985311,\n \"format-float-center\": 983655,\n \"format-float-left\": 983656,\n \"format-float-none\": 983657,\n \"format-float-right\": 983658,\n \"format-font\": 984790,\n \"format-font-size-decrease\": 985587,\n \"format-font-size-increase\": 985588,\n \"format-header-1\": 983659,\n \"format-header-2\": 983660,\n \"format-header-3\": 983661,\n \"format-header-4\": 983662,\n \"format-header-5\": 983663,\n \"format-header-6\": 983664,\n \"format-header-decrease\": 983665,\n \"format-header-equal\": 983666,\n \"format-header-increase\": 983667,\n \"format-header-pound\": 983668,\n \"format-horizontal-align-center\": 984606,\n \"format-horizontal-align-left\": 984607,\n \"format-horizontal-align-right\": 984608,\n \"format-indent-decrease\": 983669,\n \"format-indent-increase\": 983670,\n \"format-italic\": 983671,\n \"format-letter-case\": 985908,\n \"format-letter-case-lower\": 985909,\n \"format-letter-case-upper\": 985910,\n \"format-letter-ends-with\": 987064,\n \"format-letter-matches\": 987065,\n \"format-letter-spacing\": 989526,\n \"format-letter-starts-with\": 987066,\n \"format-line-spacing\": 983672,\n \"format-line-style\": 984520,\n \"format-line-weight\": 984521,\n \"format-list-bulleted\": 983673,\n \"format-list-bulleted-square\": 986576,\n \"format-list-bulleted-triangle\": 986802,\n \"format-list-bulleted-type\": 983674,\n \"format-list-checkbox\": 985450,\n \"format-list-checks\": 984918,\n \"format-list-group\": 989280,\n \"format-list-numbered\": 983675,\n \"format-list-numbered-rtl\": 986381,\n \"format-list-text\": 987759,\n \"format-overline\": 986803,\n \"format-page-break\": 984791,\n \"format-page-split\": 989463,\n \"format-paint\": 983676,\n \"format-paragraph\": 983677,\n \"format-pilcrow\": 984792,\n \"format-quote-close\": 983678,\n \"format-quote-close-outline\": 987560,\n \"format-quote-open\": 984919,\n \"format-quote-open-outline\": 987559,\n \"format-rotate-90\": 984746,\n \"format-section\": 984735,\n \"format-size\": 983679,\n \"format-strikethrough\": 983680,\n \"format-strikethrough-variant\": 983681,\n \"format-subscript\": 983682,\n \"format-superscript\": 983683,\n \"format-text\": 983684,\n \"format-text-rotation-angle-down\": 987067,\n \"format-text-rotation-angle-up\": 987068,\n \"format-text-rotation-down\": 986483,\n \"format-text-rotation-down-vertical\": 987069,\n \"format-text-rotation-none\": 986484,\n \"format-text-rotation-up\": 987070,\n \"format-text-rotation-vertical\": 987071,\n \"format-text-variant\": 986674,\n \"format-text-variant-outline\": 988431,\n \"format-text-wrapping-clip\": 986382,\n \"format-text-wrapping-overflow\": 986383,\n \"format-text-wrapping-wrap\": 986384,\n \"format-textbox\": 986385,\n \"format-textdirection-l-to-r\": 983685,\n \"format-textdirection-r-to-l\": 983686,\n \"format-title\": 984564,\n \"format-underline\": 983687,\n \"format-underline-wavy\": 989417,\n \"format-vertical-align-bottom\": 984609,\n \"format-vertical-align-center\": 984610,\n \"format-vertical-align-top\": 984611,\n \"format-wrap-inline\": 983688,\n \"format-wrap-square\": 983689,\n \"format-wrap-tight\": 983690,\n \"format-wrap-top-bottom\": 983691,\n \"forum\": 983692,\n \"forum-outline\": 985122,\n \"forward\": 983693,\n \"forwardburger\": 986485,\n \"fountain\": 985451,\n \"fountain-pen\": 986386,\n \"fountain-pen-tip\": 986387,\n \"fraction-one-half\": 989586,\n \"freebsd\": 985312,\n \"french-fries\": 989527,\n \"frequently-asked-questions\": 986804,\n \"fridge\": 983696,\n \"fridge-alert\": 987569,\n \"fridge-alert-outline\": 987570,\n \"fridge-bottom\": 983698,\n \"fridge-industrial\": 988654,\n \"fridge-industrial-alert\": 988655,\n \"fridge-industrial-alert-outline\": 988656,\n \"fridge-industrial-off\": 988657,\n \"fridge-industrial-off-outline\": 988658,\n \"fridge-industrial-outline\": 988659,\n \"fridge-off\": 987567,\n \"fridge-off-outline\": 987568,\n \"fridge-outline\": 983695,\n \"fridge-top\": 983697,\n \"fridge-variant\": 988660,\n \"fridge-variant-alert\": 988661,\n \"fridge-variant-alert-outline\": 988662,\n \"fridge-variant-off\": 988663,\n \"fridge-variant-off-outline\": 988664,\n \"fridge-variant-outline\": 988665,\n \"fruit-cherries\": 987202,\n \"fruit-cherries-off\": 988152,\n \"fruit-citrus\": 987203,\n \"fruit-citrus-off\": 988153,\n \"fruit-grapes\": 987204,\n \"fruit-grapes-outline\": 987205,\n \"fruit-pineapple\": 987206,\n \"fruit-watermelon\": 987207,\n \"fuel\": 985034,\n \"fuel-cell\": 989365,\n \"fullscreen\": 983699,\n \"fullscreen-exit\": 983700,\n \"function\": 983701,\n \"function-variant\": 985201,\n \"furigana-horizontal\": 987265,\n \"furigana-vertical\": 987266,\n \"fuse\": 986245,\n \"fuse-alert\": 988205,\n \"fuse-blade\": 986246,\n \"fuse-off\": 988204,\n \"gamepad\": 983702,\n \"gamepad-circle\": 986675,\n \"gamepad-circle-down\": 986676,\n \"gamepad-circle-left\": 986677,\n \"gamepad-circle-outline\": 986678,\n \"gamepad-circle-right\": 986679,\n \"gamepad-circle-up\": 986680,\n \"gamepad-down\": 986681,\n \"gamepad-left\": 986682,\n \"gamepad-outline\": 989465,\n \"gamepad-right\": 986683,\n \"gamepad-round\": 986684,\n \"gamepad-round-down\": 986685,\n \"gamepad-round-left\": 986686,\n \"gamepad-round-outline\": 986687,\n \"gamepad-round-right\": 986688,\n \"gamepad-round-up\": 986689,\n \"gamepad-square\": 986805,\n \"gamepad-square-outline\": 986806,\n \"gamepad-up\": 986690,\n \"gamepad-variant\": 983703,\n \"gamepad-variant-outline\": 986807,\n \"gamma\": 987374,\n \"gantry-crane\": 986577,\n \"garage\": 984793,\n \"garage-alert\": 985202,\n \"garage-alert-variant\": 987861,\n \"garage-lock\": 989179,\n \"garage-open\": 984794,\n \"garage-open-variant\": 987860,\n \"garage-variant\": 987859,\n \"garage-variant-lock\": 989180,\n \"gas-cylinder\": 984647,\n \"gas-station\": 983704,\n \"gas-station-off\": 988169,\n \"gas-station-off-outline\": 988170,\n \"gas-station-outline\": 986808,\n \"gate\": 983705,\n \"gate-alert\": 989176,\n \"gate-and\": 985313,\n \"gate-arrow-left\": 989175,\n \"gate-arrow-right\": 987497,\n \"gate-nand\": 985314,\n \"gate-nor\": 985315,\n \"gate-not\": 985316,\n \"gate-open\": 987498,\n \"gate-or\": 985317,\n \"gate-xnor\": 985318,\n \"gate-xor\": 985319,\n \"gatsby\": 986691,\n \"gauge\": 983706,\n \"gauge-empty\": 985203,\n \"gauge-full\": 985204,\n \"gauge-low\": 985205,\n \"gavel\": 983707,\n \"gender-female\": 983708,\n \"gender-male\": 983709,\n \"gender-male-female\": 983710,\n \"gender-male-female-variant\": 987455,\n \"gender-non-binary\": 987456,\n \"gender-transgender\": 983711,\n \"gentoo\": 985320,\n \"gesture\": 985035,\n \"gesture-double-tap\": 984892,\n \"gesture-pinch\": 985789,\n \"gesture-spread\": 985790,\n \"gesture-swipe\": 986486,\n \"gesture-swipe-down\": 984893,\n \"gesture-swipe-horizontal\": 985791,\n \"gesture-swipe-left\": 984894,\n \"gesture-swipe-right\": 984895,\n \"gesture-swipe-up\": 984896,\n \"gesture-swipe-vertical\": 985792,\n \"gesture-tap\": 984897,\n \"gesture-tap-box\": 987817,\n \"gesture-tap-button\": 987816,\n \"gesture-tap-hold\": 986487,\n \"gesture-two-double-tap\": 984898,\n \"gesture-two-tap\": 984899,\n \"ghost\": 983712,\n \"ghost-off\": 985589,\n \"ghost-off-outline\": 988764,\n \"ghost-outline\": 988765,\n \"gift\": 986692,\n \"gift-off\": 988911,\n \"gift-off-outline\": 988912,\n \"gift-open\": 988913,\n \"gift-open-outline\": 988914,\n \"gift-outline\": 983713,\n \"git\": 983714,\n \"github\": 983716,\n \"gitlab\": 986016,\n \"glass-cocktail\": 983894,\n \"glass-cocktail-off\": 988646,\n \"glass-flute\": 983717,\n \"glass-fragile\": 989299,\n \"glass-mug\": 983718,\n \"glass-mug-off\": 988647,\n \"glass-mug-variant\": 987414,\n \"glass-mug-variant-off\": 988648,\n \"glass-pint-outline\": 987917,\n \"glass-stange\": 983719,\n \"glass-tulip\": 983720,\n \"glass-wine\": 985206,\n \"glasses\": 983722,\n \"globe-light\": 987863,\n \"globe-model\": 985321,\n \"gmail\": 983723,\n \"gnome\": 983724,\n \"go-kart\": 986489,\n \"go-kart-track\": 986490,\n \"gog\": 986017,\n \"gold\": 987727,\n \"golf\": 985123,\n \"golf-cart\": 987556,\n \"golf-tee\": 987267,\n \"gondola\": 984710,\n \"goodreads\": 986491,\n \"google\": 983725,\n \"google-ads\": 986247,\n \"google-analytics\": 985036,\n \"google-assistant\": 985037,\n \"google-cardboard\": 983726,\n \"google-chrome\": 983727,\n \"google-circles\": 983728,\n \"google-circles-communities\": 983729,\n \"google-circles-extended\": 983730,\n \"google-circles-group\": 983731,\n \"google-classroom\": 983744,\n \"google-cloud\": 987638,\n \"google-controller\": 983732,\n \"google-controller-off\": 983733,\n \"google-downasaur\": 988002,\n \"google-drive\": 983734,\n \"google-earth\": 983735,\n \"google-fit\": 985452,\n \"google-glass\": 983736,\n \"google-hangouts\": 983753,\n \"google-home\": 985124,\n \"google-keep\": 984796,\n \"google-lens\": 985590,\n \"google-maps\": 984565,\n \"google-my-business\": 987208,\n \"google-nearby\": 983737,\n \"google-play\": 983740,\n \"google-plus\": 983741,\n \"google-podcast\": 986809,\n \"google-spreadsheet\": 985591,\n \"google-street-view\": 986248,\n \"google-translate\": 983743,\n \"gradient-horizontal\": 989002,\n \"gradient-vertical\": 984736,\n \"grain\": 986492,\n \"graph\": 987209,\n \"graph-outline\": 987210,\n \"graphql\": 985207,\n \"grass\": 988432,\n \"grave-stone\": 986018,\n \"grease-pencil\": 984648,\n \"greater-than\": 985453,\n \"greater-than-or-equal\": 985454,\n \"greenhouse\": 983085,\n \"grid\": 983745,\n \"grid-large\": 984920,\n \"grid-off\": 983746,\n \"grill\": 986693,\n \"grill-outline\": 987530,\n \"group\": 983747,\n \"guitar-acoustic\": 984945,\n \"guitar-electric\": 983748,\n \"guitar-pick\": 983749,\n \"guitar-pick-outline\": 983750,\n \"guy-fawkes-mask\": 985125,\n \"hail\": 985793,\n \"hair-dryer\": 987375,\n \"hair-dryer-outline\": 987376,\n \"halloween\": 986019,\n \"hamburger\": 984709,\n \"hamburger-check\": 989046,\n \"hamburger-minus\": 989047,\n \"hamburger-off\": 989048,\n \"hamburger-plus\": 989049,\n \"hamburger-remove\": 989050,\n \"hammer\": 985322,\n \"hammer-screwdriver\": 987938,\n \"hammer-sickle\": 989319,\n \"hammer-wrench\": 987939,\n \"hand-back-left\": 986694,\n \"hand-back-left-off\": 989232,\n \"hand-back-left-off-outline\": 989234,\n \"hand-back-left-outline\": 989228,\n \"hand-back-right\": 986695,\n \"hand-back-right-off\": 989233,\n \"hand-back-right-off-outline\": 989235,\n \"hand-back-right-outline\": 989229,\n \"hand-clap\": 989515,\n \"hand-coin\": 989327,\n \"hand-coin-outline\": 989328,\n \"hand-extended\": 989366,\n \"hand-extended-outline\": 989367,\n \"hand-front-left\": 989227,\n \"hand-front-left-outline\": 989230,\n \"hand-front-right\": 985679,\n \"hand-front-right-outline\": 989231,\n \"hand-heart\": 987377,\n \"hand-heart-outline\": 988542,\n \"hand-okay\": 985680,\n \"hand-peace\": 985681,\n \"hand-peace-variant\": 985682,\n \"hand-pointing-down\": 985683,\n \"hand-pointing-left\": 985684,\n \"hand-pointing-right\": 983751,\n \"hand-pointing-up\": 985685,\n \"hand-saw\": 986696,\n \"hand-wash\": 988543,\n \"hand-wash-outline\": 988544,\n \"hand-water\": 988063,\n \"hand-wave\": 989217,\n \"hand-wave-outline\": 989218,\n \"handball\": 986963,\n \"handcuffs\": 987454,\n \"hands-pray\": 984441,\n \"handshake\": 987672,\n \"handshake-outline\": 988577,\n \"hanger\": 983752,\n \"hard-hat\": 985455,\n \"harddisk\": 983754,\n \"harddisk-plus\": 987211,\n \"harddisk-remove\": 987212,\n \"hat-fedora\": 986020,\n \"hazard-lights\": 986249,\n \"hdr\": 986493,\n \"hdr-off\": 986494,\n \"head\": 987998,\n \"head-alert\": 987960,\n \"head-alert-outline\": 987961,\n \"head-check\": 987962,\n \"head-check-outline\": 987963,\n \"head-cog\": 987964,\n \"head-cog-outline\": 987965,\n \"head-dots-horizontal\": 987966,\n \"head-dots-horizontal-outline\": 987967,\n \"head-flash\": 987968,\n \"head-flash-outline\": 987969,\n \"head-heart\": 987970,\n \"head-heart-outline\": 987971,\n \"head-lightbulb\": 987972,\n \"head-lightbulb-outline\": 987973,\n \"head-minus\": 987974,\n \"head-minus-outline\": 987975,\n \"head-outline\": 987999,\n \"head-plus\": 987976,\n \"head-plus-outline\": 987977,\n \"head-question\": 987978,\n \"head-question-outline\": 987979,\n \"head-remove\": 987980,\n \"head-remove-outline\": 987981,\n \"head-snowflake\": 987982,\n \"head-snowflake-outline\": 987983,\n \"head-sync\": 987984,\n \"head-sync-outline\": 987985,\n \"headphones\": 983755,\n \"headphones-bluetooth\": 985456,\n \"headphones-box\": 983756,\n \"headphones-off\": 985038,\n \"headphones-settings\": 983757,\n \"headset\": 983758,\n \"headset-dock\": 983759,\n \"headset-off\": 983760,\n \"heart\": 983761,\n \"heart-box\": 983762,\n \"heart-box-outline\": 983763,\n \"heart-broken\": 983764,\n \"heart-broken-outline\": 986388,\n \"heart-circle\": 985457,\n \"heart-circle-outline\": 985458,\n \"heart-cog\": 988771,\n \"heart-cog-outline\": 988772,\n \"heart-flash\": 986873,\n \"heart-half\": 984799,\n \"heart-half-full\": 984798,\n \"heart-half-outline\": 984800,\n \"heart-minus\": 988207,\n \"heart-minus-outline\": 988210,\n \"heart-multiple\": 985686,\n \"heart-multiple-outline\": 985687,\n \"heart-off\": 984921,\n \"heart-off-outline\": 988212,\n \"heart-outline\": 983765,\n \"heart-plus\": 988206,\n \"heart-plus-outline\": 988209,\n \"heart-pulse\": 984566,\n \"heart-remove\": 988208,\n \"heart-remove-outline\": 988211,\n \"heart-settings\": 988773,\n \"heart-settings-outline\": 988774,\n \"helicopter\": 985794,\n \"help\": 983766,\n \"help-box\": 984971,\n \"help-circle\": 983767,\n \"help-circle-outline\": 984613,\n \"help-network\": 984821,\n \"help-network-outline\": 986250,\n \"help-rhombus\": 986021,\n \"help-rhombus-outline\": 986022,\n \"hexadecimal\": 987815,\n \"hexagon\": 983768,\n \"hexagon-multiple\": 984801,\n \"hexagon-multiple-outline\": 987378,\n \"hexagon-outline\": 983769,\n \"hexagon-slice-1\": 985795,\n \"hexagon-slice-2\": 985796,\n \"hexagon-slice-3\": 985797,\n \"hexagon-slice-4\": 985798,\n \"hexagon-slice-5\": 985799,\n \"hexagon-slice-6\": 985800,\n \"hexagram\": 985801,\n \"hexagram-outline\": 985802,\n \"high-definition\": 985039,\n \"high-definition-box\": 985208,\n \"highway\": 984567,\n \"hiking\": 986495,\n \"history\": 983770,\n \"hockey-puck\": 985209,\n \"hockey-sticks\": 985210,\n \"hololens\": 983771,\n \"home\": 983772,\n \"home-account\": 985126,\n \"home-alert\": 985211,\n \"home-alert-outline\": 988624,\n \"home-analytics\": 986810,\n \"home-assistant\": 985040,\n \"home-automation\": 985041,\n \"home-battery\": 989441,\n \"home-battery-outline\": 989442,\n \"home-circle\": 985042,\n \"home-circle-outline\": 987213,\n \"home-city\": 986389,\n \"home-city-outline\": 986390,\n \"home-edit\": 987481,\n \"home-edit-outline\": 987482,\n \"home-export-outline\": 987035,\n \"home-flood\": 986874,\n \"home-floor-0\": 986578,\n \"home-floor-1\": 986496,\n \"home-floor-2\": 986497,\n \"home-floor-3\": 986498,\n \"home-floor-a\": 986499,\n \"home-floor-b\": 986500,\n \"home-floor-g\": 986501,\n \"home-floor-l\": 986502,\n \"home-floor-negative-1\": 986579,\n \"home-group\": 986580,\n \"home-group-minus\": 989633,\n \"home-group-plus\": 989632,\n \"home-group-remove\": 989634,\n \"home-heart\": 985127,\n \"home-import-outline\": 987036,\n \"home-lightbulb\": 987729,\n \"home-lightbulb-outline\": 987730,\n \"home-lightning-bolt\": 989443,\n \"home-lightning-bolt-outline\": 989444,\n \"home-lock\": 985323,\n \"home-lock-open\": 985324,\n \"home-map-marker\": 984568,\n \"home-minus\": 985460,\n \"home-minus-outline\": 988117,\n \"home-modern\": 983773,\n \"home-outline\": 984737,\n \"home-plus\": 985461,\n \"home-plus-outline\": 988118,\n \"home-remove\": 987719,\n \"home-remove-outline\": 988119,\n \"home-roof\": 987435,\n \"home-search\": 988080,\n \"home-search-outline\": 988081,\n \"home-switch\": 989076,\n \"home-switch-outline\": 989077,\n \"home-thermometer\": 986964,\n \"home-thermometer-outline\": 986965,\n \"home-variant\": 983774,\n \"home-variant-outline\": 986023,\n \"hook\": 984802,\n \"hook-off\": 984803,\n \"hoop-house\": 986710,\n \"hops\": 983775,\n \"horizontal-rotate-clockwise\": 987379,\n \"horizontal-rotate-counterclockwise\": 987380,\n \"horse\": 988607,\n \"horse-human\": 988608,\n \"horse-variant\": 988609,\n \"horse-variant-fast\": 989294,\n \"horseshoe\": 985688,\n \"hospital\": 987126,\n \"hospital-box\": 983776,\n \"hospital-box-outline\": 987127,\n \"hospital-building\": 983777,\n \"hospital-marker\": 983778,\n \"hot-tub\": 985128,\n \"hours-24\": 988280,\n \"hubspot\": 986391,\n \"hulu\": 985129,\n \"human\": 983782,\n \"human-baby-changing-table\": 988043,\n \"human-cane\": 988545,\n \"human-capacity-decrease\": 988571,\n \"human-capacity-increase\": 988572,\n \"human-child\": 983783,\n \"human-dolly\": 989568,\n \"human-edit\": 988392,\n \"human-female\": 984649,\n \"human-female-boy\": 985689,\n \"human-female-dance\": 988617,\n \"human-female-female\": 985690,\n \"human-female-girl\": 985691,\n \"human-greeting\": 989124,\n \"human-greeting-proximity\": 988573,\n \"human-greeting-variant\": 984650,\n \"human-handsdown\": 984651,\n \"human-handsup\": 984652,\n \"human-male\": 984653,\n \"human-male-board\": 985232,\n \"human-male-board-poll\": 985158,\n \"human-male-boy\": 985692,\n \"human-male-child\": 988044,\n \"human-male-female\": 983784,\n \"human-male-female-child\": 989219,\n \"human-male-girl\": 985693,\n \"human-male-height\": 986875,\n \"human-male-height-variant\": 986876,\n \"human-male-male\": 985694,\n \"human-non-binary\": 989256,\n \"human-pregnant\": 984527,\n \"human-queue\": 988529,\n \"human-scooter\": 987625,\n \"human-wheelchair\": 988045,\n \"human-white-cane\": 989569,\n \"humble-bundle\": 984900,\n \"hvac\": 987986,\n \"hvac-off\": 988574,\n \"hydraulic-oil-level\": 987940,\n \"hydraulic-oil-temperature\": 987941,\n \"hydro-power\": 987877,\n \"hydrogen-station\": 989332,\n \"ice-cream\": 985130,\n \"ice-cream-off\": 986706,\n \"ice-pop\": 986877,\n \"id-card\": 987072,\n \"identifier\": 986878,\n \"ideogram-cjk\": 987953,\n \"ideogram-cjk-variant\": 987954,\n \"image\": 983785,\n \"image-album\": 983786,\n \"image-area\": 983787,\n \"image-area-close\": 983788,\n \"image-auto-adjust\": 987073,\n \"image-broken\": 983789,\n \"image-broken-variant\": 983790,\n \"image-edit\": 987619,\n \"image-edit-outline\": 987620,\n \"image-filter-black-white\": 983792,\n \"image-filter-center-focus\": 983793,\n \"image-filter-center-focus-strong\": 986879,\n \"image-filter-center-focus-strong-outline\": 986880,\n \"image-filter-center-focus-weak\": 983794,\n \"image-filter-drama\": 983795,\n \"image-filter-frames\": 983796,\n \"image-filter-hdr\": 983797,\n \"image-filter-none\": 983798,\n \"image-filter-tilt-shift\": 983799,\n \"image-filter-vintage\": 983800,\n \"image-frame\": 986697,\n \"image-marker\": 989051,\n \"image-marker-outline\": 989052,\n \"image-minus\": 988185,\n \"image-move\": 985592,\n \"image-multiple\": 983801,\n \"image-multiple-outline\": 983791,\n \"image-off\": 985131,\n \"image-off-outline\": 987601,\n \"image-outline\": 985462,\n \"image-plus\": 985212,\n \"image-remove\": 988184,\n \"image-search\": 985463,\n \"image-search-outline\": 985464,\n \"image-size-select-actual\": 986253,\n \"image-size-select-large\": 986254,\n \"image-size-select-small\": 986255,\n \"image-text\": 988685,\n \"import\": 983802,\n \"inbox\": 984711,\n \"inbox-arrow-down\": 983803,\n \"inbox-arrow-down-outline\": 987760,\n \"inbox-arrow-up\": 984017,\n \"inbox-arrow-up-outline\": 987761,\n \"inbox-full\": 987762,\n \"inbox-full-outline\": 987763,\n \"inbox-multiple\": 985264,\n \"inbox-multiple-outline\": 986024,\n \"inbox-outline\": 987764,\n \"inbox-remove\": 988575,\n \"inbox-remove-outline\": 988576,\n \"incognito\": 984569,\n \"incognito-circle\": 988193,\n \"incognito-circle-off\": 988194,\n \"incognito-off\": 983157,\n \"induction\": 989260,\n \"infinity\": 984804,\n \"information\": 983804,\n \"information-off\": 989068,\n \"information-off-outline\": 989069,\n \"information-outline\": 983805,\n \"information-variant\": 984654,\n \"instagram\": 983806,\n \"instrument-triangle\": 987214,\n \"integrated-circuit-chip\": 989459,\n \"invert-colors\": 983809,\n \"invert-colors-off\": 986698,\n \"iobroker\": 987880,\n \"ip\": 985695,\n \"ip-network\": 985696,\n \"ip-network-outline\": 986256,\n \"ip-outline\": 989570,\n \"ipod\": 986257,\n \"iron\": 989220,\n \"iron-board\": 989240,\n \"iron-outline\": 989221,\n \"island\": 987215,\n \"iv-bag\": 987321,\n \"jabber\": 986581,\n \"jeepney\": 983810,\n \"jellyfish\": 986881,\n \"jellyfish-outline\": 986882,\n \"jira\": 983811,\n \"jquery\": 985213,\n \"jsfiddle\": 983812,\n \"jump-rope\": 987903,\n \"kabaddi\": 986503,\n \"kangaroo\": 988504,\n \"karate\": 985132,\n \"kayaking\": 985263,\n \"keg\": 983813,\n \"kettle\": 984570,\n \"kettle-alert\": 987927,\n \"kettle-alert-outline\": 987928,\n \"kettle-off\": 987931,\n \"kettle-off-outline\": 987932,\n \"kettle-outline\": 986966,\n \"kettle-pour-over\": 988988,\n \"kettle-steam\": 987929,\n \"kettle-steam-outline\": 987930,\n \"kettlebell\": 987904,\n \"key\": 983814,\n \"key-alert\": 989571,\n \"key-alert-outline\": 989572,\n \"key-arrow-right\": 987922,\n \"key-chain\": 988532,\n \"key-chain-variant\": 988533,\n \"key-change\": 983815,\n \"key-link\": 987551,\n \"key-minus\": 983816,\n \"key-outline\": 986582,\n \"key-plus\": 983817,\n \"key-remove\": 983818,\n \"key-star\": 987550,\n \"key-variant\": 983819,\n \"key-wireless\": 987074,\n \"keyboard\": 983820,\n \"keyboard-backspace\": 983821,\n \"keyboard-caps\": 983822,\n \"keyboard-close\": 983823,\n \"keyboard-esc\": 987831,\n \"keyboard-f1\": 987819,\n \"keyboard-f10\": 987828,\n \"keyboard-f11\": 987829,\n \"keyboard-f12\": 987830,\n \"keyboard-f2\": 987820,\n \"keyboard-f3\": 987821,\n \"keyboard-f4\": 987822,\n \"keyboard-f5\": 987823,\n \"keyboard-f6\": 987824,\n \"keyboard-f7\": 987825,\n \"keyboard-f8\": 987826,\n \"keyboard-f9\": 987827,\n \"keyboard-off\": 983824,\n \"keyboard-off-outline\": 986699,\n \"keyboard-outline\": 985467,\n \"keyboard-return\": 983825,\n \"keyboard-settings\": 985593,\n \"keyboard-settings-outline\": 985594,\n \"keyboard-space\": 987216,\n \"keyboard-tab\": 983826,\n \"keyboard-tab-reverse\": 983845,\n \"keyboard-variant\": 983827,\n \"khanda\": 987389,\n \"kickstarter\": 984901,\n \"kite\": 989573,\n \"kite-outline\": 989574,\n \"kitesurfing\": 988996,\n \"klingon\": 987995,\n \"knife\": 985595,\n \"knife-military\": 985596,\n \"koala\": 988991,\n \"kodi\": 983828,\n \"kubernetes\": 987390,\n \"label\": 983829,\n \"label-multiple\": 988021,\n \"label-multiple-outline\": 988022,\n \"label-off\": 985803,\n \"label-off-outline\": 985804,\n \"label-outline\": 983830,\n \"label-percent\": 987882,\n \"label-percent-outline\": 987883,\n \"label-variant\": 985805,\n \"label-variant-outline\": 985806,\n \"ladder\": 988578,\n \"ladybug\": 985133,\n \"lambda\": 984615,\n \"lamp\": 984757,\n \"lamp-outline\": 989136,\n \"lamps\": 988534,\n \"lamps-outline\": 989137,\n \"lan\": 983831,\n \"lan-check\": 987818,\n \"lan-connect\": 983832,\n \"lan-disconnect\": 983833,\n \"lan-pending\": 983834,\n \"language-c\": 984689,\n \"language-cpp\": 984690,\n \"language-csharp\": 983835,\n \"language-css3\": 983836,\n \"language-fortran\": 987674,\n \"language-go\": 985043,\n \"language-haskell\": 986258,\n \"language-html5\": 983837,\n \"language-java\": 985911,\n \"language-javascript\": 983838,\n \"language-kotlin\": 987673,\n \"language-lua\": 985265,\n \"language-markdown\": 983892,\n \"language-markdown-outline\": 986971,\n \"language-php\": 983839,\n \"language-python\": 983840,\n \"language-r\": 985044,\n \"language-ruby\": 986413,\n \"language-ruby-on-rails\": 985807,\n \"language-rust\": 988695,\n \"language-swift\": 984805,\n \"language-typescript\": 984806,\n \"language-xaml\": 984691,\n \"laptop\": 983842,\n \"laptop-off\": 984807,\n \"laravel\": 985808,\n \"laser-pointer\": 988292,\n \"lasso\": 986883,\n \"lastpass\": 984134,\n \"latitude\": 986967,\n \"launch\": 983847,\n \"lava-lamp\": 985045,\n \"layers\": 983848,\n \"layers-edit\": 989330,\n \"layers-minus\": 986700,\n \"layers-off\": 983849,\n \"layers-off-outline\": 985597,\n \"layers-outline\": 985598,\n \"layers-plus\": 986701,\n \"layers-remove\": 986702,\n \"layers-search\": 987654,\n \"layers-search-outline\": 987655,\n \"layers-triple\": 986968,\n \"layers-triple-outline\": 986969,\n \"lead-pencil\": 984655,\n \"leaf\": 983850,\n \"leaf-circle\": 989445,\n \"leaf-circle-outline\": 989446,\n \"leaf-maple\": 986259,\n \"leaf-maple-off\": 987866,\n \"leaf-off\": 987865,\n \"leak\": 986583,\n \"leak-off\": 986584,\n \"led-off\": 983851,\n \"led-on\": 983852,\n \"led-outline\": 983853,\n \"led-strip\": 985046,\n \"led-strip-variant\": 987217,\n \"led-variant-off\": 983854,\n \"led-variant-on\": 983855,\n \"led-variant-outline\": 983856,\n \"leek\": 987517,\n \"less-than\": 985468,\n \"less-than-or-equal\": 985469,\n \"library\": 983857,\n \"library-shelves\": 986025,\n \"license\": 987075,\n \"lifebuoy\": 985214,\n \"light-flood-down\": 989575,\n \"light-flood-up\": 989576,\n \"light-recessed\": 989083,\n \"light-switch\": 985470,\n \"lightbulb\": 983861,\n \"lightbulb-auto\": 989184,\n \"lightbulb-auto-outline\": 989185,\n \"lightbulb-cfl\": 987656,\n \"lightbulb-cfl-off\": 987657,\n \"lightbulb-cfl-spiral\": 987765,\n \"lightbulb-cfl-spiral-off\": 987843,\n \"lightbulb-fluorescent-tube\": 989188,\n \"lightbulb-fluorescent-tube-outline\": 989189,\n \"lightbulb-group\": 987731,\n \"lightbulb-group-off\": 987853,\n \"lightbulb-group-off-outline\": 987854,\n \"lightbulb-group-outline\": 987732,\n \"lightbulb-multiple\": 987733,\n \"lightbulb-multiple-off\": 987855,\n \"lightbulb-multiple-off-outline\": 987856,\n \"lightbulb-multiple-outline\": 987734,\n \"lightbulb-off\": 986703,\n \"lightbulb-off-outline\": 986704,\n \"lightbulb-on\": 984808,\n \"lightbulb-on-outline\": 984809,\n \"lightbulb-outline\": 983862,\n \"lightbulb-spot\": 989172,\n \"lightbulb-spot-off\": 989173,\n \"lightbulb-variant\": 989186,\n \"lightbulb-variant-outline\": 989187,\n \"lighthouse\": 985599,\n \"lighthouse-on\": 985600,\n \"lightning-bolt\": 988171,\n \"lightning-bolt-circle\": 985120,\n \"lightning-bolt-outline\": 988172,\n \"line-scan\": 984612,\n \"lingerie\": 988278,\n \"link\": 983863,\n \"link-box\": 986394,\n \"link-box-outline\": 986395,\n \"link-box-variant\": 986396,\n \"link-box-variant-outline\": 986397,\n \"link-lock\": 987322,\n \"link-off\": 983864,\n \"link-plus\": 986260,\n \"link-variant\": 983865,\n \"link-variant-minus\": 987391,\n \"link-variant-off\": 983866,\n \"link-variant-plus\": 987392,\n \"link-variant-remove\": 987393,\n \"linkedin\": 983867,\n \"linux\": 983869,\n \"linux-mint\": 985325,\n \"lipstick\": 988085,\n \"liquid-spot\": 989222,\n \"liquor\": 989470,\n \"list-status\": 988587,\n \"litecoin\": 985697,\n \"loading\": 984946,\n \"location-enter\": 987076,\n \"location-exit\": 987077,\n \"lock\": 983870,\n \"lock-alert\": 985326,\n \"lock-alert-outline\": 988625,\n \"lock-check\": 988058,\n \"lock-check-outline\": 988840,\n \"lock-clock\": 985471,\n \"lock-minus\": 988841,\n \"lock-minus-outline\": 988842,\n \"lock-off\": 988785,\n \"lock-off-outline\": 988786,\n \"lock-open\": 983871,\n \"lock-open-alert\": 988059,\n \"lock-open-alert-outline\": 988626,\n \"lock-open-check\": 988060,\n \"lock-open-check-outline\": 988843,\n \"lock-open-minus\": 988844,\n \"lock-open-minus-outline\": 988845,\n \"lock-open-outline\": 983872,\n \"lock-open-plus\": 988846,\n \"lock-open-plus-outline\": 988847,\n \"lock-open-remove\": 988848,\n \"lock-open-remove-outline\": 988849,\n \"lock-open-variant\": 987078,\n \"lock-open-variant-outline\": 987079,\n \"lock-outline\": 983873,\n \"lock-pattern\": 984810,\n \"lock-plus\": 984571,\n \"lock-plus-outline\": 988850,\n \"lock-question\": 985327,\n \"lock-remove\": 988851,\n \"lock-remove-outline\": 988852,\n \"lock-reset\": 984947,\n \"lock-smart\": 985266,\n \"locker\": 985047,\n \"locker-multiple\": 985048,\n \"login\": 983874,\n \"login-variant\": 984572,\n \"logout\": 983875,\n \"logout-variant\": 984573,\n \"longitude\": 986970,\n \"looks\": 983876,\n \"lotion\": 988546,\n \"lotion-outline\": 988547,\n \"lotion-plus\": 988548,\n \"lotion-plus-outline\": 988549,\n \"loupe\": 983877,\n \"lumx\": 983878,\n \"lungs\": 987268,\n \"mace\": 989251,\n \"magazine-pistol\": 983844,\n \"magazine-rifle\": 983843,\n \"magic-staff\": 989252,\n \"magnet\": 983879,\n \"magnet-on\": 983880,\n \"magnify\": 983881,\n \"magnify-close\": 985472,\n \"magnify-expand\": 989300,\n \"magnify-minus\": 983882,\n \"magnify-minus-cursor\": 985698,\n \"magnify-minus-outline\": 984812,\n \"magnify-plus\": 983883,\n \"magnify-plus-cursor\": 985699,\n \"magnify-plus-outline\": 984813,\n \"magnify-remove-cursor\": 987660,\n \"magnify-remove-outline\": 987661,\n \"magnify-scan\": 987766,\n \"mail\": 986811,\n \"mailbox\": 984814,\n \"mailbox-open\": 986504,\n \"mailbox-open-outline\": 986505,\n \"mailbox-open-up\": 986506,\n \"mailbox-open-up-outline\": 986507,\n \"mailbox-outline\": 986508,\n \"mailbox-up\": 986509,\n \"mailbox-up-outline\": 986510,\n \"manjaro\": 988682,\n \"map\": 983885,\n \"map-check\": 986812,\n \"map-check-outline\": 986813,\n \"map-clock\": 986398,\n \"map-clock-outline\": 986399,\n \"map-legend\": 985601,\n \"map-marker\": 983886,\n \"map-marker-account\": 989411,\n \"map-marker-account-outline\": 989412,\n \"map-marker-alert\": 986885,\n \"map-marker-alert-outline\": 986886,\n \"map-marker-check\": 986261,\n \"map-marker-check-outline\": 987899,\n \"map-marker-circle\": 983887,\n \"map-marker-distance\": 985328,\n \"map-marker-down\": 987394,\n \"map-marker-left\": 987867,\n \"map-marker-left-outline\": 987869,\n \"map-marker-minus\": 984656,\n \"map-marker-minus-outline\": 987897,\n \"map-marker-multiple\": 983888,\n \"map-marker-multiple-outline\": 987767,\n \"map-marker-off\": 983889,\n \"map-marker-off-outline\": 987901,\n \"map-marker-outline\": 985049,\n \"map-marker-path\": 986400,\n \"map-marker-plus\": 984657,\n \"map-marker-plus-outline\": 987896,\n \"map-marker-question\": 986887,\n \"map-marker-question-outline\": 986888,\n \"map-marker-radius\": 983890,\n \"map-marker-radius-outline\": 987900,\n \"map-marker-remove\": 986889,\n \"map-marker-remove-outline\": 987898,\n \"map-marker-remove-variant\": 986890,\n \"map-marker-right\": 987868,\n \"map-marker-right-outline\": 987870,\n \"map-marker-star\": 988680,\n \"map-marker-star-outline\": 988681,\n \"map-marker-up\": 987395,\n \"map-minus\": 985473,\n \"map-outline\": 985474,\n \"map-plus\": 985475,\n \"map-search\": 985476,\n \"map-search-outline\": 985477,\n \"mapbox\": 986026,\n \"margin\": 983891,\n \"marker\": 984658,\n \"marker-cancel\": 986585,\n \"marker-check\": 983893,\n \"mastodon\": 985809,\n \"material-design\": 985478,\n \"material-ui\": 983895,\n \"math-compass\": 983896,\n \"math-cos\": 986262,\n \"math-integral\": 987080,\n \"math-integral-box\": 987081,\n \"math-log\": 987269,\n \"math-norm\": 987082,\n \"math-norm-box\": 987083,\n \"math-sin\": 986263,\n \"math-tan\": 986264,\n \"matrix\": 984616,\n \"medal\": 985479,\n \"medal-outline\": 987942,\n \"medical-bag\": 984815,\n \"meditation\": 987515,\n \"memory\": 983899,\n \"menorah\": 989140,\n \"menorah-fire\": 989141,\n \"menu\": 983900,\n \"menu-down\": 983901,\n \"menu-down-outline\": 984758,\n \"menu-left\": 983902,\n \"menu-left-outline\": 985602,\n \"menu-open\": 986027,\n \"menu-right\": 983903,\n \"menu-right-outline\": 985603,\n \"menu-swap\": 985700,\n \"menu-swap-outline\": 985701,\n \"menu-up\": 983904,\n \"menu-up-outline\": 984759,\n \"merge\": 986972,\n \"message\": 983905,\n \"message-alert\": 983906,\n \"message-alert-outline\": 985604,\n \"message-arrow-left\": 987890,\n \"message-arrow-left-outline\": 987891,\n \"message-arrow-right\": 987892,\n \"message-arrow-right-outline\": 987893,\n \"message-badge\": 989505,\n \"message-badge-outline\": 989506,\n \"message-bookmark\": 988588,\n \"message-bookmark-outline\": 988589,\n \"message-bulleted\": 984738,\n \"message-bulleted-off\": 984739,\n \"message-cog\": 984817,\n \"message-cog-outline\": 987506,\n \"message-draw\": 983907,\n \"message-flash\": 988585,\n \"message-flash-outline\": 988586,\n \"message-image\": 983908,\n \"message-image-outline\": 987500,\n \"message-lock\": 987084,\n \"message-lock-outline\": 987501,\n \"message-minus\": 987502,\n \"message-minus-outline\": 987503,\n \"message-off\": 988749,\n \"message-off-outline\": 988750,\n \"message-outline\": 983909,\n \"message-plus\": 984659,\n \"message-plus-outline\": 987323,\n \"message-processing\": 983910,\n \"message-processing-outline\": 987504,\n \"message-question\": 988986,\n \"message-question-outline\": 988987,\n \"message-reply\": 983911,\n \"message-reply-outline\": 988989,\n \"message-reply-text\": 983912,\n \"message-reply-text-outline\": 988990,\n \"message-settings\": 984816,\n \"message-settings-outline\": 987505,\n \"message-star\": 984730,\n \"message-star-outline\": 987728,\n \"message-text\": 983913,\n \"message-text-clock\": 987507,\n \"message-text-clock-outline\": 987508,\n \"message-text-lock\": 987085,\n \"message-text-lock-outline\": 987509,\n \"message-text-outline\": 983914,\n \"message-video\": 983915,\n \"meteor\": 984617,\n \"metronome\": 985050,\n \"metronome-tick\": 985051,\n \"micro-sd\": 985052,\n \"microphone\": 983916,\n \"microphone-minus\": 985267,\n \"microphone-off\": 983917,\n \"microphone-outline\": 983918,\n \"microphone-plus\": 985268,\n \"microphone-question\": 989577,\n \"microphone-question-outline\": 989578,\n \"microphone-settings\": 983919,\n \"microphone-variant\": 983920,\n \"microphone-variant-off\": 983921,\n \"microscope\": 984660,\n \"microsoft\": 983922,\n \"microsoft-access\": 988046,\n \"microsoft-azure\": 985093,\n \"microsoft-azure-devops\": 987093,\n \"microsoft-bing\": 983204,\n \"microsoft-dynamics-365\": 985480,\n \"microsoft-edge\": 983529,\n \"microsoft-excel\": 988047,\n \"microsoft-internet-explorer\": 983808,\n \"microsoft-office\": 984006,\n \"microsoft-onedrive\": 984010,\n \"microsoft-onenote\": 984903,\n \"microsoft-outlook\": 986402,\n \"microsoft-powerpoint\": 988048,\n \"microsoft-sharepoint\": 988049,\n \"microsoft-teams\": 983739,\n \"microsoft-visual-studio\": 984592,\n \"microsoft-visual-studio-code\": 985630,\n \"microsoft-windows\": 984499,\n \"microsoft-windows-classic\": 985633,\n \"microsoft-word\": 988050,\n \"microsoft-xbox\": 984505,\n \"microsoft-xbox-controller\": 984506,\n \"microsoft-xbox-controller-battery-alert\": 984907,\n \"microsoft-xbox-controller-battery-charging\": 985634,\n \"microsoft-xbox-controller-battery-empty\": 984908,\n \"microsoft-xbox-controller-battery-full\": 984909,\n \"microsoft-xbox-controller-battery-low\": 984910,\n \"microsoft-xbox-controller-battery-medium\": 984911,\n \"microsoft-xbox-controller-battery-unknown\": 984912,\n \"microsoft-xbox-controller-menu\": 986735,\n \"microsoft-xbox-controller-off\": 984507,\n \"microsoft-xbox-controller-view\": 986736,\n \"microwave\": 986265,\n \"microwave-off\": 988195,\n \"middleware\": 986973,\n \"middleware-outline\": 986974,\n \"midi\": 985329,\n \"midi-port\": 985330,\n \"mine\": 986586,\n \"minecraft\": 983923,\n \"mini-sd\": 985605,\n \"minidisc\": 985606,\n \"minus\": 983924,\n \"minus-box\": 983925,\n \"minus-box-multiple\": 987457,\n \"minus-box-multiple-outline\": 987458,\n \"minus-box-outline\": 984818,\n \"minus-circle\": 983926,\n \"minus-circle-multiple\": 983898,\n \"minus-circle-multiple-outline\": 985811,\n \"minus-circle-off\": 988249,\n \"minus-circle-off-outline\": 988250,\n \"minus-circle-outline\": 983927,\n \"minus-network\": 983928,\n \"minus-network-outline\": 986266,\n \"minus-thick\": 988729,\n \"mirror\": 987645,\n \"mirror-rectangle\": 989087,\n \"mirror-variant\": 989088,\n \"mixed-martial-arts\": 986511,\n \"mixed-reality\": 985215,\n \"molecule\": 986028,\n \"molecule-co\": 987902,\n \"molecule-co2\": 985060,\n \"monitor\": 983929,\n \"monitor-cellphone\": 985481,\n \"monitor-cellphone-star\": 985482,\n \"monitor-dashboard\": 985607,\n \"monitor-edit\": 987846,\n \"monitor-eye\": 988084,\n \"monitor-lock\": 986587,\n \"monitor-multiple\": 983930,\n \"monitor-off\": 986512,\n \"monitor-screenshot\": 986705,\n \"monitor-share\": 988291,\n \"monitor-shimmer\": 987396,\n \"monitor-small\": 989302,\n \"monitor-speaker\": 986975,\n \"monitor-speaker-off\": 986976,\n \"monitor-star\": 986588,\n \"moon-first-quarter\": 986977,\n \"moon-full\": 986978,\n \"moon-last-quarter\": 986979,\n \"moon-new\": 986980,\n \"moon-waning-crescent\": 986981,\n \"moon-waning-gibbous\": 986982,\n \"moon-waxing-crescent\": 986983,\n \"moon-waxing-gibbous\": 986984,\n \"moped\": 987270,\n \"moped-electric\": 988599,\n \"moped-electric-outline\": 988600,\n \"moped-outline\": 988601,\n \"more\": 983931,\n \"mortar-pestle\": 989000,\n \"mortar-pestle-plus\": 984049,\n \"mosque\": 989223,\n \"mother-heart\": 987924,\n \"mother-nurse\": 986401,\n \"motion\": 988594,\n \"motion-outline\": 988595,\n \"motion-pause\": 988560,\n \"motion-pause-outline\": 988562,\n \"motion-play\": 988559,\n \"motion-play-outline\": 988561,\n \"motion-sensor\": 986513,\n \"motion-sensor-off\": 988213,\n \"motorbike\": 983932,\n \"motorbike-electric\": 988602,\n \"mouse\": 983933,\n \"mouse-bluetooth\": 985483,\n \"mouse-move-down\": 988496,\n \"mouse-move-up\": 988497,\n \"mouse-move-vertical\": 988498,\n \"mouse-off\": 983934,\n \"mouse-variant\": 983935,\n \"mouse-variant-off\": 983936,\n \"move-resize\": 984661,\n \"move-resize-variant\": 984662,\n \"movie\": 983937,\n \"movie-check\": 988915,\n \"movie-check-outline\": 988916,\n \"movie-cog\": 988917,\n \"movie-cog-outline\": 988918,\n \"movie-edit\": 987426,\n \"movie-edit-outline\": 987427,\n \"movie-filter\": 987428,\n \"movie-filter-outline\": 987429,\n \"movie-minus\": 988919,\n \"movie-minus-outline\": 988920,\n \"movie-off\": 988921,\n \"movie-off-outline\": 988922,\n \"movie-open\": 987086,\n \"movie-open-check\": 988923,\n \"movie-open-check-outline\": 988924,\n \"movie-open-cog\": 988925,\n \"movie-open-cog-outline\": 988926,\n \"movie-open-edit\": 988927,\n \"movie-open-edit-outline\": 988928,\n \"movie-open-minus\": 988929,\n \"movie-open-minus-outline\": 988930,\n \"movie-open-off\": 988931,\n \"movie-open-off-outline\": 988932,\n \"movie-open-outline\": 987087,\n \"movie-open-play\": 988933,\n \"movie-open-play-outline\": 988934,\n \"movie-open-plus\": 988935,\n \"movie-open-plus-outline\": 988936,\n \"movie-open-remove\": 988937,\n \"movie-open-remove-outline\": 988938,\n \"movie-open-settings\": 988939,\n \"movie-open-settings-outline\": 988940,\n \"movie-open-star\": 988941,\n \"movie-open-star-outline\": 988942,\n \"movie-outline\": 986589,\n \"movie-play\": 988943,\n \"movie-play-outline\": 988944,\n \"movie-plus\": 988945,\n \"movie-plus-outline\": 988946,\n \"movie-remove\": 988947,\n \"movie-remove-outline\": 988948,\n \"movie-roll\": 985054,\n \"movie-search\": 987602,\n \"movie-search-outline\": 987603,\n \"movie-settings\": 988949,\n \"movie-settings-outline\": 988950,\n \"movie-star\": 988951,\n \"movie-star-outline\": 988952,\n \"mower\": 988783,\n \"mower-bag\": 988784,\n \"muffin\": 985484,\n \"multicast\": 989331,\n \"multiplication\": 983938,\n \"multiplication-box\": 983939,\n \"mushroom\": 985055,\n \"mushroom-off\": 988154,\n \"mushroom-off-outline\": 988155,\n \"mushroom-outline\": 985056,\n \"music\": 984922,\n \"music-accidental-double-flat\": 986985,\n \"music-accidental-double-sharp\": 986986,\n \"music-accidental-flat\": 986987,\n \"music-accidental-natural\": 986988,\n \"music-accidental-sharp\": 986989,\n \"music-box\": 983940,\n \"music-box-multiple\": 983859,\n \"music-box-multiple-outline\": 986884,\n \"music-box-outline\": 983941,\n \"music-circle\": 983942,\n \"music-circle-outline\": 985812,\n \"music-clef-alto\": 986990,\n \"music-clef-bass\": 986991,\n \"music-clef-treble\": 986992,\n \"music-note\": 983943,\n \"music-note-bluetooth\": 984574,\n \"music-note-bluetooth-off\": 984575,\n \"music-note-eighth\": 983944,\n \"music-note-eighth-dotted\": 986993,\n \"music-note-half\": 983945,\n \"music-note-half-dotted\": 986994,\n \"music-note-off\": 983946,\n \"music-note-off-outline\": 986995,\n \"music-note-outline\": 986996,\n \"music-note-plus\": 986590,\n \"music-note-quarter\": 983947,\n \"music-note-quarter-dotted\": 986997,\n \"music-note-sixteenth\": 983948,\n \"music-note-sixteenth-dotted\": 986998,\n \"music-note-whole\": 983949,\n \"music-note-whole-dotted\": 986999,\n \"music-off\": 984923,\n \"music-rest-eighth\": 987000,\n \"music-rest-half\": 987001,\n \"music-rest-quarter\": 987002,\n \"music-rest-sixteenth\": 987003,\n \"music-rest-whole\": 987004,\n \"mustache\": 988638,\n \"nail\": 986591,\n \"nas\": 985331,\n \"nativescript\": 985216,\n \"nature\": 983950,\n \"nature-people\": 983951,\n \"navigation\": 983952,\n \"navigation-outline\": 988679,\n \"navigation-variant\": 989424,\n \"navigation-variant-outline\": 989425,\n \"near-me\": 984525,\n \"necklace\": 986891,\n \"needle\": 983953,\n \"netflix\": 984902,\n \"network\": 984819,\n \"network-off\": 986267,\n \"network-off-outline\": 986268,\n \"network-outline\": 986269,\n \"network-strength-1\": 985332,\n \"network-strength-1-alert\": 985333,\n \"network-strength-2\": 985334,\n \"network-strength-2-alert\": 985335,\n \"network-strength-3\": 985336,\n \"network-strength-3-alert\": 985337,\n \"network-strength-4\": 985338,\n \"network-strength-4-alert\": 985339,\n \"network-strength-4-cog\": 989466,\n \"network-strength-off\": 985340,\n \"network-strength-off-outline\": 985341,\n \"network-strength-outline\": 985342,\n \"new-box\": 983956,\n \"newspaper\": 983957,\n \"newspaper-check\": 989507,\n \"newspaper-minus\": 986892,\n \"newspaper-plus\": 986893,\n \"newspaper-remove\": 989508,\n \"newspaper-variant\": 987137,\n \"newspaper-variant-multiple\": 987138,\n \"newspaper-variant-multiple-outline\": 987139,\n \"newspaper-variant-outline\": 987140,\n \"nfc\": 983958,\n \"nfc-search-variant\": 986707,\n \"nfc-tap\": 983959,\n \"nfc-variant\": 983960,\n \"nfc-variant-off\": 986708,\n \"ninja\": 984948,\n \"nintendo-game-boy\": 988051,\n \"nintendo-switch\": 985057,\n \"nintendo-wii\": 984491,\n \"nintendo-wiiu\": 984877,\n \"nix\": 987397,\n \"nodejs\": 983961,\n \"noodles\": 987518,\n \"not-equal\": 985485,\n \"not-equal-variant\": 985486,\n \"note\": 983962,\n \"note-alert\": 989053,\n \"note-alert-outline\": 989054,\n \"note-check\": 989055,\n \"note-check-outline\": 989056,\n \"note-edit\": 989057,\n \"note-edit-outline\": 989058,\n \"note-minus\": 988751,\n \"note-minus-outline\": 988752,\n \"note-multiple\": 984760,\n \"note-multiple-outline\": 984761,\n \"note-off\": 989059,\n \"note-off-outline\": 989060,\n \"note-outline\": 983963,\n \"note-plus\": 983964,\n \"note-plus-outline\": 983965,\n \"note-remove\": 988753,\n \"note-remove-outline\": 988754,\n \"note-search\": 988755,\n \"note-search-outline\": 988756,\n \"note-text\": 983966,\n \"note-text-outline\": 987607,\n \"notebook\": 985134,\n \"notebook-check\": 988405,\n \"notebook-check-outline\": 988406,\n \"notebook-edit\": 988391,\n \"notebook-edit-outline\": 988393,\n \"notebook-minus\": 988688,\n \"notebook-minus-outline\": 988689,\n \"notebook-multiple\": 986709,\n \"notebook-outline\": 986815,\n \"notebook-plus\": 988690,\n \"notebook-plus-outline\": 988691,\n \"notebook-remove\": 988692,\n \"notebook-remove-outline\": 988693,\n \"notification-clear-all\": 983967,\n \"npm\": 984823,\n \"nuke\": 984740,\n \"null\": 985058,\n \"numeric\": 983968,\n \"numeric-0\": 985913,\n \"numeric-0-box\": 983969,\n \"numeric-0-box-multiple\": 986894,\n \"numeric-0-box-multiple-outline\": 983970,\n \"numeric-0-box-outline\": 983971,\n \"numeric-0-circle\": 986270,\n \"numeric-0-circle-outline\": 986271,\n \"numeric-1\": 985914,\n \"numeric-1-box\": 983972,\n \"numeric-1-box-multiple\": 986895,\n \"numeric-1-box-multiple-outline\": 983973,\n \"numeric-1-box-outline\": 983974,\n \"numeric-1-circle\": 986272,\n \"numeric-1-circle-outline\": 986273,\n \"numeric-10\": 987113,\n \"numeric-10-box\": 987005,\n \"numeric-10-box-multiple\": 987114,\n \"numeric-10-box-multiple-outline\": 987115,\n \"numeric-10-box-outline\": 987006,\n \"numeric-10-circle\": 987116,\n \"numeric-10-circle-outline\": 987117,\n \"numeric-2\": 985915,\n \"numeric-2-box\": 983975,\n \"numeric-2-box-multiple\": 986896,\n \"numeric-2-box-multiple-outline\": 983976,\n \"numeric-2-box-outline\": 983977,\n \"numeric-2-circle\": 986274,\n \"numeric-2-circle-outline\": 986275,\n \"numeric-3\": 985916,\n \"numeric-3-box\": 983978,\n \"numeric-3-box-multiple\": 986897,\n \"numeric-3-box-multiple-outline\": 983979,\n \"numeric-3-box-outline\": 983980,\n \"numeric-3-circle\": 986276,\n \"numeric-3-circle-outline\": 986277,\n \"numeric-4\": 985917,\n \"numeric-4-box\": 983981,\n \"numeric-4-box-multiple\": 986898,\n \"numeric-4-box-multiple-outline\": 983986,\n \"numeric-4-box-outline\": 983982,\n \"numeric-4-circle\": 986278,\n \"numeric-4-circle-outline\": 986279,\n \"numeric-5\": 985918,\n \"numeric-5-box\": 983985,\n \"numeric-5-box-multiple\": 986899,\n \"numeric-5-box-multiple-outline\": 983983,\n \"numeric-5-box-outline\": 983984,\n \"numeric-5-circle\": 986280,\n \"numeric-5-circle-outline\": 986281,\n \"numeric-6\": 985919,\n \"numeric-6-box\": 983987,\n \"numeric-6-box-multiple\": 986900,\n \"numeric-6-box-multiple-outline\": 983988,\n \"numeric-6-box-outline\": 983989,\n \"numeric-6-circle\": 986282,\n \"numeric-6-circle-outline\": 986283,\n \"numeric-7\": 985920,\n \"numeric-7-box\": 983990,\n \"numeric-7-box-multiple\": 986901,\n \"numeric-7-box-multiple-outline\": 983991,\n \"numeric-7-box-outline\": 983992,\n \"numeric-7-circle\": 986284,\n \"numeric-7-circle-outline\": 986285,\n \"numeric-8\": 985921,\n \"numeric-8-box\": 983993,\n \"numeric-8-box-multiple\": 986902,\n \"numeric-8-box-multiple-outline\": 983994,\n \"numeric-8-box-outline\": 983995,\n \"numeric-8-circle\": 986286,\n \"numeric-8-circle-outline\": 986287,\n \"numeric-9\": 985922,\n \"numeric-9-box\": 983996,\n \"numeric-9-box-multiple\": 986903,\n \"numeric-9-box-multiple-outline\": 983997,\n \"numeric-9-box-outline\": 983998,\n \"numeric-9-circle\": 986288,\n \"numeric-9-circle-outline\": 986289,\n \"numeric-9-plus\": 987118,\n \"numeric-9-plus-box\": 983999,\n \"numeric-9-plus-box-multiple\": 986904,\n \"numeric-9-plus-box-multiple-outline\": 984000,\n \"numeric-9-plus-box-outline\": 984001,\n \"numeric-9-plus-circle\": 986290,\n \"numeric-9-plus-circle-outline\": 986291,\n \"numeric-negative-1\": 987218,\n \"numeric-positive-1\": 988619,\n \"nut\": 984824,\n \"nutrition\": 984002,\n \"nuxt\": 987398,\n \"oar\": 984700,\n \"ocarina\": 986592,\n \"oci\": 987881,\n \"ocr\": 987450,\n \"octagon\": 984003,\n \"octagon-outline\": 984004,\n \"octagram\": 984825,\n \"octagram-outline\": 984949,\n \"octahedron\": 989520,\n \"octahedron-off\": 989521,\n \"odnoklassniki\": 984005,\n \"offer\": 987675,\n \"office-building\": 985489,\n \"office-building-cog\": 989513,\n \"office-building-cog-outline\": 989514,\n \"office-building-marker\": 988448,\n \"office-building-marker-outline\": 988449,\n \"office-building-outline\": 988447,\n \"oil\": 984007,\n \"oil-lamp\": 986905,\n \"oil-level\": 987219,\n \"oil-temperature\": 987128,\n \"om\": 985459,\n \"omega\": 984009,\n \"one-up\": 986029,\n \"onepassword\": 985217,\n \"opacity\": 984524,\n \"open-in-app\": 984011,\n \"open-in-new\": 984012,\n \"open-source-initiative\": 986030,\n \"openid\": 984013,\n \"opera\": 984014,\n \"orbit\": 983064,\n \"orbit-variant\": 988635,\n \"order-alphabetical-ascending\": 983565,\n \"order-alphabetical-descending\": 986375,\n \"order-bool-ascending\": 983742,\n \"order-bool-ascending-variant\": 985487,\n \"order-bool-descending\": 988036,\n \"order-bool-descending-variant\": 985488,\n \"order-numeric-ascending\": 984389,\n \"order-numeric-descending\": 984390,\n \"origin\": 985923,\n \"ornament\": 984015,\n \"ornament-variant\": 984016,\n \"outdoor-lamp\": 987220,\n \"overscan\": 987141,\n \"owl\": 984018,\n \"pac-man\": 986031,\n \"package\": 984019,\n \"package-down\": 984020,\n \"package-up\": 984021,\n \"package-variant\": 984022,\n \"package-variant-closed\": 984023,\n \"page-first\": 984576,\n \"page-last\": 984577,\n \"page-layout-body\": 984826,\n \"page-layout-footer\": 984827,\n \"page-layout-header\": 984828,\n \"page-layout-header-footer\": 987007,\n \"page-layout-sidebar-left\": 984829,\n \"page-layout-sidebar-right\": 984830,\n \"page-next\": 986032,\n \"page-next-outline\": 986033,\n \"page-previous\": 986034,\n \"page-previous-outline\": 986035,\n \"pail\": 988183,\n \"pail-minus\": 988215,\n \"pail-minus-outline\": 988220,\n \"pail-off\": 988217,\n \"pail-off-outline\": 988222,\n \"pail-outline\": 988218,\n \"pail-plus\": 988214,\n \"pail-plus-outline\": 988219,\n \"pail-remove\": 988216,\n \"pail-remove-outline\": 988221,\n \"palette\": 984024,\n \"palette-advanced\": 984025,\n \"palette-outline\": 986636,\n \"palette-swatch\": 985269,\n \"palette-swatch-outline\": 987996,\n \"palette-swatch-variant\": 989530,\n \"palm-tree\": 987221,\n \"pan\": 986036,\n \"pan-bottom-left\": 986037,\n \"pan-bottom-right\": 986038,\n \"pan-down\": 986039,\n \"pan-horizontal\": 986040,\n \"pan-left\": 986041,\n \"pan-right\": 986042,\n \"pan-top-left\": 986043,\n \"pan-top-right\": 986044,\n \"pan-up\": 986045,\n \"pan-vertical\": 986046,\n \"panda\": 984026,\n \"pandora\": 984027,\n \"panorama\": 984028,\n \"panorama-fisheye\": 984029,\n \"panorama-horizontal\": 989480,\n \"panorama-horizontal-outline\": 984030,\n \"panorama-outline\": 989580,\n \"panorama-sphere\": 989581,\n \"panorama-sphere-outline\": 989582,\n \"panorama-variant\": 989583,\n \"panorama-variant-outline\": 989584,\n \"panorama-vertical\": 989481,\n \"panorama-vertical-outline\": 984031,\n \"panorama-wide-angle\": 989535,\n \"panorama-wide-angle-outline\": 984032,\n \"paper-cut-vertical\": 984033,\n \"paper-roll\": 987479,\n \"paper-roll-outline\": 987480,\n \"paperclip\": 984034,\n \"parachute\": 986292,\n \"parachute-outline\": 986293,\n \"paragliding\": 988997,\n \"parking\": 984035,\n \"party-popper\": 987222,\n \"passport\": 985059,\n \"passport-biometric\": 986593,\n \"pasta\": 987488,\n \"patio-heater\": 987008,\n \"patreon\": 985218,\n \"pause\": 984036,\n \"pause-circle\": 984037,\n \"pause-circle-outline\": 984038,\n \"pause-octagon\": 984039,\n \"pause-octagon-outline\": 984040,\n \"paw\": 984041,\n \"paw-off\": 984663,\n \"paw-off-outline\": 988790,\n \"paw-outline\": 988789,\n \"peace\": 985220,\n \"peanut\": 987132,\n \"peanut-off\": 987133,\n \"peanut-off-outline\": 987135,\n \"peanut-outline\": 987134,\n \"pen\": 984042,\n \"pen-lock\": 986594,\n \"pen-minus\": 986595,\n \"pen-off\": 986596,\n \"pen-plus\": 986597,\n \"pen-remove\": 986598,\n \"pencil\": 984043,\n \"pencil-box\": 984044,\n \"pencil-box-multiple\": 987460,\n \"pencil-box-multiple-outline\": 987461,\n \"pencil-box-outline\": 984045,\n \"pencil-circle\": 984831,\n \"pencil-circle-outline\": 984950,\n \"pencil-lock\": 984046,\n \"pencil-lock-outline\": 986599,\n \"pencil-minus\": 986600,\n \"pencil-minus-outline\": 986601,\n \"pencil-off\": 984047,\n \"pencil-off-outline\": 986602,\n \"pencil-outline\": 986294,\n \"pencil-plus\": 986603,\n \"pencil-plus-outline\": 986604,\n \"pencil-remove\": 986605,\n \"pencil-remove-outline\": 986606,\n \"pencil-ruler\": 987987,\n \"penguin\": 986816,\n \"pentagon\": 984833,\n \"pentagon-outline\": 984832,\n \"pentagram\": 988775,\n \"percent\": 984048,\n \"percent-outline\": 987768,\n \"periodic-table\": 985270,\n \"perspective-less\": 986403,\n \"perspective-more\": 986404,\n \"ph\": 989125,\n \"phone\": 984050,\n \"phone-alert\": 986906,\n \"phone-alert-outline\": 987534,\n \"phone-bluetooth\": 984051,\n \"phone-bluetooth-outline\": 987535,\n \"phone-cancel\": 987324,\n \"phone-cancel-outline\": 987536,\n \"phone-check\": 987561,\n \"phone-check-outline\": 987562,\n \"phone-classic\": 984578,\n \"phone-classic-off\": 987769,\n \"phone-dial\": 988505,\n \"phone-dial-outline\": 988506,\n \"phone-forward\": 984052,\n \"phone-forward-outline\": 987537,\n \"phone-hangup\": 984053,\n \"phone-hangup-outline\": 987538,\n \"phone-in-talk\": 984054,\n \"phone-in-talk-outline\": 987522,\n \"phone-incoming\": 984055,\n \"phone-incoming-outline\": 987539,\n \"phone-lock\": 984056,\n \"phone-lock-outline\": 987540,\n \"phone-log\": 984057,\n \"phone-log-outline\": 987541,\n \"phone-message\": 987542,\n \"phone-message-outline\": 987543,\n \"phone-minus\": 984664,\n \"phone-minus-outline\": 987544,\n \"phone-missed\": 984058,\n \"phone-missed-outline\": 987557,\n \"phone-off\": 986607,\n \"phone-off-outline\": 987558,\n \"phone-outgoing\": 984059,\n \"phone-outgoing-outline\": 987545,\n \"phone-outline\": 986608,\n \"phone-paused\": 984060,\n \"phone-paused-outline\": 987546,\n \"phone-plus\": 984665,\n \"phone-plus-outline\": 987547,\n \"phone-refresh\": 989587,\n \"phone-refresh-outline\": 989588,\n \"phone-remove\": 988463,\n \"phone-remove-outline\": 988464,\n \"phone-return\": 985135,\n \"phone-return-outline\": 987548,\n \"phone-ring\": 987563,\n \"phone-ring-outline\": 987564,\n \"phone-rotate-landscape\": 985221,\n \"phone-rotate-portrait\": 985222,\n \"phone-settings\": 984061,\n \"phone-settings-outline\": 987549,\n \"phone-sync\": 989589,\n \"phone-sync-outline\": 989590,\n \"phone-voip\": 984062,\n \"pi\": 984063,\n \"pi-box\": 984064,\n \"pi-hole\": 986609,\n \"piano\": 984701,\n \"piano-off\": 984728,\n \"pickaxe\": 985271,\n \"picture-in-picture-bottom-right\": 986711,\n \"picture-in-picture-bottom-right-outline\": 986712,\n \"picture-in-picture-top-right\": 986713,\n \"picture-in-picture-top-right-outline\": 986714,\n \"pier\": 985223,\n \"pier-crane\": 985224,\n \"pig\": 984065,\n \"pig-variant\": 987142,\n \"pig-variant-outline\": 988792,\n \"piggy-bank\": 987143,\n \"piggy-bank-outline\": 988793,\n \"pill\": 984066,\n \"pillar\": 984834,\n \"pin\": 984067,\n \"pin-off\": 984068,\n \"pin-off-outline\": 985392,\n \"pin-outline\": 985393,\n \"pine-tree\": 984069,\n \"pine-tree-box\": 984070,\n \"pine-tree-fire\": 988186,\n \"pinterest\": 984071,\n \"pinwheel\": 985813,\n \"pinwheel-outline\": 985814,\n \"pipe\": 985061,\n \"pipe-disconnected\": 985062,\n \"pipe-leak\": 985225,\n \"pipe-valve\": 989261,\n \"pipe-wrench\": 987988,\n \"pirate\": 985608,\n \"pistol\": 984835,\n \"piston\": 985226,\n \"pitchfork\": 988499,\n \"pizza\": 984073,\n \"play\": 984074,\n \"play-box\": 987770,\n \"play-box-multiple\": 986393,\n \"play-box-multiple-outline\": 988134,\n \"play-box-outline\": 984075,\n \"play-circle\": 984076,\n \"play-circle-outline\": 984077,\n \"play-network\": 985227,\n \"play-network-outline\": 986295,\n \"play-outline\": 986907,\n \"play-pause\": 984078,\n \"play-protected-content\": 984079,\n \"play-speed\": 985343,\n \"playlist-check\": 984519,\n \"playlist-edit\": 985344,\n \"playlist-minus\": 984080,\n \"playlist-music\": 986296,\n \"playlist-music-outline\": 986297,\n \"playlist-play\": 984081,\n \"playlist-plus\": 984082,\n \"playlist-remove\": 984083,\n \"playlist-star\": 986610,\n \"plex\": 984762,\n \"pliers\": 989604,\n \"plus\": 984085,\n \"plus-box\": 984086,\n \"plus-box-multiple\": 983860,\n \"plus-box-multiple-outline\": 987459,\n \"plus-box-outline\": 984836,\n \"plus-circle\": 984087,\n \"plus-circle-multiple\": 983884,\n \"plus-circle-multiple-outline\": 984088,\n \"plus-circle-outline\": 984089,\n \"plus-minus\": 985490,\n \"plus-minus-box\": 985491,\n \"plus-minus-variant\": 988361,\n \"plus-network\": 984090,\n \"plus-network-outline\": 986298,\n \"plus-outline\": 984837,\n \"plus-thick\": 987628,\n \"podcast\": 985492,\n \"podium\": 986405,\n \"podium-bronze\": 986406,\n \"podium-gold\": 986407,\n \"podium-silver\": 986408,\n \"point-of-sale\": 986514,\n \"pokeball\": 984093,\n \"pokemon-go\": 985609,\n \"poker-chip\": 985136,\n \"polaroid\": 984094,\n \"police-badge\": 987495,\n \"police-badge-outline\": 987496,\n \"police-station\": 989241,\n \"poll\": 984095,\n \"polo\": 988355,\n \"polymer\": 984097,\n \"pool\": 984582,\n \"popcorn\": 984098,\n \"post\": 987144,\n \"post-outline\": 987145,\n \"postage-stamp\": 986299,\n \"pot\": 983781,\n \"pot-mix\": 984667,\n \"pot-mix-outline\": 984695,\n \"pot-outline\": 983807,\n \"pot-steam\": 984666,\n \"pot-steam-outline\": 983846,\n \"pound\": 984099,\n \"pound-box\": 984100,\n \"pound-box-outline\": 987519,\n \"power\": 984101,\n \"power-cycle\": 985345,\n \"power-off\": 985346,\n \"power-on\": 985347,\n \"power-plug\": 984741,\n \"power-plug-off\": 984742,\n \"power-plug-off-outline\": 988196,\n \"power-plug-outline\": 988197,\n \"power-settings\": 984102,\n \"power-sleep\": 985348,\n \"power-socket\": 984103,\n \"power-socket-au\": 985349,\n \"power-socket-ch\": 987059,\n \"power-socket-de\": 987399,\n \"power-socket-eu\": 985063,\n \"power-socket-fr\": 987400,\n \"power-socket-it\": 988415,\n \"power-socket-jp\": 987401,\n \"power-socket-uk\": 985064,\n \"power-socket-us\": 985065,\n \"power-standby\": 985350,\n \"powershell\": 985610,\n \"prescription\": 984838,\n \"presentation\": 984104,\n \"presentation-play\": 984105,\n \"pretzel\": 988514,\n \"printer\": 984106,\n \"printer-3d\": 984107,\n \"printer-3d-nozzle\": 986715,\n \"printer-3d-nozzle-alert\": 987584,\n \"printer-3d-nozzle-alert-outline\": 987585,\n \"printer-3d-nozzle-heat\": 989368,\n \"printer-3d-nozzle-heat-outline\": 989369,\n \"printer-3d-nozzle-outline\": 986716,\n \"printer-alert\": 984108,\n \"printer-check\": 987462,\n \"printer-eye\": 988248,\n \"printer-off\": 986717,\n \"printer-off-outline\": 989061,\n \"printer-outline\": 989062,\n \"printer-pos\": 987223,\n \"printer-search\": 988247,\n \"printer-settings\": 984839,\n \"printer-wireless\": 985611,\n \"priority-high\": 984579,\n \"priority-low\": 984580,\n \"professional-hexagon\": 984109,\n \"progress-alert\": 986300,\n \"progress-check\": 985493,\n \"progress-clock\": 985494,\n \"progress-close\": 987402,\n \"progress-download\": 985495,\n \"progress-pencil\": 989063,\n \"progress-question\": 988450,\n \"progress-star\": 989064,\n \"progress-upload\": 985496,\n \"progress-wrench\": 986301,\n \"projector\": 984110,\n \"projector-screen\": 984111,\n \"projector-screen-off\": 989197,\n \"projector-screen-off-outline\": 989198,\n \"projector-screen-outline\": 988964,\n \"projector-screen-variant\": 989199,\n \"projector-screen-variant-off\": 989200,\n \"projector-screen-variant-off-outline\": 989201,\n \"projector-screen-variant-outline\": 989202,\n \"propane-tank\": 987991,\n \"propane-tank-outline\": 987992,\n \"protocol\": 987096,\n \"publish\": 984743,\n \"publish-off\": 989509,\n \"pulse\": 984112,\n \"pump\": 988162,\n \"pumpkin\": 986047,\n \"purse\": 986908,\n \"purse-outline\": 986909,\n \"puzzle\": 984113,\n \"puzzle-check\": 988198,\n \"puzzle-check-outline\": 988199,\n \"puzzle-edit\": 988371,\n \"puzzle-edit-outline\": 988377,\n \"puzzle-heart\": 988372,\n \"puzzle-heart-outline\": 988378,\n \"puzzle-minus\": 988369,\n \"puzzle-minus-outline\": 988375,\n \"puzzle-outline\": 985702,\n \"puzzle-plus\": 988368,\n \"puzzle-plus-outline\": 988374,\n \"puzzle-remove\": 988370,\n \"puzzle-remove-outline\": 988376,\n \"puzzle-star\": 988373,\n \"puzzle-star-outline\": 988379,\n \"pyramid\": 989522,\n \"pyramid-off\": 989523,\n \"qi\": 985497,\n \"qqchat\": 984581,\n \"qrcode\": 984114,\n \"qrcode-edit\": 985272,\n \"qrcode-minus\": 987532,\n \"qrcode-plus\": 987531,\n \"qrcode-remove\": 987533,\n \"qrcode-scan\": 984115,\n \"quadcopter\": 984116,\n \"quality-high\": 984117,\n \"quality-low\": 985612,\n \"quality-medium\": 985613,\n \"quora\": 986409,\n \"rabbit\": 985351,\n \"racing-helmet\": 986515,\n \"racquetball\": 986516,\n \"radar\": 984119,\n \"radiator\": 984120,\n \"radiator-disabled\": 985815,\n \"radiator-off\": 985816,\n \"radio\": 984121,\n \"radio-am\": 986302,\n \"radio-fm\": 986303,\n \"radio-handheld\": 984122,\n \"radio-off\": 987676,\n \"radio-tower\": 984123,\n \"radioactive\": 984124,\n \"radioactive-circle\": 989277,\n \"radioactive-circle-outline\": 989278,\n \"radioactive-off\": 986817,\n \"radiobox-blank\": 984125,\n \"radiobox-marked\": 984126,\n \"radiology-box\": 988357,\n \"radiology-box-outline\": 988358,\n \"radius\": 986304,\n \"radius-outline\": 986305,\n \"railroad-light\": 986910,\n \"rake\": 988484,\n \"raspberry-pi\": 984127,\n \"ray-end\": 984128,\n \"ray-end-arrow\": 984129,\n \"ray-start\": 984130,\n \"ray-start-arrow\": 984131,\n \"ray-start-end\": 984132,\n \"ray-start-vertex-end\": 988632,\n \"ray-vertex\": 984133,\n \"razor-double-edge\": 989591,\n \"razor-single-edge\": 989592,\n \"react\": 984840,\n \"read\": 984135,\n \"receipt\": 984137,\n \"record\": 984138,\n \"record-circle\": 986818,\n \"record-circle-outline\": 986819,\n \"record-player\": 985498,\n \"record-rec\": 984139,\n \"rectangle\": 986718,\n \"rectangle-outline\": 986719,\n \"recycle\": 984140,\n \"recycle-variant\": 988061,\n \"reddit\": 984141,\n \"redhat\": 987419,\n \"redo\": 984142,\n \"redo-variant\": 984143,\n \"reflect-horizontal\": 985614,\n \"reflect-vertical\": 985615,\n \"refresh\": 984144,\n \"refresh-auto\": 989426,\n \"refresh-circle\": 988023,\n \"regex\": 984145,\n \"registered-trademark\": 985703,\n \"reiterate\": 988552,\n \"relation-many-to-many\": 988310,\n \"relation-many-to-one\": 988311,\n \"relation-many-to-one-or-many\": 988312,\n \"relation-many-to-only-one\": 988313,\n \"relation-many-to-zero-or-many\": 988314,\n \"relation-many-to-zero-or-one\": 988315,\n \"relation-one-or-many-to-many\": 988316,\n \"relation-one-or-many-to-one\": 988317,\n \"relation-one-or-many-to-one-or-many\": 988318,\n \"relation-one-or-many-to-only-one\": 988319,\n \"relation-one-or-many-to-zero-or-many\": 988320,\n \"relation-one-or-many-to-zero-or-one\": 988321,\n \"relation-one-to-many\": 988322,\n \"relation-one-to-one\": 988323,\n \"relation-one-to-one-or-many\": 988324,\n \"relation-one-to-only-one\": 988325,\n \"relation-one-to-zero-or-many\": 988326,\n \"relation-one-to-zero-or-one\": 988327,\n \"relation-only-one-to-many\": 988328,\n \"relation-only-one-to-one\": 988329,\n \"relation-only-one-to-one-or-many\": 988330,\n \"relation-only-one-to-only-one\": 988331,\n \"relation-only-one-to-zero-or-many\": 988332,\n \"relation-only-one-to-zero-or-one\": 988333,\n \"relation-zero-or-many-to-many\": 988334,\n \"relation-zero-or-many-to-one\": 988335,\n \"relation-zero-or-many-to-one-or-many\": 988336,\n \"relation-zero-or-many-to-only-one\": 988337,\n \"relation-zero-or-many-to-zero-or-many\": 988338,\n \"relation-zero-or-many-to-zero-or-one\": 988339,\n \"relation-zero-or-one-to-many\": 988340,\n \"relation-zero-or-one-to-one\": 988341,\n \"relation-zero-or-one-to-one-or-many\": 988342,\n \"relation-zero-or-one-to-only-one\": 988343,\n \"relation-zero-or-one-to-zero-or-many\": 988344,\n \"relation-zero-or-one-to-zero-or-one\": 988345,\n \"relative-scale\": 984146,\n \"reload\": 984147,\n \"reload-alert\": 987403,\n \"reminder\": 985228,\n \"remote\": 984148,\n \"remote-desktop\": 985273,\n \"remote-off\": 986820,\n \"remote-tv\": 986821,\n \"remote-tv-off\": 986822,\n \"rename-box\": 984149,\n \"reorder-horizontal\": 984712,\n \"reorder-vertical\": 984713,\n \"repeat\": 984150,\n \"repeat-off\": 984151,\n \"repeat-once\": 984152,\n \"repeat-variant\": 984391,\n \"replay\": 984153,\n \"reply\": 984154,\n \"reply-all\": 984155,\n \"reply-all-outline\": 986911,\n \"reply-circle\": 987566,\n \"reply-outline\": 986912,\n \"reproduction\": 984156,\n \"resistor\": 985924,\n \"resistor-nodes\": 985925,\n \"resize\": 985704,\n \"resize-bottom-right\": 984157,\n \"responsive\": 984158,\n \"restart\": 984841,\n \"restart-alert\": 987404,\n \"restart-off\": 986517,\n \"restore\": 985499,\n \"restore-alert\": 987405,\n \"rewind\": 984159,\n \"rewind-10\": 986410,\n \"rewind-15\": 989510,\n \"rewind-30\": 986518,\n \"rewind-5\": 987641,\n \"rewind-60\": 988684,\n \"rewind-outline\": 984842,\n \"rhombus\": 984843,\n \"rhombus-medium\": 985616,\n \"rhombus-medium-outline\": 988380,\n \"rhombus-outline\": 984844,\n \"rhombus-split\": 985617,\n \"rhombus-split-outline\": 988381,\n \"ribbon\": 984160,\n \"rice\": 985066,\n \"rickshaw\": 988603,\n \"rickshaw-electric\": 988604,\n \"ring\": 985067,\n \"rivet\": 986720,\n \"road\": 984161,\n \"road-variant\": 984162,\n \"robber\": 987224,\n \"robot\": 984745,\n \"robot-angry\": 988829,\n \"robot-angry-outline\": 988830,\n \"robot-confused\": 988831,\n \"robot-confused-outline\": 988832,\n \"robot-dead\": 988833,\n \"robot-dead-outline\": 988834,\n \"robot-excited\": 988835,\n \"robot-excited-outline\": 988836,\n \"robot-happy\": 988953,\n \"robot-happy-outline\": 988954,\n \"robot-industrial\": 985926,\n \"robot-love\": 988837,\n \"robot-love-outline\": 988838,\n \"robot-mower\": 987639,\n \"robot-mower-outline\": 987635,\n \"robot-off\": 988839,\n \"robot-off-outline\": 988795,\n \"robot-outline\": 988794,\n \"robot-vacuum\": 984845,\n \"robot-vacuum-variant\": 985352,\n \"rocket\": 984163,\n \"rocket-launch\": 988382,\n \"rocket-launch-outline\": 988383,\n \"rocket-outline\": 988079,\n \"rodent\": 987943,\n \"roller-skate\": 986411,\n \"roller-skate-off\": 983365,\n \"rollerblade\": 986412,\n \"rollerblade-off\": 983086,\n \"rollupjs\": 986048,\n \"roman-numeral-1\": 987272,\n \"roman-numeral-10\": 987281,\n \"roman-numeral-2\": 987273,\n \"roman-numeral-3\": 987274,\n \"roman-numeral-4\": 987275,\n \"roman-numeral-5\": 987276,\n \"roman-numeral-6\": 987277,\n \"roman-numeral-7\": 987278,\n \"roman-numeral-8\": 987279,\n \"roman-numeral-9\": 987280,\n \"room-service\": 985229,\n \"room-service-outline\": 986519,\n \"rotate-360\": 989593,\n \"rotate-3d\": 986823,\n \"rotate-3d-variant\": 984164,\n \"rotate-left\": 984165,\n \"rotate-left-variant\": 984166,\n \"rotate-orbit\": 986520,\n \"rotate-right\": 984167,\n \"rotate-right-variant\": 984168,\n \"rounded-corner\": 984583,\n \"router\": 987618,\n \"router-network\": 987271,\n \"router-wireless\": 984169,\n \"router-wireless-off\": 988579,\n \"router-wireless-settings\": 985705,\n \"routes\": 984170,\n \"routes-clock\": 987225,\n \"rowing\": 984584,\n \"rss\": 984171,\n \"rss-box\": 984172,\n \"rss-off\": 986913,\n \"rug\": 988277,\n \"rugby\": 986521,\n \"ruler\": 984173,\n \"ruler-square\": 986306,\n \"ruler-square-compass\": 986814,\n \"run\": 984846,\n \"run-fast\": 984174,\n \"rv-truck\": 987604,\n \"sack\": 986414,\n \"sack-percent\": 986415,\n \"safe\": 985706,\n \"safe-square\": 987772,\n \"safe-square-outline\": 987773,\n \"safety-goggles\": 986416,\n \"sail-boat\": 986824,\n \"sale\": 984175,\n \"salesforce\": 985230,\n \"sass\": 985068,\n \"satellite\": 984176,\n \"satellite-uplink\": 985353,\n \"satellite-variant\": 984177,\n \"sausage\": 985274,\n \"sausage-off\": 989065,\n \"saw-blade\": 986721,\n \"sawtooth-wave\": 988282,\n \"saxophone\": 984585,\n \"scale\": 984178,\n \"scale-balance\": 984529,\n \"scale-bathroom\": 984179,\n \"scale-off\": 987226,\n \"scale-unbalanced\": 989624,\n \"scan-helper\": 988120,\n \"scanner\": 984747,\n \"scanner-off\": 985354,\n \"scatter-plot\": 986825,\n \"scatter-plot-outline\": 986826,\n \"scent\": 989528,\n \"scent-off\": 989529,\n \"school\": 984180,\n \"school-outline\": 987520,\n \"scissors-cutting\": 985707,\n \"scooter\": 988605,\n \"scooter-electric\": 988606,\n \"scoreboard\": 987774,\n \"scoreboard-outline\": 987775,\n \"screen-rotation\": 984181,\n \"screen-rotation-lock\": 984184,\n \"screw-flat-top\": 986611,\n \"screw-lag\": 986612,\n \"screw-machine-flat-top\": 986613,\n \"screw-machine-round-top\": 986614,\n \"screw-round-top\": 986615,\n \"screwdriver\": 984182,\n \"script\": 986049,\n \"script-outline\": 984183,\n \"script-text\": 986050,\n \"script-text-key\": 988965,\n \"script-text-key-outline\": 988966,\n \"script-text-outline\": 986051,\n \"script-text-play\": 988967,\n \"script-text-play-outline\": 988968,\n \"sd\": 984185,\n \"seal\": 984186,\n \"seal-variant\": 987097,\n \"search-web\": 984847,\n \"seat\": 986307,\n \"seat-flat\": 984187,\n \"seat-flat-angled\": 984188,\n \"seat-individual-suite\": 984189,\n \"seat-legroom-extra\": 984190,\n \"seat-legroom-normal\": 984191,\n \"seat-legroom-reduced\": 984192,\n \"seat-outline\": 986308,\n \"seat-passenger\": 987721,\n \"seat-recline-extra\": 984193,\n \"seat-recline-normal\": 984194,\n \"seatbelt\": 986309,\n \"security\": 984195,\n \"security-network\": 984196,\n \"seed\": 986722,\n \"seed-off\": 988157,\n \"seed-off-outline\": 988158,\n \"seed-outline\": 986723,\n \"seesaw\": 988580,\n \"segment\": 986827,\n \"select\": 984197,\n \"select-all\": 984198,\n \"select-color\": 986417,\n \"select-compare\": 985817,\n \"select-drag\": 985708,\n \"select-group\": 987010,\n \"select-inverse\": 984199,\n \"select-marker\": 987776,\n \"select-multiple\": 987777,\n \"select-multiple-marker\": 987778,\n \"select-off\": 984200,\n \"select-place\": 987098,\n \"select-remove\": 989121,\n \"select-search\": 987652,\n \"selection\": 984201,\n \"selection-drag\": 985709,\n \"selection-ellipse\": 986418,\n \"selection-ellipse-arrow-inside\": 986914,\n \"selection-ellipse-remove\": 989122,\n \"selection-marker\": 987779,\n \"selection-multiple\": 987781,\n \"selection-multiple-marker\": 987780,\n \"selection-off\": 984951,\n \"selection-remove\": 989123,\n \"selection-search\": 987653,\n \"semantic-web\": 987926,\n \"send\": 984202,\n \"send-check\": 987489,\n \"send-check-outline\": 987490,\n \"send-circle\": 986616,\n \"send-circle-outline\": 986617,\n \"send-clock\": 987491,\n \"send-clock-outline\": 987492,\n \"send-lock\": 985069,\n \"send-lock-outline\": 987494,\n \"send-outline\": 987493,\n \"serial-port\": 984668,\n \"server\": 984203,\n \"server-minus\": 984204,\n \"server-network\": 984205,\n \"server-network-off\": 984206,\n \"server-off\": 984207,\n \"server-plus\": 984208,\n \"server-remove\": 984209,\n \"server-security\": 984210,\n \"set-all\": 984952,\n \"set-center\": 984953,\n \"set-center-right\": 984954,\n \"set-left\": 984955,\n \"set-left-center\": 984956,\n \"set-left-right\": 984957,\n \"set-merge\": 988384,\n \"set-none\": 984958,\n \"set-right\": 984959,\n \"set-split\": 988385,\n \"set-square\": 988253,\n \"set-top-box\": 985503,\n \"settings-helper\": 985710,\n \"shaker\": 987406,\n \"shaker-outline\": 987407,\n \"shape\": 985137,\n \"shape-circle-plus\": 984669,\n \"shape-outline\": 985138,\n \"shape-oval-plus\": 987642,\n \"shape-plus\": 984213,\n \"shape-polygon-plus\": 984670,\n \"shape-rectangle-plus\": 984671,\n \"shape-square-plus\": 984672,\n \"shape-square-rounded-plus\": 988410,\n \"share\": 984214,\n \"share-all\": 987636,\n \"share-all-outline\": 987637,\n \"share-circle\": 987565,\n \"share-off\": 986915,\n \"share-off-outline\": 986916,\n \"share-outline\": 985394,\n \"share-variant\": 984215,\n \"share-variant-outline\": 988436,\n \"shark\": 989370,\n \"shark-fin\": 988787,\n \"shark-fin-outline\": 988788,\n \"shark-off\": 989371,\n \"sheep\": 986310,\n \"shield\": 984216,\n \"shield-account\": 985231,\n \"shield-account-outline\": 985618,\n \"shield-account-variant\": 988583,\n \"shield-account-variant-outline\": 988584,\n \"shield-airplane\": 984763,\n \"shield-airplane-outline\": 986311,\n \"shield-alert\": 986828,\n \"shield-alert-outline\": 986829,\n \"shield-bug\": 988122,\n \"shield-bug-outline\": 988123,\n \"shield-car\": 987011,\n \"shield-check\": 984421,\n \"shield-check-outline\": 986312,\n \"shield-cross\": 986313,\n \"shield-cross-outline\": 986314,\n \"shield-crown\": 989372,\n \"shield-crown-outline\": 989373,\n \"shield-edit\": 987552,\n \"shield-edit-outline\": 987553,\n \"shield-half\": 988000,\n \"shield-half-full\": 984960,\n \"shield-home\": 984714,\n \"shield-home-outline\": 986315,\n \"shield-key\": 986052,\n \"shield-key-outline\": 986053,\n \"shield-link-variant\": 986419,\n \"shield-link-variant-outline\": 986420,\n \"shield-lock\": 985501,\n \"shield-lock-open\": 989594,\n \"shield-lock-open-outline\": 989595,\n \"shield-lock-outline\": 986316,\n \"shield-moon\": 989224,\n \"shield-moon-outline\": 989225,\n \"shield-off\": 985502,\n \"shield-off-outline\": 985500,\n \"shield-outline\": 984217,\n \"shield-plus\": 985818,\n \"shield-plus-outline\": 985819,\n \"shield-refresh\": 983210,\n \"shield-refresh-outline\": 983520,\n \"shield-remove\": 985820,\n \"shield-remove-outline\": 985821,\n \"shield-search\": 986522,\n \"shield-star\": 987451,\n \"shield-star-outline\": 987452,\n \"shield-sun\": 987229,\n \"shield-sun-outline\": 987230,\n \"shield-sword\": 989374,\n \"shield-sword-outline\": 989375,\n \"shield-sync\": 987554,\n \"shield-sync-outline\": 987555,\n \"shimmer\": 988485,\n \"ship-wheel\": 985139,\n \"shipping-pallet\": 989262,\n \"shoe-ballet\": 988618,\n \"shoe-cleat\": 988615,\n \"shoe-formal\": 985927,\n \"shoe-heel\": 985928,\n \"shoe-print\": 986618,\n \"shoe-sneaker\": 988616,\n \"shopping\": 984218,\n \"shopping-music\": 984219,\n \"shopping-outline\": 987605,\n \"shopping-search\": 987012,\n \"shore\": 988409,\n \"shovel\": 984848,\n \"shovel-off\": 984849,\n \"shower\": 985504,\n \"shower-head\": 985505,\n \"shredder\": 984220,\n \"shuffle\": 984221,\n \"shuffle-disabled\": 984222,\n \"shuffle-variant\": 984223,\n \"shuriken\": 988031,\n \"sickle\": 989376,\n \"sigma\": 984224,\n \"sigma-lower\": 984619,\n \"sign-caution\": 984225,\n \"sign-direction\": 984961,\n \"sign-direction-minus\": 987136,\n \"sign-direction-plus\": 987100,\n \"sign-direction-remove\": 987101,\n \"sign-pole\": 988408,\n \"sign-real-estate\": 987416,\n \"sign-text\": 984962,\n \"signal\": 984226,\n \"signal-2g\": 984850,\n \"signal-3g\": 984851,\n \"signal-4g\": 984852,\n \"signal-5g\": 985711,\n \"signal-cellular-1\": 985276,\n \"signal-cellular-2\": 985277,\n \"signal-cellular-3\": 985278,\n \"signal-cellular-outline\": 985279,\n \"signal-distance-variant\": 986724,\n \"signal-hspa\": 984853,\n \"signal-hspa-plus\": 984854,\n \"signal-off\": 984963,\n \"signal-variant\": 984586,\n \"signature\": 986619,\n \"signature-freehand\": 986620,\n \"signature-image\": 986621,\n \"signature-text\": 986622,\n \"silo\": 985929,\n \"silverware\": 984227,\n \"silverware-clean\": 987102,\n \"silverware-fork\": 984228,\n \"silverware-fork-knife\": 985712,\n \"silverware-spoon\": 984229,\n \"silverware-variant\": 984230,\n \"sim\": 984231,\n \"sim-alert\": 984232,\n \"sim-alert-outline\": 988627,\n \"sim-off\": 984233,\n \"sim-off-outline\": 988628,\n \"sim-outline\": 988629,\n \"simple-icons\": 987933,\n \"sina-weibo\": 985823,\n \"sine-wave\": 985435,\n \"sitemap\": 984234,\n \"sitemap-outline\": 989596,\n \"size-l\": 988070,\n \"size-m\": 988069,\n \"size-s\": 988068,\n \"size-xl\": 988071,\n \"size-xs\": 988067,\n \"size-xxl\": 988072,\n \"size-xxs\": 988066,\n \"size-xxxl\": 988073,\n \"skate\": 986421,\n \"skate-off\": 984729,\n \"skateboard\": 988354,\n \"skateboarding\": 984321,\n \"skew-less\": 986422,\n \"skew-more\": 986423,\n \"ski\": 987908,\n \"ski-cross-country\": 987909,\n \"ski-water\": 987910,\n \"skip-backward\": 984235,\n \"skip-backward-outline\": 986917,\n \"skip-forward\": 984236,\n \"skip-forward-outline\": 986918,\n \"skip-next\": 984237,\n \"skip-next-circle\": 984673,\n \"skip-next-circle-outline\": 984674,\n \"skip-next-outline\": 986919,\n \"skip-previous\": 984238,\n \"skip-previous-circle\": 984675,\n \"skip-previous-circle-outline\": 984676,\n \"skip-previous-outline\": 986920,\n \"skull\": 984716,\n \"skull-crossbones\": 986054,\n \"skull-crossbones-outline\": 986055,\n \"skull-outline\": 986056,\n \"skull-scan\": 988359,\n \"skull-scan-outline\": 988360,\n \"skype\": 984239,\n \"skype-business\": 984240,\n \"slack\": 984241,\n \"slash-forward\": 987103,\n \"slash-forward-box\": 987104,\n \"sledding\": 984091,\n \"sleep\": 984242,\n \"sleep-off\": 984243,\n \"slide\": 988581,\n \"slope-downhill\": 986623,\n \"slope-uphill\": 986624,\n \"slot-machine\": 987412,\n \"slot-machine-outline\": 987413,\n \"smart-card\": 987325,\n \"smart-card-off\": 989431,\n \"smart-card-off-outline\": 989432,\n \"smart-card-outline\": 987326,\n \"smart-card-reader\": 987327,\n \"smart-card-reader-outline\": 987328,\n \"smog\": 985713,\n \"smoke\": 989081,\n \"smoke-detector\": 983954,\n \"smoke-detector-alert\": 989486,\n \"smoke-detector-alert-outline\": 989487,\n \"smoke-detector-off\": 989193,\n \"smoke-detector-off-outline\": 989194,\n \"smoke-detector-outline\": 989192,\n \"smoke-detector-variant\": 989195,\n \"smoke-detector-variant-alert\": 989488,\n \"smoke-detector-variant-off\": 989196,\n \"smoking\": 984244,\n \"smoking-off\": 984245,\n \"smoking-pipe\": 988173,\n \"smoking-pipe-off\": 988200,\n \"snail\": 988791,\n \"snake\": 988430,\n \"snapchat\": 984246,\n \"snowboard\": 987911,\n \"snowflake\": 984855,\n \"snowflake-alert\": 986921,\n \"snowflake-melt\": 987851,\n \"snowflake-off\": 988387,\n \"snowflake-variant\": 986922,\n \"snowman\": 984247,\n \"snowmobile\": 984797,\n \"soccer\": 984248,\n \"soccer-field\": 985140,\n \"social-distance-2-meters\": 988537,\n \"social-distance-6-feet\": 988538,\n \"sofa\": 984249,\n \"sofa-outline\": 988525,\n \"sofa-single\": 988526,\n \"sofa-single-outline\": 988527,\n \"solar-panel\": 986523,\n \"solar-panel-large\": 986524,\n \"solar-power\": 985714,\n \"soldering-iron\": 987282,\n \"solid\": 984717,\n \"sony-playstation\": 984084,\n \"sort\": 984250,\n \"sort-alphabetical-ascending\": 984509,\n \"sort-alphabetical-ascending-variant\": 987464,\n \"sort-alphabetical-descending\": 984511,\n \"sort-alphabetical-descending-variant\": 987465,\n \"sort-alphabetical-variant\": 984251,\n \"sort-ascending\": 984252,\n \"sort-bool-ascending\": 988037,\n \"sort-bool-ascending-variant\": 988038,\n \"sort-bool-descending\": 988039,\n \"sort-bool-descending-variant\": 988040,\n \"sort-calendar-ascending\": 988487,\n \"sort-calendar-descending\": 988488,\n \"sort-clock-ascending\": 988489,\n \"sort-clock-ascending-outline\": 988490,\n \"sort-clock-descending\": 988491,\n \"sort-clock-descending-outline\": 988492,\n \"sort-descending\": 984253,\n \"sort-numeric-ascending\": 988041,\n \"sort-numeric-ascending-variant\": 985357,\n \"sort-numeric-descending\": 988042,\n \"sort-numeric-descending-variant\": 985810,\n \"sort-numeric-variant\": 984254,\n \"sort-reverse-variant\": 983868,\n \"sort-variant\": 984255,\n \"sort-variant-lock\": 986317,\n \"sort-variant-lock-open\": 986318,\n \"sort-variant-remove\": 987463,\n \"soundbar\": 989147,\n \"soundcloud\": 984256,\n \"source-branch\": 984620,\n \"source-branch-check\": 988367,\n \"source-branch-minus\": 988363,\n \"source-branch-plus\": 988362,\n \"source-branch-refresh\": 988365,\n \"source-branch-remove\": 988364,\n \"source-branch-sync\": 988366,\n \"source-commit\": 984856,\n \"source-commit-end\": 984857,\n \"source-commit-end-local\": 984858,\n \"source-commit-local\": 984859,\n \"source-commit-next-local\": 984860,\n \"source-commit-start\": 984861,\n \"source-commit-start-next-local\": 984862,\n \"source-fork\": 984257,\n \"source-merge\": 984621,\n \"source-pull\": 984258,\n \"source-repository\": 986319,\n \"source-repository-multiple\": 986320,\n \"soy-sauce\": 985070,\n \"soy-sauce-off\": 988156,\n \"spa\": 986321,\n \"spa-outline\": 986322,\n \"space-invaders\": 986057,\n \"space-station\": 988035,\n \"spade\": 986725,\n \"speaker\": 984259,\n \"speaker-bluetooth\": 985506,\n \"speaker-multiple\": 986424,\n \"speaker-off\": 984260,\n \"speaker-wireless\": 984863,\n \"spear\": 989253,\n \"speedometer\": 984261,\n \"speedometer-medium\": 987013,\n \"speedometer-slow\": 987014,\n \"spellcheck\": 984262,\n \"sphere\": 989524,\n \"sphere-off\": 989525,\n \"spider\": 987626,\n \"spider-thread\": 987627,\n \"spider-web\": 986058,\n \"spirit-level\": 988401,\n \"spoon-sugar\": 988201,\n \"spotify\": 984263,\n \"spotlight\": 984264,\n \"spotlight-beam\": 984265,\n \"spray\": 984677,\n \"spray-bottle\": 985824,\n \"sprinkler\": 987231,\n \"sprinkler-fire\": 989597,\n \"sprinkler-variant\": 987232,\n \"sprout\": 986726,\n \"sprout-outline\": 986727,\n \"square\": 984932,\n \"square-circle\": 988416,\n \"square-edit-outline\": 985356,\n \"square-medium\": 985619,\n \"square-medium-outline\": 985620,\n \"square-off\": 987886,\n \"square-off-outline\": 987887,\n \"square-opacity\": 989268,\n \"square-outline\": 984931,\n \"square-root\": 984964,\n \"square-root-box\": 985507,\n \"square-rounded\": 988411,\n \"square-rounded-outline\": 988412,\n \"square-small\": 985621,\n \"square-wave\": 988283,\n \"squeegee\": 985825,\n \"ssh\": 985280,\n \"stack-exchange\": 984587,\n \"stack-overflow\": 984268,\n \"stackpath\": 983897,\n \"stadium\": 987129,\n \"stadium-variant\": 984864,\n \"stairs\": 984269,\n \"stairs-box\": 988062,\n \"stairs-down\": 987838,\n \"stairs-up\": 987837,\n \"stamper\": 986425,\n \"standard-definition\": 985071,\n \"star\": 984270,\n \"star-box\": 985715,\n \"star-box-multiple\": 987782,\n \"star-box-multiple-outline\": 987783,\n \"star-box-outline\": 985716,\n \"star-check\": 988518,\n \"star-check-outline\": 988522,\n \"star-circle\": 984271,\n \"star-circle-outline\": 985508,\n \"star-cog\": 988776,\n \"star-cog-outline\": 988777,\n \"star-crescent\": 985465,\n \"star-david\": 985466,\n \"star-face\": 985509,\n \"star-four-points\": 985826,\n \"star-four-points-outline\": 985827,\n \"star-half\": 983622,\n \"star-half-full\": 984272,\n \"star-minus\": 988516,\n \"star-minus-outline\": 988520,\n \"star-off\": 984273,\n \"star-off-outline\": 988507,\n \"star-outline\": 984274,\n \"star-plus\": 988515,\n \"star-plus-outline\": 988519,\n \"star-remove\": 988517,\n \"star-remove-outline\": 988521,\n \"star-settings\": 988778,\n \"star-settings-outline\": 988779,\n \"star-shooting\": 988993,\n \"star-shooting-outline\": 988994,\n \"star-three-points\": 985828,\n \"star-three-points-outline\": 985829,\n \"state-machine\": 987631,\n \"steam\": 984275,\n \"steering\": 984276,\n \"steering-off\": 985358,\n \"step-backward\": 984277,\n \"step-backward-2\": 984278,\n \"step-forward\": 984279,\n \"step-forward-2\": 984280,\n \"stethoscope\": 984281,\n \"sticker\": 988004,\n \"sticker-alert\": 988005,\n \"sticker-alert-outline\": 988006,\n \"sticker-check\": 988007,\n \"sticker-check-outline\": 988008,\n \"sticker-circle-outline\": 984528,\n \"sticker-emoji\": 984965,\n \"sticker-minus\": 988009,\n \"sticker-minus-outline\": 988010,\n \"sticker-outline\": 988011,\n \"sticker-plus\": 988012,\n \"sticker-plus-outline\": 988013,\n \"sticker-remove\": 988014,\n \"sticker-remove-outline\": 988015,\n \"sticker-text\": 989070,\n \"sticker-text-outline\": 989071,\n \"stocking\": 984282,\n \"stomach\": 987283,\n \"stool\": 989533,\n \"stool-outline\": 989534,\n \"stop\": 984283,\n \"stop-circle\": 984678,\n \"stop-circle-outline\": 984679,\n \"store\": 984284,\n \"store-24-hour\": 984285,\n \"store-alert\": 989377,\n \"store-alert-outline\": 989378,\n \"store-check\": 989379,\n \"store-check-outline\": 989380,\n \"store-clock\": 989381,\n \"store-clock-outline\": 989382,\n \"store-cog\": 989383,\n \"store-cog-outline\": 989384,\n \"store-edit\": 989385,\n \"store-edit-outline\": 989386,\n \"store-marker\": 989387,\n \"store-marker-outline\": 989388,\n \"store-minus\": 988766,\n \"store-minus-outline\": 989389,\n \"store-off\": 989390,\n \"store-off-outline\": 989391,\n \"store-outline\": 988001,\n \"store-plus\": 988767,\n \"store-plus-outline\": 989392,\n \"store-remove\": 988768,\n \"store-remove-outline\": 989393,\n \"store-search\": 989394,\n \"store-search-outline\": 989395,\n \"store-settings\": 989396,\n \"store-settings-outline\": 989397,\n \"storefront\": 985031,\n \"storefront-outline\": 987329,\n \"stove\": 984286,\n \"strategy\": 987606,\n \"stretch-to-page\": 986923,\n \"stretch-to-page-outline\": 986924,\n \"string-lights\": 987834,\n \"string-lights-off\": 987835,\n \"subdirectory-arrow-left\": 984588,\n \"subdirectory-arrow-right\": 984589,\n \"submarine\": 988524,\n \"subtitles\": 985622,\n \"subtitles-outline\": 985623,\n \"subway\": 984748,\n \"subway-alert-variant\": 986525,\n \"subway-variant\": 984287,\n \"summit\": 984966,\n \"sun-compass\": 989605,\n \"sun-snowflake\": 989078,\n \"sun-thermometer\": 989398,\n \"sun-thermometer-outline\": 989399,\n \"sun-wireless\": 989182,\n \"sun-wireless-outline\": 989183,\n \"sunglasses\": 984288,\n \"surfing\": 988998,\n \"surround-sound\": 984517,\n \"surround-sound-2-0\": 985072,\n \"surround-sound-2-1\": 988969,\n \"surround-sound-3-1\": 985073,\n \"surround-sound-5-1\": 985074,\n \"surround-sound-5-1-2\": 988970,\n \"surround-sound-7-1\": 985075,\n \"svg\": 984865,\n \"swap-horizontal\": 984289,\n \"swap-horizontal-bold\": 986061,\n \"swap-horizontal-circle\": 987105,\n \"swap-horizontal-circle-outline\": 987106,\n \"swap-horizontal-variant\": 985281,\n \"swap-vertical\": 984290,\n \"swap-vertical-bold\": 986062,\n \"swap-vertical-circle\": 987107,\n \"swap-vertical-circle-outline\": 987108,\n \"swap-vertical-variant\": 985282,\n \"swim\": 984291,\n \"switch\": 984292,\n \"sword\": 984293,\n \"sword-cross\": 984967,\n \"syllabary-hangul\": 987955,\n \"syllabary-hiragana\": 987956,\n \"syllabary-katakana\": 987957,\n \"syllabary-katakana-halfwidth\": 987958,\n \"symbol\": 988417,\n \"symfony\": 985830,\n \"sync\": 984294,\n \"sync-alert\": 984295,\n \"sync-circle\": 988024,\n \"sync-off\": 984296,\n \"tab\": 984297,\n \"tab-minus\": 985931,\n \"tab-plus\": 984924,\n \"tab-remove\": 985932,\n \"tab-search\": 989598,\n \"tab-unselected\": 984298,\n \"table\": 984299,\n \"table-account\": 988089,\n \"table-alert\": 988090,\n \"table-arrow-down\": 988091,\n \"table-arrow-left\": 988092,\n \"table-arrow-right\": 988093,\n \"table-arrow-up\": 988094,\n \"table-border\": 985624,\n \"table-cancel\": 988095,\n \"table-chair\": 987233,\n \"table-check\": 988096,\n \"table-clock\": 988097,\n \"table-cog\": 988098,\n \"table-column\": 985141,\n \"table-column-plus-after\": 984300,\n \"table-column-plus-before\": 984301,\n \"table-column-remove\": 984302,\n \"table-column-width\": 984303,\n \"table-edit\": 984304,\n \"table-eye\": 987284,\n \"table-eye-off\": 988099,\n \"table-furniture\": 984508,\n \"table-headers-eye\": 987677,\n \"table-headers-eye-off\": 987678,\n \"table-heart\": 988100,\n \"table-key\": 988101,\n \"table-large\": 984305,\n \"table-large-plus\": 987015,\n \"table-large-remove\": 987016,\n \"table-lock\": 988102,\n \"table-merge-cells\": 985510,\n \"table-minus\": 988103,\n \"table-multiple\": 988104,\n \"table-network\": 988105,\n \"table-of-contents\": 985142,\n \"table-off\": 988106,\n \"table-picnic\": 988995,\n \"table-pivot\": 989244,\n \"table-plus\": 985717,\n \"table-refresh\": 988064,\n \"table-remove\": 985718,\n \"table-row\": 985143,\n \"table-row-height\": 984306,\n \"table-row-plus-after\": 984307,\n \"table-row-plus-before\": 984308,\n \"table-row-remove\": 984309,\n \"table-search\": 985359,\n \"table-settings\": 985144,\n \"table-split-cell\": 988202,\n \"table-star\": 988107,\n \"table-sync\": 988065,\n \"table-tennis\": 986728,\n \"tablet\": 984310,\n \"tablet-android\": 984311,\n \"tablet-cellphone\": 985511,\n \"tablet-dashboard\": 986830,\n \"taco\": 984930,\n \"tag\": 984313,\n \"tag-arrow-down\": 988971,\n \"tag-arrow-down-outline\": 988972,\n \"tag-arrow-left\": 988973,\n \"tag-arrow-left-outline\": 988974,\n \"tag-arrow-right\": 988975,\n \"tag-arrow-right-outline\": 988976,\n \"tag-arrow-up\": 988977,\n \"tag-arrow-up-outline\": 988978,\n \"tag-faces\": 984314,\n \"tag-heart\": 984715,\n \"tag-heart-outline\": 986063,\n \"tag-minus\": 985360,\n \"tag-minus-outline\": 987679,\n \"tag-multiple\": 984315,\n \"tag-multiple-outline\": 987895,\n \"tag-off\": 987680,\n \"tag-off-outline\": 987681,\n \"tag-outline\": 984316,\n \"tag-plus\": 984866,\n \"tag-plus-outline\": 987682,\n \"tag-remove\": 984867,\n \"tag-remove-outline\": 987683,\n \"tag-search\": 989447,\n \"tag-search-outline\": 989448,\n \"tag-text\": 987684,\n \"tag-text-outline\": 984317,\n \"tailwind\": 988159,\n \"tangram\": 984312,\n \"tank\": 986426,\n \"tanker-truck\": 987109,\n \"tape-drive\": 988895,\n \"tape-measure\": 985933,\n \"target\": 984318,\n \"target-account\": 986064,\n \"target-variant\": 985719,\n \"taxi\": 984319,\n \"tea\": 986526,\n \"tea-outline\": 986527,\n \"teamviewer\": 984320,\n \"teddy-bear\": 989435,\n \"telescope\": 985934,\n \"television\": 984322,\n \"television-ambient-light\": 987990,\n \"television-box\": 985145,\n \"television-classic\": 985076,\n \"television-classic-off\": 985146,\n \"television-guide\": 984323,\n \"television-off\": 985147,\n \"television-pause\": 987017,\n \"television-play\": 986831,\n \"television-shimmer\": 987408,\n \"television-stop\": 987018,\n \"temperature-celsius\": 984324,\n \"temperature-fahrenheit\": 984325,\n \"temperature-kelvin\": 984326,\n \"tennis\": 986528,\n \"tennis-ball\": 984327,\n \"tent\": 984328,\n \"terraform\": 987234,\n \"terrain\": 984329,\n \"test-tube\": 984680,\n \"test-tube-empty\": 985361,\n \"test-tube-off\": 985362,\n \"text\": 985512,\n \"text-account\": 988528,\n \"text-box\": 983578,\n \"text-box-check\": 986790,\n \"text-box-check-outline\": 986791,\n \"text-box-minus\": 986792,\n \"text-box-minus-outline\": 986793,\n \"text-box-multiple\": 985783,\n \"text-box-multiple-outline\": 985784,\n \"text-box-outline\": 985581,\n \"text-box-plus\": 986794,\n \"text-box-plus-outline\": 986795,\n \"text-box-remove\": 986796,\n \"text-box-remove-outline\": 986797,\n \"text-box-search\": 986798,\n \"text-box-search-outline\": 986799,\n \"text-long\": 985514,\n \"text-recognition\": 987453,\n \"text-search\": 988088,\n \"text-shadow\": 984681,\n \"text-short\": 985513,\n \"text-to-speech\": 984330,\n \"text-to-speech-off\": 984331,\n \"texture\": 984332,\n \"texture-box\": 987110,\n \"theater\": 984333,\n \"theme-light-dark\": 984334,\n \"thermometer\": 984335,\n \"thermometer-alert\": 986625,\n \"thermometer-bluetooth\": 989333,\n \"thermometer-chevron-down\": 986626,\n \"thermometer-chevron-up\": 986627,\n \"thermometer-high\": 987330,\n \"thermometer-lines\": 984336,\n \"thermometer-low\": 987331,\n \"thermometer-minus\": 986628,\n \"thermometer-off\": 988465,\n \"thermometer-plus\": 986629,\n \"thermostat\": 983955,\n \"thermostat-box\": 985233,\n \"thought-bubble\": 985078,\n \"thought-bubble-outline\": 985079,\n \"thumb-down\": 984337,\n \"thumb-down-outline\": 984338,\n \"thumb-up\": 984339,\n \"thumb-up-outline\": 984340,\n \"thumbs-up-down\": 984341,\n \"thumbs-up-down-outline\": 989460,\n \"ticket\": 984342,\n \"ticket-account\": 984343,\n \"ticket-confirmation\": 984344,\n \"ticket-confirmation-outline\": 988074,\n \"ticket-outline\": 985363,\n \"ticket-percent\": 984868,\n \"ticket-percent-outline\": 988203,\n \"tie\": 984345,\n \"tilde\": 984869,\n \"tilde-off\": 989427,\n \"timelapse\": 984346,\n \"timeline\": 986065,\n \"timeline-alert\": 987029,\n \"timeline-alert-outline\": 987032,\n \"timeline-check\": 988466,\n \"timeline-check-outline\": 988467,\n \"timeline-clock\": 987643,\n \"timeline-clock-outline\": 987644,\n \"timeline-help\": 987033,\n \"timeline-help-outline\": 987034,\n \"timeline-minus\": 988468,\n \"timeline-minus-outline\": 988469,\n \"timeline-outline\": 986066,\n \"timeline-plus\": 987030,\n \"timeline-plus-outline\": 987031,\n \"timeline-remove\": 988470,\n \"timeline-remove-outline\": 988471,\n \"timeline-text\": 986067,\n \"timeline-text-outline\": 986068,\n \"timer\": 988075,\n \"timer-10\": 984348,\n \"timer-3\": 984349,\n \"timer-cog\": 989477,\n \"timer-cog-outline\": 989478,\n \"timer-off\": 988076,\n \"timer-off-outline\": 984350,\n \"timer-outline\": 984347,\n \"timer-sand\": 984351,\n \"timer-sand-complete\": 989599,\n \"timer-sand-empty\": 984749,\n \"timer-sand-full\": 984972,\n \"timer-sand-paused\": 989600,\n \"timer-settings\": 989475,\n \"timer-settings-outline\": 989476,\n \"timetable\": 984352,\n \"tire\": 989334,\n \"toaster\": 987235,\n \"toaster-off\": 987575,\n \"toaster-oven\": 986323,\n \"toggle-switch\": 984353,\n \"toggle-switch-off\": 984354,\n \"toggle-switch-off-outline\": 985625,\n \"toggle-switch-outline\": 985626,\n \"toilet\": 985515,\n \"toolbox\": 985516,\n \"toolbox-outline\": 985517,\n \"tools\": 987236,\n \"tooltip\": 984355,\n \"tooltip-account\": 983052,\n \"tooltip-cellphone\": 989243,\n \"tooltip-check\": 988508,\n \"tooltip-check-outline\": 988509,\n \"tooltip-edit\": 984356,\n \"tooltip-edit-outline\": 987845,\n \"tooltip-image\": 984357,\n \"tooltip-image-outline\": 986069,\n \"tooltip-minus\": 988510,\n \"tooltip-minus-outline\": 988511,\n \"tooltip-outline\": 984358,\n \"tooltip-plus\": 986070,\n \"tooltip-plus-outline\": 984359,\n \"tooltip-remove\": 988512,\n \"tooltip-remove-outline\": 988513,\n \"tooltip-text\": 984360,\n \"tooltip-text-outline\": 986071,\n \"tooth\": 985283,\n \"tooth-outline\": 984361,\n \"toothbrush\": 987433,\n \"toothbrush-electric\": 987436,\n \"toothbrush-paste\": 987434,\n \"torch\": 988678,\n \"tortoise\": 986427,\n \"toslink\": 987832,\n \"tournament\": 985518,\n \"tow-truck\": 985148,\n \"tower-beach\": 984705,\n \"tower-fire\": 984706,\n \"town-hall\": 989301,\n \"toy-brick\": 987784,\n \"toy-brick-marker\": 987785,\n \"toy-brick-marker-outline\": 987786,\n \"toy-brick-minus\": 987787,\n \"toy-brick-minus-outline\": 987788,\n \"toy-brick-outline\": 987789,\n \"toy-brick-plus\": 987790,\n \"toy-brick-plus-outline\": 987791,\n \"toy-brick-remove\": 987792,\n \"toy-brick-remove-outline\": 987793,\n \"toy-brick-search\": 987794,\n \"toy-brick-search-outline\": 987795,\n \"track-light\": 985364,\n \"trackpad\": 985080,\n \"trackpad-lock\": 985395,\n \"tractor\": 985234,\n \"tractor-variant\": 988356,\n \"trademark\": 985720,\n \"traffic-cone\": 988028,\n \"traffic-light\": 984363,\n \"traffic-light-outline\": 989226,\n \"train\": 984364,\n \"train-car\": 986072,\n \"train-car-passenger\": 988979,\n \"train-car-passenger-door\": 988980,\n \"train-car-passenger-door-open\": 988981,\n \"train-car-passenger-variant\": 988982,\n \"train-variant\": 985284,\n \"tram\": 984365,\n \"tram-side\": 987111,\n \"transcribe\": 984366,\n \"transcribe-close\": 984367,\n \"transfer\": 987237,\n \"transfer-down\": 986529,\n \"transfer-left\": 986530,\n \"transfer-right\": 984368,\n \"transfer-up\": 986531,\n \"transit-connection\": 986428,\n \"transit-connection-horizontal\": 988486,\n \"transit-connection-variant\": 986429,\n \"transit-detour\": 987019,\n \"transit-skip\": 988437,\n \"transit-transfer\": 984750,\n \"transition\": 985365,\n \"transition-masked\": 985366,\n \"translate\": 984522,\n \"translate-off\": 986630,\n \"transmission-tower\": 986430,\n \"transmission-tower-export\": 989484,\n \"transmission-tower-import\": 989485,\n \"trash-can\": 985721,\n \"trash-can-outline\": 985722,\n \"tray\": 987796,\n \"tray-alert\": 987797,\n \"tray-arrow-down\": 983328,\n \"tray-arrow-up\": 983325,\n \"tray-full\": 987798,\n \"tray-minus\": 987799,\n \"tray-plus\": 987800,\n \"tray-remove\": 987801,\n \"treasure-chest\": 984870,\n \"tree\": 984369,\n \"tree-outline\": 986729,\n \"trello\": 984370,\n \"trending-down\": 984371,\n \"trending-neutral\": 984372,\n \"trending-up\": 984373,\n \"triangle\": 984374,\n \"triangle-outline\": 984375,\n \"triangle-wave\": 988284,\n \"triforce\": 986073,\n \"trophy\": 984376,\n \"trophy-award\": 984377,\n \"trophy-broken\": 986532,\n \"trophy-outline\": 984378,\n \"trophy-variant\": 984379,\n \"trophy-variant-outline\": 984380,\n \"truck\": 984381,\n \"truck-cargo-container\": 989400,\n \"truck-check\": 986324,\n \"truck-check-outline\": 987802,\n \"truck-delivery\": 984382,\n \"truck-delivery-outline\": 987803,\n \"truck-fast\": 984968,\n \"truck-fast-outline\": 987804,\n \"truck-flatbed\": 989329,\n \"truck-minus\": 989614,\n \"truck-minus-outline\": 989629,\n \"truck-outline\": 987805,\n \"truck-plus\": 989613,\n \"truck-plus-outline\": 989628,\n \"truck-remove\": 989615,\n \"truck-remove-outline\": 989630,\n \"truck-snowflake\": 989606,\n \"truck-trailer\": 984871,\n \"trumpet\": 987286,\n \"tshirt-crew\": 985723,\n \"tshirt-crew-outline\": 984383,\n \"tshirt-v\": 985724,\n \"tshirt-v-outline\": 984384,\n \"tumble-dryer\": 985367,\n \"tumble-dryer-alert\": 987578,\n \"tumble-dryer-off\": 987579,\n \"tune\": 984622,\n \"tune-variant\": 988482,\n \"tune-vertical\": 984682,\n \"tune-vertical-variant\": 988483,\n \"tunnel\": 989245,\n \"tunnel-outline\": 989246,\n \"turkey\": 988955,\n \"turnstile\": 986325,\n \"turnstile-outline\": 986326,\n \"turtle\": 986327,\n \"twitch\": 984387,\n \"twitter\": 984388,\n \"two-factor-authentication\": 985519,\n \"typewriter\": 986925,\n \"ubisoft\": 986074,\n \"ubuntu\": 984392,\n \"ufo\": 987332,\n \"ufo-outline\": 987333,\n \"ultra-high-definition\": 985081,\n \"umbraco\": 984393,\n \"umbrella\": 984394,\n \"umbrella-beach\": 989322,\n \"umbrella-beach-outline\": 989323,\n \"umbrella-closed\": 985520,\n \"umbrella-closed-outline\": 988130,\n \"umbrella-closed-variant\": 988129,\n \"umbrella-outline\": 984395,\n \"undo\": 984396,\n \"undo-variant\": 984397,\n \"unfold-less-horizontal\": 984398,\n \"unfold-less-vertical\": 984928,\n \"unfold-more-horizontal\": 984399,\n \"unfold-more-vertical\": 984929,\n \"ungroup\": 984400,\n \"unicode\": 986832,\n \"unicorn\": 988610,\n \"unicorn-variant\": 988611,\n \"unicycle\": 988645,\n \"unity\": 984751,\n \"unreal\": 985521,\n \"update\": 984752,\n \"upload\": 984402,\n \"upload-lock\": 988019,\n \"upload-lock-outline\": 988020,\n \"upload-multiple\": 985149,\n \"upload-network\": 984822,\n \"upload-network-outline\": 986328,\n \"upload-off\": 987334,\n \"upload-off-outline\": 987335,\n \"upload-outline\": 986631,\n \"usb\": 984403,\n \"usb-flash-drive\": 987806,\n \"usb-flash-drive-outline\": 987807,\n \"usb-port\": 987632,\n \"vacuum\": 989601,\n \"vacuum-outline\": 989602,\n \"valve\": 987238,\n \"valve-closed\": 987239,\n \"valve-open\": 987240,\n \"van-passenger\": 985082,\n \"van-utility\": 985083,\n \"vanish\": 985084,\n \"vanish-quarter\": 988500,\n \"vanity-light\": 987617,\n \"variable\": 985831,\n \"variable-box\": 987409,\n \"vector-arrange-above\": 984404,\n \"vector-arrange-below\": 984405,\n \"vector-bezier\": 985832,\n \"vector-circle\": 984406,\n \"vector-circle-variant\": 984407,\n \"vector-combine\": 984408,\n \"vector-curve\": 984409,\n \"vector-difference\": 984410,\n \"vector-difference-ab\": 984411,\n \"vector-difference-ba\": 984412,\n \"vector-ellipse\": 985235,\n \"vector-intersection\": 984413,\n \"vector-line\": 984414,\n \"vector-link\": 987112,\n \"vector-point\": 984415,\n \"vector-polygon\": 984416,\n \"vector-polygon-variant\": 989270,\n \"vector-polyline\": 984417,\n \"vector-polyline-edit\": 987685,\n \"vector-polyline-minus\": 987686,\n \"vector-polyline-plus\": 987687,\n \"vector-polyline-remove\": 987688,\n \"vector-radius\": 984906,\n \"vector-rectangle\": 984518,\n \"vector-selection\": 984418,\n \"vector-square\": 983041,\n \"vector-square-close\": 989271,\n \"vector-square-edit\": 989401,\n \"vector-square-minus\": 989402,\n \"vector-square-open\": 989272,\n \"vector-square-plus\": 989403,\n \"vector-square-remove\": 989404,\n \"vector-triangle\": 984419,\n \"vector-union\": 984420,\n \"vhs\": 985627,\n \"vibrate\": 984422,\n \"vibrate-off\": 986329,\n \"video\": 984423,\n \"video-3d\": 985085,\n \"video-3d-off\": 988121,\n \"video-3d-variant\": 986833,\n \"video-4k-box\": 985150,\n \"video-account\": 985369,\n \"video-box\": 983293,\n \"video-box-off\": 983294,\n \"video-check\": 987241,\n \"video-check-outline\": 987242,\n \"video-high-definition\": 988462,\n \"video-image\": 985370,\n \"video-input-antenna\": 985151,\n \"video-input-component\": 985152,\n \"video-input-hdmi\": 985153,\n \"video-input-scart\": 987020,\n \"video-input-svideo\": 985154,\n \"video-marker\": 989609,\n \"video-marker-outline\": 989610,\n \"video-minus\": 985522,\n \"video-minus-outline\": 983738,\n \"video-off\": 984424,\n \"video-off-outline\": 986075,\n \"video-outline\": 986076,\n \"video-plus\": 985523,\n \"video-plus-outline\": 983507,\n \"video-stabilization\": 985371,\n \"video-switch\": 984425,\n \"video-switch-outline\": 984976,\n \"video-vintage\": 985628,\n \"video-wireless\": 986834,\n \"video-wireless-outline\": 986835,\n \"view-agenda\": 984426,\n \"view-agenda-outline\": 987608,\n \"view-array\": 984427,\n \"view-array-outline\": 988293,\n \"view-carousel\": 984428,\n \"view-carousel-outline\": 988294,\n \"view-column\": 984429,\n \"view-column-outline\": 988295,\n \"view-comfy\": 986730,\n \"view-comfy-outline\": 988296,\n \"view-compact\": 986731,\n \"view-compact-outline\": 986732,\n \"view-dashboard\": 984430,\n \"view-dashboard-edit\": 989511,\n \"view-dashboard-edit-outline\": 989512,\n \"view-dashboard-outline\": 985629,\n \"view-dashboard-variant\": 985155,\n \"view-dashboard-variant-outline\": 988297,\n \"view-day\": 984431,\n \"view-day-outline\": 988298,\n \"view-gallery\": 989320,\n \"view-gallery-outline\": 989321,\n \"view-grid\": 984432,\n \"view-grid-outline\": 987609,\n \"view-grid-plus\": 987021,\n \"view-grid-plus-outline\": 987610,\n \"view-headline\": 984433,\n \"view-list\": 984434,\n \"view-list-outline\": 988299,\n \"view-module\": 984435,\n \"view-module-outline\": 988300,\n \"view-parallel\": 984872,\n \"view-parallel-outline\": 988301,\n \"view-quilt\": 984436,\n \"view-quilt-outline\": 988302,\n \"view-sequential\": 984873,\n \"view-sequential-outline\": 988303,\n \"view-split-horizontal\": 986059,\n \"view-split-vertical\": 986060,\n \"view-stream\": 984437,\n \"view-stream-outline\": 988304,\n \"view-week\": 984438,\n \"view-week-outline\": 988305,\n \"vimeo\": 984439,\n \"violin\": 984591,\n \"virtual-reality\": 985236,\n \"virus\": 988086,\n \"virus-off\": 989409,\n \"virus-off-outline\": 989410,\n \"virus-outline\": 988087,\n \"vlc\": 984444,\n \"voicemail\": 984445,\n \"volleyball\": 985524,\n \"volume-high\": 984446,\n \"volume-low\": 984447,\n \"volume-medium\": 984448,\n \"volume-minus\": 984926,\n \"volume-mute\": 984927,\n \"volume-off\": 984449,\n \"volume-plus\": 984925,\n \"volume-source\": 987424,\n \"volume-variant-off\": 986632,\n \"volume-vibrate\": 987425,\n \"vote\": 985631,\n \"vote-outline\": 985632,\n \"vpn\": 984450,\n \"vuejs\": 985156,\n \"vuetify\": 986733,\n \"walk\": 984451,\n \"wall\": 985086,\n \"wall-sconce\": 985372,\n \"wall-sconce-flat\": 985373,\n \"wall-sconce-flat-outline\": 989129,\n \"wall-sconce-flat-variant\": 984092,\n \"wall-sconce-flat-variant-outline\": 989130,\n \"wall-sconce-outline\": 989131,\n \"wall-sconce-round\": 984904,\n \"wall-sconce-round-outline\": 989132,\n \"wall-sconce-round-variant\": 985374,\n \"wall-sconce-round-variant-outline\": 989133,\n \"wallet\": 984452,\n \"wallet-giftcard\": 984453,\n \"wallet-membership\": 984454,\n \"wallet-outline\": 986077,\n \"wallet-plus\": 987022,\n \"wallet-plus-outline\": 987023,\n \"wallet-travel\": 984455,\n \"wallpaper\": 986633,\n \"wan\": 984456,\n \"wardrobe\": 987024,\n \"wardrobe-outline\": 987025,\n \"warehouse\": 987009,\n \"washing-machine\": 984874,\n \"washing-machine-alert\": 987580,\n \"washing-machine-off\": 987581,\n \"watch\": 984457,\n \"watch-export\": 984458,\n \"watch-export-variant\": 985237,\n \"watch-import\": 984459,\n \"watch-import-variant\": 985238,\n \"watch-variant\": 985239,\n \"watch-vibrate\": 984753,\n \"watch-vibrate-off\": 986330,\n \"water\": 984460,\n \"water-alert\": 988418,\n \"water-alert-outline\": 988419,\n \"water-boiler\": 987026,\n \"water-boiler-alert\": 987571,\n \"water-boiler-off\": 987572,\n \"water-check\": 988420,\n \"water-check-outline\": 988421,\n \"water-circle\": 989190,\n \"water-minus\": 988422,\n \"water-minus-outline\": 988423,\n \"water-off\": 984461,\n \"water-off-outline\": 988424,\n \"water-opacity\": 989269,\n \"water-outline\": 986634,\n \"water-percent\": 984462,\n \"water-percent-alert\": 988425,\n \"water-plus\": 988426,\n \"water-plus-outline\": 988427,\n \"water-polo\": 987808,\n \"water-pump\": 984463,\n \"water-pump-off\": 987027,\n \"water-remove\": 988428,\n \"water-remove-outline\": 988429,\n \"water-sync\": 989126,\n \"water-well\": 987243,\n \"water-well-outline\": 987244,\n \"waterfall\": 989257,\n \"watering-can\": 988289,\n \"watering-can-outline\": 988290,\n \"watermark\": 984594,\n \"wave\": 986926,\n \"waveform\": 988285,\n \"waves\": 984973,\n \"waves-arrow-left\": 989273,\n \"waves-arrow-right\": 989274,\n \"waves-arrow-up\": 989275,\n \"waze\": 986078,\n \"weather-cloudy\": 984464,\n \"weather-cloudy-alert\": 986927,\n \"weather-cloudy-arrow-right\": 986734,\n \"weather-cloudy-clock\": 989430,\n \"weather-fog\": 984465,\n \"weather-hail\": 984466,\n \"weather-hazy\": 986928,\n \"weather-hurricane\": 985240,\n \"weather-lightning\": 984467,\n \"weather-lightning-rainy\": 984702,\n \"weather-night\": 984468,\n \"weather-night-partly-cloudy\": 986929,\n \"weather-partly-cloudy\": 984469,\n \"weather-partly-lightning\": 986930,\n \"weather-partly-rainy\": 986931,\n \"weather-partly-snowy\": 986932,\n \"weather-partly-snowy-rainy\": 986933,\n \"weather-pouring\": 984470,\n \"weather-rainy\": 984471,\n \"weather-snowy\": 984472,\n \"weather-snowy-heavy\": 986934,\n \"weather-snowy-rainy\": 984703,\n \"weather-sunny\": 984473,\n \"weather-sunny-alert\": 986935,\n \"weather-sunny-off\": 988388,\n \"weather-sunset\": 984474,\n \"weather-sunset-down\": 984475,\n \"weather-sunset-up\": 984476,\n \"weather-tornado\": 986936,\n \"weather-windy\": 984477,\n \"weather-windy-variant\": 984478,\n \"web\": 984479,\n \"web-box\": 987028,\n \"web-cancel\": 989072,\n \"web-check\": 984969,\n \"web-clock\": 987722,\n \"web-minus\": 987296,\n \"web-off\": 985742,\n \"web-plus\": 983091,\n \"web-refresh\": 989073,\n \"web-remove\": 984401,\n \"web-sync\": 989074,\n \"webcam\": 984480,\n \"webcam-off\": 988983,\n \"webhook\": 984623,\n \"webpack\": 984875,\n \"webrtc\": 987720,\n \"wechat\": 984593,\n \"weight\": 984481,\n \"weight-gram\": 986431,\n \"weight-kilogram\": 984482,\n \"weight-lifter\": 987485,\n \"weight-pound\": 985525,\n \"whatsapp\": 984483,\n \"wheel-barrow\": 988402,\n \"wheelchair-accessibility\": 984484,\n \"whistle\": 985526,\n \"whistle-outline\": 987836,\n \"white-balance-auto\": 984485,\n \"white-balance-incandescent\": 984486,\n \"white-balance-iridescent\": 984487,\n \"white-balance-sunny\": 984488,\n \"widgets\": 984876,\n \"widgets-outline\": 987989,\n \"wifi\": 984489,\n \"wifi-alert\": 988853,\n \"wifi-arrow-down\": 988854,\n \"wifi-arrow-left\": 988855,\n \"wifi-arrow-left-right\": 988856,\n \"wifi-arrow-right\": 988857,\n \"wifi-arrow-up\": 988858,\n \"wifi-arrow-up-down\": 988859,\n \"wifi-cancel\": 988860,\n \"wifi-check\": 988861,\n \"wifi-cog\": 988862,\n \"wifi-lock\": 988863,\n \"wifi-lock-open\": 988864,\n \"wifi-marker\": 988865,\n \"wifi-minus\": 988866,\n \"wifi-off\": 984490,\n \"wifi-plus\": 988867,\n \"wifi-refresh\": 988868,\n \"wifi-remove\": 988869,\n \"wifi-settings\": 988870,\n \"wifi-star\": 986635,\n \"wifi-strength-1\": 985375,\n \"wifi-strength-1-alert\": 985376,\n \"wifi-strength-1-lock\": 985377,\n \"wifi-strength-1-lock-open\": 988875,\n \"wifi-strength-2\": 985378,\n \"wifi-strength-2-alert\": 985379,\n \"wifi-strength-2-lock\": 985380,\n \"wifi-strength-2-lock-open\": 988876,\n \"wifi-strength-3\": 985381,\n \"wifi-strength-3-alert\": 985382,\n \"wifi-strength-3-lock\": 985383,\n \"wifi-strength-3-lock-open\": 988877,\n \"wifi-strength-4\": 985384,\n \"wifi-strength-4-alert\": 985385,\n \"wifi-strength-4-lock\": 985386,\n \"wifi-strength-4-lock-open\": 988878,\n \"wifi-strength-alert-outline\": 985387,\n \"wifi-strength-lock-open-outline\": 988879,\n \"wifi-strength-lock-outline\": 985388,\n \"wifi-strength-off\": 985389,\n \"wifi-strength-off-outline\": 985390,\n \"wifi-strength-outline\": 985391,\n \"wifi-sync\": 988871,\n \"wikipedia\": 984492,\n \"wind-turbine\": 986533,\n \"wind-turbine-alert\": 989611,\n \"wind-turbine-check\": 989612,\n \"window-close\": 984493,\n \"window-closed\": 984494,\n \"window-closed-variant\": 987611,\n \"window-maximize\": 984495,\n \"window-minimize\": 984496,\n \"window-open\": 984497,\n \"window-open-variant\": 987612,\n \"window-restore\": 984498,\n \"window-shutter\": 987420,\n \"window-shutter-alert\": 987421,\n \"window-shutter-open\": 987422,\n \"windsock\": 988666,\n \"wiper\": 985833,\n \"wiper-wash\": 986534,\n \"wiper-wash-alert\": 989407,\n \"wizard-hat\": 988279,\n \"wordpress\": 984500,\n \"wrap\": 984502,\n \"wrap-disabled\": 986079,\n \"wrench\": 984503,\n \"wrench-clock\": 989603,\n \"wrench-outline\": 986080,\n \"xamarin\": 985157,\n \"xml\": 984512,\n \"xmpp\": 985087,\n \"yahoo\": 985935,\n \"yeast\": 984513,\n \"yin-yang\": 984704,\n \"yoga\": 987516,\n \"youtube\": 984515,\n \"youtube-gaming\": 985160,\n \"youtube-studio\": 985159,\n \"youtube-subscription\": 986432,\n \"youtube-tv\": 984136,\n \"yurt\": 988438,\n \"z-wave\": 985834,\n \"zend\": 985835,\n \"zigbee\": 986433,\n \"zip-box\": 984516,\n \"zip-box-outline\": 987130,\n \"zip-disk\": 985635,\n \"zodiac-aquarius\": 985725,\n \"zodiac-aries\": 985726,\n \"zodiac-cancer\": 985727,\n \"zodiac-capricorn\": 985728,\n \"zodiac-gemini\": 985729,\n \"zodiac-leo\": 985730,\n \"zodiac-libra\": 985731,\n \"zodiac-pisces\": 985732,\n \"zodiac-sagittarius\": 985733,\n \"zodiac-scorpio\": 985734,\n \"zodiac-taurus\": 985735,\n \"zodiac-virgo\": 985736,\n \"blank\": 63116\n}","import { createTheming } from '@callstack/react-theme-provider';\nimport color from 'color';\nimport { MD2DarkTheme, MD2LightTheme, MD3DarkTheme, MD3LightTheme } from '../styles/themes';\nexport const DefaultTheme = MD3LightTheme;\nexport const {\n ThemeProvider,\n withTheme,\n useTheme: useAppTheme\n} = createTheming(MD3LightTheme);\nexport function useTheme(overrides) {\n return useAppTheme(overrides);\n}\nexport const useInternalTheme = themeOverrides => useAppTheme(themeOverrides);\nexport const withInternalTheme = WrappedComponent => withTheme(WrappedComponent);\nexport const defaultThemesByVersion = {\n 2: {\n light: MD2LightTheme,\n dark: MD2DarkTheme\n },\n 3: {\n light: MD3LightTheme,\n dark: MD3DarkTheme\n }\n};\nexport const getTheme = function () {\n let isDark = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n let isV3 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n const themeVersion = isV3 ? 3 : 2;\n const scheme = isDark ? 'dark' : 'light';\n return defaultThemesByVersion[themeVersion][scheme];\n};\n\n// eslint-disable-next-line no-redeclare\n\n// eslint-disable-next-line no-redeclare\n\n// eslint-disable-next-line no-redeclare\n\n// eslint-disable-next-line no-redeclare\nexport function adaptNavigationTheme(themes) {\n const {\n reactNavigationLight,\n reactNavigationDark,\n materialLight,\n materialDark\n } = themes;\n const getAdaptedTheme = (navigationTheme, MD3Theme) => {\n return {\n ...navigationTheme,\n colors: {\n ...navigationTheme.colors,\n primary: MD3Theme.colors.primary,\n background: MD3Theme.colors.background,\n card: MD3Theme.colors.elevation.level2,\n text: MD3Theme.colors.onSurface,\n border: MD3Theme.colors.outline,\n notification: MD3Theme.colors.error\n }\n };\n };\n const MD3Themes = {\n light: materialLight || MD3LightTheme,\n dark: materialDark || MD3DarkTheme\n };\n if (reactNavigationLight && reactNavigationDark) {\n const modes = ['light', 'dark'];\n const NavigationThemes = {\n light: reactNavigationLight,\n dark: reactNavigationDark\n };\n const {\n light: adaptedLight,\n dark: adaptedDark\n } = modes.reduce((prev, curr) => {\n return {\n ...prev,\n [curr]: getAdaptedTheme(NavigationThemes[curr], MD3Themes[curr])\n };\n }, {\n light: reactNavigationLight,\n dark: reactNavigationDark\n });\n return {\n LightTheme: adaptedLight,\n DarkTheme: adaptedDark\n };\n }\n if (reactNavigationDark) {\n return {\n DarkTheme: getAdaptedTheme(reactNavigationDark, MD3Themes.dark)\n };\n }\n return {\n LightTheme: getAdaptedTheme(reactNavigationLight, MD3Themes.light)\n };\n}\nexport const getDynamicThemeElevations = scheme => {\n const elevationValues = ['transparent', 0.05, 0.08, 0.11, 0.12, 0.14];\n return elevationValues.reduce((elevations, elevationValue, index) => {\n return {\n ...elevations,\n [`level${index}`]: index === 0 ? elevationValue : color(scheme.surface).mix(color(scheme.primary), elevationValue).rgb().string()\n };\n }, {});\n};\n//# sourceMappingURL=theming.js.map","\"use strict\";\n\nexports.__esModule = true;\n\nvar _createTheming = _interopRequireDefault(require(\"./createTheming\"));\n\nexports.createTheming = _createTheming.default;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n//# sourceMappingURL=index.js.map","\"use strict\";\n\nexports.__esModule = true;\nexports.default = createTheming;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _deepmerge = _interopRequireDefault(require(\"deepmerge\"));\n\nvar _createThemeProvider = _interopRequireDefault(require(\"./createThemeProvider\"));\n\nvar _createWithTheme = _interopRequireDefault(require(\"./createWithTheme\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }\n\nfunction createTheming(defaultTheme) {\n var ThemeContext = React.createContext(defaultTheme);\n var ThemeProvider = (0, _createThemeProvider.default)(defaultTheme, ThemeContext);\n var withTheme = (0, _createWithTheme.default)(ThemeProvider, ThemeContext);\n\n var useTheme = function useTheme(overrides) {\n var theme = React.useContext(ThemeContext);\n var result = React.useMemo(function () {\n return theme && overrides ? (0, _deepmerge.default)(theme, overrides) : theme || overrides;\n }, [theme, overrides]);\n return result;\n };\n\n return {\n ThemeContext: ThemeContext,\n ThemeProvider: ThemeProvider,\n withTheme: withTheme,\n useTheme: useTheme\n };\n}\n//# sourceMappingURL=createTheming.js.map","(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n\ttypeof define === 'function' && define.amd ? define(factory) :\n\t(global = global || self, global.deepmerge = factory());\n}(this, function () { 'use strict';\n\n\tvar isMergeableObject = function isMergeableObject(value) {\n\t\treturn isNonNullObject(value)\n\t\t\t&& !isSpecial(value)\n\t};\n\n\tfunction isNonNullObject(value) {\n\t\treturn !!value && typeof value === 'object'\n\t}\n\n\tfunction isSpecial(value) {\n\t\tvar stringValue = Object.prototype.toString.call(value);\n\n\t\treturn stringValue === '[object RegExp]'\n\t\t\t|| stringValue === '[object Date]'\n\t\t\t|| isReactElement(value)\n\t}\n\n\t// see https://github.com/facebook/react/blob/b5ac963fb791d1298e7f396236383bc955f916c1/src/isomorphic/classic/element/ReactElement.js#L21-L25\n\tvar canUseSymbol = typeof Symbol === 'function' && Symbol.for;\n\tvar REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for('react.element') : 0xeac7;\n\n\tfunction isReactElement(value) {\n\t\treturn value.$$typeof === REACT_ELEMENT_TYPE\n\t}\n\n\tfunction emptyTarget(val) {\n\t\treturn Array.isArray(val) ? [] : {}\n\t}\n\n\tfunction cloneUnlessOtherwiseSpecified(value, options) {\n\t\treturn (options.clone !== false && options.isMergeableObject(value))\n\t\t\t? deepmerge(emptyTarget(value), value, options)\n\t\t\t: value\n\t}\n\n\tfunction defaultArrayMerge(target, source, options) {\n\t\treturn target.concat(source).map(function(element) {\n\t\t\treturn cloneUnlessOtherwiseSpecified(element, options)\n\t\t})\n\t}\n\n\tfunction getMergeFunction(key, options) {\n\t\tif (!options.customMerge) {\n\t\t\treturn deepmerge\n\t\t}\n\t\tvar customMerge = options.customMerge(key);\n\t\treturn typeof customMerge === 'function' ? customMerge : deepmerge\n\t}\n\n\tfunction getEnumerableOwnPropertySymbols(target) {\n\t\treturn Object.getOwnPropertySymbols\n\t\t\t? Object.getOwnPropertySymbols(target).filter(function(symbol) {\n\t\t\t\treturn target.propertyIsEnumerable(symbol)\n\t\t\t})\n\t\t\t: []\n\t}\n\n\tfunction getKeys(target) {\n\t\treturn Object.keys(target).concat(getEnumerableOwnPropertySymbols(target))\n\t}\n\n\tfunction mergeObject(target, source, options) {\n\t\tvar destination = {};\n\t\tif (options.isMergeableObject(target)) {\n\t\t\tgetKeys(target).forEach(function(key) {\n\t\t\t\tdestination[key] = cloneUnlessOtherwiseSpecified(target[key], options);\n\t\t\t});\n\t\t}\n\t\tgetKeys(source).forEach(function(key) {\n\t\t\tif (!options.isMergeableObject(source[key]) || !target[key]) {\n\t\t\t\tdestination[key] = cloneUnlessOtherwiseSpecified(source[key], options);\n\t\t\t} else {\n\t\t\t\tdestination[key] = getMergeFunction(key, options)(target[key], source[key], options);\n\t\t\t}\n\t\t});\n\t\treturn destination\n\t}\n\n\tfunction deepmerge(target, source, options) {\n\t\toptions = options || {};\n\t\toptions.arrayMerge = options.arrayMerge || defaultArrayMerge;\n\t\toptions.isMergeableObject = options.isMergeableObject || isMergeableObject;\n\n\t\tvar sourceIsArray = Array.isArray(source);\n\t\tvar targetIsArray = Array.isArray(target);\n\t\tvar sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;\n\n\t\tif (!sourceAndTargetTypesMatch) {\n\t\t\treturn cloneUnlessOtherwiseSpecified(source, options)\n\t\t} else if (sourceIsArray) {\n\t\t\treturn options.arrayMerge(target, source, options)\n\t\t} else {\n\t\t\treturn mergeObject(target, source, options)\n\t\t}\n\t}\n\n\tdeepmerge.all = function deepmergeAll(array, options) {\n\t\tif (!Array.isArray(array)) {\n\t\t\tthrow new Error('first argument should be an array')\n\t\t}\n\n\t\treturn array.reduce(function(prev, next) {\n\t\t\treturn deepmerge(prev, next, options)\n\t\t}, {})\n\t};\n\n\tvar deepmerge_1 = deepmerge;\n\n\treturn deepmerge_1;\n\n}));\n","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction createThemeProvider(defaultTheme, ThemeContext) {\n var _class, _temp;\n\n return _temp = _class =\n /*#__PURE__*/\n function (_React$Component) {\n _inheritsLoose(ThemeProvider, _React$Component);\n\n function ThemeProvider() {\n return _React$Component.apply(this, arguments) || this;\n }\n\n var _proto = ThemeProvider.prototype;\n\n _proto.render = function render() {\n return React.createElement(ThemeContext.Provider, {\n value: this.props.theme\n }, this.props.children);\n };\n\n return ThemeProvider;\n }(React.Component), _defineProperty(_class, \"defaultProps\", {\n theme: defaultTheme\n }), _temp;\n}\n\nvar _default = createThemeProvider;\nexports.default = _default;\n//# sourceMappingURL=createThemeProvider.js.map","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _deepmerge = _interopRequireDefault(require(\"deepmerge\"));\n\nvar _hoistNonReactStatics = _interopRequireDefault(require(\"hoist-non-react-statics\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar createWithTheme = function createWithTheme(ThemeProvider, ThemeContext) {\n return function withTheme(Comp) {\n var ThemedComponent =\n /*#__PURE__*/\n function (_React$Component) {\n _inheritsLoose(ThemedComponent, _React$Component);\n\n function ThemedComponent() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _defineProperty(_assertThisInitialized(_this), \"_previous\", void 0);\n\n _defineProperty(_assertThisInitialized(_this), \"_merge\", function (a, b) {\n var previous = _this._previous;\n\n if (previous && previous.a === a && previous.b === b) {\n return previous.result;\n }\n\n var result = a && b && a !== b ? (0, _deepmerge.default)(a, b) : a || b;\n _this._previous = {\n a: a,\n b: b,\n result: result\n };\n return result;\n });\n\n return _this;\n }\n\n var _proto = ThemedComponent.prototype;\n\n _proto.render = function render() {\n var _this2 = this;\n\n var _this$props = this.props,\n _reactThemeProviderForwardedRef = _this$props._reactThemeProviderForwardedRef,\n rest = _objectWithoutPropertiesLoose(_this$props, [\"_reactThemeProviderForwardedRef\"]);\n\n return React.createElement(ThemeContext.Consumer, null, function (theme) {\n return React.createElement(Comp, _extends({}, rest, {\n theme: _this2._merge(theme, rest.theme),\n ref: _reactThemeProviderForwardedRef\n }));\n });\n };\n\n return ThemedComponent;\n }(React.Component);\n\n var ResultComponent = React.forwardRef(function (props, ref) {\n return React.createElement(ThemedComponent, _extends({}, props, {\n _reactThemeProviderForwardedRef: ref\n }));\n });\n ResultComponent.displayName = \"withTheme(\" + (Comp.displayName || Comp.name) + \")\";\n (0, _hoistNonReactStatics.default)(ResultComponent, Comp);\n return ResultComponent;\n };\n};\n\nvar _default = createWithTheme;\nexports.default = _default;\n//# sourceMappingURL=createWithTheme.js.map","'use strict';\n\nvar colorString = require('color-string');\nvar convert = require('color-convert');\n\nvar _slice = [].slice;\n\nvar skippedModels = [\n\t// to be honest, I don't really feel like keyword belongs in color convert, but eh.\n\t'keyword',\n\n\t// gray conflicts with some method names, and has its own method defined.\n\t'gray',\n\n\t// shouldn't really be in color-convert either...\n\t'hex'\n];\n\nvar hashedModelKeys = {};\nObject.keys(convert).forEach(function (model) {\n\thashedModelKeys[_slice.call(convert[model].labels).sort().join('')] = model;\n});\n\nvar limiters = {};\n\nfunction Color(obj, model) {\n\tif (!(this instanceof Color)) {\n\t\treturn new Color(obj, model);\n\t}\n\n\tif (model && model in skippedModels) {\n\t\tmodel = null;\n\t}\n\n\tif (model && !(model in convert)) {\n\t\tthrow new Error('Unknown model: ' + model);\n\t}\n\n\tvar i;\n\tvar channels;\n\n\tif (obj == null) { // eslint-disable-line no-eq-null,eqeqeq\n\t\tthis.model = 'rgb';\n\t\tthis.color = [0, 0, 0];\n\t\tthis.valpha = 1;\n\t} else if (obj instanceof Color) {\n\t\tthis.model = obj.model;\n\t\tthis.color = obj.color.slice();\n\t\tthis.valpha = obj.valpha;\n\t} else if (typeof obj === 'string') {\n\t\tvar result = colorString.get(obj);\n\t\tif (result === null) {\n\t\t\tthrow new Error('Unable to parse color from string: ' + obj);\n\t\t}\n\n\t\tthis.model = result.model;\n\t\tchannels = convert[this.model].channels;\n\t\tthis.color = result.value.slice(0, channels);\n\t\tthis.valpha = typeof result.value[channels] === 'number' ? result.value[channels] : 1;\n\t} else if (obj.length) {\n\t\tthis.model = model || 'rgb';\n\t\tchannels = convert[this.model].channels;\n\t\tvar newArr = _slice.call(obj, 0, channels);\n\t\tthis.color = zeroArray(newArr, channels);\n\t\tthis.valpha = typeof obj[channels] === 'number' ? obj[channels] : 1;\n\t} else if (typeof obj === 'number') {\n\t\t// this is always RGB - can be converted later on.\n\t\tobj &= 0xFFFFFF;\n\t\tthis.model = 'rgb';\n\t\tthis.color = [\n\t\t\t(obj >> 16) & 0xFF,\n\t\t\t(obj >> 8) & 0xFF,\n\t\t\tobj & 0xFF\n\t\t];\n\t\tthis.valpha = 1;\n\t} else {\n\t\tthis.valpha = 1;\n\n\t\tvar keys = Object.keys(obj);\n\t\tif ('alpha' in obj) {\n\t\t\tkeys.splice(keys.indexOf('alpha'), 1);\n\t\t\tthis.valpha = typeof obj.alpha === 'number' ? obj.alpha : 0;\n\t\t}\n\n\t\tvar hashedKeys = keys.sort().join('');\n\t\tif (!(hashedKeys in hashedModelKeys)) {\n\t\t\tthrow new Error('Unable to parse color from object: ' + JSON.stringify(obj));\n\t\t}\n\n\t\tthis.model = hashedModelKeys[hashedKeys];\n\n\t\tvar labels = convert[this.model].labels;\n\t\tvar color = [];\n\t\tfor (i = 0; i < labels.length; i++) {\n\t\t\tcolor.push(obj[labels[i]]);\n\t\t}\n\n\t\tthis.color = zeroArray(color);\n\t}\n\n\t// perform limitations (clamping, etc.)\n\tif (limiters[this.model]) {\n\t\tchannels = convert[this.model].channels;\n\t\tfor (i = 0; i < channels; i++) {\n\t\t\tvar limit = limiters[this.model][i];\n\t\t\tif (limit) {\n\t\t\t\tthis.color[i] = limit(this.color[i]);\n\t\t\t}\n\t\t}\n\t}\n\n\tthis.valpha = Math.max(0, Math.min(1, this.valpha));\n\n\tif (Object.freeze) {\n\t\tObject.freeze(this);\n\t}\n}\n\nColor.prototype = {\n\ttoString: function () {\n\t\treturn this.string();\n\t},\n\n\ttoJSON: function () {\n\t\treturn this[this.model]();\n\t},\n\n\tstring: function (places) {\n\t\tvar self = this.model in colorString.to ? this : this.rgb();\n\t\tself = self.round(typeof places === 'number' ? places : 1);\n\t\tvar args = self.valpha === 1 ? self.color : self.color.concat(this.valpha);\n\t\treturn colorString.to[self.model](args);\n\t},\n\n\tpercentString: function (places) {\n\t\tvar self = this.rgb().round(typeof places === 'number' ? places : 1);\n\t\tvar args = self.valpha === 1 ? self.color : self.color.concat(this.valpha);\n\t\treturn colorString.to.rgb.percent(args);\n\t},\n\n\tarray: function () {\n\t\treturn this.valpha === 1 ? this.color.slice() : this.color.concat(this.valpha);\n\t},\n\n\tobject: function () {\n\t\tvar result = {};\n\t\tvar channels = convert[this.model].channels;\n\t\tvar labels = convert[this.model].labels;\n\n\t\tfor (var i = 0; i < channels; i++) {\n\t\t\tresult[labels[i]] = this.color[i];\n\t\t}\n\n\t\tif (this.valpha !== 1) {\n\t\t\tresult.alpha = this.valpha;\n\t\t}\n\n\t\treturn result;\n\t},\n\n\tunitArray: function () {\n\t\tvar rgb = this.rgb().color;\n\t\trgb[0] /= 255;\n\t\trgb[1] /= 255;\n\t\trgb[2] /= 255;\n\n\t\tif (this.valpha !== 1) {\n\t\t\trgb.push(this.valpha);\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tunitObject: function () {\n\t\tvar rgb = this.rgb().object();\n\t\trgb.r /= 255;\n\t\trgb.g /= 255;\n\t\trgb.b /= 255;\n\n\t\tif (this.valpha !== 1) {\n\t\t\trgb.alpha = this.valpha;\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tround: function (places) {\n\t\tplaces = Math.max(places || 0, 0);\n\t\treturn new Color(this.color.map(roundToPlace(places)).concat(this.valpha), this.model);\n\t},\n\n\talpha: function (val) {\n\t\tif (arguments.length) {\n\t\t\treturn new Color(this.color.concat(Math.max(0, Math.min(1, val))), this.model);\n\t\t}\n\n\t\treturn this.valpha;\n\t},\n\n\t// rgb\n\tred: getset('rgb', 0, maxfn(255)),\n\tgreen: getset('rgb', 1, maxfn(255)),\n\tblue: getset('rgb', 2, maxfn(255)),\n\n\thue: getset(['hsl', 'hsv', 'hsl', 'hwb', 'hcg'], 0, function (val) { return ((val % 360) + 360) % 360; }), // eslint-disable-line brace-style\n\n\tsaturationl: getset('hsl', 1, maxfn(100)),\n\tlightness: getset('hsl', 2, maxfn(100)),\n\n\tsaturationv: getset('hsv', 1, maxfn(100)),\n\tvalue: getset('hsv', 2, maxfn(100)),\n\n\tchroma: getset('hcg', 1, maxfn(100)),\n\tgray: getset('hcg', 2, maxfn(100)),\n\n\twhite: getset('hwb', 1, maxfn(100)),\n\twblack: getset('hwb', 2, maxfn(100)),\n\n\tcyan: getset('cmyk', 0, maxfn(100)),\n\tmagenta: getset('cmyk', 1, maxfn(100)),\n\tyellow: getset('cmyk', 2, maxfn(100)),\n\tblack: getset('cmyk', 3, maxfn(100)),\n\n\tx: getset('xyz', 0, maxfn(100)),\n\ty: getset('xyz', 1, maxfn(100)),\n\tz: getset('xyz', 2, maxfn(100)),\n\n\tl: getset('lab', 0, maxfn(100)),\n\ta: getset('lab', 1),\n\tb: getset('lab', 2),\n\n\tkeyword: function (val) {\n\t\tif (arguments.length) {\n\t\t\treturn new Color(val);\n\t\t}\n\n\t\treturn convert[this.model].keyword(this.color);\n\t},\n\n\thex: function (val) {\n\t\tif (arguments.length) {\n\t\t\treturn new Color(val);\n\t\t}\n\n\t\treturn colorString.to.hex(this.rgb().round().color);\n\t},\n\n\trgbNumber: function () {\n\t\tvar rgb = this.rgb().color;\n\t\treturn ((rgb[0] & 0xFF) << 16) | ((rgb[1] & 0xFF) << 8) | (rgb[2] & 0xFF);\n\t},\n\n\tluminosity: function () {\n\t\t// http://www.w3.org/TR/WCAG20/#relativeluminancedef\n\t\tvar rgb = this.rgb().color;\n\n\t\tvar lum = [];\n\t\tfor (var i = 0; i < rgb.length; i++) {\n\t\t\tvar chan = rgb[i] / 255;\n\t\t\tlum[i] = (chan <= 0.03928) ? chan / 12.92 : Math.pow(((chan + 0.055) / 1.055), 2.4);\n\t\t}\n\n\t\treturn 0.2126 * lum[0] + 0.7152 * lum[1] + 0.0722 * lum[2];\n\t},\n\n\tcontrast: function (color2) {\n\t\t// http://www.w3.org/TR/WCAG20/#contrast-ratiodef\n\t\tvar lum1 = this.luminosity();\n\t\tvar lum2 = color2.luminosity();\n\n\t\tif (lum1 > lum2) {\n\t\t\treturn (lum1 + 0.05) / (lum2 + 0.05);\n\t\t}\n\n\t\treturn (lum2 + 0.05) / (lum1 + 0.05);\n\t},\n\n\tlevel: function (color2) {\n\t\tvar contrastRatio = this.contrast(color2);\n\t\tif (contrastRatio >= 7.1) {\n\t\t\treturn 'AAA';\n\t\t}\n\n\t\treturn (contrastRatio >= 4.5) ? 'AA' : '';\n\t},\n\n\tisDark: function () {\n\t\t// YIQ equation from http://24ways.org/2010/calculating-color-contrast\n\t\tvar rgb = this.rgb().color;\n\t\tvar yiq = (rgb[0] * 299 + rgb[1] * 587 + rgb[2] * 114) / 1000;\n\t\treturn yiq < 128;\n\t},\n\n\tisLight: function () {\n\t\treturn !this.isDark();\n\t},\n\n\tnegate: function () {\n\t\tvar rgb = this.rgb();\n\t\tfor (var i = 0; i < 3; i++) {\n\t\t\trgb.color[i] = 255 - rgb.color[i];\n\t\t}\n\t\treturn rgb;\n\t},\n\n\tlighten: function (ratio) {\n\t\tvar hsl = this.hsl();\n\t\thsl.color[2] += hsl.color[2] * ratio;\n\t\treturn hsl;\n\t},\n\n\tdarken: function (ratio) {\n\t\tvar hsl = this.hsl();\n\t\thsl.color[2] -= hsl.color[2] * ratio;\n\t\treturn hsl;\n\t},\n\n\tsaturate: function (ratio) {\n\t\tvar hsl = this.hsl();\n\t\thsl.color[1] += hsl.color[1] * ratio;\n\t\treturn hsl;\n\t},\n\n\tdesaturate: function (ratio) {\n\t\tvar hsl = this.hsl();\n\t\thsl.color[1] -= hsl.color[1] * ratio;\n\t\treturn hsl;\n\t},\n\n\twhiten: function (ratio) {\n\t\tvar hwb = this.hwb();\n\t\thwb.color[1] += hwb.color[1] * ratio;\n\t\treturn hwb;\n\t},\n\n\tblacken: function (ratio) {\n\t\tvar hwb = this.hwb();\n\t\thwb.color[2] += hwb.color[2] * ratio;\n\t\treturn hwb;\n\t},\n\n\tgrayscale: function () {\n\t\t// http://en.wikipedia.org/wiki/Grayscale#Converting_color_to_grayscale\n\t\tvar rgb = this.rgb().color;\n\t\tvar val = rgb[0] * 0.3 + rgb[1] * 0.59 + rgb[2] * 0.11;\n\t\treturn Color.rgb(val, val, val);\n\t},\n\n\tfade: function (ratio) {\n\t\treturn this.alpha(this.valpha - (this.valpha * ratio));\n\t},\n\n\topaquer: function (ratio) {\n\t\treturn this.alpha(this.valpha + (this.valpha * ratio));\n\t},\n\n\trotate: function (degrees) {\n\t\tvar hsl = this.hsl();\n\t\tvar hue = hsl.color[0];\n\t\thue = (hue + degrees) % 360;\n\t\thue = hue < 0 ? 360 + hue : hue;\n\t\thsl.color[0] = hue;\n\t\treturn hsl;\n\t},\n\n\tmix: function (mixinColor, weight) {\n\t\t// ported from sass implementation in C\n\t\t// https://github.com/sass/libsass/blob/0e6b4a2850092356aa3ece07c6b249f0221caced/functions.cpp#L209\n\t\tif (!mixinColor || !mixinColor.rgb) {\n\t\t\tthrow new Error('Argument to \"mix\" was not a Color instance, but rather an instance of ' + typeof mixinColor);\n\t\t}\n\t\tvar color1 = mixinColor.rgb();\n\t\tvar color2 = this.rgb();\n\t\tvar p = weight === undefined ? 0.5 : weight;\n\n\t\tvar w = 2 * p - 1;\n\t\tvar a = color1.alpha() - color2.alpha();\n\n\t\tvar w1 = (((w * a === -1) ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n\t\tvar w2 = 1 - w1;\n\n\t\treturn Color.rgb(\n\t\t\t\tw1 * color1.red() + w2 * color2.red(),\n\t\t\t\tw1 * color1.green() + w2 * color2.green(),\n\t\t\t\tw1 * color1.blue() + w2 * color2.blue(),\n\t\t\t\tcolor1.alpha() * p + color2.alpha() * (1 - p));\n\t}\n};\n\n// model conversion methods and static constructors\nObject.keys(convert).forEach(function (model) {\n\tif (skippedModels.indexOf(model) !== -1) {\n\t\treturn;\n\t}\n\n\tvar channels = convert[model].channels;\n\n\t// conversion methods\n\tColor.prototype[model] = function () {\n\t\tif (this.model === model) {\n\t\t\treturn new Color(this);\n\t\t}\n\n\t\tif (arguments.length) {\n\t\t\treturn new Color(arguments, model);\n\t\t}\n\n\t\tvar newAlpha = typeof arguments[channels] === 'number' ? channels : this.valpha;\n\t\treturn new Color(assertArray(convert[this.model][model].raw(this.color)).concat(newAlpha), model);\n\t};\n\n\t// 'static' construction methods\n\tColor[model] = function (color) {\n\t\tif (typeof color === 'number') {\n\t\t\tcolor = zeroArray(_slice.call(arguments), channels);\n\t\t}\n\t\treturn new Color(color, model);\n\t};\n});\n\nfunction roundTo(num, places) {\n\treturn Number(num.toFixed(places));\n}\n\nfunction roundToPlace(places) {\n\treturn function (num) {\n\t\treturn roundTo(num, places);\n\t};\n}\n\nfunction getset(model, channel, modifier) {\n\tmodel = Array.isArray(model) ? model : [model];\n\n\tmodel.forEach(function (m) {\n\t\t(limiters[m] || (limiters[m] = []))[channel] = modifier;\n\t});\n\n\tmodel = model[0];\n\n\treturn function (val) {\n\t\tvar result;\n\n\t\tif (arguments.length) {\n\t\t\tif (modifier) {\n\t\t\t\tval = modifier(val);\n\t\t\t}\n\n\t\t\tresult = this[model]();\n\t\t\tresult.color[channel] = val;\n\t\t\treturn result;\n\t\t}\n\n\t\tresult = this[model]().color[channel];\n\t\tif (modifier) {\n\t\t\tresult = modifier(result);\n\t\t}\n\n\t\treturn result;\n\t};\n}\n\nfunction maxfn(max) {\n\treturn function (v) {\n\t\treturn Math.max(0, Math.min(max, v));\n\t};\n}\n\nfunction assertArray(val) {\n\treturn Array.isArray(val) ? val : [val];\n}\n\nfunction zeroArray(arr, length) {\n\tfor (var i = 0; i < length; i++) {\n\t\tif (typeof arr[i] !== 'number') {\n\t\t\tarr[i] = 0;\n\t\t}\n\t}\n\n\treturn arr;\n}\n\nmodule.exports = Color;\n","/* MIT license */\nvar colorNames = require('color-name');\nvar swizzle = require('simple-swizzle');\nvar hasOwnProperty = Object.hasOwnProperty;\n\nvar reverseNames = Object.create(null);\n\n// create a list of reverse color names\nfor (var name in colorNames) {\n\tif (hasOwnProperty.call(colorNames, name)) {\n\t\treverseNames[colorNames[name]] = name;\n\t}\n}\n\nvar cs = module.exports = {\n\tto: {},\n\tget: {}\n};\n\ncs.get = function (string) {\n\tvar prefix = string.substring(0, 3).toLowerCase();\n\tvar val;\n\tvar model;\n\tswitch (prefix) {\n\t\tcase 'hsl':\n\t\t\tval = cs.get.hsl(string);\n\t\t\tmodel = 'hsl';\n\t\t\tbreak;\n\t\tcase 'hwb':\n\t\t\tval = cs.get.hwb(string);\n\t\t\tmodel = 'hwb';\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tval = cs.get.rgb(string);\n\t\t\tmodel = 'rgb';\n\t\t\tbreak;\n\t}\n\n\tif (!val) {\n\t\treturn null;\n\t}\n\n\treturn {model: model, value: val};\n};\n\ncs.get.rgb = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar abbr = /^#([a-f0-9]{3,4})$/i;\n\tvar hex = /^#([a-f0-9]{6})([a-f0-9]{2})?$/i;\n\tvar rgba = /^rgba?\\(\\s*([+-]?\\d+)(?=[\\s,])\\s*(?:,\\s*)?([+-]?\\d+)(?=[\\s,])\\s*(?:,\\s*)?([+-]?\\d+)\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)(%?)\\s*)?\\)$/;\n\tvar per = /^rgba?\\(\\s*([+-]?[\\d\\.]+)\\%\\s*,?\\s*([+-]?[\\d\\.]+)\\%\\s*,?\\s*([+-]?[\\d\\.]+)\\%\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)(%?)\\s*)?\\)$/;\n\tvar keyword = /^(\\w+)$/;\n\n\tvar rgb = [0, 0, 0, 1];\n\tvar match;\n\tvar i;\n\tvar hexAlpha;\n\n\tif (match = string.match(hex)) {\n\t\thexAlpha = match[2];\n\t\tmatch = match[1];\n\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\t// https://jsperf.com/slice-vs-substr-vs-substring-methods-long-string/19\n\t\t\tvar i2 = i * 2;\n\t\t\trgb[i] = parseInt(match.slice(i2, i2 + 2), 16);\n\t\t}\n\n\t\tif (hexAlpha) {\n\t\t\trgb[3] = parseInt(hexAlpha, 16) / 255;\n\t\t}\n\t} else if (match = string.match(abbr)) {\n\t\tmatch = match[1];\n\t\thexAlpha = match[3];\n\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = parseInt(match[i] + match[i], 16);\n\t\t}\n\n\t\tif (hexAlpha) {\n\t\t\trgb[3] = parseInt(hexAlpha + hexAlpha, 16) / 255;\n\t\t}\n\t} else if (match = string.match(rgba)) {\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = parseInt(match[i + 1], 0);\n\t\t}\n\n\t\tif (match[4]) {\n\t\t\tif (match[5]) {\n\t\t\t\trgb[3] = parseFloat(match[4]) * 0.01;\n\t\t\t} else {\n\t\t\t\trgb[3] = parseFloat(match[4]);\n\t\t\t}\n\t\t}\n\t} else if (match = string.match(per)) {\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = Math.round(parseFloat(match[i + 1]) * 2.55);\n\t\t}\n\n\t\tif (match[4]) {\n\t\t\tif (match[5]) {\n\t\t\t\trgb[3] = parseFloat(match[4]) * 0.01;\n\t\t\t} else {\n\t\t\t\trgb[3] = parseFloat(match[4]);\n\t\t\t}\n\t\t}\n\t} else if (match = string.match(keyword)) {\n\t\tif (match[1] === 'transparent') {\n\t\t\treturn [0, 0, 0, 0];\n\t\t}\n\n\t\tif (!hasOwnProperty.call(colorNames, match[1])) {\n\t\t\treturn null;\n\t\t}\n\n\t\trgb = colorNames[match[1]];\n\t\trgb[3] = 1;\n\n\t\treturn rgb;\n\t} else {\n\t\treturn null;\n\t}\n\n\tfor (i = 0; i < 3; i++) {\n\t\trgb[i] = clamp(rgb[i], 0, 255);\n\t}\n\trgb[3] = clamp(rgb[3], 0, 1);\n\n\treturn rgb;\n};\n\ncs.get.hsl = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar hsl = /^hsla?\\(\\s*([+-]?(?:\\d{0,3}\\.)?\\d+)(?:deg)?\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*(?:[,|\\/]\\s*([+-]?(?=\\.\\d|\\d)(?:0|[1-9]\\d*)?(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)\\s*)?\\)$/;\n\tvar match = string.match(hsl);\n\n\tif (match) {\n\t\tvar alpha = parseFloat(match[4]);\n\t\tvar h = ((parseFloat(match[1]) % 360) + 360) % 360;\n\t\tvar s = clamp(parseFloat(match[2]), 0, 100);\n\t\tvar l = clamp(parseFloat(match[3]), 0, 100);\n\t\tvar a = clamp(isNaN(alpha) ? 1 : alpha, 0, 1);\n\n\t\treturn [h, s, l, a];\n\t}\n\n\treturn null;\n};\n\ncs.get.hwb = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar hwb = /^hwb\\(\\s*([+-]?\\d{0,3}(?:\\.\\d+)?)(?:deg)?\\s*,\\s*([+-]?[\\d\\.]+)%\\s*,\\s*([+-]?[\\d\\.]+)%\\s*(?:,\\s*([+-]?(?=\\.\\d|\\d)(?:0|[1-9]\\d*)?(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)\\s*)?\\)$/;\n\tvar match = string.match(hwb);\n\n\tif (match) {\n\t\tvar alpha = parseFloat(match[4]);\n\t\tvar h = ((parseFloat(match[1]) % 360) + 360) % 360;\n\t\tvar w = clamp(parseFloat(match[2]), 0, 100);\n\t\tvar b = clamp(parseFloat(match[3]), 0, 100);\n\t\tvar a = clamp(isNaN(alpha) ? 1 : alpha, 0, 1);\n\t\treturn [h, w, b, a];\n\t}\n\n\treturn null;\n};\n\ncs.to.hex = function () {\n\tvar rgba = swizzle(arguments);\n\n\treturn (\n\t\t'#' +\n\t\thexDouble(rgba[0]) +\n\t\thexDouble(rgba[1]) +\n\t\thexDouble(rgba[2]) +\n\t\t(rgba[3] < 1\n\t\t\t? (hexDouble(Math.round(rgba[3] * 255)))\n\t\t\t: '')\n\t);\n};\n\ncs.to.rgb = function () {\n\tvar rgba = swizzle(arguments);\n\n\treturn rgba.length < 4 || rgba[3] === 1\n\t\t? 'rgb(' + Math.round(rgba[0]) + ', ' + Math.round(rgba[1]) + ', ' + Math.round(rgba[2]) + ')'\n\t\t: 'rgba(' + Math.round(rgba[0]) + ', ' + Math.round(rgba[1]) + ', ' + Math.round(rgba[2]) + ', ' + rgba[3] + ')';\n};\n\ncs.to.rgb.percent = function () {\n\tvar rgba = swizzle(arguments);\n\n\tvar r = Math.round(rgba[0] / 255 * 100);\n\tvar g = Math.round(rgba[1] / 255 * 100);\n\tvar b = Math.round(rgba[2] / 255 * 100);\n\n\treturn rgba.length < 4 || rgba[3] === 1\n\t\t? 'rgb(' + r + '%, ' + g + '%, ' + b + '%)'\n\t\t: 'rgba(' + r + '%, ' + g + '%, ' + b + '%, ' + rgba[3] + ')';\n};\n\ncs.to.hsl = function () {\n\tvar hsla = swizzle(arguments);\n\treturn hsla.length < 4 || hsla[3] === 1\n\t\t? 'hsl(' + hsla[0] + ', ' + hsla[1] + '%, ' + hsla[2] + '%)'\n\t\t: 'hsla(' + hsla[0] + ', ' + hsla[1] + '%, ' + hsla[2] + '%, ' + hsla[3] + ')';\n};\n\n// hwb is a bit different than rgb(a) & hsl(a) since there is no alpha specific syntax\n// (hwb have alpha optional & 1 is default value)\ncs.to.hwb = function () {\n\tvar hwba = swizzle(arguments);\n\n\tvar a = '';\n\tif (hwba.length >= 4 && hwba[3] !== 1) {\n\t\ta = ', ' + hwba[3];\n\t}\n\n\treturn 'hwb(' + hwba[0] + ', ' + hwba[1] + '%, ' + hwba[2] + '%' + a + ')';\n};\n\ncs.to.keyword = function (rgb) {\n\treturn reverseNames[rgb.slice(0, 3)];\n};\n\n// helpers\nfunction clamp(num, min, max) {\n\treturn Math.min(Math.max(min, num), max);\n}\n\nfunction hexDouble(num) {\n\tvar str = Math.round(num).toString(16).toUpperCase();\n\treturn (str.length < 2) ? '0' + str : str;\n}\n","'use strict'\r\n\r\nmodule.exports = {\r\n\t\"aliceblue\": [240, 248, 255],\r\n\t\"antiquewhite\": [250, 235, 215],\r\n\t\"aqua\": [0, 255, 255],\r\n\t\"aquamarine\": [127, 255, 212],\r\n\t\"azure\": [240, 255, 255],\r\n\t\"beige\": [245, 245, 220],\r\n\t\"bisque\": [255, 228, 196],\r\n\t\"black\": [0, 0, 0],\r\n\t\"blanchedalmond\": [255, 235, 205],\r\n\t\"blue\": [0, 0, 255],\r\n\t\"blueviolet\": [138, 43, 226],\r\n\t\"brown\": [165, 42, 42],\r\n\t\"burlywood\": [222, 184, 135],\r\n\t\"cadetblue\": [95, 158, 160],\r\n\t\"chartreuse\": [127, 255, 0],\r\n\t\"chocolate\": [210, 105, 30],\r\n\t\"coral\": [255, 127, 80],\r\n\t\"cornflowerblue\": [100, 149, 237],\r\n\t\"cornsilk\": [255, 248, 220],\r\n\t\"crimson\": [220, 20, 60],\r\n\t\"cyan\": [0, 255, 255],\r\n\t\"darkblue\": [0, 0, 139],\r\n\t\"darkcyan\": [0, 139, 139],\r\n\t\"darkgoldenrod\": [184, 134, 11],\r\n\t\"darkgray\": [169, 169, 169],\r\n\t\"darkgreen\": [0, 100, 0],\r\n\t\"darkgrey\": [169, 169, 169],\r\n\t\"darkkhaki\": [189, 183, 107],\r\n\t\"darkmagenta\": [139, 0, 139],\r\n\t\"darkolivegreen\": [85, 107, 47],\r\n\t\"darkorange\": [255, 140, 0],\r\n\t\"darkorchid\": [153, 50, 204],\r\n\t\"darkred\": [139, 0, 0],\r\n\t\"darksalmon\": [233, 150, 122],\r\n\t\"darkseagreen\": [143, 188, 143],\r\n\t\"darkslateblue\": [72, 61, 139],\r\n\t\"darkslategray\": [47, 79, 79],\r\n\t\"darkslategrey\": [47, 79, 79],\r\n\t\"darkturquoise\": [0, 206, 209],\r\n\t\"darkviolet\": [148, 0, 211],\r\n\t\"deeppink\": [255, 20, 147],\r\n\t\"deepskyblue\": [0, 191, 255],\r\n\t\"dimgray\": [105, 105, 105],\r\n\t\"dimgrey\": [105, 105, 105],\r\n\t\"dodgerblue\": [30, 144, 255],\r\n\t\"firebrick\": [178, 34, 34],\r\n\t\"floralwhite\": [255, 250, 240],\r\n\t\"forestgreen\": [34, 139, 34],\r\n\t\"fuchsia\": [255, 0, 255],\r\n\t\"gainsboro\": [220, 220, 220],\r\n\t\"ghostwhite\": [248, 248, 255],\r\n\t\"gold\": [255, 215, 0],\r\n\t\"goldenrod\": [218, 165, 32],\r\n\t\"gray\": [128, 128, 128],\r\n\t\"green\": [0, 128, 0],\r\n\t\"greenyellow\": [173, 255, 47],\r\n\t\"grey\": [128, 128, 128],\r\n\t\"honeydew\": [240, 255, 240],\r\n\t\"hotpink\": [255, 105, 180],\r\n\t\"indianred\": [205, 92, 92],\r\n\t\"indigo\": [75, 0, 130],\r\n\t\"ivory\": [255, 255, 240],\r\n\t\"khaki\": [240, 230, 140],\r\n\t\"lavender\": [230, 230, 250],\r\n\t\"lavenderblush\": [255, 240, 245],\r\n\t\"lawngreen\": [124, 252, 0],\r\n\t\"lemonchiffon\": [255, 250, 205],\r\n\t\"lightblue\": [173, 216, 230],\r\n\t\"lightcoral\": [240, 128, 128],\r\n\t\"lightcyan\": [224, 255, 255],\r\n\t\"lightgoldenrodyellow\": [250, 250, 210],\r\n\t\"lightgray\": [211, 211, 211],\r\n\t\"lightgreen\": [144, 238, 144],\r\n\t\"lightgrey\": [211, 211, 211],\r\n\t\"lightpink\": [255, 182, 193],\r\n\t\"lightsalmon\": [255, 160, 122],\r\n\t\"lightseagreen\": [32, 178, 170],\r\n\t\"lightskyblue\": [135, 206, 250],\r\n\t\"lightslategray\": [119, 136, 153],\r\n\t\"lightslategrey\": [119, 136, 153],\r\n\t\"lightsteelblue\": [176, 196, 222],\r\n\t\"lightyellow\": [255, 255, 224],\r\n\t\"lime\": [0, 255, 0],\r\n\t\"limegreen\": [50, 205, 50],\r\n\t\"linen\": [250, 240, 230],\r\n\t\"magenta\": [255, 0, 255],\r\n\t\"maroon\": [128, 0, 0],\r\n\t\"mediumaquamarine\": [102, 205, 170],\r\n\t\"mediumblue\": [0, 0, 205],\r\n\t\"mediumorchid\": [186, 85, 211],\r\n\t\"mediumpurple\": [147, 112, 219],\r\n\t\"mediumseagreen\": [60, 179, 113],\r\n\t\"mediumslateblue\": [123, 104, 238],\r\n\t\"mediumspringgreen\": [0, 250, 154],\r\n\t\"mediumturquoise\": [72, 209, 204],\r\n\t\"mediumvioletred\": [199, 21, 133],\r\n\t\"midnightblue\": [25, 25, 112],\r\n\t\"mintcream\": [245, 255, 250],\r\n\t\"mistyrose\": [255, 228, 225],\r\n\t\"moccasin\": [255, 228, 181],\r\n\t\"navajowhite\": [255, 222, 173],\r\n\t\"navy\": [0, 0, 128],\r\n\t\"oldlace\": [253, 245, 230],\r\n\t\"olive\": [128, 128, 0],\r\n\t\"olivedrab\": [107, 142, 35],\r\n\t\"orange\": [255, 165, 0],\r\n\t\"orangered\": [255, 69, 0],\r\n\t\"orchid\": [218, 112, 214],\r\n\t\"palegoldenrod\": [238, 232, 170],\r\n\t\"palegreen\": [152, 251, 152],\r\n\t\"paleturquoise\": [175, 238, 238],\r\n\t\"palevioletred\": [219, 112, 147],\r\n\t\"papayawhip\": [255, 239, 213],\r\n\t\"peachpuff\": [255, 218, 185],\r\n\t\"peru\": [205, 133, 63],\r\n\t\"pink\": [255, 192, 203],\r\n\t\"plum\": [221, 160, 221],\r\n\t\"powderblue\": [176, 224, 230],\r\n\t\"purple\": [128, 0, 128],\r\n\t\"rebeccapurple\": [102, 51, 153],\r\n\t\"red\": [255, 0, 0],\r\n\t\"rosybrown\": [188, 143, 143],\r\n\t\"royalblue\": [65, 105, 225],\r\n\t\"saddlebrown\": [139, 69, 19],\r\n\t\"salmon\": [250, 128, 114],\r\n\t\"sandybrown\": [244, 164, 96],\r\n\t\"seagreen\": [46, 139, 87],\r\n\t\"seashell\": [255, 245, 238],\r\n\t\"sienna\": [160, 82, 45],\r\n\t\"silver\": [192, 192, 192],\r\n\t\"skyblue\": [135, 206, 235],\r\n\t\"slateblue\": [106, 90, 205],\r\n\t\"slategray\": [112, 128, 144],\r\n\t\"slategrey\": [112, 128, 144],\r\n\t\"snow\": [255, 250, 250],\r\n\t\"springgreen\": [0, 255, 127],\r\n\t\"steelblue\": [70, 130, 180],\r\n\t\"tan\": [210, 180, 140],\r\n\t\"teal\": [0, 128, 128],\r\n\t\"thistle\": [216, 191, 216],\r\n\t\"tomato\": [255, 99, 71],\r\n\t\"turquoise\": [64, 224, 208],\r\n\t\"violet\": [238, 130, 238],\r\n\t\"wheat\": [245, 222, 179],\r\n\t\"white\": [255, 255, 255],\r\n\t\"whitesmoke\": [245, 245, 245],\r\n\t\"yellow\": [255, 255, 0],\r\n\t\"yellowgreen\": [154, 205, 50]\r\n};\r\n","'use strict';\n\nvar isArrayish = require('is-arrayish');\n\nvar concat = Array.prototype.concat;\nvar slice = Array.prototype.slice;\n\nvar swizzle = module.exports = function swizzle(args) {\n\tvar results = [];\n\n\tfor (var i = 0, len = args.length; i < len; i++) {\n\t\tvar arg = args[i];\n\n\t\tif (isArrayish(arg)) {\n\t\t\t// http://jsperf.com/javascript-array-concat-vs-push/98\n\t\t\tresults = concat.call(results, slice.call(arg));\n\t\t} else {\n\t\t\tresults.push(arg);\n\t\t}\n\t}\n\n\treturn results;\n};\n\nswizzle.wrap = function (fn) {\n\treturn function () {\n\t\treturn fn(swizzle(arguments));\n\t};\n};\n","module.exports = function isArrayish(obj) {\n\tif (!obj || typeof obj === 'string') {\n\t\treturn false;\n\t}\n\n\treturn obj instanceof Array || Array.isArray(obj) ||\n\t\t(obj.length >= 0 && (obj.splice instanceof Function ||\n\t\t\t(Object.getOwnPropertyDescriptor(obj, (obj.length - 1)) && obj.constructor.name !== 'String')));\n};\n","var conversions = require('./conversions');\nvar route = require('./route');\n\nvar convert = {};\n\nvar models = Object.keys(conversions);\n\nfunction wrapRaw(fn) {\n\tvar wrappedFn = function (args) {\n\t\tif (args === undefined || args === null) {\n\t\t\treturn args;\n\t\t}\n\n\t\tif (arguments.length > 1) {\n\t\t\targs = Array.prototype.slice.call(arguments);\n\t\t}\n\n\t\treturn fn(args);\n\t};\n\n\t// preserve .conversion property if there is one\n\tif ('conversion' in fn) {\n\t\twrappedFn.conversion = fn.conversion;\n\t}\n\n\treturn wrappedFn;\n}\n\nfunction wrapRounded(fn) {\n\tvar wrappedFn = function (args) {\n\t\tif (args === undefined || args === null) {\n\t\t\treturn args;\n\t\t}\n\n\t\tif (arguments.length > 1) {\n\t\t\targs = Array.prototype.slice.call(arguments);\n\t\t}\n\n\t\tvar result = fn(args);\n\n\t\t// we're assuming the result is an array here.\n\t\t// see notice in conversions.js; don't use box types\n\t\t// in conversion functions.\n\t\tif (typeof result === 'object') {\n\t\t\tfor (var len = result.length, i = 0; i < len; i++) {\n\t\t\t\tresult[i] = Math.round(result[i]);\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t};\n\n\t// preserve .conversion property if there is one\n\tif ('conversion' in fn) {\n\t\twrappedFn.conversion = fn.conversion;\n\t}\n\n\treturn wrappedFn;\n}\n\nmodels.forEach(function (fromModel) {\n\tconvert[fromModel] = {};\n\n\tObject.defineProperty(convert[fromModel], 'channels', {value: conversions[fromModel].channels});\n\tObject.defineProperty(convert[fromModel], 'labels', {value: conversions[fromModel].labels});\n\n\tvar routes = route(fromModel);\n\tvar routeModels = Object.keys(routes);\n\n\trouteModels.forEach(function (toModel) {\n\t\tvar fn = routes[toModel];\n\n\t\tconvert[fromModel][toModel] = wrapRounded(fn);\n\t\tconvert[fromModel][toModel].raw = wrapRaw(fn);\n\t});\n});\n\nmodule.exports = convert;\n","/* MIT license */\nvar cssKeywords = require('color-name');\n\n// NOTE: conversions should only return primitive values (i.e. arrays, or\n// values that give correct `typeof` results).\n// do not use box values types (i.e. Number(), String(), etc.)\n\nvar reverseKeywords = {};\nfor (var key in cssKeywords) {\n\tif (cssKeywords.hasOwnProperty(key)) {\n\t\treverseKeywords[cssKeywords[key]] = key;\n\t}\n}\n\nvar convert = module.exports = {\n\trgb: {channels: 3, labels: 'rgb'},\n\thsl: {channels: 3, labels: 'hsl'},\n\thsv: {channels: 3, labels: 'hsv'},\n\thwb: {channels: 3, labels: 'hwb'},\n\tcmyk: {channels: 4, labels: 'cmyk'},\n\txyz: {channels: 3, labels: 'xyz'},\n\tlab: {channels: 3, labels: 'lab'},\n\tlch: {channels: 3, labels: 'lch'},\n\thex: {channels: 1, labels: ['hex']},\n\tkeyword: {channels: 1, labels: ['keyword']},\n\tansi16: {channels: 1, labels: ['ansi16']},\n\tansi256: {channels: 1, labels: ['ansi256']},\n\thcg: {channels: 3, labels: ['h', 'c', 'g']},\n\tapple: {channels: 3, labels: ['r16', 'g16', 'b16']},\n\tgray: {channels: 1, labels: ['gray']}\n};\n\n// hide .channels and .labels properties\nfor (var model in convert) {\n\tif (convert.hasOwnProperty(model)) {\n\t\tif (!('channels' in convert[model])) {\n\t\t\tthrow new Error('missing channels property: ' + model);\n\t\t}\n\n\t\tif (!('labels' in convert[model])) {\n\t\t\tthrow new Error('missing channel labels property: ' + model);\n\t\t}\n\n\t\tif (convert[model].labels.length !== convert[model].channels) {\n\t\t\tthrow new Error('channel and label counts mismatch: ' + model);\n\t\t}\n\n\t\tvar channels = convert[model].channels;\n\t\tvar labels = convert[model].labels;\n\t\tdelete convert[model].channels;\n\t\tdelete convert[model].labels;\n\t\tObject.defineProperty(convert[model], 'channels', {value: channels});\n\t\tObject.defineProperty(convert[model], 'labels', {value: labels});\n\t}\n}\n\nconvert.rgb.hsl = function (rgb) {\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\tvar min = Math.min(r, g, b);\n\tvar max = Math.max(r, g, b);\n\tvar delta = max - min;\n\tvar h;\n\tvar s;\n\tvar l;\n\n\tif (max === min) {\n\t\th = 0;\n\t} else if (r === max) {\n\t\th = (g - b) / delta;\n\t} else if (g === max) {\n\t\th = 2 + (b - r) / delta;\n\t} else if (b === max) {\n\t\th = 4 + (r - g) / delta;\n\t}\n\n\th = Math.min(h * 60, 360);\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tl = (min + max) / 2;\n\n\tif (max === min) {\n\t\ts = 0;\n\t} else if (l <= 0.5) {\n\t\ts = delta / (max + min);\n\t} else {\n\t\ts = delta / (2 - max - min);\n\t}\n\n\treturn [h, s * 100, l * 100];\n};\n\nconvert.rgb.hsv = function (rgb) {\n\tvar rdif;\n\tvar gdif;\n\tvar bdif;\n\tvar h;\n\tvar s;\n\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\tvar v = Math.max(r, g, b);\n\tvar diff = v - Math.min(r, g, b);\n\tvar diffc = function (c) {\n\t\treturn (v - c) / 6 / diff + 1 / 2;\n\t};\n\n\tif (diff === 0) {\n\t\th = s = 0;\n\t} else {\n\t\ts = diff / v;\n\t\trdif = diffc(r);\n\t\tgdif = diffc(g);\n\t\tbdif = diffc(b);\n\n\t\tif (r === v) {\n\t\t\th = bdif - gdif;\n\t\t} else if (g === v) {\n\t\t\th = (1 / 3) + rdif - bdif;\n\t\t} else if (b === v) {\n\t\t\th = (2 / 3) + gdif - rdif;\n\t\t}\n\t\tif (h < 0) {\n\t\t\th += 1;\n\t\t} else if (h > 1) {\n\t\t\th -= 1;\n\t\t}\n\t}\n\n\treturn [\n\t\th * 360,\n\t\ts * 100,\n\t\tv * 100\n\t];\n};\n\nconvert.rgb.hwb = function (rgb) {\n\tvar r = rgb[0];\n\tvar g = rgb[1];\n\tvar b = rgb[2];\n\tvar h = convert.rgb.hsl(rgb)[0];\n\tvar w = 1 / 255 * Math.min(r, Math.min(g, b));\n\n\tb = 1 - 1 / 255 * Math.max(r, Math.max(g, b));\n\n\treturn [h, w * 100, b * 100];\n};\n\nconvert.rgb.cmyk = function (rgb) {\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\tvar c;\n\tvar m;\n\tvar y;\n\tvar k;\n\n\tk = Math.min(1 - r, 1 - g, 1 - b);\n\tc = (1 - r - k) / (1 - k) || 0;\n\tm = (1 - g - k) / (1 - k) || 0;\n\ty = (1 - b - k) / (1 - k) || 0;\n\n\treturn [c * 100, m * 100, y * 100, k * 100];\n};\n\n/**\n * See https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance\n * */\nfunction comparativeDistance(x, y) {\n\treturn (\n\t\tMath.pow(x[0] - y[0], 2) +\n\t\tMath.pow(x[1] - y[1], 2) +\n\t\tMath.pow(x[2] - y[2], 2)\n\t);\n}\n\nconvert.rgb.keyword = function (rgb) {\n\tvar reversed = reverseKeywords[rgb];\n\tif (reversed) {\n\t\treturn reversed;\n\t}\n\n\tvar currentClosestDistance = Infinity;\n\tvar currentClosestKeyword;\n\n\tfor (var keyword in cssKeywords) {\n\t\tif (cssKeywords.hasOwnProperty(keyword)) {\n\t\t\tvar value = cssKeywords[keyword];\n\n\t\t\t// Compute comparative distance\n\t\t\tvar distance = comparativeDistance(rgb, value);\n\n\t\t\t// Check if its less, if so set as closest\n\t\t\tif (distance < currentClosestDistance) {\n\t\t\t\tcurrentClosestDistance = distance;\n\t\t\t\tcurrentClosestKeyword = keyword;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn currentClosestKeyword;\n};\n\nconvert.keyword.rgb = function (keyword) {\n\treturn cssKeywords[keyword];\n};\n\nconvert.rgb.xyz = function (rgb) {\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\n\t// assume sRGB\n\tr = r > 0.04045 ? Math.pow(((r + 0.055) / 1.055), 2.4) : (r / 12.92);\n\tg = g > 0.04045 ? Math.pow(((g + 0.055) / 1.055), 2.4) : (g / 12.92);\n\tb = b > 0.04045 ? Math.pow(((b + 0.055) / 1.055), 2.4) : (b / 12.92);\n\n\tvar x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805);\n\tvar y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722);\n\tvar z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505);\n\n\treturn [x * 100, y * 100, z * 100];\n};\n\nconvert.rgb.lab = function (rgb) {\n\tvar xyz = convert.rgb.xyz(rgb);\n\tvar x = xyz[0];\n\tvar y = xyz[1];\n\tvar z = xyz[2];\n\tvar l;\n\tvar a;\n\tvar b;\n\n\tx /= 95.047;\n\ty /= 100;\n\tz /= 108.883;\n\n\tx = x > 0.008856 ? Math.pow(x, 1 / 3) : (7.787 * x) + (16 / 116);\n\ty = y > 0.008856 ? Math.pow(y, 1 / 3) : (7.787 * y) + (16 / 116);\n\tz = z > 0.008856 ? Math.pow(z, 1 / 3) : (7.787 * z) + (16 / 116);\n\n\tl = (116 * y) - 16;\n\ta = 500 * (x - y);\n\tb = 200 * (y - z);\n\n\treturn [l, a, b];\n};\n\nconvert.hsl.rgb = function (hsl) {\n\tvar h = hsl[0] / 360;\n\tvar s = hsl[1] / 100;\n\tvar l = hsl[2] / 100;\n\tvar t1;\n\tvar t2;\n\tvar t3;\n\tvar rgb;\n\tvar val;\n\n\tif (s === 0) {\n\t\tval = l * 255;\n\t\treturn [val, val, val];\n\t}\n\n\tif (l < 0.5) {\n\t\tt2 = l * (1 + s);\n\t} else {\n\t\tt2 = l + s - l * s;\n\t}\n\n\tt1 = 2 * l - t2;\n\n\trgb = [0, 0, 0];\n\tfor (var i = 0; i < 3; i++) {\n\t\tt3 = h + 1 / 3 * -(i - 1);\n\t\tif (t3 < 0) {\n\t\t\tt3++;\n\t\t}\n\t\tif (t3 > 1) {\n\t\t\tt3--;\n\t\t}\n\n\t\tif (6 * t3 < 1) {\n\t\t\tval = t1 + (t2 - t1) * 6 * t3;\n\t\t} else if (2 * t3 < 1) {\n\t\t\tval = t2;\n\t\t} else if (3 * t3 < 2) {\n\t\t\tval = t1 + (t2 - t1) * (2 / 3 - t3) * 6;\n\t\t} else {\n\t\t\tval = t1;\n\t\t}\n\n\t\trgb[i] = val * 255;\n\t}\n\n\treturn rgb;\n};\n\nconvert.hsl.hsv = function (hsl) {\n\tvar h = hsl[0];\n\tvar s = hsl[1] / 100;\n\tvar l = hsl[2] / 100;\n\tvar smin = s;\n\tvar lmin = Math.max(l, 0.01);\n\tvar sv;\n\tvar v;\n\n\tl *= 2;\n\ts *= (l <= 1) ? l : 2 - l;\n\tsmin *= lmin <= 1 ? lmin : 2 - lmin;\n\tv = (l + s) / 2;\n\tsv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s);\n\n\treturn [h, sv * 100, v * 100];\n};\n\nconvert.hsv.rgb = function (hsv) {\n\tvar h = hsv[0] / 60;\n\tvar s = hsv[1] / 100;\n\tvar v = hsv[2] / 100;\n\tvar hi = Math.floor(h) % 6;\n\n\tvar f = h - Math.floor(h);\n\tvar p = 255 * v * (1 - s);\n\tvar q = 255 * v * (1 - (s * f));\n\tvar t = 255 * v * (1 - (s * (1 - f)));\n\tv *= 255;\n\n\tswitch (hi) {\n\t\tcase 0:\n\t\t\treturn [v, t, p];\n\t\tcase 1:\n\t\t\treturn [q, v, p];\n\t\tcase 2:\n\t\t\treturn [p, v, t];\n\t\tcase 3:\n\t\t\treturn [p, q, v];\n\t\tcase 4:\n\t\t\treturn [t, p, v];\n\t\tcase 5:\n\t\t\treturn [v, p, q];\n\t}\n};\n\nconvert.hsv.hsl = function (hsv) {\n\tvar h = hsv[0];\n\tvar s = hsv[1] / 100;\n\tvar v = hsv[2] / 100;\n\tvar vmin = Math.max(v, 0.01);\n\tvar lmin;\n\tvar sl;\n\tvar l;\n\n\tl = (2 - s) * v;\n\tlmin = (2 - s) * vmin;\n\tsl = s * vmin;\n\tsl /= (lmin <= 1) ? lmin : 2 - lmin;\n\tsl = sl || 0;\n\tl /= 2;\n\n\treturn [h, sl * 100, l * 100];\n};\n\n// http://dev.w3.org/csswg/css-color/#hwb-to-rgb\nconvert.hwb.rgb = function (hwb) {\n\tvar h = hwb[0] / 360;\n\tvar wh = hwb[1] / 100;\n\tvar bl = hwb[2] / 100;\n\tvar ratio = wh + bl;\n\tvar i;\n\tvar v;\n\tvar f;\n\tvar n;\n\n\t// wh + bl cant be > 1\n\tif (ratio > 1) {\n\t\twh /= ratio;\n\t\tbl /= ratio;\n\t}\n\n\ti = Math.floor(6 * h);\n\tv = 1 - bl;\n\tf = 6 * h - i;\n\n\tif ((i & 0x01) !== 0) {\n\t\tf = 1 - f;\n\t}\n\n\tn = wh + f * (v - wh); // linear interpolation\n\n\tvar r;\n\tvar g;\n\tvar b;\n\tswitch (i) {\n\t\tdefault:\n\t\tcase 6:\n\t\tcase 0: r = v; g = n; b = wh; break;\n\t\tcase 1: r = n; g = v; b = wh; break;\n\t\tcase 2: r = wh; g = v; b = n; break;\n\t\tcase 3: r = wh; g = n; b = v; break;\n\t\tcase 4: r = n; g = wh; b = v; break;\n\t\tcase 5: r = v; g = wh; b = n; break;\n\t}\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.cmyk.rgb = function (cmyk) {\n\tvar c = cmyk[0] / 100;\n\tvar m = cmyk[1] / 100;\n\tvar y = cmyk[2] / 100;\n\tvar k = cmyk[3] / 100;\n\tvar r;\n\tvar g;\n\tvar b;\n\n\tr = 1 - Math.min(1, c * (1 - k) + k);\n\tg = 1 - Math.min(1, m * (1 - k) + k);\n\tb = 1 - Math.min(1, y * (1 - k) + k);\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.xyz.rgb = function (xyz) {\n\tvar x = xyz[0] / 100;\n\tvar y = xyz[1] / 100;\n\tvar z = xyz[2] / 100;\n\tvar r;\n\tvar g;\n\tvar b;\n\n\tr = (x * 3.2406) + (y * -1.5372) + (z * -0.4986);\n\tg = (x * -0.9689) + (y * 1.8758) + (z * 0.0415);\n\tb = (x * 0.0557) + (y * -0.2040) + (z * 1.0570);\n\n\t// assume sRGB\n\tr = r > 0.0031308\n\t\t? ((1.055 * Math.pow(r, 1.0 / 2.4)) - 0.055)\n\t\t: r * 12.92;\n\n\tg = g > 0.0031308\n\t\t? ((1.055 * Math.pow(g, 1.0 / 2.4)) - 0.055)\n\t\t: g * 12.92;\n\n\tb = b > 0.0031308\n\t\t? ((1.055 * Math.pow(b, 1.0 / 2.4)) - 0.055)\n\t\t: b * 12.92;\n\n\tr = Math.min(Math.max(0, r), 1);\n\tg = Math.min(Math.max(0, g), 1);\n\tb = Math.min(Math.max(0, b), 1);\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.xyz.lab = function (xyz) {\n\tvar x = xyz[0];\n\tvar y = xyz[1];\n\tvar z = xyz[2];\n\tvar l;\n\tvar a;\n\tvar b;\n\n\tx /= 95.047;\n\ty /= 100;\n\tz /= 108.883;\n\n\tx = x > 0.008856 ? Math.pow(x, 1 / 3) : (7.787 * x) + (16 / 116);\n\ty = y > 0.008856 ? Math.pow(y, 1 / 3) : (7.787 * y) + (16 / 116);\n\tz = z > 0.008856 ? Math.pow(z, 1 / 3) : (7.787 * z) + (16 / 116);\n\n\tl = (116 * y) - 16;\n\ta = 500 * (x - y);\n\tb = 200 * (y - z);\n\n\treturn [l, a, b];\n};\n\nconvert.lab.xyz = function (lab) {\n\tvar l = lab[0];\n\tvar a = lab[1];\n\tvar b = lab[2];\n\tvar x;\n\tvar y;\n\tvar z;\n\n\ty = (l + 16) / 116;\n\tx = a / 500 + y;\n\tz = y - b / 200;\n\n\tvar y2 = Math.pow(y, 3);\n\tvar x2 = Math.pow(x, 3);\n\tvar z2 = Math.pow(z, 3);\n\ty = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787;\n\tx = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787;\n\tz = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787;\n\n\tx *= 95.047;\n\ty *= 100;\n\tz *= 108.883;\n\n\treturn [x, y, z];\n};\n\nconvert.lab.lch = function (lab) {\n\tvar l = lab[0];\n\tvar a = lab[1];\n\tvar b = lab[2];\n\tvar hr;\n\tvar h;\n\tvar c;\n\n\thr = Math.atan2(b, a);\n\th = hr * 360 / 2 / Math.PI;\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tc = Math.sqrt(a * a + b * b);\n\n\treturn [l, c, h];\n};\n\nconvert.lch.lab = function (lch) {\n\tvar l = lch[0];\n\tvar c = lch[1];\n\tvar h = lch[2];\n\tvar a;\n\tvar b;\n\tvar hr;\n\n\thr = h / 360 * 2 * Math.PI;\n\ta = c * Math.cos(hr);\n\tb = c * Math.sin(hr);\n\n\treturn [l, a, b];\n};\n\nconvert.rgb.ansi16 = function (args) {\n\tvar r = args[0];\n\tvar g = args[1];\n\tvar b = args[2];\n\tvar value = 1 in arguments ? arguments[1] : convert.rgb.hsv(args)[2]; // hsv -> ansi16 optimization\n\n\tvalue = Math.round(value / 50);\n\n\tif (value === 0) {\n\t\treturn 30;\n\t}\n\n\tvar ansi = 30\n\t\t+ ((Math.round(b / 255) << 2)\n\t\t| (Math.round(g / 255) << 1)\n\t\t| Math.round(r / 255));\n\n\tif (value === 2) {\n\t\tansi += 60;\n\t}\n\n\treturn ansi;\n};\n\nconvert.hsv.ansi16 = function (args) {\n\t// optimization here; we already know the value and don't need to get\n\t// it converted for us.\n\treturn convert.rgb.ansi16(convert.hsv.rgb(args), args[2]);\n};\n\nconvert.rgb.ansi256 = function (args) {\n\tvar r = args[0];\n\tvar g = args[1];\n\tvar b = args[2];\n\n\t// we use the extended greyscale palette here, with the exception of\n\t// black and white. normal palette only has 4 greyscale shades.\n\tif (r === g && g === b) {\n\t\tif (r < 8) {\n\t\t\treturn 16;\n\t\t}\n\n\t\tif (r > 248) {\n\t\t\treturn 231;\n\t\t}\n\n\t\treturn Math.round(((r - 8) / 247) * 24) + 232;\n\t}\n\n\tvar ansi = 16\n\t\t+ (36 * Math.round(r / 255 * 5))\n\t\t+ (6 * Math.round(g / 255 * 5))\n\t\t+ Math.round(b / 255 * 5);\n\n\treturn ansi;\n};\n\nconvert.ansi16.rgb = function (args) {\n\tvar color = args % 10;\n\n\t// handle greyscale\n\tif (color === 0 || color === 7) {\n\t\tif (args > 50) {\n\t\t\tcolor += 3.5;\n\t\t}\n\n\t\tcolor = color / 10.5 * 255;\n\n\t\treturn [color, color, color];\n\t}\n\n\tvar mult = (~~(args > 50) + 1) * 0.5;\n\tvar r = ((color & 1) * mult) * 255;\n\tvar g = (((color >> 1) & 1) * mult) * 255;\n\tvar b = (((color >> 2) & 1) * mult) * 255;\n\n\treturn [r, g, b];\n};\n\nconvert.ansi256.rgb = function (args) {\n\t// handle greyscale\n\tif (args >= 232) {\n\t\tvar c = (args - 232) * 10 + 8;\n\t\treturn [c, c, c];\n\t}\n\n\targs -= 16;\n\n\tvar rem;\n\tvar r = Math.floor(args / 36) / 5 * 255;\n\tvar g = Math.floor((rem = args % 36) / 6) / 5 * 255;\n\tvar b = (rem % 6) / 5 * 255;\n\n\treturn [r, g, b];\n};\n\nconvert.rgb.hex = function (args) {\n\tvar integer = ((Math.round(args[0]) & 0xFF) << 16)\n\t\t+ ((Math.round(args[1]) & 0xFF) << 8)\n\t\t+ (Math.round(args[2]) & 0xFF);\n\n\tvar string = integer.toString(16).toUpperCase();\n\treturn '000000'.substring(string.length) + string;\n};\n\nconvert.hex.rgb = function (args) {\n\tvar match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);\n\tif (!match) {\n\t\treturn [0, 0, 0];\n\t}\n\n\tvar colorString = match[0];\n\n\tif (match[0].length === 3) {\n\t\tcolorString = colorString.split('').map(function (char) {\n\t\t\treturn char + char;\n\t\t}).join('');\n\t}\n\n\tvar integer = parseInt(colorString, 16);\n\tvar r = (integer >> 16) & 0xFF;\n\tvar g = (integer >> 8) & 0xFF;\n\tvar b = integer & 0xFF;\n\n\treturn [r, g, b];\n};\n\nconvert.rgb.hcg = function (rgb) {\n\tvar r = rgb[0] / 255;\n\tvar g = rgb[1] / 255;\n\tvar b = rgb[2] / 255;\n\tvar max = Math.max(Math.max(r, g), b);\n\tvar min = Math.min(Math.min(r, g), b);\n\tvar chroma = (max - min);\n\tvar grayscale;\n\tvar hue;\n\n\tif (chroma < 1) {\n\t\tgrayscale = min / (1 - chroma);\n\t} else {\n\t\tgrayscale = 0;\n\t}\n\n\tif (chroma <= 0) {\n\t\thue = 0;\n\t} else\n\tif (max === r) {\n\t\thue = ((g - b) / chroma) % 6;\n\t} else\n\tif (max === g) {\n\t\thue = 2 + (b - r) / chroma;\n\t} else {\n\t\thue = 4 + (r - g) / chroma + 4;\n\t}\n\n\thue /= 6;\n\thue %= 1;\n\n\treturn [hue * 360, chroma * 100, grayscale * 100];\n};\n\nconvert.hsl.hcg = function (hsl) {\n\tvar s = hsl[1] / 100;\n\tvar l = hsl[2] / 100;\n\tvar c = 1;\n\tvar f = 0;\n\n\tif (l < 0.5) {\n\t\tc = 2.0 * s * l;\n\t} else {\n\t\tc = 2.0 * s * (1.0 - l);\n\t}\n\n\tif (c < 1.0) {\n\t\tf = (l - 0.5 * c) / (1.0 - c);\n\t}\n\n\treturn [hsl[0], c * 100, f * 100];\n};\n\nconvert.hsv.hcg = function (hsv) {\n\tvar s = hsv[1] / 100;\n\tvar v = hsv[2] / 100;\n\n\tvar c = s * v;\n\tvar f = 0;\n\n\tif (c < 1.0) {\n\t\tf = (v - c) / (1 - c);\n\t}\n\n\treturn [hsv[0], c * 100, f * 100];\n};\n\nconvert.hcg.rgb = function (hcg) {\n\tvar h = hcg[0] / 360;\n\tvar c = hcg[1] / 100;\n\tvar g = hcg[2] / 100;\n\n\tif (c === 0.0) {\n\t\treturn [g * 255, g * 255, g * 255];\n\t}\n\n\tvar pure = [0, 0, 0];\n\tvar hi = (h % 1) * 6;\n\tvar v = hi % 1;\n\tvar w = 1 - v;\n\tvar mg = 0;\n\n\tswitch (Math.floor(hi)) {\n\t\tcase 0:\n\t\t\tpure[0] = 1; pure[1] = v; pure[2] = 0; break;\n\t\tcase 1:\n\t\t\tpure[0] = w; pure[1] = 1; pure[2] = 0; break;\n\t\tcase 2:\n\t\t\tpure[0] = 0; pure[1] = 1; pure[2] = v; break;\n\t\tcase 3:\n\t\t\tpure[0] = 0; pure[1] = w; pure[2] = 1; break;\n\t\tcase 4:\n\t\t\tpure[0] = v; pure[1] = 0; pure[2] = 1; break;\n\t\tdefault:\n\t\t\tpure[0] = 1; pure[1] = 0; pure[2] = w;\n\t}\n\n\tmg = (1.0 - c) * g;\n\n\treturn [\n\t\t(c * pure[0] + mg) * 255,\n\t\t(c * pure[1] + mg) * 255,\n\t\t(c * pure[2] + mg) * 255\n\t];\n};\n\nconvert.hcg.hsv = function (hcg) {\n\tvar c = hcg[1] / 100;\n\tvar g = hcg[2] / 100;\n\n\tvar v = c + g * (1.0 - c);\n\tvar f = 0;\n\n\tif (v > 0.0) {\n\t\tf = c / v;\n\t}\n\n\treturn [hcg[0], f * 100, v * 100];\n};\n\nconvert.hcg.hsl = function (hcg) {\n\tvar c = hcg[1] / 100;\n\tvar g = hcg[2] / 100;\n\n\tvar l = g * (1.0 - c) + 0.5 * c;\n\tvar s = 0;\n\n\tif (l > 0.0 && l < 0.5) {\n\t\ts = c / (2 * l);\n\t} else\n\tif (l >= 0.5 && l < 1.0) {\n\t\ts = c / (2 * (1 - l));\n\t}\n\n\treturn [hcg[0], s * 100, l * 100];\n};\n\nconvert.hcg.hwb = function (hcg) {\n\tvar c = hcg[1] / 100;\n\tvar g = hcg[2] / 100;\n\tvar v = c + g * (1.0 - c);\n\treturn [hcg[0], (v - c) * 100, (1 - v) * 100];\n};\n\nconvert.hwb.hcg = function (hwb) {\n\tvar w = hwb[1] / 100;\n\tvar b = hwb[2] / 100;\n\tvar v = 1 - b;\n\tvar c = v - w;\n\tvar g = 0;\n\n\tif (c < 1) {\n\t\tg = (v - c) / (1 - c);\n\t}\n\n\treturn [hwb[0], c * 100, g * 100];\n};\n\nconvert.apple.rgb = function (apple) {\n\treturn [(apple[0] / 65535) * 255, (apple[1] / 65535) * 255, (apple[2] / 65535) * 255];\n};\n\nconvert.rgb.apple = function (rgb) {\n\treturn [(rgb[0] / 255) * 65535, (rgb[1] / 255) * 65535, (rgb[2] / 255) * 65535];\n};\n\nconvert.gray.rgb = function (args) {\n\treturn [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255];\n};\n\nconvert.gray.hsl = convert.gray.hsv = function (args) {\n\treturn [0, 0, args[0]];\n};\n\nconvert.gray.hwb = function (gray) {\n\treturn [0, 100, gray[0]];\n};\n\nconvert.gray.cmyk = function (gray) {\n\treturn [0, 0, 0, gray[0]];\n};\n\nconvert.gray.lab = function (gray) {\n\treturn [gray[0], 0, 0];\n};\n\nconvert.gray.hex = function (gray) {\n\tvar val = Math.round(gray[0] / 100 * 255) & 0xFF;\n\tvar integer = (val << 16) + (val << 8) + val;\n\n\tvar string = integer.toString(16).toUpperCase();\n\treturn '000000'.substring(string.length) + string;\n};\n\nconvert.rgb.gray = function (rgb) {\n\tvar val = (rgb[0] + rgb[1] + rgb[2]) / 3;\n\treturn [val / 255 * 100];\n};\n","'use strict'\r\n\r\nmodule.exports = {\r\n\t\"aliceblue\": [240, 248, 255],\r\n\t\"antiquewhite\": [250, 235, 215],\r\n\t\"aqua\": [0, 255, 255],\r\n\t\"aquamarine\": [127, 255, 212],\r\n\t\"azure\": [240, 255, 255],\r\n\t\"beige\": [245, 245, 220],\r\n\t\"bisque\": [255, 228, 196],\r\n\t\"black\": [0, 0, 0],\r\n\t\"blanchedalmond\": [255, 235, 205],\r\n\t\"blue\": [0, 0, 255],\r\n\t\"blueviolet\": [138, 43, 226],\r\n\t\"brown\": [165, 42, 42],\r\n\t\"burlywood\": [222, 184, 135],\r\n\t\"cadetblue\": [95, 158, 160],\r\n\t\"chartreuse\": [127, 255, 0],\r\n\t\"chocolate\": [210, 105, 30],\r\n\t\"coral\": [255, 127, 80],\r\n\t\"cornflowerblue\": [100, 149, 237],\r\n\t\"cornsilk\": [255, 248, 220],\r\n\t\"crimson\": [220, 20, 60],\r\n\t\"cyan\": [0, 255, 255],\r\n\t\"darkblue\": [0, 0, 139],\r\n\t\"darkcyan\": [0, 139, 139],\r\n\t\"darkgoldenrod\": [184, 134, 11],\r\n\t\"darkgray\": [169, 169, 169],\r\n\t\"darkgreen\": [0, 100, 0],\r\n\t\"darkgrey\": [169, 169, 169],\r\n\t\"darkkhaki\": [189, 183, 107],\r\n\t\"darkmagenta\": [139, 0, 139],\r\n\t\"darkolivegreen\": [85, 107, 47],\r\n\t\"darkorange\": [255, 140, 0],\r\n\t\"darkorchid\": [153, 50, 204],\r\n\t\"darkred\": [139, 0, 0],\r\n\t\"darksalmon\": [233, 150, 122],\r\n\t\"darkseagreen\": [143, 188, 143],\r\n\t\"darkslateblue\": [72, 61, 139],\r\n\t\"darkslategray\": [47, 79, 79],\r\n\t\"darkslategrey\": [47, 79, 79],\r\n\t\"darkturquoise\": [0, 206, 209],\r\n\t\"darkviolet\": [148, 0, 211],\r\n\t\"deeppink\": [255, 20, 147],\r\n\t\"deepskyblue\": [0, 191, 255],\r\n\t\"dimgray\": [105, 105, 105],\r\n\t\"dimgrey\": [105, 105, 105],\r\n\t\"dodgerblue\": [30, 144, 255],\r\n\t\"firebrick\": [178, 34, 34],\r\n\t\"floralwhite\": [255, 250, 240],\r\n\t\"forestgreen\": [34, 139, 34],\r\n\t\"fuchsia\": [255, 0, 255],\r\n\t\"gainsboro\": [220, 220, 220],\r\n\t\"ghostwhite\": [248, 248, 255],\r\n\t\"gold\": [255, 215, 0],\r\n\t\"goldenrod\": [218, 165, 32],\r\n\t\"gray\": [128, 128, 128],\r\n\t\"green\": [0, 128, 0],\r\n\t\"greenyellow\": [173, 255, 47],\r\n\t\"grey\": [128, 128, 128],\r\n\t\"honeydew\": [240, 255, 240],\r\n\t\"hotpink\": [255, 105, 180],\r\n\t\"indianred\": [205, 92, 92],\r\n\t\"indigo\": [75, 0, 130],\r\n\t\"ivory\": [255, 255, 240],\r\n\t\"khaki\": [240, 230, 140],\r\n\t\"lavender\": [230, 230, 250],\r\n\t\"lavenderblush\": [255, 240, 245],\r\n\t\"lawngreen\": [124, 252, 0],\r\n\t\"lemonchiffon\": [255, 250, 205],\r\n\t\"lightblue\": [173, 216, 230],\r\n\t\"lightcoral\": [240, 128, 128],\r\n\t\"lightcyan\": [224, 255, 255],\r\n\t\"lightgoldenrodyellow\": [250, 250, 210],\r\n\t\"lightgray\": [211, 211, 211],\r\n\t\"lightgreen\": [144, 238, 144],\r\n\t\"lightgrey\": [211, 211, 211],\r\n\t\"lightpink\": [255, 182, 193],\r\n\t\"lightsalmon\": [255, 160, 122],\r\n\t\"lightseagreen\": [32, 178, 170],\r\n\t\"lightskyblue\": [135, 206, 250],\r\n\t\"lightslategray\": [119, 136, 153],\r\n\t\"lightslategrey\": [119, 136, 153],\r\n\t\"lightsteelblue\": [176, 196, 222],\r\n\t\"lightyellow\": [255, 255, 224],\r\n\t\"lime\": [0, 255, 0],\r\n\t\"limegreen\": [50, 205, 50],\r\n\t\"linen\": [250, 240, 230],\r\n\t\"magenta\": [255, 0, 255],\r\n\t\"maroon\": [128, 0, 0],\r\n\t\"mediumaquamarine\": [102, 205, 170],\r\n\t\"mediumblue\": [0, 0, 205],\r\n\t\"mediumorchid\": [186, 85, 211],\r\n\t\"mediumpurple\": [147, 112, 219],\r\n\t\"mediumseagreen\": [60, 179, 113],\r\n\t\"mediumslateblue\": [123, 104, 238],\r\n\t\"mediumspringgreen\": [0, 250, 154],\r\n\t\"mediumturquoise\": [72, 209, 204],\r\n\t\"mediumvioletred\": [199, 21, 133],\r\n\t\"midnightblue\": [25, 25, 112],\r\n\t\"mintcream\": [245, 255, 250],\r\n\t\"mistyrose\": [255, 228, 225],\r\n\t\"moccasin\": [255, 228, 181],\r\n\t\"navajowhite\": [255, 222, 173],\r\n\t\"navy\": [0, 0, 128],\r\n\t\"oldlace\": [253, 245, 230],\r\n\t\"olive\": [128, 128, 0],\r\n\t\"olivedrab\": [107, 142, 35],\r\n\t\"orange\": [255, 165, 0],\r\n\t\"orangered\": [255, 69, 0],\r\n\t\"orchid\": [218, 112, 214],\r\n\t\"palegoldenrod\": [238, 232, 170],\r\n\t\"palegreen\": [152, 251, 152],\r\n\t\"paleturquoise\": [175, 238, 238],\r\n\t\"palevioletred\": [219, 112, 147],\r\n\t\"papayawhip\": [255, 239, 213],\r\n\t\"peachpuff\": [255, 218, 185],\r\n\t\"peru\": [205, 133, 63],\r\n\t\"pink\": [255, 192, 203],\r\n\t\"plum\": [221, 160, 221],\r\n\t\"powderblue\": [176, 224, 230],\r\n\t\"purple\": [128, 0, 128],\r\n\t\"rebeccapurple\": [102, 51, 153],\r\n\t\"red\": [255, 0, 0],\r\n\t\"rosybrown\": [188, 143, 143],\r\n\t\"royalblue\": [65, 105, 225],\r\n\t\"saddlebrown\": [139, 69, 19],\r\n\t\"salmon\": [250, 128, 114],\r\n\t\"sandybrown\": [244, 164, 96],\r\n\t\"seagreen\": [46, 139, 87],\r\n\t\"seashell\": [255, 245, 238],\r\n\t\"sienna\": [160, 82, 45],\r\n\t\"silver\": [192, 192, 192],\r\n\t\"skyblue\": [135, 206, 235],\r\n\t\"slateblue\": [106, 90, 205],\r\n\t\"slategray\": [112, 128, 144],\r\n\t\"slategrey\": [112, 128, 144],\r\n\t\"snow\": [255, 250, 250],\r\n\t\"springgreen\": [0, 255, 127],\r\n\t\"steelblue\": [70, 130, 180],\r\n\t\"tan\": [210, 180, 140],\r\n\t\"teal\": [0, 128, 128],\r\n\t\"thistle\": [216, 191, 216],\r\n\t\"tomato\": [255, 99, 71],\r\n\t\"turquoise\": [64, 224, 208],\r\n\t\"violet\": [238, 130, 238],\r\n\t\"wheat\": [245, 222, 179],\r\n\t\"white\": [255, 255, 255],\r\n\t\"whitesmoke\": [245, 245, 245],\r\n\t\"yellow\": [255, 255, 0],\r\n\t\"yellowgreen\": [154, 205, 50]\r\n};\r\n","var conversions = require('./conversions');\n\n/*\n\tthis function routes a model to all other models.\n\n\tall functions that are routed have a property `.conversion` attached\n\tto the returned synthetic function. This property is an array\n\tof strings, each with the steps in between the 'from' and 'to'\n\tcolor models (inclusive).\n\n\tconversions that are not possible simply are not included.\n*/\n\nfunction buildGraph() {\n\tvar graph = {};\n\t// https://jsperf.com/object-keys-vs-for-in-with-closure/3\n\tvar models = Object.keys(conversions);\n\n\tfor (var len = models.length, i = 0; i < len; i++) {\n\t\tgraph[models[i]] = {\n\t\t\t// http://jsperf.com/1-vs-infinity\n\t\t\t// micro-opt, but this is simple.\n\t\t\tdistance: -1,\n\t\t\tparent: null\n\t\t};\n\t}\n\n\treturn graph;\n}\n\n// https://en.wikipedia.org/wiki/Breadth-first_search\nfunction deriveBFS(fromModel) {\n\tvar graph = buildGraph();\n\tvar queue = [fromModel]; // unshift -> queue -> pop\n\n\tgraph[fromModel].distance = 0;\n\n\twhile (queue.length) {\n\t\tvar current = queue.pop();\n\t\tvar adjacents = Object.keys(conversions[current]);\n\n\t\tfor (var len = adjacents.length, i = 0; i < len; i++) {\n\t\t\tvar adjacent = adjacents[i];\n\t\t\tvar node = graph[adjacent];\n\n\t\t\tif (node.distance === -1) {\n\t\t\t\tnode.distance = graph[current].distance + 1;\n\t\t\t\tnode.parent = current;\n\t\t\t\tqueue.unshift(adjacent);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn graph;\n}\n\nfunction link(from, to) {\n\treturn function (args) {\n\t\treturn to(from(args));\n\t};\n}\n\nfunction wrapConversion(toModel, graph) {\n\tvar path = [graph[toModel].parent, toModel];\n\tvar fn = conversions[graph[toModel].parent][toModel];\n\n\tvar cur = graph[toModel].parent;\n\twhile (graph[cur].parent) {\n\t\tpath.unshift(graph[cur].parent);\n\t\tfn = link(conversions[graph[cur].parent][cur], fn);\n\t\tcur = graph[cur].parent;\n\t}\n\n\tfn.conversion = path;\n\treturn fn;\n}\n\nmodule.exports = function (fromModel) {\n\tvar graph = deriveBFS(fromModel);\n\tvar conversion = {};\n\n\tvar models = Object.keys(graph);\n\tfor (var len = models.length, i = 0; i < len; i++) {\n\t\tvar toModel = models[i];\n\t\tvar node = graph[toModel];\n\n\t\tif (node.parent === null) {\n\t\t\t// no possible conversion, or this node is the source model.\n\t\t\tcontinue;\n\t\t}\n\n\t\tconversion[toModel] = wrapConversion(toModel, graph);\n\t}\n\n\treturn conversion;\n};\n\n","export { MD3LightTheme } from './v3/LightTheme';\nexport { MD3DarkTheme } from './v3/DarkTheme';\nexport { MD2LightTheme } from './v2/LightTheme';\nexport { MD2DarkTheme } from './v2/DarkTheme';\n//# sourceMappingURL=index.js.map","import color from 'color';\nimport { MD3Colors, tokens } from './tokens';\nimport configureFonts from '../../fonts';\nconst {\n palette,\n opacity\n} = tokens.md.ref;\nexport const MD3LightTheme = {\n dark: false,\n roundness: 4,\n version: 3,\n isV3: true,\n colors: {\n primary: palette.primary40,\n primaryContainer: palette.primary90,\n secondary: palette.secondary40,\n secondaryContainer: palette.secondary90,\n tertiary: palette.tertiary40,\n tertiaryContainer: palette.tertiary90,\n surface: palette.neutral99,\n surfaceVariant: palette.neutralVariant90,\n surfaceDisabled: color(palette.neutral10).alpha(opacity.level2).rgb().string(),\n background: palette.neutral99,\n error: palette.error40,\n errorContainer: palette.error90,\n onPrimary: palette.primary100,\n onPrimaryContainer: palette.primary10,\n onSecondary: palette.secondary100,\n onSecondaryContainer: palette.secondary10,\n onTertiary: palette.tertiary100,\n onTertiaryContainer: palette.tertiary10,\n onSurface: palette.neutral10,\n onSurfaceVariant: palette.neutralVariant30,\n onSurfaceDisabled: color(palette.neutral10).alpha(opacity.level4).rgb().string(),\n onError: palette.error100,\n onErrorContainer: palette.error10,\n onBackground: palette.neutral10,\n outline: palette.neutralVariant50,\n outlineVariant: palette.neutralVariant80,\n inverseSurface: palette.neutral20,\n inverseOnSurface: palette.neutral95,\n inversePrimary: palette.primary80,\n shadow: palette.neutral0,\n scrim: palette.neutral0,\n backdrop: color(MD3Colors.neutralVariant20).alpha(0.4).rgb().string(),\n elevation: {\n level0: 'transparent',\n // Note: Color values with transparency cause RN to transfer shadows to children nodes\n // instead of View component in Surface. Providing solid background fixes the issue.\n // Opaque color values generated with `palette.primary99` used as background\n level1: 'rgb(247, 243, 249)',\n // palette.primary40, alpha 0.05\n level2: 'rgb(243, 237, 246)',\n // palette.primary40, alpha 0.08\n level3: 'rgb(238, 232, 244)',\n // palette.primary40, alpha 0.11\n level4: 'rgb(236, 230, 243)',\n // palette.primary40, alpha 0.12\n level5: 'rgb(233, 227, 241)' // palette.primary40, alpha 0.14\n }\n },\n\n fonts: configureFonts(),\n animation: {\n scale: 1.0\n }\n};\n//# sourceMappingURL=LightTheme.js.map","import { Platform } from 'react-native';\nconst ref = {\n palette: {\n primary100: 'rgba(255, 255, 255, 1)',\n primary99: 'rgba(255, 251, 254, 1)',\n primary95: 'rgba(246, 237, 255, 1)',\n primary90: 'rgba(234, 221, 255, 1)',\n primary80: 'rgba(208, 188, 255, 1)',\n primary70: 'rgba(182, 157, 248, 1)',\n primary60: 'rgba(154, 130, 219, 1)',\n primary50: 'rgba(127, 103, 190, 1)',\n primary40: 'rgba(103, 80, 164, 1)',\n primary30: 'rgba(79, 55, 139, 1)',\n primary20: 'rgba(56, 30, 114, 1)',\n primary10: 'rgba(33, 0, 93, 1)',\n primary0: 'rgba(0, 0, 0, 1)',\n secondary100: 'rgba(255, 255, 255, 1)',\n secondary99: 'rgba(255, 251, 254, 1)',\n secondary95: 'rgba(246, 237, 255, 1)',\n secondary90: 'rgba(232, 222, 248, 1)',\n secondary80: 'rgba(204, 194, 220, 1)',\n secondary70: 'rgba(176, 167, 192, 1)',\n secondary60: 'rgba(149, 141, 165, 1)',\n secondary50: 'rgba(122, 114, 137, 1)',\n secondary40: 'rgba(98, 91, 113, 1)',\n secondary30: 'rgba(74, 68, 88, 1)',\n secondary20: 'rgba(51, 45, 65, 1)',\n secondary10: 'rgba(29, 25, 43, 1)',\n secondary0: 'rgba(0, 0, 0, 1)',\n tertiary100: 'rgba(255, 255, 255, 1)',\n tertiary99: 'rgba(255, 251, 250, 1)',\n tertiary95: 'rgba(255, 236, 241, 1)',\n tertiary90: 'rgba(255, 216, 228, 1)',\n tertiary80: 'rgba(239, 184, 200, 1)',\n tertiary70: 'rgba(210, 157, 172, 1)',\n tertiary60: 'rgba(181, 131, 146, 1)',\n tertiary50: 'rgba(152, 105, 119, 1)',\n tertiary40: 'rgba(125, 82, 96, 1)',\n tertiary30: 'rgba(99, 59, 72, 1)',\n tertiary20: 'rgba(73, 37, 50, 1)',\n tertiary10: 'rgba(49, 17, 29, 1)',\n tertiary0: 'rgba(0, 0, 0, 1)',\n neutral100: 'rgba(255, 255, 255, 1)',\n neutral99: 'rgba(255, 251, 254, 1)',\n neutral95: 'rgba(244, 239, 244, 1)',\n neutral90: 'rgba(230, 225, 229, 1)',\n neutral80: 'rgba(201, 197, 202, 1)',\n neutral70: 'rgba(174, 170, 174, 1)',\n neutral60: 'rgba(147, 144, 148, 1)',\n neutral50: 'rgba(120, 117, 121, 1)',\n neutral40: 'rgba(96, 93, 98, 1)',\n neutral30: 'rgba(72, 70, 73, 1)',\n neutral20: 'rgba(49, 48, 51, 1)',\n neutral10: 'rgba(28, 27, 31, 1)',\n neutral0: 'rgba(0, 0, 0, 1)',\n neutralVariant100: 'rgba(255, 255, 255, 1)',\n neutralVariant99: 'rgba(255, 251, 254, 1)',\n neutralVariant95: 'rgba(245, 238, 250, 1)',\n neutralVariant90: 'rgba(231, 224, 236, 1)',\n neutralVariant80: 'rgba(202, 196, 208, 1)',\n neutralVariant70: 'rgba(174, 169, 180, 1)',\n neutralVariant60: 'rgba(147, 143, 153, 1)',\n neutralVariant50: 'rgba(121, 116, 126, 1)',\n neutralVariant40: 'rgba(96, 93, 102, 1)',\n neutralVariant30: 'rgba(73, 69, 79, 1)',\n neutralVariant20: 'rgba(50, 47, 55, 1)',\n neutralVariant10: 'rgba(29, 26, 34, 1)',\n neutralVariant0: 'rgba(0, 0, 0, 1)',\n error100: 'rgba(255, 255, 255, 1)',\n error99: 'rgba(255, 251, 249, 1)',\n error95: 'rgba(252, 238, 238, 1)',\n error90: 'rgba(249, 222, 220, 1)',\n error80: 'rgba(242, 184, 181, 1)',\n error70: 'rgba(236, 146, 142, 1)',\n error60: 'rgba(228, 105, 98, 1)',\n error50: 'rgba(220, 54, 46, 1)',\n error40: 'rgba(179, 38, 30, 1)',\n error30: 'rgba(140, 29, 24, 1)',\n error20: 'rgba(96, 20, 16, 1)',\n error10: 'rgba(65, 14, 11, 1)',\n error0: 'rgba(0, 0, 0, 1)'\n },\n typeface: {\n brandRegular: Platform.select({\n web: 'Roboto, \"Helvetica Neue\", Helvetica, Arial, sans-serif',\n ios: 'System',\n default: 'sans-serif'\n }),\n weightRegular: '400',\n plainMedium: Platform.select({\n web: 'Roboto, \"Helvetica Neue\", Helvetica, Arial, sans-serif',\n ios: 'System',\n default: 'sans-serif-medium'\n }),\n weightMedium: '500'\n },\n opacity: {\n level1: 0.08,\n level2: 0.12,\n level3: 0.16,\n level4: 0.38\n }\n};\nconst regularType = {\n fontFamily: ref.typeface.brandRegular,\n letterSpacing: 0,\n fontWeight: ref.typeface.weightRegular\n};\nconst mediumType = {\n fontFamily: ref.typeface.plainMedium,\n letterSpacing: 0.15,\n fontWeight: ref.typeface.weightMedium\n};\nexport const typescale = {\n displayLarge: {\n ...regularType,\n lineHeight: 64,\n fontSize: 57\n },\n displayMedium: {\n ...regularType,\n lineHeight: 52,\n fontSize: 45\n },\n displaySmall: {\n ...regularType,\n lineHeight: 44,\n fontSize: 36\n },\n headlineLarge: {\n ...regularType,\n lineHeight: 40,\n fontSize: 32\n },\n headlineMedium: {\n ...regularType,\n lineHeight: 36,\n fontSize: 28\n },\n headlineSmall: {\n ...regularType,\n lineHeight: 32,\n fontSize: 24\n },\n titleLarge: {\n ...regularType,\n lineHeight: 28,\n fontSize: 22\n },\n titleMedium: {\n ...mediumType,\n lineHeight: 24,\n fontSize: 16\n },\n titleSmall: {\n ...mediumType,\n letterSpacing: 0.1,\n lineHeight: 20,\n fontSize: 14\n },\n labelLarge: {\n ...mediumType,\n letterSpacing: 0.1,\n lineHeight: 20,\n fontSize: 14\n },\n labelMedium: {\n ...mediumType,\n letterSpacing: 0.5,\n lineHeight: 16,\n fontSize: 12\n },\n labelSmall: {\n ...mediumType,\n letterSpacing: 0.5,\n lineHeight: 16,\n fontSize: 11\n },\n bodyLarge: {\n ...mediumType,\n fontWeight: ref.typeface.weightRegular,\n fontFamily: ref.typeface.brandRegular,\n lineHeight: 24,\n fontSize: 16\n },\n bodyMedium: {\n ...mediumType,\n fontWeight: ref.typeface.weightRegular,\n fontFamily: ref.typeface.brandRegular,\n letterSpacing: 0.25,\n lineHeight: 20,\n fontSize: 14\n },\n bodySmall: {\n ...mediumType,\n fontWeight: ref.typeface.weightRegular,\n fontFamily: ref.typeface.brandRegular,\n letterSpacing: 0.4,\n lineHeight: 16,\n fontSize: 12\n },\n default: {\n ...regularType\n }\n};\nexport const tokens = {\n md: {\n ref,\n sys: {\n typescale\n }\n }\n};\nexport const MD3Colors = ref.palette;\n//# sourceMappingURL=tokens.js.map","import { Platform } from 'react-native';\nimport { typescale } from './themes/v3/tokens';\nexport const fontConfig = {\n web: {\n regular: {\n fontFamily: 'Roboto, \"Helvetica Neue\", Helvetica, Arial, sans-serif',\n fontWeight: '400'\n },\n medium: {\n fontFamily: 'Roboto, \"Helvetica Neue\", Helvetica, Arial, sans-serif',\n fontWeight: '500'\n },\n light: {\n fontFamily: 'Roboto, \"Helvetica Neue\", Helvetica, Arial, sans-serif',\n fontWeight: '300'\n },\n thin: {\n fontFamily: 'Roboto, \"Helvetica Neue\", Helvetica, Arial, sans-serif',\n fontWeight: '100'\n }\n },\n ios: {\n regular: {\n fontFamily: 'System',\n fontWeight: '400'\n },\n medium: {\n fontFamily: 'System',\n fontWeight: '500'\n },\n light: {\n fontFamily: 'System',\n fontWeight: '300'\n },\n thin: {\n fontFamily: 'System',\n fontWeight: '100'\n }\n },\n default: {\n regular: {\n fontFamily: 'sans-serif',\n fontWeight: 'normal'\n },\n medium: {\n fontFamily: 'sans-serif-medium',\n fontWeight: 'normal'\n },\n light: {\n fontFamily: 'sans-serif-light',\n fontWeight: 'normal'\n },\n thin: {\n fontFamily: 'sans-serif-thin',\n fontWeight: 'normal'\n }\n }\n};\nfunction configureV2Fonts(config) {\n const fonts = Platform.select({\n ...fontConfig,\n ...config\n });\n return fonts;\n}\nfunction configureV3Fonts(config) {\n if (!config) {\n return typescale;\n }\n const isFlatConfig = Object.keys(config).every(key => typeof config[key] !== 'object');\n if (isFlatConfig) {\n return Object.fromEntries(Object.entries(typescale).map(_ref => {\n let [variantName, variantProperties] = _ref;\n return [variantName, {\n ...variantProperties,\n ...config\n }];\n }));\n }\n return Object.assign({}, typescale, ...Object.entries(config).map(_ref2 => {\n let [variantName, variantProperties] = _ref2;\n return {\n [variantName]: {\n ...typescale[variantName],\n ...variantProperties\n }\n };\n }));\n}\n\n// eslint-disable-next-line no-redeclare\n\n// eslint-disable-next-line no-redeclare\n\n// eslint-disable-next-line no-redeclare\n\n// eslint-disable-next-line no-redeclare\n\n// eslint-disable-next-line no-redeclare\n\n// eslint-disable-next-line no-redeclare\nexport default function configureFonts(params) {\n const {\n isV3 = true,\n config\n } = params || {};\n if (isV3) {\n return configureV3Fonts(config);\n }\n return configureV2Fonts(config);\n}\n//# sourceMappingURL=fonts.js.map","import color from 'color';\nimport { MD3LightTheme } from './LightTheme';\nimport { MD3Colors, tokens } from './tokens';\nconst {\n palette,\n opacity\n} = tokens.md.ref;\nexport const MD3DarkTheme = {\n ...MD3LightTheme,\n dark: true,\n mode: 'adaptive',\n version: 3,\n isV3: true,\n colors: {\n primary: palette.primary80,\n primaryContainer: palette.primary30,\n secondary: palette.secondary80,\n secondaryContainer: palette.secondary30,\n tertiary: palette.tertiary80,\n tertiaryContainer: palette.tertiary30,\n surface: palette.neutral10,\n surfaceVariant: palette.neutralVariant30,\n surfaceDisabled: color(palette.neutral90).alpha(opacity.level2).rgb().string(),\n background: palette.neutral10,\n error: palette.error80,\n errorContainer: palette.error30,\n onPrimary: palette.primary20,\n onPrimaryContainer: palette.primary90,\n onSecondary: palette.secondary20,\n onSecondaryContainer: palette.secondary90,\n onTertiary: palette.tertiary20,\n onTertiaryContainer: palette.tertiary90,\n onSurface: palette.neutral90,\n onSurfaceVariant: palette.neutralVariant80,\n onSurfaceDisabled: color(palette.neutral90).alpha(opacity.level4).rgb().string(),\n onError: palette.error20,\n onErrorContainer: palette.error80,\n onBackground: palette.neutral90,\n outline: palette.neutralVariant60,\n outlineVariant: palette.neutralVariant30,\n inverseSurface: palette.neutral90,\n inverseOnSurface: palette.neutral20,\n inversePrimary: palette.primary40,\n shadow: palette.neutral0,\n scrim: palette.neutral0,\n backdrop: color(MD3Colors.neutralVariant20).alpha(0.4).rgb().string(),\n elevation: {\n level0: 'transparent',\n // Note: Color values with transparency cause RN to transfer shadows to children nodes\n // instead of View component in Surface. Providing solid background fixes the issue.\n // Opaque color values generated with `palette.primary80` used as background\n level1: 'rgb(37, 35, 42)',\n // palette.primary80, alpha 0.05\n level2: 'rgb(44, 40, 49)',\n // palette.primary80, alpha 0.08\n level3: 'rgb(49, 44, 56)',\n // palette.primary80, alpha 0.11\n level4: 'rgb(51, 46, 58)',\n // palette.primary80, alpha 0.12\n level5: 'rgb(52, 49, 63)' // palette.primary80, alpha 0.14\n }\n }\n};\n//# sourceMappingURL=DarkTheme.js.map","import color from 'color';\nimport { black, pinkA400, white } from './colors';\nimport configureFonts from '../../fonts';\nexport const MD2LightTheme = {\n dark: false,\n roundness: 4,\n version: 2,\n isV3: false,\n colors: {\n primary: '#6200ee',\n accent: '#03dac4',\n background: '#f6f6f6',\n surface: white,\n error: '#B00020',\n text: black,\n onSurface: '#000000',\n disabled: color(black).alpha(0.26).rgb().string(),\n placeholder: color(black).alpha(0.54).rgb().string(),\n backdrop: color(black).alpha(0.5).rgb().string(),\n notification: pinkA400,\n tooltip: 'rgba(28, 27, 31, 1)'\n },\n fonts: configureFonts({\n isV3: false\n }),\n animation: {\n scale: 1.0\n }\n};\n//# sourceMappingURL=LightTheme.js.map","import color from 'color';\nimport { black, pinkA100, white } from './colors';\nimport { MD2LightTheme } from './LightTheme';\nimport configureFonts from '../../fonts';\nexport const MD2DarkTheme = {\n ...MD2LightTheme,\n dark: true,\n mode: 'adaptive',\n version: 2,\n isV3: false,\n colors: {\n ...MD2LightTheme.colors,\n primary: '#BB86FC',\n accent: '#03dac6',\n background: '#121212',\n surface: '#121212',\n error: '#CF6679',\n onSurface: '#FFFFFF',\n text: white,\n disabled: color(white).alpha(0.38).rgb().string(),\n placeholder: color(white).alpha(0.54).rgb().string(),\n backdrop: color(black).alpha(0.5).rgb().string(),\n notification: pinkA100,\n tooltip: 'rgba(230, 225, 229, 1)'\n },\n fonts: configureFonts({\n isV3: false\n })\n};\n//# sourceMappingURL=DarkTheme.js.map","import * as React from 'react';\nimport { View, StyleSheet } from 'react-native';\nimport PortalManager from './PortalManager';\nexport const PortalContext = /*#__PURE__*/React.createContext(null);\n\n/**\n * Portal host renders all of its children `Portal` elements.\n * For example, you can wrap a screen in `Portal.Host` to render items above the screen.\n * If you're using the `Provider` component, it already includes `Portal.Host`.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Text } from 'react-native';\n * import { Portal } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * Content of the app\n * \n * );\n *\n * export default MyComponent;\n * ```\n *\n * Here any `Portal` elements under `` are rendered alongside `` and will appear above `` like a `Modal`.\n */\nexport default class PortalHost extends React.Component {\n static displayName = 'Portal.Host';\n componentDidMount() {\n const manager = this.manager;\n const queue = this.queue;\n while (queue.length && manager) {\n const action = queue.pop();\n if (action) {\n // eslint-disable-next-line default-case\n switch (action.type) {\n case 'mount':\n manager.mount(action.key, action.children);\n break;\n case 'update':\n manager.update(action.key, action.children);\n break;\n case 'unmount':\n manager.unmount(action.key);\n break;\n }\n }\n }\n }\n setManager = manager => {\n this.manager = manager;\n };\n mount = children => {\n const key = this.nextKey++;\n if (this.manager) {\n this.manager.mount(key, children);\n } else {\n this.queue.push({\n type: 'mount',\n key,\n children\n });\n }\n return key;\n };\n update = (key, children) => {\n if (this.manager) {\n this.manager.update(key, children);\n } else {\n const op = {\n type: 'mount',\n key,\n children\n };\n const index = this.queue.findIndex(o => o.type === 'mount' || o.type === 'update' && o.key === key);\n if (index > -1) {\n this.queue[index] = op;\n } else {\n this.queue.push(op);\n }\n }\n };\n unmount = key => {\n if (this.manager) {\n this.manager.unmount(key);\n } else {\n this.queue.push({\n type: 'unmount',\n key\n });\n }\n };\n nextKey = 0;\n queue = [];\n render() {\n return /*#__PURE__*/React.createElement(PortalContext.Provider, {\n value: {\n mount: this.mount,\n update: this.update,\n unmount: this.unmount\n }\n }, /*#__PURE__*/React.createElement(View, {\n style: styles.container,\n collapsable: false,\n pointerEvents: \"box-none\"\n }, this.props.children), /*#__PURE__*/React.createElement(PortalManager, {\n ref: this.setManager\n }));\n }\n}\nconst styles = StyleSheet.create({\n container: {\n flex: 1\n }\n});\n//# sourceMappingURL=PortalHost.js.map","import * as React from 'react';\nimport { View, StyleSheet } from 'react-native';\n/**\n * Portal host is the component which actually renders all Portals.\n */\nexport default class PortalManager extends React.PureComponent {\n state = {\n portals: []\n };\n mount = (key, children) => {\n this.setState(state => ({\n portals: [...state.portals, {\n key,\n children\n }]\n }));\n };\n update = (key, children) => this.setState(state => ({\n portals: state.portals.map(item => {\n if (item.key === key) {\n return {\n ...item,\n children\n };\n }\n return item;\n })\n }));\n unmount = key => this.setState(state => ({\n portals: state.portals.filter(item => item.key !== key)\n }));\n render() {\n return this.state.portals.map(_ref => {\n let {\n key,\n children\n } = _ref;\n return /*#__PURE__*/React.createElement(View, {\n key: key,\n collapsable: false /* Need collapsable=false here to clip the elevations, otherwise they appear above sibling components */,\n\n pointerEvents: \"box-none\",\n style: StyleSheet.absoluteFill\n }, children);\n });\n }\n}\n//# sourceMappingURL=PortalManager.js.map","export function addEventListener(Module) {\n for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n rest[_key - 1] = arguments[_key];\n }\n const [eventName, handler] = rest;\n let removed = false;\n const subscription = Module.addEventListener(eventName, handler) ?? {\n remove: () => {\n var _Module$removeEventLi, _Module$remove;\n if (removed) {\n return;\n }\n (_Module$removeEventLi = Module.removeEventListener) === null || _Module$removeEventLi === void 0 ? void 0 : _Module$removeEventLi.call(Module, eventName, handler);\n (_Module$remove = Module.remove) === null || _Module$remove === void 0 ? void 0 : _Module$remove.call(Module, eventName, handler);\n removed = true;\n }\n };\n return subscription;\n}\nexport function addListener(Module) {\n for (var _len2 = arguments.length, rest = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n rest[_key2 - 1] = arguments[_key2];\n }\n const [eventName, handler] = rest;\n let removed = false;\n const subscription = Module.addListener(eventName, handler) ?? {\n remove: () => {\n if (removed) {\n return;\n }\n Module.removeEventListener(eventName, handler);\n removed = true;\n }\n };\n return subscription;\n}\n//# sourceMappingURL=addEventListener.js.map","export { default as Link } from './Link';\nexport { default as LinkingContext } from './LinkingContext';\nexport { default as NavigationContainer } from './NavigationContainer';\nexport { default as ServerContainer } from './ServerContainer';\nexport { default as DarkTheme } from './theming/DarkTheme';\nexport { default as DefaultTheme } from './theming/DefaultTheme';\nexport { default as ThemeProvider } from './theming/ThemeProvider';\nexport { default as useTheme } from './theming/useTheme';\nexport * from './types';\nexport { default as useLinkBuilder } from './useLinkBuilder';\nexport { default as useLinkProps } from './useLinkProps';\nexport { default as useLinkTo } from './useLinkTo';\nexport { default as useScrollToTop } from './useScrollToTop';\nexport * from '@react-navigation/core';\n//# sourceMappingURL=index.js.map","import * as React from 'react';\nimport { Platform, Text } from 'react-native';\nimport useLinkProps from './useLinkProps';\n/**\n * Component to render link to another screen using a path.\n * Uses an anchor tag on the web.\n *\n * @param props.to Absolute path to screen (e.g. `/feeds/hot`).\n * @param props.action Optional action to use for in-page navigation. By default, the path is parsed to an action based on linking config.\n * @param props.children Child elements to render the content.\n */\nexport default function Link(_ref) {\n let {\n to,\n action,\n ...rest\n } = _ref;\n const props = useLinkProps({\n to,\n action\n });\n const onPress = e => {\n if ('onPress' in rest) {\n var _rest$onPress;\n (_rest$onPress = rest.onPress) === null || _rest$onPress === void 0 ? void 0 : _rest$onPress.call(rest, e);\n }\n props.onPress(e);\n };\n return /*#__PURE__*/React.createElement(Text, {\n ...props,\n ...rest,\n ...Platform.select({\n web: {\n onClick: onPress\n },\n default: {\n onPress\n }\n })\n });\n}\n//# sourceMappingURL=Link.js.map","import { getPathFromState, NavigationContainerRefContext, NavigationHelpersContext } from '@react-navigation/core';\nimport * as React from 'react';\nimport { Platform } from 'react-native';\nimport LinkingContext from './LinkingContext';\nimport useLinkTo from './useLinkTo';\nconst getStateFromParams = params => {\n if (params !== null && params !== void 0 && params.state) {\n return params.state;\n }\n if (params !== null && params !== void 0 && params.screen) {\n return {\n routes: [{\n name: params.screen,\n params: params.params,\n // @ts-expect-error\n state: params.screen ? getStateFromParams(params.params) : undefined\n }]\n };\n }\n return undefined;\n};\n\n/**\n * Hook to get props for an anchor tag so it can work with in page navigation.\n *\n * @param props.to Absolute path to screen (e.g. `/feeds/hot`).\n * @param props.action Optional action to use for in-page navigation. By default, the path is parsed to an action based on linking config.\n */\nexport default function useLinkProps(_ref) {\n let {\n to,\n action\n } = _ref;\n const root = React.useContext(NavigationContainerRefContext);\n const navigation = React.useContext(NavigationHelpersContext);\n const {\n options\n } = React.useContext(LinkingContext);\n const linkTo = useLinkTo();\n const onPress = e => {\n var _e$currentTarget;\n let shouldHandle = false;\n if (Platform.OS !== 'web' || !e) {\n shouldHandle = e ? !e.defaultPrevented : true;\n } else if (!e.defaultPrevented &&\n // onPress prevented default\n // @ts-expect-error: these properties exist on web, but not in React Native\n !(e.metaKey || e.altKey || e.ctrlKey || e.shiftKey) && (\n // ignore clicks with modifier keys\n // @ts-expect-error: these properties exist on web, but not in React Native\n e.button == null || e.button === 0) &&\n // ignore everything but left clicks\n // @ts-expect-error: these properties exist on web, but not in React Native\n [undefined, null, '', 'self'].includes((_e$currentTarget = e.currentTarget) === null || _e$currentTarget === void 0 ? void 0 : _e$currentTarget.target) // let browser handle \"target=_blank\" etc.\n ) {\n e.preventDefault();\n shouldHandle = true;\n }\n if (shouldHandle) {\n if (action) {\n if (navigation) {\n navigation.dispatch(action);\n } else if (root) {\n root.dispatch(action);\n } else {\n throw new Error(\"Couldn't find a navigation object. Is your component inside NavigationContainer?\");\n }\n } else {\n linkTo(to);\n }\n }\n };\n const getPathFromStateHelper = (options === null || options === void 0 ? void 0 : options.getPathFromState) ?? getPathFromState;\n const href = typeof to === 'string' ? to : getPathFromStateHelper({\n routes: [{\n name: to.screen,\n // @ts-expect-error\n params: to.params,\n // @ts-expect-error\n state: getStateFromParams(to.params)\n }]\n }, options === null || options === void 0 ? void 0 : options.config);\n return {\n href,\n accessibilityRole: 'link',\n onPress\n };\n}\n//# sourceMappingURL=useLinkProps.js.map","export { default as BaseNavigationContainer } from './BaseNavigationContainer';\nexport { default as createNavigationContainerRef } from './createNavigationContainerRef';\nexport { default as createNavigatorFactory } from './createNavigatorFactory';\nexport { default as CurrentRenderContext } from './CurrentRenderContext';\nexport { default as findFocusedRoute } from './findFocusedRoute';\nexport { default as getActionFromState } from './getActionFromState';\nexport { default as getFocusedRouteNameFromRoute } from './getFocusedRouteNameFromRoute';\nexport { default as getPathFromState } from './getPathFromState';\nexport { default as getStateFromPath } from './getStateFromPath';\nexport { default as NavigationContainerRefContext } from './NavigationContainerRefContext';\nexport { default as NavigationContext } from './NavigationContext';\nexport { default as NavigationHelpersContext } from './NavigationHelpersContext';\nexport { default as NavigationRouteContext } from './NavigationRouteContext';\nexport { default as PreventRemoveContext } from './PreventRemoveContext';\nexport { default as PreventRemoveProvider } from './PreventRemoveProvider';\nexport * from './types';\nexport { default as useFocusEffect } from './useFocusEffect';\nexport { default as useIsFocused } from './useIsFocused';\nexport { default as useNavigation } from './useNavigation';\nexport { default as useNavigationBuilder } from './useNavigationBuilder';\nexport { default as useNavigationContainerRef } from './useNavigationContainerRef';\nexport { default as useNavigationState } from './useNavigationState';\nexport { default as UNSTABLE_usePreventRemove } from './usePreventRemove';\nexport { default as usePreventRemoveContext } from './usePreventRemoveContext';\nexport { default as useRoute } from './useRoute';\nexport { default as validatePathConfig } from './validatePathConfig';\nexport * from '@react-navigation/routers';\n//# sourceMappingURL=index.js.map","import { CommonActions } from '@react-navigation/routers';\nimport * as React from 'react';\nimport checkDuplicateRouteNames from './checkDuplicateRouteNames';\nimport checkSerializable from './checkSerializable';\nimport { NOT_INITIALIZED_ERROR } from './createNavigationContainerRef';\nimport EnsureSingleNavigator from './EnsureSingleNavigator';\nimport findFocusedRoute from './findFocusedRoute';\nimport NavigationBuilderContext from './NavigationBuilderContext';\nimport NavigationContainerRefContext from './NavigationContainerRefContext';\nimport NavigationContext from './NavigationContext';\nimport NavigationRouteContext from './NavigationRouteContext';\nimport NavigationStateContext from './NavigationStateContext';\nimport UnhandledActionContext from './UnhandledActionContext';\nimport useChildListeners from './useChildListeners';\nimport useEventEmitter from './useEventEmitter';\nimport useKeyedChildListeners from './useKeyedChildListeners';\nimport useOptionsGetters from './useOptionsGetters';\nimport { ScheduleUpdateContext } from './useScheduleUpdate';\nimport useSyncState from './useSyncState';\nconst serializableWarnings = [];\nconst duplicateNameWarnings = [];\n\n/**\n * Remove `key` and `routeNames` from the state objects recursively to get partial state.\n *\n * @param state Initial state object.\n */\nconst getPartialState = state => {\n if (state === undefined) {\n return;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const {\n key,\n routeNames,\n ...partialState\n } = state;\n return {\n ...partialState,\n stale: true,\n routes: state.routes.map(route => {\n if (route.state === undefined) {\n return route;\n }\n return {\n ...route,\n state: getPartialState(route.state)\n };\n })\n };\n};\n\n/**\n * Container component which holds the navigation state.\n * This should be rendered at the root wrapping the whole app.\n *\n * @param props.initialState Initial state object for the navigation tree.\n * @param props.onStateChange Callback which is called with the latest navigation state when it changes.\n * @param props.children Child elements to render the content.\n * @param props.ref Ref object which refers to the navigation object containing helper methods.\n */\nconst BaseNavigationContainer = /*#__PURE__*/React.forwardRef(function BaseNavigationContainer(_ref, ref) {\n let {\n initialState,\n onStateChange,\n onUnhandledAction,\n independent,\n children\n } = _ref;\n const parent = React.useContext(NavigationStateContext);\n if (!parent.isDefault && !independent) {\n throw new Error(\"Looks like you have nested a 'NavigationContainer' inside another. Normally you need only one container at the root of the app, so this was probably an error. If this was intentional, pass 'independent={true}' explicitly. Note that this will make the child navigators disconnected from the parent and you won't be able to navigate between them.\");\n }\n const [state, getState, setState, scheduleUpdate, flushUpdates] = useSyncState(() => getPartialState(initialState == null ? undefined : initialState));\n const isFirstMountRef = React.useRef(true);\n const navigatorKeyRef = React.useRef();\n const getKey = React.useCallback(() => navigatorKeyRef.current, []);\n const setKey = React.useCallback(key => {\n navigatorKeyRef.current = key;\n }, []);\n const {\n listeners,\n addListener\n } = useChildListeners();\n const {\n keyedListeners,\n addKeyedListener\n } = useKeyedChildListeners();\n const dispatch = React.useCallback(action => {\n if (listeners.focus[0] == null) {\n console.error(NOT_INITIALIZED_ERROR);\n } else {\n listeners.focus[0](navigation => navigation.dispatch(action));\n }\n }, [listeners.focus]);\n const canGoBack = React.useCallback(() => {\n if (listeners.focus[0] == null) {\n return false;\n }\n const {\n result,\n handled\n } = listeners.focus[0](navigation => navigation.canGoBack());\n if (handled) {\n return result;\n } else {\n return false;\n }\n }, [listeners.focus]);\n const resetRoot = React.useCallback(state => {\n var _keyedListeners$getSt, _keyedListeners$getSt2;\n const target = (state === null || state === void 0 ? void 0 : state.key) ?? ((_keyedListeners$getSt = (_keyedListeners$getSt2 = keyedListeners.getState).root) === null || _keyedListeners$getSt === void 0 ? void 0 : _keyedListeners$getSt.call(_keyedListeners$getSt2).key);\n if (target == null) {\n console.error(NOT_INITIALIZED_ERROR);\n } else {\n listeners.focus[0](navigation => navigation.dispatch({\n ...CommonActions.reset(state),\n target\n }));\n }\n }, [keyedListeners.getState, listeners.focus]);\n const getRootState = React.useCallback(() => {\n var _keyedListeners$getSt3, _keyedListeners$getSt4;\n return (_keyedListeners$getSt3 = (_keyedListeners$getSt4 = keyedListeners.getState).root) === null || _keyedListeners$getSt3 === void 0 ? void 0 : _keyedListeners$getSt3.call(_keyedListeners$getSt4);\n }, [keyedListeners.getState]);\n const getCurrentRoute = React.useCallback(() => {\n const state = getRootState();\n if (state == null) {\n return undefined;\n }\n const route = findFocusedRoute(state);\n return route;\n }, [getRootState]);\n const emitter = useEventEmitter();\n const {\n addOptionsGetter,\n getCurrentOptions\n } = useOptionsGetters({});\n const navigation = React.useMemo(() => ({\n ...Object.keys(CommonActions).reduce((acc, name) => {\n acc[name] = function () {\n return (\n // @ts-expect-error: this is ok\n dispatch(CommonActions[name](...arguments))\n );\n };\n return acc;\n }, {}),\n ...emitter.create('root'),\n dispatch,\n resetRoot,\n isFocused: () => true,\n canGoBack,\n getParent: () => undefined,\n getState: () => stateRef.current,\n getRootState,\n getCurrentRoute,\n getCurrentOptions,\n isReady: () => listeners.focus[0] != null\n }), [canGoBack, dispatch, emitter, getCurrentOptions, getCurrentRoute, getRootState, listeners.focus, resetRoot]);\n React.useImperativeHandle(ref, () => navigation, [navigation]);\n const onDispatchAction = React.useCallback((action, noop) => {\n emitter.emit({\n type: '__unsafe_action__',\n data: {\n action,\n noop,\n stack: stackRef.current\n }\n });\n }, [emitter]);\n const lastEmittedOptionsRef = React.useRef();\n const onOptionsChange = React.useCallback(options => {\n if (lastEmittedOptionsRef.current === options) {\n return;\n }\n lastEmittedOptionsRef.current = options;\n emitter.emit({\n type: 'options',\n data: {\n options\n }\n });\n }, [emitter]);\n const stackRef = React.useRef();\n const builderContext = React.useMemo(() => ({\n addListener,\n addKeyedListener,\n onDispatchAction,\n onOptionsChange,\n stackRef\n }), [addListener, addKeyedListener, onDispatchAction, onOptionsChange]);\n const scheduleContext = React.useMemo(() => ({\n scheduleUpdate,\n flushUpdates\n }), [scheduleUpdate, flushUpdates]);\n const isInitialRef = React.useRef(true);\n const getIsInitial = React.useCallback(() => isInitialRef.current, []);\n const context = React.useMemo(() => ({\n state,\n getState,\n setState,\n getKey,\n setKey,\n getIsInitial,\n addOptionsGetter\n }), [state, getState, setState, getKey, setKey, getIsInitial, addOptionsGetter]);\n const onStateChangeRef = React.useRef(onStateChange);\n const stateRef = React.useRef(state);\n React.useEffect(() => {\n isInitialRef.current = false;\n onStateChangeRef.current = onStateChange;\n stateRef.current = state;\n });\n React.useEffect(() => {\n const hydratedState = getRootState();\n if (process.env.NODE_ENV !== 'production') {\n if (hydratedState !== undefined) {\n const serializableResult = checkSerializable(hydratedState);\n if (!serializableResult.serializable) {\n const {\n location,\n reason\n } = serializableResult;\n let path = '';\n let pointer = hydratedState;\n let params = false;\n for (let i = 0; i < location.length; i++) {\n const curr = location[i];\n const prev = location[i - 1];\n pointer = pointer[curr];\n if (!params && curr === 'state') {\n continue;\n } else if (!params && curr === 'routes') {\n if (path) {\n path += ' > ';\n }\n } else if (!params && typeof curr === 'number' && prev === 'routes') {\n var _pointer;\n path += (_pointer = pointer) === null || _pointer === void 0 ? void 0 : _pointer.name;\n } else if (!params) {\n path += ` > ${curr}`;\n params = true;\n } else {\n if (typeof curr === 'number' || /^[0-9]+$/.test(curr)) {\n path += `[${curr}]`;\n } else if (/^[a-z$_]+$/i.test(curr)) {\n path += `.${curr}`;\n } else {\n path += `[${JSON.stringify(curr)}]`;\n }\n }\n }\n const message = `Non-serializable values were found in the navigation state. Check:\\n\\n${path} (${reason})\\n\\nThis can break usage such as persisting and restoring state. This might happen if you passed non-serializable values such as function, class instances etc. in params. If you need to use components with callbacks in your options, you can use 'navigation.setOptions' instead. See https://reactnavigation.org/docs/troubleshooting#i-get-the-warning-non-serializable-values-were-found-in-the-navigation-state for more details.`;\n if (!serializableWarnings.includes(message)) {\n serializableWarnings.push(message);\n console.warn(message);\n }\n }\n const duplicateRouteNamesResult = checkDuplicateRouteNames(hydratedState);\n if (duplicateRouteNamesResult.length) {\n const message = `Found screens with the same name nested inside one another. Check:\\n${duplicateRouteNamesResult.map(locations => `\\n${locations.join(', ')}`)}\\n\\nThis can cause confusing behavior during navigation. Consider using unique names for each screen instead.`;\n if (!duplicateNameWarnings.includes(message)) {\n duplicateNameWarnings.push(message);\n console.warn(message);\n }\n }\n }\n }\n emitter.emit({\n type: 'state',\n data: {\n state\n }\n });\n if (!isFirstMountRef.current && onStateChangeRef.current) {\n onStateChangeRef.current(hydratedState);\n }\n isFirstMountRef.current = false;\n }, [getRootState, emitter, state]);\n const defaultOnUnhandledAction = React.useCallback(action => {\n if (process.env.NODE_ENV === 'production') {\n return;\n }\n const payload = action.payload;\n let message = `The action '${action.type}'${payload ? ` with payload ${JSON.stringify(action.payload)}` : ''} was not handled by any navigator.`;\n switch (action.type) {\n case 'NAVIGATE':\n case 'PUSH':\n case 'REPLACE':\n case 'JUMP_TO':\n if (payload !== null && payload !== void 0 && payload.name) {\n message += `\\n\\nDo you have a screen named '${payload.name}'?\\n\\nIf you're trying to navigate to a screen in a nested navigator, see https://reactnavigation.org/docs/nesting-navigators#navigating-to-a-screen-in-a-nested-navigator.`;\n } else {\n message += `\\n\\nYou need to pass the name of the screen to navigate to.\\n\\nSee https://reactnavigation.org/docs/navigation-actions for usage.`;\n }\n break;\n case 'GO_BACK':\n case 'POP':\n case 'POP_TO_TOP':\n message += `\\n\\nIs there any screen to go back to?`;\n break;\n case 'OPEN_DRAWER':\n case 'CLOSE_DRAWER':\n case 'TOGGLE_DRAWER':\n message += `\\n\\nIs your screen inside a Drawer navigator?`;\n break;\n }\n message += `\\n\\nThis is a development-only warning and won't be shown in production.`;\n console.error(message);\n }, []);\n let element = /*#__PURE__*/React.createElement(NavigationContainerRefContext.Provider, {\n value: navigation\n }, /*#__PURE__*/React.createElement(ScheduleUpdateContext.Provider, {\n value: scheduleContext\n }, /*#__PURE__*/React.createElement(NavigationBuilderContext.Provider, {\n value: builderContext\n }, /*#__PURE__*/React.createElement(NavigationStateContext.Provider, {\n value: context\n }, /*#__PURE__*/React.createElement(UnhandledActionContext.Provider, {\n value: onUnhandledAction ?? defaultOnUnhandledAction\n }, /*#__PURE__*/React.createElement(EnsureSingleNavigator, null, children))))));\n if (independent) {\n // We need to clear any existing contexts for nested independent container to work correctly\n element = /*#__PURE__*/React.createElement(NavigationRouteContext.Provider, {\n value: undefined\n }, /*#__PURE__*/React.createElement(NavigationContext.Provider, {\n value: undefined\n }, element));\n }\n return element;\n});\nexport default BaseNavigationContainer;\n//# sourceMappingURL=BaseNavigationContainer.js.map","import * as CommonActions from './CommonActions';\nexport { CommonActions };\nexport { default as BaseRouter } from './BaseRouter';\nexport { DrawerActions, default as DrawerRouter } from './DrawerRouter';\nexport { StackActions, default as StackRouter } from './StackRouter';\nexport { TabActions, default as TabRouter } from './TabRouter';\nexport * from './types';\n//# sourceMappingURL=index.js.map","export function goBack() {\n return {\n type: 'GO_BACK'\n };\n}\n// eslint-disable-next-line no-redeclare\nexport function navigate() {\n if (typeof (arguments.length <= 0 ? undefined : arguments[0]) === 'string') {\n return {\n type: 'NAVIGATE',\n payload: {\n name: arguments.length <= 0 ? undefined : arguments[0],\n params: arguments.length <= 1 ? undefined : arguments[1]\n }\n };\n } else {\n const payload = (arguments.length <= 0 ? undefined : arguments[0]) || {};\n if (!payload.hasOwnProperty('key') && !payload.hasOwnProperty('name')) {\n throw new Error('You need to specify name or key when calling navigate with an object as the argument. See https://reactnavigation.org/docs/navigation-actions#navigate for usage.');\n }\n return {\n type: 'NAVIGATE',\n payload\n };\n }\n}\nexport function reset(state) {\n return {\n type: 'RESET',\n payload: state\n };\n}\nexport function setParams(params) {\n return {\n type: 'SET_PARAMS',\n payload: {\n params\n }\n };\n}\n//# sourceMappingURL=CommonActions.js.map","import { nanoid } from 'nanoid/non-secure';\n/**\n * Base router object that can be used when writing custom routers.\n * This provides few helper methods to handle common actions such as `RESET`.\n */\nconst BaseRouter = {\n getStateForAction(state, action) {\n switch (action.type) {\n case 'SET_PARAMS':\n {\n const index = action.source ? state.routes.findIndex(r => r.key === action.source) : state.index;\n if (index === -1) {\n return null;\n }\n return {\n ...state,\n routes: state.routes.map((r, i) => i === index ? {\n ...r,\n params: {\n ...r.params,\n ...action.payload.params\n }\n } : r)\n };\n }\n case 'RESET':\n {\n const nextState = action.payload;\n if (nextState.routes.length === 0 || nextState.routes.some(route => !state.routeNames.includes(route.name))) {\n return null;\n }\n if (nextState.stale === false) {\n if (state.routeNames.length !== nextState.routeNames.length || nextState.routeNames.some(name => !state.routeNames.includes(name))) {\n return null;\n }\n return {\n ...nextState,\n routes: nextState.routes.map(route => route.key ? route : {\n ...route,\n key: `${route.name}-${nanoid()}`\n })\n };\n }\n return nextState;\n }\n default:\n return null;\n }\n },\n shouldActionChangeFocus(action) {\n return action.type === 'NAVIGATE';\n }\n};\nexport default BaseRouter;\n//# sourceMappingURL=BaseRouter.js.map","let urlAlphabet =\n 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict'\nlet customAlphabet = (alphabet, defaultSize = 21) => {\n return (size = defaultSize) => {\n let id = ''\n let i = size\n while (i--) {\n id += alphabet[(Math.random() * alphabet.length) | 0]\n }\n return id\n }\n}\nlet nanoid = (size = 21) => {\n let id = ''\n let i = size\n while (i--) {\n id += urlAlphabet[(Math.random() * 64) | 0]\n }\n return id\n}\nexport { nanoid, customAlphabet }\n","import { nanoid } from 'nanoid/non-secure';\nimport TabRouter, { TabActions } from './TabRouter';\nexport const DrawerActions = {\n ...TabActions,\n openDrawer() {\n return {\n type: 'OPEN_DRAWER'\n };\n },\n closeDrawer() {\n return {\n type: 'CLOSE_DRAWER'\n };\n },\n toggleDrawer() {\n return {\n type: 'TOGGLE_DRAWER'\n };\n }\n};\nexport default function DrawerRouter(_ref) {\n let {\n defaultStatus = 'closed',\n ...rest\n } = _ref;\n const router = TabRouter(rest);\n const isDrawerInHistory = state => {\n var _state$history;\n return Boolean((_state$history = state.history) === null || _state$history === void 0 ? void 0 : _state$history.some(it => it.type === 'drawer'));\n };\n const addDrawerToHistory = state => {\n if (isDrawerInHistory(state)) {\n return state;\n }\n return {\n ...state,\n history: [...state.history, {\n type: 'drawer',\n status: defaultStatus === 'open' ? 'closed' : 'open'\n }]\n };\n };\n const removeDrawerFromHistory = state => {\n if (!isDrawerInHistory(state)) {\n return state;\n }\n return {\n ...state,\n history: state.history.filter(it => it.type !== 'drawer')\n };\n };\n const openDrawer = state => {\n if (defaultStatus === 'open') {\n return removeDrawerFromHistory(state);\n }\n return addDrawerToHistory(state);\n };\n const closeDrawer = state => {\n if (defaultStatus === 'open') {\n return addDrawerToHistory(state);\n }\n return removeDrawerFromHistory(state);\n };\n return {\n ...router,\n type: 'drawer',\n getInitialState(_ref2) {\n let {\n routeNames,\n routeParamList,\n routeGetIdList\n } = _ref2;\n const state = router.getInitialState({\n routeNames,\n routeParamList,\n routeGetIdList\n });\n return {\n ...state,\n default: defaultStatus,\n stale: false,\n type: 'drawer',\n key: `drawer-${nanoid()}`\n };\n },\n getRehydratedState(partialState, _ref3) {\n let {\n routeNames,\n routeParamList,\n routeGetIdList\n } = _ref3;\n if (partialState.stale === false) {\n return partialState;\n }\n let state = router.getRehydratedState(partialState, {\n routeNames,\n routeParamList,\n routeGetIdList\n });\n if (isDrawerInHistory(partialState)) {\n // Re-sync the drawer entry in history to correct it if it was wrong\n state = removeDrawerFromHistory(state);\n state = addDrawerToHistory(state);\n }\n return {\n ...state,\n default: defaultStatus,\n type: 'drawer',\n key: `drawer-${nanoid()}`\n };\n },\n getStateForRouteFocus(state, key) {\n const result = router.getStateForRouteFocus(state, key);\n return closeDrawer(result);\n },\n getStateForAction(state, action, options) {\n switch (action.type) {\n case 'OPEN_DRAWER':\n return openDrawer(state);\n case 'CLOSE_DRAWER':\n return closeDrawer(state);\n case 'TOGGLE_DRAWER':\n if (isDrawerInHistory(state)) {\n return removeDrawerFromHistory(state);\n }\n return addDrawerToHistory(state);\n case 'JUMP_TO':\n case 'NAVIGATE':\n {\n const result = router.getStateForAction(state, action, options);\n if (result != null && result.index !== state.index) {\n return closeDrawer(result);\n }\n return result;\n }\n case 'GO_BACK':\n if (isDrawerInHistory(state)) {\n return removeDrawerFromHistory(state);\n }\n return router.getStateForAction(state, action, options);\n default:\n return router.getStateForAction(state, action, options);\n }\n },\n actionCreators: DrawerActions\n };\n}\n//# sourceMappingURL=DrawerRouter.js.map","import { nanoid } from 'nanoid/non-secure';\nimport BaseRouter from './BaseRouter';\nconst TYPE_ROUTE = 'route';\nexport const TabActions = {\n jumpTo(name, params) {\n return {\n type: 'JUMP_TO',\n payload: {\n name,\n params\n }\n };\n }\n};\nconst getRouteHistory = (routes, index, backBehavior, initialRouteName) => {\n const history = [{\n type: TYPE_ROUTE,\n key: routes[index].key\n }];\n let initialRouteIndex;\n switch (backBehavior) {\n case 'order':\n for (let i = index; i > 0; i--) {\n history.unshift({\n type: TYPE_ROUTE,\n key: routes[i - 1].key\n });\n }\n break;\n case 'firstRoute':\n if (index !== 0) {\n history.unshift({\n type: TYPE_ROUTE,\n key: routes[0].key\n });\n }\n break;\n case 'initialRoute':\n initialRouteIndex = routes.findIndex(route => route.name === initialRouteName);\n initialRouteIndex = initialRouteIndex === -1 ? 0 : initialRouteIndex;\n if (index !== initialRouteIndex) {\n history.unshift({\n type: TYPE_ROUTE,\n key: routes[initialRouteIndex].key\n });\n }\n break;\n case 'history':\n // The history will fill up on navigation\n break;\n }\n return history;\n};\nconst changeIndex = (state, index, backBehavior, initialRouteName) => {\n let history;\n if (backBehavior === 'history') {\n const currentKey = state.routes[index].key;\n history = state.history.filter(it => it.type === 'route' ? it.key !== currentKey : false).concat({\n type: TYPE_ROUTE,\n key: currentKey\n });\n } else {\n history = getRouteHistory(state.routes, index, backBehavior, initialRouteName);\n }\n return {\n ...state,\n index,\n history\n };\n};\nexport default function TabRouter(_ref) {\n let {\n initialRouteName,\n backBehavior = 'firstRoute'\n } = _ref;\n const router = {\n ...BaseRouter,\n type: 'tab',\n getInitialState(_ref2) {\n let {\n routeNames,\n routeParamList\n } = _ref2;\n const index = initialRouteName !== undefined && routeNames.includes(initialRouteName) ? routeNames.indexOf(initialRouteName) : 0;\n const routes = routeNames.map(name => ({\n name,\n key: `${name}-${nanoid()}`,\n params: routeParamList[name]\n }));\n const history = getRouteHistory(routes, index, backBehavior, initialRouteName);\n return {\n stale: false,\n type: 'tab',\n key: `tab-${nanoid()}`,\n index,\n routeNames,\n history,\n routes\n };\n },\n getRehydratedState(partialState, _ref3) {\n var _state$routes, _state$history;\n let {\n routeNames,\n routeParamList\n } = _ref3;\n let state = partialState;\n if (state.stale === false) {\n return state;\n }\n const routes = routeNames.map(name => {\n const route = state.routes.find(r => r.name === name);\n return {\n ...route,\n name,\n key: route && route.name === name && route.key ? route.key : `${name}-${nanoid()}`,\n params: routeParamList[name] !== undefined ? {\n ...routeParamList[name],\n ...(route ? route.params : undefined)\n } : route ? route.params : undefined\n };\n });\n const index = Math.min(Math.max(routeNames.indexOf((_state$routes = state.routes[(state === null || state === void 0 ? void 0 : state.index) ?? 0]) === null || _state$routes === void 0 ? void 0 : _state$routes.name), 0), routes.length - 1);\n const history = ((_state$history = state.history) === null || _state$history === void 0 ? void 0 : _state$history.filter(it => routes.find(r => r.key === it.key))) ?? [];\n return changeIndex({\n stale: false,\n type: 'tab',\n key: `tab-${nanoid()}`,\n index,\n routeNames,\n history,\n routes\n }, index, backBehavior, initialRouteName);\n },\n getStateForRouteNamesChange(state, _ref4) {\n let {\n routeNames,\n routeParamList,\n routeKeyChanges\n } = _ref4;\n const routes = routeNames.map(name => state.routes.find(r => r.name === name && !routeKeyChanges.includes(r.name)) || {\n name,\n key: `${name}-${nanoid()}`,\n params: routeParamList[name]\n });\n const index = Math.max(0, routeNames.indexOf(state.routes[state.index].name));\n let history = state.history.filter(\n // Type will always be 'route' for tabs, but could be different in a router extending this (e.g. drawer)\n it => it.type !== 'route' || routes.find(r => r.key === it.key));\n if (!history.length) {\n history = getRouteHistory(routes, index, backBehavior, initialRouteName);\n }\n return {\n ...state,\n history,\n routeNames,\n routes,\n index\n };\n },\n getStateForRouteFocus(state, key) {\n const index = state.routes.findIndex(r => r.key === key);\n if (index === -1 || index === state.index) {\n return state;\n }\n return changeIndex(state, index, backBehavior, initialRouteName);\n },\n getStateForAction(state, action, _ref5) {\n let {\n routeParamList,\n routeGetIdList\n } = _ref5;\n switch (action.type) {\n case 'JUMP_TO':\n case 'NAVIGATE':\n {\n let index = -1;\n if (action.type === 'NAVIGATE' && action.payload.key) {\n index = state.routes.findIndex(route => route.key === action.payload.key);\n } else {\n index = state.routes.findIndex(route => route.name === action.payload.name);\n }\n if (index === -1) {\n return null;\n }\n return changeIndex({\n ...state,\n routes: state.routes.map((route, i) => {\n if (i !== index) {\n return route;\n }\n const getId = routeGetIdList[route.name];\n const currentId = getId === null || getId === void 0 ? void 0 : getId({\n params: route.params\n });\n const nextId = getId === null || getId === void 0 ? void 0 : getId({\n params: action.payload.params\n });\n const key = currentId === nextId ? route.key : `${route.name}-${nanoid()}`;\n let params;\n if (action.type === 'NAVIGATE' && action.payload.merge && currentId === nextId) {\n params = action.payload.params !== undefined || routeParamList[route.name] !== undefined ? {\n ...routeParamList[route.name],\n ...route.params,\n ...action.payload.params\n } : route.params;\n } else {\n params = routeParamList[route.name] !== undefined ? {\n ...routeParamList[route.name],\n ...action.payload.params\n } : action.payload.params;\n }\n const path = action.type === 'NAVIGATE' && action.payload.path != null ? action.payload.path : route.path;\n return params !== route.params || path !== route.path ? {\n ...route,\n key,\n path,\n params\n } : route;\n })\n }, index, backBehavior, initialRouteName);\n }\n case 'GO_BACK':\n {\n if (state.history.length === 1) {\n return null;\n }\n const previousKey = state.history[state.history.length - 2].key;\n const index = state.routes.findIndex(route => route.key === previousKey);\n if (index === -1) {\n return null;\n }\n return {\n ...state,\n history: state.history.slice(0, -1),\n index\n };\n }\n default:\n return BaseRouter.getStateForAction(state, action);\n }\n },\n shouldActionChangeFocus(action) {\n return action.type === 'NAVIGATE';\n },\n actionCreators: TabActions\n };\n return router;\n}\n//# sourceMappingURL=TabRouter.js.map","import { nanoid } from 'nanoid/non-secure';\nimport BaseRouter from './BaseRouter';\nexport const StackActions = {\n replace(name, params) {\n return {\n type: 'REPLACE',\n payload: {\n name,\n params\n }\n };\n },\n push(name, params) {\n return {\n type: 'PUSH',\n payload: {\n name,\n params\n }\n };\n },\n pop() {\n let count = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1;\n return {\n type: 'POP',\n payload: {\n count\n }\n };\n },\n popToTop() {\n return {\n type: 'POP_TO_TOP'\n };\n }\n};\nexport default function StackRouter(options) {\n const router = {\n ...BaseRouter,\n type: 'stack',\n getInitialState(_ref) {\n let {\n routeNames,\n routeParamList\n } = _ref;\n const initialRouteName = options.initialRouteName !== undefined && routeNames.includes(options.initialRouteName) ? options.initialRouteName : routeNames[0];\n return {\n stale: false,\n type: 'stack',\n key: `stack-${nanoid()}`,\n index: 0,\n routeNames,\n routes: [{\n key: `${initialRouteName}-${nanoid()}`,\n name: initialRouteName,\n params: routeParamList[initialRouteName]\n }]\n };\n },\n getRehydratedState(partialState, _ref2) {\n let {\n routeNames,\n routeParamList\n } = _ref2;\n let state = partialState;\n if (state.stale === false) {\n return state;\n }\n const routes = state.routes.filter(route => routeNames.includes(route.name)).map(route => ({\n ...route,\n key: route.key || `${route.name}-${nanoid()}`,\n params: routeParamList[route.name] !== undefined ? {\n ...routeParamList[route.name],\n ...route.params\n } : route.params\n }));\n if (routes.length === 0) {\n const initialRouteName = options.initialRouteName !== undefined ? options.initialRouteName : routeNames[0];\n routes.push({\n key: `${initialRouteName}-${nanoid()}`,\n name: initialRouteName,\n params: routeParamList[initialRouteName]\n });\n }\n return {\n stale: false,\n type: 'stack',\n key: `stack-${nanoid()}`,\n index: routes.length - 1,\n routeNames,\n routes\n };\n },\n getStateForRouteNamesChange(state, _ref3) {\n let {\n routeNames,\n routeParamList,\n routeKeyChanges\n } = _ref3;\n const routes = state.routes.filter(route => routeNames.includes(route.name) && !routeKeyChanges.includes(route.name));\n if (routes.length === 0) {\n const initialRouteName = options.initialRouteName !== undefined && routeNames.includes(options.initialRouteName) ? options.initialRouteName : routeNames[0];\n routes.push({\n key: `${initialRouteName}-${nanoid()}`,\n name: initialRouteName,\n params: routeParamList[initialRouteName]\n });\n }\n return {\n ...state,\n routeNames,\n routes,\n index: Math.min(state.index, routes.length - 1)\n };\n },\n getStateForRouteFocus(state, key) {\n const index = state.routes.findIndex(r => r.key === key);\n if (index === -1 || index === state.index) {\n return state;\n }\n return {\n ...state,\n index,\n routes: state.routes.slice(0, index + 1)\n };\n },\n getStateForAction(state, action, options) {\n const {\n routeParamList\n } = options;\n switch (action.type) {\n case 'REPLACE':\n {\n const index = action.target === state.key && action.source ? state.routes.findIndex(r => r.key === action.source) : state.index;\n if (index === -1) {\n return null;\n }\n const {\n name,\n key,\n params\n } = action.payload;\n if (!state.routeNames.includes(name)) {\n return null;\n }\n return {\n ...state,\n routes: state.routes.map((route, i) => i === index ? {\n key: key !== undefined ? key : `${name}-${nanoid()}`,\n name,\n params: routeParamList[name] !== undefined ? {\n ...routeParamList[name],\n ...params\n } : params\n } : route)\n };\n }\n case 'PUSH':\n if (state.routeNames.includes(action.payload.name)) {\n const getId = options.routeGetIdList[action.payload.name];\n const id = getId === null || getId === void 0 ? void 0 : getId({\n params: action.payload.params\n });\n const route = id ? state.routes.find(route => route.name === action.payload.name && id === (getId === null || getId === void 0 ? void 0 : getId({\n params: route.params\n }))) : undefined;\n let routes;\n if (route) {\n routes = state.routes.filter(r => r.key !== route.key);\n routes.push({\n ...route,\n params: routeParamList[action.payload.name] !== undefined ? {\n ...routeParamList[action.payload.name],\n ...action.payload.params\n } : action.payload.params\n });\n } else {\n routes = [...state.routes, {\n key: `${action.payload.name}-${nanoid()}`,\n name: action.payload.name,\n params: routeParamList[action.payload.name] !== undefined ? {\n ...routeParamList[action.payload.name],\n ...action.payload.params\n } : action.payload.params\n }];\n }\n return {\n ...state,\n index: routes.length - 1,\n routes\n };\n }\n return null;\n case 'POP':\n {\n const index = action.target === state.key && action.source ? state.routes.findIndex(r => r.key === action.source) : state.index;\n if (index > 0) {\n const count = Math.max(index - action.payload.count + 1, 1);\n const routes = state.routes.slice(0, count).concat(state.routes.slice(index + 1));\n return {\n ...state,\n index: routes.length - 1,\n routes\n };\n }\n return null;\n }\n case 'POP_TO_TOP':\n return router.getStateForAction(state, {\n type: 'POP',\n payload: {\n count: state.routes.length - 1\n }\n }, options);\n case 'NAVIGATE':\n if (action.payload.name !== undefined && !state.routeNames.includes(action.payload.name)) {\n return null;\n }\n if (action.payload.key || action.payload.name) {\n // If the route already exists, navigate to that\n let index = -1;\n const getId =\n // `getId` and `key` can't be used together\n action.payload.key === undefined && action.payload.name !== undefined ? options.routeGetIdList[action.payload.name] : undefined;\n const id = getId === null || getId === void 0 ? void 0 : getId({\n params: action.payload.params\n });\n if (id) {\n index = state.routes.findIndex(route => route.name === action.payload.name && id === (getId === null || getId === void 0 ? void 0 : getId({\n params: route.params\n })));\n } else if (state.routes[state.index].name === action.payload.name && action.payload.key === undefined || state.routes[state.index].key === action.payload.key) {\n index = state.index;\n } else {\n for (let i = state.routes.length - 1; i >= 0; i--) {\n if (state.routes[i].name === action.payload.name && action.payload.key === undefined || state.routes[i].key === action.payload.key) {\n index = i;\n break;\n }\n }\n }\n if (index === -1 && action.payload.key && action.payload.name === undefined) {\n return null;\n }\n if (index === -1 && action.payload.name !== undefined) {\n const routes = [...state.routes, {\n key: action.payload.key ?? `${action.payload.name}-${nanoid()}`,\n name: action.payload.name,\n path: action.payload.path,\n params: routeParamList[action.payload.name] !== undefined ? {\n ...routeParamList[action.payload.name],\n ...action.payload.params\n } : action.payload.params\n }];\n return {\n ...state,\n routes,\n index: routes.length - 1\n };\n }\n const route = state.routes[index];\n let params;\n if (action.payload.merge) {\n params = action.payload.params !== undefined || routeParamList[route.name] !== undefined ? {\n ...routeParamList[route.name],\n ...route.params,\n ...action.payload.params\n } : route.params;\n } else {\n params = routeParamList[route.name] !== undefined ? {\n ...routeParamList[route.name],\n ...action.payload.params\n } : action.payload.params;\n }\n return {\n ...state,\n index,\n routes: [...state.routes.slice(0, index), params !== route.params || action.payload.path && action.payload.path !== route.path ? {\n ...route,\n path: action.payload.path ?? route.path,\n params\n } : state.routes[index]]\n };\n }\n return null;\n case 'GO_BACK':\n if (state.index > 0) {\n return router.getStateForAction(state, {\n type: 'POP',\n payload: {\n count: 1\n },\n target: action.target,\n source: action.source\n }, options);\n }\n return null;\n default:\n return BaseRouter.getStateForAction(state, action);\n }\n },\n actionCreators: StackActions\n };\n return router;\n}\n//# sourceMappingURL=StackRouter.js.map","export {};\n//# sourceMappingURL=types.js.map","export default function checkDuplicateRouteNames(state) {\n const duplicates = [];\n const getRouteNames = (location, state) => {\n state.routes.forEach(route => {\n var _route$state, _route$state$routeNam;\n const currentLocation = location ? `${location} > ${route.name}` : route.name;\n (_route$state = route.state) === null || _route$state === void 0 ? void 0 : (_route$state$routeNam = _route$state.routeNames) === null || _route$state$routeNam === void 0 ? void 0 : _route$state$routeNam.forEach(routeName => {\n if (routeName === route.name) {\n duplicates.push([currentLocation, `${currentLocation} > ${route.name}`]);\n }\n });\n if (route.state) {\n getRouteNames(currentLocation, route.state);\n }\n });\n };\n getRouteNames('', state);\n return duplicates;\n}\n//# sourceMappingURL=checkDuplicateRouteNames.js.map","const checkSerializableWithoutCircularReference = (o, seen, location) => {\n if (o === undefined || o === null || typeof o === 'boolean' || typeof o === 'number' || typeof o === 'string') {\n return {\n serializable: true\n };\n }\n if (Object.prototype.toString.call(o) !== '[object Object]' && !Array.isArray(o)) {\n return {\n serializable: false,\n location,\n reason: typeof o === 'function' ? 'Function' : String(o)\n };\n }\n if (seen.has(o)) {\n return {\n serializable: false,\n reason: 'Circular reference',\n location\n };\n }\n seen.add(o);\n if (Array.isArray(o)) {\n for (let i = 0; i < o.length; i++) {\n const childResult = checkSerializableWithoutCircularReference(o[i], new Set(seen), [...location, i]);\n if (!childResult.serializable) {\n return childResult;\n }\n }\n } else {\n for (const key in o) {\n const childResult = checkSerializableWithoutCircularReference(o[key], new Set(seen), [...location, key]);\n if (!childResult.serializable) {\n return childResult;\n }\n }\n }\n return {\n serializable: true\n };\n};\nexport default function checkSerializable(o) {\n return checkSerializableWithoutCircularReference(o, new Set(), []);\n}\n//# sourceMappingURL=checkSerializable.js.map","import { CommonActions } from '@react-navigation/routers';\nexport const NOT_INITIALIZED_ERROR = \"The 'navigation' object hasn't been initialized yet. This might happen if you don't have a navigator mounted, or if the navigator hasn't finished mounting. See https://reactnavigation.org/docs/navigating-without-navigation-prop#handling-initialization for more details.\";\nexport default function createNavigationContainerRef() {\n const methods = [...Object.keys(CommonActions), 'addListener', 'removeListener', 'resetRoot', 'dispatch', 'isFocused', 'canGoBack', 'getRootState', 'getState', 'getParent', 'getCurrentRoute', 'getCurrentOptions'];\n const listeners = {};\n const removeListener = (event, callback) => {\n if (listeners[event]) {\n listeners[event] = listeners[event].filter(cb => cb !== callback);\n }\n };\n let current = null;\n const ref = {\n get current() {\n return current;\n },\n set current(value) {\n current = value;\n if (value != null) {\n Object.entries(listeners).forEach(_ref => {\n let [event, callbacks] = _ref;\n callbacks.forEach(callback => {\n value.addListener(event, callback);\n });\n });\n }\n },\n isReady: () => {\n if (current == null) {\n return false;\n }\n return current.isReady();\n },\n ...methods.reduce((acc, name) => {\n acc[name] = function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n if (current == null) {\n switch (name) {\n case 'addListener':\n {\n const [event, callback] = args;\n listeners[event] = listeners[event] || [];\n listeners[event].push(callback);\n return () => removeListener(event, callback);\n }\n case 'removeListener':\n {\n const [event, callback] = args;\n removeListener(event, callback);\n break;\n }\n default:\n console.error(NOT_INITIALIZED_ERROR);\n }\n } else {\n // @ts-expect-error: this is ok\n return current[name](...args);\n }\n };\n return acc;\n }, {})\n };\n return ref;\n}\n//# sourceMappingURL=createNavigationContainerRef.js.map","import * as React from 'react';\nconst MULTIPLE_NAVIGATOR_ERROR = `Another navigator is already registered for this container. You likely have multiple navigators under a single \"NavigationContainer\" or \"Screen\". Make sure each navigator is under a separate \"Screen\" container. See https://reactnavigation.org/docs/nesting-navigators for a guide on nesting.`;\nexport const SingleNavigatorContext = /*#__PURE__*/React.createContext(undefined);\n\n/**\n * Component which ensures that there's only one navigator nested under it.\n */\nexport default function EnsureSingleNavigator(_ref) {\n let {\n children\n } = _ref;\n const navigatorKeyRef = React.useRef();\n const value = React.useMemo(() => ({\n register(key) {\n const currentKey = navigatorKeyRef.current;\n if (currentKey !== undefined && key !== currentKey) {\n throw new Error(MULTIPLE_NAVIGATOR_ERROR);\n }\n navigatorKeyRef.current = key;\n },\n unregister(key) {\n const currentKey = navigatorKeyRef.current;\n if (key !== currentKey) {\n return;\n }\n navigatorKeyRef.current = undefined;\n }\n }), []);\n return /*#__PURE__*/React.createElement(SingleNavigatorContext.Provider, {\n value: value\n }, children);\n}\n//# sourceMappingURL=EnsureSingleNavigator.js.map","export default function findFocusedRoute(state) {\n var _current2, _current3;\n let current = state;\n while (((_current = current) === null || _current === void 0 ? void 0 : _current.routes[current.index ?? 0].state) != null) {\n var _current;\n current = current.routes[current.index ?? 0].state;\n }\n const route = (_current2 = current) === null || _current2 === void 0 ? void 0 : _current2.routes[((_current3 = current) === null || _current3 === void 0 ? void 0 : _current3.index) ?? 0];\n return route;\n}\n//# sourceMappingURL=findFocusedRoute.js.map","import * as React from 'react';\n/**\n * Context which holds the required helpers needed to build nested navigators.\n */\nconst NavigationBuilderContext = /*#__PURE__*/React.createContext({\n onDispatchAction: () => undefined,\n onOptionsChange: () => undefined\n});\nexport default NavigationBuilderContext;\n//# sourceMappingURL=NavigationBuilderContext.js.map","import * as React from 'react';\n/**\n * Context which holds the route prop for a screen.\n */\nconst NavigationContainerRefContext = /*#__PURE__*/React.createContext(undefined);\nexport default NavigationContainerRefContext;\n//# sourceMappingURL=NavigationContainerRefContext.js.map","import * as React from 'react';\n/**\n * Context which holds the navigation prop for a screen.\n */\nconst NavigationContext = /*#__PURE__*/React.createContext(undefined);\nexport default NavigationContext;\n//# sourceMappingURL=NavigationContext.js.map","import * as React from 'react';\n\n/**\n * Context which holds the route prop for a screen.\n */\nconst NavigationRouteContext = /*#__PURE__*/React.createContext(undefined);\nexport default NavigationRouteContext;\n//# sourceMappingURL=NavigationRouteContext.js.map","import * as React from 'react';\nconst MISSING_CONTEXT_ERROR = \"Couldn't find a navigation context. Have you wrapped your app with 'NavigationContainer'? See https://reactnavigation.org/docs/getting-started for setup instructions.\";\nexport default /*#__PURE__*/React.createContext({\n isDefault: true,\n get getKey() {\n throw new Error(MISSING_CONTEXT_ERROR);\n },\n get setKey() {\n throw new Error(MISSING_CONTEXT_ERROR);\n },\n get getState() {\n throw new Error(MISSING_CONTEXT_ERROR);\n },\n get setState() {\n throw new Error(MISSING_CONTEXT_ERROR);\n },\n get getIsInitial() {\n throw new Error(MISSING_CONTEXT_ERROR);\n }\n});\n//# sourceMappingURL=NavigationStateContext.js.map","import * as React from 'react';\nconst UnhandledActionContext = /*#__PURE__*/React.createContext(undefined);\nexport default UnhandledActionContext;\n//# sourceMappingURL=UnhandledActionContext.js.map","import * as React from 'react';\n/**\n * Hook which lets child navigators add action listeners.\n */\nexport default function useChildListeners() {\n const {\n current: listeners\n } = React.useRef({\n action: [],\n focus: []\n });\n const addListener = React.useCallback((type, listener) => {\n listeners[type].push(listener);\n let removed = false;\n return () => {\n const index = listeners[type].indexOf(listener);\n if (!removed && index > -1) {\n removed = true;\n listeners[type].splice(index, 1);\n }\n };\n }, [listeners]);\n return {\n listeners,\n addListener\n };\n}\n//# sourceMappingURL=useChildListeners.js.map","import * as React from 'react';\n/**\n * Hook to manage the event system used by the navigator to notify screens of various events.\n */\nexport default function useEventEmitter(listen) {\n const listenRef = React.useRef(listen);\n React.useEffect(() => {\n listenRef.current = listen;\n });\n const listeners = React.useRef(Object.create(null));\n const create = React.useCallback(target => {\n const removeListener = (type, callback) => {\n const callbacks = listeners.current[type] ? listeners.current[type][target] : undefined;\n if (!callbacks) {\n return;\n }\n const index = callbacks.indexOf(callback);\n if (index > -1) {\n callbacks.splice(index, 1);\n }\n };\n const addListener = (type, callback) => {\n listeners.current[type] = listeners.current[type] || {};\n listeners.current[type][target] = listeners.current[type][target] || [];\n listeners.current[type][target].push(callback);\n let removed = false;\n return () => {\n // Prevent removing other listeners when unsubscribing same listener multiple times\n if (!removed) {\n removed = true;\n removeListener(type, callback);\n }\n };\n };\n return {\n addListener,\n removeListener\n };\n }, []);\n const emit = React.useCallback(_ref => {\n var _items$target, _listenRef$current;\n let {\n type,\n data,\n target,\n canPreventDefault\n } = _ref;\n const items = listeners.current[type] || {};\n\n // Copy the current list of callbacks in case they are mutated during execution\n const callbacks = target !== undefined ? (_items$target = items[target]) === null || _items$target === void 0 ? void 0 : _items$target.slice() : [].concat(...Object.keys(items).map(t => items[t])).filter((cb, i, self) => self.lastIndexOf(cb) === i);\n const event = {\n get type() {\n return type;\n }\n };\n if (target !== undefined) {\n Object.defineProperty(event, 'target', {\n enumerable: true,\n get() {\n return target;\n }\n });\n }\n if (data !== undefined) {\n Object.defineProperty(event, 'data', {\n enumerable: true,\n get() {\n return data;\n }\n });\n }\n if (canPreventDefault) {\n let defaultPrevented = false;\n Object.defineProperties(event, {\n defaultPrevented: {\n enumerable: true,\n get() {\n return defaultPrevented;\n }\n },\n preventDefault: {\n enumerable: true,\n value() {\n defaultPrevented = true;\n }\n }\n });\n }\n (_listenRef$current = listenRef.current) === null || _listenRef$current === void 0 ? void 0 : _listenRef$current.call(listenRef, event);\n callbacks === null || callbacks === void 0 ? void 0 : callbacks.forEach(cb => cb(event));\n return event;\n }, []);\n return React.useMemo(() => ({\n create,\n emit\n }), [create, emit]);\n}\n//# sourceMappingURL=useEventEmitter.js.map","import * as React from 'react';\n/**\n * Hook which lets child navigators add getters to be called for obtaining rehydrated state.\n */\nexport default function useKeyedChildListeners() {\n const {\n current: keyedListeners\n } = React.useRef(Object.assign(Object.create(null), {\n getState: {},\n beforeRemove: {}\n }));\n const addKeyedListener = React.useCallback((type, key, listener) => {\n // @ts-expect-error: according to ref stated above you can use `key` to index type\n keyedListeners[type][key] = listener;\n return () => {\n // @ts-expect-error: according to ref stated above you can use `key` to index type\n keyedListeners[type][key] = undefined;\n };\n }, [keyedListeners]);\n return {\n keyedListeners,\n addKeyedListener\n };\n}\n//# sourceMappingURL=useKeyedChildListeners.js.map","import * as React from 'react';\nimport NavigationBuilderContext from './NavigationBuilderContext';\nimport NavigationStateContext from './NavigationStateContext';\nexport default function useOptionsGetters(_ref) {\n let {\n key,\n options,\n navigation\n } = _ref;\n const optionsRef = React.useRef(options);\n const optionsGettersFromChildRef = React.useRef({});\n const {\n onOptionsChange\n } = React.useContext(NavigationBuilderContext);\n const {\n addOptionsGetter: parentAddOptionsGetter\n } = React.useContext(NavigationStateContext);\n const optionsChangeListener = React.useCallback(() => {\n const isFocused = (navigation === null || navigation === void 0 ? void 0 : navigation.isFocused()) ?? true;\n const hasChildren = Object.keys(optionsGettersFromChildRef.current).length;\n if (isFocused && !hasChildren) {\n onOptionsChange(optionsRef.current ?? {});\n }\n }, [navigation, onOptionsChange]);\n React.useEffect(() => {\n optionsRef.current = options;\n optionsChangeListener();\n return navigation === null || navigation === void 0 ? void 0 : navigation.addListener('focus', optionsChangeListener);\n }, [navigation, options, optionsChangeListener]);\n const getOptionsFromListener = React.useCallback(() => {\n for (let key in optionsGettersFromChildRef.current) {\n if (optionsGettersFromChildRef.current.hasOwnProperty(key)) {\n var _optionsGettersFromCh, _optionsGettersFromCh2;\n const result = (_optionsGettersFromCh = (_optionsGettersFromCh2 = optionsGettersFromChildRef.current)[key]) === null || _optionsGettersFromCh === void 0 ? void 0 : _optionsGettersFromCh.call(_optionsGettersFromCh2);\n\n // null means unfocused route\n if (result !== null) {\n return result;\n }\n }\n }\n return null;\n }, []);\n const getCurrentOptions = React.useCallback(() => {\n const isFocused = (navigation === null || navigation === void 0 ? void 0 : navigation.isFocused()) ?? true;\n if (!isFocused) {\n return null;\n }\n const optionsFromListener = getOptionsFromListener();\n if (optionsFromListener !== null) {\n return optionsFromListener;\n }\n return optionsRef.current;\n }, [navigation, getOptionsFromListener]);\n React.useEffect(() => {\n return parentAddOptionsGetter === null || parentAddOptionsGetter === void 0 ? void 0 : parentAddOptionsGetter(key, getCurrentOptions);\n }, [getCurrentOptions, parentAddOptionsGetter, key]);\n const addOptionsGetter = React.useCallback((key, getter) => {\n optionsGettersFromChildRef.current[key] = getter;\n optionsChangeListener();\n return () => {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete optionsGettersFromChildRef.current[key];\n optionsChangeListener();\n };\n }, [optionsChangeListener]);\n return {\n addOptionsGetter,\n getCurrentOptions\n };\n}\n//# sourceMappingURL=useOptionsGetters.js.map","import * as React from 'react';\nconst MISSING_CONTEXT_ERROR = \"Couldn't find a schedule context.\";\nexport const ScheduleUpdateContext = /*#__PURE__*/React.createContext({\n scheduleUpdate() {\n throw new Error(MISSING_CONTEXT_ERROR);\n },\n flushUpdates() {\n throw new Error(MISSING_CONTEXT_ERROR);\n }\n});\n\n/**\n * When screen config changes, we want to update the navigator in the same update phase.\n * However, navigation state is in the root component and React won't let us update it from a child.\n * This is a workaround for that, the scheduled update is stored in the ref without actually calling setState.\n * It lets all subsequent updates access the latest state so it stays correct.\n * Then we call setState during after the component updates.\n */\nexport default function useScheduleUpdate(callback) {\n const {\n scheduleUpdate,\n flushUpdates\n } = React.useContext(ScheduleUpdateContext);\n scheduleUpdate(callback);\n React.useEffect(flushUpdates);\n}\n//# sourceMappingURL=useScheduleUpdate.js.map","import * as React from 'react';\nconst UNINTIALIZED_STATE = {};\n\n/**\n * This is definitely not compatible with concurrent mode, but we don't have a solution for sync state yet.\n */\nexport default function useSyncState(initialState) {\n const stateRef = React.useRef(UNINTIALIZED_STATE);\n const isSchedulingRef = React.useRef(false);\n const isMountedRef = React.useRef(true);\n React.useEffect(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n };\n }, []);\n if (stateRef.current === UNINTIALIZED_STATE) {\n stateRef.current =\n // @ts-expect-error: initialState is a function, but TypeScript doesn't think so\n typeof initialState === 'function' ? initialState() : initialState;\n }\n const [trackingState, setTrackingState] = React.useState(stateRef.current);\n const getState = React.useCallback(() => stateRef.current, []);\n const setState = React.useCallback(state => {\n if (state === stateRef.current || !isMountedRef.current) {\n return;\n }\n stateRef.current = state;\n if (!isSchedulingRef.current) {\n setTrackingState(state);\n }\n }, []);\n const scheduleUpdate = React.useCallback(callback => {\n isSchedulingRef.current = true;\n try {\n callback();\n } finally {\n isSchedulingRef.current = false;\n }\n }, []);\n const flushUpdates = React.useCallback(() => {\n if (!isMountedRef.current) {\n return;\n }\n\n // Make sure that the tracking state is up-to-date.\n // We call it unconditionally, but React should skip the update if state is unchanged.\n setTrackingState(stateRef.current);\n }, []);\n\n // If we're rendering and the tracking state is out of date, update it immediately\n // This will make sure that our updates are applied as early as possible.\n if (trackingState !== stateRef.current) {\n setTrackingState(stateRef.current);\n }\n const state = stateRef.current;\n React.useDebugValue(state);\n return [state, getState, setState, scheduleUpdate, flushUpdates];\n}\n//# sourceMappingURL=useSyncState.js.map","import Group from './Group';\nimport Screen from './Screen';\n/**\n * Higher order component to create a `Navigator` and `Screen` pair.\n * Custom navigators should wrap the navigator component in `createNavigator` before exporting.\n *\n * @param Navigator The navigtor component to wrap.\n * @returns Factory method to create a `Navigator` and `Screen` pair.\n */\nexport default function createNavigatorFactory(Navigator) {\n return function () {\n if (arguments[0] !== undefined) {\n throw new Error(\"Creating a navigator doesn't take an argument. Maybe you are trying to use React Navigation 4 API? See https://reactnavigation.org/docs/hello-react-navigation for the latest API and guides.\");\n }\n return {\n Navigator,\n Group,\n Screen\n };\n };\n}\n//# sourceMappingURL=createNavigatorFactory.js.map","/**\n * Empty component used for grouping screen configs.\n */\nexport default function Group(_) {\n /* istanbul ignore next */\n return null;\n}\n//# sourceMappingURL=Group.js.map","/**\n * Empty component used for specifying route configuration.\n */\nexport default function Screen(_) {\n /* istanbul ignore next */\n return null;\n}\n//# sourceMappingURL=Screen.js.map","import * as React from 'react';\n\n/**\n * Context which holds the values for the current navigation tree.\n * Intended for use in SSR. This is not safe to use on the client.\n */\nconst CurrentRenderContext = /*#__PURE__*/React.createContext(undefined);\nexport default CurrentRenderContext;\n//# sourceMappingURL=CurrentRenderContext.js.map","export default function getActionFromState(state, options) {\n var _normalizedConfig$scr;\n // Create a normalized configs object which will be easier to use\n const normalizedConfig = options ? createNormalizedConfigItem(options) : {};\n const routes = state.index != null ? state.routes.slice(0, state.index + 1) : state.routes;\n if (routes.length === 0) {\n return undefined;\n }\n if (!(routes.length === 1 && routes[0].key === undefined || routes.length === 2 && routes[0].key === undefined && routes[0].name === (normalizedConfig === null || normalizedConfig === void 0 ? void 0 : normalizedConfig.initialRouteName) && routes[1].key === undefined)) {\n return {\n type: 'RESET',\n payload: state\n };\n }\n const route = state.routes[state.index ?? state.routes.length - 1];\n let current = route === null || route === void 0 ? void 0 : route.state;\n let config = normalizedConfig === null || normalizedConfig === void 0 ? void 0 : (_normalizedConfig$scr = normalizedConfig.screens) === null || _normalizedConfig$scr === void 0 ? void 0 : _normalizedConfig$scr[route === null || route === void 0 ? void 0 : route.name];\n let params = {\n ...route.params\n };\n let payload = route ? {\n name: route.name,\n path: route.path,\n params\n } : undefined;\n while (current) {\n var _config, _config2, _config2$screens;\n if (current.routes.length === 0) {\n return undefined;\n }\n const routes = current.index != null ? current.routes.slice(0, current.index + 1) : current.routes;\n const route = routes[routes.length - 1];\n\n // Explicitly set to override existing value when merging params\n Object.assign(params, {\n initial: undefined,\n screen: undefined,\n params: undefined,\n state: undefined\n });\n if (routes.length === 1 && routes[0].key === undefined) {\n params.initial = true;\n params.screen = route.name;\n } else if (routes.length === 2 && routes[0].key === undefined && routes[0].name === ((_config = config) === null || _config === void 0 ? void 0 : _config.initialRouteName) && routes[1].key === undefined) {\n params.initial = false;\n params.screen = route.name;\n } else {\n params.state = current;\n break;\n }\n if (route.state) {\n params.params = {\n ...route.params\n };\n params = params.params;\n } else {\n params.path = route.path;\n params.params = route.params;\n }\n current = route.state;\n config = (_config2 = config) === null || _config2 === void 0 ? void 0 : (_config2$screens = _config2.screens) === null || _config2$screens === void 0 ? void 0 : _config2$screens[route.name];\n }\n if (!payload) {\n return;\n }\n\n // Try to construct payload for a `NAVIGATE` action from the state\n // This lets us preserve the navigation state and not lose it\n return {\n type: 'NAVIGATE',\n payload\n };\n}\nconst createNormalizedConfigItem = config => typeof config === 'object' && config != null ? {\n initialRouteName: config.initialRouteName,\n screens: config.screens != null ? createNormalizedConfigs(config.screens) : undefined\n} : {};\nconst createNormalizedConfigs = options => Object.entries(options).reduce((acc, _ref) => {\n let [k, v] = _ref;\n acc[k] = createNormalizedConfigItem(v);\n return acc;\n}, {});\n//# sourceMappingURL=getActionFromState.js.map","import { CHILD_STATE } from './useRouteCache';\nexport default function getFocusedRouteNameFromRoute(route) {\n // @ts-expect-error: this isn't in type definitions coz we want this private\n const state = route[CHILD_STATE] ?? route.state;\n const params = route.params;\n const routeName = state ?\n // Get the currently active route name in the nested navigator\n state.routes[\n // If we have a partial state without index, for tab/drawer, first screen will be focused one, and last for stack\n // The type property will only exist for rehydrated state and not for state from deep link\n state.index ?? (typeof state.type === 'string' && state.type !== 'stack' ? 0 : state.routes.length - 1)].name :\n // If state doesn't exist, we need to default to `screen` param if available\n typeof (params === null || params === void 0 ? void 0 : params.screen) === 'string' ? params.screen : undefined;\n return routeName;\n}\n//# sourceMappingURL=getFocusedRouteNameFromRoute.js.map","import * as React from 'react';\n/**\n * Utilites such as `getFocusedRouteNameFromRoute` need to access state.\n * So we need a way to suppress the warning for those use cases.\n * This is fine since they are internal utilities and this is not public API.\n */\nexport const CHILD_STATE = Symbol('CHILD_STATE');\n\n/**\n * Hook to cache route props for each screen in the navigator.\n * This lets add warnings and modifications to the route object but keep references between renders.\n */\nexport default function useRouteCache(routes) {\n // Cache object which holds route objects for each screen\n const cache = React.useMemo(() => ({\n current: new Map()\n }), []);\n if (process.env.NODE_ENV === 'production') {\n // We don't want the overhead of creating extra maps every render in prod\n return routes;\n }\n cache.current = routes.reduce((acc, route) => {\n const previous = cache.current.get(route);\n if (previous) {\n // If a cached route object already exists, reuse it\n acc.set(route, previous);\n } else {\n const {\n state,\n ...proxy\n } = route;\n Object.defineProperty(proxy, CHILD_STATE, {\n enumerable: false,\n value: state\n });\n acc.set(route, proxy);\n }\n return acc;\n }, new Map());\n return Array.from(cache.current.values());\n}\n//# sourceMappingURL=useRouteCache.js.map","import * as queryString from 'query-string';\nimport fromEntries from './fromEntries';\nimport validatePathConfig from './validatePathConfig';\nconst getActiveRoute = state => {\n const route = typeof state.index === 'number' ? state.routes[state.index] : state.routes[state.routes.length - 1];\n if (route.state) {\n return getActiveRoute(route.state);\n }\n return route;\n};\n\n/**\n * Utility to serialize a navigation state object to a path string.\n *\n * @example\n * ```js\n * getPathFromState(\n * {\n * routes: [\n * {\n * name: 'Chat',\n * params: { author: 'Jane', id: 42 },\n * },\n * ],\n * },\n * {\n * screens: {\n * Chat: {\n * path: 'chat/:author/:id',\n * stringify: { author: author => author.toLowerCase() }\n * }\n * }\n * }\n * )\n * ```\n *\n * @param state Navigation state to serialize.\n * @param options Extra options to fine-tune how to serialize the path.\n * @returns Path representing the state, e.g. /foo/bar?count=42.\n */\nexport default function getPathFromState(state, options) {\n if (state == null) {\n throw Error(\"Got 'undefined' for the navigation state. You must pass a valid state object.\");\n }\n if (options) {\n validatePathConfig(options);\n }\n\n // Create a normalized configs object which will be easier to use\n const configs = options !== null && options !== void 0 && options.screens ? createNormalizedConfigs(options === null || options === void 0 ? void 0 : options.screens) : {};\n let path = '/';\n let current = state;\n const allParams = {};\n while (current) {\n let index = typeof current.index === 'number' ? current.index : 0;\n let route = current.routes[index];\n let pattern;\n let focusedParams;\n let focusedRoute = getActiveRoute(state);\n let currentOptions = configs;\n\n // Keep all the route names that appeared during going deeper in config in case the pattern is resolved to undefined\n let nestedRouteNames = [];\n let hasNext = true;\n while (route.name in currentOptions && hasNext) {\n pattern = currentOptions[route.name].pattern;\n nestedRouteNames.push(route.name);\n if (route.params) {\n var _currentOptions$route;\n const stringify = (_currentOptions$route = currentOptions[route.name]) === null || _currentOptions$route === void 0 ? void 0 : _currentOptions$route.stringify;\n const currentParams = fromEntries(Object.entries(route.params).map(_ref => {\n let [key, value] = _ref;\n return [key, stringify !== null && stringify !== void 0 && stringify[key] ? stringify[key](value) : String(value)];\n }));\n if (pattern) {\n Object.assign(allParams, currentParams);\n }\n if (focusedRoute === route) {\n var _pattern;\n // If this is the focused route, keep the params for later use\n // We save it here since it's been stringified already\n focusedParams = {\n ...currentParams\n };\n (_pattern = pattern) === null || _pattern === void 0 ? void 0 : _pattern.split('/').filter(p => p.startsWith(':'))\n // eslint-disable-next-line no-loop-func\n .forEach(p => {\n const name = getParamName(p);\n\n // Remove the params present in the pattern since we'll only use the rest for query string\n if (focusedParams) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete focusedParams[name];\n }\n });\n }\n }\n\n // If there is no `screens` property or no nested state, we return pattern\n if (!currentOptions[route.name].screens || route.state === undefined) {\n hasNext = false;\n } else {\n index = typeof route.state.index === 'number' ? route.state.index : route.state.routes.length - 1;\n const nextRoute = route.state.routes[index];\n const nestedConfig = currentOptions[route.name].screens;\n\n // if there is config for next route name, we go deeper\n if (nestedConfig && nextRoute.name in nestedConfig) {\n route = nextRoute;\n currentOptions = nestedConfig;\n } else {\n // If not, there is no sense in going deeper in config\n hasNext = false;\n }\n }\n }\n if (pattern === undefined) {\n pattern = nestedRouteNames.join('/');\n }\n if (currentOptions[route.name] !== undefined) {\n path += pattern.split('/').map(p => {\n const name = getParamName(p);\n\n // We don't know what to show for wildcard patterns\n // Showing the route name seems ok, though whatever we show here will be incorrect\n // Since the page doesn't actually exist\n if (p === '*') {\n return route.name;\n }\n\n // If the path has a pattern for a param, put the param in the path\n if (p.startsWith(':')) {\n const value = allParams[name];\n if (value === undefined && p.endsWith('?')) {\n // Optional params without value assigned in route.params should be ignored\n return '';\n }\n return encodeURIComponent(value);\n }\n return encodeURIComponent(p);\n }).join('/');\n } else {\n path += encodeURIComponent(route.name);\n }\n if (!focusedParams) {\n focusedParams = focusedRoute.params;\n }\n if (route.state) {\n path += '/';\n } else if (focusedParams) {\n for (let param in focusedParams) {\n if (focusedParams[param] === 'undefined') {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete focusedParams[param];\n }\n }\n const query = queryString.stringify(focusedParams, {\n sort: false\n });\n if (query) {\n path += `?${query}`;\n }\n }\n current = route.state;\n }\n\n // Remove multiple as well as trailing slashes\n path = path.replace(/\\/+/g, '/');\n path = path.length > 1 ? path.replace(/\\/$/, '') : path;\n return path;\n}\nconst getParamName = pattern => pattern.replace(/^:/, '').replace(/\\?$/, '');\nconst joinPaths = function () {\n for (var _len = arguments.length, paths = new Array(_len), _key = 0; _key < _len; _key++) {\n paths[_key] = arguments[_key];\n }\n return [].concat(...paths.map(p => p.split('/'))).filter(Boolean).join('/');\n};\nconst createConfigItem = (config, parentPattern) => {\n var _pattern2;\n if (typeof config === 'string') {\n // If a string is specified as the value of the key(e.g. Foo: '/path'), use it as the pattern\n const pattern = parentPattern ? joinPaths(parentPattern, config) : config;\n return {\n pattern\n };\n }\n\n // If an object is specified as the value (e.g. Foo: { ... }),\n // It can have `path` property and `screens` prop which has nested configs\n let pattern;\n if (config.exact && config.path === undefined) {\n throw new Error(\"A 'path' needs to be specified when specifying 'exact: true'. If you don't want this screen in the URL, specify it as empty string, e.g. `path: ''`.\");\n }\n pattern = config.exact !== true ? joinPaths(parentPattern || '', config.path || '') : config.path || '';\n const screens = config.screens ? createNormalizedConfigs(config.screens, pattern) : undefined;\n return {\n // Normalize pattern to remove any leading, trailing slashes, duplicate slashes etc.\n pattern: (_pattern2 = pattern) === null || _pattern2 === void 0 ? void 0 : _pattern2.split('/').filter(Boolean).join('/'),\n stringify: config.stringify,\n screens\n };\n};\nconst createNormalizedConfigs = (options, pattern) => fromEntries(Object.entries(options).map(_ref2 => {\n let [name, c] = _ref2;\n const result = createConfigItem(c, pattern);\n return [name, result];\n}));\n//# sourceMappingURL=getPathFromState.js.map","'use strict';\nconst strictUriEncode = require('strict-uri-encode');\nconst decodeComponent = require('decode-uri-component');\nconst splitOnFirst = require('split-on-first');\nconst filterObject = require('filter-obj');\n\nconst isNullOrUndefined = value => value === null || value === undefined;\n\nconst encodeFragmentIdentifier = Symbol('encodeFragmentIdentifier');\n\nfunction encoderForArrayFormat(options) {\n\tswitch (options.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tconst index = result.length;\n\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, [encode(key, options), '[', index, ']'].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [\n\t\t\t\t\t...result,\n\t\t\t\t\t[encode(key, options), '[', encode(index, options), ']=', encode(value, options)].join('')\n\t\t\t\t];\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, [encode(key, options), '[]'].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [...result, [encode(key, options), '[]=', encode(value, options)].join('')];\n\t\t\t};\n\n\t\tcase 'colon-list-separator':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, [encode(key, options), ':list='].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [...result, [encode(key, options), ':list=', encode(value, options)].join('')];\n\t\t\t};\n\n\t\tcase 'comma':\n\t\tcase 'separator':\n\t\tcase 'bracket-separator': {\n\t\t\tconst keyValueSep = options.arrayFormat === 'bracket-separator' ?\n\t\t\t\t'[]=' :\n\t\t\t\t'=';\n\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\t// Translate null to an empty string so that it doesn't serialize as 'null'\n\t\t\t\tvalue = value === null ? '' : value;\n\n\t\t\t\tif (result.length === 0) {\n\t\t\t\t\treturn [[encode(key, options), keyValueSep, encode(value, options)].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [[result, encode(value, options)].join(options.arrayFormatSeparator)];\n\t\t\t};\n\t\t}\n\n\t\tdefault:\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, encode(key, options)];\n\t\t\t\t}\n\n\t\t\t\treturn [...result, [encode(key, options), '=', encode(value, options)].join('')];\n\t\t\t};\n\t}\n}\n\nfunction parserForArrayFormat(options) {\n\tlet result;\n\n\tswitch (options.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tresult = /\\[(\\d*)\\]$/.exec(key);\n\n\t\t\t\tkey = key.replace(/\\[\\d*\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = {};\n\t\t\t\t}\n\n\t\t\t\taccumulator[key][result[1]] = value;\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tresult = /(\\[\\])$/.exec(key);\n\t\t\t\tkey = key.replace(/\\[\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = [value];\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\n\t\tcase 'colon-list-separator':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tresult = /(:list)$/.exec(key);\n\t\t\t\tkey = key.replace(/:list$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = [value];\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\n\t\tcase 'comma':\n\t\tcase 'separator':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tconst isArray = typeof value === 'string' && value.includes(options.arrayFormatSeparator);\n\t\t\t\tconst isEncodedArray = (typeof value === 'string' && !isArray && decode(value, options).includes(options.arrayFormatSeparator));\n\t\t\t\tvalue = isEncodedArray ? decode(value, options) : value;\n\t\t\t\tconst newValue = isArray || isEncodedArray ? value.split(options.arrayFormatSeparator).map(item => decode(item, options)) : value === null ? value : decode(value, options);\n\t\t\t\taccumulator[key] = newValue;\n\t\t\t};\n\n\t\tcase 'bracket-separator':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tconst isArray = /(\\[\\])$/.test(key);\n\t\t\t\tkey = key.replace(/\\[\\]$/, '');\n\n\t\t\t\tif (!isArray) {\n\t\t\t\t\taccumulator[key] = value ? decode(value, options) : value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst arrayValue = value === null ?\n\t\t\t\t\t[] :\n\t\t\t\t\tvalue.split(options.arrayFormatSeparator).map(item => decode(item, options));\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = arrayValue;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], arrayValue);\n\t\t\t};\n\n\t\tdefault:\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\t}\n}\n\nfunction validateArrayFormatSeparator(value) {\n\tif (typeof value !== 'string' || value.length !== 1) {\n\t\tthrow new TypeError('arrayFormatSeparator must be single character string');\n\t}\n}\n\nfunction encode(value, options) {\n\tif (options.encode) {\n\t\treturn options.strict ? strictUriEncode(value) : encodeURIComponent(value);\n\t}\n\n\treturn value;\n}\n\nfunction decode(value, options) {\n\tif (options.decode) {\n\t\treturn decodeComponent(value);\n\t}\n\n\treturn value;\n}\n\nfunction keysSorter(input) {\n\tif (Array.isArray(input)) {\n\t\treturn input.sort();\n\t}\n\n\tif (typeof input === 'object') {\n\t\treturn keysSorter(Object.keys(input))\n\t\t\t.sort((a, b) => Number(a) - Number(b))\n\t\t\t.map(key => input[key]);\n\t}\n\n\treturn input;\n}\n\nfunction removeHash(input) {\n\tconst hashStart = input.indexOf('#');\n\tif (hashStart !== -1) {\n\t\tinput = input.slice(0, hashStart);\n\t}\n\n\treturn input;\n}\n\nfunction getHash(url) {\n\tlet hash = '';\n\tconst hashStart = url.indexOf('#');\n\tif (hashStart !== -1) {\n\t\thash = url.slice(hashStart);\n\t}\n\n\treturn hash;\n}\n\nfunction extract(input) {\n\tinput = removeHash(input);\n\tconst queryStart = input.indexOf('?');\n\tif (queryStart === -1) {\n\t\treturn '';\n\t}\n\n\treturn input.slice(queryStart + 1);\n}\n\nfunction parseValue(value, options) {\n\tif (options.parseNumbers && !Number.isNaN(Number(value)) && (typeof value === 'string' && value.trim() !== '')) {\n\t\tvalue = Number(value);\n\t} else if (options.parseBooleans && value !== null && (value.toLowerCase() === 'true' || value.toLowerCase() === 'false')) {\n\t\tvalue = value.toLowerCase() === 'true';\n\t}\n\n\treturn value;\n}\n\nfunction parse(query, options) {\n\toptions = Object.assign({\n\t\tdecode: true,\n\t\tsort: true,\n\t\tarrayFormat: 'none',\n\t\tarrayFormatSeparator: ',',\n\t\tparseNumbers: false,\n\t\tparseBooleans: false\n\t}, options);\n\n\tvalidateArrayFormatSeparator(options.arrayFormatSeparator);\n\n\tconst formatter = parserForArrayFormat(options);\n\n\t// Create an object with no prototype\n\tconst ret = Object.create(null);\n\n\tif (typeof query !== 'string') {\n\t\treturn ret;\n\t}\n\n\tquery = query.trim().replace(/^[?#&]/, '');\n\n\tif (!query) {\n\t\treturn ret;\n\t}\n\n\tfor (const param of query.split('&')) {\n\t\tif (param === '') {\n\t\t\tcontinue;\n\t\t}\n\n\t\tlet [key, value] = splitOnFirst(options.decode ? param.replace(/\\+/g, ' ') : param, '=');\n\n\t\t// Missing `=` should be `null`:\n\t\t// http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\t\tvalue = value === undefined ? null : ['comma', 'separator', 'bracket-separator'].includes(options.arrayFormat) ? value : decode(value, options);\n\t\tformatter(decode(key, options), value, ret);\n\t}\n\n\tfor (const key of Object.keys(ret)) {\n\t\tconst value = ret[key];\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tfor (const k of Object.keys(value)) {\n\t\t\t\tvalue[k] = parseValue(value[k], options);\n\t\t\t}\n\t\t} else {\n\t\t\tret[key] = parseValue(value, options);\n\t\t}\n\t}\n\n\tif (options.sort === false) {\n\t\treturn ret;\n\t}\n\n\treturn (options.sort === true ? Object.keys(ret).sort() : Object.keys(ret).sort(options.sort)).reduce((result, key) => {\n\t\tconst value = ret[key];\n\t\tif (Boolean(value) && typeof value === 'object' && !Array.isArray(value)) {\n\t\t\t// Sort object keys, not values\n\t\t\tresult[key] = keysSorter(value);\n\t\t} else {\n\t\t\tresult[key] = value;\n\t\t}\n\n\t\treturn result;\n\t}, Object.create(null));\n}\n\nexports.extract = extract;\nexports.parse = parse;\n\nexports.stringify = (object, options) => {\n\tif (!object) {\n\t\treturn '';\n\t}\n\n\toptions = Object.assign({\n\t\tencode: true,\n\t\tstrict: true,\n\t\tarrayFormat: 'none',\n\t\tarrayFormatSeparator: ','\n\t}, options);\n\n\tvalidateArrayFormatSeparator(options.arrayFormatSeparator);\n\n\tconst shouldFilter = key => (\n\t\t(options.skipNull && isNullOrUndefined(object[key])) ||\n\t\t(options.skipEmptyString && object[key] === '')\n\t);\n\n\tconst formatter = encoderForArrayFormat(options);\n\n\tconst objectCopy = {};\n\n\tfor (const key of Object.keys(object)) {\n\t\tif (!shouldFilter(key)) {\n\t\t\tobjectCopy[key] = object[key];\n\t\t}\n\t}\n\n\tconst keys = Object.keys(objectCopy);\n\n\tif (options.sort !== false) {\n\t\tkeys.sort(options.sort);\n\t}\n\n\treturn keys.map(key => {\n\t\tconst value = object[key];\n\n\t\tif (value === undefined) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (value === null) {\n\t\t\treturn encode(key, options);\n\t\t}\n\n\t\tif (Array.isArray(value)) {\n\t\t\tif (value.length === 0 && options.arrayFormat === 'bracket-separator') {\n\t\t\t\treturn encode(key, options) + '[]';\n\t\t\t}\n\n\t\t\treturn value\n\t\t\t\t.reduce(formatter(key), [])\n\t\t\t\t.join('&');\n\t\t}\n\n\t\treturn encode(key, options) + '=' + encode(value, options);\n\t}).filter(x => x.length > 0).join('&');\n};\n\nexports.parseUrl = (url, options) => {\n\toptions = Object.assign({\n\t\tdecode: true\n\t}, options);\n\n\tconst [url_, hash] = splitOnFirst(url, '#');\n\n\treturn Object.assign(\n\t\t{\n\t\t\turl: url_.split('?')[0] || '',\n\t\t\tquery: parse(extract(url), options)\n\t\t},\n\t\toptions && options.parseFragmentIdentifier && hash ? {fragmentIdentifier: decode(hash, options)} : {}\n\t);\n};\n\nexports.stringifyUrl = (object, options) => {\n\toptions = Object.assign({\n\t\tencode: true,\n\t\tstrict: true,\n\t\t[encodeFragmentIdentifier]: true\n\t}, options);\n\n\tconst url = removeHash(object.url).split('?')[0] || '';\n\tconst queryFromUrl = exports.extract(object.url);\n\tconst parsedQueryFromUrl = exports.parse(queryFromUrl, {sort: false});\n\n\tconst query = Object.assign(parsedQueryFromUrl, object.query);\n\tlet queryString = exports.stringify(query, options);\n\tif (queryString) {\n\t\tqueryString = `?${queryString}`;\n\t}\n\n\tlet hash = getHash(object.url);\n\tif (object.fragmentIdentifier) {\n\t\thash = `#${options[encodeFragmentIdentifier] ? encode(object.fragmentIdentifier, options) : object.fragmentIdentifier}`;\n\t}\n\n\treturn `${url}${queryString}${hash}`;\n};\n\nexports.pick = (input, filter, options) => {\n\toptions = Object.assign({\n\t\tparseFragmentIdentifier: true,\n\t\t[encodeFragmentIdentifier]: false\n\t}, options);\n\n\tconst {url, query, fragmentIdentifier} = exports.parseUrl(input, options);\n\treturn exports.stringifyUrl({\n\t\turl,\n\t\tquery: filterObject(query, filter),\n\t\tfragmentIdentifier\n\t}, options);\n};\n\nexports.exclude = (input, filter, options) => {\n\tconst exclusionFilter = Array.isArray(filter) ? key => !filter.includes(key) : (key, value) => !filter(key, value);\n\n\treturn exports.pick(input, exclusionFilter, options);\n};\n","'use strict';\nmodule.exports = str => encodeURIComponent(str).replace(/[!'()*]/g, x => `%${x.charCodeAt(0).toString(16).toUpperCase()}`);\n","'use strict';\nvar token = '%[a-f0-9]{2}';\nvar singleMatcher = new RegExp('(' + token + ')|([^%]+?)', 'gi');\nvar multiMatcher = new RegExp('(' + token + ')+', 'gi');\n\nfunction decodeComponents(components, split) {\n\ttry {\n\t\t// Try to decode the entire string first\n\t\treturn [decodeURIComponent(components.join(''))];\n\t} catch (err) {\n\t\t// Do nothing\n\t}\n\n\tif (components.length === 1) {\n\t\treturn components;\n\t}\n\n\tsplit = split || 1;\n\n\t// Split the array in 2 parts\n\tvar left = components.slice(0, split);\n\tvar right = components.slice(split);\n\n\treturn Array.prototype.concat.call([], decodeComponents(left), decodeComponents(right));\n}\n\nfunction decode(input) {\n\ttry {\n\t\treturn decodeURIComponent(input);\n\t} catch (err) {\n\t\tvar tokens = input.match(singleMatcher) || [];\n\n\t\tfor (var i = 1; i < tokens.length; i++) {\n\t\t\tinput = decodeComponents(tokens, i).join('');\n\n\t\t\ttokens = input.match(singleMatcher) || [];\n\t\t}\n\n\t\treturn input;\n\t}\n}\n\nfunction customDecodeURIComponent(input) {\n\t// Keep track of all the replacements and prefill the map with the `BOM`\n\tvar replaceMap = {\n\t\t'%FE%FF': '\\uFFFD\\uFFFD',\n\t\t'%FF%FE': '\\uFFFD\\uFFFD'\n\t};\n\n\tvar match = multiMatcher.exec(input);\n\twhile (match) {\n\t\ttry {\n\t\t\t// Decode as big chunks as possible\n\t\t\treplaceMap[match[0]] = decodeURIComponent(match[0]);\n\t\t} catch (err) {\n\t\t\tvar result = decode(match[0]);\n\n\t\t\tif (result !== match[0]) {\n\t\t\t\treplaceMap[match[0]] = result;\n\t\t\t}\n\t\t}\n\n\t\tmatch = multiMatcher.exec(input);\n\t}\n\n\t// Add `%C2` at the end of the map to make sure it does not replace the combinator before everything else\n\treplaceMap['%C2'] = '\\uFFFD';\n\n\tvar entries = Object.keys(replaceMap);\n\n\tfor (var i = 0; i < entries.length; i++) {\n\t\t// Replace all decoded components\n\t\tvar key = entries[i];\n\t\tinput = input.replace(new RegExp(key, 'g'), replaceMap[key]);\n\t}\n\n\treturn input;\n}\n\nmodule.exports = function (encodedURI) {\n\tif (typeof encodedURI !== 'string') {\n\t\tthrow new TypeError('Expected `encodedURI` to be of type `string`, got `' + typeof encodedURI + '`');\n\t}\n\n\ttry {\n\t\tencodedURI = encodedURI.replace(/\\+/g, ' ');\n\n\t\t// Try the built in decoder first\n\t\treturn decodeURIComponent(encodedURI);\n\t} catch (err) {\n\t\t// Fallback to a more advanced decoder\n\t\treturn customDecodeURIComponent(encodedURI);\n\t}\n};\n","'use strict';\n\nmodule.exports = (string, separator) => {\n\tif (!(typeof string === 'string' && typeof separator === 'string')) {\n\t\tthrow new TypeError('Expected the arguments to be of type `string`');\n\t}\n\n\tif (separator === '') {\n\t\treturn [string];\n\t}\n\n\tconst separatorIndex = string.indexOf(separator);\n\n\tif (separatorIndex === -1) {\n\t\treturn [string];\n\t}\n\n\treturn [\n\t\tstring.slice(0, separatorIndex),\n\t\tstring.slice(separatorIndex + separator.length)\n\t];\n};\n","'use strict';\nmodule.exports = function (obj, predicate) {\n\tvar ret = {};\n\tvar keys = Object.keys(obj);\n\tvar isArr = Array.isArray(predicate);\n\n\tfor (var i = 0; i < keys.length; i++) {\n\t\tvar key = keys[i];\n\t\tvar val = obj[key];\n\n\t\tif (isArr ? predicate.indexOf(key) !== -1 : predicate(key, val, obj)) {\n\t\t\tret[key] = val;\n\t\t}\n\t}\n\n\treturn ret;\n};\n","// Object.fromEntries is not available in older iOS versions\nexport default function fromEntries(entries) {\n return entries.reduce((acc, _ref) => {\n let [k, v] = _ref;\n if (acc.hasOwnProperty(k)) {\n throw new Error(`A value for key '${k}' already exists in the object.`);\n }\n acc[k] = v;\n return acc;\n }, {});\n}\n//# sourceMappingURL=fromEntries.js.map","const formatToList = items => items.map(key => `- ${key}`).join('\\n');\nexport default function validatePathConfig(config) {\n let root = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n const validKeys = ['initialRouteName', 'screens'];\n if (!root) {\n validKeys.push('path', 'exact', 'stringify', 'parse');\n }\n const invalidKeys = Object.keys(config).filter(key => !validKeys.includes(key));\n if (invalidKeys.length) {\n throw new Error(`Found invalid properties in the configuration:\\n${formatToList(invalidKeys)}\\n\\nDid you forget to specify them under a 'screens' property?\\n\\nYou can only specify the following properties:\\n${formatToList(validKeys)}\\n\\nSee https://reactnavigation.org/docs/configuring-links for more details on how to specify a linking configuration.`);\n }\n if (config.screens) {\n Object.entries(config.screens).forEach(_ref => {\n let [_, value] = _ref;\n if (typeof value !== 'string') {\n validatePathConfig(value, false);\n }\n });\n }\n}\n//# sourceMappingURL=validatePathConfig.js.map","import escape from 'escape-string-regexp';\nimport * as queryString from 'query-string';\nimport findFocusedRoute from './findFocusedRoute';\nimport validatePathConfig from './validatePathConfig';\n/**\n * Utility to parse a path string to initial state object accepted by the container.\n * This is useful for deep linking when we need to handle the incoming URL.\n *\n * @example\n * ```js\n * getStateFromPath(\n * '/chat/jane/42',\n * {\n * screens: {\n * Chat: {\n * path: 'chat/:author/:id',\n * parse: { id: Number }\n * }\n * }\n * }\n * )\n * ```\n * @param path Path string to parse and convert, e.g. /foo/bar?count=42.\n * @param options Extra options to fine-tune how to parse the path.\n */\nexport default function getStateFromPath(path, options) {\n if (options) {\n validatePathConfig(options);\n }\n let initialRoutes = [];\n if (options !== null && options !== void 0 && options.initialRouteName) {\n initialRoutes.push({\n initialRouteName: options.initialRouteName,\n parentScreens: []\n });\n }\n const screens = options === null || options === void 0 ? void 0 : options.screens;\n let remaining = path.replace(/\\/+/g, '/') // Replace multiple slash (//) with single ones\n .replace(/^\\//, '') // Remove extra leading slash\n .replace(/\\?.*$/, ''); // Remove query params which we will handle later\n\n // Make sure there is a trailing slash\n remaining = remaining.endsWith('/') ? remaining : `${remaining}/`;\n if (screens === undefined) {\n // When no config is specified, use the path segments as route names\n const routes = remaining.split('/').filter(Boolean).map(segment => {\n const name = decodeURIComponent(segment);\n return {\n name\n };\n });\n if (routes.length) {\n return createNestedStateObject(path, routes, initialRoutes);\n }\n return undefined;\n }\n\n // Create a normalized configs array which will be easier to use\n const configs = [].concat(...Object.keys(screens).map(key => createNormalizedConfigs(key, screens, [], initialRoutes, []))).sort((a, b) => {\n // Sort config so that:\n // - the most exhaustive ones are always at the beginning\n // - patterns with wildcard are always at the end\n\n // If 2 patterns are same, move the one with less route names up\n // This is an error state, so it's only useful for consistent error messages\n if (a.pattern === b.pattern) {\n return b.routeNames.join('>').localeCompare(a.routeNames.join('>'));\n }\n\n // If one of the patterns starts with the other, it's more exhaustive\n // So move it up\n if (a.pattern.startsWith(b.pattern)) {\n return -1;\n }\n if (b.pattern.startsWith(a.pattern)) {\n return 1;\n }\n const aParts = a.pattern.split('/');\n const bParts = b.pattern.split('/');\n for (let i = 0; i < Math.max(aParts.length, bParts.length); i++) {\n // if b is longer, b get higher priority\n if (aParts[i] == null) {\n return 1;\n }\n // if a is longer, a get higher priority\n if (bParts[i] == null) {\n return -1;\n }\n const aWildCard = aParts[i] === '*' || aParts[i].startsWith(':');\n const bWildCard = bParts[i] === '*' || bParts[i].startsWith(':');\n // if both are wildcard we compare next component\n if (aWildCard && bWildCard) {\n continue;\n }\n // if only a is wild card, b get higher priority\n if (aWildCard) {\n return 1;\n }\n // if only b is wild card, a get higher priority\n if (bWildCard) {\n return -1;\n }\n }\n return bParts.length - aParts.length;\n });\n\n // Check for duplicate patterns in the config\n configs.reduce((acc, config) => {\n if (acc[config.pattern]) {\n const a = acc[config.pattern].routeNames;\n const b = config.routeNames;\n\n // It's not a problem if the path string omitted from a inner most screen\n // For example, it's ok if a path resolves to `A > B > C` or `A > B`\n const intersects = a.length > b.length ? b.every((it, i) => a[i] === it) : a.every((it, i) => b[i] === it);\n if (!intersects) {\n throw new Error(`Found conflicting screens with the same pattern. The pattern '${config.pattern}' resolves to both '${a.join(' > ')}' and '${b.join(' > ')}'. Patterns must be unique and cannot resolve to more than one screen.`);\n }\n }\n return Object.assign(acc, {\n [config.pattern]: config\n });\n }, {});\n if (remaining === '/') {\n // We need to add special handling of empty path so navigation to empty path also works\n // When handling empty path, we should only look at the root level config\n const match = configs.find(config => config.path === '' && config.routeNames.every(\n // Make sure that none of the parent configs have a non-empty path defined\n name => {\n var _configs$find;\n return !((_configs$find = configs.find(c => c.screen === name)) !== null && _configs$find !== void 0 && _configs$find.path);\n }));\n if (match) {\n return createNestedStateObject(path, match.routeNames.map(name => ({\n name\n })), initialRoutes, configs);\n }\n return undefined;\n }\n let result;\n let current;\n\n // We match the whole path against the regex instead of segments\n // This makes sure matches such as wildcard will catch any unmatched routes, even if nested\n const {\n routes,\n remainingPath\n } = matchAgainstConfigs(remaining, configs.map(c => ({\n ...c,\n // Add `$` to the regex to make sure it matches till end of the path and not just beginning\n regex: c.regex ? new RegExp(c.regex.source + '$') : undefined\n })));\n if (routes !== undefined) {\n // This will always be empty if full path matched\n current = createNestedStateObject(path, routes, initialRoutes, configs);\n remaining = remainingPath;\n result = current;\n }\n if (current == null || result == null) {\n return undefined;\n }\n return result;\n}\nconst joinPaths = function () {\n for (var _len = arguments.length, paths = new Array(_len), _key = 0; _key < _len; _key++) {\n paths[_key] = arguments[_key];\n }\n return [].concat(...paths.map(p => p.split('/'))).filter(Boolean).join('/');\n};\nconst matchAgainstConfigs = (remaining, configs) => {\n let routes;\n let remainingPath = remaining;\n\n // Go through all configs, and see if the next path segment matches our regex\n for (const config of configs) {\n if (!config.regex) {\n continue;\n }\n const match = remainingPath.match(config.regex);\n\n // If our regex matches, we need to extract params from the path\n if (match) {\n var _config$pattern;\n const matchedParams = (_config$pattern = config.pattern) === null || _config$pattern === void 0 ? void 0 : _config$pattern.split('/').filter(p => p.startsWith(':')).reduce((acc, p, i) => Object.assign(acc, {\n // The param segments appear every second item starting from 2 in the regex match result\n [p]: match[(i + 1) * 2].replace(/\\//, '')\n }), {});\n routes = config.routeNames.map(name => {\n var _config$path;\n const config = configs.find(c => c.screen === name);\n const params = config === null || config === void 0 ? void 0 : (_config$path = config.path) === null || _config$path === void 0 ? void 0 : _config$path.split('/').filter(p => p.startsWith(':')).reduce((acc, p) => {\n const value = matchedParams[p];\n if (value) {\n var _config$parse;\n const key = p.replace(/^:/, '').replace(/\\?$/, '');\n acc[key] = (_config$parse = config.parse) !== null && _config$parse !== void 0 && _config$parse[key] ? config.parse[key](value) : value;\n }\n return acc;\n }, {});\n if (params && Object.keys(params).length) {\n return {\n name,\n params\n };\n }\n return {\n name\n };\n });\n remainingPath = remainingPath.replace(match[1], '');\n break;\n }\n }\n return {\n routes,\n remainingPath\n };\n};\nconst createNormalizedConfigs = function (screen, routeConfig) {\n let routeNames = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];\n let initials = arguments.length > 3 ? arguments[3] : undefined;\n let parentScreens = arguments.length > 4 ? arguments[4] : undefined;\n let parentPattern = arguments.length > 5 ? arguments[5] : undefined;\n const configs = [];\n routeNames.push(screen);\n parentScreens.push(screen);\n\n // @ts-expect-error: we can't strongly typecheck this for now\n const config = routeConfig[screen];\n if (typeof config === 'string') {\n // If a string is specified as the value of the key(e.g. Foo: '/path'), use it as the pattern\n const pattern = parentPattern ? joinPaths(parentPattern, config) : config;\n configs.push(createConfigItem(screen, routeNames, pattern, config));\n } else if (typeof config === 'object') {\n let pattern;\n\n // if an object is specified as the value (e.g. Foo: { ... }),\n // it can have `path` property and\n // it could have `screens` prop which has nested configs\n if (typeof config.path === 'string') {\n if (config.exact && config.path === undefined) {\n throw new Error(\"A 'path' needs to be specified when specifying 'exact: true'. If you don't want this screen in the URL, specify it as empty string, e.g. `path: ''`.\");\n }\n pattern = config.exact !== true ? joinPaths(parentPattern || '', config.path || '') : config.path || '';\n configs.push(createConfigItem(screen, routeNames, pattern, config.path, config.parse));\n }\n if (config.screens) {\n // property `initialRouteName` without `screens` has no purpose\n if (config.initialRouteName) {\n initials.push({\n initialRouteName: config.initialRouteName,\n parentScreens\n });\n }\n Object.keys(config.screens).forEach(nestedConfig => {\n const result = createNormalizedConfigs(nestedConfig, config.screens, routeNames, initials, [...parentScreens], pattern ?? parentPattern);\n configs.push(...result);\n });\n }\n }\n routeNames.pop();\n return configs;\n};\nconst createConfigItem = (screen, routeNames, pattern, path, parse) => {\n // Normalize pattern to remove any leading, trailing slashes, duplicate slashes etc.\n pattern = pattern.split('/').filter(Boolean).join('/');\n const regex = pattern ? new RegExp(`^(${pattern.split('/').map(it => {\n if (it.startsWith(':')) {\n return `(([^/]+\\\\/)${it.endsWith('?') ? '?' : ''})`;\n }\n return `${it === '*' ? '.*' : escape(it)}\\\\/`;\n }).join('')})`) : undefined;\n return {\n screen,\n regex,\n pattern,\n path,\n // The routeNames array is mutated, so copy it to keep the current state\n routeNames: [...routeNames],\n parse\n };\n};\nconst findParseConfigForRoute = (routeName, flatConfig) => {\n for (const config of flatConfig) {\n if (routeName === config.routeNames[config.routeNames.length - 1]) {\n return config.parse;\n }\n }\n return undefined;\n};\n\n// Try to find an initial route connected with the one passed\nconst findInitialRoute = (routeName, parentScreens, initialRoutes) => {\n for (const config of initialRoutes) {\n if (parentScreens.length === config.parentScreens.length) {\n let sameParents = true;\n for (let i = 0; i < parentScreens.length; i++) {\n if (parentScreens[i].localeCompare(config.parentScreens[i]) !== 0) {\n sameParents = false;\n break;\n }\n }\n if (sameParents) {\n return routeName !== config.initialRouteName ? config.initialRouteName : undefined;\n }\n }\n }\n return undefined;\n};\n\n// returns state object with values depending on whether\n// it is the end of state and if there is initialRoute for this level\nconst createStateObject = (initialRoute, route, isEmpty) => {\n if (isEmpty) {\n if (initialRoute) {\n return {\n index: 1,\n routes: [{\n name: initialRoute\n }, route]\n };\n } else {\n return {\n routes: [route]\n };\n }\n } else {\n if (initialRoute) {\n return {\n index: 1,\n routes: [{\n name: initialRoute\n }, {\n ...route,\n state: {\n routes: []\n }\n }]\n };\n } else {\n return {\n routes: [{\n ...route,\n state: {\n routes: []\n }\n }]\n };\n }\n }\n};\nconst createNestedStateObject = (path, routes, initialRoutes, flatConfig) => {\n let state;\n let route = routes.shift();\n const parentScreens = [];\n let initialRoute = findInitialRoute(route.name, parentScreens, initialRoutes);\n parentScreens.push(route.name);\n state = createStateObject(initialRoute, route, routes.length === 0);\n if (routes.length > 0) {\n let nestedState = state;\n while (route = routes.shift()) {\n initialRoute = findInitialRoute(route.name, parentScreens, initialRoutes);\n const nestedStateIndex = nestedState.index || nestedState.routes.length - 1;\n nestedState.routes[nestedStateIndex].state = createStateObject(initialRoute, route, routes.length === 0);\n if (routes.length > 0) {\n nestedState = nestedState.routes[nestedStateIndex].state;\n }\n parentScreens.push(route.name);\n }\n }\n route = findFocusedRoute(state);\n route.path = path;\n const params = parseQueryParams(path, flatConfig ? findParseConfigForRoute(route.name, flatConfig) : undefined);\n if (params) {\n route.params = {\n ...route.params,\n ...params\n };\n }\n return state;\n};\nconst parseQueryParams = (path, parseConfig) => {\n const query = path.split('?')[1];\n const params = queryString.parse(query);\n if (parseConfig) {\n Object.keys(params).forEach(name => {\n if (Object.hasOwnProperty.call(parseConfig, name) && typeof params[name] === 'string') {\n params[name] = parseConfig[name](params[name]);\n }\n });\n }\n return Object.keys(params).length ? params : undefined;\n};\n//# sourceMappingURL=getStateFromPath.js.map","'use strict';\n\nmodule.exports = string => {\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError('Expected a string');\n\t}\n\n\t// Escape characters with special meaning either inside or outside character sets.\n\t// Use a simple backslash escape when it’s always valid, and a \\unnnn escape when the simpler form would be disallowed by Unicode patterns’ stricter grammar.\n\treturn string\n\t\t.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&')\n\t\t.replace(/-/g, '\\\\x2d');\n};\n","import * as React from 'react';\n/**\n * Context which holds the navigation helpers of the parent navigator.\n * Navigators should use this context in their view component.\n */\nconst NavigationHelpersContext = /*#__PURE__*/React.createContext(undefined);\nexport default NavigationHelpersContext;\n//# sourceMappingURL=NavigationHelpersContext.js.map","import * as React from 'react';\n\n/**\n * A type of an object that have a route key as an object key\n * and a value whether to prevent that route.\n */\n\nconst PreventRemoveContext = /*#__PURE__*/React.createContext(undefined);\nexport default PreventRemoveContext;\n//# sourceMappingURL=PreventRemoveContext.js.map","import { nanoid } from 'nanoid/non-secure';\nimport * as React from 'react';\nimport useLatestCallback from 'use-latest-callback';\nimport NavigationHelpersContext from './NavigationHelpersContext';\nimport NavigationRouteContext from './NavigationRouteContext';\nimport PreventRemoveContext from './PreventRemoveContext';\n/**\n * Util function to transform map of prevented routes to a simpler object.\n */\nconst transformPreventedRoutes = preventedRoutesMap => {\n const preventedRoutesToTransform = [...preventedRoutesMap.values()];\n const preventedRoutes = preventedRoutesToTransform.reduce((acc, _ref) => {\n var _acc$routeKey;\n let {\n routeKey,\n preventRemove\n } = _ref;\n acc[routeKey] = {\n preventRemove: ((_acc$routeKey = acc[routeKey]) === null || _acc$routeKey === void 0 ? void 0 : _acc$routeKey.preventRemove) || preventRemove\n };\n return acc;\n }, {});\n return preventedRoutes;\n};\n\n/**\n * Component used for managing which routes have to be prevented from removal in native-stack.\n */\nexport default function PreventRemoveProvider(_ref2) {\n let {\n children\n } = _ref2;\n const [parentId] = React.useState(() => nanoid());\n const [preventedRoutesMap, setPreventedRoutesMap] = React.useState(new Map());\n const navigation = React.useContext(NavigationHelpersContext);\n const route = React.useContext(NavigationRouteContext);\n const preventRemoveContextValue = React.useContext(PreventRemoveContext);\n // take `setPreventRemove` from parent context - if exist it means we're in a nested context\n const setParentPrevented = preventRemoveContextValue === null || preventRemoveContextValue === void 0 ? void 0 : preventRemoveContextValue.setPreventRemove;\n const setPreventRemove = useLatestCallback((id, routeKey, preventRemove) => {\n if (preventRemove && (navigation == null || navigation !== null && navigation !== void 0 && navigation.getState().routes.every(route => route.key !== routeKey))) {\n throw new Error(`Couldn't find a route with the key ${routeKey}. Is your component inside NavigationContent?`);\n }\n setPreventedRoutesMap(prevPrevented => {\n var _prevPrevented$get, _prevPrevented$get2;\n // values haven't changed - do nothing\n if (routeKey === ((_prevPrevented$get = prevPrevented.get(id)) === null || _prevPrevented$get === void 0 ? void 0 : _prevPrevented$get.routeKey) && preventRemove === ((_prevPrevented$get2 = prevPrevented.get(id)) === null || _prevPrevented$get2 === void 0 ? void 0 : _prevPrevented$get2.preventRemove)) {\n return prevPrevented;\n }\n const nextPrevented = new Map(prevPrevented);\n if (preventRemove) {\n nextPrevented.set(id, {\n routeKey,\n preventRemove\n });\n } else {\n nextPrevented.delete(id);\n }\n return nextPrevented;\n });\n });\n const isPrevented = [...preventedRoutesMap.values()].some(_ref3 => {\n let {\n preventRemove\n } = _ref3;\n return preventRemove;\n });\n React.useEffect(() => {\n if ((route === null || route === void 0 ? void 0 : route.key) !== undefined && setParentPrevented !== undefined) {\n // when route is defined (and setParentPrevented) it means we're in a nested stack\n // route.key then will be the route key of parent\n setParentPrevented(parentId, route.key, isPrevented);\n return () => {\n setParentPrevented(parentId, route.key, false);\n };\n }\n return;\n }, [parentId, isPrevented, route === null || route === void 0 ? void 0 : route.key, setParentPrevented]);\n const value = React.useMemo(() => ({\n setPreventRemove,\n preventedRoutes: transformPreventedRoutes(preventedRoutesMap)\n }), [setPreventRemove, preventedRoutesMap]);\n return /*#__PURE__*/React.createElement(PreventRemoveContext.Provider, {\n value: value\n }, children);\n}\n//# sourceMappingURL=PreventRemoveProvider.js.map","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (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};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar React = __importStar(require(\"react\"));\nvar useIsomorphicLayoutEffect = typeof document !== 'undefined' ? React.useLayoutEffect : React.useEffect;\n/**\n * React hook which returns the latest callback without changing the reference.\n */\nfunction useLatestCallback(callback) {\n var ref = React.useRef(callback);\n var latestCallback = React.useRef(function latestCallback() {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n // eslint-disable-next-line babel/no-invalid-this\n return ref.current.apply(this, args);\n }).current;\n useIsomorphicLayoutEffect(function () {\n ref.current = callback;\n });\n return latestCallback;\n}\nexports.default = useLatestCallback;\n","export class PrivateValueStore {}\n//# sourceMappingURL=types.js.map","import * as React from 'react';\nimport useNavigation from './useNavigation';\n/**\n * Hook to run an effect in a focused screen, similar to `React.useEffect`.\n * This can be used to perform side-effects such as fetching data or subscribing to events.\n * The passed callback should be wrapped in `React.useCallback` to avoid running the effect too often.\n *\n * @param callback Memoized callback containing the effect, should optionally return a cleanup function.\n */\nexport default function useFocusEffect(effect) {\n const navigation = useNavigation();\n if (arguments[1] !== undefined) {\n const message = \"You passed a second argument to 'useFocusEffect', but it only accepts one argument. \" + \"If you want to pass a dependency array, you can use 'React.useCallback':\\n\\n\" + 'useFocusEffect(\\n' + ' React.useCallback(() => {\\n' + ' // Your code here\\n' + ' }, [depA, depB])\\n' + ');\\n\\n' + 'See usage guide: https://reactnavigation.org/docs/use-focus-effect';\n console.error(message);\n }\n React.useEffect(() => {\n let isFocused = false;\n let cleanup;\n const callback = () => {\n const destroy = effect();\n if (destroy === undefined || typeof destroy === 'function') {\n return destroy;\n }\n if (process.env.NODE_ENV !== 'production') {\n let message = 'An effect function must not return anything besides a function, which is used for clean-up.';\n if (destroy === null) {\n message += \" You returned 'null'. If your effect does not require clean-up, return 'undefined' (or nothing).\";\n } else if (typeof destroy.then === 'function') {\n message += \"\\n\\nIt looks like you wrote 'useFocusEffect(async () => ...)' or returned a Promise. \" + 'Instead, write the async function inside your effect ' + 'and call it immediately:\\n\\n' + 'useFocusEffect(\\n' + ' React.useCallback(() => {\\n' + ' async function fetchData() {\\n' + ' // You can await here\\n' + ' const response = await MyAPI.getData(someId);\\n' + ' // ...\\n' + ' }\\n\\n' + ' fetchData();\\n' + ' }, [someId])\\n' + ');\\n\\n' + 'See usage guide: https://reactnavigation.org/docs/use-focus-effect';\n } else {\n message += ` You returned '${JSON.stringify(destroy)}'.`;\n }\n console.error(message);\n }\n };\n\n // We need to run the effect on intial render/dep changes if the screen is focused\n if (navigation.isFocused()) {\n cleanup = callback();\n isFocused = true;\n }\n const unsubscribeFocus = navigation.addListener('focus', () => {\n // If callback was already called for focus, avoid calling it again\n // The focus event may also fire on intial render, so we guard against runing the effect twice\n if (isFocused) {\n return;\n }\n if (cleanup !== undefined) {\n cleanup();\n }\n cleanup = callback();\n isFocused = true;\n });\n const unsubscribeBlur = navigation.addListener('blur', () => {\n if (cleanup !== undefined) {\n cleanup();\n }\n cleanup = undefined;\n isFocused = false;\n });\n return () => {\n if (cleanup !== undefined) {\n cleanup();\n }\n unsubscribeFocus();\n unsubscribeBlur();\n };\n }, [effect, navigation]);\n}\n//# sourceMappingURL=useFocusEffect.js.map","import * as React from 'react';\nimport NavigationContainerRefContext from './NavigationContainerRefContext';\nimport NavigationContext from './NavigationContext';\n/**\n * Hook to access the navigation prop of the parent screen anywhere.\n *\n * @returns Navigation prop of the parent screen.\n */\nexport default function useNavigation() {\n const root = React.useContext(NavigationContainerRefContext);\n const navigation = React.useContext(NavigationContext);\n if (navigation === undefined && root === undefined) {\n throw new Error(\"Couldn't find a navigation object. Is your component inside NavigationContainer?\");\n }\n\n // FIXME: Figure out a better way to do this\n return navigation ?? root;\n}\n//# sourceMappingURL=useNavigation.js.map","import * as React from 'react';\nimport { useState } from 'react';\nimport useNavigation from './useNavigation';\n\n/**\n * Hook to get the current focus state of the screen. Returns a `true` if screen is focused, otherwise `false`.\n * This can be used if a component needs to render something based on the focus state.\n */\nexport default function useIsFocused() {\n const navigation = useNavigation();\n const [isFocused, setIsFocused] = useState(navigation.isFocused);\n const valueToReturn = navigation.isFocused();\n if (isFocused !== valueToReturn) {\n // If the value has changed since the last render, we need to update it.\n // This could happen if we missed an update from the event listeners during re-render.\n // React will process this update immediately, so the old subscription value won't be committed.\n // It is still nice to avoid returning a mismatched value though, so let's override the return value.\n // This is the same logic as in https://github.com/facebook/react/tree/master/packages/use-subscription\n setIsFocused(valueToReturn);\n }\n React.useEffect(() => {\n const unsubscribeFocus = navigation.addListener('focus', () => setIsFocused(true));\n const unsubscribeBlur = navigation.addListener('blur', () => setIsFocused(false));\n return () => {\n unsubscribeFocus();\n unsubscribeBlur();\n };\n }, [navigation]);\n React.useDebugValue(valueToReturn);\n return valueToReturn;\n}\n//# sourceMappingURL=useIsFocused.js.map","import { CommonActions } from '@react-navigation/routers';\nimport * as React from 'react';\nimport { isValidElementType } from 'react-is';\nimport Group from './Group';\nimport isArrayEqual from './isArrayEqual';\nimport isRecordEqual from './isRecordEqual';\nimport NavigationHelpersContext from './NavigationHelpersContext';\nimport NavigationRouteContext from './NavigationRouteContext';\nimport NavigationStateContext from './NavigationStateContext';\nimport PreventRemoveProvider from './PreventRemoveProvider';\nimport Screen from './Screen';\nimport { PrivateValueStore } from './types';\nimport useChildListeners from './useChildListeners';\nimport useComponent from './useComponent';\nimport useCurrentRender from './useCurrentRender';\nimport useDescriptors from './useDescriptors';\nimport useEventEmitter from './useEventEmitter';\nimport useFocusedListenersChildrenAdapter from './useFocusedListenersChildrenAdapter';\nimport useFocusEvents from './useFocusEvents';\nimport useKeyedChildListeners from './useKeyedChildListeners';\nimport useNavigationHelpers from './useNavigationHelpers';\nimport useOnAction from './useOnAction';\nimport useOnGetState from './useOnGetState';\nimport useOnRouteFocus from './useOnRouteFocus';\nimport useRegisterNavigator from './useRegisterNavigator';\nimport useScheduleUpdate from './useScheduleUpdate';\n\n// This is to make TypeScript compiler happy\n// eslint-disable-next-line babel/no-unused-expressions\nPrivateValueStore;\nconst isValidKey = key => key === undefined || typeof key === 'string' && key !== '';\n\n/**\n * Extract route config object from React children elements.\n *\n * @param children React Elements to extract the config from.\n */\nconst getRouteConfigsFromChildren = (children, groupKey, groupOptions) => {\n const configs = React.Children.toArray(children).reduce((acc, child) => {\n var _child$type, _child$props;\n if ( /*#__PURE__*/React.isValidElement(child)) {\n if (child.type === Screen) {\n // We can only extract the config from `Screen` elements\n // If something else was rendered, it's probably a bug\n\n if (!isValidKey(child.props.navigationKey)) {\n throw new Error(`Got an invalid 'navigationKey' prop (${JSON.stringify(child.props.navigationKey)}) for the screen '${child.props.name}'. It must be a non-empty string or 'undefined'.`);\n }\n acc.push({\n keys: [groupKey, child.props.navigationKey],\n options: groupOptions,\n props: child.props\n });\n return acc;\n }\n if (child.type === React.Fragment || child.type === Group) {\n if (!isValidKey(child.props.navigationKey)) {\n throw new Error(`Got an invalid 'navigationKey' prop (${JSON.stringify(child.props.navigationKey)}) for the group. It must be a non-empty string or 'undefined'.`);\n }\n\n // When we encounter a fragment or group, we need to dive into its children to extract the configs\n // This is handy to conditionally define a group of screens\n acc.push(...getRouteConfigsFromChildren(child.props.children, child.props.navigationKey, child.type !== Group ? groupOptions : groupOptions != null ? [...groupOptions, child.props.screenOptions] : [child.props.screenOptions]));\n return acc;\n }\n }\n throw new Error(`A navigator can only contain 'Screen', 'Group' or 'React.Fragment' as its direct children (found ${/*#__PURE__*/React.isValidElement(child) ? `'${typeof child.type === 'string' ? child.type : (_child$type = child.type) === null || _child$type === void 0 ? void 0 : _child$type.name}'${child.props != null && typeof child.props === 'object' && 'name' in child.props && (_child$props = child.props) !== null && _child$props !== void 0 && _child$props.name ? ` for the screen '${child.props.name}'` : ''}` : typeof child === 'object' ? JSON.stringify(child) : `'${String(child)}'`}). To render this component in the navigator, pass it in the 'component' prop to 'Screen'.`);\n }, []);\n if (process.env.NODE_ENV !== 'production') {\n configs.forEach(config => {\n const {\n name,\n children,\n component,\n getComponent\n } = config.props;\n if (typeof name !== 'string' || !name) {\n throw new Error(`Got an invalid name (${JSON.stringify(name)}) for the screen. It must be a non-empty string.`);\n }\n if (children != null || component !== undefined || getComponent !== undefined) {\n if (children != null && component !== undefined) {\n throw new Error(`Got both 'component' and 'children' props for the screen '${name}'. You must pass only one of them.`);\n }\n if (children != null && getComponent !== undefined) {\n throw new Error(`Got both 'getComponent' and 'children' props for the screen '${name}'. You must pass only one of them.`);\n }\n if (component !== undefined && getComponent !== undefined) {\n throw new Error(`Got both 'component' and 'getComponent' props for the screen '${name}'. You must pass only one of them.`);\n }\n if (children != null && typeof children !== 'function') {\n throw new Error(`Got an invalid value for 'children' prop for the screen '${name}'. It must be a function returning a React Element.`);\n }\n if (component !== undefined && !isValidElementType(component)) {\n throw new Error(`Got an invalid value for 'component' prop for the screen '${name}'. It must be a valid React Component.`);\n }\n if (getComponent !== undefined && typeof getComponent !== 'function') {\n throw new Error(`Got an invalid value for 'getComponent' prop for the screen '${name}'. It must be a function returning a React Component.`);\n }\n if (typeof component === 'function') {\n if (component.name === 'component') {\n // Inline anonymous functions passed in the `component` prop will have the name of the prop\n // It's relatively safe to assume that it's not a component since it should also have PascalCase name\n // We won't catch all scenarios here, but this should catch a good chunk of incorrect use.\n console.warn(`Looks like you're passing an inline function for 'component' prop for the screen '${name}' (e.g. component={() => }). Passing an inline function will cause the component state to be lost on re-render and cause perf issues since it's re-created every render. You can pass the function as children to 'Screen' instead to achieve the desired behaviour.`);\n } else if (/^[a-z]/.test(component.name)) {\n console.warn(`Got a component with the name '${component.name}' for the screen '${name}'. React Components must start with an uppercase letter. If you're passing a regular function and not a component, pass it as children to 'Screen' instead. Otherwise capitalize your component's name.`);\n }\n }\n } else {\n throw new Error(`Couldn't find a 'component', 'getComponent' or 'children' prop for the screen '${name}'. This can happen if you passed 'undefined'. You likely forgot to export your component from the file it's defined in, or mixed up default import and named import when importing.`);\n }\n });\n }\n return configs;\n};\n\n/**\n * Hook for building navigators.\n *\n * @param createRouter Factory method which returns router object.\n * @param options Options object containing `children` and additional options for the router.\n * @returns An object containing `state`, `navigation`, `descriptors` objects.\n */\nexport default function useNavigationBuilder(createRouter, options) {\n const navigatorKey = useRegisterNavigator();\n const route = React.useContext(NavigationRouteContext);\n const {\n children,\n screenListeners,\n ...rest\n } = options;\n const {\n current: router\n } = React.useRef(createRouter({\n ...rest,\n ...(route !== null && route !== void 0 && route.params && route.params.state == null && route.params.initial !== false && typeof route.params.screen === 'string' ? {\n initialRouteName: route.params.screen\n } : null)\n }));\n const routeConfigs = getRouteConfigsFromChildren(children);\n const screens = routeConfigs.reduce((acc, config) => {\n if (config.props.name in acc) {\n throw new Error(`A navigator cannot contain multiple 'Screen' components with the same name (found duplicate screen named '${config.props.name}')`);\n }\n acc[config.props.name] = config;\n return acc;\n }, {});\n const routeNames = routeConfigs.map(config => config.props.name);\n const routeKeyList = routeNames.reduce((acc, curr) => {\n acc[curr] = screens[curr].keys.map(key => key ?? '').join(':');\n return acc;\n }, {});\n const routeParamList = routeNames.reduce((acc, curr) => {\n const {\n initialParams\n } = screens[curr].props;\n acc[curr] = initialParams;\n return acc;\n }, {});\n const routeGetIdList = routeNames.reduce((acc, curr) => Object.assign(acc, {\n [curr]: screens[curr].props.getId\n }), {});\n if (!routeNames.length) {\n throw new Error(\"Couldn't find any screens for the navigator. Have you defined any screens as its children?\");\n }\n const isStateValid = React.useCallback(state => state.type === undefined || state.type === router.type, [router.type]);\n const isStateInitialized = React.useCallback(state => state !== undefined && state.stale === false && isStateValid(state), [isStateValid]);\n const {\n state: currentState,\n getState: getCurrentState,\n setState: setCurrentState,\n setKey,\n getKey,\n getIsInitial\n } = React.useContext(NavigationStateContext);\n const stateCleanedUp = React.useRef(false);\n const cleanUpState = React.useCallback(() => {\n setCurrentState(undefined);\n stateCleanedUp.current = true;\n }, [setCurrentState]);\n const setState = React.useCallback(state => {\n if (stateCleanedUp.current) {\n // State might have been already cleaned up due to unmount\n // We do not want to expose API allowing to override this\n // This would lead to old data preservation on main navigator unmount\n return;\n }\n setCurrentState(state);\n }, [setCurrentState]);\n const [initializedState, isFirstStateInitialization] = React.useMemo(() => {\n var _route$params4;\n const initialRouteParamList = routeNames.reduce((acc, curr) => {\n var _route$params, _route$params2, _route$params3;\n const {\n initialParams\n } = screens[curr].props;\n const initialParamsFromParams = (route === null || route === void 0 ? void 0 : (_route$params = route.params) === null || _route$params === void 0 ? void 0 : _route$params.state) == null && (route === null || route === void 0 ? void 0 : (_route$params2 = route.params) === null || _route$params2 === void 0 ? void 0 : _route$params2.initial) !== false && (route === null || route === void 0 ? void 0 : (_route$params3 = route.params) === null || _route$params3 === void 0 ? void 0 : _route$params3.screen) === curr ? route.params.params : undefined;\n acc[curr] = initialParams !== undefined || initialParamsFromParams !== undefined ? {\n ...initialParams,\n ...initialParamsFromParams\n } : undefined;\n return acc;\n }, {});\n\n // If the current state isn't initialized on first render, we initialize it\n // We also need to re-initialize it if the state passed from parent was changed (maybe due to reset)\n // Otherwise assume that the state was provided as initial state\n // So we need to rehydrate it to make it usable\n if ((currentState === undefined || !isStateValid(currentState)) && (route === null || route === void 0 ? void 0 : (_route$params4 = route.params) === null || _route$params4 === void 0 ? void 0 : _route$params4.state) == null) {\n return [router.getInitialState({\n routeNames,\n routeParamList: initialRouteParamList,\n routeGetIdList\n }), true];\n } else {\n var _route$params5;\n return [router.getRehydratedState((route === null || route === void 0 ? void 0 : (_route$params5 = route.params) === null || _route$params5 === void 0 ? void 0 : _route$params5.state) ?? currentState, {\n routeNames,\n routeParamList: initialRouteParamList,\n routeGetIdList\n }), false];\n }\n // We explicitly don't include routeNames, route.params etc. in the dep list\n // below. We want to avoid forcing a new state to be calculated in those cases\n // Instead, we handle changes to these in the nextState code below. Note\n // that some changes to routeConfigs are explicitly ignored, such as changes\n // to initialParams\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [currentState, router, isStateValid]);\n const previousRouteKeyListRef = React.useRef(routeKeyList);\n React.useEffect(() => {\n previousRouteKeyListRef.current = routeKeyList;\n });\n const previousRouteKeyList = previousRouteKeyListRef.current;\n let state =\n // If the state isn't initialized, or stale, use the state we initialized instead\n // The state won't update until there's a change needed in the state we have initalized locally\n // So it'll be `undefined` or stale until the first navigation event happens\n isStateInitialized(currentState) ? currentState : initializedState;\n let nextState = state;\n if (!isArrayEqual(state.routeNames, routeNames) || !isRecordEqual(routeKeyList, previousRouteKeyList)) {\n // When the list of route names change, the router should handle it to remove invalid routes\n nextState = router.getStateForRouteNamesChange(state, {\n routeNames,\n routeParamList,\n routeGetIdList,\n routeKeyChanges: Object.keys(routeKeyList).filter(name => previousRouteKeyList.hasOwnProperty(name) && routeKeyList[name] !== previousRouteKeyList[name])\n });\n }\n const previousNestedParamsRef = React.useRef(route === null || route === void 0 ? void 0 : route.params);\n React.useEffect(() => {\n previousNestedParamsRef.current = route === null || route === void 0 ? void 0 : route.params;\n }, [route === null || route === void 0 ? void 0 : route.params]);\n if (route !== null && route !== void 0 && route.params) {\n const previousParams = previousNestedParamsRef.current;\n let action;\n if (typeof route.params.state === 'object' && route.params.state != null && route.params !== previousParams) {\n // If the route was updated with new state, we should reset to it\n action = CommonActions.reset(route.params.state);\n } else if (typeof route.params.screen === 'string' && (route.params.initial === false && isFirstStateInitialization || route.params !== previousParams)) {\n // If the route was updated with new screen name and/or params, we should navigate there\n action = CommonActions.navigate({\n name: route.params.screen,\n params: route.params.params,\n path: route.params.path\n });\n }\n\n // The update should be limited to current navigator only, so we call the router manually\n const updatedState = action ? router.getStateForAction(nextState, action, {\n routeNames,\n routeParamList,\n routeGetIdList\n }) : null;\n nextState = updatedState !== null ? router.getRehydratedState(updatedState, {\n routeNames,\n routeParamList,\n routeGetIdList\n }) : nextState;\n }\n const shouldUpdate = state !== nextState;\n useScheduleUpdate(() => {\n if (shouldUpdate) {\n // If the state needs to be updated, we'll schedule an update\n setState(nextState);\n }\n });\n\n // The up-to-date state will come in next render, but we don't need to wait for it\n // We can't use the outdated state since the screens have changed, which will cause error due to mismatched config\n // So we override the state object we return to use the latest state as soon as possible\n state = nextState;\n React.useEffect(() => {\n setKey(navigatorKey);\n if (!getIsInitial()) {\n // If it's not initial render, we need to update the state\n // This will make sure that our container gets notifier of state changes due to new mounts\n // This is necessary for proper screen tracking, URL updates etc.\n setState(nextState);\n }\n return () => {\n // We need to clean up state for this navigator on unmount\n // We do it in a timeout because we need to detect if another navigator mounted in the meantime\n // For example, if another navigator has started rendering, we should skip cleanup\n // Otherwise, our cleanup step will cleanup state for the other navigator and re-initialize it\n setTimeout(() => {\n if (getCurrentState() !== undefined && getKey() === navigatorKey) {\n cleanUpState();\n }\n }, 0);\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n // We initialize this ref here to avoid a new getState getting initialized\n // whenever initializedState changes. We want getState to have access to the\n // latest initializedState, but don't need it to change when that happens\n const initializedStateRef = React.useRef();\n initializedStateRef.current = initializedState;\n const getState = React.useCallback(() => {\n const currentState = getCurrentState();\n return isStateInitialized(currentState) ? currentState : initializedStateRef.current;\n }, [getCurrentState, isStateInitialized]);\n const emitter = useEventEmitter(e => {\n let routeNames = [];\n let route;\n if (e.target) {\n var _route;\n route = state.routes.find(route => route.key === e.target);\n if ((_route = route) !== null && _route !== void 0 && _route.name) {\n routeNames.push(route.name);\n }\n } else {\n route = state.routes[state.index];\n routeNames.push(...Object.keys(screens).filter(name => {\n var _route2;\n return ((_route2 = route) === null || _route2 === void 0 ? void 0 : _route2.name) === name;\n }));\n }\n if (route == null) {\n return;\n }\n const navigation = descriptors[route.key].navigation;\n const listeners = [].concat(\n // Get an array of listeners for all screens + common listeners on navigator\n ...[screenListeners, ...routeNames.map(name => {\n const {\n listeners\n } = screens[name].props;\n return listeners;\n })].map(listeners => {\n const map = typeof listeners === 'function' ? listeners({\n route: route,\n navigation\n }) : listeners;\n return map ? Object.keys(map).filter(type => type === e.type).map(type => map === null || map === void 0 ? void 0 : map[type]) : undefined;\n }))\n // We don't want same listener to be called multiple times for same event\n // So we remove any duplicate functions from the array\n .filter((cb, i, self) => cb && self.lastIndexOf(cb) === i);\n listeners.forEach(listener => listener === null || listener === void 0 ? void 0 : listener(e));\n });\n useFocusEvents({\n state,\n emitter\n });\n React.useEffect(() => {\n emitter.emit({\n type: 'state',\n data: {\n state\n }\n });\n }, [emitter, state]);\n const {\n listeners: childListeners,\n addListener\n } = useChildListeners();\n const {\n keyedListeners,\n addKeyedListener\n } = useKeyedChildListeners();\n const onAction = useOnAction({\n router,\n getState,\n setState,\n key: route === null || route === void 0 ? void 0 : route.key,\n actionListeners: childListeners.action,\n beforeRemoveListeners: keyedListeners.beforeRemove,\n routerConfigOptions: {\n routeNames,\n routeParamList,\n routeGetIdList\n },\n emitter\n });\n const onRouteFocus = useOnRouteFocus({\n router,\n key: route === null || route === void 0 ? void 0 : route.key,\n getState,\n setState\n });\n const navigation = useNavigationHelpers({\n id: options.id,\n onAction,\n getState,\n emitter,\n router\n });\n useFocusedListenersChildrenAdapter({\n navigation,\n focusedListeners: childListeners.focus\n });\n useOnGetState({\n getState,\n getStateListeners: keyedListeners.getState\n });\n const descriptors = useDescriptors({\n state,\n screens,\n navigation,\n screenOptions: options.screenOptions,\n defaultScreenOptions: options.defaultScreenOptions,\n onAction,\n getState,\n setState,\n onRouteFocus,\n addListener,\n addKeyedListener,\n router,\n // @ts-expect-error: this should have both core and custom events, but too much work right now\n emitter\n });\n useCurrentRender({\n state,\n navigation,\n descriptors\n });\n const NavigationContent = useComponent(children => /*#__PURE__*/React.createElement(NavigationHelpersContext.Provider, {\n value: navigation\n }, /*#__PURE__*/React.createElement(PreventRemoveProvider, null, children)));\n return {\n state,\n navigation,\n descriptors,\n NavigationContent\n };\n}\n//# sourceMappingURL=useNavigationBuilder.js.map","/**\n * Compare two arrays with primitive values as the content.\n * We need to make sure that both values and order match.\n */\nexport default function isArrayEqual(a, b) {\n if (a === b) {\n return true;\n }\n if (a.length !== b.length) {\n return false;\n }\n return a.every((it, index) => it === b[index]);\n}\n//# sourceMappingURL=isArrayEqual.js.map","/**\n * Compare two records with primitive values as the content.\n */\nexport default function isRecordEqual(a, b) {\n if (a === b) {\n return true;\n }\n const aKeys = Object.keys(a);\n const bKeys = Object.keys(b);\n if (aKeys.length !== bKeys.length) {\n return false;\n }\n return aKeys.every(key => a[key] === b[key]);\n}\n//# sourceMappingURL=isRecordEqual.js.map","import * as React from 'react';\nconst NavigationContent = _ref => {\n let {\n render,\n children\n } = _ref;\n return render(children);\n};\nexport default function useComponent(render) {\n const renderRef = React.useRef(render);\n\n // Normally refs shouldn't be mutated in render\n // But we return a component which will be rendered\n // So it's just for immediate consumption\n renderRef.current = render;\n React.useEffect(() => {\n renderRef.current = null;\n });\n return React.useRef(_ref2 => {\n let {\n children\n } = _ref2;\n const render = renderRef.current;\n if (render === null) {\n throw new Error('The returned component must be rendered in the same render phase as the hook.');\n }\n return /*#__PURE__*/React.createElement(NavigationContent, {\n render: render\n }, children);\n }).current;\n}\n//# sourceMappingURL=useComponent.js.map","import * as React from 'react';\nimport CurrentRenderContext from './CurrentRenderContext';\n/**\n * Write the current options, so that server renderer can get current values\n * Mutating values like this is not safe in async mode, but it doesn't apply to SSR\n */\nexport default function useCurrentRender(_ref) {\n let {\n state,\n navigation,\n descriptors\n } = _ref;\n const current = React.useContext(CurrentRenderContext);\n if (current && navigation.isFocused()) {\n current.options = descriptors[state.routes[state.index].key].options;\n }\n}\n//# sourceMappingURL=useCurrentRender.js.map","import * as React from 'react';\nimport NavigationBuilderContext from './NavigationBuilderContext';\nimport NavigationContext from './NavigationContext';\nimport NavigationRouteContext from './NavigationRouteContext';\nimport SceneView from './SceneView';\nimport useNavigationCache from './useNavigationCache';\nimport useRouteCache from './useRouteCache';\n/**\n * Hook to create descriptor objects for the child routes.\n *\n * A descriptor object provides 3 things:\n * - Helper method to render a screen\n * - Options specified by the screen for the navigator\n * - Navigation object intended for the route\n */\nexport default function useDescriptors(_ref) {\n let {\n state,\n screens,\n navigation,\n screenOptions,\n defaultScreenOptions,\n onAction,\n getState,\n setState,\n addListener,\n addKeyedListener,\n onRouteFocus,\n router,\n emitter\n } = _ref;\n const [options, setOptions] = React.useState({});\n const {\n onDispatchAction,\n onOptionsChange,\n stackRef\n } = React.useContext(NavigationBuilderContext);\n const context = React.useMemo(() => ({\n navigation,\n onAction,\n addListener,\n addKeyedListener,\n onRouteFocus,\n onDispatchAction,\n onOptionsChange,\n stackRef\n }), [navigation, onAction, addListener, addKeyedListener, onRouteFocus, onDispatchAction, onOptionsChange, stackRef]);\n const navigations = useNavigationCache({\n state,\n getState,\n navigation,\n setOptions,\n router,\n emitter\n });\n const routes = useRouteCache(state.routes);\n return routes.reduce((acc, route, i) => {\n const config = screens[route.name];\n const screen = config.props;\n const navigation = navigations[route.key];\n const optionsList = [\n // The default `screenOptions` passed to the navigator\n screenOptions,\n // The `screenOptions` props passed to `Group` elements\n ...(config.options ? config.options.filter(Boolean) : []),\n // The `options` prop passed to `Screen` elements,\n screen.options,\n // The options set via `navigation.setOptions`\n options[route.key]];\n const customOptions = optionsList.reduce((acc, curr) => Object.assign(acc,\n // @ts-expect-error: we check for function but TS still complains\n typeof curr !== 'function' ? curr : curr({\n route,\n navigation\n })), {});\n const mergedOptions = {\n ...(typeof defaultScreenOptions === 'function' ?\n // @ts-expect-error: ts gives incorrect error here\n defaultScreenOptions({\n route,\n navigation,\n options: customOptions\n }) : defaultScreenOptions),\n ...customOptions\n };\n const clearOptions = () => setOptions(o => {\n if (route.key in o) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const {\n [route.key]: _,\n ...rest\n } = o;\n return rest;\n }\n return o;\n });\n acc[route.key] = {\n route,\n // @ts-expect-error: it's missing action helpers, fix later\n navigation,\n render() {\n return /*#__PURE__*/React.createElement(NavigationBuilderContext.Provider, {\n key: route.key,\n value: context\n }, /*#__PURE__*/React.createElement(NavigationContext.Provider, {\n value: navigation\n }, /*#__PURE__*/React.createElement(NavigationRouteContext.Provider, {\n value: route\n }, /*#__PURE__*/React.createElement(SceneView, {\n navigation: navigation,\n route: route,\n screen: screen,\n routeState: state.routes[i].state,\n getState: getState,\n setState: setState,\n options: mergedOptions,\n clearOptions: clearOptions\n }))));\n },\n options: mergedOptions\n };\n return acc;\n }, {});\n}\n//# sourceMappingURL=useDescriptors.js.map","import * as React from 'react';\nimport EnsureSingleNavigator from './EnsureSingleNavigator';\nimport NavigationStateContext from './NavigationStateContext';\nimport StaticContainer from './StaticContainer';\nimport useOptionsGetters from './useOptionsGetters';\n/**\n * Component which takes care of rendering the screen for a route.\n * It provides all required contexts and applies optimizations when applicable.\n */\nexport default function SceneView(_ref) {\n let {\n screen,\n route,\n navigation,\n routeState,\n getState,\n setState,\n options,\n clearOptions\n } = _ref;\n const navigatorKeyRef = React.useRef();\n const getKey = React.useCallback(() => navigatorKeyRef.current, []);\n const {\n addOptionsGetter\n } = useOptionsGetters({\n key: route.key,\n options,\n navigation\n });\n const setKey = React.useCallback(key => {\n navigatorKeyRef.current = key;\n }, []);\n const getCurrentState = React.useCallback(() => {\n const state = getState();\n const currentRoute = state.routes.find(r => r.key === route.key);\n return currentRoute ? currentRoute.state : undefined;\n }, [getState, route.key]);\n const setCurrentState = React.useCallback(child => {\n const state = getState();\n setState({\n ...state,\n routes: state.routes.map(r => r.key === route.key ? {\n ...r,\n state: child\n } : r)\n });\n }, [getState, route.key, setState]);\n const isInitialRef = React.useRef(true);\n React.useEffect(() => {\n isInitialRef.current = false;\n });\n\n // Clear options set by this screen when it is unmounted\n React.useEffect(() => {\n return clearOptions;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n const getIsInitial = React.useCallback(() => isInitialRef.current, []);\n const context = React.useMemo(() => ({\n state: routeState,\n getState: getCurrentState,\n setState: setCurrentState,\n getKey,\n setKey,\n getIsInitial,\n addOptionsGetter\n }), [routeState, getCurrentState, setCurrentState, getKey, setKey, getIsInitial, addOptionsGetter]);\n const ScreenComponent = screen.getComponent ? screen.getComponent() : screen.component;\n return /*#__PURE__*/React.createElement(NavigationStateContext.Provider, {\n value: context\n }, /*#__PURE__*/React.createElement(EnsureSingleNavigator, null, /*#__PURE__*/React.createElement(StaticContainer, {\n name: screen.name,\n render: ScreenComponent || screen.children,\n navigation: navigation,\n route: route\n }, ScreenComponent !== undefined ? /*#__PURE__*/React.createElement(ScreenComponent, {\n navigation: navigation,\n route: route\n }) : screen.children !== undefined ? screen.children({\n navigation,\n route\n }) : null)));\n}\n//# sourceMappingURL=SceneView.js.map","import * as React from 'react';\n\n/**\n * Component which prevents updates for children if no props changed\n */\nfunction StaticContainer(props) {\n return props.children;\n}\nexport default /*#__PURE__*/React.memo(StaticContainer, (prevProps, nextProps) => {\n const prevPropKeys = Object.keys(prevProps);\n const nextPropKeys = Object.keys(nextProps);\n if (prevPropKeys.length !== nextPropKeys.length) {\n return false;\n }\n for (const key of prevPropKeys) {\n if (key === 'children') {\n continue;\n }\n if (prevProps[key] !== nextProps[key]) {\n return false;\n }\n }\n return true;\n});\n//# sourceMappingURL=StaticContainer.js.map","import { CommonActions } from '@react-navigation/routers';\nimport * as React from 'react';\nimport NavigationBuilderContext from './NavigationBuilderContext';\n/**\n * Hook to cache navigation objects for each screen in the navigator.\n * It's important to cache them to make sure navigation objects don't change between renders.\n * This lets us apply optimizations like `React.memo` to minimize re-rendering screens.\n */\nexport default function useNavigationCache(_ref) {\n let {\n state,\n getState,\n navigation,\n setOptions,\n router,\n emitter\n } = _ref;\n const {\n stackRef\n } = React.useContext(NavigationBuilderContext);\n\n // Cache object which holds navigation objects for each screen\n // We use `React.useMemo` instead of `React.useRef` coz we want to invalidate it when deps change\n // In reality, these deps will rarely change, if ever\n const cache = React.useMemo(() => ({\n current: {}\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [getState, navigation, setOptions, router, emitter]);\n const actions = {\n ...router.actionCreators,\n ...CommonActions\n };\n cache.current = state.routes.reduce((acc, route) => {\n const previous = cache.current[route.key];\n if (previous) {\n // If a cached navigation object already exists, reuse it\n acc[route.key] = previous;\n } else {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const {\n emit,\n ...rest\n } = navigation;\n const dispatch = thunk => {\n const action = typeof thunk === 'function' ? thunk(getState()) : thunk;\n if (action != null) {\n navigation.dispatch({\n source: route.key,\n ...action\n });\n }\n };\n const withStack = callback => {\n let isStackSet = false;\n try {\n if (process.env.NODE_ENV !== 'production' && stackRef && !stackRef.current) {\n // Capture the stack trace for devtools\n stackRef.current = new Error().stack;\n isStackSet = true;\n }\n callback();\n } finally {\n if (isStackSet && stackRef) {\n stackRef.current = undefined;\n }\n }\n };\n const helpers = Object.keys(actions).reduce((acc, name) => {\n acc[name] = function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return withStack(() =>\n // @ts-expect-error: name is a valid key, but TypeScript is dumb\n dispatch(actions[name](...args)));\n };\n return acc;\n }, {});\n acc[route.key] = {\n ...rest,\n ...helpers,\n // FIXME: too much work to fix the types for now\n ...emitter.create(route.key),\n dispatch: thunk => withStack(() => dispatch(thunk)),\n getParent: id => {\n if (id !== undefined && id === rest.getId()) {\n // If the passed id is the same as the current navigation id,\n // we return the cached navigation object for the relevant route\n return acc[route.key];\n }\n return rest.getParent(id);\n },\n setOptions: options => setOptions(o => ({\n ...o,\n [route.key]: {\n ...o[route.key],\n ...options\n }\n })),\n isFocused: () => {\n const state = getState();\n if (state.routes[state.index].key !== route.key) {\n return false;\n }\n\n // If the current screen is focused, we also need to check if parent navigator is focused\n // This makes sure that we return the focus state in the whole tree, not just this navigator\n return navigation ? navigation.isFocused() : true;\n }\n };\n }\n return acc;\n }, {});\n return cache.current;\n}\n//# sourceMappingURL=useNavigationCache.js.map","import * as React from 'react';\nimport NavigationBuilderContext from './NavigationBuilderContext';\n/**\n * Hook for passing focus callback to children\n */\nexport default function useFocusedListenersChildrenAdapter(_ref) {\n let {\n navigation,\n focusedListeners\n } = _ref;\n const {\n addListener\n } = React.useContext(NavigationBuilderContext);\n const listener = React.useCallback(callback => {\n if (navigation.isFocused()) {\n for (const listener of focusedListeners) {\n const {\n handled,\n result\n } = listener(callback);\n if (handled) {\n return {\n handled,\n result\n };\n }\n }\n return {\n handled: true,\n result: callback(navigation)\n };\n } else {\n return {\n handled: false,\n result: null\n };\n }\n }, [focusedListeners, navigation]);\n React.useEffect(() => addListener === null || addListener === void 0 ? void 0 : addListener('focus', listener), [addListener, listener]);\n}\n//# sourceMappingURL=useFocusedListenersChildrenAdapter.js.map","import * as React from 'react';\nimport NavigationContext from './NavigationContext';\n/**\n * Hook to take care of emitting `focus` and `blur` events.\n */\nexport default function useFocusEvents(_ref) {\n let {\n state,\n emitter\n } = _ref;\n const navigation = React.useContext(NavigationContext);\n const lastFocusedKeyRef = React.useRef();\n const currentFocusedKey = state.routes[state.index].key;\n\n // When the parent screen changes its focus state, we also need to change child's focus\n // Coz the child screen can't be focused if the parent screen is out of focus\n React.useEffect(() => navigation === null || navigation === void 0 ? void 0 : navigation.addListener('focus', () => {\n lastFocusedKeyRef.current = currentFocusedKey;\n emitter.emit({\n type: 'focus',\n target: currentFocusedKey\n });\n }), [currentFocusedKey, emitter, navigation]);\n React.useEffect(() => navigation === null || navigation === void 0 ? void 0 : navigation.addListener('blur', () => {\n lastFocusedKeyRef.current = undefined;\n emitter.emit({\n type: 'blur',\n target: currentFocusedKey\n });\n }), [currentFocusedKey, emitter, navigation]);\n React.useEffect(() => {\n const lastFocusedKey = lastFocusedKeyRef.current;\n lastFocusedKeyRef.current = currentFocusedKey;\n\n // We wouldn't have `lastFocusedKey` on initial mount\n // Fire focus event for the current route on mount if there's no parent navigator\n if (lastFocusedKey === undefined && !navigation) {\n emitter.emit({\n type: 'focus',\n target: currentFocusedKey\n });\n }\n\n // We should only emit events when the focused key changed and navigator is focused\n // When navigator is not focused, screens inside shouldn't receive focused status either\n if (lastFocusedKey === currentFocusedKey || !(navigation ? navigation.isFocused() : true)) {\n return;\n }\n if (lastFocusedKey === undefined) {\n // Only fire events after initial mount\n return;\n }\n emitter.emit({\n type: 'blur',\n target: lastFocusedKey\n });\n emitter.emit({\n type: 'focus',\n target: currentFocusedKey\n });\n }, [currentFocusedKey, emitter, navigation]);\n}\n//# sourceMappingURL=useFocusEvents.js.map","import { CommonActions } from '@react-navigation/routers';\nimport * as React from 'react';\nimport NavigationContext from './NavigationContext';\nimport { PrivateValueStore } from './types';\nimport UnhandledActionContext from './UnhandledActionContext';\n// This is to make TypeScript compiler happy\n// eslint-disable-next-line babel/no-unused-expressions\nPrivateValueStore;\n/**\n * Navigation object with helper methods to be used by a navigator.\n * This object includes methods for common actions as well as methods the parent screen's navigation object.\n */\nexport default function useNavigationHelpers(_ref) {\n let {\n id: navigatorId,\n onAction,\n getState,\n emitter,\n router\n } = _ref;\n const onUnhandledAction = React.useContext(UnhandledActionContext);\n const parentNavigationHelpers = React.useContext(NavigationContext);\n return React.useMemo(() => {\n const dispatch = op => {\n const action = typeof op === 'function' ? op(getState()) : op;\n const handled = onAction(action);\n if (!handled) {\n onUnhandledAction === null || onUnhandledAction === void 0 ? void 0 : onUnhandledAction(action);\n }\n };\n const actions = {\n ...router.actionCreators,\n ...CommonActions\n };\n const helpers = Object.keys(actions).reduce((acc, name) => {\n // @ts-expect-error: name is a valid key, but TypeScript is dumb\n acc[name] = function () {\n return dispatch(actions[name](...arguments));\n };\n return acc;\n }, {});\n const navigationHelpers = {\n ...parentNavigationHelpers,\n ...helpers,\n dispatch,\n emit: emitter.emit,\n isFocused: parentNavigationHelpers ? parentNavigationHelpers.isFocused : () => true,\n canGoBack: () => {\n const state = getState();\n return router.getStateForAction(state, CommonActions.goBack(), {\n routeNames: state.routeNames,\n routeParamList: {},\n routeGetIdList: {}\n }) !== null || (parentNavigationHelpers === null || parentNavigationHelpers === void 0 ? void 0 : parentNavigationHelpers.canGoBack()) || false;\n },\n getId: () => navigatorId,\n getParent: id => {\n if (id !== undefined) {\n let current = navigationHelpers;\n while (current && id !== current.getId()) {\n current = current.getParent();\n }\n return current;\n }\n return parentNavigationHelpers;\n },\n getState\n };\n return navigationHelpers;\n }, [navigatorId, emitter.emit, getState, onAction, onUnhandledAction, parentNavigationHelpers, router]);\n}\n//# sourceMappingURL=useNavigationHelpers.js.map","import * as React from 'react';\nimport NavigationBuilderContext from './NavigationBuilderContext';\nimport useOnPreventRemove, { shouldPreventRemove } from './useOnPreventRemove';\n/**\n * Hook to handle actions for a navigator, including state updates and bubbling.\n *\n * Bubbling an action is achieved in 2 ways:\n * 1. To bubble action to parent, we expose the action handler in context and then access the parent context\n * 2. To bubble action to child, child adds event listeners subscribing to actions from parent\n *\n * When the action handler handles as action, it returns `true`, otherwise `false`.\n */\nexport default function useOnAction(_ref) {\n let {\n router,\n getState,\n setState,\n key,\n actionListeners,\n beforeRemoveListeners,\n routerConfigOptions,\n emitter\n } = _ref;\n const {\n onAction: onActionParent,\n onRouteFocus: onRouteFocusParent,\n addListener: addListenerParent,\n onDispatchAction\n } = React.useContext(NavigationBuilderContext);\n const routerConfigOptionsRef = React.useRef(routerConfigOptions);\n React.useEffect(() => {\n routerConfigOptionsRef.current = routerConfigOptions;\n });\n const onAction = React.useCallback(function (action) {\n let visitedNavigators = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : new Set();\n const state = getState();\n\n // Since actions can bubble both up and down, they could come to the same navigator again\n // We keep track of navigators which have already tried to handle the action and return if it's already visited\n if (visitedNavigators.has(state.key)) {\n return false;\n }\n visitedNavigators.add(state.key);\n if (typeof action.target !== 'string' || action.target === state.key) {\n let result = router.getStateForAction(state, action, routerConfigOptionsRef.current);\n\n // If a target is specified and set to current navigator, the action shouldn't bubble\n // So instead of `null`, we use the state object for such cases to signal that action was handled\n result = result === null && action.target === state.key ? state : result;\n if (result !== null) {\n onDispatchAction(action, state === result);\n if (state !== result) {\n const isPrevented = shouldPreventRemove(emitter, beforeRemoveListeners, state.routes, result.routes, action);\n if (isPrevented) {\n return true;\n }\n setState(result);\n }\n if (onRouteFocusParent !== undefined) {\n // Some actions such as `NAVIGATE` also want to bring the navigated route to focus in the whole tree\n // This means we need to focus all of the parent navigators of this navigator as well\n const shouldFocus = router.shouldActionChangeFocus(action);\n if (shouldFocus && key !== undefined) {\n onRouteFocusParent(key);\n }\n }\n return true;\n }\n }\n if (onActionParent !== undefined) {\n // Bubble action to the parent if the current navigator didn't handle it\n if (onActionParent(action, visitedNavigators)) {\n return true;\n }\n }\n\n // If the action wasn't handled by current navigator or a parent navigator, let children handle it\n for (let i = actionListeners.length - 1; i >= 0; i--) {\n const listener = actionListeners[i];\n if (listener(action, visitedNavigators)) {\n return true;\n }\n }\n return false;\n }, [actionListeners, beforeRemoveListeners, emitter, getState, key, onActionParent, onDispatchAction, onRouteFocusParent, router, setState]);\n useOnPreventRemove({\n getState,\n emitter,\n beforeRemoveListeners\n });\n React.useEffect(() => addListenerParent === null || addListenerParent === void 0 ? void 0 : addListenerParent('action', onAction), [addListenerParent, onAction]);\n return onAction;\n}\n//# sourceMappingURL=useOnAction.js.map","import * as React from 'react';\nimport NavigationBuilderContext from './NavigationBuilderContext';\nimport NavigationRouteContext from './NavigationRouteContext';\nconst VISITED_ROUTE_KEYS = Symbol('VISITED_ROUTE_KEYS');\nexport const shouldPreventRemove = (emitter, beforeRemoveListeners, currentRoutes, nextRoutes, action) => {\n const nextRouteKeys = nextRoutes.map(route => route.key);\n\n // Call these in reverse order so last screens handle the event first\n const removedRoutes = currentRoutes.filter(route => !nextRouteKeys.includes(route.key)).reverse();\n const visitedRouteKeys =\n // @ts-expect-error: add this property to mark that we've already emitted this action\n action[VISITED_ROUTE_KEYS] ?? new Set();\n const beforeRemoveAction = {\n ...action,\n [VISITED_ROUTE_KEYS]: visitedRouteKeys\n };\n for (const route of removedRoutes) {\n var _beforeRemoveListener;\n if (visitedRouteKeys.has(route.key)) {\n // Skip if we've already emitted this action for this screen\n continue;\n }\n\n // First, we need to check if any child screens want to prevent it\n const isPrevented = (_beforeRemoveListener = beforeRemoveListeners[route.key]) === null || _beforeRemoveListener === void 0 ? void 0 : _beforeRemoveListener.call(beforeRemoveListeners, beforeRemoveAction);\n if (isPrevented) {\n return true;\n }\n visitedRouteKeys.add(route.key);\n const event = emitter.emit({\n type: 'beforeRemove',\n target: route.key,\n data: {\n action: beforeRemoveAction\n },\n canPreventDefault: true\n });\n if (event.defaultPrevented) {\n return true;\n }\n }\n return false;\n};\nexport default function useOnPreventRemove(_ref) {\n let {\n getState,\n emitter,\n beforeRemoveListeners\n } = _ref;\n const {\n addKeyedListener\n } = React.useContext(NavigationBuilderContext);\n const route = React.useContext(NavigationRouteContext);\n const routeKey = route === null || route === void 0 ? void 0 : route.key;\n React.useEffect(() => {\n if (routeKey) {\n return addKeyedListener === null || addKeyedListener === void 0 ? void 0 : addKeyedListener('beforeRemove', routeKey, action => {\n const state = getState();\n return shouldPreventRemove(emitter, beforeRemoveListeners, state.routes, [], action);\n });\n }\n }, [addKeyedListener, beforeRemoveListeners, emitter, getState, routeKey]);\n}\n//# sourceMappingURL=useOnPreventRemove.js.map","import * as React from 'react';\nimport isArrayEqual from './isArrayEqual';\nimport NavigationBuilderContext from './NavigationBuilderContext';\nimport NavigationRouteContext from './NavigationRouteContext';\nexport default function useOnGetState(_ref) {\n let {\n getState,\n getStateListeners\n } = _ref;\n const {\n addKeyedListener\n } = React.useContext(NavigationBuilderContext);\n const route = React.useContext(NavigationRouteContext);\n const key = route ? route.key : 'root';\n const getRehydratedState = React.useCallback(() => {\n const state = getState();\n\n // Avoid returning new route objects if we don't need to\n const routes = state.routes.map(route => {\n var _getStateListeners$ro;\n const childState = (_getStateListeners$ro = getStateListeners[route.key]) === null || _getStateListeners$ro === void 0 ? void 0 : _getStateListeners$ro.call(getStateListeners);\n if (route.state === childState) {\n return route;\n }\n return {\n ...route,\n state: childState\n };\n });\n if (isArrayEqual(state.routes, routes)) {\n return state;\n }\n return {\n ...state,\n routes\n };\n }, [getState, getStateListeners]);\n React.useEffect(() => {\n return addKeyedListener === null || addKeyedListener === void 0 ? void 0 : addKeyedListener('getState', key, getRehydratedState);\n }, [addKeyedListener, getRehydratedState, key]);\n}\n//# sourceMappingURL=useOnGetState.js.map","import * as React from 'react';\nimport NavigationBuilderContext from './NavigationBuilderContext';\n/**\n * Hook to handle focus actions for a route.\n * Focus action needs to be treated specially, coz when a nested route is focused,\n * the parent navigators also needs to be focused.\n */\nexport default function useOnRouteFocus(_ref) {\n let {\n router,\n getState,\n key: sourceRouteKey,\n setState\n } = _ref;\n const {\n onRouteFocus: onRouteFocusParent\n } = React.useContext(NavigationBuilderContext);\n return React.useCallback(key => {\n const state = getState();\n const result = router.getStateForRouteFocus(state, key);\n if (result !== state) {\n setState(result);\n }\n if (onRouteFocusParent !== undefined && sourceRouteKey !== undefined) {\n onRouteFocusParent(sourceRouteKey);\n }\n }, [getState, onRouteFocusParent, router, setState, sourceRouteKey]);\n}\n//# sourceMappingURL=useOnRouteFocus.js.map","import { nanoid } from 'nanoid/non-secure';\nimport * as React from 'react';\nimport { SingleNavigatorContext } from './EnsureSingleNavigator';\n\n/**\n * Register a navigator in the parent context (either a navigation container or a screen).\n * This is used to prevent multiple navigators under a single container or screen.\n */\nexport default function useRegisterNavigator() {\n const [key] = React.useState(() => nanoid());\n const container = React.useContext(SingleNavigatorContext);\n if (container === undefined) {\n throw new Error(\"Couldn't register the navigator. Have you wrapped your app with 'NavigationContainer'?\\n\\nThis can also happen if there are multiple copies of '@react-navigation' packages installed.\");\n }\n React.useEffect(() => {\n const {\n register,\n unregister\n } = container;\n register(key);\n return () => unregister(key);\n }, [container, key]);\n return key;\n}\n//# sourceMappingURL=useRegisterNavigator.js.map","import * as React from 'react';\nimport createNavigationContainerRef from './createNavigationContainerRef';\nexport default function useNavigationContainerRef() {\n const navigation = React.useRef(null);\n if (navigation.current == null) {\n navigation.current = createNavigationContainerRef();\n }\n return navigation.current;\n}\n//# sourceMappingURL=useNavigationContainerRef.js.map","import * as React from 'react';\nimport useNavigation from './useNavigation';\n/**\n * Hook to get a value from the current navigation state using a selector.\n *\n * @param selector Selector function to get a value from the state.\n */\nexport default function useNavigationState(selector) {\n const navigation = useNavigation();\n\n // We don't care about the state value, we run the selector again at the end\n // The state is only to make sure that there's a re-render when we have a new value\n const [, setResult] = React.useState(() => selector(navigation.getState()));\n\n // We store the selector in a ref to avoid re-subscribing listeners every render\n const selectorRef = React.useRef(selector);\n React.useEffect(() => {\n selectorRef.current = selector;\n });\n React.useEffect(() => {\n const unsubscribe = navigation.addListener('state', e => {\n setResult(selectorRef.current(e.data.state));\n });\n return unsubscribe;\n }, [navigation]);\n return selector(navigation.getState());\n}\n//# sourceMappingURL=useNavigationState.js.map","import { nanoid } from 'nanoid/non-secure';\nimport * as React from 'react';\nimport useLatestCallback from 'use-latest-callback';\nimport useNavigation from './useNavigation';\nimport usePreventRemoveContext from './usePreventRemoveContext';\nimport useRoute from './useRoute';\n\n/**\n * Hook to prevent screen from being removed. Can be used to prevent users from leaving the screen.\n *\n * @param preventRemove Boolean indicating whether to prevent screen from being removed.\n * @param callback Function which is executed when screen was prevented from being removed.\n */\nexport default function usePreventRemove(preventRemove, callback) {\n const [id] = React.useState(() => nanoid());\n const navigation = useNavigation();\n const {\n key: routeKey\n } = useRoute();\n const {\n setPreventRemove\n } = usePreventRemoveContext();\n React.useEffect(() => {\n setPreventRemove(id, routeKey, preventRemove);\n return () => {\n setPreventRemove(id, routeKey, false);\n };\n }, [setPreventRemove, id, routeKey, preventRemove]);\n const beforeRemoveListener = useLatestCallback(e => {\n if (!preventRemove) {\n return;\n }\n e.preventDefault();\n callback({\n data: e.data\n });\n });\n React.useEffect(() => navigation === null || navigation === void 0 ? void 0 : navigation.addListener('beforeRemove', beforeRemoveListener), [navigation, beforeRemoveListener]);\n}\n//# sourceMappingURL=usePreventRemove.js.map","import * as React from 'react';\nimport PreventRemoveContext from './PreventRemoveContext';\nexport default function usePreventRemoveContext() {\n const value = React.useContext(PreventRemoveContext);\n if (value == null) {\n throw new Error(\"Couldn't find the prevent remove context. Is your component inside NavigationContent?\");\n }\n return value;\n}\n//# sourceMappingURL=usePreventRemoveContext.js.map","import * as React from 'react';\nimport NavigationRouteContext from './NavigationRouteContext';\n/**\n * Hook to access the route prop of the parent screen anywhere.\n *\n * @returns Route prop of the parent screen.\n */\nexport default function useRoute() {\n const route = React.useContext(NavigationRouteContext);\n if (route === undefined) {\n throw new Error(\"Couldn't find a route object. Is your component inside a screen in a navigator?\");\n }\n return route;\n}\n//# sourceMappingURL=useRoute.js.map","import * as React from 'react';\nconst LinkingContext = /*#__PURE__*/React.createContext({\n options: undefined\n});\nLinkingContext.displayName = 'LinkingContext';\nexport default LinkingContext;\n//# sourceMappingURL=LinkingContext.js.map","import { getActionFromState, getStateFromPath, NavigationContainerRefContext } from '@react-navigation/core';\nimport * as React from 'react';\nimport LinkingContext from './LinkingContext';\nexport default function useLinkTo() {\n const navigation = React.useContext(NavigationContainerRefContext);\n const linking = React.useContext(LinkingContext);\n const linkTo = React.useCallback(to => {\n if (navigation === undefined) {\n throw new Error(\"Couldn't find a navigation object. Is your component inside NavigationContainer?\");\n }\n if (typeof to !== 'string') {\n // @ts-expect-error: This is fine\n navigation.navigate(to.screen, to.params);\n return;\n }\n if (!to.startsWith('/')) {\n throw new Error(`The path must start with '/' (${to}).`);\n }\n const {\n options\n } = linking;\n const state = options !== null && options !== void 0 && options.getStateFromPath ? options.getStateFromPath(to, options.config) : getStateFromPath(to, options === null || options === void 0 ? void 0 : options.config);\n if (state) {\n const action = getActionFromState(state, options === null || options === void 0 ? void 0 : options.config);\n if (action !== undefined) {\n navigation.dispatch(action);\n } else {\n navigation.reset(state);\n }\n } else {\n throw new Error('Failed to parse the path to a navigation state.');\n }\n }, [linking, navigation]);\n return linkTo;\n}\n//# sourceMappingURL=useLinkTo.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport { BaseNavigationContainer, getActionFromState, getPathFromState, getStateFromPath, validatePathConfig } from '@react-navigation/core';\nimport * as React from 'react';\nimport LinkingContext from './LinkingContext';\nimport DefaultTheme from './theming/DefaultTheme';\nimport ThemeProvider from './theming/ThemeProvider';\nimport useBackButton from './useBackButton';\nimport useDocumentTitle from './useDocumentTitle';\nimport useLinking from './useLinking';\nimport useThenable from './useThenable';\nglobal.REACT_NAVIGATION_DEVTOOLS = new WeakMap();\n/**\n * Container component which holds the navigation state designed for React Native apps.\n * This should be rendered at the root wrapping the whole app.\n *\n * @param props.initialState Initial state object for the navigation tree. When deep link handling is enabled, this will override deep links when specified. Make sure that you don't specify an `initialState` when there's a deep link (`Linking.getInitialURL()`).\n * @param props.onReady Callback which is called after the navigation tree mounts.\n * @param props.onStateChange Callback which is called with the latest navigation state when it changes.\n * @param props.theme Theme object for the navigators.\n * @param props.linking Options for deep linking. Deep link handling is enabled when this prop is provided, unless `linking.enabled` is `false`.\n * @param props.fallback Fallback component to render until we have finished getting initial state when linking is enabled. Defaults to `null`.\n * @param props.documentTitle Options to configure the document title on Web. Updating document title is handled by default unless `documentTitle.enabled` is `false`.\n * @param props.children Child elements to render the content.\n * @param props.ref Ref object which refers to the navigation object containing helper methods.\n */\nfunction NavigationContainerInner(_ref, ref) {\n let {\n theme = DefaultTheme,\n linking,\n fallback = null,\n documentTitle,\n onReady,\n ...rest\n } = _ref;\n const isLinkingEnabled = linking ? linking.enabled !== false : false;\n if (linking !== null && linking !== void 0 && linking.config) {\n validatePathConfig(linking.config);\n }\n const refContainer = React.useRef(null);\n useBackButton(refContainer);\n useDocumentTitle(refContainer, documentTitle);\n const {\n getInitialState\n } = useLinking(refContainer, {\n independent: rest.independent,\n enabled: isLinkingEnabled,\n prefixes: [],\n ...linking\n });\n\n // Add additional linking related info to the ref\n // This will be used by the devtools\n React.useEffect(() => {\n if (refContainer.current) {\n REACT_NAVIGATION_DEVTOOLS.set(refContainer.current, {\n get linking() {\n return {\n ...linking,\n enabled: isLinkingEnabled,\n prefixes: (linking === null || linking === void 0 ? void 0 : linking.prefixes) ?? [],\n getStateFromPath: (linking === null || linking === void 0 ? void 0 : linking.getStateFromPath) ?? getStateFromPath,\n getPathFromState: (linking === null || linking === void 0 ? void 0 : linking.getPathFromState) ?? getPathFromState,\n getActionFromState: (linking === null || linking === void 0 ? void 0 : linking.getActionFromState) ?? getActionFromState\n };\n }\n });\n }\n });\n const [isResolved, initialState] = useThenable(getInitialState);\n React.useImperativeHandle(ref, () => refContainer.current);\n const linkingContext = React.useMemo(() => ({\n options: linking\n }), [linking]);\n const isReady = rest.initialState != null || !isLinkingEnabled || isResolved;\n const onReadyRef = React.useRef(onReady);\n React.useEffect(() => {\n onReadyRef.current = onReady;\n });\n React.useEffect(() => {\n if (isReady) {\n var _onReadyRef$current;\n (_onReadyRef$current = onReadyRef.current) === null || _onReadyRef$current === void 0 ? void 0 : _onReadyRef$current.call(onReadyRef);\n }\n }, [isReady]);\n if (!isReady) {\n // This is temporary until we have Suspense for data-fetching\n // Then the fallback will be handled by a parent `Suspense` component\n return fallback;\n }\n return /*#__PURE__*/React.createElement(LinkingContext.Provider, {\n value: linkingContext\n }, /*#__PURE__*/React.createElement(ThemeProvider, {\n value: theme\n }, /*#__PURE__*/React.createElement(BaseNavigationContainer, _extends({}, rest, {\n initialState: rest.initialState == null ? initialState : rest.initialState,\n ref: refContainer\n }))));\n}\nconst NavigationContainer = /*#__PURE__*/React.forwardRef(NavigationContainerInner);\nexport default NavigationContainer;\n//# sourceMappingURL=NavigationContainer.js.map","const DefaultTheme = {\n dark: false,\n colors: {\n primary: 'rgb(0, 122, 255)',\n background: 'rgb(242, 242, 242)',\n card: 'rgb(255, 255, 255)',\n text: 'rgb(28, 28, 30)',\n border: 'rgb(216, 216, 216)',\n notification: 'rgb(255, 59, 48)'\n }\n};\nexport default DefaultTheme;\n//# sourceMappingURL=DefaultTheme.js.map","import * as React from 'react';\nimport ThemeContext from './ThemeContext';\nexport default function ThemeProvider(_ref) {\n let {\n value,\n children\n } = _ref;\n return /*#__PURE__*/React.createElement(ThemeContext.Provider, {\n value: value\n }, children);\n}\n//# sourceMappingURL=ThemeProvider.js.map","import * as React from 'react';\nimport DefaultTheme from './DefaultTheme';\nconst ThemeContext = /*#__PURE__*/React.createContext(DefaultTheme);\nThemeContext.displayName = 'ThemeContext';\nexport default ThemeContext;\n//# sourceMappingURL=ThemeContext.js.map","export default function useBackButton(_) {\n // No-op\n // BackHandler is not available on web\n}\n//# sourceMappingURL=useBackButton.js.map","import * as React from 'react';\n/**\n * Set the document title for the active screen\n */\nexport default function useDocumentTitle(ref) {\n let {\n enabled = true,\n formatter = (options, route) => (options === null || options === void 0 ? void 0 : options.title) ?? (route === null || route === void 0 ? void 0 : route.name)\n } = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n React.useEffect(() => {\n if (!enabled) {\n return;\n }\n const navigation = ref.current;\n if (navigation) {\n const title = formatter(navigation.getCurrentOptions(), navigation.getCurrentRoute());\n document.title = title;\n }\n return navigation === null || navigation === void 0 ? void 0 : navigation.addListener('options', e => {\n const title = formatter(e.data.options, navigation === null || navigation === void 0 ? void 0 : navigation.getCurrentRoute());\n document.title = title;\n });\n });\n}\n//# sourceMappingURL=useDocumentTitle.js.map","import { findFocusedRoute, getActionFromState as getActionFromStateDefault, getPathFromState as getPathFromStateDefault, getStateFromPath as getStateFromPathDefault } from '@react-navigation/core';\nimport isEqual from 'fast-deep-equal';\nimport * as React from 'react';\nimport createMemoryHistory from './createMemoryHistory';\nimport ServerContext from './ServerContext';\n/**\n * Find the matching navigation state that changed between 2 navigation states\n * e.g.: a -> b -> c -> d and a -> b -> c -> e -> f, if history in b changed, b is the matching state\n */\nconst findMatchingState = (a, b) => {\n if (a === undefined || b === undefined || a.key !== b.key) {\n return [undefined, undefined];\n }\n\n // Tab and drawer will have `history` property, but stack will have history in `routes`\n const aHistoryLength = a.history ? a.history.length : a.routes.length;\n const bHistoryLength = b.history ? b.history.length : b.routes.length;\n const aRoute = a.routes[a.index];\n const bRoute = b.routes[b.index];\n const aChildState = aRoute.state;\n const bChildState = bRoute.state;\n\n // Stop here if this is the state object that changed:\n // - history length is different\n // - focused routes are different\n // - one of them doesn't have child state\n // - child state keys are different\n if (aHistoryLength !== bHistoryLength || aRoute.key !== bRoute.key || aChildState === undefined || bChildState === undefined || aChildState.key !== bChildState.key) {\n return [a, b];\n }\n return findMatchingState(aChildState, bChildState);\n};\n\n/**\n * Run async function in series as it's called.\n */\nexport const series = cb => {\n let queue = Promise.resolve();\n const callback = () => {\n queue = queue.then(cb);\n };\n return callback;\n};\nlet linkingHandlers = [];\nexport default function useLinking(ref, _ref) {\n let {\n independent,\n enabled = true,\n config,\n getStateFromPath = getStateFromPathDefault,\n getPathFromState = getPathFromStateDefault,\n getActionFromState = getActionFromStateDefault\n } = _ref;\n React.useEffect(() => {\n if (process.env.NODE_ENV === 'production') {\n return undefined;\n }\n if (independent) {\n return undefined;\n }\n if (enabled !== false && linkingHandlers.length) {\n console.error(['Looks like you have configured linking in multiple places. This is likely an error since deep links should only be handled in one place to avoid conflicts. Make sure that:', \"- You don't have multiple NavigationContainers in the app each with 'linking' enabled\", '- Only a single instance of the root component is rendered'].join('\\n').trim());\n }\n const handler = Symbol();\n if (enabled !== false) {\n linkingHandlers.push(handler);\n }\n return () => {\n const index = linkingHandlers.indexOf(handler);\n if (index > -1) {\n linkingHandlers.splice(index, 1);\n }\n };\n }, [enabled, independent]);\n const [history] = React.useState(createMemoryHistory);\n\n // We store these options in ref to avoid re-creating getInitialState and re-subscribing listeners\n // This lets user avoid wrapping the items in `React.useCallback` or `React.useMemo`\n // Not re-creating `getInitialState` is important coz it makes it easier for the user to use in an effect\n const enabledRef = React.useRef(enabled);\n const configRef = React.useRef(config);\n const getStateFromPathRef = React.useRef(getStateFromPath);\n const getPathFromStateRef = React.useRef(getPathFromState);\n const getActionFromStateRef = React.useRef(getActionFromState);\n React.useEffect(() => {\n enabledRef.current = enabled;\n configRef.current = config;\n getStateFromPathRef.current = getStateFromPath;\n getPathFromStateRef.current = getPathFromState;\n getActionFromStateRef.current = getActionFromState;\n });\n const server = React.useContext(ServerContext);\n const getInitialState = React.useCallback(() => {\n let value;\n if (enabledRef.current) {\n const location = (server === null || server === void 0 ? void 0 : server.location) ?? (typeof window !== 'undefined' ? window.location : undefined);\n const path = location ? location.pathname + location.search : undefined;\n if (path) {\n value = getStateFromPathRef.current(path, configRef.current);\n }\n }\n const thenable = {\n then(onfulfilled) {\n return Promise.resolve(onfulfilled ? onfulfilled(value) : value);\n },\n catch() {\n return thenable;\n }\n };\n return thenable;\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n const previousIndexRef = React.useRef(undefined);\n const previousStateRef = React.useRef(undefined);\n const pendingPopStatePathRef = React.useRef(undefined);\n React.useEffect(() => {\n previousIndexRef.current = history.index;\n return history.listen(() => {\n const navigation = ref.current;\n if (!navigation || !enabled) {\n return;\n }\n const path = location.pathname + location.search;\n const index = history.index;\n const previousIndex = previousIndexRef.current ?? 0;\n previousIndexRef.current = index;\n pendingPopStatePathRef.current = path;\n\n // When browser back/forward is clicked, we first need to check if state object for this index exists\n // If it does we'll reset to that state object\n // Otherwise, we'll handle it like a regular deep link\n const record = history.get(index);\n if ((record === null || record === void 0 ? void 0 : record.path) === path && record !== null && record !== void 0 && record.state) {\n navigation.resetRoot(record.state);\n return;\n }\n const state = getStateFromPathRef.current(path, configRef.current);\n\n // We should only dispatch an action when going forward\n // Otherwise the action will likely add items to history, which would mess things up\n if (state) {\n // Make sure that the routes in the state exist in the root navigator\n // Otherwise there's an error in the linking configuration\n const rootState = navigation.getRootState();\n if (state.routes.some(r => !(rootState !== null && rootState !== void 0 && rootState.routeNames.includes(r.name)))) {\n console.warn(\"The navigation state parsed from the URL contains routes not present in the root navigator. This usually means that the linking configuration doesn't match the navigation structure. See https://reactnavigation.org/docs/configuring-links for more details on how to specify a linking configuration.\");\n return;\n }\n if (index > previousIndex) {\n const action = getActionFromStateRef.current(state, configRef.current);\n if (action !== undefined) {\n try {\n navigation.dispatch(action);\n } catch (e) {\n // Ignore any errors from deep linking.\n // This could happen in case of malformed links, navigation object not being initialized etc.\n console.warn(`An error occurred when trying to handle the link '${path}': ${typeof e === 'object' && e != null && 'message' in e ? e.message : e}`);\n }\n } else {\n navigation.resetRoot(state);\n }\n } else {\n navigation.resetRoot(state);\n }\n } else {\n // if current path didn't return any state, we should revert to initial state\n navigation.resetRoot(state);\n }\n });\n }, [enabled, history, ref]);\n React.useEffect(() => {\n var _ref$current;\n if (!enabled) {\n return;\n }\n const getPathForRoute = (route, state) => {\n // If the `route` object contains a `path`, use that path as long as `route.name` and `params` still match\n // This makes sure that we preserve the original URL for wildcard routes\n if (route !== null && route !== void 0 && route.path) {\n const stateForPath = getStateFromPathRef.current(route.path, configRef.current);\n if (stateForPath) {\n const focusedRoute = findFocusedRoute(stateForPath);\n if (focusedRoute && focusedRoute.name === route.name && isEqual(focusedRoute.params, route.params)) {\n return route.path;\n }\n }\n }\n return getPathFromStateRef.current(state, configRef.current);\n };\n if (ref.current) {\n // We need to record the current metadata on the first render if they aren't set\n // This will allow the initial state to be in the history entry\n const state = ref.current.getRootState();\n if (state) {\n const route = findFocusedRoute(state);\n const path = getPathForRoute(route, state);\n if (previousStateRef.current === undefined) {\n previousStateRef.current = state;\n }\n history.replace({\n path,\n state\n });\n }\n }\n const onStateChange = async () => {\n const navigation = ref.current;\n if (!navigation || !enabled) {\n return;\n }\n const previousState = previousStateRef.current;\n const state = navigation.getRootState();\n\n // root state may not available, for example when root navigators switch inside the container\n if (!state) {\n return;\n }\n const pendingPath = pendingPopStatePathRef.current;\n const route = findFocusedRoute(state);\n const path = getPathForRoute(route, state);\n previousStateRef.current = state;\n pendingPopStatePathRef.current = undefined;\n\n // To detect the kind of state change, we need to:\n // - Find the common focused navigation state in previous and current state\n // - If only the route keys changed, compare history/routes.length to check if we go back/forward/replace\n // - If no common focused navigation state found, it's a replace\n const [previousFocusedState, focusedState] = findMatchingState(previousState, state);\n if (previousFocusedState && focusedState &&\n // We should only handle push/pop if path changed from what was in last `popstate`\n // Otherwise it's likely a change triggered by `popstate`\n path !== pendingPath) {\n const historyDelta = (focusedState.history ? focusedState.history.length : focusedState.routes.length) - (previousFocusedState.history ? previousFocusedState.history.length : previousFocusedState.routes.length);\n if (historyDelta > 0) {\n // If history length is increased, we should pushState\n // Note that path might not actually change here, for example, drawer open should pushState\n history.push({\n path,\n state\n });\n } else if (historyDelta < 0) {\n // If history length is decreased, i.e. entries were removed, we want to go back\n\n const nextIndex = history.backIndex({\n path\n });\n const currentIndex = history.index;\n try {\n if (nextIndex !== -1 && nextIndex < currentIndex) {\n // An existing entry for this path exists and it's less than current index, go back to that\n await history.go(nextIndex - currentIndex);\n } else {\n // We couldn't find an existing entry to go back to, so we'll go back by the delta\n // This won't be correct if multiple routes were pushed in one go before\n // Usually this shouldn't happen and this is a fallback for that\n await history.go(historyDelta);\n }\n\n // Store the updated state as well as fix the path if incorrect\n history.replace({\n path,\n state\n });\n } catch (e) {\n // The navigation was interrupted\n }\n } else {\n // If history length is unchanged, we want to replaceState\n history.replace({\n path,\n state\n });\n }\n } else {\n // If no common navigation state was found, assume it's a replace\n // This would happen if the user did a reset/conditionally changed navigators\n history.replace({\n path,\n state\n });\n }\n };\n\n // We debounce onStateChange coz we don't want multiple state changes to be handled at one time\n // This could happen since `history.go(n)` is asynchronous\n // If `pushState` or `replaceState` were called before `history.go(n)` completes, it'll mess stuff up\n return (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.addListener('state', series(onStateChange));\n }, [enabled, history, ref]);\n return {\n getInitialState\n };\n}\n//# sourceMappingURL=useLinking.js.map","'use strict';\n\n// do not edit .js files directly - edit src/index.jst\n\n\n\nmodule.exports = function equal(a, b) {\n if (a === b) return true;\n\n if (a && b && typeof a == 'object' && typeof b == 'object') {\n if (a.constructor !== b.constructor) return false;\n\n var length, i, keys;\n if (Array.isArray(a)) {\n length = a.length;\n if (length != b.length) return false;\n for (i = length; i-- !== 0;)\n if (!equal(a[i], b[i])) return false;\n return true;\n }\n\n\n\n if (a.constructor === RegExp) return a.source === b.source && a.flags === b.flags;\n if (a.valueOf !== Object.prototype.valueOf) return a.valueOf() === b.valueOf();\n if (a.toString !== Object.prototype.toString) return a.toString() === b.toString();\n\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) return false;\n\n for (i = length; i-- !== 0;)\n if (!Object.prototype.hasOwnProperty.call(b, keys[i])) return false;\n\n for (i = length; i-- !== 0;) {\n var key = keys[i];\n\n if (!equal(a[key], b[key])) return false;\n }\n\n return true;\n }\n\n // true if both NaN, false otherwise\n return a!==a && b!==b;\n};\n","import { nanoid } from 'nanoid/non-secure';\nexport default function createMemoryHistory() {\n let index = 0;\n let items = [];\n\n // Pending callbacks for `history.go(n)`\n // We might modify the callback stored if it was interrupted, so we have a ref to identify it\n const pending = [];\n const interrupt = () => {\n // If another history operation was performed we need to interrupt existing ones\n // This makes sure that calls such as `history.replace` after `history.go` don't happen\n // Since otherwise it won't be correct if something else has changed\n pending.forEach(it => {\n const cb = it.cb;\n it.cb = () => cb(true);\n });\n };\n const history = {\n get index() {\n var _window$history$state;\n // We store an id in the state instead of an index\n // Index could get out of sync with in-memory values if page reloads\n const id = (_window$history$state = window.history.state) === null || _window$history$state === void 0 ? void 0 : _window$history$state.id;\n if (id) {\n const index = items.findIndex(item => item.id === id);\n return index > -1 ? index : 0;\n }\n return 0;\n },\n get(index) {\n return items[index];\n },\n backIndex(_ref) {\n let {\n path\n } = _ref;\n // We need to find the index from the element before current to get closest path to go back to\n for (let i = index - 1; i >= 0; i--) {\n const item = items[i];\n if (item.path === path) {\n return i;\n }\n }\n return -1;\n },\n push(_ref2) {\n let {\n path,\n state\n } = _ref2;\n interrupt();\n const id = nanoid();\n\n // When a new entry is pushed, all the existing entries after index will be inaccessible\n // So we remove any existing entries after the current index to clean them up\n items = items.slice(0, index + 1);\n items.push({\n path,\n state,\n id\n });\n index = items.length - 1;\n\n // We pass empty string for title because it's ignored in all browsers except safari\n // We don't store state object in history.state because:\n // - browsers have limits on how big it can be, and we don't control the size\n // - while not recommended, there could be non-serializable data in state\n window.history.pushState({\n id\n }, '', path);\n },\n replace(_ref3) {\n var _window$history$state2;\n let {\n path,\n state\n } = _ref3;\n interrupt();\n const id = ((_window$history$state2 = window.history.state) === null || _window$history$state2 === void 0 ? void 0 : _window$history$state2.id) ?? nanoid();\n\n // Need to keep the hash part of the path if there was no previous history entry\n // or the previous history entry had the same path\n let pathWithHash = path;\n if (!items.length || items.findIndex(item => item.id === id) < 0) {\n // There are two scenarios for creating an array with only one history record:\n // - When loaded id not found in the items array, this function by default will replace\n // the first item. We need to keep only the new updated object, otherwise it will break\n // the page when navigating forward in history.\n // - This is the first time any state modifications are done\n // So we need to push the entry as there's nothing to replace\n pathWithHash = pathWithHash + location.hash;\n items = [{\n path: pathWithHash,\n state,\n id\n }];\n index = 0;\n } else {\n if (items[index].path === path) {\n pathWithHash = pathWithHash + location.hash;\n }\n items[index] = {\n path,\n state,\n id\n };\n }\n window.history.replaceState({\n id\n }, '', pathWithHash);\n },\n // `history.go(n)` is asynchronous, there are couple of things to keep in mind:\n // - it won't do anything if we can't go `n` steps, the `popstate` event won't fire.\n // - each `history.go(n)` call will trigger a separate `popstate` event with correct location.\n // - the `popstate` event fires before the next frame after calling `history.go(n)`.\n // This method differs from `history.go(n)` in the sense that it'll go back as many steps it can.\n go(n) {\n interrupt();\n\n // To guard against unexpected navigation out of the app we will assume that browser history is only as deep as the length of our memory\n // history. If we don't have an item to navigate to then update our index and navigate as far as we can without taking the user out of the app.\n const nextIndex = index + n;\n const lastItemIndex = items.length - 1;\n if (n < 0 && !items[nextIndex]) {\n // Attempted to navigate beyond the first index. Negating the current index will align the browser history with the first item.\n n = -index;\n index = 0;\n } else if (n > 0 && nextIndex > lastItemIndex) {\n // Attempted to navigate past the last index. Calculate how many indices away from the last index and go there.\n n = lastItemIndex - index;\n index = lastItemIndex;\n } else {\n index = nextIndex;\n }\n if (n === 0) {\n return;\n }\n\n // When we call `history.go`, `popstate` will fire when there's history to go back to\n // So we need to somehow handle following cases:\n // - There's history to go back, `history.go` is called, and `popstate` fires\n // - `history.go` is called multiple times, we need to resolve on respective `popstate`\n // - No history to go back, but `history.go` was called, browser has no API to detect it\n return new Promise((resolve, reject) => {\n const done = interrupted => {\n clearTimeout(timer);\n if (interrupted) {\n reject(new Error('History was changed during navigation.'));\n return;\n }\n\n // There seems to be a bug in Chrome regarding updating the title\n // If we set a title just before calling `history.go`, the title gets lost\n // However the value of `document.title` is still what we set it to\n // It's just not displayed in the tab bar\n // To update the tab bar, we need to reset the title to something else first (e.g. '')\n // And set the title to what it was before so it gets applied\n // It won't work without setting it to empty string coz otherwise title isn't changing\n // Which means that the browser won't do anything after setting the title\n const {\n title\n } = window.document;\n window.document.title = '';\n window.document.title = title;\n resolve();\n };\n pending.push({\n ref: done,\n cb: done\n });\n\n // If navigation didn't happen within 100ms, assume that it won't happen\n // This may not be accurate, but hopefully it won't take so much time\n // In Chrome, navigation seems to happen instantly in next microtask\n // But on Firefox, it seems to take much longer, around 50ms from our testing\n // We're using a hacky timeout since there doesn't seem to be way to know for sure\n const timer = setTimeout(() => {\n const index = pending.findIndex(it => it.ref === done);\n if (index > -1) {\n pending[index].cb();\n pending.splice(index, 1);\n }\n }, 100);\n const onPopState = () => {\n var _window$history$state3;\n const id = (_window$history$state3 = window.history.state) === null || _window$history$state3 === void 0 ? void 0 : _window$history$state3.id;\n const currentIndex = items.findIndex(item => item.id === id);\n\n // Fix createMemoryHistory.index variable's value\n // as it may go out of sync when navigating in the browser.\n index = Math.max(currentIndex, 0);\n const last = pending.pop();\n window.removeEventListener('popstate', onPopState);\n last === null || last === void 0 ? void 0 : last.cb();\n };\n window.addEventListener('popstate', onPopState);\n window.history.go(n);\n });\n },\n // The `popstate` event is triggered when history changes, except `pushState` and `replaceState`\n // If we call `history.go(n)` ourselves, we don't want it to trigger the listener\n // Here we normalize it so that only external changes (e.g. user pressing back/forward) trigger the listener\n listen(listener) {\n const onPopState = () => {\n if (pending.length) {\n // This was triggered by `history.go(n)`, we shouldn't call the listener\n return;\n }\n listener();\n };\n window.addEventListener('popstate', onPopState);\n return () => window.removeEventListener('popstate', onPopState);\n }\n };\n return history;\n}\n//# sourceMappingURL=createMemoryHistory.js.map","import * as React from 'react';\nconst ServerContext = /*#__PURE__*/React.createContext(undefined);\nexport default ServerContext;\n//# sourceMappingURL=ServerContext.js.map","import * as React from 'react';\nexport default function useThenable(create) {\n const [promise] = React.useState(create);\n let initialState = [false, undefined];\n\n // Check if our thenable is synchronous\n promise.then(result => {\n initialState = [true, result];\n });\n const [state, setState] = React.useState(initialState);\n const [resolved] = state;\n React.useEffect(() => {\n let cancelled = false;\n const resolve = async () => {\n let result;\n try {\n result = await promise;\n } finally {\n if (!cancelled) {\n setState([true, result]);\n }\n }\n };\n if (!resolved) {\n resolve();\n }\n return () => {\n cancelled = true;\n };\n }, [promise, resolved]);\n return state;\n}\n//# sourceMappingURL=useThenable.js.map","import { CurrentRenderContext } from '@react-navigation/core';\nimport * as React from 'react';\nimport ServerContext from './ServerContext';\n/**\n * Container component for server rendering.\n *\n * @param props.location Location object to base the initial URL for SSR.\n * @param props.children Child elements to render the content.\n * @param props.ref Ref object which contains helper methods.\n */\nexport default /*#__PURE__*/React.forwardRef(function ServerContainer(_ref, ref) {\n let {\n children,\n location\n } = _ref;\n React.useEffect(() => {\n console.error(\"'ServerContainer' should only be used on the server with 'react-dom/server' for SSR.\");\n }, []);\n const current = {};\n if (ref) {\n const value = {\n getCurrentOptions() {\n return current.options;\n }\n };\n\n // We write to the `ref` during render instead of `React.useImperativeHandle`\n // This is because `useImperativeHandle` will update the ref after 'commit',\n // and there's no 'commit' phase during SSR.\n // Mutating ref during render is unsafe in concurrent mode, but we don't care about it for SSR.\n if (typeof ref === 'function') {\n ref(value);\n } else {\n // @ts-expect-error: the TS types are incorrect and say that ref.current is readonly\n ref.current = value;\n }\n }\n return /*#__PURE__*/React.createElement(ServerContext.Provider, {\n value: {\n location\n }\n }, /*#__PURE__*/React.createElement(CurrentRenderContext.Provider, {\n value: current\n }, children));\n});\n//# sourceMappingURL=ServerContainer.js.map","const DarkTheme = {\n dark: true,\n colors: {\n primary: 'rgb(10, 132, 255)',\n background: 'rgb(1, 1, 1)',\n card: 'rgb(18, 18, 18)',\n text: 'rgb(229, 229, 231)',\n border: 'rgb(39, 39, 41)',\n notification: 'rgb(255, 69, 58)'\n }\n};\nexport default DarkTheme;\n//# sourceMappingURL=DarkTheme.js.map","import * as React from 'react';\nimport ThemeContext from './ThemeContext';\nexport default function useTheme() {\n const theme = React.useContext(ThemeContext);\n return theme;\n}\n//# sourceMappingURL=useTheme.js.map","export {};\n//# sourceMappingURL=types.js.map","import { getPathFromState, NavigationHelpersContext } from '@react-navigation/core';\nimport * as React from 'react';\nimport LinkingContext from './LinkingContext';\nconst getRootStateForNavigate = (navigation, state) => {\n const parent = navigation.getParent();\n if (parent) {\n const parentState = parent.getState();\n return getRootStateForNavigate(parent, {\n index: 0,\n routes: [{\n ...parentState.routes[parentState.index],\n state: state\n }]\n });\n }\n return state;\n};\n\n/**\n * Build destination link for a navigate action.\n * Useful for showing anchor tags on the web for buttons that perform navigation.\n */\nexport default function useLinkBuilder() {\n const navigation = React.useContext(NavigationHelpersContext);\n const linking = React.useContext(LinkingContext);\n const buildLink = React.useCallback((name, params) => {\n const {\n options\n } = linking;\n if ((options === null || options === void 0 ? void 0 : options.enabled) === false) {\n return undefined;\n }\n const state = navigation ? getRootStateForNavigate(navigation, {\n index: 0,\n routes: [{\n name,\n params\n }]\n }) :\n // If we couldn't find a navigation object in context, we're at root\n // So we'll construct a basic state object to use\n {\n index: 0,\n routes: [{\n name,\n params\n }]\n };\n const path = options !== null && options !== void 0 && options.getPathFromState ? options.getPathFromState(state, options === null || options === void 0 ? void 0 : options.config) : getPathFromState(state, options === null || options === void 0 ? void 0 : options.config);\n return path;\n }, [linking, navigation]);\n return buildLink;\n}\n//# sourceMappingURL=useLinkBuilder.js.map","import { useNavigation, useRoute } from '@react-navigation/core';\nimport * as React from 'react';\nfunction getScrollableNode(ref) {\n if (ref.current == null) {\n return null;\n }\n if ('scrollToTop' in ref.current || 'scrollTo' in ref.current || 'scrollToOffset' in ref.current || 'scrollResponderScrollTo' in ref.current) {\n // This is already a scrollable node.\n return ref.current;\n } else if ('getScrollResponder' in ref.current) {\n // If the view is a wrapper like FlatList, SectionList etc.\n // We need to use `getScrollResponder` to get access to the scroll responder\n return ref.current.getScrollResponder();\n } else if ('getNode' in ref.current) {\n // When a `ScrollView` is wraped in `Animated.createAnimatedComponent`\n // we need to use `getNode` to get the ref to the actual scrollview.\n // Note that `getNode` is deprecated in newer versions of react-native\n // this is why we check if we already have a scrollable node above.\n return ref.current.getNode();\n } else {\n return ref.current;\n }\n}\nexport default function useScrollToTop(ref) {\n const navigation = useNavigation();\n const route = useRoute();\n React.useEffect(() => {\n let tabNavigations = [];\n let currentNavigation = navigation;\n\n // If the screen is nested inside multiple tab navigators, we should scroll to top for any of them\n // So we need to find all the parent tab navigators and add the listeners there\n while (currentNavigation) {\n if (currentNavigation.getState().type === 'tab') {\n tabNavigations.push(currentNavigation);\n }\n currentNavigation = currentNavigation.getParent();\n }\n if (tabNavigations.length === 0) {\n return;\n }\n const unsubscribers = tabNavigations.map(tab => {\n return tab.addListener(\n // We don't wanna import tab types here to avoid extra deps\n // in addition, there are multiple tab implementations\n // @ts-expect-error\n 'tabPress', e => {\n // We should scroll to top only when the screen is focused\n const isFocused = navigation.isFocused();\n\n // In a nested stack navigator, tab press resets the stack to first screen\n // So we should scroll to top only when we are on first screen\n const isFirst = tabNavigations.includes(navigation) || navigation.getState().routes[0].key === route.key;\n\n // Run the operation in the next frame so we're sure all listeners have been run\n // This is necessary to know if preventDefault() has been called\n requestAnimationFrame(() => {\n const scrollable = getScrollableNode(ref);\n if (isFocused && isFirst && scrollable && !e.defaultPrevented) {\n if ('scrollToTop' in scrollable) {\n scrollable.scrollToTop();\n } else if ('scrollTo' in scrollable) {\n scrollable.scrollTo({\n y: 0,\n animated: true\n });\n } else if ('scrollToOffset' in scrollable) {\n scrollable.scrollToOffset({\n offset: 0,\n animated: true\n });\n } else if ('scrollResponderScrollTo' in scrollable) {\n scrollable.scrollResponderScrollTo({\n y: 0,\n animated: true\n });\n }\n }\n });\n });\n });\n return () => {\n unsubscribers.forEach(unsubscribe => unsubscribe());\n };\n }, [navigation, ref, route.key]);\n}\n//# sourceMappingURL=useScrollToTop.js.map","\nimport { MD2LightTheme as DefaultTheme,} from 'react-native-paper';\n\nimport {configureFonts} from \"react-native-paper\";\n\nconst fontConfig = {\n web: {\n black: {\n fontFamily: 'Montserrat-Black',\n fontWeight: 'normal',\n },\n bold: {\n fontFamily: 'Montserrat-Bold',\n fontWeight: 'normal',\n },\n extrabold: {\n fontFamily: 'Montserrat-ExtraBold',\n fontWeight: 'normal',\n },\n semibold: {\n fontFamily: 'Montserrat-SemiBold',\n fontWeight: 'normal',\n },\n regular: {\n fontFamily: 'Montserrat-Regular',\n fontWeight: 'normal',\n },\n medium: {\n fontFamily: 'Montserrat-Medium',\n fontWeight: 'normal',\n },\n light: {\n fontFamily: 'Montserrat-Light',\n fontWeight: 'normal',\n },\n thin: {\n fontFamily: 'Montserrat-Thin',\n fontWeight: 'normal',\n },\n },\n ios: {\n black: {\n fontFamily: 'Montserrat-Black',\n fontWeight: 'normal',\n },\n bold: {\n fontFamily: 'Montserrat-Bold',\n fontWeight: 'normal',\n },\n extrabold: {\n fontFamily: 'Montserrat-ExtraBold',\n fontWeight: 'normal',\n },\n semibold: {\n fontFamily: 'Montserrat-SemiBold',\n fontWeight: 'normal',\n },\n regular: {\n fontFamily: 'Montserrat-Regular',\n fontWeight: 'normal',\n },\n medium: {\n fontFamily: 'Montserrat-Medium',\n fontWeight: 'normal',\n },\n light: {\n fontFamily: 'Montserrat-Light',\n fontWeight: 'normal',\n },\n thin: {\n fontFamily: 'Montserrat-Thin',\n fontWeight: 'normal',\n },\n },\n android: {\n black: {\n fontFamily: 'Montserrat-Black',\n fontWeight: 'normal',\n },\n bold: {\n fontFamily: 'Montserrat-Bold',\n fontWeight: 'normal',\n },\n extrabold: {\n fontFamily: 'Montserrat-ExtraBold',\n fontWeight: 'normal',\n },\n semibold: {\n fontFamily: 'Montserrat-SemiBold',\n fontWeight: 'normal',\n },\n regular: {\n fontFamily: 'Montserrat-Regular',\n fontWeight: 'normal',\n },\n medium: {\n fontFamily: 'Montserrat-Medium',\n fontWeight: 'normal',\n },\n light: {\n fontFamily: 'Montserrat-Light',\n fontWeight: 'normal',\n },\n thin: {\n fontFamily: 'Montserrat-Thin',\n fontWeight: 'normal',\n },\n }\n};\n\nexport const theme = {\n ...DefaultTheme,\n fonts: configureFonts({config: fontConfig, isV3: false}),\n colors: {\n ...DefaultTheme.colors,\n background: \"#fafafa\",\n primary: '#223F8F',\n primaryTransparent: '#223F8FAA',\n primaryLight: '#999db3',\n primaryLighter: '#f3f5ff',\n accentDark: '#f1ba00',\n accent: '#ffc80a',\n accentLight: '#FFDC64',\n accentLighter: '#fff1db',\n successDark: '#249e7f',\n success: '#00BE89',\n successTransparent: '#01AE5144',\n phone: '#4CABB4',\n phoneLight: '#cdfbff',\n successLighter: '#59bba0',\n successGray: '#bad3cb',\n successLight: '#f1fff3',\n successLightMore: '#f7fff8',\n warning: '#ff9f43',\n warningLight: '#fff1e6',\n warningLighter: '#ffb980',\n error: '#ea5455',\n errorLight: '#ffe5e5',\n errorLighter: '#ff7171',\n errorDark: '#662526',\n brown: '#895D33',\n info: '#00cfe8',\n white: '#ffffff',\n whiteTransparentMore: '#ffffff99',\n whiteTransparent: '#ffffff44',\n light: '#aaaaaa',\n lightMore: '#e2e2e2',\n lightMoreTransparent: '#e2e2e244',\n lighter: '#F3F3F3',\n whiteAlmost: '#fafafa',\n linkAlt: '#662FFF',\n link: '#2F66FF',\n linkLight: '#779bff',\n linkLighter: '#e0ebff',\n xp: '#01AE51',\n xpText: '#004D24',\n feather: '#2D2F38',\n greyAlt: '#6E6E6E',\n grey: '#505050',\n greyBg: '#F2F2F2',\n black: '#000000',\n blackTransparent: '#00000033',\n blackTransparent2: '#00000066',\n petal: '#9DD767',\n petalDarker: '#80af54',\n petalNew: '#D3918F',\n petalNewDarker: '#985857',\n gems: '#BC3B60',\n gemsLight: '#ffe5ed',\n transparent: '#FFFFFF00',\n purple: '#7A6EB5',\n purpleTransparent: '#7A6EB588',\n purpleLight: '#faf9ff',\n zoe: '#D98759',\n zoeLight: '#F2EB64',\n abou: '#9650C9',\n abouLight: '#DCC1F7',\n sam: '#3B708E',\n samLight: '#8ABFEA',\n tina: '#45D090',\n tinaLight: '#9CF6C7',\n tintColors: [\n \"#FF6B6B\", // A vibrant red\n \"#4ECDC4\", // A calming teal\n \"#FFD166\", // A sunny yellow\n \"#06D6A0\", // A bright turquoise\n \"#8338EC\", // A lively purple\n \"#FF9F1C\", // A zesty orange\n \"#3A86FF\", // A clear blue\n \"#118AB2\", // A deep ocean blue\n \"#EE6352\", // A warm coral\n \"#6F2DBD\" // A rich violet\n ],\n material: {\n \"primary\": {\n \"50\": \"#e7eaf4\",\n \"100\": \"#c2c9e3\",\n \"200\": \"#9aa6d0\",\n \"300\": \"#7284be\",\n \"400\": \"#536ab1\",\n \"500\": \"#3250a4\",\n \"600\": \"#2c499b\",\n \"700\": \"#223f8f\", // main primary\n \"800\": \"#1a3583\",\n \"900\": \"#0a256d\"\n },\n \"secondary\": {\n \"50\": \"#fff8e0\",\n \"100\": \"#ffecb0\",\n \"200\": \"#ffe07c\",\n \"300\": \"#ffd544\",\n \"400\": \"#ffc80a\", // main secondary\n \"500\": \"#ffc100\",\n \"600\": \"#ffb200\",\n \"700\": \"#ff9f00\",\n \"800\": \"#ff8d00\",\n \"900\": \"#ff6b00\"\n }\n },\n },\n roundness: 15,\n animation: {\n scale: 1.0,\n },\n};","export { MD3Colors } from './styles/themes/v3/tokens';\nexport { useTheme, withTheme, ThemeProvider, DefaultTheme, adaptNavigationTheme } from './core/theming';\nexport * from './styles/themes';\nexport { default as Provider } from './core/PaperProvider';\nexport { default as PaperProvider } from './core/PaperProvider';\nexport { default as shadow } from './styles/shadow';\nexport { default as overlay } from './styles/overlay';\nexport { default as configureFonts } from './styles/fonts';\nimport * as Avatar from './components/Avatar/Avatar';\nimport * as Drawer from './components/Drawer/Drawer';\nimport * as List from './components/List/List';\nimport * as MD2Colors from './styles/themes/v2/colors';\nexport { MD2Colors };\nexport { Avatar, List, Drawer };\nexport * from './components/FAB/AnimatedFAB';\nexport { default as Badge } from './components/Badge';\nexport { default as ActivityIndicator } from './components/ActivityIndicator';\nexport { default as Banner } from './components/Banner';\nexport { default as BottomNavigation } from './components/BottomNavigation/BottomNavigation';\nexport { default as Button } from './components/Button/Button';\nexport { default as Card } from './components/Card/Card';\nexport { default as Checkbox } from './components/Checkbox';\nexport { default as Chip } from './components/Chip/Chip';\nexport { default as DataTable } from './components/DataTable/DataTable';\nexport { default as Dialog } from './components/Dialog/Dialog';\nexport { default as Divider } from './components/Divider';\nexport { default as FAB } from './components/FAB';\nexport { default as AnimatedFAB } from './components/FAB/AnimatedFAB';\nexport { default as HelperText } from './components/HelperText/HelperText';\nexport { default as Icon } from './components/Icon';\nexport { default as IconButton } from './components/IconButton/IconButton';\nexport { default as Menu } from './components/Menu/Menu';\nexport { default as Modal } from './components/Modal';\nexport { default as Portal } from './components/Portal/Portal';\nexport { default as ProgressBar } from './components/ProgressBar';\nexport { default as RadioButton } from './components/RadioButton';\nexport { default as Searchbar } from './components/Searchbar';\nexport { default as Snackbar } from './components/Snackbar';\nexport { default as Surface } from './components/Surface';\nexport { default as Switch } from './components/Switch/Switch';\nexport { default as Appbar } from './components/Appbar';\nexport { default as TouchableRipple } from './components/TouchableRipple/TouchableRipple';\nexport { default as TextInput } from './components/TextInput/TextInput';\nexport { default as ToggleButton } from './components/ToggleButton';\nexport { default as SegmentedButtons } from './components/SegmentedButtons/SegmentedButtons';\nexport { default as Tooltip } from './components/Tooltip/Tooltip';\nexport { Caption, Headline, Paragraph, Subheading, Title } from './components/Typography/v2';\nexport { default as Text, customText } from './components/Typography/Text';\n\n// Types\n//# sourceMappingURL=index.js.map","import { Animated } from 'react-native';\nimport * as MD2Colors from './themes/v2/colors';\nimport { MD3Colors } from './themes/v3/tokens';\nconst SHADOW_COLOR = MD2Colors.black;\nconst SHADOW_OPACITY = 0.24;\nconst MD3_SHADOW_OPACITY = 0.3;\nconst MD3_SHADOW_COLOR = MD3Colors.primary0;\nexport default function shadow() {\n let elevation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n let isV3 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n return isV3 ? v3Shadow(elevation) : v2Shadow(elevation);\n}\nfunction v2Shadow() {\n let elevation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n if (elevation instanceof Animated.Value) {\n const inputRange = [0, 1, 2, 3, 8, 24];\n return {\n shadowColor: SHADOW_COLOR,\n shadowOffset: {\n width: new Animated.Value(0),\n height: elevation.interpolate({\n inputRange,\n outputRange: [0, 0.5, 0.75, 2, 7, 23]\n })\n },\n shadowOpacity: elevation.interpolate({\n inputRange: [0, 1],\n outputRange: [0, SHADOW_OPACITY],\n extrapolate: 'clamp'\n }),\n shadowRadius: elevation.interpolate({\n inputRange,\n outputRange: [0, 0.75, 1.5, 3, 8, 24]\n })\n };\n } else {\n if (elevation === 0) {\n return {};\n }\n let height, radius;\n switch (elevation) {\n case 1:\n height = 0.5;\n radius = 0.75;\n break;\n case 2:\n height = 0.75;\n radius = 1.5;\n break;\n default:\n height = elevation - 1;\n radius = elevation;\n }\n return {\n shadowColor: SHADOW_COLOR,\n shadowOffset: {\n width: 0,\n height\n },\n shadowOpacity: SHADOW_OPACITY,\n shadowRadius: radius\n };\n }\n}\nfunction v3Shadow() {\n let elevation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n const inputRange = [0, 1, 2, 3, 4, 5];\n const shadowHeight = [0, 1, 2, 4, 6, 8];\n const shadowRadius = [0, 3, 6, 8, 10, 12];\n if (elevation instanceof Animated.Value) {\n return {\n shadowColor: MD3_SHADOW_COLOR,\n shadowOffset: {\n width: new Animated.Value(0),\n height: elevation.interpolate({\n inputRange,\n outputRange: shadowHeight\n })\n },\n shadowOpacity: elevation.interpolate({\n inputRange: [0, 1],\n outputRange: [0, MD3_SHADOW_OPACITY],\n extrapolate: 'clamp'\n }),\n shadowRadius: elevation.interpolate({\n inputRange,\n outputRange: shadowRadius\n })\n };\n } else {\n return {\n shadowColor: MD3_SHADOW_COLOR,\n shadowOpacity: elevation ? MD3_SHADOW_OPACITY : 0,\n shadowOffset: {\n width: 0,\n height: shadowHeight[elevation]\n },\n shadowRadius: shadowRadius[elevation]\n };\n }\n}\n//# sourceMappingURL=shadow.js.map","import { Animated } from 'react-native';\nimport color from 'color';\nimport { MD2DarkTheme } from './themes/v2/DarkTheme';\nexport const isAnimatedValue = it => it instanceof Animated.Value;\nexport default function overlay(elevation) {\n var _MD2DarkTheme$colors;\n let surfaceColor = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : (_MD2DarkTheme$colors = MD2DarkTheme.colors) === null || _MD2DarkTheme$colors === void 0 ? void 0 : _MD2DarkTheme$colors.surface;\n if (isAnimatedValue(elevation)) {\n const inputRange = [0, 1, 2, 3, 8, 24];\n\n // @ts-expect-error: TS doesn't seem to refine the type correctly\n return elevation.interpolate({\n inputRange,\n outputRange: inputRange.map(elevation => {\n return calculateColor(surfaceColor, elevation);\n })\n });\n }\n\n // @ts-expect-error: TS doesn't seem to refine the type correctly\n return calculateColor(surfaceColor, elevation);\n}\nfunction calculateColor(surfaceColor) {\n let elevation = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;\n let overlayTransparency;\n if (elevation >= 1 && elevation <= 24) {\n overlayTransparency = elevationOverlayTransparency[elevation];\n } else if (elevation > 24) {\n overlayTransparency = elevationOverlayTransparency[24];\n } else {\n overlayTransparency = elevationOverlayTransparency[1];\n }\n return color(surfaceColor).mix(color('white'), overlayTransparency * 0.01).hex();\n}\nconst elevationOverlayTransparency = {\n 1: 5,\n 2: 7,\n 3: 8,\n 4: 9,\n 5: 10,\n 6: 11,\n 7: 11.5,\n 8: 12,\n 9: 12.5,\n 10: 13,\n 11: 13.5,\n 12: 14,\n 13: 14.25,\n 14: 14.5,\n 15: 14.75,\n 16: 15,\n 17: 15.12,\n 18: 15.24,\n 19: 15.36,\n 20: 15.48,\n 21: 15.6,\n 22: 15.72,\n 23: 15.84,\n 24: 16\n};\n//# sourceMappingURL=overlay.js.map","// @component ./AvatarIcon.tsx\nexport { default as Icon } from './AvatarIcon';\n\n// @component ./AvatarImage.tsx\nexport { default as Image } from './AvatarImage';\n\n// @component ./AvatarText.tsx\nexport { default as Text } from './AvatarText';\n//# sourceMappingURL=Avatar.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\nimport { white } from '../../styles/themes/v2/colors';\nimport getContrastingColor from '../../utils/getContrastingColor';\nimport Icon from '../Icon';\nconst defaultSize = 64;\n/**\n * Avatars can be used to represent people in a graphical way.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Avatar } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n * ```\n */\nconst Avatar = _ref => {\n var _theme$colors;\n let {\n icon,\n size = defaultSize,\n style,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n backgroundColor = (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.primary,\n ...restStyle\n } = StyleSheet.flatten(style) || {};\n const textColor = rest.color ?? getContrastingColor(backgroundColor, white, 'rgba(0, 0, 0, .54)');\n return /*#__PURE__*/React.createElement(View, _extends({\n style: [{\n width: size,\n height: size,\n borderRadius: size / 2,\n backgroundColor\n }, styles.container, restStyle]\n }, rest), /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n color: textColor,\n size: size * 0.6\n }));\n};\nAvatar.displayName = 'Avatar.Icon';\nconst styles = StyleSheet.create({\n container: {\n justifyContent: 'center',\n alignItems: 'center'\n }\n});\nexport default Avatar;\n//# sourceMappingURL=AvatarIcon.js.map","import color from 'color';\nexport default function getContrastingColor(input, light, dark) {\n if (typeof input === 'string') {\n return color(input).isLight() ? dark : light;\n }\n return light;\n}\n//# sourceMappingURL=getContrastingColor.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { I18nManager, Image, Platform } from 'react-native';\nimport { accessibilityProps } from './MaterialCommunityIcon';\nimport { Consumer as SettingsConsumer } from '../core/settings';\nimport { useInternalTheme } from '../core/theming';\nconst isImageSource = source =>\n// source is an object with uri\ntypeof source === 'object' && source !== null && Object.prototype.hasOwnProperty.call(source, 'uri') && typeof source.uri === 'string' ||\n// source is a module, e.g. - require('image')\ntypeof source === 'number' ||\n// image url on web\nPlatform.OS === 'web' && typeof source === 'string' && (source.startsWith('data:image') || /\\.(bmp|jpg|jpeg|png|gif|svg)$/.test(source));\nconst getIconId = source => {\n if (typeof source === 'object' && source !== null && Object.prototype.hasOwnProperty.call(source, 'uri') && typeof source.uri === 'string') {\n return source.uri;\n }\n return source;\n};\nexport const isValidIcon = source => typeof source === 'string' || typeof source === 'function' || isImageSource(source);\nexport const isEqualIcon = (a, b) => a === b || getIconId(a) === getIconId(b);\n/**\n * An icon component which renders icon from vector library.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Icon, MD3Colors } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\n\nconst Icon = _ref => {\n let {\n source,\n color,\n size,\n theme: themeOverrides,\n testID,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const direction = typeof source === 'object' && source.direction && source.source ? source.direction === 'auto' ? I18nManager.getConstants().isRTL ? 'rtl' : 'ltr' : source.direction : null;\n const s = typeof source === 'object' && source.direction && source.source ? source.source : source;\n const iconColor = color || (theme.isV3 ? theme.colors.onSurface : theme.colors.text);\n if (isImageSource(s)) {\n return /*#__PURE__*/React.createElement(Image, _extends({}, rest, {\n testID: testID,\n source: s,\n style: [{\n transform: [{\n scaleX: direction === 'rtl' ? -1 : 1\n }]\n }, {\n width: size,\n height: size,\n tintColor: color,\n resizeMode: `contain`\n }]\n }, accessibilityProps, {\n accessibilityIgnoresInvertColors: true\n }));\n } else if (typeof s === 'string') {\n return /*#__PURE__*/React.createElement(SettingsConsumer, null, _ref2 => {\n let {\n icon\n } = _ref2;\n return icon === null || icon === void 0 ? void 0 : icon({\n name: s,\n color: iconColor,\n size,\n direction,\n testID\n });\n });\n } else if (typeof s === 'function') {\n return s({\n color: iconColor,\n size,\n direction,\n testID\n });\n }\n return null;\n};\nexport default Icon;\n//# sourceMappingURL=Icon.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Image, StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\nconst defaultSize = 64;\n/**\n * Avatars can be used to represent people in a graphical way.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Avatar } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n * export default MyComponent\n * ```\n */\nconst AvatarImage = _ref => {\n let {\n size = defaultSize,\n source,\n style,\n onError,\n onLayout,\n onLoad,\n onLoadEnd,\n onLoadStart,\n onProgress,\n theme: themeOverrides,\n testID,\n ...rest\n } = _ref;\n const {\n colors\n } = useInternalTheme(themeOverrides);\n const {\n backgroundColor = colors === null || colors === void 0 ? void 0 : colors.primary\n } = StyleSheet.flatten(style) || {};\n return /*#__PURE__*/React.createElement(View, _extends({\n style: [{\n width: size,\n height: size,\n borderRadius: size / 2,\n backgroundColor\n }, style]\n }, rest), typeof source === 'function' && source({\n size\n }), typeof source !== 'function' && /*#__PURE__*/React.createElement(Image, {\n testID: testID,\n source: source,\n style: {\n width: size,\n height: size,\n borderRadius: size / 2\n },\n onError: onError,\n onLayout: onLayout,\n onLoad: onLoad,\n onLoadEnd: onLoadEnd,\n onLoadStart: onLoadStart,\n onProgress: onProgress,\n accessibilityIgnoresInvertColors: true\n }));\n};\nAvatarImage.displayName = 'Avatar.Image';\nexport default AvatarImage;\n//# sourceMappingURL=AvatarImage.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, useWindowDimensions, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\nimport { white } from '../../styles/themes/v2/colors';\nimport getContrastingColor from '../../utils/getContrastingColor';\nimport Text from '../Typography/Text';\nconst defaultSize = 64;\n/**\n * Avatars can be used to represent people in a graphical way.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Avatar } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n * ```\n */\nconst AvatarText = _ref => {\n var _theme$colors;\n let {\n label,\n size = defaultSize,\n style,\n labelStyle,\n color: customColor,\n theme: themeOverrides,\n maxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n backgroundColor = (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.primary,\n ...restStyle\n } = StyleSheet.flatten(style) || {};\n const textColor = customColor ?? getContrastingColor(backgroundColor, white, 'rgba(0, 0, 0, .54)');\n const {\n fontScale\n } = useWindowDimensions();\n return /*#__PURE__*/React.createElement(View, _extends({\n style: [{\n width: size,\n height: size,\n borderRadius: size / 2,\n backgroundColor\n }, styles.container, restStyle]\n }, rest), /*#__PURE__*/React.createElement(Text, {\n style: [styles.text, {\n color: textColor,\n fontSize: size / 2,\n lineHeight: size / fontScale\n }, labelStyle],\n numberOfLines: 1,\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, label));\n};\nAvatarText.displayName = 'Avatar.Text';\nconst styles = StyleSheet.create({\n container: {\n justifyContent: 'center',\n alignItems: 'center'\n },\n text: {\n textAlign: 'center',\n textAlignVertical: 'center'\n }\n});\nexport default AvatarText;\n//# sourceMappingURL=AvatarText.js.map","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n * \n */\n\n'use strict';\n\nimport Dimensions from '../Dimensions';\nimport { useEffect, useState } from 'react';\nexport default function useWindowDimensions() {\n var _useState = useState(() => Dimensions.get('window')),\n dims = _useState[0],\n setDims = _useState[1];\n useEffect(() => {\n function handleChange(_ref) {\n var window = _ref.window;\n if (window != null) {\n setDims(window);\n }\n }\n Dimensions.addEventListener('change', handleChange);\n // We might have missed an update between calling `get` in render and\n // `addEventListener` in this handler, so we set it here. If there was\n // no change, React will filter out this update as a no-op.\n setDims(Dimensions.get('window'));\n return () => {\n Dimensions.removeEventListener('change', handleChange);\n };\n }, []);\n return dims;\n}","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { I18nManager, StyleSheet, Text as NativeText } from 'react-native';\nimport AnimatedText from './AnimatedText';\nimport StyledText from './v2/StyledText';\nimport { useInternalTheme } from '../../core/theming';\nimport { forwardRef } from '../../utils/forwardRef';\n// @component-group Typography\n/**\n * Typography component showing styles complied with passed `variant` prop and supported by the type system.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Text } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * <>\n * Display Large\n * Display Medium\n * Display small\n *\n * Headline Large\n * Headline Medium\n * Headline Small\n *\n * Title Large\n * Title Medium\n * Title Small\n *\n * Body Large\n * Body Medium\n * Body Small\n *\n * Label Large\n * Label Medium\n * Label Small\n * \n * );\n *\n * export default MyComponent;\n * ```\n *\n * @extends Text props https://reactnative.dev/docs/text#props\n */\nconst Text = (_ref, ref) => {\n let {\n style,\n variant,\n theme: initialTheme,\n ...rest\n } = _ref;\n const root = React.useRef(null);\n // FIXME: destructure it in TS 4.6+\n const theme = useInternalTheme(initialTheme);\n const writingDirection = I18nManager.getConstants().isRTL ? 'rtl' : 'ltr';\n React.useImperativeHandle(ref, () => ({\n setNativeProps: args => {\n var _root$current;\n return (_root$current = root.current) === null || _root$current === void 0 ? void 0 : _root$current.setNativeProps(args);\n }\n }));\n if (theme.isV3 && variant) {\n let font = theme.fonts[variant];\n let textStyle = [font, style];\n if ( /*#__PURE__*/React.isValidElement(rest.children) && (rest.children.type === Component || rest.children.type === AnimatedText || rest.children.type === StyledText)) {\n const {\n props\n } = rest.children;\n\n // Context: Some components have the built-in `Text` component with a predefined variant,\n // that also accepts `children` as a `React.Node`. This can result in a situation,\n // where another `Text` component is rendered within the built-in `Text` component.\n // By doing that, we assume that user doesn't want to consume pre-defined font properties.\n // Case one: Nested `Text` has different `variant` that specified in parent. For example:\n // \n // Nested\n // \n // Solution: To address the following scenario, the code below overrides the `variant`\n // specified in a parent in favor of children's variant:\n if (props.variant) {\n font = theme.fonts[props.variant];\n textStyle = [style, font];\n }\n\n // Case two: Nested `Text` has specified `styles` which intefere\n // with font properties, from the parent's `variant`. For example:\n // \n // Nested\n // \n // Solution: To address the following scenario, the code below overrides the\n // parent's style with children's style:\n if (!props.variant) {\n textStyle = [style, props.style];\n }\n }\n if (typeof font !== 'object') {\n throw new Error(`Variant ${variant} was not provided properly. Valid variants are ${Object.keys(theme.fonts).join(', ')}.`);\n }\n return /*#__PURE__*/React.createElement(NativeText, _extends({\n ref: root,\n style: [styles.text, {\n writingDirection,\n color: theme.colors.onSurface\n }, textStyle]\n }, rest));\n } else {\n var _theme$fonts, _theme$colors;\n const font = theme.isV3 ? theme.fonts.default : (_theme$fonts = theme.fonts) === null || _theme$fonts === void 0 ? void 0 : _theme$fonts.regular;\n const textStyle = {\n ...font,\n color: theme.isV3 ? (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.onSurface : theme.colors.text\n };\n return /*#__PURE__*/React.createElement(NativeText, _extends({}, rest, {\n ref: root,\n style: [styles.text, textStyle, {\n writingDirection\n }, style]\n }));\n }\n};\nconst styles = StyleSheet.create({\n text: {\n textAlign: 'left'\n }\n});\nconst Component = forwardRef(Text);\nexport const customText = () => Component;\nexport default Component;\n//# sourceMappingURL=Text.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, I18nManager, StyleSheet } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * Animated text component which follows styles from the theme.\n *\n * @extends Text props https://reactnative.dev/docs/text#props\n */\nfunction AnimatedText(_ref) {\n let {\n style,\n theme: themeOverrides,\n variant,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const writingDirection = I18nManager.getConstants().isRTL ? 'rtl' : 'ltr';\n if (theme.isV3 && variant) {\n const font = theme.fonts[variant];\n if (typeof font !== 'object') {\n throw new Error(`Variant ${variant} was not provided properly. Valid variants are ${Object.keys(theme.fonts).join(', ')}.`);\n }\n return /*#__PURE__*/React.createElement(Animated.Text, _extends({}, rest, {\n style: [font, styles.text, {\n writingDirection,\n color: theme.colors.onSurface\n }, style]\n }));\n } else {\n const font = !theme.isV3 ? theme.fonts.regular : theme.fonts.bodyMedium;\n const textStyle = {\n ...font,\n color: theme.isV3 ? theme.colors.onSurface : theme.colors.text\n };\n return /*#__PURE__*/React.createElement(Animated.Text, _extends({}, rest, {\n style: [styles.text, textStyle, {\n writingDirection\n }, style]\n }));\n }\n}\nconst styles = StyleSheet.create({\n text: {\n textAlign: 'left'\n }\n});\nexport const customAnimatedText = () => AnimatedText;\nexport default AnimatedText;\n//# sourceMappingURL=AnimatedText.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { I18nManager, StyleSheet } from 'react-native';\nimport color from 'color';\nimport Text from './Text';\nimport { useInternalTheme } from '../../../core/theming';\nconst StyledText = _ref => {\n var _theme$colors, _theme$fonts;\n let {\n alpha = 1,\n family,\n style,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const textColor = color(theme.isV3 ? theme.colors.onSurface : (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.text).alpha(alpha).rgb().string();\n const writingDirection = I18nManager.getConstants().isRTL ? 'rtl' : 'ltr';\n return /*#__PURE__*/React.createElement(Text, _extends({}, rest, {\n style: [styles.text, {\n color: textColor,\n ...(!theme.isV3 && ((_theme$fonts = theme.fonts) === null || _theme$fonts === void 0 ? void 0 : _theme$fonts[family])),\n writingDirection\n }, style]\n }));\n};\nconst styles = StyleSheet.create({\n text: {\n textAlign: 'left'\n }\n});\nexport default StyledText;\n//# sourceMappingURL=StyledText.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, Text as NativeText } from 'react-native';\nimport { useInternalTheme } from '../../../core/theming';\nimport { forwardRef } from '../../../utils/forwardRef';\n// @component-group Typography\n/**\n * Text component which follows styles from the theme.\n *\n * @extends Text props https://reactnative.dev/docs/text#props\n */\nconst Text = (_ref, ref) => {\n var _theme$fonts, _theme$colors;\n let {\n style,\n theme: overrideTheme,\n ...rest\n } = _ref;\n const root = React.useRef(null);\n const theme = useInternalTheme(overrideTheme);\n React.useImperativeHandle(ref, () => ({\n setNativeProps: args => {\n var _root$current;\n return (_root$current = root.current) === null || _root$current === void 0 ? void 0 : _root$current.setNativeProps(args);\n }\n }));\n return /*#__PURE__*/React.createElement(NativeText, _extends({}, rest, {\n ref: root,\n style: [{\n ...(!theme.isV3 && ((_theme$fonts = theme.fonts) === null || _theme$fonts === void 0 ? void 0 : _theme$fonts.regular)),\n color: theme.isV3 ? (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.onSurface : theme.colors.text\n }, styles.text, style]\n }));\n};\nconst styles = StyleSheet.create({\n text: {\n textAlign: 'left'\n }\n});\nexport default forwardRef(Text);\n//# sourceMappingURL=Text.js.map","import * as React from 'react';\n/**\n * TypeScript generated a large union of props from `ViewProps` in\n * `d.ts` files when using `React.forwardRef`. To prevent this\n * `ForwardRefComponent` was created and exported. Use this\n * `forwardRef` instead of `React.forwardRef` so you don't have to\n * import `ForwardRefComponent`.\n * More info: https://github.com/callstack/react-native-paper/pull/3603\n */\nexport const forwardRef = React.forwardRef;\n//# sourceMappingURL=forwardRef.js.map","// @component ./DrawerItem.tsx\nexport { default as Item } from './DrawerItem';\n\n// @component ./DrawerCollapsedItem.tsx\nexport { default as CollapsedItem } from './DrawerCollapsedItem';\n\n// @component ./DrawerSection.tsx\nexport { default as Section } from './DrawerSection';\n//# sourceMappingURL=Drawer.js.map","import * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { useInternalTheme } from '../../core/theming';\nimport Icon from '../Icon';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * A component used to show an action item with an icon and a label in a navigation drawer.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Drawer } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst DrawerItem = _ref => {\n let {\n icon,\n label,\n active,\n disabled,\n theme: themeOverrides,\n rippleColor: customRippleColor,\n style,\n onPress,\n background,\n accessibilityLabel,\n right,\n labelMaxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n roundness,\n isV3\n } = theme;\n const backgroundColor = active ? isV3 ? theme.colors.secondaryContainer : color(theme.colors.primary).alpha(0.12).rgb().string() : undefined;\n const contentColor = active ? isV3 ? theme.colors.onSecondaryContainer : theme.colors.primary : isV3 ? theme.colors.onSurfaceVariant : color(theme.colors.text).alpha(0.68).rgb().string();\n const labelMargin = icon ? isV3 ? 12 : 32 : 0;\n const borderRadius = (isV3 ? 7 : 1) * roundness;\n const rippleColor = isV3 ? color(contentColor).alpha(0.12).rgb().string() : undefined;\n const font = isV3 ? theme.fonts.labelLarge : theme.fonts.medium;\n return /*#__PURE__*/React.createElement(View, rest, /*#__PURE__*/React.createElement(TouchableRipple, {\n borderless: true,\n disabled: disabled,\n background: background,\n onPress: onPress,\n style: [styles.container, {\n backgroundColor,\n borderRadius\n }, isV3 && styles.v3Container, style],\n accessibilityRole: \"button\",\n accessibilityState: {\n selected: active\n },\n accessibilityLabel: accessibilityLabel,\n rippleColor: customRippleColor || rippleColor,\n theme: theme\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.wrapper, isV3 && styles.v3Wrapper]\n }, /*#__PURE__*/React.createElement(View, {\n style: styles.content\n }, icon ? /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n size: 24,\n color: contentColor\n }) : null, /*#__PURE__*/React.createElement(Text, {\n variant: \"labelLarge\",\n selectable: false,\n numberOfLines: 1,\n style: [styles.label, {\n color: contentColor,\n marginLeft: labelMargin,\n ...font\n }],\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier\n }, label)), right === null || right === void 0 ? void 0 : right({\n color: contentColor\n }))));\n};\nDrawerItem.displayName = 'Drawer.Item';\nconst styles = StyleSheet.create({\n container: {\n marginHorizontal: 10,\n marginVertical: 4\n },\n v3Container: {\n justifyContent: 'center',\n height: 56,\n marginLeft: 12,\n marginRight: 12,\n marginVertical: 0\n },\n wrapper: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 8\n },\n v3Wrapper: {\n marginLeft: 16,\n marginRight: 24,\n padding: 0\n },\n content: {\n flex: 1,\n flexDirection: 'row',\n alignItems: 'center'\n },\n label: {\n marginRight: 32\n }\n});\nexport default DrawerItem;\n//# sourceMappingURL=DrawerItem.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Platform, StyleSheet } from 'react-native';\nimport color from 'color';\nimport { Pressable } from './Pressable';\nimport { getTouchableRippleColors } from './utils';\nimport { SettingsContext } from '../../core/settings';\nimport { useInternalTheme } from '../../core/theming';\nimport { forwardRef } from '../../utils/forwardRef';\nimport hasTouchHandler from '../../utils/hasTouchHandler';\n/**\n * A wrapper for views that should respond to touches.\n * Provides a material \"ink ripple\" interaction effect for supported platforms (>= Android Lollipop).\n * On unsupported platforms, it falls back to a highlight effect.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { Text, TouchableRipple } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * console.log('Pressed')}\n * rippleColor=\"rgba(0, 0, 0, .32)\"\n * >\n * Press anywhere\n * \n * );\n *\n * export default MyComponent;\n * ```\n *\n * @extends Pressable props https://reactnative.dev/docs/Pressable#props\n */\nconst TouchableRipple = (_ref, ref) => {\n let {\n style,\n background: _background,\n borderless = false,\n disabled: disabledProp,\n rippleColor,\n underlayColor: _underlayColor,\n children,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n calculatedRippleColor\n } = getTouchableRippleColors({\n theme,\n rippleColor\n });\n const hoverColor = color(calculatedRippleColor).fade(0.5).rgb().string();\n const {\n rippleEffectEnabled\n } = React.useContext(SettingsContext);\n const {\n onPress,\n onLongPress,\n onPressIn,\n onPressOut\n } = rest;\n const handlePressIn = React.useCallback(e => {\n onPressIn === null || onPressIn === void 0 ? void 0 : onPressIn(e);\n if (rippleEffectEnabled) {\n const {\n centered\n } = rest;\n const button = e.currentTarget;\n const style = window.getComputedStyle(button);\n const dimensions = button.getBoundingClientRect();\n let touchX;\n let touchY;\n const {\n changedTouches,\n touches\n } = e.nativeEvent;\n const touch = (touches === null || touches === void 0 ? void 0 : touches[0]) ?? (changedTouches === null || changedTouches === void 0 ? void 0 : changedTouches[0]);\n\n // If centered or it was pressed using keyboard - enter or space\n if (centered || !touch) {\n touchX = dimensions.width / 2;\n touchY = dimensions.height / 2;\n } else {\n touchX = touch.locationX ?? e.pageX;\n touchY = touch.locationY ?? e.pageY;\n }\n\n // Get the size of the button to determine how big the ripple should be\n const size = centered ?\n // If ripple is always centered, we don't need to make it too big\n Math.min(dimensions.width, dimensions.height) * 1.25 :\n // Otherwise make it twice as big so clicking on one end spreads ripple to other\n Math.max(dimensions.width, dimensions.height) * 2;\n\n // Create a container for our ripple effect so we don't need to change the parent's style\n const container = document.createElement('span');\n container.setAttribute('data-paper-ripple', '');\n Object.assign(container.style, {\n position: 'absolute',\n pointerEvents: 'none',\n top: '0',\n left: '0',\n right: '0',\n bottom: '0',\n borderTopLeftRadius: style.borderTopLeftRadius,\n borderTopRightRadius: style.borderTopRightRadius,\n borderBottomRightRadius: style.borderBottomRightRadius,\n borderBottomLeftRadius: style.borderBottomLeftRadius,\n overflow: centered ? 'visible' : 'hidden'\n });\n\n // Create span to show the ripple effect\n const ripple = document.createElement('span');\n Object.assign(ripple.style, {\n position: 'absolute',\n pointerEvents: 'none',\n backgroundColor: calculatedRippleColor,\n borderRadius: '50%',\n /* Transition configuration */\n transitionProperty: 'transform opacity',\n transitionDuration: `${Math.min(size * 1.5, 350)}ms`,\n transitionTimingFunction: 'linear',\n transformOrigin: 'center',\n /* We'll animate these properties */\n transform: 'translate3d(-50%, -50%, 0) scale3d(0.1, 0.1, 0.1)',\n opacity: '0.5',\n // Position the ripple where cursor was\n left: `${touchX}px`,\n top: `${touchY}px`,\n width: `${size}px`,\n height: `${size}px`\n });\n\n // Finally, append it to DOM\n container.appendChild(ripple);\n button.appendChild(container);\n\n // rAF runs in the same frame as the event handler\n // Use double rAF to ensure the transition class is added in next frame\n // This will make sure that the transition animation is triggered\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n Object.assign(ripple.style, {\n transform: 'translate3d(-50%, -50%, 0) scale3d(1, 1, 1)',\n opacity: '1'\n });\n });\n });\n }\n }, [onPressIn, rest, rippleEffectEnabled, calculatedRippleColor]);\n const handlePressOut = React.useCallback(e => {\n onPressOut === null || onPressOut === void 0 ? void 0 : onPressOut(e);\n if (rippleEffectEnabled) {\n const containers = e.currentTarget.querySelectorAll('[data-paper-ripple]');\n requestAnimationFrame(() => {\n requestAnimationFrame(() => {\n containers.forEach(container => {\n const ripple = container.firstChild;\n Object.assign(ripple.style, {\n transitionDuration: '250ms',\n opacity: 0\n });\n\n // Finally remove the span after the transition\n setTimeout(() => {\n const {\n parentNode\n } = container;\n if (parentNode) {\n parentNode.removeChild(container);\n }\n }, 500);\n });\n });\n });\n }\n }, [onPressOut, rippleEffectEnabled]);\n const hasPassedTouchHandler = hasTouchHandler({\n onPress,\n onLongPress,\n onPressIn,\n onPressOut\n });\n const disabled = disabledProp || !hasPassedTouchHandler;\n return /*#__PURE__*/React.createElement(Pressable, _extends({}, rest, {\n ref: ref,\n onPressIn: handlePressIn,\n onPressOut: handlePressOut,\n disabled: disabled,\n style: state => [styles.touchable, borderless && styles.borderless,\n // focused state is not ready yet: https://github.com/necolas/react-native-web/issues/1849\n // state.focused && { backgroundColor: ___ },\n state.hovered && {\n backgroundColor: hoverColor\n }, typeof style === 'function' ? style(state) : style]\n }), state => React.Children.only(typeof children === 'function' ? children(state) : children));\n};\n\n/**\n * Whether ripple effect is supported.\n */\nTouchableRipple.supported = true;\nconst styles = StyleSheet.create({\n touchable: {\n position: 'relative',\n ...(Platform.OS === 'web' && {\n cursor: 'pointer',\n transition: '150ms background-color'\n })\n },\n borderless: {\n overflow: 'hidden'\n }\n});\nconst Component = forwardRef(TouchableRipple);\nexport default Component;\n//# sourceMappingURL=TouchableRipple.js.map","import { Pressable as PressableNative } from 'react-native';\n\n// This component is added to support type-safe hover and focus states on web\n// https://necolas.github.io/react-native-web/docs/pressable/\nexport const Pressable = PressableNative;\n//# sourceMappingURL=Pressable.js.map","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\n'use strict';\n\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"children\", \"delayLongPress\", \"delayPressIn\", \"delayPressOut\", \"disabled\", \"onBlur\", \"onContextMenu\", \"onFocus\", \"onHoverIn\", \"onHoverOut\", \"onKeyDown\", \"onLongPress\", \"onPress\", \"onPressMove\", \"onPressIn\", \"onPressOut\", \"style\", \"tabIndex\", \"testOnly_hovered\", \"testOnly_pressed\"];\nimport * as React from 'react';\nimport { forwardRef, memo, useMemo, useState, useRef } from 'react';\nimport useMergeRefs from '../../modules/useMergeRefs';\nimport useHover from '../../modules/useHover';\nimport usePressEvents from '../../modules/usePressEvents';\nimport StyleSheet from '../StyleSheet';\nimport View from '../View';\n/**\n * Component used to build display components that should respond to whether the\n * component is currently pressed or not.\n */\nfunction Pressable(props, forwardedRef) {\n var children = props.children,\n delayLongPress = props.delayLongPress,\n delayPressIn = props.delayPressIn,\n delayPressOut = props.delayPressOut,\n disabled = props.disabled,\n onBlur = props.onBlur,\n onContextMenu = props.onContextMenu,\n onFocus = props.onFocus,\n onHoverIn = props.onHoverIn,\n onHoverOut = props.onHoverOut,\n onKeyDown = props.onKeyDown,\n onLongPress = props.onLongPress,\n onPress = props.onPress,\n onPressMove = props.onPressMove,\n onPressIn = props.onPressIn,\n onPressOut = props.onPressOut,\n style = props.style,\n tabIndex = props.tabIndex,\n testOnly_hovered = props.testOnly_hovered,\n testOnly_pressed = props.testOnly_pressed,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n var _useForceableState = useForceableState(testOnly_hovered === true),\n hovered = _useForceableState[0],\n setHovered = _useForceableState[1];\n var _useForceableState2 = useForceableState(false),\n focused = _useForceableState2[0],\n setFocused = _useForceableState2[1];\n var _useForceableState3 = useForceableState(testOnly_pressed === true),\n pressed = _useForceableState3[0],\n setPressed = _useForceableState3[1];\n var hostRef = useRef(null);\n var setRef = useMergeRefs(forwardedRef, hostRef);\n var pressConfig = useMemo(() => ({\n delayLongPress,\n delayPressStart: delayPressIn,\n delayPressEnd: delayPressOut,\n disabled,\n onLongPress,\n onPress,\n onPressChange: setPressed,\n onPressStart: onPressIn,\n onPressMove,\n onPressEnd: onPressOut\n }), [delayLongPress, delayPressIn, delayPressOut, disabled, onLongPress, onPress, onPressIn, onPressMove, onPressOut, setPressed]);\n var pressEventHandlers = usePressEvents(hostRef, pressConfig);\n var onContextMenuPress = pressEventHandlers.onContextMenu,\n onKeyDownPress = pressEventHandlers.onKeyDown;\n useHover(hostRef, {\n contain: true,\n disabled,\n onHoverChange: setHovered,\n onHoverStart: onHoverIn,\n onHoverEnd: onHoverOut\n });\n var interactionState = {\n hovered,\n focused,\n pressed\n };\n var blurHandler = React.useCallback(e => {\n if (e.nativeEvent.target === hostRef.current) {\n setFocused(false);\n if (onBlur != null) {\n onBlur(e);\n }\n }\n }, [hostRef, setFocused, onBlur]);\n var focusHandler = React.useCallback(e => {\n if (e.nativeEvent.target === hostRef.current) {\n setFocused(true);\n if (onFocus != null) {\n onFocus(e);\n }\n }\n }, [hostRef, setFocused, onFocus]);\n var contextMenuHandler = React.useCallback(e => {\n if (onContextMenuPress != null) {\n onContextMenuPress(e);\n }\n if (onContextMenu != null) {\n onContextMenu(e);\n }\n }, [onContextMenu, onContextMenuPress]);\n var keyDownHandler = React.useCallback(e => {\n if (onKeyDownPress != null) {\n onKeyDownPress(e);\n }\n if (onKeyDown != null) {\n onKeyDown(e);\n }\n }, [onKeyDown, onKeyDownPress]);\n var _tabIndex;\n if (tabIndex !== undefined) {\n _tabIndex = tabIndex;\n } else {\n _tabIndex = disabled ? -1 : 0;\n }\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, pressEventHandlers, {\n \"aria-disabled\": disabled,\n onBlur: blurHandler,\n onContextMenu: contextMenuHandler,\n onFocus: focusHandler,\n onKeyDown: keyDownHandler,\n ref: setRef,\n style: [disabled ? styles.disabled : styles.active, typeof style === 'function' ? style(interactionState) : style],\n tabIndex: _tabIndex\n }), typeof children === 'function' ? children(interactionState) : children);\n}\nfunction useForceableState(forced) {\n var _useState = useState(false),\n bool = _useState[0],\n setBool = _useState[1];\n return [bool || forced, setBool];\n}\nvar styles = StyleSheet.create({\n active: {\n cursor: 'pointer',\n touchAction: 'manipulation'\n },\n disabled: {\n pointerEvents: 'box-none'\n }\n});\nvar MemoedPressable = /*#__PURE__*/memo( /*#__PURE__*/forwardRef(Pressable));\nMemoedPressable.displayName = 'Pressable';\nexport default MemoedPressable;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport { getModality } from '../modality';\nimport useEvent from '../useEvent';\nimport useLayoutEffect from '../useLayoutEffect';\n\n/**\n * Types\n */\n\n/**\n * Implementation\n */\n\nvar emptyObject = {};\nvar opts = {\n passive: true\n};\nvar lockEventType = 'react-gui:hover:lock';\nvar unlockEventType = 'react-gui:hover:unlock';\nvar supportsPointerEvent = () => !!(typeof window !== 'undefined' && window.PointerEvent != null);\nfunction dispatchCustomEvent(target, type, payload) {\n var event = document.createEvent('CustomEvent');\n var _ref = payload || emptyObject,\n _ref$bubbles = _ref.bubbles,\n bubbles = _ref$bubbles === void 0 ? true : _ref$bubbles,\n _ref$cancelable = _ref.cancelable,\n cancelable = _ref$cancelable === void 0 ? true : _ref$cancelable,\n detail = _ref.detail;\n event.initCustomEvent(type, bubbles, cancelable, detail);\n target.dispatchEvent(event);\n}\n\n// This accounts for the non-PointerEvent fallback events.\nfunction getPointerType(event) {\n var pointerType = event.pointerType;\n return pointerType != null ? pointerType : getModality();\n}\nexport default function useHover(targetRef, config) {\n var contain = config.contain,\n disabled = config.disabled,\n onHoverStart = config.onHoverStart,\n onHoverChange = config.onHoverChange,\n onHoverUpdate = config.onHoverUpdate,\n onHoverEnd = config.onHoverEnd;\n var canUsePE = supportsPointerEvent();\n var addMoveListener = useEvent(canUsePE ? 'pointermove' : 'mousemove', opts);\n var addEnterListener = useEvent(canUsePE ? 'pointerenter' : 'mouseenter', opts);\n var addLeaveListener = useEvent(canUsePE ? 'pointerleave' : 'mouseleave', opts);\n // These custom events are used to implement the \"contain\" prop.\n var addLockListener = useEvent(lockEventType, opts);\n var addUnlockListener = useEvent(unlockEventType, opts);\n useLayoutEffect(() => {\n var target = targetRef.current;\n if (target !== null) {\n /**\n * End the hover gesture\n */\n var hoverEnd = function hoverEnd(e) {\n if (onHoverEnd != null) {\n onHoverEnd(e);\n }\n if (onHoverChange != null) {\n onHoverChange(false);\n }\n // Remove the listeners once finished.\n addMoveListener(target, null);\n addLeaveListener(target, null);\n };\n\n /**\n * Leave element\n */\n var leaveListener = function leaveListener(e) {\n var target = targetRef.current;\n if (target != null && getPointerType(e) !== 'touch') {\n if (contain) {\n dispatchCustomEvent(target, unlockEventType);\n }\n hoverEnd(e);\n }\n };\n\n /**\n * Move within element\n */\n var moveListener = function moveListener(e) {\n if (getPointerType(e) !== 'touch') {\n if (onHoverUpdate != null) {\n // Not all browsers have these properties\n if (e.x == null) {\n e.x = e.clientX;\n }\n if (e.y == null) {\n e.y = e.clientY;\n }\n onHoverUpdate(e);\n }\n }\n };\n\n /**\n * Start the hover gesture\n */\n var hoverStart = function hoverStart(e) {\n if (onHoverStart != null) {\n onHoverStart(e);\n }\n if (onHoverChange != null) {\n onHoverChange(true);\n }\n // Set the listeners needed for the rest of the hover gesture.\n if (onHoverUpdate != null) {\n addMoveListener(target, !disabled ? moveListener : null);\n }\n addLeaveListener(target, !disabled ? leaveListener : null);\n };\n\n /**\n * Enter element\n */\n var enterListener = function enterListener(e) {\n var target = targetRef.current;\n if (target != null && getPointerType(e) !== 'touch') {\n if (contain) {\n dispatchCustomEvent(target, lockEventType);\n }\n hoverStart(e);\n var lockListener = function lockListener(lockEvent) {\n if (lockEvent.target !== target) {\n hoverEnd(e);\n }\n };\n var unlockListener = function unlockListener(lockEvent) {\n if (lockEvent.target !== target) {\n hoverStart(e);\n }\n };\n addLockListener(target, !disabled ? lockListener : null);\n addUnlockListener(target, !disabled ? unlockListener : null);\n }\n };\n addEnterListener(target, !disabled ? enterListener : null);\n }\n }, [addEnterListener, addMoveListener, addLeaveListener, addLockListener, addUnlockListener, contain, disabled, onHoverStart, onHoverChange, onHoverUpdate, onHoverEnd, targetRef]);\n}","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport { addEventListener } from '../addEventListener';\nimport canUseDOM from '../canUseDom';\nvar supportsPointerEvent = () => !!(typeof window !== 'undefined' && window.PointerEvent != null);\nvar activeModality = 'keyboard';\nvar modality = 'keyboard';\nvar previousModality;\nvar previousActiveModality;\nvar isEmulatingMouseEvents = false;\nvar listeners = new Set();\nvar KEYBOARD = 'keyboard';\nvar MOUSE = 'mouse';\nvar TOUCH = 'touch';\nvar BLUR = 'blur';\nvar CONTEXTMENU = 'contextmenu';\nvar FOCUS = 'focus';\nvar KEYDOWN = 'keydown';\nvar MOUSEDOWN = 'mousedown';\nvar MOUSEMOVE = 'mousemove';\nvar MOUSEUP = 'mouseup';\nvar POINTERDOWN = 'pointerdown';\nvar POINTERMOVE = 'pointermove';\nvar SCROLL = 'scroll';\nvar SELECTIONCHANGE = 'selectionchange';\nvar TOUCHCANCEL = 'touchcancel';\nvar TOUCHMOVE = 'touchmove';\nvar TOUCHSTART = 'touchstart';\nvar VISIBILITYCHANGE = 'visibilitychange';\nvar bubbleOptions = {\n passive: true\n};\nvar captureOptions = {\n capture: true,\n passive: true\n};\nfunction restoreModality() {\n if (previousModality != null || previousActiveModality != null) {\n if (previousModality != null) {\n modality = previousModality;\n previousModality = null;\n }\n if (previousActiveModality != null) {\n activeModality = previousActiveModality;\n previousActiveModality = null;\n }\n callListeners();\n }\n}\nfunction onBlurWindow() {\n previousModality = modality;\n previousActiveModality = activeModality;\n activeModality = KEYBOARD;\n modality = KEYBOARD;\n callListeners();\n // for fallback events\n isEmulatingMouseEvents = false;\n}\nfunction onFocusWindow() {\n restoreModality();\n}\nfunction onKeyDown(event) {\n if (event.metaKey || event.altKey || event.ctrlKey) {\n return;\n }\n if (modality !== KEYBOARD) {\n modality = KEYBOARD;\n activeModality = KEYBOARD;\n callListeners();\n }\n}\nfunction onVisibilityChange() {\n if (document.visibilityState !== 'hidden') {\n restoreModality();\n }\n}\nfunction onPointerish(event) {\n var eventType = event.type;\n if (supportsPointerEvent()) {\n if (eventType === POINTERDOWN) {\n if (activeModality !== event.pointerType) {\n modality = event.pointerType;\n activeModality = event.pointerType;\n callListeners();\n }\n return;\n }\n if (eventType === POINTERMOVE) {\n if (modality !== event.pointerType) {\n modality = event.pointerType;\n callListeners();\n }\n return;\n }\n }\n // Fallback for non-PointerEvent environment\n else {\n if (!isEmulatingMouseEvents) {\n if (eventType === MOUSEDOWN) {\n if (activeModality !== MOUSE) {\n modality = MOUSE;\n activeModality = MOUSE;\n callListeners();\n }\n }\n if (eventType === MOUSEMOVE) {\n if (modality !== MOUSE) {\n modality = MOUSE;\n callListeners();\n }\n }\n }\n\n // Flag when browser may produce emulated events\n if (eventType === TOUCHSTART) {\n isEmulatingMouseEvents = true;\n if (event.touches && event.touches.length > 1) {\n isEmulatingMouseEvents = false;\n }\n if (activeModality !== TOUCH) {\n modality = TOUCH;\n activeModality = TOUCH;\n callListeners();\n }\n return;\n }\n\n // Remove flag after emulated events are finished or cancelled, and if an\n // event occurs that cuts short a touch event sequence.\n if (eventType === CONTEXTMENU || eventType === MOUSEUP || eventType === SELECTIONCHANGE || eventType === SCROLL || eventType === TOUCHCANCEL || eventType === TOUCHMOVE) {\n isEmulatingMouseEvents = false;\n }\n }\n}\nif (canUseDOM) {\n // Window events\n addEventListener(window, BLUR, onBlurWindow, bubbleOptions);\n addEventListener(window, FOCUS, onFocusWindow, bubbleOptions);\n // Must be capture phase because 'stopPropagation' might prevent these\n // events bubbling to the document.\n addEventListener(document, KEYDOWN, onKeyDown, captureOptions);\n addEventListener(document, VISIBILITYCHANGE, onVisibilityChange, captureOptions);\n addEventListener(document, POINTERDOWN, onPointerish, captureOptions);\n addEventListener(document, POINTERMOVE, onPointerish, captureOptions);\n // Fallback events\n addEventListener(document, CONTEXTMENU, onPointerish, captureOptions);\n addEventListener(document, MOUSEDOWN, onPointerish, captureOptions);\n addEventListener(document, MOUSEMOVE, onPointerish, captureOptions);\n addEventListener(document, MOUSEUP, onPointerish, captureOptions);\n addEventListener(document, TOUCHCANCEL, onPointerish, captureOptions);\n addEventListener(document, TOUCHMOVE, onPointerish, captureOptions);\n addEventListener(document, TOUCHSTART, onPointerish, captureOptions);\n addEventListener(document, SELECTIONCHANGE, onPointerish, captureOptions);\n addEventListener(document, SCROLL, onPointerish, captureOptions);\n}\nfunction callListeners() {\n var value = {\n activeModality,\n modality\n };\n listeners.forEach(listener => {\n listener(value);\n });\n}\nexport function getActiveModality() {\n return activeModality;\n}\nexport function getModality() {\n return modality;\n}\nexport function addModalityListener(listener) {\n listeners.add(listener);\n return () => {\n listeners.delete(listener);\n };\n}\nexport function testOnly_resetActiveModality() {\n isEmulatingMouseEvents = false;\n activeModality = KEYBOARD;\n modality = KEYBOARD;\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\n'use strict';\n\nimport canUseDOM from '../canUseDom';\nvar emptyFunction = () => {};\nfunction supportsPassiveEvents() {\n var supported = false;\n // Check if browser supports event with passive listeners\n // https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#Safely_detecting_option_support\n if (canUseDOM) {\n try {\n var options = {};\n Object.defineProperty(options, 'passive', {\n get() {\n supported = true;\n return false;\n }\n });\n window.addEventListener('test', null, options);\n window.removeEventListener('test', null, options);\n } catch (e) {}\n }\n return supported;\n}\nvar canUsePassiveEvents = supportsPassiveEvents();\nfunction getOptions(options) {\n if (options == null) {\n return false;\n }\n return canUsePassiveEvents ? options : Boolean(options.capture);\n}\n\n/**\n * Shim generic API compatibility with ReactDOM's synthetic events, without needing the\n * large amount of code ReactDOM uses to do this. Ideally we wouldn't use a synthetic\n * event wrapper at all.\n */\nfunction isPropagationStopped() {\n return this.cancelBubble;\n}\nfunction isDefaultPrevented() {\n return this.defaultPrevented;\n}\nfunction normalizeEvent(event) {\n event.nativeEvent = event;\n event.persist = emptyFunction;\n event.isDefaultPrevented = isDefaultPrevented;\n event.isPropagationStopped = isPropagationStopped;\n return event;\n}\n\n/**\n *\n */\nexport function addEventListener(target, type, listener, options) {\n var opts = getOptions(options);\n var compatListener = e => listener(normalizeEvent(e));\n target.addEventListener(type, compatListener, opts);\n return function removeEventListener() {\n if (target != null) {\n target.removeEventListener(type, compatListener, opts);\n }\n };\n}","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport { addEventListener } from '../addEventListener';\nimport useLayoutEffect from '../useLayoutEffect';\nimport useStable from '../useStable';\n/**\n * This can be used with any event type include custom events.\n *\n * const click = useEvent('click', options);\n * useEffect(() => {\n * click.setListener(target, onClick);\n * return () => click.clear();\n * }).\n */\nexport default function useEvent(eventType, options) {\n var targetListeners = useStable(() => new Map());\n var addListener = useStable(() => {\n return (target, callback) => {\n var removeTargetListener = targetListeners.get(target);\n if (removeTargetListener != null) {\n removeTargetListener();\n }\n if (callback == null) {\n targetListeners.delete(target);\n callback = () => {};\n }\n var removeEventListener = addEventListener(target, eventType, callback, options);\n targetListeners.set(target, removeEventListener);\n return removeEventListener;\n };\n });\n useLayoutEffect(() => {\n return () => {\n targetListeners.forEach(removeListener => {\n removeListener();\n });\n targetListeners.clear();\n };\n }, [targetListeners]);\n return addListener;\n}","import color from 'color';\nconst getUnderlayColor = _ref => {\n let {\n theme,\n calculatedRippleColor,\n underlayColor\n } = _ref;\n if (underlayColor != null) {\n return underlayColor;\n }\n if (theme.isV3) {\n return color(calculatedRippleColor).rgb().string();\n }\n return color(calculatedRippleColor).fade(0.5).rgb().string();\n};\nconst getRippleColor = _ref2 => {\n let {\n theme,\n rippleColor\n } = _ref2;\n if (rippleColor) {\n return rippleColor;\n }\n if (theme.isV3) {\n return color(theme.colors.onSurface).alpha(0.12).rgb().string();\n }\n if (theme.dark) {\n return color(theme.colors.text).alpha(0.32).rgb().string();\n }\n return color(theme.colors.text).alpha(0.2).rgb().string();\n};\nexport const getTouchableRippleColors = _ref3 => {\n let {\n theme,\n rippleColor,\n underlayColor\n } = _ref3;\n const calculatedRippleColor = getRippleColor({\n theme,\n rippleColor\n });\n return {\n calculatedRippleColor,\n calculatedUnderlayColor: getUnderlayColor({\n theme,\n calculatedRippleColor,\n underlayColor\n })\n };\n};\n//# sourceMappingURL=utils.js.map","const touchableEvents = ['onPress', 'onLongPress', 'onPressIn', 'onPressOut'];\nexport default function hasTouchHandler(touchableEventObject) {\n return touchableEvents.some(event => {\n return Boolean(touchableEventObject[event]);\n });\n}\n//# sourceMappingURL=hasTouchHandler.js.map","import * as React from 'react';\nimport { Animated, Platform, Pressable, StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\nimport Badge from '../Badge';\nimport Icon from '../Icon';\nimport Text from '../Typography/Text';\nconst badgeSize = 8;\nconst iconSize = 24;\nconst itemSize = 56;\nconst outlineHeight = 32;\n\n/**\n * Note: Available in v5.x with theme version 3\n *\n * Collapsed component used to show an action item with an icon and optionally label in a navigation drawer.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Drawer } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst DrawerCollapsedItem = _ref => {\n let {\n focusedIcon,\n unfocusedIcon,\n label,\n active,\n theme: themeOverrides,\n style,\n onPress,\n disabled,\n accessibilityLabel,\n badge = false,\n testID = 'drawer-collapsed-item',\n labelMaxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3\n } = theme;\n const {\n scale\n } = theme.animation;\n const [numOfLines, setNumOfLines] = React.useState(1);\n const {\n current: animScale\n } = React.useRef(new Animated.Value(active ? 1 : 0.5));\n React.useEffect(() => {\n if (!active) {\n animScale.setValue(0.5);\n }\n }, [animScale, active]);\n if (!isV3) {\n return null;\n }\n const handlePressOut = () => {\n Animated.timing(animScale, {\n toValue: 1,\n duration: 150 * scale,\n useNativeDriver: true\n }).start();\n };\n const iconPadding = ((!label ? itemSize : outlineHeight) - iconSize) / 2;\n const backgroundColor = active ? theme.colors.secondaryContainer : 'transparent';\n const labelColor = active ? theme.colors.onSurface : theme.colors.onSurfaceVariant;\n const iconColor = active ? theme.colors.onSecondaryContainer : theme.colors.onSurfaceVariant;\n const onTextLayout = _ref2 => {\n let {\n nativeEvent\n } = _ref2;\n setNumOfLines(nativeEvent.lines.length);\n };\n\n // Label is cut off on Android, when centered \"labelMedium\" text\n // has more than 4 lines, so there is a need to decrease the letter spacing.\n const androidLetterSpacingStyle = Platform.OS === 'android' && numOfLines > 4 && styles.letterSpacing;\n const labelTextStyle = {\n color: labelColor,\n ...(isV3 ? theme.fonts.labelMedium : {})\n };\n const icon = !active && unfocusedIcon !== undefined ? unfocusedIcon : focusedIcon;\n return /*#__PURE__*/React.createElement(View, rest, /*#__PURE__*/React.createElement(Pressable, {\n onPress: onPress,\n onPressOut: onPress ? handlePressOut : undefined,\n disabled: disabled\n // @ts-expect-error We keep old a11y props for backwards compat with old RN versions\n ,\n accessibilityTraits: active ? ['button', 'selected'] : 'button',\n accessibilityComponentType: \"button\",\n accessibilityRole: \"button\",\n accessibilityState: {\n selected: active\n },\n accessibilityLabel: accessibilityLabel,\n testID: testID\n }, /*#__PURE__*/React.createElement(View, {\n style: styles.wrapper\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.outline, !label && styles.roundedOutline, {\n transform: [label ? {\n scaleX: animScale\n } : {\n scale: animScale\n }],\n backgroundColor\n }, style],\n testID: `${testID}-outline`\n }), /*#__PURE__*/React.createElement(View, {\n style: [styles.icon, {\n top: iconPadding\n }],\n testID: `${testID}-container`\n }, badge && /*#__PURE__*/React.createElement(View, {\n style: styles.badgeContainer\n }, typeof badge === 'boolean' ? /*#__PURE__*/React.createElement(Badge, {\n visible: badge,\n size: badgeSize\n }) : /*#__PURE__*/React.createElement(Badge, {\n visible: badge != null,\n size: 2 * badgeSize\n }, badge)), /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n size: iconSize,\n color: iconColor\n })), label ? /*#__PURE__*/React.createElement(Text, {\n variant: \"labelMedium\",\n selectable: false,\n numberOfLines: 2,\n onTextLayout: onTextLayout,\n style: [styles.label, androidLetterSpacingStyle, labelTextStyle],\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier\n }, label) : null)));\n};\nDrawerCollapsedItem.displayName = 'Drawer.CollapsedItem';\nconst styles = StyleSheet.create({\n wrapper: {\n width: 80,\n marginBottom: 12,\n minHeight: itemSize,\n alignItems: 'center'\n },\n outline: {\n width: itemSize,\n height: outlineHeight,\n borderRadius: itemSize / 2,\n alignItems: 'center',\n justifyContent: 'center'\n },\n roundedOutline: {\n height: itemSize\n },\n icon: {\n position: 'absolute'\n },\n letterSpacing: {\n letterSpacing: 0.3,\n alignSelf: 'stretch'\n },\n label: {\n marginHorizontal: 12,\n marginTop: 4,\n textAlign: 'center'\n },\n badgeContainer: {\n position: 'absolute',\n left: 20,\n bottom: 20,\n zIndex: 2\n }\n});\nexport default DrawerCollapsedItem;\n//# sourceMappingURL=DrawerCollapsedItem.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, StyleSheet, useWindowDimensions } from 'react-native';\nimport { useInternalTheme } from '../core/theming';\nimport { black, white } from '../styles/themes/v2/colors';\nimport getContrastingColor from '../utils/getContrastingColor';\nconst defaultSize = 20;\n/**\n * Badges are small status descriptors for UI elements.\n * A badge consists of a small circle, typically containing a number or other short set of characters, that appears in proximity to another object.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Badge } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * 3\n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Badge = _ref => {\n var _theme$colors;\n let {\n children,\n size = defaultSize,\n style,\n theme: themeOverrides,\n visible = true,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n current: opacity\n } = React.useRef(new Animated.Value(visible ? 1 : 0));\n const {\n fontScale\n } = useWindowDimensions();\n const isFirstRendering = React.useRef(true);\n const {\n animation: {\n scale\n }\n } = theme;\n React.useEffect(() => {\n // Do not run animation on very first rendering\n if (isFirstRendering.current) {\n isFirstRendering.current = false;\n return;\n }\n Animated.timing(opacity, {\n toValue: visible ? 1 : 0,\n duration: 150 * scale,\n useNativeDriver: true\n }).start();\n }, [visible, opacity, scale]);\n const {\n backgroundColor = theme.isV3 ? theme.colors.error : (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.notification,\n ...restStyle\n } = StyleSheet.flatten(style) || {};\n const textColor = theme.isV3 ? theme.colors.onError : getContrastingColor(backgroundColor, white, black);\n const borderRadius = size / 2;\n const paddingHorizontal = theme.isV3 ? 3 : 4;\n return /*#__PURE__*/React.createElement(Animated.Text, _extends({\n numberOfLines: 1,\n style: [{\n opacity,\n backgroundColor,\n color: textColor,\n fontSize: size * 0.5,\n ...(!theme.isV3 && theme.fonts.regular),\n lineHeight: size / fontScale,\n height: size,\n minWidth: size,\n borderRadius,\n paddingHorizontal\n }, styles.container, restStyle]\n }, rest), children);\n};\nexport default Badge;\nconst styles = StyleSheet.create({\n container: {\n alignSelf: 'flex-end',\n textAlign: 'center',\n textAlignVertical: 'center',\n overflow: 'hidden'\n }\n});\n//# sourceMappingURL=Badge.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { useInternalTheme } from '../../core/theming';\nimport { MD3Colors } from '../../styles/themes/v3/tokens';\nimport Divider from '../Divider';\nimport Text from '../Typography/Text';\n/**\n * A component to group content inside a navigation drawer.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Drawer } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [active, setActive] = React.useState('');\n *\n * return (\n * \n * setActive('first')}\n * />\n * setActive('second')}\n * />\n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst DrawerSection = _ref => {\n let {\n children,\n title,\n theme: themeOverrides,\n style,\n showDivider = true,\n titleMaxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3\n } = theme;\n const titleColor = isV3 ? theme.colors.onSurfaceVariant : color(theme.colors.text).alpha(0.54).rgb().string();\n const titleMargin = isV3 ? 28 : 16;\n const font = isV3 ? theme.fonts.titleSmall : theme.fonts.medium;\n return /*#__PURE__*/React.createElement(View, _extends({\n style: [styles.container, style]\n }, rest), title && /*#__PURE__*/React.createElement(View, {\n style: [styles.titleContainer, isV3 && styles.v3TitleContainer]\n }, title && /*#__PURE__*/React.createElement(Text, {\n variant: \"titleSmall\",\n numberOfLines: 1,\n style: [{\n color: titleColor,\n marginLeft: titleMargin,\n ...font\n }],\n maxFontSizeMultiplier: titleMaxFontSizeMultiplier\n }, title)), children, showDivider && /*#__PURE__*/React.createElement(Divider, _extends({}, isV3 && {\n horizontalInset: true,\n bold: true\n }, {\n style: [styles.divider, isV3 && styles.v3Divider],\n theme: theme\n })));\n};\nDrawerSection.displayName = 'Drawer.Section';\nconst styles = StyleSheet.create({\n container: {\n marginBottom: 4\n },\n titleContainer: {\n height: 40,\n justifyContent: 'center'\n },\n v3TitleContainer: {\n height: 56\n },\n divider: {\n marginTop: 4\n },\n v3Divider: {\n backgroundColor: MD3Colors.neutralVariant50\n }\n});\nexport default DrawerSection;\n//# sourceMappingURL=DrawerSection.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { useInternalTheme } from '../core/theming';\nimport { black, white } from '../styles/themes/v2/colors';\n/**\n * A divider is a thin, lightweight separator that groups content in lists and page layouts.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { Divider, Text } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * Lemon\n * \n * Mango\n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Divider = _ref => {\n let {\n leftInset,\n horizontalInset = false,\n style,\n theme: themeOverrides,\n bold = false,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n dark: isDarkTheme,\n isV3\n } = theme;\n const dividerColor = isV3 ? theme.colors.outlineVariant : color(isDarkTheme ? white : black).alpha(0.12).rgb().string();\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, {\n style: [{\n height: StyleSheet.hairlineWidth,\n backgroundColor: dividerColor\n }, leftInset && (isV3 ? styles.v3LeftInset : styles.leftInset), isV3 && horizontalInset && styles.horizontalInset, isV3 && bold && styles.bold, style]\n }));\n};\nconst styles = StyleSheet.create({\n leftInset: {\n marginLeft: 72\n },\n v3LeftInset: {\n marginLeft: 16\n },\n horizontalInset: {\n marginLeft: 16,\n marginRight: 16\n },\n bold: {\n height: 1\n }\n});\nexport default Divider;\n//# sourceMappingURL=Divider.js.map","// @component ./ListAccordion.tsx\nexport { default as Accordion } from './ListAccordion';\n\n// @component ./ListAccordionGroup.tsx\nexport { default as AccordionGroup } from './ListAccordionGroup';\n\n// @component ./ListIcon.tsx\nexport { default as Icon } from './ListIcon';\n\n// @component ./ListItem.tsx\nexport { default as Item } from './ListItem';\n\n// @component ./ListSection.tsx\nexport { default as Section } from './ListSection';\n\n// @component ./ListSubheader.tsx\nexport { default as Subheader } from './ListSubheader';\n\n// @component ./ListImage.tsx\nexport { default as Image } from './ListImage';\n//# sourceMappingURL=List.js.map","import * as React from 'react';\nimport { I18nManager, StyleSheet, View } from 'react-native';\nimport { ListAccordionGroupContext } from './ListAccordionGroup';\nimport { getAccordionColors, getLeftStyles } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport MaterialCommunityIcon from '../MaterialCommunityIcon';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * A component used to display an expandable list item.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { List } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [expanded, setExpanded] = React.useState(true);\n *\n * const handlePress = () => setExpanded(!expanded);\n *\n * return (\n * \n * }>\n * \n * \n * \n *\n * }\n * expanded={expanded}\n * onPress={handlePress}>\n * \n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst ListAccordion = _ref => {\n var _theme$colors, _theme$colors2;\n let {\n left,\n right,\n title,\n description,\n children,\n theme: themeOverrides,\n titleStyle,\n descriptionStyle,\n titleNumberOfLines = 1,\n descriptionNumberOfLines = 2,\n rippleColor: customRippleColor,\n style,\n id,\n testID,\n background,\n onPress,\n onLongPress,\n delayLongPress,\n expanded: expandedProp,\n accessibilityLabel,\n pointerEvents = 'none',\n titleMaxFontSizeMultiplier,\n descriptionMaxFontSizeMultiplier\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const [expanded, setExpanded] = React.useState(expandedProp || false);\n const [alignToTop, setAlignToTop] = React.useState(false);\n const onDescriptionTextLayout = event => {\n if (!theme.isV3) {\n return;\n }\n const {\n nativeEvent\n } = event;\n setAlignToTop(nativeEvent.lines.length >= 2);\n };\n const handlePressAction = e => {\n onPress === null || onPress === void 0 ? void 0 : onPress(e);\n if (expandedProp === undefined) {\n // Only update state of the `expanded` prop was not passed\n // If it was passed, the component will act as a controlled component\n setExpanded(expanded => !expanded);\n }\n };\n const expandedInternal = expandedProp !== undefined ? expandedProp : expanded;\n const groupContext = React.useContext(ListAccordionGroupContext);\n if (groupContext !== null && (id === undefined || id === null || id === '')) {\n throw new Error('List.Accordion is used inside a List.AccordionGroup without specifying an id prop.');\n }\n const isExpanded = groupContext ? groupContext.expandedId === id : expandedInternal;\n const {\n titleColor,\n descriptionColor,\n titleTextColor,\n rippleColor\n } = getAccordionColors({\n theme,\n isExpanded,\n customRippleColor\n });\n const handlePress = groupContext && id !== undefined ? () => groupContext.onAccordionPress(id) : handlePressAction;\n return /*#__PURE__*/React.createElement(View, null, /*#__PURE__*/React.createElement(View, {\n style: {\n backgroundColor: theme === null || theme === void 0 || (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.background\n }\n }, /*#__PURE__*/React.createElement(TouchableRipple, {\n style: [theme.isV3 ? styles.containerV3 : styles.container, style],\n onPress: handlePress,\n onLongPress: onLongPress,\n delayLongPress: delayLongPress,\n rippleColor: rippleColor,\n accessibilityRole: \"button\",\n accessibilityState: {\n expanded: isExpanded\n },\n accessibilityLabel: accessibilityLabel,\n testID: testID,\n theme: theme,\n background: background,\n borderless: true\n }, /*#__PURE__*/React.createElement(View, {\n style: theme.isV3 ? styles.rowV3 : styles.row,\n pointerEvents: pointerEvents\n }, left ? left({\n color: isExpanded ? (_theme$colors2 = theme.colors) === null || _theme$colors2 === void 0 ? void 0 : _theme$colors2.primary : descriptionColor,\n style: getLeftStyles(alignToTop, description, theme.isV3)\n }) : null, /*#__PURE__*/React.createElement(View, {\n style: [theme.isV3 ? styles.itemV3 : styles.item, styles.content]\n }, /*#__PURE__*/React.createElement(Text, {\n selectable: false,\n numberOfLines: titleNumberOfLines,\n style: [styles.title, {\n color: titleTextColor\n }, titleStyle],\n maxFontSizeMultiplier: titleMaxFontSizeMultiplier\n }, title), description ? /*#__PURE__*/React.createElement(Text, {\n selectable: false,\n numberOfLines: descriptionNumberOfLines,\n style: [styles.description, {\n color: descriptionColor\n }, descriptionStyle],\n onTextLayout: onDescriptionTextLayout,\n maxFontSizeMultiplier: descriptionMaxFontSizeMultiplier\n }, description) : null), /*#__PURE__*/React.createElement(View, {\n style: [styles.item, description ? styles.multiline : undefined]\n }, right ? right({\n isExpanded: isExpanded\n }) : /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: isExpanded ? 'chevron-up' : 'chevron-down',\n color: theme.isV3 ? descriptionColor : titleColor,\n size: 24,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n }))))), isExpanded ? React.Children.map(children, child => {\n if (left && /*#__PURE__*/React.isValidElement(child) && !child.props.left && !child.props.right) {\n return /*#__PURE__*/React.cloneElement(child, {\n style: [theme.isV3 ? styles.childV3 : styles.child, child.props.style],\n theme\n });\n }\n return child;\n }) : null);\n};\nListAccordion.displayName = 'List.Accordion';\nconst styles = StyleSheet.create({\n container: {\n padding: 8\n },\n containerV3: {\n paddingVertical: 8,\n paddingRight: 24\n },\n row: {\n flexDirection: 'row',\n alignItems: 'center'\n },\n rowV3: {\n flexDirection: 'row',\n marginVertical: 6\n },\n multiline: {\n height: 40,\n alignItems: 'center',\n justifyContent: 'center'\n },\n title: {\n fontSize: 16\n },\n description: {\n fontSize: 14\n },\n item: {\n marginVertical: 6,\n paddingLeft: 8\n },\n itemV3: {\n paddingLeft: 16\n },\n child: {\n paddingLeft: 64\n },\n childV3: {\n paddingLeft: 40\n },\n content: {\n flex: 1,\n justifyContent: 'center'\n }\n});\nexport default ListAccordion;\n//# sourceMappingURL=ListAccordion.js.map","import * as React from 'react';\nexport const ListAccordionGroupContext = /*#__PURE__*/React.createContext(null);\n\n/**\n * List.AccordionGroup allows to control a group of List Accordions. `id` prop for List.Accordion is required in order for group to work.\n * List.AccordionGroup can be a controlled or uncontrolled component. The example shows the uncontrolled version.\n * At most one Accordion can be expanded at a given time.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View, Text } from 'react-native';\n * import { List } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * \n * \n * \n * \n * \n * \n * \n * \n * List.Accordion can be wrapped because implementation uses React.Context.\n * \n * \n * \n * \n * \n * \n * );\n *\n * export default MyComponent;\n *```\n */\nconst ListAccordionGroup = _ref => {\n let {\n expandedId: expandedIdProp,\n onAccordionPress,\n children\n } = _ref;\n const [expandedId, setExpandedId] = React.useState(undefined);\n const onAccordionPressDefault = newExpandedId => {\n setExpandedId(currentExpandedId => currentExpandedId === newExpandedId ? undefined : newExpandedId);\n };\n return /*#__PURE__*/React.createElement(ListAccordionGroupContext.Provider, {\n value: {\n expandedId: expandedIdProp || expandedId,\n // component can be controlled or uncontrolled\n onAccordionPress: onAccordionPress || onAccordionPressDefault\n }\n }, children);\n};\nListAccordionGroup.displayName = 'List.AccordionGroup';\nexport default ListAccordionGroup;\n//# sourceMappingURL=ListAccordionGroup.js.map","import { StyleSheet } from 'react-native';\nimport color from 'color';\nexport const getLeftStyles = (alignToTop, description, isV3) => {\n const stylesV3 = {\n marginRight: 0,\n marginLeft: 16,\n alignSelf: alignToTop ? 'flex-start' : 'center'\n };\n if (!description) {\n return {\n ...styles.iconMarginLeft,\n ...styles.marginVerticalNone,\n ...(isV3 && {\n ...stylesV3\n })\n };\n }\n if (!isV3) {\n return styles.iconMarginLeft;\n }\n return {\n ...styles.iconMarginLeft,\n ...stylesV3\n };\n};\nexport const getRightStyles = (alignToTop, description, isV3) => {\n const stylesV3 = {\n marginLeft: 16,\n alignSelf: alignToTop ? 'flex-start' : 'center'\n };\n if (!description) {\n return {\n ...styles.iconMarginRight,\n ...styles.marginVerticalNone,\n ...(isV3 && {\n ...stylesV3\n })\n };\n }\n if (!isV3) {\n return styles.iconMarginRight;\n }\n return {\n ...styles.iconMarginRight,\n ...stylesV3\n };\n};\nconst styles = StyleSheet.create({\n marginVerticalNone: {\n marginVertical: 0\n },\n iconMarginLeft: {\n marginLeft: 0,\n marginRight: 16\n },\n iconMarginRight: {\n marginRight: 0\n }\n});\nexport const getAccordionColors = _ref => {\n var _theme$colors;\n let {\n theme,\n isExpanded,\n customRippleColor\n } = _ref;\n const titleColor = theme.isV3 ? theme.colors.onSurface : color(theme.colors.text).alpha(0.87).rgb().string();\n const descriptionColor = theme.isV3 ? theme.colors.onSurfaceVariant : color(theme.colors.text).alpha(0.54).rgb().string();\n const titleTextColor = isExpanded ? (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.primary : titleColor;\n const rippleColor = customRippleColor || color(titleTextColor).alpha(0.12).rgb().string();\n return {\n titleColor,\n descriptionColor,\n titleTextColor,\n rippleColor\n };\n};\n//# sourceMappingURL=utils.js.map","import * as React from 'react';\nimport { View, StyleSheet } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\nimport Icon from '../Icon';\nconst ICON_SIZE = 24;\n\n/**\n * A component to show an icon in a list item.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { List, MD3Colors } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * <>\n * \n * \n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst ListIcon = _ref => {\n let {\n icon,\n color: iconColor,\n style,\n theme: themeOverrides\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n return /*#__PURE__*/React.createElement(View, {\n style: [theme.isV3 ? styles.itemV3 : styles.item, style],\n pointerEvents: \"box-none\"\n }, /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n size: ICON_SIZE,\n color: iconColor,\n theme: theme\n }));\n};\nconst styles = StyleSheet.create({\n item: {\n margin: 8,\n height: 40,\n width: 40,\n alignItems: 'center',\n justifyContent: 'center'\n },\n itemV3: {\n alignItems: 'center',\n justifyContent: 'center'\n }\n});\nListIcon.displayName = 'List.Icon';\nexport default ListIcon;\n//# sourceMappingURL=ListIcon.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { getLeftStyles, getRightStyles } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { forwardRef } from '../../utils/forwardRef';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * A component to show tiles inside a List.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { List } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * }\n * />\n * );\n *\n * export default MyComponent;\n * ```\n *\n * @extends TouchableRipple props https://callstack.github.io/react-native-paper/docs/components/TouchableRipple\n */\nconst ListItem = (_ref, ref) => {\n let {\n left,\n right,\n title,\n description,\n onPress,\n theme: themeOverrides,\n style,\n contentStyle,\n titleStyle,\n titleNumberOfLines = 1,\n descriptionNumberOfLines = 2,\n titleEllipsizeMode,\n descriptionEllipsizeMode,\n descriptionStyle,\n descriptionMaxFontSizeMultiplier,\n titleMaxFontSizeMultiplier,\n testID,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const [alignToTop, setAlignToTop] = React.useState(false);\n const onDescriptionTextLayout = event => {\n if (!theme.isV3) {\n return;\n }\n const {\n nativeEvent\n } = event;\n setAlignToTop(nativeEvent.lines.length >= 2);\n };\n const renderDescription = (descriptionColor, description) => {\n return typeof description === 'function' ? description({\n selectable: false,\n ellipsizeMode: descriptionEllipsizeMode,\n color: descriptionColor,\n fontSize: styles.description.fontSize\n }) : /*#__PURE__*/React.createElement(Text, {\n selectable: false,\n numberOfLines: descriptionNumberOfLines,\n ellipsizeMode: descriptionEllipsizeMode,\n style: [styles.description, {\n color: descriptionColor\n }, descriptionStyle],\n onTextLayout: onDescriptionTextLayout,\n maxFontSizeMultiplier: descriptionMaxFontSizeMultiplier\n }, description);\n };\n const renderTitle = () => {\n const titleColor = theme.isV3 ? theme.colors.onSurface : color(theme.colors.text).alpha(0.87).rgb().string();\n return typeof title === 'function' ? title({\n selectable: false,\n ellipsizeMode: titleEllipsizeMode,\n color: titleColor,\n fontSize: styles.title.fontSize\n }) : /*#__PURE__*/React.createElement(Text, {\n selectable: false,\n ellipsizeMode: titleEllipsizeMode,\n numberOfLines: titleNumberOfLines,\n style: [styles.title, {\n color: titleColor\n }, titleStyle],\n maxFontSizeMultiplier: titleMaxFontSizeMultiplier\n }, title);\n };\n const descriptionColor = theme.isV3 ? theme.colors.onSurfaceVariant : color(theme.colors.text).alpha(0.54).rgb().string();\n return /*#__PURE__*/React.createElement(TouchableRipple, _extends({}, rest, {\n ref: ref,\n style: [theme.isV3 ? styles.containerV3 : styles.container, style],\n onPress: onPress,\n theme: theme,\n testID: testID\n }), /*#__PURE__*/React.createElement(View, {\n style: theme.isV3 ? styles.rowV3 : styles.row\n }, left ? left({\n color: descriptionColor,\n style: getLeftStyles(alignToTop, description, theme.isV3)\n }) : null, /*#__PURE__*/React.createElement(View, {\n style: [theme.isV3 ? styles.itemV3 : styles.item, styles.content, contentStyle],\n testID: `${testID}-content`\n }, renderTitle(), description ? renderDescription(descriptionColor, description) : null), right ? right({\n color: descriptionColor,\n style: getRightStyles(alignToTop, description, theme.isV3)\n }) : null));\n};\nconst Component = forwardRef(ListItem);\nComponent.displayName = 'List.Item';\nconst styles = StyleSheet.create({\n container: {\n padding: 8\n },\n containerV3: {\n paddingVertical: 8,\n paddingRight: 24\n },\n row: {\n width: '100%',\n flexDirection: 'row'\n },\n rowV3: {\n width: '100%',\n flexDirection: 'row',\n marginVertical: 6\n },\n title: {\n fontSize: 16\n },\n description: {\n fontSize: 14\n },\n item: {\n marginVertical: 6,\n paddingLeft: 8\n },\n itemV3: {\n paddingLeft: 16\n },\n content: {\n flexShrink: 1,\n flexGrow: 1,\n justifyContent: 'center'\n }\n});\nexport default Component;\n//# sourceMappingURL=ListItem.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport ListSubheader from './ListSubheader';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * A component used to group list items.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { List, MD3Colors } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * Some title\n * } />\n * }\n * />\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst ListSection = _ref => {\n let {\n children,\n title,\n titleStyle,\n style,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const viewProps = {\n ...rest,\n theme\n };\n return /*#__PURE__*/React.createElement(View, _extends({}, viewProps, {\n style: [styles.container, style]\n }), title ? /*#__PURE__*/React.createElement(ListSubheader, {\n style: titleStyle,\n theme: theme\n }, title) : null, children);\n};\nListSection.displayName = 'List.Section';\nconst styles = StyleSheet.create({\n container: {\n marginVertical: 8\n }\n});\nexport default ListSection;\n//# sourceMappingURL=ListSection.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport color from 'color';\nimport { useInternalTheme } from '../../core/theming';\nimport Text from '../Typography/Text';\n/**\n * A component used to display a header in lists.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { List } from 'react-native-paper';\n *\n * const MyComponent = () => My List Title;\n *\n * export default MyComponent;\n * ```\n */\nconst ListSubheader = _ref => {\n let {\n style,\n theme: overrideTheme,\n maxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(overrideTheme);\n const textColor = theme.isV3 ? theme.colors.onSurfaceVariant : color(theme.colors.text).alpha(0.54).rgb().string();\n const font = theme.isV3 ? theme.fonts.bodyMedium : theme.fonts.medium;\n return /*#__PURE__*/React.createElement(Text, _extends({\n variant: \"bodyMedium\",\n numberOfLines: 1,\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, rest, {\n style: [styles.container, {\n color: textColor,\n ...font\n }, style]\n }));\n};\nListSubheader.displayName = 'List.Subheader';\nconst styles = StyleSheet.create({\n container: {\n paddingHorizontal: 16,\n paddingVertical: 13\n }\n});\nexport default ListSubheader;\n//# sourceMappingURL=ListSubheader.js.map","import * as React from 'react';\nimport { StyleSheet, Image } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * A component to show image in a list item.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { List, MD3Colors } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * <>\n * \n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst ListImage = _ref => {\n let {\n style,\n source,\n variant = 'image',\n theme: themeOverrides\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const getStyles = () => {\n if (variant === 'video') {\n if (!theme.isV3) {\n return [style, styles.video];\n }\n return [style, styles.videoV3];\n }\n return [style, styles.image];\n };\n return /*#__PURE__*/React.createElement(Image, {\n style: getStyles(),\n source: source,\n accessibilityIgnoresInvertColors: true,\n testID: \"list-image\"\n });\n};\nconst styles = StyleSheet.create({\n image: {\n width: 56,\n height: 56\n },\n video: {\n width: 100,\n height: 64,\n marginLeft: 0\n },\n videoV3: {\n width: 114,\n height: 64,\n marginLeft: 0\n }\n});\nListImage.displayName = 'List.Image';\nexport default ListImage;\n//# sourceMappingURL=ListImage.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Easing, I18nManager, Platform, ScrollView, StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { getCombinedStyles, getFABColors } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport Icon from '../Icon';\nimport Surface from '../Surface';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport AnimatedText from '../Typography/AnimatedText';\nconst SIZE = 56;\nconst SCALE = 0.9;\n\n/**\n * An animated, extending horizontally floating action button represents the primary action in an application.\n *\n * ## Usage\n * ```js\n * import React from 'react';\n * import {\n * StyleProp,\n * ViewStyle,\n * Animated,\n * StyleSheet,\n * Platform,\n * ScrollView,\n * Text,\n * SafeAreaView,\n * I18nManager,\n * } from 'react-native';\n * import { AnimatedFAB } from 'react-native-paper';\n *\n * const MyComponent = ({\n * animatedValue,\n * visible,\n * extended,\n * label,\n * animateFrom,\n * style,\n * iconMode,\n * }) => {\n * const [isExtended, setIsExtended] = React.useState(true);\n *\n * const isIOS = Platform.OS === 'ios';\n *\n * const onScroll = ({ nativeEvent }) => {\n * const currentScrollPosition =\n * Math.floor(nativeEvent?.contentOffset?.y) ?? 0;\n *\n * setIsExtended(currentScrollPosition <= 0);\n * };\n *\n * const fabStyle = { [animateFrom]: 16 };\n *\n * return (\n * \n * \n * {[...new Array(100).keys()].map((_, i) => (\n * {i}\n * ))}\n * \n * console.log('Pressed')}\n * visible={visible}\n * animateFrom={'right'}\n * iconMode={'static'}\n * style={[styles.fabStyle, style, fabStyle]}\n * />\n * \n * );\n * };\n *\n * export default MyComponent;\n *\n * const styles = StyleSheet.create({\n * container: {\n * flexGrow: 1,\n * },\n * fabStyle: {\n * bottom: 16,\n * right: 16,\n * position: 'absolute',\n * },\n * });\n * ```\n */\nconst AnimatedFAB = _ref => {\n let {\n icon,\n label,\n background,\n accessibilityLabel = label,\n accessibilityState,\n color: customColor,\n rippleColor: customRippleColor,\n disabled,\n onPress,\n onLongPress,\n delayLongPress,\n theme: themeOverrides,\n style,\n visible = true,\n uppercase: uppercaseProp,\n testID = 'animated-fab',\n animateFrom = 'right',\n extended = false,\n iconMode = 'dynamic',\n variant = 'primary',\n labelMaxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const uppercase = uppercaseProp ?? !theme.isV3;\n const isIOS = Platform.OS === 'ios';\n const isAnimatedFromRight = animateFrom === 'right';\n const isIconStatic = iconMode === 'static';\n const {\n isRTL\n } = I18nManager;\n const {\n current: visibility\n } = React.useRef(new Animated.Value(visible ? 1 : 0));\n const {\n current: animFAB\n } = React.useRef(new Animated.Value(0));\n const {\n isV3,\n animation\n } = theme;\n const {\n scale\n } = animation;\n const [textWidth, setTextWidth] = React.useState(0);\n const [textHeight, setTextHeight] = React.useState(0);\n const borderRadius = SIZE / (isV3 ? 3.5 : 2);\n React.useEffect(() => {\n if (visible) {\n Animated.timing(visibility, {\n toValue: 1,\n duration: 200 * scale,\n useNativeDriver: true\n }).start();\n } else {\n Animated.timing(visibility, {\n toValue: 0,\n duration: 150 * scale,\n useNativeDriver: true\n }).start();\n }\n }, [visible, scale, visibility]);\n const {\n backgroundColor: customBackgroundColor,\n ...restStyle\n } = StyleSheet.flatten(style) || {};\n const {\n backgroundColor,\n foregroundColor\n } = getFABColors({\n theme,\n variant,\n disabled,\n customColor,\n customBackgroundColor\n });\n const rippleColor = customRippleColor || color(foregroundColor).alpha(0.12).rgb().string();\n const extendedWidth = textWidth + SIZE + borderRadius;\n const distance = isAnimatedFromRight ? -textWidth - borderRadius : textWidth + borderRadius;\n React.useEffect(() => {\n Animated.timing(animFAB, {\n toValue: !extended ? 0 : distance,\n duration: 150 * scale,\n useNativeDriver: true,\n easing: Easing.linear\n }).start();\n }, [animFAB, scale, distance, extended]);\n const onTextLayout = _ref2 => {\n let {\n nativeEvent\n } = _ref2;\n const currentWidth = Math.ceil(nativeEvent.lines[0].width);\n const currentHeight = Math.ceil(nativeEvent.lines[0].height);\n if (currentWidth !== textWidth || currentHeight !== textHeight) {\n setTextHeight(currentHeight);\n if (isIOS) {\n return setTextWidth(currentWidth - 12);\n }\n setTextWidth(currentWidth);\n }\n };\n const propForDirection = right => {\n if (isAnimatedFromRight) {\n return right;\n }\n return right.reverse();\n };\n const combinedStyles = getCombinedStyles({\n isAnimatedFromRight,\n isIconStatic,\n distance,\n animFAB\n });\n const font = isV3 ? theme.fonts.labelLarge : theme.fonts.medium;\n const textStyle = {\n color: foregroundColor,\n ...font\n };\n const md2Elevation = disabled || !isIOS ? 0 : 6;\n const md3Elevation = disabled || !isIOS ? 0 : 3;\n const shadowStyle = isV3 ? styles.v3Shadow : styles.shadow;\n const baseStyle = [StyleSheet.absoluteFill, disabled ? styles.disabled : shadowStyle];\n const newAccessibilityState = {\n ...accessibilityState,\n disabled\n };\n return /*#__PURE__*/React.createElement(Surface, _extends({}, rest, {\n testID: `${testID}-container`,\n style: [{\n opacity: visibility,\n transform: [{\n scale: visibility\n }],\n borderRadius\n }, !isV3 && {\n elevation: md2Elevation\n }, styles.container, restStyle]\n }, isV3 && {\n elevation: md3Elevation\n }, {\n theme: theme\n }), /*#__PURE__*/React.createElement(Animated.View, {\n style: [!isV3 && {\n transform: [{\n scaleY: animFAB.interpolate({\n inputRange: propForDirection([distance, 0]),\n outputRange: propForDirection([SCALE, 1])\n })\n }]\n }, styles.standard, {\n borderRadius\n }]\n }, /*#__PURE__*/React.createElement(View, {\n style: [StyleSheet.absoluteFill, styles.shadowWrapper]\n }, /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: \"none\",\n style: [baseStyle, {\n width: extendedWidth,\n opacity: animFAB.interpolate({\n inputRange: propForDirection([distance, 0.9 * distance, 0]),\n outputRange: propForDirection([1, 0.15, 0])\n }),\n borderRadius\n }],\n testID: `${testID}-extended-shadow`\n }), /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: \"none\",\n style: [baseStyle, {\n opacity: animFAB.interpolate({\n inputRange: propForDirection([distance, 0.9 * distance, 0]),\n outputRange: propForDirection([0, 0.85, 1])\n }),\n width: SIZE,\n borderRadius: animFAB.interpolate({\n inputRange: propForDirection([distance, 0]),\n outputRange: propForDirection([SIZE / (extendedWidth / SIZE), borderRadius])\n })\n }, combinedStyles.absoluteFill],\n testID: `${testID}-shadow`\n })), /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: \"box-none\",\n style: [styles.innerWrapper, {\n borderRadius\n }]\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.standard, {\n width: extendedWidth,\n backgroundColor,\n borderRadius\n }, combinedStyles.innerWrapper]\n }, /*#__PURE__*/React.createElement(TouchableRipple, {\n borderless: true,\n background: background,\n onPress: onPress,\n onLongPress: onLongPress,\n delayLongPress: delayLongPress,\n rippleColor: rippleColor,\n disabled: disabled,\n accessibilityLabel: accessibilityLabel,\n accessibilityRole: \"button\",\n accessibilityState: newAccessibilityState,\n testID: testID,\n style: {\n borderRadius\n },\n theme: theme\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.standard, {\n width: extendedWidth,\n borderRadius\n }]\n }))))), /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.iconWrapper, combinedStyles.iconWrapper],\n pointerEvents: \"none\"\n }, /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n size: 24,\n color: foregroundColor,\n theme: theme\n })), /*#__PURE__*/React.createElement(View, {\n pointerEvents: \"none\"\n }, /*#__PURE__*/React.createElement(AnimatedText, {\n variant: \"labelLarge\",\n numberOfLines: 1,\n onTextLayout: isIOS ? onTextLayout : undefined,\n ellipsizeMode: 'tail',\n style: [{\n [isAnimatedFromRight || isRTL ? 'right' : 'left']: isIconStatic ? textWidth - SIZE + borderRadius / (isV3 ? 1 : 2) : borderRadius\n }, {\n minWidth: textWidth,\n top: -SIZE / 2 - textHeight / 2,\n opacity: animFAB.interpolate({\n inputRange: propForDirection([distance, 0.7 * distance, 0]),\n outputRange: propForDirection([1, 0, 0])\n }),\n // TODO: check\n transform: [{\n translateX: animFAB.interpolate({\n inputRange: propForDirection([distance, 0]),\n outputRange: propForDirection([0, SIZE])\n })\n }]\n }, styles.label, uppercase && styles.uppercaseLabel, textStyle],\n theme: theme,\n testID: `${testID}-text`,\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier\n }, label)), !isIOS &&\n /*#__PURE__*/\n // Method `onTextLayout` on Android returns sizes of text visible on the screen,\n // however during render the text in `FAB` isn't fully visible. In order to get\n // proper text measurements there is a need to additionaly render that text, but\n // wrapped in absolutely positioned `ScrollView` which height is 0.\n React.createElement(ScrollView, {\n style: styles.textPlaceholderContainer\n }, /*#__PURE__*/React.createElement(AnimatedText, {\n variant: \"labelLarge\",\n numberOfLines: 1,\n onTextLayout: onTextLayout,\n ellipsizeMode: 'tail',\n style: [styles.label, uppercase && styles.uppercaseLabel, textStyle],\n theme: theme\n }, label)));\n};\nconst styles = StyleSheet.create({\n standard: {\n height: SIZE\n },\n disabled: {\n elevation: 0\n },\n // eslint-disable-next-line react-native/no-color-literals\n container: {\n position: 'absolute',\n backgroundColor: 'transparent'\n },\n innerWrapper: {\n flexDirection: 'row',\n overflow: 'hidden'\n },\n shadowWrapper: {\n elevation: 0\n },\n shadow: {\n elevation: 6\n },\n v3Shadow: {\n elevation: 3\n },\n iconWrapper: {\n alignItems: 'center',\n justifyContent: 'center',\n position: 'absolute',\n height: SIZE,\n width: SIZE\n },\n label: {\n position: 'absolute'\n },\n uppercaseLabel: {\n textTransform: 'uppercase'\n },\n textPlaceholderContainer: {\n height: 0,\n position: 'absolute'\n }\n});\nexport default AnimatedFAB;\n//# sourceMappingURL=AnimatedFAB.js.map","import { I18nManager } from 'react-native';\nimport color from 'color';\nimport { black, white } from '../../styles/themes/v2/colors';\nimport getContrastingColor from '../../utils/getContrastingColor';\nexport const getCombinedStyles = _ref => {\n let {\n isAnimatedFromRight,\n isIconStatic,\n distance,\n animFAB\n } = _ref;\n const {\n isRTL\n } = I18nManager;\n const defaultPositionStyles = {\n left: -distance,\n right: undefined\n };\n const combinedStyles = {\n innerWrapper: {\n ...defaultPositionStyles\n },\n iconWrapper: {\n ...defaultPositionStyles\n },\n absoluteFill: {}\n };\n const animatedFromRight = isAnimatedFromRight && !isRTL;\n const animatedFromRightRTL = isAnimatedFromRight && isRTL;\n const animatedFromLeft = !isAnimatedFromRight && !isRTL;\n const animatedFromLeftRTL = !isAnimatedFromRight && isRTL;\n if (animatedFromRight) {\n combinedStyles.innerWrapper.transform = [{\n translateX: animFAB.interpolate({\n inputRange: [distance, 0],\n outputRange: [distance, 0]\n })\n }];\n combinedStyles.iconWrapper.transform = [{\n translateX: isIconStatic ? 0 : animFAB\n }];\n combinedStyles.absoluteFill.transform = [{\n translateX: animFAB.interpolate({\n inputRange: [distance, 0],\n outputRange: [Math.abs(distance) / 2, Math.abs(distance)]\n })\n }];\n } else if (animatedFromRightRTL) {\n combinedStyles.iconWrapper.transform = [{\n translateX: isIconStatic ? 0 : animFAB.interpolate({\n inputRange: [distance, 0],\n outputRange: [-distance, 0]\n })\n }];\n combinedStyles.innerWrapper.transform = [{\n translateX: animFAB.interpolate({\n inputRange: [distance, 0],\n outputRange: [-distance, 0]\n })\n }];\n combinedStyles.absoluteFill.transform = [{\n translateX: animFAB.interpolate({\n inputRange: [distance, 0],\n outputRange: [0, distance]\n })\n }];\n } else if (animatedFromLeft) {\n combinedStyles.iconWrapper.transform = [{\n translateX: isIconStatic ? distance : animFAB.interpolate({\n inputRange: [0, distance],\n outputRange: [distance, distance * 2]\n })\n }];\n combinedStyles.innerWrapper.transform = [{\n translateX: animFAB\n }];\n combinedStyles.absoluteFill.transform = [{\n translateX: animFAB.interpolate({\n inputRange: [0, distance],\n outputRange: [0, Math.abs(distance) / 2]\n })\n }];\n } else if (animatedFromLeftRTL) {\n combinedStyles.iconWrapper.transform = [{\n translateX: isIconStatic ? animFAB.interpolate({\n inputRange: [0, distance],\n outputRange: [-distance, -distance * 2]\n }) : -distance\n }];\n combinedStyles.innerWrapper.transform = [{\n translateX: animFAB.interpolate({\n inputRange: [0, distance],\n outputRange: [0, -distance]\n })\n }];\n combinedStyles.absoluteFill.transform = [{\n translateX: animFAB.interpolate({\n inputRange: [0, distance],\n outputRange: [0, -distance]\n })\n }];\n }\n return combinedStyles;\n};\nconst getBackgroundColor = _ref2 => {\n var _theme$colors;\n let {\n theme,\n isVariant,\n disabled,\n customBackgroundColor\n } = _ref2;\n if (customBackgroundColor && !disabled) {\n return customBackgroundColor;\n }\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.surfaceDisabled;\n }\n if (isVariant('primary')) {\n return theme.colors.primaryContainer;\n }\n if (isVariant('secondary')) {\n return theme.colors.secondaryContainer;\n }\n if (isVariant('tertiary')) {\n return theme.colors.tertiaryContainer;\n }\n if (isVariant('surface')) {\n return theme.colors.elevation.level3;\n }\n }\n if (disabled) {\n if (theme.dark) {\n return color(white).alpha(0.12).rgb().string();\n }\n return color(black).alpha(0.12).rgb().string();\n }\n\n //@ts-ignore\n return (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.accent;\n};\nconst getForegroundColor = _ref3 => {\n let {\n theme,\n isVariant,\n disabled,\n backgroundColor,\n customColor\n } = _ref3;\n if (typeof customColor !== 'undefined' && !disabled) {\n return customColor;\n }\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n if (isVariant('primary')) {\n return theme.colors.onPrimaryContainer;\n }\n if (isVariant('secondary')) {\n return theme.colors.onSecondaryContainer;\n }\n if (isVariant('tertiary')) {\n return theme.colors.onTertiaryContainer;\n }\n if (isVariant('surface')) {\n return theme.colors.primary;\n }\n }\n if (disabled) {\n if (theme.dark) {\n return color(white).alpha(0.32).rgb().string();\n }\n return color(black).alpha(0.32).rgb().string();\n }\n if (backgroundColor) {\n return getContrastingColor(backgroundColor || white, white, 'rgba(0, 0, 0, .54)');\n }\n return getContrastingColor(white, white, 'rgba(0, 0, 0, .54)');\n};\nexport const getFABColors = _ref4 => {\n let {\n theme,\n variant,\n disabled,\n customColor,\n customBackgroundColor,\n customRippleColor\n } = _ref4;\n const isVariant = variantToCompare => {\n return variant === variantToCompare;\n };\n const baseFABColorProps = {\n theme,\n isVariant,\n disabled\n };\n const backgroundColor = getBackgroundColor({\n ...baseFABColorProps,\n customBackgroundColor\n });\n const foregroundColor = getForegroundColor({\n ...baseFABColorProps,\n customColor,\n backgroundColor\n });\n return {\n backgroundColor,\n foregroundColor,\n rippleColor: customRippleColor || color(foregroundColor).alpha(0.12).rgb().string()\n };\n};\nconst getLabelColor = _ref5 => {\n let {\n theme\n } = _ref5;\n if (theme.isV3) {\n return theme.colors.onSurface;\n }\n if (theme.dark) {\n return theme.colors.text;\n }\n return color(theme.colors.text).fade(0.54).rgb().string();\n};\nconst getBackdropColor = _ref6 => {\n var _theme$colors2;\n let {\n theme,\n customBackdropColor\n } = _ref6;\n if (customBackdropColor) {\n return customBackdropColor;\n }\n if (theme.isV3) {\n return color(theme.colors.background).alpha(0.95).rgb().string();\n }\n return (_theme$colors2 = theme.colors) === null || _theme$colors2 === void 0 ? void 0 : _theme$colors2.backdrop;\n};\nconst getStackedFABBackgroundColor = _ref7 => {\n let {\n theme\n } = _ref7;\n if (theme.isV3) {\n return theme.colors.elevation.level3;\n }\n return theme.colors.surface;\n};\nexport const getFABGroupColors = _ref8 => {\n let {\n theme,\n customBackdropColor\n } = _ref8;\n return {\n labelColor: getLabelColor({\n theme\n }),\n backdropColor: getBackdropColor({\n theme,\n customBackdropColor\n }),\n stackedFABBackgroundColor: getStackedFABBackgroundColor({\n theme\n })\n };\n};\nconst standardSize = {\n height: 56,\n width: 56,\n borderRadius: 28\n};\nconst smallSize = {\n height: 40,\n width: 40,\n borderRadius: 28\n};\nconst v3SmallSize = {\n height: 40,\n width: 40\n};\nconst v3MediumSize = {\n height: 56,\n width: 56\n};\nconst v3LargeSize = {\n height: 96,\n width: 96\n};\nconst getCustomFabSize = (customSize, roundness) => ({\n height: customSize,\n width: customSize,\n borderRadius: roundness === 0 ? 0 : customSize / roundness\n});\nexport const getFabStyle = _ref9 => {\n let {\n size,\n theme,\n customSize\n } = _ref9;\n const {\n isV3,\n roundness\n } = theme;\n if (customSize) return getCustomFabSize(customSize, roundness);\n if (isV3) {\n switch (size) {\n case 'small':\n return {\n ...v3SmallSize,\n borderRadius: 3 * roundness\n };\n case 'medium':\n return {\n ...v3MediumSize,\n borderRadius: 4 * roundness\n };\n case 'large':\n return {\n ...v3LargeSize,\n borderRadius: 7 * roundness\n };\n }\n }\n if (size === 'small') {\n return smallSize;\n }\n return standardSize;\n};\nconst extended = {\n height: 48,\n paddingHorizontal: 16\n};\nconst v3Extended = {\n height: 56,\n borderRadius: 16,\n paddingHorizontal: 16\n};\nconst getExtendedFabDimensions = customSize => ({\n height: customSize,\n paddingHorizontal: 16\n});\nexport const getExtendedFabStyle = _ref10 => {\n let {\n customSize,\n theme\n } = _ref10;\n if (customSize) return getExtendedFabDimensions(customSize);\n const {\n isV3\n } = theme;\n return isV3 ? v3Extended : extended;\n};\n//# sourceMappingURL=utils.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Platform, StyleSheet } from 'react-native';\nimport { useInternalTheme } from '../core/theming';\nimport overlay, { isAnimatedValue } from '../styles/overlay';\nimport shadow from '../styles/shadow';\nimport { forwardRef } from '../utils/forwardRef';\nimport { splitStyles } from '../utils/splitStyles';\nconst MD2Surface = forwardRef((_ref, ref) => {\n let {\n style,\n theme: overrideTheme,\n ...rest\n } = _ref;\n const {\n elevation = 4\n } = StyleSheet.flatten(style) || {};\n const {\n dark: isDarkTheme,\n mode,\n colors\n } = useInternalTheme(overrideTheme);\n return /*#__PURE__*/React.createElement(Animated.View, _extends({\n ref: ref\n }, rest, {\n style: [{\n backgroundColor: isDarkTheme && mode === 'adaptive' ? overlay(elevation, colors === null || colors === void 0 ? void 0 : colors.surface) : colors === null || colors === void 0 ? void 0 : colors.surface\n }, elevation ? shadow(elevation) : null, style]\n }));\n});\nconst outerLayerStyleProperties = ['position', 'alignSelf', 'top', 'right', 'bottom', 'left', 'start', 'end', 'flex', 'flexShrink', 'flexGrow', 'width', 'height', 'transform', 'opacity'];\nconst shadowColor = '#000';\nconst iOSShadowOutputRanges = [{\n shadowOpacity: 0.15,\n height: [0, 1, 2, 4, 6, 8],\n shadowRadius: [0, 3, 6, 8, 10, 12]\n}, {\n shadowOpacity: 0.3,\n height: [0, 1, 1, 1, 2, 4],\n shadowRadius: [0, 1, 2, 3, 3, 4]\n}];\nconst inputRange = [0, 1, 2, 3, 4, 5];\nfunction getStyleForShadowLayer(elevation, layer) {\n if (isAnimatedValue(elevation)) {\n return {\n shadowColor,\n shadowOpacity: elevation.interpolate({\n inputRange: [0, 1],\n outputRange: [0, iOSShadowOutputRanges[layer].shadowOpacity],\n extrapolate: 'clamp'\n }),\n shadowOffset: {\n width: 0,\n height: elevation.interpolate({\n inputRange,\n outputRange: iOSShadowOutputRanges[layer].height\n })\n },\n shadowRadius: elevation.interpolate({\n inputRange,\n outputRange: iOSShadowOutputRanges[layer].shadowRadius\n })\n };\n }\n return {\n shadowColor,\n shadowOpacity: elevation ? iOSShadowOutputRanges[layer].shadowOpacity : 0,\n shadowOffset: {\n width: 0,\n height: iOSShadowOutputRanges[layer].height[elevation]\n },\n shadowRadius: iOSShadowOutputRanges[layer].shadowRadius[elevation]\n };\n}\nconst SurfaceIOS = forwardRef((_ref2, ref) => {\n let {\n elevation,\n style,\n backgroundColor,\n testID,\n children,\n mode = 'elevated',\n ...props\n } = _ref2;\n const [outerLayerViewStyles, innerLayerViewStyles] = React.useMemo(() => {\n const flattenedStyles = StyleSheet.flatten(style) || {};\n const [filteredStyles, outerLayerStyles, borderRadiusStyles] = splitStyles(flattenedStyles, style => outerLayerStyleProperties.includes(style) || style.startsWith('margin'), style => style.startsWith('border') && style.endsWith('Radius'));\n if (process.env.NODE_ENV !== 'production' && filteredStyles.overflow === 'hidden' && elevation !== 0) {\n console.warn('When setting overflow to hidden on Surface the shadow will not be displayed correctly. Wrap the content of your component in a separate View with the overflow style.');\n }\n const bgColor = flattenedStyles.backgroundColor || backgroundColor;\n const isElevated = mode === 'elevated';\n const outerLayerViewStyles = {\n ...(isElevated && getStyleForShadowLayer(elevation, 0)),\n ...outerLayerStyles,\n ...borderRadiusStyles,\n backgroundColor: bgColor\n };\n const innerLayerViewStyles = {\n ...(isElevated && getStyleForShadowLayer(elevation, 1)),\n ...filteredStyles,\n ...borderRadiusStyles,\n flex: flattenedStyles.height ? 1 : undefined,\n backgroundColor: bgColor\n };\n return [outerLayerViewStyles, innerLayerViewStyles];\n }, [style, elevation, backgroundColor, mode]);\n return /*#__PURE__*/React.createElement(Animated.View, {\n ref: ref,\n style: outerLayerViewStyles,\n testID: `${testID}-outer-layer`\n }, /*#__PURE__*/React.createElement(Animated.View, _extends({}, props, {\n style: innerLayerViewStyles,\n testID: testID\n }), children));\n});\n\n/**\n * Surface is a basic container that can give depth to an element with elevation shadow.\n * On dark theme with `adaptive` mode, surface is constructed by also placing a semi-transparent white overlay over a component surface.\n * See [Dark Theme](https://callstack.github.io/react-native-paper/docs/guides/theming#dark-theme) for more information.\n * Overlay and shadow can be applied by specifying the `elevation` property both on Android and iOS.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Surface, Text } from 'react-native-paper';\n * import { StyleSheet } from 'react-native';\n *\n * const MyComponent = () => (\n * \n * Surface\n * \n * );\n *\n * export default MyComponent;\n *\n * const styles = StyleSheet.create({\n * surface: {\n * padding: 8,\n * height: 80,\n * width: 80,\n * alignItems: 'center',\n * justifyContent: 'center',\n * },\n * });\n * ```\n */\nconst Surface = forwardRef((_ref3, ref) => {\n let {\n elevation = 1,\n children,\n theme: overridenTheme,\n style,\n testID = 'surface',\n mode = 'elevated',\n ...props\n } = _ref3;\n const theme = useInternalTheme(overridenTheme);\n if (!theme.isV3) return /*#__PURE__*/React.createElement(MD2Surface, _extends({}, props, {\n theme: theme,\n style: style,\n ref: ref\n }), children);\n const {\n colors\n } = theme;\n const inputRange = [0, 1, 2, 3, 4, 5];\n const backgroundColor = (_colors$elevation2 => {\n if (isAnimatedValue(elevation)) {\n return elevation.interpolate({\n inputRange,\n outputRange: inputRange.map(elevation => {\n var _colors$elevation;\n return (_colors$elevation = colors.elevation) === null || _colors$elevation === void 0 ? void 0 : _colors$elevation[`level${elevation}`];\n })\n });\n }\n return (_colors$elevation2 = colors.elevation) === null || _colors$elevation2 === void 0 ? void 0 : _colors$elevation2[`level${elevation}`];\n })();\n const isElevated = mode === 'elevated';\n if (Platform.OS === 'web') {\n const {\n pointerEvents = 'auto'\n } = props;\n return /*#__PURE__*/React.createElement(Animated.View, _extends({}, props, {\n pointerEvents: pointerEvents,\n ref: ref,\n testID: testID,\n style: [{\n backgroundColor\n }, elevation && isElevated ? shadow(elevation, theme.isV3) : null, style]\n }), children);\n }\n if (Platform.OS === 'android') {\n const elevationLevel = [0, 3, 6, 9, 12, 15];\n const getElevationAndroid = () => {\n if (isAnimatedValue(elevation)) {\n return elevation.interpolate({\n inputRange,\n outputRange: elevationLevel\n });\n }\n return elevationLevel[elevation];\n };\n const {\n margin,\n padding,\n transform,\n borderRadius\n } = StyleSheet.flatten(style) || {};\n const outerLayerStyles = {\n margin,\n padding,\n transform,\n borderRadius\n };\n const sharedStyle = [{\n backgroundColor\n }, style];\n return /*#__PURE__*/React.createElement(Animated.View, _extends({}, props, {\n testID: testID,\n ref: ref,\n style: [{\n backgroundColor,\n transform\n }, outerLayerStyles, sharedStyle, isElevated && {\n elevation: getElevationAndroid()\n }]\n }), children);\n }\n return /*#__PURE__*/React.createElement(SurfaceIOS, _extends({}, props, {\n ref: ref,\n elevation: elevation,\n backgroundColor: backgroundColor,\n style: style,\n testID: testID,\n mode: mode\n }), children);\n});\nexport default Surface;\n//# sourceMappingURL=Surface.js.map","/**\n * Utility function to extract styles in separate objects\n *\n * @param styles The style object you want to filter\n * @param filters The filters by which you want to split the styles\n * @returns An array of filtered style objects:\n * - The first style object contains the properties that didn't match any filter\n * - After that there will be a style object for each filter you passed in the same order as the matching filters\n * - A style property will exist in a single style object, the first filter it matched\n */\nexport function splitStyles(styles) {\n for (var _len = arguments.length, filters = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n filters[_key - 1] = arguments[_key];\n }\n if (process.env.NODE_ENV !== 'production' && filters.length === 0) {\n console.error('No filters were passed when calling splitStyles');\n }\n\n // `Object.entries` will be used to iterate over the styles and `Object.fromEntries` will be called before returning\n // Entries which match the given filters will be temporarily stored in `newStyles`\n const newStyles = filters.map(() => []);\n\n // Entries which match no filter\n const rest = [];\n\n // Iterate every style property\n outer: for (const item of Object.entries(styles)) {\n // Check each filter\n for (let i = 0; i < filters.length; i++) {\n // Check if filter matches\n if (filters[i](item[0])) {\n newStyles[i].push(item); // Push to temporary filtered entries array\n continue outer; // Skip to checking next style property\n }\n }\n\n // Adds to rest styles if not filtered\n rest.push(item);\n }\n\n // Put unmatched styles in the beginning\n newStyles.unshift(rest);\n\n // Convert arrays of entries into objects\n return newStyles.map(styles => Object.fromEntries(styles));\n}\n//# sourceMappingURL=splitStyles.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Easing, Platform, StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../core/theming';\nconst DURATION = 2400;\n\n/**\n * Activity indicator is used to present progress of some activity in the app.\n * It can be used as a drop-in for the ActivityIndicator shipped with React Native.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { ActivityIndicator, MD2Colors } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst ActivityIndicator = _ref => {\n var _theme$colors;\n let {\n animating = true,\n color: indicatorColor,\n hidesWhenStopped = true,\n size: indicatorSize = 'small',\n style,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n current: timer\n } = React.useRef(new Animated.Value(0));\n const {\n current: fade\n } = React.useRef(new Animated.Value(!animating && hidesWhenStopped ? 0 : 1));\n const rotation = React.useRef(undefined);\n const {\n animation: {\n scale\n }\n } = theme;\n const startRotation = React.useCallback(() => {\n // Show indicator\n Animated.timing(fade, {\n duration: 200 * scale,\n toValue: 1,\n isInteraction: false,\n useNativeDriver: true\n }).start();\n\n // Circular animation in loop\n if (rotation.current) {\n timer.setValue(0);\n // $FlowFixMe\n Animated.loop(rotation.current).start();\n }\n }, [scale, fade, timer]);\n const stopRotation = () => {\n if (rotation.current) {\n rotation.current.stop();\n }\n };\n React.useEffect(() => {\n if (rotation.current === undefined) {\n // Circular animation in loop\n rotation.current = Animated.timing(timer, {\n duration: DURATION,\n easing: Easing.linear,\n // Animated.loop does not work if useNativeDriver is true on web\n useNativeDriver: Platform.OS !== 'web',\n toValue: 1,\n isInteraction: false\n });\n }\n if (animating) {\n startRotation();\n } else if (hidesWhenStopped) {\n // Hide indicator first and then stop rotation\n Animated.timing(fade, {\n duration: 200 * scale,\n toValue: 0,\n useNativeDriver: true,\n isInteraction: false\n }).start(stopRotation);\n } else {\n stopRotation();\n }\n }, [animating, fade, hidesWhenStopped, startRotation, scale, timer]);\n const color = indicatorColor || ((_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.primary);\n const size = typeof indicatorSize === 'string' ? indicatorSize === 'small' ? 24 : 48 : indicatorSize ? indicatorSize : 24;\n const frames = 60 * DURATION / 1000;\n const easing = Easing.bezier(0.4, 0.0, 0.7, 1.0);\n const containerStyle = {\n width: size,\n height: size / 2,\n overflow: 'hidden'\n };\n return /*#__PURE__*/React.createElement(View, _extends({\n style: [styles.container, style]\n }, rest, {\n accessible: true,\n accessibilityRole: \"progressbar\",\n accessibilityState: {\n busy: animating\n }\n }), /*#__PURE__*/React.createElement(Animated.View, {\n style: [{\n width: size,\n height: size,\n opacity: fade\n }],\n collapsable: false\n }, [0, 1].map(index => {\n // Thanks to https://github.com/n4kz/react-native-indicators for the great work\n const inputRange = Array.from(new Array(frames), (_, frameIndex) => frameIndex / (frames - 1));\n const outputRange = Array.from(new Array(frames), (_, frameIndex) => {\n let progress = 2 * frameIndex / (frames - 1);\n const rotation = index ? +(360 - 15) : -(180 - 15);\n if (progress > 1.0) {\n progress = 2.0 - progress;\n }\n const direction = index ? -1 : +1;\n return `${direction * (180 - 30) * easing(progress) + rotation}deg`;\n });\n const layerStyle = {\n width: size,\n height: size,\n transform: [{\n rotate: timer.interpolate({\n inputRange: [0, 1],\n outputRange: [`${0 + 30 + 15}deg`, `${2 * 360 + 30 + 15}deg`]\n })\n }]\n };\n const viewportStyle = {\n width: size,\n height: size,\n transform: [{\n translateY: index ? -size / 2 : 0\n }, {\n rotate: timer.interpolate({\n inputRange,\n outputRange\n })\n }]\n };\n const offsetStyle = index ? {\n top: size / 2\n } : null;\n const lineStyle = {\n width: size,\n height: size,\n borderColor: color,\n borderWidth: size / 10,\n borderRadius: size / 2\n };\n return /*#__PURE__*/React.createElement(Animated.View, {\n key: index,\n style: [styles.layer]\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: layerStyle\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: [containerStyle, offsetStyle],\n collapsable: false\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: viewportStyle\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: containerStyle,\n collapsable: false\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: lineStyle\n }))))));\n })));\n};\nconst styles = StyleSheet.create({\n container: {\n justifyContent: 'center',\n alignItems: 'center'\n },\n layer: {\n ...StyleSheet.absoluteFillObject,\n justifyContent: 'center',\n alignItems: 'center'\n }\n});\nexport default ActivityIndicator;\n//# sourceMappingURL=ActivityIndicator.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, StyleSheet, View } from 'react-native';\nimport useLatestCallback from 'use-latest-callback';\nimport Button from './Button/Button';\nimport Icon from './Icon';\nimport Surface from './Surface';\nimport Text from './Typography/Text';\nimport { useInternalTheme } from '../core/theming';\nconst DEFAULT_MAX_WIDTH = 960;\n/**\n * Banner displays a prominent message and related actions.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Image } from 'react-native';\n * import { Banner } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(true);\n *\n * return (\n * setVisible(false),\n * },\n * {\n * label: 'Learn more',\n * onPress: () => setVisible(false),\n * },\n * ]}\n * icon={({size}) => (\n * \n * )}>\n * There was a problem processing a transaction on your credit card.\n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst Banner = _ref => {\n let {\n visible,\n icon,\n children,\n actions = [],\n contentStyle,\n elevation = 1,\n style,\n theme: themeOverrides,\n onShowAnimationFinished = () => {},\n onHideAnimationFinished = () => {},\n maxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n current: position\n } = React.useRef(new Animated.Value(visible ? 1 : 0));\n const [layout, setLayout] = React.useState({\n height: 0,\n measured: false\n });\n const showCallback = useLatestCallback(onShowAnimationFinished);\n const hideCallback = useLatestCallback(onHideAnimationFinished);\n const {\n scale\n } = theme.animation;\n const opacity = position.interpolate({\n inputRange: [0, 0.1, 1],\n outputRange: [0, 1, 1]\n });\n React.useEffect(() => {\n if (visible) {\n // show\n Animated.timing(position, {\n duration: 250 * scale,\n toValue: 1,\n useNativeDriver: false\n }).start(showCallback);\n } else {\n // hide\n Animated.timing(position, {\n duration: 200 * scale,\n toValue: 0,\n useNativeDriver: false\n }).start(hideCallback);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [visible, position, scale]);\n const handleLayout = _ref2 => {\n let {\n nativeEvent\n } = _ref2;\n const {\n height\n } = nativeEvent.layout;\n setLayout({\n height,\n measured: true\n });\n };\n\n // The banner animation has 2 parts:\n // 1. Blank spacer element which animates its height to move the content\n // 2. Actual banner which animates its translateY\n // In initial render, we position everything normally and measure the height of the banner\n // Once we have the height, we apply the height to the spacer and switch the banner to position: absolute\n // We need this because we need to move the content below as if banner's height was being animated\n // However we can't animated banner's height directly as it'll also resize the content inside\n const height = Animated.multiply(position, layout.height);\n const translateY = Animated.multiply(Animated.add(position, -1), layout.height);\n return /*#__PURE__*/React.createElement(Surface, _extends({}, rest, {\n style: [!theme.isV3 && styles.elevation, {\n opacity\n }, style],\n theme: theme\n }, theme.isV3 && {\n elevation\n }), /*#__PURE__*/React.createElement(View, {\n style: [styles.wrapper, contentStyle]\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: {\n height\n }\n }), /*#__PURE__*/React.createElement(Animated.View, {\n onLayout: handleLayout,\n style: [layout.measured || !visible ?\n // If we have measured banner's height or it's invisible,\n // Position it absolutely, the layout will be taken care of the spacer\n [styles.absolute, {\n transform: [{\n translateY\n }]\n }] :\n // Otherwise position it normally\n null, !layout.measured && !visible ?\n // If we haven't measured banner's height yet and it's invisible,\n // hide it with opacity: 0 so user doesn't see it\n styles.transparent : null]\n }, /*#__PURE__*/React.createElement(View, {\n style: styles.content\n }, icon ? /*#__PURE__*/React.createElement(View, {\n style: styles.icon\n }, /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n size: 40\n })) : null, /*#__PURE__*/React.createElement(Text, {\n style: [styles.message, {\n color: theme.isV3 ? theme.colors.onSurface : theme.colors.text\n }],\n accessibilityLiveRegion: visible ? 'polite' : 'none',\n accessibilityRole: \"alert\",\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, children)), /*#__PURE__*/React.createElement(View, {\n style: styles.actions\n }, actions.map((_ref3, i) => {\n var _theme$colors;\n let {\n label,\n ...others\n } = _ref3;\n return /*#__PURE__*/React.createElement(Button, _extends({\n key: /* eslint-disable-line react/no-array-index-key */i,\n compact: true,\n mode: \"text\",\n style: styles.button,\n textColor: (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.primary,\n theme: theme\n }, others), label);\n })))));\n};\nconst styles = StyleSheet.create({\n wrapper: {\n overflow: 'hidden',\n alignSelf: 'center',\n width: '100%',\n maxWidth: DEFAULT_MAX_WIDTH\n },\n absolute: {\n position: 'absolute',\n top: 0,\n width: '100%'\n },\n content: {\n flexDirection: 'row',\n justifyContent: 'flex-start',\n marginHorizontal: 8,\n marginTop: 16,\n marginBottom: 0\n },\n icon: {\n margin: 8\n },\n message: {\n flex: 1,\n margin: 8\n },\n actions: {\n flexDirection: 'row',\n justifyContent: 'flex-end',\n margin: 4\n },\n button: {\n margin: 4\n },\n elevation: {\n elevation: 1\n },\n transparent: {\n opacity: 0\n }\n});\nexport default Banner;\n//# sourceMappingURL=Banner.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Platform, StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { getButtonColors } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { forwardRef } from '../../utils/forwardRef';\nimport hasTouchHandler from '../../utils/hasTouchHandler';\nimport { splitStyles } from '../../utils/splitStyles';\nimport ActivityIndicator from '../ActivityIndicator';\nimport Icon from '../Icon';\nimport Surface from '../Surface';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * A button is component that the user can press to trigger an action.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Button } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Button = (_ref, ref) => {\n var _StyleSheet$flatten;\n let {\n disabled,\n compact,\n mode = 'text',\n dark,\n loading,\n icon,\n buttonColor: customButtonColor,\n textColor: customTextColor,\n rippleColor: customRippleColor,\n children,\n accessibilityLabel,\n accessibilityHint,\n accessibilityRole = 'button',\n onPress,\n onPressIn,\n onPressOut,\n onLongPress,\n delayLongPress,\n style,\n theme: themeOverrides,\n uppercase: uppercaseProp,\n contentStyle,\n labelStyle,\n testID = 'button',\n accessible,\n background,\n maxFontSizeMultiplier,\n touchableRef,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const isMode = React.useCallback(modeToCompare => {\n return mode === modeToCompare;\n }, [mode]);\n const {\n roundness,\n isV3,\n animation\n } = theme;\n const uppercase = uppercaseProp ?? !theme.isV3;\n const hasPassedTouchHandler = hasTouchHandler({\n onPress,\n onPressIn,\n onPressOut,\n onLongPress\n });\n const isElevationEntitled = !disabled && (isV3 ? isMode('elevated') : isMode('contained'));\n const initialElevation = isV3 ? 1 : 2;\n const activeElevation = isV3 ? 2 : 8;\n const {\n current: elevation\n } = React.useRef(new Animated.Value(isElevationEntitled ? initialElevation : 0));\n React.useEffect(() => {\n elevation.setValue(isElevationEntitled ? initialElevation : 0);\n }, [isElevationEntitled, elevation, initialElevation]);\n const handlePressIn = e => {\n onPressIn === null || onPressIn === void 0 ? void 0 : onPressIn(e);\n if (isV3 ? isMode('elevated') : isMode('contained')) {\n const {\n scale\n } = animation;\n Animated.timing(elevation, {\n toValue: activeElevation,\n duration: 200 * scale,\n useNativeDriver: Platform.OS === 'web' || Platform.constants.reactNativeVersion.minor <= 72\n }).start();\n }\n };\n const handlePressOut = e => {\n onPressOut === null || onPressOut === void 0 ? void 0 : onPressOut(e);\n if (isV3 ? isMode('elevated') : isMode('contained')) {\n const {\n scale\n } = animation;\n Animated.timing(elevation, {\n toValue: initialElevation,\n duration: 150 * scale,\n useNativeDriver: Platform.OS === 'web' || Platform.constants.reactNativeVersion.minor <= 72\n }).start();\n }\n };\n const flattenedStyles = StyleSheet.flatten(style) || {};\n const [, borderRadiusStyles] = splitStyles(flattenedStyles, style => style.startsWith('border') && style.endsWith('Radius'));\n const borderRadius = (isV3 ? 5 : 1) * roundness;\n const iconSize = isV3 ? 18 : 16;\n const {\n backgroundColor,\n borderColor,\n textColor,\n borderWidth\n } = getButtonColors({\n customButtonColor,\n customTextColor,\n theme,\n mode,\n disabled,\n dark\n });\n const rippleColor = customRippleColor || color(textColor).alpha(0.12).rgb().string();\n const touchableStyle = {\n ...borderRadiusStyles,\n borderRadius: borderRadiusStyles.borderRadius ?? borderRadius\n };\n const buttonStyle = {\n backgroundColor,\n borderColor,\n borderWidth,\n ...touchableStyle\n };\n const {\n color: customLabelColor,\n fontSize: customLabelSize\n } = StyleSheet.flatten(labelStyle) || {};\n const font = isV3 ? theme.fonts.labelLarge : theme.fonts.medium;\n const textStyle = {\n color: textColor,\n ...font\n };\n const iconStyle = ((_StyleSheet$flatten = StyleSheet.flatten(contentStyle)) === null || _StyleSheet$flatten === void 0 ? void 0 : _StyleSheet$flatten.flexDirection) === 'row-reverse' ? [styles.iconReverse, isV3 && styles[`md3IconReverse${compact ? 'Compact' : ''}`], isV3 && isMode('text') && styles[`md3IconReverseTextMode${compact ? 'Compact' : ''}`]] : [styles.icon, isV3 && styles[`md3Icon${compact ? 'Compact' : ''}`], isV3 && isMode('text') && styles[`md3IconTextMode${compact ? 'Compact' : ''}`]];\n return /*#__PURE__*/React.createElement(Surface, _extends({}, rest, {\n ref: ref,\n testID: `${testID}-container`,\n style: [styles.button, compact && styles.compact, buttonStyle, style, !isV3 && !disabled && {\n elevation\n }]\n }, isV3 && {\n elevation: elevation\n }), /*#__PURE__*/React.createElement(TouchableRipple, {\n borderless: true,\n background: background,\n onPress: onPress,\n onLongPress: onLongPress,\n onPressIn: hasPassedTouchHandler ? handlePressIn : undefined,\n onPressOut: hasPassedTouchHandler ? handlePressOut : undefined,\n delayLongPress: delayLongPress,\n accessibilityLabel: accessibilityLabel,\n accessibilityHint: accessibilityHint,\n accessibilityRole: accessibilityRole,\n accessibilityState: {\n disabled\n },\n accessible: accessible,\n disabled: disabled,\n rippleColor: rippleColor,\n style: touchableStyle,\n testID: testID,\n theme: theme,\n ref: touchableRef\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.content, contentStyle]\n }, icon && loading !== true ? /*#__PURE__*/React.createElement(View, {\n style: iconStyle,\n testID: `${testID}-icon-container`\n }, /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n size: customLabelSize ?? iconSize,\n color: typeof customLabelColor === 'string' ? customLabelColor : textColor\n })) : null, loading ? /*#__PURE__*/React.createElement(ActivityIndicator, {\n size: customLabelSize ?? iconSize,\n color: typeof customLabelColor === 'string' ? customLabelColor : textColor,\n style: iconStyle\n }) : null, /*#__PURE__*/React.createElement(Text, {\n variant: \"labelLarge\",\n selectable: false,\n numberOfLines: 1,\n testID: `${testID}-text`,\n style: [styles.label, !isV3 && styles.md2Label, isV3 && (isMode('text') ? icon || loading ? styles.md3LabelTextAddons : styles.md3LabelText : styles.md3Label), compact && styles.compactLabel, uppercase && styles.uppercaseLabel, textStyle, labelStyle],\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, children))));\n};\nconst styles = StyleSheet.create({\n button: {\n minWidth: 64,\n borderStyle: 'solid'\n },\n compact: {\n minWidth: 'auto'\n },\n content: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center'\n },\n icon: {\n marginLeft: 12,\n marginRight: -4\n },\n iconReverse: {\n marginRight: 12,\n marginLeft: -4\n },\n /* eslint-disable react-native/no-unused-styles */\n md3Icon: {\n marginLeft: 16,\n marginRight: -16\n },\n md3IconCompact: {\n marginLeft: 8,\n marginRight: 0\n },\n md3IconReverse: {\n marginLeft: -16,\n marginRight: 16\n },\n md3IconReverseCompact: {\n marginLeft: 0,\n marginRight: 8\n },\n md3IconTextMode: {\n marginLeft: 12,\n marginRight: -8\n },\n md3IconTextModeCompact: {\n marginLeft: 6,\n marginRight: 0\n },\n md3IconReverseTextMode: {\n marginLeft: -8,\n marginRight: 12\n },\n md3IconReverseTextModeCompact: {\n marginLeft: 0,\n marginRight: 6\n },\n /* eslint-enable react-native/no-unused-styles */\n label: {\n textAlign: 'center',\n marginVertical: 9,\n marginHorizontal: 16\n },\n md2Label: {\n letterSpacing: 1\n },\n compactLabel: {\n marginHorizontal: 8\n },\n uppercaseLabel: {\n textTransform: 'uppercase'\n },\n md3Label: {\n marginVertical: 10,\n marginHorizontal: 24\n },\n md3LabelText: {\n marginHorizontal: 12\n },\n md3LabelTextAddons: {\n marginHorizontal: 16\n }\n});\nexport default forwardRef(Button);\n//# sourceMappingURL=Button.js.map","import { StyleSheet } from 'react-native';\nimport color from 'color';\nimport { black, white } from '../../styles/themes/v2/colors';\nconst isDark = _ref => {\n let {\n dark,\n backgroundColor\n } = _ref;\n if (typeof dark === 'boolean') {\n return dark;\n }\n if (backgroundColor === 'transparent') {\n return false;\n }\n if (backgroundColor !== 'transparent') {\n return !color(backgroundColor).isLight();\n }\n return false;\n};\nconst getButtonBackgroundColor = _ref2 => {\n let {\n isMode,\n theme,\n disabled,\n customButtonColor\n } = _ref2;\n if (customButtonColor && !disabled) {\n return customButtonColor;\n }\n if (theme.isV3) {\n if (disabled) {\n if (isMode('outlined') || isMode('text')) {\n return 'transparent';\n }\n return theme.colors.surfaceDisabled;\n }\n if (isMode('elevated')) {\n return theme.colors.elevation.level1;\n }\n if (isMode('contained')) {\n return theme.colors.primary;\n }\n if (isMode('contained-tonal')) {\n return theme.colors.secondaryContainer;\n }\n }\n if (isMode('contained')) {\n if (disabled) {\n return color(theme.dark ? white : black).alpha(0.12).rgb().string();\n }\n return theme.colors.primary;\n }\n return 'transparent';\n};\nconst getButtonTextColor = _ref3 => {\n let {\n isMode,\n theme,\n disabled,\n customTextColor,\n backgroundColor,\n dark\n } = _ref3;\n if (customTextColor && !disabled) {\n return customTextColor;\n }\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n if (typeof dark === 'boolean') {\n if (isMode('contained') || isMode('contained-tonal') || isMode('elevated')) {\n return isDark({\n dark,\n backgroundColor\n }) ? white : black;\n }\n }\n if (isMode('outlined') || isMode('text') || isMode('elevated')) {\n return theme.colors.primary;\n }\n if (isMode('contained')) {\n return theme.colors.onPrimary;\n }\n if (isMode('contained-tonal')) {\n return theme.colors.onSecondaryContainer;\n }\n }\n if (disabled) {\n return color(theme.dark ? white : black).alpha(0.32).rgb().string();\n }\n if (isMode('contained')) {\n return isDark({\n dark,\n backgroundColor\n }) ? white : black;\n }\n return theme.colors.primary;\n};\nconst getButtonBorderColor = _ref4 => {\n let {\n isMode,\n disabled,\n theme\n } = _ref4;\n if (theme.isV3) {\n if (disabled && isMode('outlined')) {\n return theme.colors.surfaceDisabled;\n }\n if (isMode('outlined')) {\n return theme.colors.outline;\n }\n }\n if (isMode('outlined')) {\n return color(theme.dark ? white : black).alpha(0.29).rgb().string();\n }\n return 'transparent';\n};\nconst getButtonBorderWidth = _ref5 => {\n let {\n isMode,\n theme\n } = _ref5;\n if (theme.isV3) {\n if (isMode('outlined')) {\n return 1;\n }\n }\n if (isMode('outlined')) {\n return StyleSheet.hairlineWidth;\n }\n return 0;\n};\nexport const getButtonColors = _ref6 => {\n let {\n theme,\n mode,\n customButtonColor,\n customTextColor,\n disabled,\n dark\n } = _ref6;\n const isMode = modeToCompare => {\n return mode === modeToCompare;\n };\n const backgroundColor = getButtonBackgroundColor({\n isMode,\n theme,\n disabled,\n customButtonColor\n });\n const textColor = getButtonTextColor({\n isMode,\n theme,\n disabled,\n customTextColor,\n backgroundColor,\n dark\n });\n const borderColor = getButtonBorderColor({\n isMode,\n theme,\n disabled\n });\n const borderWidth = getButtonBorderWidth({\n isMode,\n theme\n });\n return {\n backgroundColor,\n borderColor,\n textColor,\n borderWidth\n };\n};\n//# sourceMappingURL=utils.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Platform, StyleSheet, View } from 'react-native';\nimport useLatestCallback from 'use-latest-callback';\nimport BottomNavigationBar from './BottomNavigationBar';\nimport BottomNavigationRouteScreen from './BottomNavigationRouteScreen';\nimport { useInternalTheme } from '../../core/theming';\nimport useAnimatedValueArray from '../../utils/useAnimatedValueArray';\nconst FAR_FAR_AWAY = Platform.OS === 'web' ? 0 : 9999;\nconst SceneComponent = /*#__PURE__*/React.memo(_ref => {\n let {\n component,\n ...rest\n } = _ref;\n return /*#__PURE__*/React.createElement(component, rest);\n});\n\n/**\n * BottomNavigation provides quick navigation between top-level views of an app with a bottom navigation bar.\n * It is primarily designed for use on mobile. If you want to use the navigation bar only see [`BottomNavigation.Bar`](BottomNavigationBar).\n *\n * By default BottomNavigation uses primary color as a background, in dark theme with `adaptive` mode it will use surface colour instead.\n * See [Dark Theme](https://callstack.github.io/react-native-paper/docs/guides/theming#dark-theme) for more information.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { BottomNavigation, Text } from 'react-native-paper';\n *\n * const MusicRoute = () => Music;\n *\n * const AlbumsRoute = () => Albums;\n *\n * const RecentsRoute = () => Recents;\n *\n * const NotificationsRoute = () => Notifications;\n *\n * const MyComponent = () => {\n * const [index, setIndex] = React.useState(0);\n * const [routes] = React.useState([\n * { key: 'music', title: 'Favorites', focusedIcon: 'heart', unfocusedIcon: 'heart-outline'},\n * { key: 'albums', title: 'Albums', focusedIcon: 'album' },\n * { key: 'recents', title: 'Recents', focusedIcon: 'history' },\n * { key: 'notifications', title: 'Notifications', focusedIcon: 'bell', unfocusedIcon: 'bell-outline' },\n * ]);\n *\n * const renderScene = BottomNavigation.SceneMap({\n * music: MusicRoute,\n * albums: AlbumsRoute,\n * recents: RecentsRoute,\n * notifications: NotificationsRoute,\n * });\n *\n * return (\n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst BottomNavigation = _ref2 => {\n let {\n navigationState,\n renderScene,\n renderIcon,\n renderLabel,\n renderTouchable,\n getLabelText,\n getBadge,\n getColor,\n getAccessibilityLabel,\n getTestID,\n activeColor,\n inactiveColor,\n keyboardHidesNavigationBar = Platform.OS === 'android',\n barStyle,\n labeled = true,\n style,\n activeIndicatorStyle,\n sceneAnimationEnabled = false,\n sceneAnimationType = 'opacity',\n sceneAnimationEasing,\n onTabPress,\n onTabLongPress,\n onIndexChange,\n shifting: shiftingProp,\n safeAreaInsets,\n labelMaxFontSizeMultiplier = 1,\n compact: compactProp,\n testID = 'bottom-navigation',\n theme: themeOverrides,\n getLazy = _ref3 => {\n let {\n route\n } = _ref3;\n return route.lazy;\n }\n } = _ref2;\n const theme = useInternalTheme(themeOverrides);\n const {\n scale\n } = theme.animation;\n const compact = compactProp ?? !theme.isV3;\n let shifting = shiftingProp ?? (theme.isV3 ? false : navigationState.routes.length > 3);\n if (shifting && navigationState.routes.length < 2) {\n shifting = false;\n console.warn('BottomNavigation needs at least 2 tabs to run shifting animation');\n }\n const focusedKey = navigationState.routes[navigationState.index].key;\n\n /**\n * Active state of individual tab item positions:\n * -1 if they're before the active tab, 0 if they're active, 1 if they're after the active tab\n */\n const tabsPositionAnims = useAnimatedValueArray(navigationState.routes.map((_, i) => i === navigationState.index ? 0 : i >= navigationState.index ? 1 : -1));\n\n /**\n * The top offset for each tab item to position it offscreen.\n * Placing items offscreen helps to save memory usage for inactive screens with removeClippedSubviews.\n * We use animated values for this to prevent unnecessary re-renders.\n */\n const offsetsAnims = useAnimatedValueArray(navigationState.routes.map(\n // offscreen === 1, normal === 0\n (_, i) => i === navigationState.index ? 0 : 1));\n\n /**\n * List of loaded tabs, tabs will be loaded when navigated to.\n */\n const [loaded, setLoaded] = React.useState([focusedKey]);\n if (!loaded.includes(focusedKey)) {\n // Set the current tab to be loaded if it was not loaded before\n setLoaded(loaded => [...loaded, focusedKey]);\n }\n const animateToIndex = React.useCallback(index => {\n Animated.parallel([...navigationState.routes.map((_, i) => Animated.timing(tabsPositionAnims[i], {\n toValue: i === index ? 0 : i >= index ? 1 : -1,\n duration: theme.isV3 || shifting ? 150 * scale : 0,\n useNativeDriver: true,\n easing: sceneAnimationEasing\n }))]).start(_ref4 => {\n let {\n finished\n } = _ref4;\n if (finished) {\n // Position all inactive screens offscreen to save memory usage\n // Only do it when animation has finished to avoid glitches mid-transition if switching fast\n offsetsAnims.forEach((offset, i) => {\n if (i === index) {\n offset.setValue(0);\n } else {\n offset.setValue(1);\n }\n });\n }\n });\n }, [shifting, navigationState.routes, offsetsAnims, scale, tabsPositionAnims, sceneAnimationEasing, theme]);\n React.useEffect(() => {\n // Workaround for native animated bug in react-native@^0.57\n // Context: https://github.com/callstack/react-native-paper/pull/637\n animateToIndex(navigationState.index);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n const prevNavigationState = React.useRef();\n React.useEffect(() => {\n // Reset offsets of previous and current tabs before animation\n offsetsAnims.forEach((offset, i) => {\n var _prevNavigationState$;\n if (i === navigationState.index || i === ((_prevNavigationState$ = prevNavigationState.current) === null || _prevNavigationState$ === void 0 ? void 0 : _prevNavigationState$.index)) {\n offset.setValue(0);\n }\n });\n animateToIndex(navigationState.index);\n }, [navigationState.index, animateToIndex, offsetsAnims]);\n const handleTabPress = useLatestCallback(event => {\n onTabPress === null || onTabPress === void 0 ? void 0 : onTabPress(event);\n if (event.defaultPrevented) {\n return;\n }\n const index = navigationState.routes.findIndex(route => event.route.key === route.key);\n if (index !== navigationState.index) {\n prevNavigationState.current = navigationState;\n onIndexChange(index);\n }\n });\n const jumpTo = useLatestCallback(key => {\n const index = navigationState.routes.findIndex(route => route.key === key);\n prevNavigationState.current = navigationState;\n onIndexChange(index);\n });\n const {\n routes\n } = navigationState;\n const {\n colors\n } = theme;\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.container, style],\n testID: testID\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.content, {\n backgroundColor: colors === null || colors === void 0 ? void 0 : colors.background\n }]\n }, routes.map((route, index) => {\n var _prevNavigationState$2;\n if (getLazy({\n route\n }) !== false && !loaded.includes(route.key)) {\n // Don't render a screen if we've never navigated to it\n return null;\n }\n const focused = navigationState.index === index;\n const previouslyFocused = ((_prevNavigationState$2 = prevNavigationState.current) === null || _prevNavigationState$2 === void 0 ? void 0 : _prevNavigationState$2.index) === index;\n const countAlphaOffscreen = sceneAnimationEnabled && (focused || previouslyFocused);\n const renderToHardwareTextureAndroid = sceneAnimationEnabled && focused;\n const opacity = sceneAnimationEnabled ? tabsPositionAnims[index].interpolate({\n inputRange: [-1, 0, 1],\n outputRange: [0, 1, 0]\n }) : focused ? 1 : 0;\n const offsetTarget = focused ? 0 : FAR_FAR_AWAY;\n const top = sceneAnimationEnabled ? offsetsAnims[index].interpolate({\n inputRange: [0, 1],\n outputRange: [0, offsetTarget]\n }) : offsetTarget;\n const left = sceneAnimationType === 'shifting' ? tabsPositionAnims[index].interpolate({\n inputRange: [-1, 0, 1],\n outputRange: [-50, 0, 50]\n }) : 0;\n const zIndex = focused ? 1 : 0;\n return /*#__PURE__*/React.createElement(BottomNavigationRouteScreen, {\n key: route.key,\n pointerEvents: focused ? 'auto' : 'none',\n accessibilityElementsHidden: !focused,\n importantForAccessibility: focused ? 'auto' : 'no-hide-descendants',\n index: index,\n visibility: opacity,\n style: [StyleSheet.absoluteFill, {\n zIndex\n }],\n collapsable: false,\n removeClippedSubviews:\n // On iOS, set removeClippedSubviews to true only when not focused\n // This is an workaround for a bug where the clipped view never re-appears\n Platform.OS === 'ios' ? navigationState.index !== index : true\n }, /*#__PURE__*/React.createElement(Animated.View, _extends({}, Platform.OS === 'android' && {\n needsOffscreenAlphaCompositing: countAlphaOffscreen\n }, {\n renderToHardwareTextureAndroid: renderToHardwareTextureAndroid,\n style: [styles.content, {\n opacity,\n transform: [{\n translateX: left\n }, {\n translateY: top\n }]\n }]\n }), renderScene({\n route,\n jumpTo\n })));\n })), /*#__PURE__*/React.createElement(BottomNavigationBar, {\n navigationState: navigationState,\n renderIcon: renderIcon,\n renderLabel: renderLabel,\n renderTouchable: renderTouchable,\n getLabelText: getLabelText,\n getBadge: getBadge,\n getColor: getColor,\n getAccessibilityLabel: getAccessibilityLabel,\n getTestID: getTestID,\n activeColor: activeColor,\n inactiveColor: inactiveColor,\n keyboardHidesNavigationBar: keyboardHidesNavigationBar,\n style: barStyle,\n activeIndicatorStyle: activeIndicatorStyle,\n labeled: labeled,\n animationEasing: sceneAnimationEasing,\n onTabPress: handleTabPress,\n onTabLongPress: onTabLongPress,\n shifting: shifting,\n safeAreaInsets: safeAreaInsets,\n labelMaxFontSizeMultiplier: labelMaxFontSizeMultiplier,\n compact: compact,\n testID: `${testID}-bar`,\n theme: theme\n }));\n};\n\n/**\n * Function which takes a map of route keys to components.\n * Pure components are used to minimize re-rendering of the pages.\n * This drastically improves the animation performance.\n */\nBottomNavigation.SceneMap = scenes => {\n return _ref5 => {\n let {\n route,\n jumpTo\n } = _ref5;\n return /*#__PURE__*/React.createElement(SceneComponent, {\n key: route.key,\n component: scenes[route.key ? route.key : ''],\n route: route,\n jumpTo: jumpTo\n });\n };\n};\n\n// @component ./BottomNavigationBar.tsx\nBottomNavigation.Bar = BottomNavigationBar;\nexport default BottomNavigation;\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n overflow: 'hidden'\n },\n content: {\n flex: 1\n }\n});\n//# sourceMappingURL=BottomNavigation.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Platform, StyleSheet, Pressable, View } from 'react-native';\nimport color from 'color';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport { getActiveTintColor, getInactiveTintColor, getLabelColor } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport overlay from '../../styles/overlay';\nimport { black, white } from '../../styles/themes/v2/colors';\nimport useAnimatedValue from '../../utils/useAnimatedValue';\nimport useAnimatedValueArray from '../../utils/useAnimatedValueArray';\nimport useIsKeyboardShown from '../../utils/useIsKeyboardShown';\nimport useLayout from '../../utils/useLayout';\nimport Badge from '../Badge';\nimport Icon from '../Icon';\nimport Surface from '../Surface';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\nconst MIN_RIPPLE_SCALE = 0.001; // Minimum scale is not 0 due to bug with animation\nconst MIN_TAB_WIDTH = 96;\nconst MAX_TAB_WIDTH = 168;\nconst BAR_HEIGHT = 56;\nconst OUTLINE_WIDTH = 64;\nconst Touchable = _ref => {\n let {\n route: _0,\n style,\n children,\n borderless,\n centered,\n rippleColor,\n ...rest\n } = _ref;\n return TouchableRipple.supported ? /*#__PURE__*/React.createElement(TouchableRipple, _extends({}, rest, {\n disabled: rest.disabled || undefined,\n borderless: borderless,\n centered: centered,\n rippleColor: rippleColor,\n style: style\n }), children) : /*#__PURE__*/React.createElement(Pressable, _extends({\n style: style\n }, rest), children);\n};\n\n/**\n * A navigation bar which can easily be integrated with [React Navigation's Bottom Tabs Navigator](https://reactnavigation.org/docs/bottom-tab-navigator/).\n *\n * ## Usage\n * ```js\n * import React from 'react';\n * import { View, StyleSheet } from 'react-native';\n *\n * import { CommonActions } from '@react-navigation/native';\n * import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';\n * import { Text, BottomNavigation } from 'react-native-paper';\n * import Icon from 'react-native-vector-icons/MaterialCommunityIcons';\n *\n * const Tab = createBottomTabNavigator();\n *\n * export default function MyComponent() {\n * return (\n * (\n * {\n * const event = navigation.emit({\n * type: 'tabPress',\n * target: route.key,\n * canPreventDefault: true,\n * });\n *\n * if (event.defaultPrevented) {\n * preventDefault();\n * } else {\n * navigation.dispatch({\n * ...CommonActions.navigate(route.name, route.params),\n * target: state.key,\n * });\n * }\n * }}\n * renderIcon={({ route, focused, color }) => {\n * const { options } = descriptors[route.key];\n * if (options.tabBarIcon) {\n * return options.tabBarIcon({ focused, color, size: 24 });\n * }\n *\n * return null;\n * }}\n * getLabelText={({ route }) => {\n * const { options } = descriptors[route.key];\n * const label =\n * options.tabBarLabel !== undefined\n * ? options.tabBarLabel\n * : options.title !== undefined\n * ? options.title\n * : route.title;\n *\n * return label;\n * }}\n * />\n * )}\n * >\n * {\n * return ;\n * },\n * }}\n * />\n * {\n * return ;\n * },\n * }}\n * />\n * \n * );\n * }\n *\n * function HomeScreen() {\n * return (\n * \n * Home!\n * \n * );\n * }\n *\n * function SettingsScreen() {\n * return (\n * \n * Settings!\n * \n * );\n * }\n *\n * const styles = StyleSheet.create({\n * container: {\n * flex: 1,\n * justifyContent: 'center',\n * alignItems: 'center',\n * },\n * });\n * ```\n */\nconst BottomNavigationBar = _ref2 => {\n let {\n navigationState,\n renderIcon,\n renderLabel,\n renderTouchable = props => /*#__PURE__*/React.createElement(Touchable, props),\n getLabelText = _ref3 => {\n let {\n route\n } = _ref3;\n return route.title;\n },\n getBadge = _ref4 => {\n let {\n route\n } = _ref4;\n return route.badge;\n },\n getColor = _ref5 => {\n let {\n route\n } = _ref5;\n return route.color;\n },\n getAccessibilityLabel = _ref6 => {\n let {\n route\n } = _ref6;\n return route.accessibilityLabel;\n },\n getTestID = _ref7 => {\n let {\n route\n } = _ref7;\n return route.testID;\n },\n activeColor,\n inactiveColor,\n keyboardHidesNavigationBar = Platform.OS === 'android',\n style,\n activeIndicatorStyle,\n labeled = true,\n animationEasing,\n onTabPress,\n onTabLongPress,\n shifting: shiftingProp,\n safeAreaInsets,\n labelMaxFontSizeMultiplier = 1,\n compact: compactProp,\n testID = 'bottom-navigation-bar',\n theme: themeOverrides\n } = _ref2;\n const theme = useInternalTheme(themeOverrides);\n const {\n bottom,\n left,\n right\n } = useSafeAreaInsets();\n const {\n scale\n } = theme.animation;\n const compact = compactProp ?? !theme.isV3;\n let shifting = shiftingProp ?? (theme.isV3 ? false : navigationState.routes.length > 3);\n if (shifting && navigationState.routes.length < 2) {\n shifting = false;\n console.warn('BottomNavigation.Bar needs at least 2 tabs to run shifting animation');\n }\n\n /**\n * Visibility of the navigation bar, visible state is 1 and invisible is 0.\n */\n const visibleAnim = useAnimatedValue(1);\n\n /**\n * Active state of individual tab items, active state is 1 and inactive state is 0.\n */\n const tabsAnims = useAnimatedValueArray(navigationState.routes.map(\n // focused === 1, unfocused === 0\n (_, i) => i === navigationState.index ? 1 : 0));\n\n /**\n * Index of the currently active tab. Used for setting the background color.\n * We don't use the color as an animated value directly, because `setValue` seems to be buggy with colors?.\n */\n const indexAnim = useAnimatedValue(navigationState.index);\n\n /**\n * Animation for the background color ripple, used to determine it's scale and opacity.\n */\n const rippleAnim = useAnimatedValue(MIN_RIPPLE_SCALE);\n\n /**\n * Layout of the navigation bar. The width is used to determine the size and position of the ripple.\n */\n const [layout, onLayout] = useLayout();\n\n /**\n * Track whether the keyboard is visible to show and hide the navigation bar.\n */\n const [keyboardVisible, setKeyboardVisible] = React.useState(false);\n const handleKeyboardShow = React.useCallback(() => {\n setKeyboardVisible(true);\n Animated.timing(visibleAnim, {\n toValue: 0,\n duration: 150 * scale,\n useNativeDriver: true\n }).start();\n }, [scale, visibleAnim]);\n const handleKeyboardHide = React.useCallback(() => {\n Animated.timing(visibleAnim, {\n toValue: 1,\n duration: 100 * scale,\n useNativeDriver: true\n }).start(() => {\n setKeyboardVisible(false);\n });\n }, [scale, visibleAnim]);\n const animateToIndex = React.useCallback(index => {\n // Reset the ripple to avoid glitch if it's currently animating\n rippleAnim.setValue(MIN_RIPPLE_SCALE);\n Animated.parallel([Animated.timing(rippleAnim, {\n toValue: 1,\n duration: theme.isV3 || shifting ? 400 * scale : 0,\n useNativeDriver: true\n }), ...navigationState.routes.map((_, i) => Animated.timing(tabsAnims[i], {\n toValue: i === index ? 1 : 0,\n duration: theme.isV3 || shifting ? 150 * scale : 0,\n useNativeDriver: true,\n easing: animationEasing\n }))]).start(() => {\n // Workaround a bug in native animations where this is reset after first animation\n tabsAnims.map((tab, i) => tab.setValue(i === index ? 1 : 0));\n\n // Update the index to change bar's background color and then hide the ripple\n indexAnim.setValue(index);\n rippleAnim.setValue(MIN_RIPPLE_SCALE);\n });\n }, [rippleAnim, theme.isV3, shifting, scale, navigationState.routes, tabsAnims, animationEasing, indexAnim]);\n React.useEffect(() => {\n // Workaround for native animated bug in react-native@^0.57\n // Context: https://github.com/callstack/react-native-paper/pull/637\n animateToIndex(navigationState.index);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n useIsKeyboardShown({\n onShow: handleKeyboardShow,\n onHide: handleKeyboardHide\n });\n React.useEffect(() => {\n animateToIndex(navigationState.index);\n }, [navigationState.index, animateToIndex]);\n const eventForIndex = index => {\n const event = {\n route: navigationState.routes[index],\n defaultPrevented: false,\n preventDefault: () => {\n event.defaultPrevented = true;\n }\n };\n return event;\n };\n const {\n routes\n } = navigationState;\n const {\n colors,\n dark: isDarkTheme,\n mode,\n isV3\n } = theme;\n const {\n backgroundColor: customBackground,\n elevation = 4\n } = StyleSheet.flatten(style) || {};\n const approxBackgroundColor = customBackground ? customBackground : isDarkTheme && mode === 'adaptive' ? overlay(elevation, colors === null || colors === void 0 ? void 0 : colors.surface) : colors === null || colors === void 0 ? void 0 : colors.primary;\n const v2BackgroundColorInterpolation = shifting ? indexAnim.interpolate({\n inputRange: routes.map((_, i) => i),\n // FIXME: does outputRange support ColorValue or just strings?\n // @ts-expect-error\n outputRange: routes.map(route => getColor({\n route\n }) || approxBackgroundColor)\n }) : approxBackgroundColor;\n const backgroundColor = isV3 ? customBackground || theme.colors.elevation.level2 : shifting ? v2BackgroundColorInterpolation : approxBackgroundColor;\n const isDark = typeof approxBackgroundColor === 'string' ? !color(approxBackgroundColor).isLight() : true;\n const textColor = isDark ? white : black;\n const activeTintColor = getActiveTintColor({\n activeColor,\n defaultColor: textColor,\n theme\n });\n const inactiveTintColor = getInactiveTintColor({\n inactiveColor,\n defaultColor: textColor,\n theme\n });\n const touchColor = color(activeTintColor).alpha(0.12).rgb().string();\n const maxTabWidth = routes.length > 3 ? MIN_TAB_WIDTH : MAX_TAB_WIDTH;\n const maxTabBarWidth = maxTabWidth * routes.length;\n const rippleSize = layout.width / 4;\n const insets = {\n left: (safeAreaInsets === null || safeAreaInsets === void 0 ? void 0 : safeAreaInsets.left) ?? left,\n right: (safeAreaInsets === null || safeAreaInsets === void 0 ? void 0 : safeAreaInsets.right) ?? right,\n bottom: (safeAreaInsets === null || safeAreaInsets === void 0 ? void 0 : safeAreaInsets.bottom) ?? bottom\n };\n return /*#__PURE__*/React.createElement(Surface, _extends({}, theme.isV3 && {\n elevation: 0\n }, {\n testID: testID,\n style: [!theme.isV3 && styles.elevation, styles.bar, keyboardHidesNavigationBar // eslint-disable-next-line react-native/no-inline-styles\n ? {\n // When the keyboard is shown, slide down the navigation bar\n transform: [{\n translateY: visibleAnim.interpolate({\n inputRange: [0, 1],\n outputRange: [layout.height, 0]\n })\n }],\n // Absolutely position the navigation bar so that the content is below it\n // This is needed to avoid gap at bottom when the navigation bar is hidden\n position: keyboardVisible ? 'absolute' : undefined\n } : null, style],\n pointerEvents: layout.measured ? keyboardHidesNavigationBar && keyboardVisible ? 'none' : 'auto' : 'none',\n onLayout: onLayout\n }), /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.barContent, {\n backgroundColor\n }],\n testID: `${testID}-content`\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.items, {\n marginBottom: insets.bottom,\n marginHorizontal: Math.max(insets.left, insets.right)\n }, compact && {\n maxWidth: maxTabBarWidth\n }],\n accessibilityRole: 'tablist',\n testID: `${testID}-content-wrapper`\n }, shifting && !isV3 ? /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: \"none\",\n style: [styles.ripple, {\n // Since we have a single ripple, we have to reposition it so that it appears to expand from active tab.\n // We need to move it from the top to center of the navigation bar and from the left to the active tab.\n top: (BAR_HEIGHT - rippleSize) / 2,\n left: Math.min(layout.width, maxTabBarWidth) / routes.length * (navigationState.index + 0.5) - rippleSize / 2,\n height: rippleSize,\n width: rippleSize,\n borderRadius: rippleSize / 2,\n backgroundColor: getColor({\n route: routes[navigationState.index]\n }),\n transform: [{\n // Scale to twice the size to ensure it covers the whole navigation bar\n scale: rippleAnim.interpolate({\n inputRange: [0, 1],\n outputRange: [0, 8]\n })\n }],\n opacity: rippleAnim.interpolate({\n inputRange: [0, MIN_RIPPLE_SCALE, 0.3, 1],\n outputRange: [0, 0, 1, 1]\n })\n }],\n testID: `${testID}-content-ripple`\n }) : null, routes.map((route, index) => {\n const focused = navigationState.index === index;\n const active = tabsAnims[index];\n\n // Scale the label up\n const scale = labeled && shifting ? active.interpolate({\n inputRange: [0, 1],\n outputRange: [0.5, 1]\n }) : 1;\n\n // Move down the icon to account for no-label in shifting and smaller label in non-shifting.\n const translateY = labeled ? shifting ? active.interpolate({\n inputRange: [0, 1],\n outputRange: [7, 0]\n }) : 0 : 7;\n\n // We render the active icon and label on top of inactive ones and cross-fade them on change.\n // This trick gives the illusion that we are animating between active and inactive colors.\n // This is to ensure that we can use native driver, as colors cannot be animated with native driver.\n const activeOpacity = active;\n const inactiveOpacity = active.interpolate({\n inputRange: [0, 1],\n outputRange: [1, 0]\n });\n const v3ActiveOpacity = focused ? 1 : 0;\n const v3InactiveOpacity = shifting ? inactiveOpacity : focused ? 0 : 1;\n\n // Scale horizontally the outline pill\n const outlineScale = focused ? active.interpolate({\n inputRange: [0, 1],\n outputRange: [0.5, 1]\n }) : 0;\n const badge = getBadge({\n route\n });\n const activeLabelColor = getLabelColor({\n tintColor: activeTintColor,\n hasColor: Boolean(activeColor),\n focused,\n defaultColor: textColor,\n theme\n });\n const inactiveLabelColor = getLabelColor({\n tintColor: inactiveTintColor,\n hasColor: Boolean(inactiveColor),\n focused,\n defaultColor: textColor,\n theme\n });\n const badgeStyle = {\n top: !isV3 ? -2 : typeof badge === 'boolean' ? 4 : 2,\n right: (badge != null && typeof badge !== 'boolean' ? String(badge).length * -2 : 0) - (!isV3 ? 2 : 0)\n };\n const isV3Shifting = isV3 && shifting && labeled;\n const font = isV3 ? theme.fonts.labelMedium : {};\n return renderTouchable({\n key: route.key,\n route,\n borderless: true,\n centered: true,\n rippleColor: isV3 ? 'transparent' : touchColor,\n onPress: () => onTabPress(eventForIndex(index)),\n onLongPress: () => onTabLongPress === null || onTabLongPress === void 0 ? void 0 : onTabLongPress(eventForIndex(index)),\n testID: getTestID({\n route\n }),\n accessibilityLabel: getAccessibilityLabel({\n route\n }),\n accessibilityRole: Platform.OS === 'ios' ? 'button' : 'tab',\n accessibilityState: {\n selected: focused\n },\n style: [styles.item, isV3 && styles.v3Item],\n children: /*#__PURE__*/React.createElement(View, {\n pointerEvents: \"none\",\n style: isV3 && (labeled ? styles.v3TouchableContainer : styles.v3NoLabelContainer)\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.iconContainer, isV3 && styles.v3IconContainer, (!isV3 || isV3Shifting) && {\n transform: [{\n translateY\n }]\n }]\n }, isV3 && focused && /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.outline, {\n transform: [{\n scaleX: outlineScale\n }],\n backgroundColor: theme.colors.secondaryContainer\n }, activeIndicatorStyle]\n }), /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.iconWrapper, isV3 && styles.v3IconWrapper, {\n opacity: isV3 ? v3ActiveOpacity : activeOpacity\n }]\n }, renderIcon ? renderIcon({\n route,\n focused: true,\n color: activeTintColor\n }) : /*#__PURE__*/React.createElement(Icon, {\n source: route.focusedIcon,\n color: activeTintColor,\n size: 24\n })), /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.iconWrapper, isV3 && styles.v3IconWrapper, {\n opacity: isV3 ? v3InactiveOpacity : inactiveOpacity\n }]\n }, renderIcon ? renderIcon({\n route,\n focused: false,\n color: inactiveTintColor\n }) : /*#__PURE__*/React.createElement(Icon, {\n source: theme.isV3 && route.unfocusedIcon !== undefined ? route.unfocusedIcon : route.focusedIcon,\n color: inactiveTintColor,\n size: 24\n })), /*#__PURE__*/React.createElement(View, {\n style: [styles.badgeContainer, badgeStyle]\n }, typeof badge === 'boolean' ? /*#__PURE__*/React.createElement(Badge, {\n visible: badge,\n size: isV3 ? 6 : 8\n }) : /*#__PURE__*/React.createElement(Badge, {\n visible: badge != null,\n size: 16\n }, badge))), labeled ? /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.labelContainer, !isV3 && {\n transform: [{\n scale\n }]\n }]\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.labelWrapper, (!isV3 || isV3Shifting) && {\n opacity: activeOpacity\n }]\n }, renderLabel ? renderLabel({\n route,\n focused: true,\n color: activeLabelColor\n }) : /*#__PURE__*/React.createElement(Text, {\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier,\n variant: \"labelMedium\",\n style: [styles.label, {\n color: activeLabelColor,\n ...font\n }]\n }, getLabelText({\n route\n }))), shifting ? null : /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.labelWrapper, {\n opacity: inactiveOpacity\n }]\n }, renderLabel ? renderLabel({\n route,\n focused: false,\n color: inactiveLabelColor\n }) : /*#__PURE__*/React.createElement(Text, {\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier,\n variant: \"labelMedium\",\n selectable: false,\n style: [styles.label, {\n color: inactiveLabelColor,\n ...font\n }]\n }, getLabelText({\n route\n })))) : !isV3 && /*#__PURE__*/React.createElement(View, {\n style: styles.labelContainer\n }))\n });\n }))));\n};\nBottomNavigationBar.displayName = 'BottomNavigation.Bar';\nexport default BottomNavigationBar;\nconst styles = StyleSheet.create({\n bar: {\n left: 0,\n right: 0,\n bottom: 0\n },\n barContent: {\n alignItems: 'center',\n overflow: 'hidden'\n },\n items: {\n flexDirection: 'row',\n ...(Platform.OS === 'web' ? {\n width: '100%'\n } : null)\n },\n item: {\n flex: 1,\n // Top padding is 6 and bottom padding is 10\n // The extra 4dp bottom padding is offset by label's height\n paddingVertical: 6\n },\n v3Item: {\n paddingVertical: 0\n },\n ripple: {\n position: 'absolute'\n },\n iconContainer: {\n height: 24,\n width: 24,\n marginTop: 2,\n marginHorizontal: 12,\n alignSelf: 'center'\n },\n v3IconContainer: {\n height: 32,\n width: 32,\n marginBottom: 4,\n marginTop: 0,\n justifyContent: 'center'\n },\n iconWrapper: {\n ...StyleSheet.absoluteFillObject,\n alignItems: 'center'\n },\n v3IconWrapper: {\n top: 4\n },\n labelContainer: {\n height: 16,\n paddingBottom: 2\n },\n labelWrapper: {\n ...StyleSheet.absoluteFillObject\n },\n // eslint-disable-next-line react-native/no-color-literals\n label: {\n fontSize: 12,\n height: BAR_HEIGHT,\n textAlign: 'center',\n backgroundColor: 'transparent',\n ...(Platform.OS === 'web' ? {\n whiteSpace: 'nowrap',\n alignSelf: 'center'\n } : null)\n },\n badgeContainer: {\n position: 'absolute',\n left: 0\n },\n v3TouchableContainer: {\n paddingTop: 12,\n paddingBottom: 16\n },\n v3NoLabelContainer: {\n height: 80,\n justifyContent: 'center',\n alignItems: 'center'\n },\n outline: {\n width: OUTLINE_WIDTH,\n height: OUTLINE_WIDTH / 2,\n borderRadius: OUTLINE_WIDTH / 4,\n alignSelf: 'center'\n },\n elevation: {\n elevation: 4\n }\n});\n//# sourceMappingURL=BottomNavigationBar.js.map","import color from 'color';\nexport const getActiveTintColor = _ref => {\n let {\n activeColor,\n defaultColor,\n theme\n } = _ref;\n if (typeof activeColor === 'string') {\n return activeColor;\n }\n if (theme.isV3) {\n return theme.colors.onSecondaryContainer;\n }\n return defaultColor;\n};\nexport const getInactiveTintColor = _ref2 => {\n let {\n inactiveColor,\n defaultColor,\n theme\n } = _ref2;\n if (typeof inactiveColor === 'string') {\n return inactiveColor;\n }\n if (theme.isV3) {\n return theme.colors.onSurfaceVariant;\n }\n return color(defaultColor).alpha(0.5).rgb().string();\n};\nexport const getLabelColor = _ref3 => {\n let {\n tintColor,\n hasColor,\n focused,\n defaultColor,\n theme\n } = _ref3;\n if (hasColor) {\n return tintColor;\n }\n if (theme.isV3) {\n if (focused) {\n return theme.colors.onSurface;\n }\n return theme.colors.onSurfaceVariant;\n }\n return defaultColor;\n};\n//# sourceMappingURL=utils.js.map","import { Animated } from 'react-native';\nimport useLazyRef from './useLazyRef';\nexport default function useAnimatedValue(initialValue) {\n const {\n current\n } = useLazyRef(() => new Animated.Value(initialValue));\n return current;\n}\n//# sourceMappingURL=useAnimatedValue.js.map","import * as React from 'react';\nexport default function useLazyRef(callback) {\n const lazyRef = React.useRef();\n if (lazyRef.current === undefined) {\n lazyRef.current = callback();\n }\n return lazyRef;\n}\n//# sourceMappingURL=useLazyRef.js.map","import * as React from 'react';\nimport { Animated } from 'react-native';\nexport default function useAnimatedValueArray(initialValues) {\n const refs = React.useRef([]);\n refs.current.length = initialValues.length;\n initialValues.forEach((initialValue, i) => {\n refs.current[i] = refs.current[i] ?? new Animated.Value(initialValue);\n });\n return refs.current;\n}\n//# sourceMappingURL=useAnimatedValueArray.js.map","import * as React from 'react';\nimport { Keyboard, Platform } from 'react-native';\nexport default function useIsKeyboardShown(_ref) {\n let {\n onShow,\n onHide\n } = _ref;\n React.useEffect(() => {\n let willShowSubscription;\n let willHideSubscription;\n let didShowSubscription;\n let didHideSubscription;\n if (Platform.OS === 'ios') {\n willShowSubscription = Keyboard.addListener('keyboardWillShow', onShow);\n willHideSubscription = Keyboard.addListener('keyboardWillHide', onHide);\n } else {\n didShowSubscription = Keyboard.addListener('keyboardDidShow', onShow);\n didHideSubscription = Keyboard.addListener('keyboardDidHide', onHide);\n }\n return () => {\n if (Platform.OS === 'ios') {\n var _willShowSubscription, _willHideSubscription;\n if ((_willShowSubscription = willShowSubscription) !== null && _willShowSubscription !== void 0 && _willShowSubscription.remove) {\n willShowSubscription.remove();\n } else {\n // @ts-expect-error: We keep deprecated listener remove method for backwards compat with old RN versions\n Keyboard.removeListener('keyboardWillShow', onShow);\n }\n if ((_willHideSubscription = willHideSubscription) !== null && _willHideSubscription !== void 0 && _willHideSubscription.remove) {\n willHideSubscription.remove();\n } else {\n // @ts-expect-error: We keep deprecated listener remove method for backwards compat with old RN versions\n Keyboard.removeListener('keyboardWillHide', onHide);\n }\n } else {\n var _didShowSubscription, _didHideSubscription;\n if ((_didShowSubscription = didShowSubscription) !== null && _didShowSubscription !== void 0 && _didShowSubscription.remove) {\n didShowSubscription.remove();\n } else {\n // @ts-expect-error: We keep deprecated listener remove method for backwards compat with old RN versions\n Keyboard.removeListener('keyboardDidShow', onShow);\n }\n if ((_didHideSubscription = didHideSubscription) !== null && _didHideSubscription !== void 0 && _didHideSubscription.remove) {\n didHideSubscription.remove();\n } else {\n // @ts-expect-error: We keep deprecated listener remove method for backwards compat with old RN versions\n Keyboard.removeListener('keyboardDidHide', onHide);\n }\n }\n };\n }, [onHide, onShow]);\n}\n//# sourceMappingURL=useIsKeyboardShown.js.map","import * as React from 'react';\nexport default function useLayout() {\n const [layout, setLayout] = React.useState({\n height: 0,\n width: 0,\n measured: false\n });\n const onLayout = React.useCallback(e => {\n const {\n height,\n width\n } = e.nativeEvent.layout;\n if (height === layout.height && width === layout.width) {\n return;\n }\n setLayout({\n height,\n width,\n measured: true\n });\n }, [layout.height, layout.width]);\n return [layout, onLayout];\n}\n//# sourceMappingURL=useLayout.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport React from 'react';\nimport { Animated, Platform, View } from 'react-native';\nclass BottomNavigationRouteScreen extends React.Component {\n render() {\n const {\n style,\n index,\n children,\n visibility,\n ...rest\n } = this.props;\n\n // On Web, the unfocused tab screens can still be clicked since they are transparent, but still there\n // Hiding them with `display: none` makes sure that they won't receive clicks\n // We only set it on Web since on native, react-native-pager-view's breaks due to layout changing\n const display = Platform.OS === 'web' ? visibility === 0 ? 'none' : 'flex' : undefined;\n return /*#__PURE__*/React.createElement(View, _extends({\n testID: `RouteScreen: ${index}`,\n style: [style, {\n display\n }]\n }, rest), children);\n }\n}\nexport default Animated.createAnimatedComponent(BottomNavigationRouteScreen);\n//# sourceMappingURL=BottomNavigationRouteScreen.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, StyleSheet, Pressable, View } from 'react-native';\nimport useLatestCallback from 'use-latest-callback';\nimport CardActions from './CardActions';\nimport CardContent from './CardContent';\nimport CardCover from './CardCover';\nimport CardTitle from './CardTitle';\nimport { getCardColors } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { forwardRef } from '../../utils/forwardRef';\nimport hasTouchHandler from '../../utils/hasTouchHandler';\nimport { splitStyles } from '../../utils/splitStyles';\nimport Surface from '../Surface';\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\n/**\n * A card is a sheet of material that serves as an entry point to more detailed information.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Avatar, Button, Card, Text } from 'react-native-paper';\n *\n * const LeftContent = props => \n *\n * const MyComponent = () => (\n * \n * \n * \n * Card title\n * Card content\n * \n * \n * \n * \n * \n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst CardComponent = (_ref, ref) => {\n let {\n elevation: cardElevation = 1,\n delayLongPress,\n onPress,\n onLongPress,\n onPressOut,\n onPressIn,\n mode: cardMode = 'elevated',\n children,\n style,\n contentStyle,\n theme: themeOverrides,\n testID = 'card',\n accessible,\n disabled,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const isMode = React.useCallback(modeToCompare => {\n return cardMode === modeToCompare;\n }, [cardMode]);\n const hasPassedTouchHandler = hasTouchHandler({\n onPress,\n onLongPress,\n onPressIn,\n onPressOut\n });\n\n // Default animated value\n const {\n current: elevation\n } = React.useRef(new Animated.Value(cardElevation));\n // Dark adaptive animated value, used in case of toggling the theme,\n // it prevents animating the background with native drivers inside Surface\n const {\n current: elevationDarkAdaptive\n } = React.useRef(new Animated.Value(cardElevation));\n const {\n animation,\n dark,\n mode,\n roundness,\n isV3\n } = theme;\n const prevDarkRef = React.useRef(dark);\n React.useEffect(() => {\n prevDarkRef.current = dark;\n });\n const prevDark = prevDarkRef.current;\n const isAdaptiveMode = mode === 'adaptive';\n const animationDuration = 150 * animation.scale;\n React.useEffect(() => {\n /**\n * Resets animations values if updating to dark adaptive mode,\n * otherwise, any card that is in the middle of animation while\n * toggling the theme will stay at that animated value until\n * the next press-in\n */\n if (dark && isAdaptiveMode && !prevDark) {\n elevation.setValue(cardElevation);\n elevationDarkAdaptive.setValue(cardElevation);\n }\n }, [prevDark, dark, isAdaptiveMode, cardElevation, elevation, elevationDarkAdaptive]);\n const runElevationAnimation = pressType => {\n const isPressTypeIn = pressType === 'in';\n if (dark && isAdaptiveMode) {\n Animated.timing(elevationDarkAdaptive, {\n toValue: isPressTypeIn ? isV3 ? 2 : 8 : cardElevation,\n duration: animationDuration,\n useNativeDriver: false\n }).start();\n } else {\n Animated.timing(elevation, {\n toValue: isPressTypeIn ? isV3 ? 2 : 8 : cardElevation,\n duration: animationDuration,\n useNativeDriver: false\n }).start();\n }\n };\n const handlePressIn = useLatestCallback(e => {\n onPressIn === null || onPressIn === void 0 ? void 0 : onPressIn(e);\n runElevationAnimation('in');\n });\n const handlePressOut = useLatestCallback(e => {\n onPressOut === null || onPressOut === void 0 ? void 0 : onPressOut(e);\n runElevationAnimation('out');\n });\n const total = React.Children.count(children);\n const siblings = React.Children.map(children, child => /*#__PURE__*/React.isValidElement(child) && child.type ? child.type.displayName : null);\n const computedElevation = dark && isAdaptiveMode ? elevationDarkAdaptive : elevation;\n const {\n backgroundColor,\n borderColor: themedBorderColor\n } = getCardColors({\n theme,\n mode: cardMode\n });\n const flattenedStyles = StyleSheet.flatten(style) || {};\n const {\n borderColor = themedBorderColor\n } = flattenedStyles;\n const [, borderRadiusStyles] = splitStyles(flattenedStyles, style => style.startsWith('border') && style.endsWith('Radius'));\n const borderRadiusCombinedStyles = {\n borderRadius: (isV3 ? 3 : 1) * roundness,\n ...borderRadiusStyles\n };\n const content = /*#__PURE__*/React.createElement(View, {\n style: [styles.innerContainer, contentStyle],\n testID: testID\n }, React.Children.map(children, (child, index) => /*#__PURE__*/React.isValidElement(child) ? /*#__PURE__*/React.cloneElement(child, {\n index,\n total,\n siblings,\n borderRadiusStyles\n }) : child));\n return /*#__PURE__*/React.createElement(Surface, _extends({\n ref: ref,\n style: [isV3 && !isMode('elevated') && {\n backgroundColor\n }, !isV3 && isMode('outlined') ? styles.resetElevation : {\n elevation: computedElevation\n }, borderRadiusCombinedStyles, style],\n theme: theme\n }, isV3 && {\n elevation: isMode('elevated') ? computedElevation : 0\n }, {\n testID: `${testID}-container`\n }, rest), isMode('outlined') && /*#__PURE__*/React.createElement(View, {\n pointerEvents: \"none\",\n testID: `${testID}-outline`,\n style: [{\n borderColor\n }, styles.outline, borderRadiusCombinedStyles]\n }), hasPassedTouchHandler ? /*#__PURE__*/React.createElement(Pressable, {\n accessible: accessible,\n unstable_pressDelay: 0,\n disabled: disabled,\n delayLongPress: delayLongPress,\n onLongPress: onLongPress,\n onPress: onPress,\n onPressIn: handlePressIn,\n onPressOut: handlePressOut\n }, content) : content);\n};\nconst Component = forwardRef(CardComponent);\nComponent.displayName = 'Card';\nconst Card = Component;\n\n// @component ./CardContent.tsx\nCard.Content = CardContent;\n// @component ./CardActions.tsx\nCard.Actions = CardActions;\n// @component ./CardCover.tsx\nCard.Cover = CardCover;\n// @component ./CardTitle.tsx\nCard.Title = CardTitle;\nconst styles = StyleSheet.create({\n innerContainer: {\n flexShrink: 1\n },\n outline: {\n borderWidth: 1,\n position: 'absolute',\n width: '100%',\n height: '100%',\n zIndex: 2\n },\n resetElevation: {\n elevation: 0\n }\n});\nexport default Card;\n//# sourceMappingURL=Card.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * A component to show a list of actions inside a Card.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Card, Button } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * \n * \n * \n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst CardActions = props => {\n const {\n isV3\n } = useInternalTheme(props.theme);\n const justifyContent = isV3 ? 'flex-end' : 'flex-start';\n return /*#__PURE__*/React.createElement(View, _extends({}, props, {\n style: [styles.container, props.style, {\n justifyContent\n }]\n }), React.Children.map(props.children, (child, i) => {\n return /*#__PURE__*/React.isValidElement(child) ? /*#__PURE__*/React.cloneElement(child, {\n compact: !isV3 && child.props.compact !== false,\n mode: child.props.mode || isV3 && (i === 0 ? 'outlined' : 'contained'),\n style: [isV3 && styles.button, child.props.style]\n }) : child;\n }));\n};\nCardActions.displayName = 'Card.Actions';\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 8\n },\n button: {\n marginLeft: 8\n }\n});\nexport default CardActions;\n//# sourceMappingURL=CardActions.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\n/**\n * A component to show content inside a Card.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Card, Text } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * \n * Card title\n * Card content\n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst CardContent = _ref => {\n let {\n index,\n total,\n siblings,\n style,\n ...rest\n } = _ref;\n const cover = 'withInternalTheme(CardCover)';\n const title = 'withInternalTheme(CardTitle)';\n let contentStyle, prev, next;\n if (typeof index === 'number' && siblings) {\n prev = siblings[index - 1];\n next = siblings[index + 1];\n }\n if (prev === cover && next === cover || prev === title && next === title || total === 1) {\n contentStyle = styles.only;\n } else if (index === 0) {\n if (next === cover || next === title) {\n contentStyle = styles.only;\n } else {\n contentStyle = styles.first;\n }\n } else if (typeof total === 'number' && index === total - 1) {\n if (prev === cover || prev === title) {\n contentStyle = styles.only;\n } else {\n contentStyle = styles.last;\n }\n } else if (prev === cover || prev === title) {\n contentStyle = styles.first;\n } else if (next === cover || next === title) {\n contentStyle = styles.last;\n }\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, {\n style: [styles.container, contentStyle, style]\n }));\n};\nCardContent.displayName = 'Card.Content';\nconst styles = StyleSheet.create({\n container: {\n paddingHorizontal: 16\n },\n first: {\n paddingTop: 16\n },\n last: {\n paddingBottom: 16\n },\n only: {\n paddingVertical: 16\n }\n});\nexport default CardContent;\n//# sourceMappingURL=CardContent.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Image, StyleSheet, View } from 'react-native';\nimport { getCardCoverStyle } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { grey200 } from '../../styles/themes/v2/colors';\nimport { splitStyles } from '../../utils/splitStyles';\n/**\n * A component to show a cover image inside a Card.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Card } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n *\n * @extends Image props https://reactnative.dev/docs/image#props\n */\nconst CardCover = _ref => {\n let {\n index,\n total,\n style,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const flattenedStyles = StyleSheet.flatten(style) || {};\n const [, borderRadiusStyles] = splitStyles(flattenedStyles, style => style.startsWith('border') && style.endsWith('Radius'));\n const coverStyle = getCardCoverStyle({\n theme,\n index,\n total,\n borderRadiusStyles\n });\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.container, coverStyle, style]\n }, /*#__PURE__*/React.createElement(Image, _extends({}, rest, {\n style: [styles.image, coverStyle],\n accessibilityIgnoresInvertColors: true\n })));\n};\nCardCover.displayName = 'Card.Cover';\nconst styles = StyleSheet.create({\n container: {\n height: 195,\n backgroundColor: grey200,\n overflow: 'hidden'\n },\n image: {\n flex: 1,\n height: undefined,\n width: undefined,\n padding: 16,\n justifyContent: 'flex-end'\n }\n});\nexport default CardCover;\n\n// @component-docs ignore-next-line\nexport { CardCover };\n//# sourceMappingURL=CardCover.js.map","import color from 'color';\nimport { black, white } from '../../styles/themes/v2/colors';\nexport const getCardCoverStyle = _ref => {\n let {\n theme,\n index,\n total,\n borderRadiusStyles\n } = _ref;\n const {\n isV3,\n roundness\n } = theme;\n if (Object.keys(borderRadiusStyles).length > 0) {\n return {\n borderRadius: 3 * roundness,\n ...borderRadiusStyles\n };\n }\n if (isV3) {\n return {\n borderRadius: 3 * roundness\n };\n }\n if (index === 0) {\n if (total === 1) {\n return {\n borderRadius: roundness\n };\n }\n return {\n borderTopLeftRadius: roundness,\n borderTopRightRadius: roundness\n };\n }\n if (typeof total === 'number' && index === total - 1) {\n return {\n borderBottomLeftRadius: roundness\n };\n }\n return undefined;\n};\nconst getBorderColor = _ref2 => {\n let {\n theme\n } = _ref2;\n if (theme.isV3) {\n return theme.colors.outline;\n }\n if (theme.dark) {\n return color(white).alpha(0.12).rgb().string();\n }\n return color(black).alpha(0.12).rgb().string();\n};\nconst getBackgroundColor = _ref3 => {\n let {\n theme,\n isMode\n } = _ref3;\n if (theme.isV3) {\n if (isMode('contained')) {\n return theme.colors.surfaceVariant;\n }\n if (isMode('outlined')) {\n return theme.colors.surface;\n }\n }\n return undefined;\n};\nexport const getCardColors = _ref4 => {\n let {\n theme,\n mode\n } = _ref4;\n const isMode = modeToCompare => {\n return mode === modeToCompare;\n };\n return {\n backgroundColor: getBackgroundColor({\n theme,\n isMode\n }),\n borderColor: getBorderColor({\n theme\n })\n };\n};\n//# sourceMappingURL=utils.js.map","import * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\nimport Text from '../Typography/Text';\nimport Caption from '../Typography/v2/Caption';\nimport Title from '../Typography/v2/Title';\nconst LEFT_SIZE = 40;\n\n/**\n * A component to show a title, subtitle and an avatar inside a Card.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Avatar, Card, IconButton } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * }\n * right={(props) => {}} />}\n * />\n * );\n *\n * export default MyComponent;\n * ```\n */\nconst CardTitle = _ref => {\n let {\n title,\n titleStyle,\n titleNumberOfLines = 1,\n titleVariant = 'bodyLarge',\n titleMaxFontSizeMultiplier,\n subtitle,\n subtitleStyle,\n subtitleNumberOfLines = 1,\n subtitleVariant = 'bodyMedium',\n subtitleMaxFontSizeMultiplier,\n left,\n leftStyle,\n right,\n rightStyle,\n style,\n theme: themeOverrides\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const TitleComponent = theme.isV3 ? Text : Title;\n const SubtitleComponent = theme.isV3 ? Text : Caption;\n const minHeight = subtitle || left || right ? 72 : 50;\n const marginBottom = subtitle ? 0 : 2;\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.container, {\n minHeight\n }, style]\n }, left ? /*#__PURE__*/React.createElement(View, {\n style: [styles.left, leftStyle]\n }, left({\n size: LEFT_SIZE\n })) : null, /*#__PURE__*/React.createElement(View, {\n style: [styles.titles]\n }, title && /*#__PURE__*/React.createElement(TitleComponent, {\n style: [styles.title, {\n marginBottom\n }, titleStyle],\n numberOfLines: titleNumberOfLines,\n variant: titleVariant,\n maxFontSizeMultiplier: titleMaxFontSizeMultiplier\n }, title), subtitle && /*#__PURE__*/React.createElement(SubtitleComponent, {\n style: [styles.subtitle, subtitleStyle],\n numberOfLines: subtitleNumberOfLines,\n variant: subtitleVariant,\n maxFontSizeMultiplier: subtitleMaxFontSizeMultiplier\n }, subtitle)), /*#__PURE__*/React.createElement(View, {\n style: rightStyle\n }, right ? right({\n size: 24\n }) : null));\n};\nCardTitle.displayName = 'Card.Title';\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'space-between',\n paddingLeft: 16\n },\n left: {\n justifyContent: 'center',\n marginRight: 16,\n height: LEFT_SIZE,\n width: LEFT_SIZE\n },\n titles: {\n flex: 1,\n flexDirection: 'column',\n justifyContent: 'center'\n },\n title: {\n minHeight: 30,\n paddingRight: 16\n },\n subtitle: {\n minHeight: 20,\n marginVertical: 0,\n paddingRight: 16\n }\n});\nexport default CardTitle;\n\n// @component-docs ignore-next-line\nexport { CardTitle };\n//# sourceMappingURL=CardTitle.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport StyledText from './StyledText';\n// @component-group Typography\n/**\n * Typography component for showing a caption.\n *\n *
\n * \n *
\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Caption } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * Caption\n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Caption = props => /*#__PURE__*/React.createElement(StyledText, _extends({}, props, {\n alpha: 0.54,\n family: \"regular\",\n style: [styles.text, props.style]\n}));\nexport default Caption;\nconst styles = StyleSheet.create({\n text: {\n fontSize: 12,\n lineHeight: 20,\n marginVertical: 2,\n letterSpacing: 0.4\n }\n});\n//# sourceMappingURL=Caption.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport StyledText from './StyledText';\n// @component-group Typography\n/**\n * Typography component for showing a title.\n *\n *
\n * \n *
\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Title } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * Title\n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Title = props => /*#__PURE__*/React.createElement(StyledText, _extends({}, props, {\n alpha: 0.87,\n family: \"medium\",\n style: [styles.text, props.style]\n}));\nexport default Title;\nconst styles = StyleSheet.create({\n text: {\n fontSize: 20,\n lineHeight: 30,\n marginVertical: 2,\n letterSpacing: 0.15\n }\n});\n//# sourceMappingURL=Title.js.map","import CheckboxComponent from './Checkbox';\nimport CheckboxAndroid from './CheckboxAndroid';\nimport CheckboxIOS from './CheckboxIOS';\nimport CheckboxItem from './CheckboxItem';\nconst Checkbox = Object.assign(\n// @component ./Checkbox.tsx\nCheckboxComponent, {\n // @component ./CheckboxItem.tsx\n Item: CheckboxItem,\n // @component ./CheckboxAndroid.tsx\n Android: CheckboxAndroid,\n // @component ./CheckboxIOS.tsx\n IOS: CheckboxIOS\n});\nexport default Checkbox;\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Platform } from 'react-native';\nimport CheckboxAndroid from './CheckboxAndroid';\nimport CheckboxIOS from './CheckboxIOS';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * Checkboxes allow the selection of multiple options from a set.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Checkbox } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [checked, setChecked] = React.useState(false);\n *\n * return (\n * {\n * setChecked(!checked);\n * }}\n * />\n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst Checkbox = _ref => {\n let {\n theme: themeOverrides,\n ...props\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n return Platform.OS === 'ios' ? /*#__PURE__*/React.createElement(CheckboxIOS, _extends({}, props, {\n theme: theme\n })) : /*#__PURE__*/React.createElement(CheckboxAndroid, _extends({}, props, {\n theme: theme\n }));\n};\nexport default Checkbox;\n\n// @component-docs ignore-next-line\nconst CheckboxWithTheme = Checkbox;\n// @component-docs ignore-next-line\nexport { CheckboxWithTheme as Checkbox };\n//# sourceMappingURL=Checkbox.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, StyleSheet, View } from 'react-native';\nimport { getAndroidSelectionControlColor } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport MaterialCommunityIcon from '../MaterialCommunityIcon';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\n// From https://material.io/design/motion/speed.html#duration\nconst ANIMATION_DURATION = 100;\n\n/**\n * Checkboxes allow the selection of multiple options from a set.\n * This component follows platform guidelines for Android, but can be used\n * on any platform.\n *\n * @extends TouchableRipple props https://callstack.github.io/react-native-paper/docs/components/TouchableRipple\n */\nconst CheckboxAndroid = _ref => {\n let {\n status,\n theme: themeOverrides,\n disabled,\n onPress,\n testID,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n current: scaleAnim\n } = React.useRef(new Animated.Value(1));\n const isFirstRendering = React.useRef(true);\n const {\n animation: {\n scale\n }\n } = theme;\n React.useEffect(() => {\n // Do not run animation on very first rendering\n if (isFirstRendering.current) {\n isFirstRendering.current = false;\n return;\n }\n const checked = status === 'checked';\n Animated.sequence([Animated.timing(scaleAnim, {\n toValue: 0.85,\n duration: checked ? ANIMATION_DURATION * scale : 0,\n useNativeDriver: false\n }), Animated.timing(scaleAnim, {\n toValue: 1,\n duration: checked ? ANIMATION_DURATION * scale : ANIMATION_DURATION * scale * 1.75,\n useNativeDriver: false\n })]).start();\n }, [status, scaleAnim, scale]);\n const checked = status === 'checked';\n const indeterminate = status === 'indeterminate';\n const {\n rippleColor,\n selectionControlColor\n } = getAndroidSelectionControlColor({\n theme,\n disabled,\n checked,\n customColor: rest.color,\n customUncheckedColor: rest.uncheckedColor\n });\n const borderWidth = scaleAnim.interpolate({\n inputRange: [0.8, 1],\n outputRange: [7, 0]\n });\n const icon = indeterminate ? 'minus-box' : checked ? 'checkbox-marked' : 'checkbox-blank-outline';\n return /*#__PURE__*/React.createElement(TouchableRipple, _extends({}, rest, {\n borderless: true,\n rippleColor: rippleColor,\n onPress: onPress,\n disabled: disabled,\n accessibilityRole: \"checkbox\",\n accessibilityState: {\n disabled,\n checked\n },\n accessibilityLiveRegion: \"polite\",\n style: styles.container,\n testID: testID,\n theme: theme\n }), /*#__PURE__*/React.createElement(Animated.View, {\n style: {\n transform: [{\n scale: scaleAnim\n }]\n }\n }, /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n allowFontScaling: false,\n name: icon,\n size: 24,\n color: selectionControlColor,\n direction: \"ltr\"\n }), /*#__PURE__*/React.createElement(View, {\n style: [StyleSheet.absoluteFill, styles.fillContainer]\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.fill, {\n borderColor: selectionControlColor\n }, {\n borderWidth\n }]\n }))));\n};\nCheckboxAndroid.displayName = 'Checkbox.Android';\nconst styles = StyleSheet.create({\n container: {\n borderRadius: 18,\n width: 36,\n height: 36,\n padding: 6\n },\n fillContainer: {\n alignItems: 'center',\n justifyContent: 'center'\n },\n fill: {\n height: 14,\n width: 14\n }\n});\nexport default CheckboxAndroid;\n\n// @component-docs ignore-next-line\nexport { CheckboxAndroid };\n//# sourceMappingURL=CheckboxAndroid.js.map","import color from 'color';\nconst getAndroidCheckedColor = _ref => {\n let {\n theme,\n customColor\n } = _ref;\n if (customColor) {\n return customColor;\n }\n if (theme.isV3) {\n return theme.colors.primary;\n }\n return theme.colors.accent;\n};\nconst getAndroidUncheckedColor = _ref2 => {\n let {\n theme,\n customUncheckedColor\n } = _ref2;\n if (customUncheckedColor) {\n return customUncheckedColor;\n }\n if (theme.isV3) {\n return theme.colors.onSurfaceVariant;\n }\n if (theme.dark) {\n return color(theme.colors.text).alpha(0.7).rgb().string();\n }\n return color(theme.colors.text).alpha(0.54).rgb().string();\n};\nconst getAndroidRippleColor = _ref3 => {\n let {\n theme,\n checkedColor,\n disabled\n } = _ref3;\n if (disabled) {\n if (theme.isV3) {\n return color(theme.colors.onSurface).alpha(0.16).rgb().string();\n }\n return color(theme.colors.text).alpha(0.16).rgb().string();\n }\n return color(checkedColor).fade(0.32).rgb().string();\n};\nconst getAndroidControlColor = _ref4 => {\n let {\n theme,\n checked,\n disabled,\n checkedColor,\n uncheckedColor\n } = _ref4;\n if (disabled) {\n if (theme.isV3) {\n return theme.colors.onSurfaceDisabled;\n }\n return theme.colors.disabled;\n }\n if (checked) {\n return checkedColor;\n }\n return uncheckedColor;\n};\nexport const getAndroidSelectionControlColor = _ref5 => {\n let {\n theme,\n disabled,\n checked,\n customColor,\n customUncheckedColor\n } = _ref5;\n const checkedColor = getAndroidCheckedColor({\n theme,\n customColor\n });\n const uncheckedColor = getAndroidUncheckedColor({\n theme,\n customUncheckedColor\n });\n return {\n rippleColor: getAndroidRippleColor({\n theme,\n checkedColor,\n disabled\n }),\n selectionControlColor: getAndroidControlColor({\n theme,\n disabled,\n checked,\n checkedColor,\n uncheckedColor\n })\n };\n};\nconst getIOSCheckedColor = _ref6 => {\n let {\n theme,\n disabled,\n customColor\n } = _ref6;\n if (disabled) {\n if (theme.isV3) {\n return theme.colors.onSurfaceDisabled;\n }\n return theme.colors.disabled;\n }\n if (customColor) {\n return customColor;\n }\n if (theme.isV3) {\n return theme.colors.primary;\n }\n return theme.colors.accent;\n};\nconst getIOSRippleColor = _ref7 => {\n let {\n theme,\n checkedColor,\n disabled\n } = _ref7;\n if (disabled) {\n if (theme.isV3) {\n return color(theme.colors.onSurface).alpha(0.16).rgb().string();\n }\n return color(theme.colors.text).alpha(0.16).rgb().string();\n }\n return color(checkedColor).fade(0.32).rgb().string();\n};\nexport const getSelectionControlIOSColor = _ref8 => {\n let {\n theme,\n disabled,\n customColor\n } = _ref8;\n const checkedColor = getIOSCheckedColor({\n theme,\n disabled,\n customColor\n });\n return {\n checkedColor,\n rippleColor: getIOSRippleColor({\n theme,\n checkedColor,\n disabled\n })\n };\n};\n//# sourceMappingURL=utils.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { getSelectionControlIOSColor } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport MaterialCommunityIcon from '../MaterialCommunityIcon';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\n/**\n * Checkboxes allow the selection of multiple options from a set.\n * This component follows platform guidelines for iOS, but can be used\n * on any platform.\n *\n * @extends TouchableRipple props https://callstack.github.io/react-native-paper/docs/components/TouchableRipple\n */\nconst CheckboxIOS = _ref => {\n let {\n status,\n disabled,\n onPress,\n theme: themeOverrides,\n testID,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const checked = status === 'checked';\n const indeterminate = status === 'indeterminate';\n const {\n checkedColor,\n rippleColor\n } = getSelectionControlIOSColor({\n theme,\n disabled,\n customColor: rest.color\n });\n const icon = indeterminate ? 'minus' : 'check';\n const opacity = indeterminate || checked ? 1 : 0;\n return /*#__PURE__*/React.createElement(TouchableRipple, _extends({}, rest, {\n borderless: true,\n rippleColor: rippleColor,\n onPress: onPress,\n disabled: disabled,\n accessibilityRole: \"checkbox\",\n accessibilityState: {\n disabled,\n checked\n },\n accessibilityLiveRegion: \"polite\",\n style: styles.container,\n testID: testID,\n theme: theme\n }), /*#__PURE__*/React.createElement(View, {\n style: {\n opacity\n }\n }, /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n allowFontScaling: false,\n name: icon,\n size: 24,\n color: checkedColor,\n direction: \"ltr\"\n })));\n};\nCheckboxIOS.displayName = 'Checkbox.IOS';\nconst styles = StyleSheet.create({\n container: {\n borderRadius: 18,\n padding: 6\n }\n});\nexport default CheckboxIOS;\n\n// @component-docs ignore-next-line\nexport { CheckboxIOS };\n//# sourceMappingURL=CheckboxIOS.js.map","import * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport Checkbox from './Checkbox';\nimport CheckboxAndroid from './CheckboxAndroid';\nimport CheckboxIOS from './CheckboxIOS';\nimport { useInternalTheme } from '../../core/theming';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * Checkbox.Item allows you to press the whole row (item) instead of only the Checkbox.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { Checkbox } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * \n * \n * );\n *\n * export default MyComponent;\n *```\n */\n\nconst CheckboxItem = _ref => {\n let {\n style,\n status,\n label,\n onPress,\n onLongPress,\n labelStyle,\n theme: themeOverrides,\n testID,\n mode,\n position = 'trailing',\n accessibilityLabel = label,\n disabled,\n labelVariant = 'bodyLarge',\n labelMaxFontSizeMultiplier = 1.5,\n rippleColor,\n background,\n ...props\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const checkboxProps = {\n ...props,\n status,\n theme,\n disabled\n };\n const isLeading = position === 'leading';\n let checkbox;\n if (mode === 'android') {\n checkbox = /*#__PURE__*/React.createElement(CheckboxAndroid, checkboxProps);\n } else if (mode === 'ios') {\n checkbox = /*#__PURE__*/React.createElement(CheckboxIOS, checkboxProps);\n } else {\n checkbox = /*#__PURE__*/React.createElement(Checkbox, checkboxProps);\n }\n const textColor = theme.isV3 ? theme.colors.onSurface : theme.colors.text;\n const disabledTextColor = theme.isV3 ? theme.colors.onSurfaceDisabled : theme.colors.disabled;\n const textAlign = isLeading ? 'right' : 'left';\n const computedStyle = {\n color: disabled ? disabledTextColor : textColor,\n textAlign\n };\n return /*#__PURE__*/React.createElement(TouchableRipple, {\n accessibilityLabel: accessibilityLabel,\n accessibilityRole: \"checkbox\",\n accessibilityState: {\n checked: status === 'checked',\n disabled\n },\n onPress: onPress,\n onLongPress: onLongPress,\n testID: testID,\n disabled: disabled,\n rippleColor: rippleColor,\n theme: theme,\n background: background\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.container, style],\n pointerEvents: \"none\",\n importantForAccessibility: \"no-hide-descendants\"\n }, isLeading && checkbox, /*#__PURE__*/React.createElement(Text, {\n variant: labelVariant,\n testID: `${testID}-text`,\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier,\n style: [styles.label, !theme.isV3 && styles.font, computedStyle, labelStyle]\n }, label), !isLeading && checkbox));\n};\nCheckboxItem.displayName = 'Checkbox.Item';\nexport default CheckboxItem;\n\n// @component-docs ignore-next-line\nexport { CheckboxItem };\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'space-between',\n paddingVertical: 8,\n paddingHorizontal: 16\n },\n label: {\n flexShrink: 1,\n flexGrow: 1\n },\n font: {\n fontSize: 16\n }\n});\n//# sourceMappingURL=CheckboxItem.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Platform, StyleSheet, Pressable, View } from 'react-native';\nimport useLatestCallback from 'use-latest-callback';\nimport { getChipColors } from './helpers';\nimport { useInternalTheme } from '../../core/theming';\nimport { white } from '../../styles/themes/v2/colors';\nimport hasTouchHandler from '../../utils/hasTouchHandler';\nimport Icon from '../Icon';\nimport MaterialCommunityIcon from '../MaterialCommunityIcon';\nimport Surface from '../Surface';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * Chips are compact elements that can represent inputs, attributes, or actions.\n * They can have an icon or avatar on the left, and a close button icon on the right.\n * They are typically used to:\n *
    \n *
  • Present multiple options
  • \n *
  • Represent attributes active or chosen
  • \n *
  • Present filter options
  • \n *
  • Trigger actions related to primary content
  • \n *
\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Chip } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * console.log('Pressed')}>Example Chip\n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Chip = _ref => {\n let {\n mode = 'flat',\n children,\n icon,\n avatar,\n selected = false,\n disabled = false,\n background,\n accessibilityLabel,\n accessibilityRole = 'button',\n closeIconAccessibilityLabel = 'Close',\n onPress,\n onLongPress,\n onPressOut,\n onPressIn,\n delayLongPress,\n onClose,\n closeIcon,\n textStyle,\n style,\n theme: themeOverrides,\n testID = 'chip',\n selectedColor,\n rippleColor: customRippleColor,\n showSelectedOverlay = false,\n showSelectedCheck = true,\n ellipsizeMode,\n compact,\n elevated = false,\n maxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3,\n roundness\n } = theme;\n const {\n current: elevation\n } = React.useRef(new Animated.Value(isV3 && elevated ? 1 : 0));\n const hasPassedTouchHandler = hasTouchHandler({\n onPress,\n onLongPress,\n onPressIn,\n onPressOut\n });\n const isOutlined = mode === 'outlined';\n const handlePressIn = useLatestCallback(e => {\n const {\n scale\n } = theme.animation;\n onPressIn === null || onPressIn === void 0 ? void 0 : onPressIn(e);\n Animated.timing(elevation, {\n toValue: isV3 ? elevated ? 2 : 0 : 4,\n duration: 200 * scale,\n useNativeDriver: Platform.OS === 'web' || Platform.constants.reactNativeVersion.minor <= 72\n }).start();\n });\n const handlePressOut = useLatestCallback(e => {\n const {\n scale\n } = theme.animation;\n onPressOut === null || onPressOut === void 0 ? void 0 : onPressOut(e);\n Animated.timing(elevation, {\n toValue: isV3 && elevated ? 1 : 0,\n duration: 150 * scale,\n useNativeDriver: Platform.OS === 'web' || Platform.constants.reactNativeVersion.minor <= 72\n }).start();\n });\n const opacity = isV3 ? 0.38 : 0.26;\n const defaultBorderRadius = roundness * (isV3 ? 2 : 4);\n const iconSize = isV3 ? 18 : 16;\n const {\n backgroundColor: customBackgroundColor,\n borderRadius = defaultBorderRadius\n } = StyleSheet.flatten(style) || {};\n const {\n borderColor,\n textColor,\n iconColor,\n rippleColor,\n selectedBackgroundColor,\n backgroundColor\n } = getChipColors({\n isOutlined,\n theme,\n selectedColor,\n showSelectedOverlay,\n customBackgroundColor,\n disabled,\n customRippleColor\n });\n const accessibilityState = {\n selected,\n disabled\n };\n const elevationStyle = isV3 || Platform.OS === 'android' ? elevation : 0;\n const multiplier = isV3 ? compact ? 1.5 : 2 : 1;\n const labelSpacings = {\n marginRight: onClose ? 0 : 8 * multiplier,\n marginLeft: avatar || icon || selected && showSelectedCheck ? 4 * multiplier : 8 * multiplier\n };\n const contentSpacings = {\n paddingRight: isV3 ? onClose ? 34 : 0 : onClose ? 32 : 4\n };\n const labelTextStyle = {\n color: textColor,\n ...(isV3 ? theme.fonts.labelLarge : theme.fonts.regular)\n };\n return /*#__PURE__*/React.createElement(Surface, _extends({\n style: [styles.container, isV3 && (isOutlined ? styles.md3OutlineContainer : styles.md3FlatContainer), !theme.isV3 && {\n elevation: elevationStyle\n }, {\n backgroundColor: selected ? selectedBackgroundColor : backgroundColor,\n borderColor,\n borderRadius\n }, style]\n }, theme.isV3 && {\n elevation: elevationStyle\n }, rest, {\n testID: `${testID}-container`,\n theme: theme\n }), /*#__PURE__*/React.createElement(TouchableRipple, {\n borderless: true,\n background: background,\n style: [{\n borderRadius\n }, styles.touchable],\n onPress: onPress,\n onLongPress: onLongPress,\n onPressIn: hasPassedTouchHandler ? handlePressIn : undefined,\n onPressOut: hasPassedTouchHandler ? handlePressOut : undefined,\n delayLongPress: delayLongPress,\n rippleColor: rippleColor,\n disabled: disabled,\n accessibilityLabel: accessibilityLabel,\n accessibilityRole: accessibilityRole,\n accessibilityState: accessibilityState,\n testID: testID,\n theme: theme\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.content, isV3 && styles.md3Content, contentSpacings]\n }, avatar && !icon ? /*#__PURE__*/React.createElement(View, {\n style: [styles.avatarWrapper, isV3 && styles.md3AvatarWrapper, disabled && {\n opacity\n }]\n }, /*#__PURE__*/React.isValidElement(avatar) ? /*#__PURE__*/React.cloneElement(avatar, {\n style: [styles.avatar, avatar.props.style]\n }) : avatar) : null, icon || selected && showSelectedCheck ? /*#__PURE__*/React.createElement(View, {\n style: [styles.icon, isV3 && styles.md3Icon, avatar ? [styles.avatar, styles.avatarSelected, isV3 && selected && styles.md3SelectedIcon] : null]\n }, icon ? /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n color: avatar ? white : !disabled && theme.isV3 ? theme.colors.primary : iconColor,\n size: 18,\n theme: theme\n }) : /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"check\",\n color: avatar ? white : iconColor,\n size: 18,\n direction: \"ltr\"\n })) : null, /*#__PURE__*/React.createElement(Text, {\n variant: \"labelLarge\",\n selectable: false,\n numberOfLines: 1,\n style: [isV3 ? styles.md3LabelText : styles.labelText, labelTextStyle, labelSpacings, textStyle],\n ellipsizeMode: ellipsizeMode,\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, children))), onClose ? /*#__PURE__*/React.createElement(View, {\n style: styles.closeButtonStyle\n }, /*#__PURE__*/React.createElement(Pressable, {\n onPress: onClose,\n disabled: disabled,\n accessibilityRole: \"button\",\n accessibilityLabel: closeIconAccessibilityLabel\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.icon, styles.closeIcon, isV3 && styles.md3CloseIcon]\n }, closeIcon ? /*#__PURE__*/React.createElement(Icon, {\n source: closeIcon,\n color: iconColor,\n size: iconSize\n }) : /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: isV3 ? 'close' : 'close-circle',\n size: iconSize,\n color: iconColor,\n direction: \"ltr\"\n })))) : null);\n};\nconst styles = StyleSheet.create({\n container: {\n borderWidth: StyleSheet.hairlineWidth,\n borderStyle: 'solid',\n flexDirection: Platform.select({\n default: 'column',\n web: 'row'\n })\n },\n md3OutlineContainer: {\n borderWidth: 1\n },\n md3FlatContainer: {\n borderWidth: 0\n },\n content: {\n flexDirection: 'row',\n alignItems: 'center',\n paddingLeft: 4,\n position: 'relative'\n },\n md3Content: {\n paddingLeft: 0\n },\n icon: {\n padding: 4,\n alignSelf: 'center'\n },\n md3Icon: {\n paddingLeft: 8,\n paddingRight: 0\n },\n closeIcon: {\n marginRight: 4\n },\n md3CloseIcon: {\n marginRight: 8,\n padding: 0\n },\n labelText: {\n minHeight: 24,\n lineHeight: 24,\n textAlignVertical: 'center',\n marginVertical: 4\n },\n md3LabelText: {\n textAlignVertical: 'center',\n marginVertical: 6\n },\n avatar: {\n width: 24,\n height: 24,\n borderRadius: 12\n },\n avatarWrapper: {\n marginRight: 4\n },\n md3AvatarWrapper: {\n marginLeft: 4,\n marginRight: 0\n },\n md3SelectedIcon: {\n paddingLeft: 4\n },\n // eslint-disable-next-line react-native/no-color-literals\n avatarSelected: {\n position: 'absolute',\n top: 4,\n left: 4,\n backgroundColor: 'rgba(0, 0, 0, .29)'\n },\n closeButtonStyle: {\n position: 'absolute',\n right: 0,\n height: '100%',\n justifyContent: 'center',\n alignItems: 'center'\n },\n touchable: {\n width: '100%'\n }\n});\nexport default Chip;\n//# sourceMappingURL=Chip.js.map","import color from 'color';\nimport { black, white } from '../../styles/themes/v2/colors';\nconst getBorderColor = _ref => {\n let {\n theme,\n isOutlined,\n disabled,\n selectedColor,\n backgroundColor\n } = _ref;\n const isSelectedColor = selectedColor !== undefined;\n if (theme.isV3) {\n if (disabled) {\n return color(theme.colors.onSurfaceVariant).alpha(0.12).rgb().string();\n }\n if (isSelectedColor) {\n return color(selectedColor).alpha(0.29).rgb().string();\n }\n return theme.colors.outline;\n }\n if (isOutlined) {\n if (isSelectedColor) {\n return color(selectedColor).alpha(0.29).rgb().string();\n }\n if (theme.dark) {\n return color(white).alpha(0.29).rgb().string();\n }\n return color(black).alpha(0.29).rgb().string();\n }\n return backgroundColor;\n};\nconst getTextColor = _ref2 => {\n let {\n theme,\n isOutlined,\n disabled,\n selectedColor\n } = _ref2;\n const isSelectedColor = selectedColor !== undefined;\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n if (isSelectedColor) {\n return selectedColor;\n }\n if (isOutlined) {\n return theme.colors.onSurfaceVariant;\n }\n return theme.colors.onSecondaryContainer;\n }\n if (disabled) {\n return theme.colors.disabled;\n }\n if (isSelectedColor) {\n return color(selectedColor).alpha(0.87).rgb().string();\n }\n return color(theme.colors.text).alpha(0.87).rgb().string();\n};\nconst getDefaultBackgroundColor = _ref3 => {\n let {\n theme,\n isOutlined\n } = _ref3;\n if (theme.isV3) {\n if (isOutlined) {\n return theme.colors.surface;\n }\n return theme.colors.secondaryContainer;\n }\n if (isOutlined) {\n var _theme$colors;\n return (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.surface;\n }\n if (theme.dark) {\n return '#383838';\n }\n return '#ebebeb';\n};\nconst getBackgroundColor = _ref4 => {\n let {\n theme,\n isOutlined,\n disabled,\n customBackgroundColor\n } = _ref4;\n if (typeof customBackgroundColor === 'string') {\n return customBackgroundColor;\n }\n if (theme.isV3) {\n if (disabled) {\n if (isOutlined) {\n return 'transparent';\n }\n return color(theme.colors.onSurfaceVariant).alpha(0.12).rgb().string();\n }\n }\n return getDefaultBackgroundColor({\n theme,\n isOutlined\n });\n};\nconst getSelectedBackgroundColor = _ref5 => {\n let {\n theme,\n isOutlined,\n disabled,\n customBackgroundColor,\n showSelectedOverlay\n } = _ref5;\n const backgroundColor = getBackgroundColor({\n theme,\n disabled,\n isOutlined,\n customBackgroundColor\n });\n if (theme.isV3) {\n if (isOutlined) {\n if (showSelectedOverlay) {\n return color(backgroundColor).mix(color(theme.colors.onSurfaceVariant), 0.12).rgb().string();\n }\n return color(backgroundColor).mix(color(theme.colors.onSurfaceVariant), 0).rgb().string();\n }\n if (showSelectedOverlay) {\n return color(backgroundColor).mix(color(theme.colors.onSecondaryContainer), 0.12).rgb().string();\n }\n return color(backgroundColor).mix(color(theme.colors.onSecondaryContainer), 0).rgb().string();\n }\n if (theme.dark) {\n if (isOutlined) {\n return color(backgroundColor).lighten(0.2).rgb().string();\n }\n return color(backgroundColor).lighten(0.4).rgb().string();\n }\n if (isOutlined) {\n return color(backgroundColor).darken(0.08).rgb().string();\n }\n return color(backgroundColor).darken(0.2).rgb().string();\n};\nconst getIconColor = _ref6 => {\n let {\n theme,\n isOutlined,\n disabled,\n selectedColor\n } = _ref6;\n const isSelectedColor = selectedColor !== undefined;\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n if (isSelectedColor) {\n return selectedColor;\n }\n if (isOutlined) {\n return theme.colors.onSurfaceVariant;\n }\n return theme.colors.onSecondaryContainer;\n }\n if (disabled) {\n return theme.colors.disabled;\n }\n if (isSelectedColor) {\n return color(selectedColor).alpha(0.54).rgb().string();\n }\n return color(theme.colors.text).alpha(0.54).rgb().string();\n};\nconst getRippleColor = _ref7 => {\n let {\n theme,\n isOutlined,\n disabled,\n selectedColor,\n selectedBackgroundColor,\n customRippleColor\n } = _ref7;\n if (customRippleColor) {\n return customRippleColor;\n }\n const isSelectedColor = selectedColor !== undefined;\n const textColor = getTextColor({\n theme,\n disabled,\n selectedColor,\n isOutlined\n });\n if (theme.isV3) {\n if (isSelectedColor) {\n return color(selectedColor).alpha(0.12).rgb().string();\n }\n return color(textColor).alpha(0.12).rgb().string();\n }\n if (isSelectedColor) {\n return color(selectedColor).fade(0.5).rgb().string();\n }\n return selectedBackgroundColor;\n};\nexport const getChipColors = _ref8 => {\n let {\n isOutlined,\n theme,\n selectedColor,\n showSelectedOverlay,\n customBackgroundColor,\n disabled,\n customRippleColor\n } = _ref8;\n const baseChipColorProps = {\n theme,\n isOutlined,\n disabled\n };\n const backgroundColor = getBackgroundColor({\n ...baseChipColorProps,\n customBackgroundColor\n });\n const selectedBackgroundColor = getSelectedBackgroundColor({\n ...baseChipColorProps,\n customBackgroundColor,\n showSelectedOverlay\n });\n return {\n borderColor: getBorderColor({\n ...baseChipColorProps,\n selectedColor,\n backgroundColor\n }),\n textColor: getTextColor({\n ...baseChipColorProps,\n selectedColor\n }),\n iconColor: getIconColor({\n ...baseChipColorProps,\n selectedColor\n }),\n rippleColor: getRippleColor({\n ...baseChipColorProps,\n selectedColor,\n selectedBackgroundColor,\n customRippleColor\n }),\n backgroundColor,\n selectedBackgroundColor\n };\n};\n//# sourceMappingURL=helpers.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport DataTableCell from './DataTableCell';\nimport DataTableHeader\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfrom './DataTableHeader';\nimport DataTablePagination\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfrom './DataTablePagination';\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nimport DataTableRow from './DataTableRow';\nimport DataTableTitle\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfrom './DataTableTitle';\n/**\n * Data tables allow displaying sets of data.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { DataTable } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [page, setPage] = React.useState(0);\n * const [numberOfItemsPerPageList] = React.useState([2, 3, 4]);\n * const [itemsPerPage, onItemsPerPageChange] = React.useState(\n * numberOfItemsPerPageList[0]\n * );\n *\n * const [items] = React.useState([\n * {\n * key: 1,\n * name: 'Cupcake',\n * calories: 356,\n * fat: 16,\n * },\n * {\n * key: 2,\n * name: 'Eclair',\n * calories: 262,\n * fat: 16,\n * },\n * {\n * key: 3,\n * name: 'Frozen yogurt',\n * calories: 159,\n * fat: 6,\n * },\n * {\n * key: 4,\n * name: 'Gingerbread',\n * calories: 305,\n * fat: 3.7,\n * },\n * ]);\n *\n * const from = page * itemsPerPage;\n * const to = Math.min((page + 1) * itemsPerPage, items.length);\n *\n * React.useEffect(() => {\n * setPage(0);\n * }, [itemsPerPage]);\n *\n * return (\n * \n * \n * Dessert\n * Calories\n * Fat\n * \n *\n * {items.slice(from, to).map((item) => (\n * \n * {item.name}\n * {item.calories}\n * {item.fat}\n * \n * ))}\n *\n * setPage(page)}\n * label={`${from + 1}-${to} of ${items.length}`}\n * numberOfItemsPerPageList={numberOfItemsPerPageList}\n * numberOfItemsPerPage={itemsPerPage}\n * onItemsPerPageChange={onItemsPerPageChange}\n * showFastPaginationControls\n * selectPageDropdownLabel={'Rows per page'}\n * />\n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst DataTable = _ref => {\n let {\n children,\n style,\n ...rest\n } = _ref;\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, {\n style: [styles.container, style]\n }), children);\n};\n\n// @component ./DataTableHeader.tsx\nDataTable.Header = DataTableHeader;\n\n// @component ./DataTableTitle.tsx\nDataTable.Title = DataTableTitle;\n\n// @component ./DataTableRow.tsx\nDataTable.Row = DataTableRow;\n\n// @component ./DataTableCell.tsx\nDataTable.Cell = DataTableCell;\n\n// @component ./DataTablePagination.tsx\nDataTable.Pagination = DataTablePagination;\nconst styles = StyleSheet.create({\n container: {\n width: '100%'\n }\n});\nexport default DataTable;\n//# sourceMappingURL=DataTable.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * A component to show a single cell inside of a table.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { DataTable } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * 1\n * 2\n * 3\n * 4\n * \n * );\n *\n * export default MyComponent;\n * ```\n *\n * If you want to support multiline text, please use View instead, as multiline text doesn't comply with\n * MD Guidelines (https://github.com/callstack/react-native-paper/issues/2381).\n *\n * @extends TouchableRipple props https://callstack.github.io/react-native-paper/docs/components/TouchableRipple\n */\nconst DataTableCell = _ref => {\n let {\n children,\n textStyle,\n style,\n numeric,\n maxFontSizeMultiplier,\n testID,\n ...rest\n } = _ref;\n return /*#__PURE__*/React.createElement(TouchableRipple, _extends({}, rest, {\n testID: testID,\n style: [styles.container, numeric && styles.right, style]\n }), /*#__PURE__*/React.createElement(CellContent, {\n textStyle: textStyle,\n testID: testID,\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, children));\n};\nconst CellContent = _ref2 => {\n let {\n children,\n textStyle,\n maxFontSizeMultiplier,\n testID\n } = _ref2;\n if ( /*#__PURE__*/React.isValidElement(children)) {\n return children;\n }\n return /*#__PURE__*/React.createElement(Text, {\n style: textStyle,\n numberOfLines: 1,\n maxFontSizeMultiplier: maxFontSizeMultiplier,\n testID: `${testID}-text-container`\n }, children);\n};\nDataTableCell.displayName = 'DataTable.Cell';\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n flexDirection: 'row',\n alignItems: 'center'\n },\n right: {\n justifyContent: 'flex-end'\n }\n});\nexport default DataTableCell;\n//# sourceMappingURL=DataTableCell.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { useInternalTheme } from '../../core/theming';\nimport { black, white } from '../../styles/themes/v2/colors';\n/**\n * A component to display title in table header.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { DataTable } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * \n * \n * Dessert\n * \n * Calories\n * Fat (g)\n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\n\nconst DataTableHeader = _ref => {\n let {\n children,\n style,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const borderBottomColor = theme.isV3 ? theme.colors.surfaceVariant : color(theme.dark ? white : black).alpha(0.12).rgb().string();\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, {\n style: [styles.header, {\n borderBottomColor\n }, style]\n }), children);\n};\nDataTableHeader.displayName = 'DataTable.Header';\nconst styles = StyleSheet.create({\n header: {\n flexDirection: 'row',\n paddingHorizontal: 16,\n borderBottomWidth: StyleSheet.hairlineWidth * 2\n }\n});\nexport default DataTableHeader;\n\n// @component-docs ignore-next-line\nexport { DataTableHeader };\n//# sourceMappingURL=DataTableHeader.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { I18nManager, StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { useInternalTheme } from '../../core/theming';\nimport Button from '../Button/Button';\nimport IconButton from '../IconButton/IconButton';\nimport MaterialCommunityIcon from '../MaterialCommunityIcon';\nimport Menu from '../Menu/Menu';\nimport Text from '../Typography/Text';\nconst PaginationControls = _ref => {\n let {\n page,\n numberOfPages,\n onPageChange,\n showFastPaginationControls,\n theme: themeOverrides,\n paginationControlRippleColor\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const textColor = theme.isV3 ? theme.colors.onSurface : theme.colors.text;\n return /*#__PURE__*/React.createElement(React.Fragment, null, showFastPaginationControls ? /*#__PURE__*/React.createElement(IconButton, {\n icon: _ref2 => {\n let {\n size,\n color\n } = _ref2;\n return /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"page-first\",\n color: color,\n size: size,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n });\n },\n iconColor: textColor,\n rippleColor: paginationControlRippleColor,\n disabled: page === 0,\n onPress: () => onPageChange(0),\n accessibilityLabel: \"page-first\",\n theme: theme\n }) : null, /*#__PURE__*/React.createElement(IconButton, {\n icon: _ref3 => {\n let {\n size,\n color\n } = _ref3;\n return /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"chevron-left\",\n color: color,\n size: size,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n });\n },\n iconColor: textColor,\n rippleColor: paginationControlRippleColor,\n disabled: page === 0,\n onPress: () => onPageChange(page - 1),\n accessibilityLabel: \"chevron-left\",\n theme: theme\n }), /*#__PURE__*/React.createElement(IconButton, {\n icon: _ref4 => {\n let {\n size,\n color\n } = _ref4;\n return /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"chevron-right\",\n color: color,\n size: size,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n });\n },\n iconColor: textColor,\n rippleColor: paginationControlRippleColor,\n disabled: numberOfPages === 0 || page === numberOfPages - 1,\n onPress: () => onPageChange(page + 1),\n accessibilityLabel: \"chevron-right\",\n theme: theme\n }), showFastPaginationControls ? /*#__PURE__*/React.createElement(IconButton, {\n icon: _ref5 => {\n let {\n size,\n color\n } = _ref5;\n return /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"page-last\",\n color: color,\n size: size,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n });\n },\n iconColor: textColor,\n rippleColor: paginationControlRippleColor,\n disabled: numberOfPages === 0 || page === numberOfPages - 1,\n onPress: () => onPageChange(numberOfPages - 1),\n accessibilityLabel: \"page-last\",\n theme: theme\n }) : null);\n};\nconst PaginationDropdown = _ref6 => {\n let {\n numberOfItemsPerPageList,\n numberOfItemsPerPage,\n onItemsPerPageChange,\n theme: themeOverrides,\n selectPageDropdownRippleColor,\n dropdownItemRippleColor\n } = _ref6;\n const theme = useInternalTheme(themeOverrides);\n const {\n colors\n } = theme;\n const [showSelect, toggleSelect] = React.useState(false);\n return /*#__PURE__*/React.createElement(Menu, {\n visible: showSelect,\n onDismiss: () => toggleSelect(!showSelect),\n theme: theme,\n anchor: /*#__PURE__*/React.createElement(Button, {\n mode: \"outlined\",\n onPress: () => toggleSelect(true),\n style: styles.button,\n icon: \"menu-down\",\n contentStyle: styles.contentStyle,\n theme: theme,\n rippleColor: selectPageDropdownRippleColor\n }, `${numberOfItemsPerPage}`)\n }, numberOfItemsPerPageList === null || numberOfItemsPerPageList === void 0 ? void 0 : numberOfItemsPerPageList.map(option => /*#__PURE__*/React.createElement(Menu.Item, {\n key: option,\n titleStyle: option === numberOfItemsPerPage && {\n color: colors === null || colors === void 0 ? void 0 : colors.primary\n },\n onPress: () => {\n onItemsPerPageChange === null || onItemsPerPageChange === void 0 ? void 0 : onItemsPerPageChange(option);\n toggleSelect(false);\n },\n rippleColor: dropdownItemRippleColor,\n title: option,\n theme: theme\n })));\n};\n\n/**\n * A component to show pagination for data table.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { DataTable } from 'react-native-paper';\n *\n * const numberOfItemsPerPageList = [2, 3, 4];\n *\n * const items = [\n * {\n * key: 1,\n * name: 'Page 1',\n * },\n * {\n * key: 2,\n * name: 'Page 2',\n * },\n * {\n * key: 3,\n * name: 'Page 3',\n * },\n * ];\n *\n * const MyComponent = () => {\n * const [page, setPage] = React.useState(0);\n * const [numberOfItemsPerPage, onItemsPerPageChange] = React.useState(numberOfItemsPerPageList[0]);\n * const from = page * numberOfItemsPerPage;\n * const to = Math.min((page + 1) * numberOfItemsPerPage, items.length);\n *\n * React.useEffect(() => {\n * setPage(0);\n * }, [numberOfItemsPerPage]);\n *\n * return (\n * \n * setPage(page)}\n * label={`${from + 1}-${to} of ${items.length}`}\n * showFastPaginationControls\n * numberOfItemsPerPageList={numberOfItemsPerPageList}\n * numberOfItemsPerPage={numberOfItemsPerPage}\n * onItemsPerPageChange={onItemsPerPageChange}\n * selectPageDropdownLabel={'Rows per page'}\n * />\n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst DataTablePagination = _ref7 => {\n let {\n label,\n accessibilityLabel,\n page,\n numberOfPages,\n onPageChange,\n style,\n showFastPaginationControls = false,\n numberOfItemsPerPageList,\n numberOfItemsPerPage,\n onItemsPerPageChange,\n selectPageDropdownLabel,\n selectPageDropdownAccessibilityLabel,\n selectPageDropdownRippleColor,\n dropdownItemRippleColor,\n theme: themeOverrides,\n ...rest\n } = _ref7;\n const theme = useInternalTheme(themeOverrides);\n const labelColor = color(theme.isV3 ? theme.colors.onSurface : theme === null || theme === void 0 ? void 0 : theme.colors.text).alpha(0.6).rgb().string();\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, {\n style: [styles.container, style],\n accessibilityLabel: \"pagination-container\"\n }), numberOfItemsPerPageList && numberOfItemsPerPage && onItemsPerPageChange && /*#__PURE__*/React.createElement(View, {\n accessibilityLabel: \"Options Select\",\n style: styles.optionsContainer\n }, /*#__PURE__*/React.createElement(Text, {\n style: [styles.label, {\n color: labelColor\n }],\n numberOfLines: 3,\n accessibilityLabel: selectPageDropdownAccessibilityLabel || 'selectPageDropdownLabel'\n }, selectPageDropdownLabel), /*#__PURE__*/React.createElement(PaginationDropdown, {\n numberOfItemsPerPageList: numberOfItemsPerPageList,\n numberOfItemsPerPage: numberOfItemsPerPage,\n onItemsPerPageChange: onItemsPerPageChange,\n selectPageDropdownRippleColor: selectPageDropdownRippleColor,\n dropdownItemRippleColor: dropdownItemRippleColor,\n theme: theme\n })), /*#__PURE__*/React.createElement(Text, {\n style: [styles.label, {\n color: labelColor\n }],\n numberOfLines: 3,\n accessibilityLabel: accessibilityLabel || 'label'\n }, label), /*#__PURE__*/React.createElement(View, {\n style: styles.iconsContainer\n }, /*#__PURE__*/React.createElement(PaginationControls, {\n showFastPaginationControls: showFastPaginationControls,\n onPageChange: onPageChange,\n page: page,\n numberOfPages: numberOfPages,\n theme: theme\n })));\n};\nDataTablePagination.displayName = 'DataTable.Pagination';\nconst styles = StyleSheet.create({\n container: {\n justifyContent: 'flex-end',\n flexDirection: 'row',\n alignItems: 'center',\n paddingLeft: 16,\n flexWrap: 'wrap'\n },\n optionsContainer: {\n flexDirection: 'row',\n alignItems: 'center',\n marginVertical: 6\n },\n label: {\n fontSize: 12,\n marginRight: 16\n },\n button: {\n textAlign: 'center',\n marginRight: 16\n },\n iconsContainer: {\n flexDirection: 'row'\n },\n contentStyle: {\n flexDirection: 'row-reverse'\n }\n});\nexport default DataTablePagination;\n\n// @component-docs ignore-next-line\nexport { DataTablePagination };\n//# sourceMappingURL=DataTablePagination.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport { getIconButtonColor } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { forwardRef } from '../../utils/forwardRef';\nimport ActivityIndicator from '../ActivityIndicator';\nimport CrossFadeIcon from '../CrossFadeIcon';\nimport Icon from '../Icon';\nimport Surface from '../Surface';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nconst PADDING = 8;\n/**\n * An icon button is a button which displays only an icon without a label.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { IconButton, MD3Colors } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * console.log('Pressed')}\n * />\n * );\n *\n * export default MyComponent;\n * ```\n *\n * @extends TouchableRipple props https://callstack.github.io/react-native-paper/docs/components/TouchableRipple\n */\nconst IconButton = forwardRef((_ref, ref) => {\n let {\n icon,\n iconColor: customIconColor,\n containerColor: customContainerColor,\n rippleColor: customRippleColor,\n size = 24,\n accessibilityLabel,\n disabled,\n onPress,\n selected = false,\n animated = false,\n mode,\n style,\n theme: themeOverrides,\n testID = 'icon-button',\n loading = false,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3\n } = theme;\n const IconComponent = animated ? CrossFadeIcon : Icon;\n const {\n iconColor,\n rippleColor,\n backgroundColor,\n borderColor\n } = getIconButtonColor({\n theme,\n disabled,\n selected,\n mode,\n customIconColor,\n customContainerColor,\n customRippleColor\n });\n const buttonSize = isV3 ? size + 2 * PADDING : size * 1.5;\n const {\n borderWidth = isV3 && mode === 'outlined' && !selected ? 1 : 0,\n borderRadius = buttonSize / 2\n } = StyleSheet.flatten(style) || {};\n const borderStyles = {\n borderWidth,\n borderRadius,\n borderColor\n };\n return /*#__PURE__*/React.createElement(Surface, _extends({\n ref: ref,\n testID: `${testID}-container`,\n style: [{\n backgroundColor,\n width: buttonSize,\n height: buttonSize\n }, styles.container, borderStyles, !isV3 && disabled && styles.disabled, style]\n }, isV3 && {\n elevation: 0\n }), /*#__PURE__*/React.createElement(TouchableRipple, _extends({\n borderless: true,\n centered: true,\n onPress: onPress,\n rippleColor: rippleColor,\n accessibilityLabel: accessibilityLabel,\n style: [styles.touchable, {\n borderRadius\n }]\n // @ts-expect-error We keep old a11y props for backwards compat with old RN versions\n ,\n accessibilityTraits: disabled ? ['button', 'disabled'] : 'button',\n accessibilityComponentType: \"button\",\n accessibilityRole: \"button\",\n accessibilityState: {\n disabled\n },\n disabled: disabled,\n hitSlop: TouchableRipple.supported ? {\n top: 10,\n left: 10,\n bottom: 10,\n right: 10\n } : {\n top: 6,\n left: 6,\n bottom: 6,\n right: 6\n },\n testID: testID\n }, rest), loading ? /*#__PURE__*/React.createElement(ActivityIndicator, {\n size: size,\n color: iconColor\n }) : /*#__PURE__*/React.createElement(IconComponent, {\n color: iconColor,\n source: icon,\n size: size\n })));\n});\nconst styles = StyleSheet.create({\n container: {\n overflow: 'hidden',\n margin: 6,\n elevation: 0\n },\n touchable: {\n flexGrow: 1,\n justifyContent: 'center',\n alignItems: 'center'\n },\n disabled: {\n opacity: 0.32\n }\n});\nexport default IconButton;\n//# sourceMappingURL=IconButton.js.map","import color from 'color';\nconst getBorderColor = _ref => {\n let {\n theme,\n disabled\n } = _ref;\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.surfaceDisabled;\n }\n return theme.colors.outline;\n }\n return undefined;\n};\nconst getBackgroundColor = _ref2 => {\n let {\n theme,\n isMode,\n disabled,\n selected,\n customContainerColor\n } = _ref2;\n if (theme.isV3) {\n if (disabled) {\n if (isMode('contained') || isMode('contained-tonal')) {\n return theme.colors.surfaceDisabled;\n }\n }\n if (typeof customContainerColor !== 'undefined') {\n return customContainerColor;\n }\n if (isMode('contained')) {\n if (selected) {\n return theme.colors.primary;\n }\n return theme.colors.surfaceVariant;\n }\n if (isMode('contained-tonal')) {\n if (selected) {\n return theme.colors.secondaryContainer;\n }\n return theme.colors.surfaceVariant;\n }\n if (isMode('outlined')) {\n if (selected) {\n return theme.colors.inverseSurface;\n }\n }\n }\n if (typeof customContainerColor !== 'undefined') {\n return customContainerColor;\n }\n return undefined;\n};\nconst getIconColor = _ref3 => {\n let {\n theme,\n isMode,\n disabled,\n selected,\n customIconColor\n } = _ref3;\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n if (typeof customIconColor !== 'undefined') {\n return customIconColor;\n }\n if (isMode('contained')) {\n if (selected) {\n return theme.colors.onPrimary;\n }\n return theme.colors.primary;\n }\n if (isMode('contained-tonal')) {\n if (selected) {\n return theme.colors.onSecondaryContainer;\n }\n return theme.colors.onSurfaceVariant;\n }\n if (isMode('outlined')) {\n if (selected) {\n return theme.colors.inverseOnSurface;\n }\n return theme.colors.onSurfaceVariant;\n }\n if (selected) {\n return theme.colors.primary;\n }\n return theme.colors.onSurfaceVariant;\n }\n if (typeof customIconColor !== 'undefined') {\n return customIconColor;\n }\n return theme.colors.text;\n};\nconst getRippleColor = _ref4 => {\n let {\n theme,\n iconColor,\n customRippleColor\n } = _ref4;\n if (customRippleColor) {\n return customRippleColor;\n }\n if (theme.isV3) {\n return color(iconColor).alpha(0.12).rgb().string();\n }\n return color(iconColor).alpha(0.32).rgb().string();\n};\nexport const getIconButtonColor = _ref5 => {\n let {\n theme,\n disabled,\n mode,\n selected,\n customIconColor,\n customContainerColor,\n customRippleColor\n } = _ref5;\n const isMode = modeToCompare => {\n return mode === modeToCompare;\n };\n const baseIconColorProps = {\n theme,\n isMode,\n disabled,\n selected\n };\n const iconColor = getIconColor({\n ...baseIconColorProps,\n customIconColor\n });\n return {\n iconColor,\n backgroundColor: getBackgroundColor({\n ...baseIconColorProps,\n customContainerColor\n }),\n rippleColor: getRippleColor({\n theme,\n iconColor,\n customRippleColor\n }),\n borderColor: getBorderColor({\n theme,\n disabled\n })\n };\n};\n//# sourceMappingURL=utils.js.map","import * as React from 'react';\nimport { Animated, StyleSheet, View } from 'react-native';\nimport Icon, { isEqualIcon, isValidIcon } from './Icon';\nimport { useInternalTheme } from '../core/theming';\nconst CrossFadeIcon = _ref => {\n let {\n color,\n size,\n source,\n theme: themeOverrides,\n testID = 'cross-fade-icon'\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const [currentIcon, setCurrentIcon] = React.useState(() => source);\n const [previousIcon, setPreviousIcon] = React.useState(null);\n const {\n current: fade\n } = React.useRef(new Animated.Value(1));\n const {\n scale\n } = theme.animation;\n if (currentIcon !== source) {\n setPreviousIcon(() => currentIcon);\n setCurrentIcon(() => source);\n }\n React.useEffect(() => {\n if (isValidIcon(previousIcon) && !isEqualIcon(previousIcon, currentIcon)) {\n fade.setValue(1);\n Animated.timing(fade, {\n duration: scale * 200,\n toValue: 0,\n useNativeDriver: true\n }).start();\n }\n }, [currentIcon, previousIcon, fade, scale]);\n const opacityPrev = fade;\n const opacityNext = previousIcon ? fade.interpolate({\n inputRange: [0, 1],\n outputRange: [1, 0]\n }) : 1;\n const rotatePrev = fade.interpolate({\n inputRange: [0, 1],\n outputRange: ['-90deg', '0deg']\n });\n const rotateNext = previousIcon ? fade.interpolate({\n inputRange: [0, 1],\n outputRange: ['0deg', '-180deg']\n }) : '0deg';\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.content, {\n height: size,\n width: size\n }]\n }, previousIcon ? /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.icon, {\n opacity: opacityPrev,\n transform: [{\n rotate: rotatePrev\n }]\n }],\n testID: `${testID}-previous`\n }, /*#__PURE__*/React.createElement(Icon, {\n source: previousIcon,\n size: size,\n color: color,\n theme: theme\n })) : null, /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.icon, {\n opacity: opacityNext,\n transform: [{\n rotate: rotateNext\n }]\n }],\n testID: `${testID}-current`\n }, /*#__PURE__*/React.createElement(Icon, {\n source: currentIcon,\n size: size,\n color: color,\n theme: theme\n })));\n};\nexport default CrossFadeIcon;\nconst styles = StyleSheet.create({\n content: {\n alignItems: 'center',\n justifyContent: 'center'\n },\n icon: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0\n }\n});\n//# sourceMappingURL=CrossFadeIcon.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Dimensions, Easing, findNodeHandle, I18nManager, Keyboard, Platform, ScrollView, StyleSheet, View, Pressable } from 'react-native';\nimport MenuItem from './MenuItem';\nimport { APPROX_STATUSBAR_HEIGHT } from '../../constants';\nimport { withInternalTheme } from '../../core/theming';\nimport { ElevationLevels } from '../../types';\nimport { addEventListener } from '../../utils/addEventListener';\nimport { BackHandler } from '../../utils/BackHandler/BackHandler';\nimport Portal from '../Portal/Portal';\nimport Surface from '../Surface';\n// Minimum padding between the edge of the screen and the menu\nconst SCREEN_INDENT = 8;\n// From https://material.io/design/motion/speed.html#duration\nconst ANIMATION_DURATION = 250;\n// From the 'Standard easing' section of https://material.io/design/motion/speed.html#easing\nconst EASING = Easing.bezier(0.4, 0, 0.2, 1);\nconst WINDOW_LAYOUT = Dimensions.get('window');\nconst DEFAULT_ELEVATION = 2;\nexport const ELEVATION_LEVELS_MAP = Object.values(ElevationLevels);\nconst DEFAULT_MODE = 'elevated';\n\n/**\n * Menus display a list of choices on temporary elevated surfaces. Their placement varies based on the element that opens them.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { Button, Menu, Divider, PaperProvider } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const openMenu = () => setVisible(true);\n *\n * const closeMenu = () => setVisible(false);\n *\n * return (\n * \n * \n * Show menu}>\n * {}} title=\"Item 1\" />\n * {}} title=\"Item 2\" />\n * \n * {}} title=\"Item 3\" />\n * \n *
\n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n *\n * ### Note\n * When using `Menu` within a React Native's `Modal` component, you need to wrap all\n * `Modal` contents within a `PaperProvider` in order for the menu to show. This\n * wrapping is not necessary if you use Paper's `Modal` instead.\n */\nclass Menu extends React.Component {\n // @component ./MenuItem.tsx\n static Item = MenuItem;\n static defaultProps = {\n statusBarHeight: APPROX_STATUSBAR_HEIGHT,\n overlayAccessibilityLabel: 'Close menu',\n testID: 'menu'\n };\n static getDerivedStateFromProps(nextProps, prevState) {\n if (nextProps.visible && !prevState.rendered) {\n return {\n rendered: true\n };\n }\n return null;\n }\n state = {\n rendered: this.props.visible,\n top: 0,\n left: 0,\n menuLayout: {\n width: 0,\n height: 0\n },\n anchorLayout: {\n width: 0,\n height: 0\n },\n opacityAnimation: new Animated.Value(0),\n scaleAnimation: new Animated.ValueXY({\n x: 0,\n y: 0\n }),\n windowLayout: {\n width: WINDOW_LAYOUT.width,\n height: WINDOW_LAYOUT.height\n }\n };\n componentDidMount() {\n this.keyboardDidShowListener = Keyboard.addListener('keyboardDidShow', this.keyboardDidShow);\n this.keyboardDidHideListener = Keyboard.addListener('keyboardDidHide', this.keyboardDidHide);\n }\n componentDidUpdate(prevProps) {\n if (prevProps.visible !== this.props.visible) {\n this.updateVisibility();\n }\n }\n componentWillUnmount() {\n var _this$keyboardDidShow, _this$keyboardDidHide;\n this.removeListeners();\n (_this$keyboardDidShow = this.keyboardDidShowListener) === null || _this$keyboardDidShow === void 0 ? void 0 : _this$keyboardDidShow.remove();\n (_this$keyboardDidHide = this.keyboardDidHideListener) === null || _this$keyboardDidHide === void 0 ? void 0 : _this$keyboardDidHide.remove();\n }\n anchor = null;\n menu = null;\n keyboardHeight = 0;\n isCoordinate = anchor => ! /*#__PURE__*/React.isValidElement(anchor) && typeof (anchor === null || anchor === void 0 ? void 0 : anchor.x) === 'number' && typeof (anchor === null || anchor === void 0 ? void 0 : anchor.y) === 'number';\n measureMenuLayout = () => new Promise(resolve => {\n if (this.menu) {\n this.menu.measureInWindow((x, y, width, height) => {\n resolve({\n x,\n y,\n width,\n height\n });\n });\n }\n });\n measureAnchorLayout = () => new Promise(resolve => {\n const {\n anchor\n } = this.props;\n if (this.isCoordinate(anchor)) {\n resolve({\n x: anchor.x,\n y: anchor.y,\n width: 0,\n height: 0\n });\n return;\n }\n if (this.anchor) {\n this.anchor.measureInWindow((x, y, width, height) => {\n resolve({\n x,\n y,\n width,\n height\n });\n });\n }\n });\n updateVisibility = async () => {\n // Menu is rendered in Portal, which updates items asynchronously\n // We need to do the same here so that the ref is up-to-date\n await Promise.resolve();\n if (this.props.visible) {\n this.show();\n } else {\n this.hide();\n }\n };\n isBrowser = () => Platform.OS === 'web' && 'document' in global;\n focusFirstDOMNode = el => {\n if (el && this.isBrowser()) {\n // When in the browser, we want to focus the first focusable item on toggle\n // For example, when menu is shown, focus the first item in the menu\n // And when menu is dismissed, send focus back to the button to resume tabbing\n const node = findNodeHandle(el);\n const focusableNode = node.querySelector(\n // This is a rough list of selectors that can be focused\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])');\n focusableNode === null || focusableNode === void 0 ? void 0 : focusableNode.focus();\n }\n };\n handleDismiss = () => {\n if (this.props.visible) {\n var _this$props$onDismiss, _this$props;\n (_this$props$onDismiss = (_this$props = this.props).onDismiss) === null || _this$props$onDismiss === void 0 ? void 0 : _this$props$onDismiss.call(_this$props);\n }\n return true;\n };\n handleKeypress = e => {\n if (e.key === 'Escape') {\n var _this$props$onDismiss2, _this$props2;\n (_this$props$onDismiss2 = (_this$props2 = this.props).onDismiss) === null || _this$props$onDismiss2 === void 0 ? void 0 : _this$props$onDismiss2.call(_this$props2);\n }\n };\n attachListeners = () => {\n this.backHandlerSubscription = addEventListener(BackHandler, 'hardwareBackPress', this.handleDismiss);\n this.dimensionsSubscription = addEventListener(Dimensions, 'change', this.handleDismiss);\n this.isBrowser() && document.addEventListener('keyup', this.handleKeypress);\n };\n removeListeners = () => {\n var _this$backHandlerSubs, _this$dimensionsSubsc;\n (_this$backHandlerSubs = this.backHandlerSubscription) === null || _this$backHandlerSubs === void 0 ? void 0 : _this$backHandlerSubs.remove();\n (_this$dimensionsSubsc = this.dimensionsSubscription) === null || _this$dimensionsSubsc === void 0 ? void 0 : _this$dimensionsSubsc.remove();\n this.isBrowser() && document.removeEventListener('keyup', this.handleKeypress);\n };\n show = async () => {\n const windowLayout = Dimensions.get('window');\n const [menuLayout, anchorLayout] = await Promise.all([this.measureMenuLayout(), this.measureAnchorLayout()]);\n\n // When visible is true for first render\n // native views can be still not rendered and\n // measureMenuLayout/measureAnchorLayout functions\n // return wrong values e.g { x:0, y: 0, width: 0, height: 0 }\n // so we have to wait until views are ready\n // and rerun this function to show menu\n if (!windowLayout.width || !windowLayout.height || !menuLayout.width || !menuLayout.height || !anchorLayout.width && !this.isCoordinate(this.props.anchor) || !anchorLayout.height && !this.isCoordinate(this.props.anchor)) {\n requestAnimationFrame(this.show);\n return;\n }\n this.setState(() => ({\n left: anchorLayout.x,\n top: anchorLayout.y,\n anchorLayout: {\n height: anchorLayout.height,\n width: anchorLayout.width\n },\n menuLayout: {\n width: menuLayout.width,\n height: menuLayout.height\n },\n windowLayout: {\n height: windowLayout.height - this.keyboardHeight,\n width: windowLayout.width\n }\n }), () => {\n this.attachListeners();\n const {\n animation\n } = this.props.theme;\n Animated.parallel([Animated.timing(this.state.scaleAnimation, {\n toValue: {\n x: menuLayout.width,\n y: menuLayout.height\n },\n duration: ANIMATION_DURATION * animation.scale,\n easing: EASING,\n useNativeDriver: true\n }), Animated.timing(this.state.opacityAnimation, {\n toValue: 1,\n duration: ANIMATION_DURATION * animation.scale,\n easing: EASING,\n useNativeDriver: true\n })]).start(_ref => {\n let {\n finished\n } = _ref;\n if (finished) {\n this.focusFirstDOMNode(this.menu);\n }\n });\n });\n };\n hide = () => {\n this.removeListeners();\n const {\n animation\n } = this.props.theme;\n Animated.timing(this.state.opacityAnimation, {\n toValue: 0,\n duration: ANIMATION_DURATION * animation.scale,\n easing: EASING,\n useNativeDriver: true\n }).start(_ref2 => {\n let {\n finished\n } = _ref2;\n if (finished) {\n this.setState({\n menuLayout: {\n width: 0,\n height: 0\n },\n rendered: false\n });\n this.state.scaleAnimation.setValue({\n x: 0,\n y: 0\n });\n this.focusFirstDOMNode(this.anchor);\n }\n });\n };\n keyboardDidShow = e => {\n const keyboardHeight = e.endCoordinates.height;\n this.keyboardHeight = keyboardHeight;\n };\n keyboardDidHide = () => {\n this.keyboardHeight = 0;\n };\n render() {\n const {\n visible,\n anchor,\n anchorPosition,\n contentStyle,\n style,\n elevation = DEFAULT_ELEVATION,\n mode = DEFAULT_MODE,\n children,\n theme,\n statusBarHeight,\n onDismiss,\n overlayAccessibilityLabel,\n keyboardShouldPersistTaps,\n testID\n } = this.props;\n const {\n rendered,\n menuLayout,\n anchorLayout,\n opacityAnimation,\n scaleAnimation,\n windowLayout\n } = this.state;\n let {\n left,\n top\n } = this.state;\n if (!this.isCoordinate(this.anchor) && anchorPosition === 'bottom') {\n top += anchorLayout.height;\n }\n\n // I don't know why but on Android measure function is wrong by 24\n const additionalVerticalValue = Platform.select({\n android: statusBarHeight,\n default: 0\n });\n const scaleTransforms = [{\n scaleX: scaleAnimation.x.interpolate({\n inputRange: [0, menuLayout.width],\n outputRange: [0, 1]\n })\n }, {\n scaleY: scaleAnimation.y.interpolate({\n inputRange: [0, menuLayout.height],\n outputRange: [0, 1]\n })\n }];\n\n // We need to translate menu while animating scale to imitate transform origin for scale animation\n const positionTransforms = [];\n\n // Check if menu fits horizontally and if not align it to right.\n if (left <= windowLayout.width - menuLayout.width - SCREEN_INDENT) {\n positionTransforms.push({\n translateX: scaleAnimation.x.interpolate({\n inputRange: [0, menuLayout.width],\n outputRange: [-(menuLayout.width / 2), 0]\n })\n });\n\n // Check if menu position has enough space from left side\n if (left < SCREEN_INDENT) {\n left = SCREEN_INDENT;\n }\n } else {\n positionTransforms.push({\n translateX: scaleAnimation.x.interpolate({\n inputRange: [0, menuLayout.width],\n outputRange: [menuLayout.width / 2, 0]\n })\n });\n left += anchorLayout.width - menuLayout.width;\n const right = left + menuLayout.width;\n // Check if menu position has enough space from right side\n if (right > windowLayout.width - SCREEN_INDENT) {\n left = windowLayout.width - SCREEN_INDENT - menuLayout.width;\n }\n }\n\n // If the menu is larger than available vertical space,\n // calculate the height of scrollable view\n let scrollableMenuHeight = 0;\n\n // Check if the menu should be scrollable\n if (\n // Check if the menu overflows from bottom side\n top >= windowLayout.height - menuLayout.height - SCREEN_INDENT - additionalVerticalValue &&\n // And bottom side of the screen has more space than top side\n top <= windowLayout.height - top) {\n // Scrollable menu should be below the anchor (expands downwards)\n scrollableMenuHeight = windowLayout.height - top - SCREEN_INDENT - additionalVerticalValue;\n } else if (\n // Check if the menu overflows from bottom side\n top >= windowLayout.height - menuLayout.height - SCREEN_INDENT - additionalVerticalValue &&\n // And top side of the screen has more space than bottom side\n top >= windowLayout.height - top &&\n // And menu overflows from top side\n top <= menuLayout.height - anchorLayout.height + SCREEN_INDENT - additionalVerticalValue) {\n // Scrollable menu should be above the anchor (expands upwards)\n scrollableMenuHeight = top + anchorLayout.height - SCREEN_INDENT + additionalVerticalValue;\n }\n\n // Scrollable menu max height\n scrollableMenuHeight = scrollableMenuHeight > windowLayout.height - 2 * SCREEN_INDENT ? windowLayout.height - 2 * SCREEN_INDENT : scrollableMenuHeight;\n\n // Menu is typically positioned below the element that generates it\n // So first check if it fits below the anchor (expands downwards)\n if (\n // Check if menu fits vertically\n top <= windowLayout.height - menuLayout.height - SCREEN_INDENT - additionalVerticalValue ||\n // Or if the menu overflows from bottom side\n top >= windowLayout.height - menuLayout.height - SCREEN_INDENT - additionalVerticalValue &&\n // And bottom side of the screen has more space than top side\n top <= windowLayout.height - top) {\n positionTransforms.push({\n translateY: scaleAnimation.y.interpolate({\n inputRange: [0, menuLayout.height],\n outputRange: [-((scrollableMenuHeight || menuLayout.height) / 2), 0]\n })\n });\n\n // Check if menu position has enough space from top side\n if (top < SCREEN_INDENT) {\n top = SCREEN_INDENT;\n }\n } else {\n positionTransforms.push({\n translateY: scaleAnimation.y.interpolate({\n inputRange: [0, menuLayout.height],\n outputRange: [(scrollableMenuHeight || menuLayout.height) / 2, 0]\n })\n });\n top += anchorLayout.height - (scrollableMenuHeight || menuLayout.height);\n const bottom = top + (scrollableMenuHeight || menuLayout.height) + additionalVerticalValue;\n\n // Check if menu position has enough space from bottom side\n if (bottom > windowLayout.height - SCREEN_INDENT) {\n top = scrollableMenuHeight === windowLayout.height - 2 * SCREEN_INDENT ? -SCREEN_INDENT * 2 : windowLayout.height - menuLayout.height - SCREEN_INDENT - additionalVerticalValue;\n }\n }\n const shadowMenuContainerStyle = {\n opacity: opacityAnimation,\n transform: scaleTransforms,\n borderRadius: theme.roundness,\n ...(!theme.isV3 && {\n elevation: 8\n }),\n ...(scrollableMenuHeight ? {\n height: scrollableMenuHeight\n } : {})\n };\n const positionStyle = {\n top: this.isCoordinate(anchor) ? top : top + additionalVerticalValue,\n ...(I18nManager.getConstants().isRTL ? {\n right: left\n } : {\n left\n })\n };\n const pointerEvents = visible ? 'box-none' : 'none';\n return /*#__PURE__*/React.createElement(View, {\n ref: ref => {\n this.anchor = ref;\n },\n collapsable: false\n }, this.isCoordinate(anchor) ? null : anchor, rendered ? /*#__PURE__*/React.createElement(Portal, null, /*#__PURE__*/React.createElement(Pressable, {\n accessibilityLabel: overlayAccessibilityLabel,\n accessibilityRole: \"button\",\n onPress: onDismiss,\n style: styles.pressableOverlay\n }), /*#__PURE__*/React.createElement(View, {\n ref: ref => {\n this.menu = ref;\n },\n collapsable: false,\n accessibilityViewIsModal: visible,\n style: [styles.wrapper, positionStyle, style],\n pointerEvents: pointerEvents,\n onAccessibilityEscape: onDismiss,\n testID: `${testID}-view`\n }, /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: pointerEvents,\n style: {\n transform: positionTransforms\n }\n }, /*#__PURE__*/React.createElement(Surface, _extends({\n mode: mode,\n pointerEvents: pointerEvents,\n style: [styles.shadowMenuContainer, shadowMenuContainerStyle, theme.isV3 && {\n backgroundColor: theme.colors.elevation[ELEVATION_LEVELS_MAP[elevation]]\n }, contentStyle]\n }, theme.isV3 && {\n elevation\n }, {\n testID: `${testID}-surface`,\n theme: theme\n }), scrollableMenuHeight && /*#__PURE__*/React.createElement(ScrollView, {\n keyboardShouldPersistTaps: keyboardShouldPersistTaps\n }, children) || /*#__PURE__*/React.createElement(React.Fragment, null, children))))) : null);\n }\n}\nconst styles = StyleSheet.create({\n wrapper: {\n position: 'absolute'\n },\n shadowMenuContainer: {\n opacity: 0,\n paddingVertical: 8\n },\n pressableOverlay: {\n ...StyleSheet.absoluteFillObject,\n ...(Platform.OS === 'web' && {\n cursor: 'default'\n }),\n width: '100%'\n }\n});\nexport default withInternalTheme(Menu);\n//# sourceMappingURL=Menu.js.map","import * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { getContentMaxWidth, getMenuItemColor, MAX_WIDTH, MIN_WIDTH } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport Icon from '../Icon';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * A component to show a single list item inside a Menu.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { Menu } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * {}} title=\"Redo\" />\n * {}} title=\"Undo\" />\n * {}} title=\"Cut\" disabled />\n * {}} title=\"Copy\" disabled />\n * {}} title=\"Paste\" />\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst MenuItem = _ref => {\n let {\n leadingIcon,\n trailingIcon,\n dense,\n title,\n disabled,\n background,\n onPress,\n style,\n contentStyle,\n titleStyle,\n rippleColor: customRippleColor,\n testID = 'menu-item',\n accessibilityLabel,\n accessibilityState,\n theme: themeOverrides,\n titleMaxFontSizeMultiplier = 1.5\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n titleColor,\n iconColor,\n rippleColor\n } = getMenuItemColor({\n theme,\n disabled,\n customRippleColor\n });\n const {\n isV3\n } = theme;\n const containerPadding = isV3 ? 12 : 8;\n const iconWidth = isV3 ? 24 : 40;\n const minWidth = MIN_WIDTH - (isV3 ? 12 : 16);\n const maxWidth = getContentMaxWidth({\n isV3,\n iconWidth,\n leadingIcon,\n trailingIcon\n });\n const titleTextStyle = {\n color: titleColor,\n ...(isV3 ? theme.fonts.bodyLarge : {})\n };\n const newAccessibilityState = {\n ...accessibilityState,\n disabled\n };\n return /*#__PURE__*/React.createElement(TouchableRipple, {\n style: [styles.container, {\n paddingHorizontal: containerPadding\n }, dense && styles.md3DenseContainer, style],\n onPress: onPress,\n disabled: disabled,\n testID: testID,\n background: background,\n accessibilityLabel: accessibilityLabel,\n accessibilityRole: \"menuitem\",\n accessibilityState: newAccessibilityState,\n rippleColor: rippleColor\n }, /*#__PURE__*/React.createElement(View, {\n style: styles.row\n }, leadingIcon ? /*#__PURE__*/React.createElement(View, {\n style: [!isV3 && styles.item, {\n width: iconWidth\n }],\n pointerEvents: \"box-none\"\n }, /*#__PURE__*/React.createElement(Icon, {\n source: leadingIcon,\n size: 24,\n color: iconColor\n })) : null, /*#__PURE__*/React.createElement(View, {\n style: [!isV3 && styles.item, styles.content, {\n minWidth,\n maxWidth\n }, isV3 && (leadingIcon ? styles.md3LeadingIcon : styles.md3WithoutLeadingIcon), contentStyle],\n pointerEvents: \"none\"\n }, /*#__PURE__*/React.createElement(Text, {\n variant: \"bodyLarge\",\n selectable: false,\n numberOfLines: 1,\n testID: `${testID}-title`,\n style: [!isV3 && styles.title, titleTextStyle, titleStyle],\n maxFontSizeMultiplier: titleMaxFontSizeMultiplier\n }, title)), isV3 && trailingIcon ? /*#__PURE__*/React.createElement(View, {\n style: [!isV3 && styles.item, {\n width: iconWidth\n }],\n pointerEvents: \"box-none\"\n }, /*#__PURE__*/React.createElement(Icon, {\n source: trailingIcon,\n size: 24,\n color: iconColor\n })) : null));\n};\nMenuItem.displayName = 'Menu.Item';\nconst styles = StyleSheet.create({\n container: {\n minWidth: MIN_WIDTH,\n maxWidth: MAX_WIDTH,\n height: 48,\n justifyContent: 'center'\n },\n md3DenseContainer: {\n height: 32\n },\n row: {\n flexDirection: 'row'\n },\n title: {\n fontSize: 16\n },\n item: {\n marginHorizontal: 8\n },\n content: {\n justifyContent: 'center'\n },\n md3LeadingIcon: {\n marginLeft: 12\n },\n md3WithoutLeadingIcon: {\n marginLeft: 4\n }\n});\nexport default MenuItem;\n//# sourceMappingURL=MenuItem.js.map","import color from 'color';\nimport { black, white } from '../../styles/themes/v2/colors';\nexport const MIN_WIDTH = 112;\nexport const MAX_WIDTH = 280;\nconst getDisabledColor = theme => {\n if (theme.isV3) {\n return theme.colors.onSurfaceDisabled;\n }\n return color(theme.dark ? white : black).alpha(0.32).rgb().string();\n};\nconst getTitleColor = _ref => {\n let {\n theme,\n disabled\n } = _ref;\n if (disabled) {\n return getDisabledColor(theme);\n }\n if (theme.isV3) {\n return theme.colors.onSurface;\n }\n return color(theme.colors.text).alpha(0.87).rgb().string();\n};\nconst getIconColor = _ref2 => {\n let {\n theme,\n disabled\n } = _ref2;\n if (disabled) {\n return getDisabledColor(theme);\n }\n if (theme.isV3) {\n return theme.colors.onSurfaceVariant;\n }\n return color(theme.colors.text).alpha(0.54).rgb().string();\n};\nconst getRippleColor = _ref3 => {\n let {\n theme,\n customRippleColor\n } = _ref3;\n if (customRippleColor) {\n return customRippleColor;\n }\n if (theme.isV3) {\n return color(theme.colors.onSurfaceVariant).alpha(0.12).rgb().string();\n }\n return undefined;\n};\nexport const getMenuItemColor = _ref4 => {\n let {\n theme,\n disabled,\n customRippleColor\n } = _ref4;\n return {\n titleColor: getTitleColor({\n theme,\n disabled\n }),\n iconColor: getIconColor({\n theme,\n disabled\n }),\n rippleColor: getRippleColor({\n theme,\n customRippleColor\n })\n };\n};\nexport const getContentMaxWidth = _ref5 => {\n let {\n isV3,\n iconWidth,\n leadingIcon,\n trailingIcon\n } = _ref5;\n if (isV3) {\n if (leadingIcon && trailingIcon) {\n return MAX_WIDTH - (2 * iconWidth + 24);\n }\n if (leadingIcon || trailingIcon) {\n return MAX_WIDTH - (iconWidth + 24);\n }\n return MAX_WIDTH - 12;\n }\n if (leadingIcon) {\n return MAX_WIDTH - (iconWidth + 48);\n }\n return MAX_WIDTH - 16;\n};\n//# sourceMappingURL=utils.js.map","var _NativeModules$Native;\nimport { NativeModules, Platform } from 'react-native';\n\n// Use the existence of expo-constants as a heuristic for determining if the\n// status bar is translucent on Android. This should be replaced in the future\n// with react-native-safe-area-context.\nconst estimatedStatusBarHeight = ((_NativeModules$Native = NativeModules.NativeUnimoduleProxy) === null || _NativeModules$Native === void 0 || (_NativeModules$Native = _NativeModules$Native.modulesConstants) === null || _NativeModules$Native === void 0 || (_NativeModules$Native = _NativeModules$Native.ExponentConstants) === null || _NativeModules$Native === void 0 ? void 0 : _NativeModules$Native.statusBarHeight) ?? 0;\nexport const APPROX_STATUSBAR_HEIGHT = Platform.select({\n android: estimatedStatusBarHeight,\n ios: Platform.Version < 11 ? estimatedStatusBarHeight : 0\n});\n//# sourceMappingURL=constants.js.map","// MD3 types\nexport let MD3TypescaleKey = /*#__PURE__*/function (MD3TypescaleKey) {\n MD3TypescaleKey[\"displayLarge\"] = \"displayLarge\";\n MD3TypescaleKey[\"displayMedium\"] = \"displayMedium\";\n MD3TypescaleKey[\"displaySmall\"] = \"displaySmall\";\n MD3TypescaleKey[\"headlineLarge\"] = \"headlineLarge\";\n MD3TypescaleKey[\"headlineMedium\"] = \"headlineMedium\";\n MD3TypescaleKey[\"headlineSmall\"] = \"headlineSmall\";\n MD3TypescaleKey[\"titleLarge\"] = \"titleLarge\";\n MD3TypescaleKey[\"titleMedium\"] = \"titleMedium\";\n MD3TypescaleKey[\"titleSmall\"] = \"titleSmall\";\n MD3TypescaleKey[\"labelLarge\"] = \"labelLarge\";\n MD3TypescaleKey[\"labelMedium\"] = \"labelMedium\";\n MD3TypescaleKey[\"labelSmall\"] = \"labelSmall\";\n MD3TypescaleKey[\"bodyLarge\"] = \"bodyLarge\";\n MD3TypescaleKey[\"bodyMedium\"] = \"bodyMedium\";\n MD3TypescaleKey[\"bodySmall\"] = \"bodySmall\";\n return MD3TypescaleKey;\n}({});\nexport let ElevationLevels = /*#__PURE__*/function (ElevationLevels) {\n ElevationLevels[ElevationLevels[\"level0\"] = 0] = \"level0\";\n ElevationLevels[ElevationLevels[\"level1\"] = 1] = \"level1\";\n ElevationLevels[ElevationLevels[\"level2\"] = 2] = \"level2\";\n ElevationLevels[ElevationLevels[\"level3\"] = 3] = \"level3\";\n ElevationLevels[ElevationLevels[\"level4\"] = 4] = \"level4\";\n ElevationLevels[ElevationLevels[\"level5\"] = 5] = \"level5\";\n return ElevationLevels;\n}({});\n//# sourceMappingURL=types.js.map","function emptyFunction() {}\nexport const BackHandler = {\n exitApp: emptyFunction,\n addEventListener() {\n return {\n remove: emptyFunction\n };\n },\n removeEventListener: emptyFunction\n};\n//# sourceMappingURL=BackHandler.js.map","import * as React from 'react';\nimport PortalConsumer from './PortalConsumer';\nimport PortalHost, { PortalContext } from './PortalHost';\nimport { Consumer as SettingsConsumer, Provider as SettingsProvider } from '../../core/settings';\nimport { ThemeProvider, withInternalTheme } from '../../core/theming';\n/**\n * Portal allows rendering a component at a different place in the parent tree.\n * You can use it to render content which should appear above other elements, similar to `Modal`.\n * It requires a [`Portal.Host`](PortalHost) component to be rendered somewhere in the parent tree.\n * Note that if you're using the `Provider` component, this already includes a `Portal.Host`.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Portal, Text } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * This is rendered at a different place\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nclass Portal extends React.Component {\n // @component ./PortalHost.tsx\n static Host = PortalHost;\n render() {\n const {\n children,\n theme\n } = this.props;\n return /*#__PURE__*/React.createElement(SettingsConsumer, null, settings => /*#__PURE__*/React.createElement(PortalContext.Consumer, null, manager => /*#__PURE__*/React.createElement(PortalConsumer, {\n manager: manager\n }, /*#__PURE__*/React.createElement(SettingsProvider, {\n value: settings\n }, /*#__PURE__*/React.createElement(ThemeProvider, {\n theme: theme\n }, children)))));\n }\n}\nexport default withInternalTheme(Portal);\n//# sourceMappingURL=Portal.js.map","import * as React from 'react';\nexport default class PortalConsumer extends React.Component {\n componentDidMount() {\n this.checkManager();\n this.key = this.props.manager.mount(this.props.children);\n }\n componentDidUpdate() {\n this.checkManager();\n this.props.manager.update(this.key, this.props.children);\n }\n componentWillUnmount() {\n this.checkManager();\n this.props.manager.unmount(this.key);\n }\n checkManager() {\n if (!this.props.manager) {\n throw new Error('Looks like you forgot to wrap your root component with `Provider` component from `react-native-paper`.\\n\\n' + \"Please read our getting-started guide and make sure you've followed all the required steps.\\n\\n\" + 'https://callstack.github.io/react-native-paper/docs/guides/getting-started');\n }\n }\n render() {\n return null;\n }\n}\n//# sourceMappingURL=PortalConsumer.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { useInternalTheme } from '../../core/theming';\nimport { black, white } from '../../styles/themes/v2/colors';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\n/**\n * A component to show a single row inside of a table.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { DataTable } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * 1\n * 2\n * 3\n * 4\n * \n * );\n *\n * export default MyComponent;\n * ```\n *\n * @extends TouchableRipple props https://callstack.github.io/react-native-paper/docs/components/TouchableRipple\n */\nconst DataTableRow = _ref => {\n let {\n onPress,\n style,\n children,\n pointerEvents,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const borderBottomColor = theme.isV3 ? theme.colors.surfaceVariant : color(theme.dark ? white : black).alpha(0.12).rgb().string();\n return /*#__PURE__*/React.createElement(TouchableRipple, _extends({}, rest, {\n onPress: onPress,\n style: [styles.container, {\n borderBottomColor\n }, style]\n }), /*#__PURE__*/React.createElement(View, {\n style: styles.content,\n pointerEvents: pointerEvents\n }, children));\n};\nDataTableRow.displayName = 'DataTable.Row';\nconst styles = StyleSheet.create({\n container: {\n borderStyle: 'solid',\n borderBottomWidth: StyleSheet.hairlineWidth,\n minHeight: 48,\n paddingHorizontal: 16\n },\n content: {\n flex: 1,\n flexDirection: 'row'\n }\n});\nexport default DataTableRow;\n\n// @component-docs ignore-next-line\nexport { DataTableRow };\n//# sourceMappingURL=DataTableRow.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, I18nManager, Pressable, StyleSheet } from 'react-native';\nimport color from 'color';\nimport { useInternalTheme } from '../../core/theming';\nimport MaterialCommunityIcon from '../MaterialCommunityIcon';\nimport Text from '../Typography/Text';\n/**\n * A component to display title in table header.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { DataTable } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * \n * \n * Dessert\n * \n * Calories\n * Fat (g)\n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\n\nconst DataTableTitle = _ref => {\n var _theme$colors;\n let {\n numeric,\n children,\n onPress,\n sortDirection,\n textStyle,\n style,\n theme: themeOverrides,\n numberOfLines = 1,\n maxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n current: spinAnim\n } = React.useRef(new Animated.Value(sortDirection === 'ascending' ? 0 : 1));\n React.useEffect(() => {\n Animated.timing(spinAnim, {\n toValue: sortDirection === 'ascending' ? 0 : 1,\n duration: 150,\n useNativeDriver: true\n }).start();\n }, [sortDirection, spinAnim]);\n const textColor = theme.isV3 ? theme.colors.onSurface : theme === null || theme === void 0 || (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.text;\n const alphaTextColor = color(textColor).alpha(0.6).rgb().string();\n const spin = spinAnim.interpolate({\n inputRange: [0, 1],\n outputRange: ['0deg', '180deg']\n });\n const icon = sortDirection ? /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.icon, {\n transform: [{\n rotate: spin\n }]\n }]\n }, /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"arrow-up\",\n size: 16,\n color: textColor,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n })) : null;\n return /*#__PURE__*/React.createElement(Pressable, _extends({\n disabled: !onPress,\n onPress: onPress\n }, rest, {\n style: [styles.container, numeric && styles.right, style]\n }), icon, /*#__PURE__*/React.createElement(Text, {\n style: [styles.cell,\n // height must scale with numberOfLines\n {\n maxHeight: 24 * numberOfLines\n },\n // if numberOfLines causes wrap, center is lost. Align directly, sensitive to numeric and RTL\n numberOfLines > 1 ? numeric ? I18nManager.getConstants().isRTL ? styles.leftText : styles.rightText : styles.centerText : {}, sortDirection ? styles.sorted : {\n color: alphaTextColor\n }, textStyle],\n numberOfLines: numberOfLines,\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, children));\n};\nDataTableTitle.displayName = 'DataTable.Title';\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n flexDirection: 'row',\n alignContent: 'center',\n paddingVertical: 12\n },\n rightText: {\n textAlign: 'right'\n },\n leftText: {\n textAlign: 'left'\n },\n centerText: {\n textAlign: 'center'\n },\n right: {\n justifyContent: 'flex-end'\n },\n cell: {\n lineHeight: 24,\n fontSize: 12,\n fontWeight: '500',\n alignItems: 'center'\n },\n sorted: {\n marginLeft: 8\n },\n icon: {\n height: 24,\n justifyContent: 'center'\n }\n});\nexport default DataTableTitle;\n\n// @component-docs ignore-next-line\nexport { DataTableTitle };\n//# sourceMappingURL=DataTableTitle.js.map","import * as React from 'react';\nimport { Platform, StyleSheet } from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport DialogActions from './DialogActions';\nimport DialogContent from './DialogContent';\nimport DialogIcon from './DialogIcon';\nimport DialogScrollArea from './DialogScrollArea';\nimport DialogTitle from './DialogTitle';\nimport { useInternalTheme } from '../../core/theming';\nimport overlay from '../../styles/overlay';\nimport Modal from '../Modal';\nconst DIALOG_ELEVATION = 24;\n\n/**\n * Dialogs inform users about a specific task and may contain critical information, require decisions, or involve multiple tasks.\n * To render the `Dialog` above other components, you'll need to wrap it with the [`Portal`](../../Portal) component.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { Button, Dialog, Portal, PaperProvider, Text } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const showDialog = () => setVisible(true);\n *\n * const hideDialog = () => setVisible(false);\n *\n * return (\n * \n * \n * \n * \n * \n * Alert\n * \n * This is simple dialog\n * \n * \n * \n * \n * \n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst Dialog = _ref => {\n let {\n children,\n dismissable = true,\n dismissableBackButton = dismissable,\n onDismiss,\n visible = false,\n style,\n theme: themeOverrides,\n testID\n } = _ref;\n const {\n right,\n left\n } = useSafeAreaInsets();\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3,\n dark,\n mode,\n colors,\n roundness\n } = theme;\n const borderRadius = (isV3 ? 7 : 1) * roundness;\n const backgroundColorV2 = dark && mode === 'adaptive' ? overlay(DIALOG_ELEVATION, colors === null || colors === void 0 ? void 0 : colors.surface) : colors === null || colors === void 0 ? void 0 : colors.surface;\n const backgroundColor = isV3 ? theme.colors.elevation.level3 : backgroundColorV2;\n return /*#__PURE__*/React.createElement(Modal, {\n dismissable: dismissable,\n dismissableBackButton: dismissableBackButton,\n onDismiss: onDismiss,\n visible: visible,\n contentContainerStyle: [{\n borderRadius,\n backgroundColor,\n marginHorizontal: Math.max(left, right, 26)\n }, styles.container, style],\n theme: theme,\n testID: testID\n }, React.Children.toArray(children).filter(child => child != null && typeof child !== 'boolean').map((child, i) => {\n if (isV3) {\n if (i === 0 && /*#__PURE__*/React.isValidElement(child)) {\n return /*#__PURE__*/React.cloneElement(child, {\n style: [{\n marginTop: 24\n }, child.props.style]\n });\n }\n }\n if (i === 0 && /*#__PURE__*/React.isValidElement(child) && child.type === DialogContent) {\n // Dialog content is the first item, so we add a top padding\n return /*#__PURE__*/React.cloneElement(child, {\n style: [{\n paddingTop: 24\n }, child.props.style]\n });\n }\n return child;\n }));\n};\n\n// @component ./DialogContent.tsx\nDialog.Content = DialogContent;\n// @component ./DialogActions.tsx\nDialog.Actions = DialogActions;\n// @component ./DialogTitle.tsx\nDialog.Title = DialogTitle;\n// @component ./DialogScrollArea.tsx\nDialog.ScrollArea = DialogScrollArea;\n// @component ./DialogIcon.tsx\nDialog.Icon = DialogIcon;\nconst styles = StyleSheet.create({\n container: {\n /**\n * This prevents the shadow from being clipped on Android since Android\n * doesn't support `overflow: visible`.\n * One downside for this fix is that it will disable clicks on the area\n * of the shadow around the dialog, consequently, if you click around the\n * dialog (44 pixel from the top and bottom) it won't be dismissed.\n */\n marginVertical: Platform.OS === 'android' ? 44 : 0,\n elevation: DIALOG_ELEVATION,\n justifyContent: 'flex-start'\n }\n});\nexport default Dialog;\n//# sourceMappingURL=Dialog.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * A component to show a list of actions in a Dialog.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Button, Dialog, Portal } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const hideDialog = () => setVisible(false);\n *\n * return (\n * \n * \n * \n * \n * \n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst DialogActions = props => {\n const {\n isV3\n } = useInternalTheme(props.theme);\n const actionsLength = React.Children.toArray(props.children).length;\n return /*#__PURE__*/React.createElement(View, _extends({}, props, {\n style: [isV3 ? styles.v3Container : styles.container, props.style]\n }), React.Children.map(props.children, (child, i) => /*#__PURE__*/React.isValidElement(child) ? /*#__PURE__*/React.cloneElement(child, {\n compact: true,\n uppercase: !isV3,\n style: [isV3 && {\n marginRight: i + 1 === actionsLength ? 0 : 8\n }, child.props.style]\n }) : child));\n};\nDialogActions.displayName = 'Dialog.Actions';\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'flex-end',\n padding: 8\n },\n v3Container: {\n flexDirection: 'row',\n flexGrow: 1,\n alignItems: 'center',\n justifyContent: 'flex-end',\n paddingBottom: 24,\n paddingHorizontal: 24\n }\n});\nexport default DialogActions;\n//# sourceMappingURL=DialogActions.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { View, StyleSheet } from 'react-native';\n/**\n * A component to show content in a Dialog.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Dialog, Portal, Text } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const hideDialog = () => setVisible(false);\n *\n * return (\n * \n * \n * \n * This is simple dialog\n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst DialogContent = props => /*#__PURE__*/React.createElement(View, _extends({}, props, {\n style: [styles.container, props.style]\n}), props.children);\nDialogContent.displayName = 'Dialog.Content';\nconst styles = StyleSheet.create({\n container: {\n paddingBottom: 24,\n paddingHorizontal: 24\n }\n});\nexport default DialogContent;\n//# sourceMappingURL=DialogContent.js.map","import * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\nimport Icon from '../Icon';\n/**\n * @supported Available in v5.x with theme version 3\n * A component to show an icon in a Dialog.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { StyleSheet } from 'react-native';\n * import { Dialog, Portal, Text } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const hideDialog = () => setVisible(false);\n *\n * return (\n * \n * \n * \n * This is a title\n * \n * This is simple dialog\n * \n * \n * \n * );\n * };\n *\n * const styles = StyleSheet.create({\n * title: {\n * textAlign: 'center',\n * },\n * })\n *\n * export default MyComponent;\n * ```\n */\nconst DialogIcon = _ref => {\n let {\n size = 24,\n color,\n icon,\n theme: themeOverrides\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n if (!theme.isV3) {\n return null;\n }\n\n //@ts-ignore\n const iconColor = color || theme.colors.secondary;\n return /*#__PURE__*/React.createElement(View, {\n style: styles.wrapper\n }, /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n color: iconColor,\n size: size\n }));\n};\nDialogIcon.displayName = 'Dialog.Icon';\nconst styles = StyleSheet.create({\n wrapper: {\n alignItems: 'center',\n justifyContent: 'center',\n paddingTop: 24\n }\n});\nexport default DialogIcon;\n\n// @component-docs ignore-next-line\nexport { DialogIcon };\n//# sourceMappingURL=DialogIcon.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * A component to show a scrollable content in a Dialog. The component only provides appropriate styling.\n * For the scrollable content you can use `ScrollView`, `FlatList` etc. depending on your requirement.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { ScrollView } from 'react-native';\n * import { Dialog, Portal, Text } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const hideDialog = () => setVisible(false);\n *\n * return (\n * \n * \n * \n * \n * This is a scrollable area\n * \n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst DialogScrollArea = props => {\n const theme = useInternalTheme(props.theme);\n const borderStyles = {\n borderColor: theme.isV3 ? theme.colors.surfaceVariant : 'rgba(0, 0, 0, .12)',\n borderTopWidth: theme.isV3 ? 1 : StyleSheet.hairlineWidth,\n borderBottomWidth: theme.isV3 ? 1 : StyleSheet.hairlineWidth\n };\n return /*#__PURE__*/React.createElement(View, _extends({}, props, {\n style: [styles.container, borderStyles, theme.isV3 && styles.v3Container, props.style]\n }), props.children);\n};\nDialogScrollArea.displayName = 'Dialog.ScrollArea';\nconst styles = StyleSheet.create({\n container: {\n paddingHorizontal: 24,\n flexGrow: 1,\n flexShrink: 1\n },\n v3Container: {\n marginBottom: 24\n }\n});\nexport default DialogScrollArea;\n//# sourceMappingURL=DialogScrollArea.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport { useInternalTheme } from '../../core/theming';\nimport Text from '../Typography/Text';\nimport Title from '../Typography/v2/Title';\n/**\n * A component to show a title in a Dialog.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Dialog, Portal, Text } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const hideDialog = () => setVisible(false);\n *\n * return (\n * \n * \n * This is a title\n * \n * This is simple dialog\n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst DialogTitle = _ref => {\n let {\n children,\n theme: themeOverrides,\n style,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3,\n colors,\n fonts\n } = theme;\n const TextComponent = isV3 ? Text : Title;\n const headerTextStyle = {\n color: isV3 ? colors.onSurface : colors === null || colors === void 0 ? void 0 : colors.text,\n ...(isV3 ? fonts.headlineSmall : {})\n };\n return /*#__PURE__*/React.createElement(TextComponent, _extends({\n variant: \"headlineSmall\",\n accessibilityRole: \"header\",\n style: [styles.text, isV3 && styles.v3Text, headerTextStyle, style]\n }, rest), children);\n};\nDialogTitle.displayName = 'Dialog.Title';\nconst styles = StyleSheet.create({\n text: {\n marginTop: 22,\n marginBottom: 18,\n marginHorizontal: 24\n },\n v3Text: {\n marginTop: 16,\n marginBottom: 16\n }\n});\nexport default DialogTitle;\n\n// @component-docs ignore-next-line\nexport { DialogTitle };\n//# sourceMappingURL=DialogTitle.js.map","import * as React from 'react';\nimport { Animated, Easing, StyleSheet, Pressable, View } from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport useLatestCallback from 'use-latest-callback';\nimport Surface from './Surface';\nimport { useInternalTheme } from '../core/theming';\nimport { addEventListener } from '../utils/addEventListener';\nimport { BackHandler } from '../utils/BackHandler/BackHandler';\nimport useAnimatedValue from '../utils/useAnimatedValue';\nconst DEFAULT_DURATION = 220;\nconst AnimatedPressable = Animated.createAnimatedComponent(Pressable);\n\n/**\n * The Modal component is a simple way to present content above an enclosing view.\n * To render the `Modal` above other components, you'll need to wrap it with the [`Portal`](./Portal) component.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Modal, Portal, Text, Button, PaperProvider } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const showModal = () => setVisible(true);\n * const hideModal = () => setVisible(false);\n * const containerStyle = {backgroundColor: 'white', padding: 20};\n *\n * return (\n * \n * \n * \n * Example Modal. Click outside this area to dismiss.\n * \n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nfunction Modal(_ref) {\n var _theme$colors;\n let {\n dismissable = true,\n dismissableBackButton = dismissable,\n visible = false,\n overlayAccessibilityLabel = 'Close modal',\n onDismiss = () => {},\n children,\n contentContainerStyle,\n style,\n theme: themeOverrides,\n testID = 'modal'\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const visibleRef = React.useRef(visible);\n React.useEffect(() => {\n visibleRef.current = visible;\n });\n const onDismissCallback = useLatestCallback(onDismiss);\n const {\n scale\n } = theme.animation;\n const {\n top,\n bottom\n } = useSafeAreaInsets();\n const opacity = useAnimatedValue(visible ? 1 : 0);\n const [rendered, setRendered] = React.useState(visible);\n if (visible && !rendered) {\n setRendered(true);\n }\n const showModal = React.useCallback(() => {\n Animated.timing(opacity, {\n toValue: 1,\n duration: scale * DEFAULT_DURATION,\n easing: Easing.out(Easing.cubic),\n useNativeDriver: true\n }).start();\n }, [opacity, scale]);\n const hideModal = React.useCallback(() => {\n Animated.timing(opacity, {\n toValue: 0,\n duration: scale * DEFAULT_DURATION,\n easing: Easing.out(Easing.cubic),\n useNativeDriver: true\n }).start(_ref2 => {\n let {\n finished\n } = _ref2;\n if (!finished) {\n return;\n }\n if (visible) {\n onDismissCallback();\n }\n if (visibleRef.current) {\n showModal();\n } else {\n setRendered(false);\n }\n });\n }, [onDismissCallback, opacity, scale, showModal, visible]);\n React.useEffect(() => {\n if (!visible) {\n return undefined;\n }\n const onHardwareBackPress = () => {\n if (dismissable || dismissableBackButton) {\n hideModal();\n }\n return true;\n };\n const subscription = addEventListener(BackHandler, 'hardwareBackPress', onHardwareBackPress);\n return () => subscription.remove();\n }, [dismissable, dismissableBackButton, hideModal, visible]);\n const prevVisible = React.useRef(null);\n React.useEffect(() => {\n if (prevVisible.current !== visible) {\n if (visible) {\n showModal();\n } else {\n hideModal();\n }\n }\n prevVisible.current = visible;\n });\n if (!rendered) return null;\n return /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: visible ? 'auto' : 'none',\n accessibilityViewIsModal: true,\n accessibilityLiveRegion: \"polite\",\n style: StyleSheet.absoluteFill,\n onAccessibilityEscape: hideModal,\n testID: testID\n }, /*#__PURE__*/React.createElement(AnimatedPressable, {\n accessibilityLabel: overlayAccessibilityLabel,\n accessibilityRole: \"button\",\n disabled: !dismissable,\n onPress: dismissable ? hideModal : undefined,\n importantForAccessibility: \"no\",\n style: [styles.backdrop, {\n backgroundColor: (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.backdrop,\n opacity\n }],\n testID: `${testID}-backdrop`\n }), /*#__PURE__*/React.createElement(View, {\n style: [styles.wrapper, {\n marginTop: top,\n marginBottom: bottom\n }, style],\n pointerEvents: \"box-none\",\n testID: `${testID}-wrapper`\n }, /*#__PURE__*/React.createElement(Surface, {\n testID: `${testID}-surface`,\n theme: theme,\n style: [{\n opacity\n }, styles.content, contentContainerStyle]\n }, children)));\n}\nexport default Modal;\nconst styles = StyleSheet.create({\n backdrop: {\n flex: 1\n },\n wrapper: {\n ...StyleSheet.absoluteFillObject,\n justifyContent: 'center'\n },\n // eslint-disable-next-line react-native/no-color-literals\n content: {\n backgroundColor: 'transparent',\n justifyContent: 'center'\n }\n});\n//# sourceMappingURL=Modal.js.map","import FABComponent from './FAB';\nimport FABGroup from './FABGroup';\nconst FAB = Object.assign(\n// @component ./FAB.tsx\nFABComponent, {\n // @component ./FABGroup.tsx\n Group: FABGroup\n});\nexport default FAB;\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, StyleSheet, View } from 'react-native';\nimport { getExtendedFabStyle, getFABColors, getFabStyle } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { forwardRef } from '../../utils/forwardRef';\nimport ActivityIndicator from '../ActivityIndicator';\nimport CrossFadeIcon from '../CrossFadeIcon';\nimport Icon from '../Icon';\nimport Surface from '../Surface';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * A floating action button represents the primary action on a screen. It appears in front of all screen content.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { StyleSheet } from 'react-native';\n * import { FAB } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * console.log('Pressed')}\n * />\n * );\n *\n * const styles = StyleSheet.create({\n * fab: {\n * position: 'absolute',\n * margin: 16,\n * right: 0,\n * bottom: 0,\n * },\n * })\n *\n * export default MyComponent;\n * ```\n */\nconst FAB = forwardRef((_ref, ref) => {\n let {\n icon,\n label,\n background,\n accessibilityLabel = label,\n accessibilityState,\n animated = true,\n color: customColor,\n rippleColor: customRippleColor,\n disabled,\n onPress,\n onLongPress,\n delayLongPress,\n theme: themeOverrides,\n style,\n visible = true,\n uppercase: uppercaseProp,\n loading,\n testID = 'fab',\n size = 'medium',\n customSize,\n mode = 'elevated',\n variant = 'primary',\n labelMaxFontSizeMultiplier,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const uppercase = uppercaseProp ?? !theme.isV3;\n const {\n current: visibility\n } = React.useRef(new Animated.Value(visible ? 1 : 0));\n const {\n isV3,\n animation\n } = theme;\n const {\n scale\n } = animation;\n React.useEffect(() => {\n if (visible) {\n Animated.timing(visibility, {\n toValue: 1,\n duration: 200 * scale,\n useNativeDriver: true\n }).start();\n } else {\n Animated.timing(visibility, {\n toValue: 0,\n duration: 150 * scale,\n useNativeDriver: true\n }).start();\n }\n }, [visible, scale, visibility]);\n const IconComponent = animated ? CrossFadeIcon : Icon;\n const fabStyle = getFabStyle({\n customSize,\n size,\n theme\n });\n const {\n borderRadius = fabStyle.borderRadius,\n backgroundColor: customBackgroundColor\n } = StyleSheet.flatten(style) || {};\n const {\n backgroundColor,\n foregroundColor,\n rippleColor\n } = getFABColors({\n theme,\n variant,\n disabled,\n customColor,\n customBackgroundColor,\n customRippleColor\n });\n const isLargeSize = size === 'large';\n const isFlatMode = mode === 'flat';\n const iconSize = isLargeSize ? 36 : 24;\n const loadingIndicatorSize = isLargeSize ? 24 : 18;\n const font = isV3 ? theme.fonts.labelLarge : theme.fonts.medium;\n const extendedStyle = getExtendedFabStyle({\n customSize,\n theme\n });\n const textStyle = {\n color: foregroundColor,\n ...font\n };\n const md3Elevation = isFlatMode || disabled ? 0 : 3;\n const newAccessibilityState = {\n ...accessibilityState,\n disabled\n };\n return /*#__PURE__*/React.createElement(Surface, _extends({\n ref: ref\n }, rest, {\n style: [{\n borderRadius,\n backgroundColor,\n opacity: visibility,\n transform: [{\n scale: visibility\n }]\n }, !isV3 && styles.elevated, !isV3 && disabled && styles.disabled, style],\n pointerEvents: visible ? 'auto' : 'none',\n testID: `${testID}-container`\n }, isV3 && {\n elevation: md3Elevation\n }), /*#__PURE__*/React.createElement(TouchableRipple, _extends({\n borderless: true,\n background: background,\n onPress: onPress,\n onLongPress: onLongPress,\n delayLongPress: delayLongPress,\n rippleColor: rippleColor,\n disabled: disabled,\n accessibilityLabel: accessibilityLabel,\n accessibilityRole: \"button\",\n accessibilityState: newAccessibilityState,\n testID: testID,\n style: {\n borderRadius\n }\n }, rest), /*#__PURE__*/React.createElement(View, {\n style: [styles.content, label ? extendedStyle : fabStyle],\n testID: `${testID}-content`,\n pointerEvents: \"none\"\n }, icon && loading !== true ? /*#__PURE__*/React.createElement(IconComponent, {\n source: icon,\n size: customSize ? customSize / 2 : iconSize,\n color: foregroundColor\n }) : null, loading ? /*#__PURE__*/React.createElement(ActivityIndicator, {\n size: customSize ? customSize / 2 : loadingIndicatorSize,\n color: foregroundColor\n }) : null, label ? /*#__PURE__*/React.createElement(Text, {\n variant: \"labelLarge\",\n selectable: false,\n testID: `${testID}-text`,\n style: [styles.label, uppercase && styles.uppercaseLabel, textStyle],\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier\n }, label) : null)));\n});\nconst styles = StyleSheet.create({\n elevated: {\n elevation: 6\n },\n content: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center'\n },\n label: {\n marginHorizontal: 8\n },\n uppercaseLabel: {\n textTransform: 'uppercase'\n },\n disabled: {\n elevation: 0\n }\n});\nexport default FAB;\n\n// @component-docs ignore-next-line\nexport { FAB };\n//# sourceMappingURL=FAB.js.map","import * as React from 'react';\nimport { Animated, Pressable, StyleSheet, View } from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport FAB from './FAB';\nimport { getFABGroupColors } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport Card from '../Card/Card';\nimport Text from '../Typography/Text';\nconst AnimatedPressable = Animated.createAnimatedComponent(Pressable);\n/**\n * A component to display a stack of FABs with related actions in a speed dial.\n * To render the group above other components, you'll need to wrap it with the [`Portal`](../Portal) component.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { FAB, Portal, PaperProvider } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [state, setState] = React.useState({ open: false });\n *\n * const onStateChange = ({ open }) => setState({ open });\n *\n * const { open } = state;\n *\n * return (\n * \n * \n * console.log('Pressed add') },\n * {\n * icon: 'star',\n * label: 'Star',\n * onPress: () => console.log('Pressed star'),\n * },\n * {\n * icon: 'email',\n * label: 'Email',\n * onPress: () => console.log('Pressed email'),\n * },\n * {\n * icon: 'bell',\n * label: 'Remind',\n * onPress: () => console.log('Pressed notifications'),\n * },\n * ]}\n * onStateChange={onStateChange}\n * onPress={() => {\n * if (open) {\n * // do something if the speed dial is open\n * }\n * }}\n * />\n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst FABGroup = _ref => {\n let {\n actions,\n icon,\n open,\n onPress,\n onLongPress,\n toggleStackOnLongPress,\n accessibilityLabel,\n theme: themeOverrides,\n style,\n fabStyle,\n visible,\n label,\n testID,\n onStateChange,\n color: colorProp,\n delayLongPress = 200,\n variant = 'primary',\n enableLongPressWhenStackOpened = false,\n backdropColor: customBackdropColor,\n rippleColor\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n current: backdrop\n } = React.useRef(new Animated.Value(0));\n const animations = React.useRef(actions.map(() => new Animated.Value(open ? 1 : 0)));\n const [prevActions, setPrevActions] = React.useState(null);\n const {\n scale\n } = theme.animation;\n const {\n isV3\n } = theme;\n React.useEffect(() => {\n if (open) {\n Animated.parallel([Animated.timing(backdrop, {\n toValue: 1,\n duration: 250 * scale,\n useNativeDriver: true\n }), Animated.stagger(isV3 ? 15 : 50 * scale, animations.current.map(animation => Animated.timing(animation, {\n toValue: 1,\n duration: 150 * scale,\n useNativeDriver: true\n })).reverse())]).start();\n } else {\n Animated.parallel([Animated.timing(backdrop, {\n toValue: 0,\n duration: 200 * scale,\n useNativeDriver: true\n }), ...animations.current.map(animation => Animated.timing(animation, {\n toValue: 0,\n duration: 150 * scale,\n useNativeDriver: true\n }))]).start();\n }\n }, [open, actions, backdrop, scale, isV3]);\n const close = () => onStateChange({\n open: false\n });\n const toggle = () => onStateChange({\n open: !open\n });\n const {\n labelColor,\n backdropColor,\n stackedFABBackgroundColor\n } = getFABGroupColors({\n theme,\n customBackdropColor\n });\n const backdropOpacity = open ? backdrop.interpolate({\n inputRange: [0, 0.5, 1],\n outputRange: [0, 1, 1]\n }) : backdrop;\n const opacities = animations.current;\n const scales = opacities.map(opacity => open ? opacity.interpolate({\n inputRange: [0, 1],\n outputRange: [0.5, 1]\n }) : 1);\n const translations = opacities.map(opacity => open ? opacity.interpolate({\n inputRange: [0, 1],\n outputRange: [24, -8]\n }) : -8);\n const labelTranslations = opacities.map(opacity => open ? opacity.interpolate({\n inputRange: [0, 1],\n outputRange: [8, -8]\n }) : -8);\n const {\n top,\n bottom,\n right,\n left\n } = useSafeAreaInsets();\n const containerPaddings = {\n paddingBottom: bottom,\n paddingRight: right,\n paddingLeft: left,\n paddingTop: top\n };\n if (actions.length !== (prevActions === null || prevActions === void 0 ? void 0 : prevActions.length)) {\n animations.current = actions.map((_, i) => animations.current[i] || new Animated.Value(open ? 1 : 0));\n setPrevActions(actions);\n }\n return /*#__PURE__*/React.createElement(View, {\n pointerEvents: \"box-none\",\n style: [styles.container, containerPaddings, style]\n }, /*#__PURE__*/React.createElement(AnimatedPressable, {\n accessibilityRole: \"button\",\n onPress: close,\n pointerEvents: open ? 'auto' : 'none',\n style: [styles.backdrop, {\n opacity: backdropOpacity,\n backgroundColor: backdropColor\n }]\n }), /*#__PURE__*/React.createElement(View, {\n pointerEvents: \"box-none\",\n style: styles.safeArea\n }, /*#__PURE__*/React.createElement(View, {\n pointerEvents: open ? 'box-none' : 'none'\n }, actions.map((it, i) => {\n const labelTextStyle = {\n color: it.labelTextColor ?? labelColor,\n ...(isV3 ? theme.fonts.titleMedium : {})\n };\n const marginHorizontal = typeof it.size === 'undefined' || it.size === 'small' ? 24 : 16;\n const accessibilityLabel = typeof it.accessibilityLabel !== 'undefined' ? it.accessibilityLabel : it.label;\n const size = typeof it.size !== 'undefined' ? it.size : 'small';\n return /*#__PURE__*/React.createElement(View, {\n key: i // eslint-disable-line react/no-array-index-key\n ,\n style: [styles.item, {\n marginHorizontal\n }],\n pointerEvents: open ? 'box-none' : 'none',\n accessibilityRole: \"button\",\n importantForAccessibility: \"yes\",\n accessible: true,\n accessibilityLabel: accessibilityLabel\n }, it.label && /*#__PURE__*/React.createElement(View, null, /*#__PURE__*/React.createElement(Card, {\n mode: isV3 ? 'contained' : 'elevated',\n onPress: e => {\n it.onPress(e);\n close();\n },\n accessibilityHint: it.accessibilityHint,\n importantForAccessibility: \"no-hide-descendants\",\n accessibilityElementsHidden: true,\n style: [styles.containerStyle, {\n transform: [isV3 ? {\n translateY: labelTranslations[i]\n } : {\n scale: scales[i]\n }],\n opacity: opacities[i]\n }, isV3 && styles.v3ContainerStyle, it.containerStyle]\n }, /*#__PURE__*/React.createElement(Text, {\n variant: \"titleMedium\",\n importantForAccessibility: \"no-hide-descendants\",\n accessibilityElementsHidden: true,\n style: [labelTextStyle, it.labelStyle],\n maxFontSizeMultiplier: it.labelMaxFontSizeMultiplier\n }, it.label))), /*#__PURE__*/React.createElement(FAB, {\n size: size,\n icon: it.icon,\n color: it.color,\n style: [{\n transform: [{\n scale: scales[i]\n }],\n opacity: opacities[i],\n backgroundColor: stackedFABBackgroundColor\n }, isV3 && {\n transform: [{\n translateY: translations[i]\n }]\n }, it.style],\n accessibilityElementsHidden: true,\n theme: theme,\n onPress: e => {\n it.onPress(e);\n close();\n },\n importantForAccessibility: \"no-hide-descendants\",\n testID: it.testID,\n visible: open,\n rippleColor: it.rippleColor\n }));\n })), /*#__PURE__*/React.createElement(FAB, {\n onPress: e => {\n onPress === null || onPress === void 0 ? void 0 : onPress(e);\n if (!toggleStackOnLongPress || open) {\n toggle();\n }\n },\n onLongPress: e => {\n if (!open || enableLongPressWhenStackOpened) {\n onLongPress === null || onLongPress === void 0 ? void 0 : onLongPress(e);\n if (toggleStackOnLongPress) {\n toggle();\n }\n }\n },\n delayLongPress: delayLongPress,\n icon: icon,\n color: colorProp,\n accessibilityLabel: accessibilityLabel,\n accessibilityRole: \"button\",\n accessibilityState: {\n expanded: open\n },\n style: [styles.fab, fabStyle],\n theme: theme,\n visible: visible,\n label: label,\n testID: testID,\n variant: variant,\n rippleColor: rippleColor\n })));\n};\nFABGroup.displayName = 'FAB.Group';\nexport default FABGroup;\n\n// @component-docs ignore-next-line\nexport { FABGroup };\nconst styles = StyleSheet.create({\n safeArea: {\n alignItems: 'flex-end'\n },\n container: {\n ...StyleSheet.absoluteFillObject,\n justifyContent: 'flex-end'\n },\n fab: {\n marginHorizontal: 16,\n marginBottom: 16,\n marginTop: 0\n },\n backdrop: {\n ...StyleSheet.absoluteFillObject\n },\n containerStyle: {\n borderRadius: 5,\n paddingHorizontal: 12,\n paddingVertical: 6,\n marginVertical: 8,\n marginHorizontal: 16,\n elevation: 2\n },\n item: {\n marginBottom: 16,\n flexDirection: 'row',\n justifyContent: 'flex-end',\n alignItems: 'center'\n },\n // eslint-disable-next-line react-native/no-color-literals\n v3ContainerStyle: {\n backgroundColor: 'transparent',\n elevation: 0\n }\n});\n//# sourceMappingURL=FABGroup.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, StyleSheet } from 'react-native';\nimport { getTextColor } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport AnimatedText from '../Typography/AnimatedText';\n/**\n * Helper text is used in conjuction with input elements to provide additional hints for the user.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { HelperText, TextInput } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [text, setText] = React.useState('');\n *\n * const onChangeText = text => setText(text);\n *\n * const hasErrors = () => {\n * return !text.includes('@');\n * };\n *\n * return (\n * \n * \n * \n * Email address is invalid!\n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst HelperText = _ref => {\n let {\n style,\n type = 'info',\n visible = true,\n theme: themeOverrides,\n onLayout,\n padding = 'normal',\n disabled,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n current: shown\n } = React.useRef(new Animated.Value(visible ? 1 : 0));\n let {\n current: textHeight\n } = React.useRef(0);\n const {\n scale\n } = theme.animation;\n const {\n maxFontSizeMultiplier = 1.5\n } = rest;\n React.useEffect(() => {\n if (visible) {\n // show text\n Animated.timing(shown, {\n toValue: 1,\n duration: 150 * scale,\n useNativeDriver: true\n }).start();\n } else {\n // hide text\n Animated.timing(shown, {\n toValue: 0,\n duration: 180 * scale,\n useNativeDriver: true\n }).start();\n }\n }, [visible, scale, shown]);\n const handleTextLayout = e => {\n onLayout === null || onLayout === void 0 ? void 0 : onLayout(e);\n textHeight = e.nativeEvent.layout.height;\n };\n const textColor = getTextColor({\n theme,\n disabled,\n type\n });\n return /*#__PURE__*/React.createElement(AnimatedText, _extends({\n onLayout: handleTextLayout,\n style: [styles.text, padding !== 'none' ? styles.padding : {}, {\n color: textColor,\n opacity: shown,\n transform: visible && type === 'error' ? [{\n translateY: shown.interpolate({\n inputRange: [0, 1],\n outputRange: [-textHeight / 2, 0]\n })\n }] : []\n }, style],\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, rest), rest.children);\n};\nconst styles = StyleSheet.create({\n text: {\n fontSize: 12,\n paddingVertical: 4\n },\n padding: {\n paddingHorizontal: 12\n }\n});\nexport default HelperText;\n//# sourceMappingURL=HelperText.js.map","import color from 'color';\nexport function getTextColor(_ref) {\n var _theme$colors;\n let {\n theme,\n disabled,\n type\n } = _ref;\n const {\n colors,\n dark\n } = theme;\n if (type === 'error') {\n return colors === null || colors === void 0 ? void 0 : colors.error;\n }\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n } else {\n return theme.colors.onSurfaceVariant;\n }\n }\n return color(theme === null || theme === void 0 || (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.text).alpha(dark ? 0.7 : 0.54).rgb().string();\n}\n//# sourceMappingURL=utils.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, I18nManager, Platform, StyleSheet, View } from 'react-native';\nimport setColor from 'color';\nimport { useInternalTheme } from '../core/theming';\nconst INDETERMINATE_DURATION = 2000;\nconst INDETERMINATE_MAX_WIDTH = 0.6;\nconst {\n isRTL\n} = I18nManager;\n\n/**\n * Progress bar is an indicator used to present progress of some activity in the app.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { ProgressBar, MD3Colors } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst ProgressBar = _ref => {\n var _theme$colors;\n let {\n color,\n indeterminate,\n progress = 0,\n visible = true,\n theme: themeOverrides,\n animatedValue,\n style,\n fillStyle,\n testID = 'progress-bar',\n ...rest\n } = _ref;\n const isWeb = Platform.OS === 'web';\n const theme = useInternalTheme(themeOverrides);\n const {\n current: timer\n } = React.useRef(new Animated.Value(0));\n const {\n current: fade\n } = React.useRef(new Animated.Value(0));\n const passedAnimatedValue = React.useRef(animatedValue);\n const [width, setWidth] = React.useState(0);\n const [prevWidth, setPrevWidth] = React.useState(0);\n const indeterminateAnimation = React.useRef(null);\n const {\n scale\n } = theme.animation;\n React.useEffect(() => {\n passedAnimatedValue.current = animatedValue;\n });\n const startAnimation = React.useCallback(() => {\n // Show progress bar\n Animated.timing(fade, {\n duration: 200 * scale,\n toValue: 1,\n useNativeDriver: true,\n isInteraction: false\n }).start();\n\n /**\n * We shouldn't add @param animatedValue to the\n * deps array, to avoid the unnecessary loop.\n * We can only check if the prop is passed initially,\n * and we do early return.\n */\n const externalAnimation = typeof passedAnimatedValue.current !== 'undefined' && passedAnimatedValue.current >= 0;\n if (externalAnimation) {\n return;\n }\n\n // Animate progress bar\n if (indeterminate) {\n if (!indeterminateAnimation.current) {\n indeterminateAnimation.current = Animated.timing(timer, {\n duration: INDETERMINATE_DURATION,\n toValue: 1,\n // Animated.loop does not work if useNativeDriver is true on web\n useNativeDriver: !isWeb,\n isInteraction: false\n });\n }\n\n // Reset timer to the beginning\n timer.setValue(0);\n Animated.loop(indeterminateAnimation.current).start();\n } else {\n Animated.timing(timer, {\n duration: 200 * scale,\n toValue: progress ? progress : 0,\n useNativeDriver: true,\n isInteraction: false\n }).start();\n }\n }, [fade, scale, indeterminate, timer, progress, isWeb]);\n const stopAnimation = React.useCallback(() => {\n // Stop indeterminate animation\n if (indeterminateAnimation.current) {\n indeterminateAnimation.current.stop();\n }\n Animated.timing(fade, {\n duration: 200 * scale,\n toValue: 0,\n useNativeDriver: true,\n isInteraction: false\n }).start();\n }, [fade, scale]);\n React.useEffect(() => {\n if (visible) startAnimation();else stopAnimation();\n }, [visible, startAnimation, stopAnimation]);\n React.useEffect(() => {\n if (animatedValue && animatedValue >= 0) {\n timer.setValue(animatedValue);\n }\n }, [animatedValue, timer]);\n React.useEffect(() => {\n // Start animation the very first time when previously the width was unclear\n if (visible && prevWidth === 0) {\n startAnimation();\n }\n }, [prevWidth, startAnimation, visible]);\n const onLayout = event => {\n setPrevWidth(width);\n setWidth(event.nativeEvent.layout.width);\n };\n const tintColor = color || ((_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.primary);\n const trackTintColor = theme.isV3 ? theme.colors.surfaceVariant : setColor(tintColor).alpha(0.38).rgb().string();\n return /*#__PURE__*/React.createElement(View, _extends({\n onLayout: onLayout\n }, rest, {\n accessible: true,\n accessibilityRole: \"progressbar\",\n accessibilityState: {\n busy: visible\n },\n accessibilityValue: indeterminate ? {} : {\n min: 0,\n max: 100,\n now: progress * 100\n },\n style: isWeb && styles.webContainer,\n testID: testID\n }), /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.container, {\n backgroundColor: trackTintColor,\n opacity: fade\n }, style]\n }, width ? /*#__PURE__*/React.createElement(Animated.View, {\n testID: `${testID}-fill`,\n style: [styles.progressBar, {\n width,\n backgroundColor: tintColor,\n transform: [{\n translateX: timer.interpolate(indeterminate ? {\n inputRange: [0, 0.5, 1],\n outputRange: [(isRTL ? 1 : -1) * 0.5 * width, (isRTL ? 1 : -1) * 0.5 * INDETERMINATE_MAX_WIDTH * width, (isRTL ? -1 : 1) * 0.7 * width]\n } : {\n inputRange: [0, 1],\n outputRange: [(isRTL ? 1 : -1) * 0.5 * width, 0]\n })\n }, {\n // Workaround for workaround for https://github.com/facebook/react-native/issues/6278\n scaleX: timer.interpolate(indeterminate ? {\n inputRange: [0, 0.5, 1],\n outputRange: [0.0001, INDETERMINATE_MAX_WIDTH, 0.0001]\n } : {\n inputRange: [0, 1],\n outputRange: [0.0001, 1]\n })\n }]\n }, fillStyle]\n }) : null));\n};\nconst styles = StyleSheet.create({\n container: {\n height: 4,\n overflow: 'hidden'\n },\n webContainer: {\n width: '100%',\n height: '100%'\n },\n progressBar: {\n flex: 1\n }\n});\nexport default ProgressBar;\n//# sourceMappingURL=ProgressBar.js.map","import RadioButtonComponent from './RadioButton';\nimport RadioButtonAndroid from './RadioButtonAndroid';\nimport RadioButtonGroup from './RadioButtonGroup';\nimport RadioButtonIOS from './RadioButtonIOS';\nimport RadioButtonItem from './RadioButtonItem';\nconst RadioButton = Object.assign(\n// @component ./RadioButton.tsx\nRadioButtonComponent, {\n // @component ./RadioButtonGroup.tsx\n Group: RadioButtonGroup,\n // @component ./RadioButtonAndroid.tsx\n Android: RadioButtonAndroid,\n // @component ./RadioButtonIOS.tsx\n IOS: RadioButtonIOS,\n // @component ./RadioButtonItem.tsx\n Item: RadioButtonItem\n});\nexport default RadioButton;\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Platform } from 'react-native';\nimport RadioButtonAndroid from './RadioButtonAndroid';\nimport RadioButtonIOS from './RadioButtonIOS';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * Radio buttons allow the selection a single option from a set.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { RadioButton } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [checked, setChecked] = React.useState('first');\n *\n * return (\n * \n * setChecked('first')}\n * />\n * setChecked('second')}\n * />\n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst RadioButton = _ref => {\n let {\n theme: themeOverrides,\n ...props\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const Button = Platform.select({\n default: RadioButtonAndroid,\n ios: RadioButtonIOS\n });\n return /*#__PURE__*/React.createElement(Button, _extends({}, props, {\n theme: theme\n }));\n};\nexport default RadioButton;\n//# sourceMappingURL=RadioButton.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, StyleSheet, View } from 'react-native';\nimport { RadioButtonContext } from './RadioButtonGroup';\nimport { handlePress, isChecked } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { getAndroidSelectionControlColor } from '../Checkbox/utils';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nconst BORDER_WIDTH = 2;\n\n/**\n * Radio buttons allow the selection a single option from a set.\n * This component follows platform guidelines for Android, but can be used\n * on any platform.\n *\n * @extends TouchableRipple props https://callstack.github.io/react-native-paper/docs/components/TouchableRipple\n */\nconst RadioButtonAndroid = _ref => {\n let {\n disabled,\n onPress,\n theme: themeOverrides,\n value,\n status,\n testID,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n current: borderAnim\n } = React.useRef(new Animated.Value(BORDER_WIDTH));\n const {\n current: radioAnim\n } = React.useRef(new Animated.Value(1));\n const isFirstRendering = React.useRef(true);\n const {\n scale\n } = theme.animation;\n React.useEffect(() => {\n // Do not run animation on very first rendering\n if (isFirstRendering.current) {\n isFirstRendering.current = false;\n return;\n }\n if (status === 'checked') {\n radioAnim.setValue(1.2);\n Animated.timing(radioAnim, {\n toValue: 1,\n duration: 150 * scale,\n useNativeDriver: true\n }).start();\n } else {\n borderAnim.setValue(10);\n Animated.timing(borderAnim, {\n toValue: BORDER_WIDTH,\n duration: 150 * scale,\n useNativeDriver: false\n }).start();\n }\n }, [status, borderAnim, radioAnim, scale]);\n return /*#__PURE__*/React.createElement(RadioButtonContext.Consumer, null, context => {\n const checked = isChecked({\n contextValue: context === null || context === void 0 ? void 0 : context.value,\n status,\n value\n }) === 'checked';\n const {\n rippleColor,\n selectionControlColor\n } = getAndroidSelectionControlColor({\n theme,\n disabled,\n checked,\n customColor: rest.color,\n customUncheckedColor: rest.uncheckedColor\n });\n return /*#__PURE__*/React.createElement(TouchableRipple, _extends({}, rest, {\n borderless: true,\n rippleColor: rippleColor,\n onPress: disabled ? undefined : event => {\n handlePress({\n onPress,\n onValueChange: context === null || context === void 0 ? void 0 : context.onValueChange,\n value,\n event\n });\n },\n accessibilityRole: \"radio\",\n accessibilityState: {\n disabled,\n checked\n },\n accessibilityLiveRegion: \"polite\",\n style: styles.container,\n testID: testID,\n theme: theme\n }), /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.radio, {\n borderColor: selectionControlColor,\n borderWidth: borderAnim\n }]\n }, checked ? /*#__PURE__*/React.createElement(View, {\n style: [StyleSheet.absoluteFill, styles.radioContainer]\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.dot, {\n backgroundColor: selectionControlColor,\n transform: [{\n scale: radioAnim\n }]\n }]\n })) : null));\n });\n};\nRadioButtonAndroid.displayName = 'RadioButton.Android';\nconst styles = StyleSheet.create({\n container: {\n borderRadius: 18\n },\n radioContainer: {\n alignItems: 'center',\n justifyContent: 'center'\n },\n radio: {\n height: 20,\n width: 20,\n borderRadius: 10,\n margin: 8\n },\n dot: {\n height: 10,\n width: 10,\n borderRadius: 5\n }\n});\nexport default RadioButtonAndroid;\n\n// @component-docs ignore-next-line\nexport { RadioButtonAndroid };\n//# sourceMappingURL=RadioButtonAndroid.js.map","import * as React from 'react';\nimport { View } from 'react-native';\nexport const RadioButtonContext = /*#__PURE__*/React.createContext(null);\n\n/**\n * Radio button group allows to control a group of radio buttons.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View } from 'react-native';\n * import { RadioButton, Text } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [value, setValue] = React.useState('first');\n *\n * return (\n * setValue(newValue)} value={value}>\n * \n * First\n * \n * \n * \n * Second\n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n *```\n */\nconst RadioButtonGroup = _ref => {\n let {\n value,\n onValueChange,\n children\n } = _ref;\n return /*#__PURE__*/React.createElement(RadioButtonContext.Provider, {\n value: {\n value,\n onValueChange\n }\n }, /*#__PURE__*/React.createElement(View, {\n accessibilityRole: \"radiogroup\"\n }, children));\n};\nRadioButtonGroup.displayName = 'RadioButton.Group';\nexport default RadioButtonGroup;\n\n// @component-docs ignore-next-line\nexport { RadioButtonGroup };\n//# sourceMappingURL=RadioButtonGroup.js.map","export const handlePress = _ref => {\n let {\n onPress,\n value,\n onValueChange,\n event\n } = _ref;\n if (onPress && onValueChange) {\n console.warn(`onPress in the scope of RadioButtonGroup will not be executed, use onValueChange instead`);\n }\n onValueChange ? onValueChange(value) : onPress === null || onPress === void 0 ? void 0 : onPress(event);\n};\nexport const isChecked = _ref2 => {\n let {\n value,\n status,\n contextValue\n } = _ref2;\n if (contextValue !== undefined && contextValue !== null) {\n return contextValue === value ? 'checked' : 'unchecked';\n } else {\n return status;\n }\n};\n//# sourceMappingURL=utils.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { RadioButtonContext } from './RadioButtonGroup';\nimport { handlePress, isChecked } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { getSelectionControlIOSColor } from '../Checkbox/utils';\nimport MaterialCommunityIcon from '../MaterialCommunityIcon';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\n/**\n * Radio buttons allow the selection a single option from a set.\n * This component follows platform guidelines for iOS, but can be used\n * on any platform.\n *\n * @extends TouchableRipple props https://callstack.github.io/react-native-paper/docs/components/TouchableRipple\n */\nconst RadioButtonIOS = _ref => {\n let {\n disabled,\n onPress,\n theme: themeOverrides,\n status,\n value,\n testID,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n return /*#__PURE__*/React.createElement(RadioButtonContext.Consumer, null, context => {\n const checked = isChecked({\n contextValue: context === null || context === void 0 ? void 0 : context.value,\n status,\n value\n }) === 'checked';\n const {\n checkedColor,\n rippleColor\n } = getSelectionControlIOSColor({\n theme,\n disabled,\n customColor: rest.color\n });\n const opacity = checked ? 1 : 0;\n return /*#__PURE__*/React.createElement(TouchableRipple, _extends({}, rest, {\n borderless: true,\n rippleColor: rippleColor,\n onPress: disabled ? undefined : event => {\n handlePress({\n onPress,\n value,\n onValueChange: context === null || context === void 0 ? void 0 : context.onValueChange,\n event\n });\n },\n accessibilityRole: \"radio\",\n accessibilityState: {\n disabled,\n checked\n },\n accessibilityLiveRegion: \"polite\",\n style: styles.container,\n testID: testID,\n theme: theme\n }), /*#__PURE__*/React.createElement(View, {\n style: {\n opacity\n }\n }, /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n allowFontScaling: false,\n name: \"check\",\n size: 24,\n color: checkedColor,\n direction: \"ltr\"\n })));\n });\n};\nRadioButtonIOS.displayName = 'RadioButton.IOS';\nconst styles = StyleSheet.create({\n container: {\n borderRadius: 18,\n padding: 6\n }\n});\nexport default RadioButtonIOS;\n\n// @component-docs ignore-next-line\nexport { RadioButtonIOS };\n//# sourceMappingURL=RadioButtonIOS.js.map","import * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport RadioButton from './RadioButton';\nimport RadioButtonAndroid from './RadioButtonAndroid';\nimport { RadioButtonContext } from './RadioButtonGroup';\nimport RadioButtonIOS from './RadioButtonIOS';\nimport { handlePress, isChecked } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\n/**\n * RadioButton.Item allows you to press the whole row (item) instead of only the RadioButton.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { RadioButton } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [value, setValue] = React.useState('first');\n *\n * return (\n * setValue(value)} value={value}>\n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n *```\n */\nconst RadioButtonItem = _ref => {\n let {\n value,\n label,\n style,\n labelStyle,\n onPress,\n onLongPress,\n disabled,\n color,\n uncheckedColor,\n rippleColor,\n status,\n theme: themeOverrides,\n background,\n accessibilityLabel = label,\n testID,\n mode,\n position = 'trailing',\n labelVariant = 'bodyLarge',\n labelMaxFontSizeMultiplier\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const radioButtonProps = {\n value,\n disabled,\n status,\n color,\n theme,\n uncheckedColor\n };\n const isLeading = position === 'leading';\n let radioButton;\n if (mode === 'android') {\n radioButton = /*#__PURE__*/React.createElement(RadioButtonAndroid, radioButtonProps);\n } else if (mode === 'ios') {\n radioButton = /*#__PURE__*/React.createElement(RadioButtonIOS, radioButtonProps);\n } else {\n radioButton = /*#__PURE__*/React.createElement(RadioButton, radioButtonProps);\n }\n const textColor = theme.isV3 ? theme.colors.onSurface : theme.colors.text;\n const disabledTextColor = theme.isV3 ? theme.colors.onSurfaceDisabled : theme.colors.disabled;\n const textAlign = isLeading ? 'right' : 'left';\n const computedStyle = {\n color: disabled ? disabledTextColor : textColor,\n textAlign\n };\n return /*#__PURE__*/React.createElement(RadioButtonContext.Consumer, null, context => {\n const checked = isChecked({\n contextValue: context === null || context === void 0 ? void 0 : context.value,\n status,\n value\n }) === 'checked';\n return /*#__PURE__*/React.createElement(TouchableRipple, {\n onPress: event => handlePress({\n onPress: onPress,\n onValueChange: context === null || context === void 0 ? void 0 : context.onValueChange,\n value,\n event\n }),\n onLongPress: onLongPress,\n accessibilityLabel: accessibilityLabel,\n accessibilityRole: \"radio\",\n accessibilityState: {\n checked,\n disabled\n },\n testID: testID,\n disabled: disabled,\n background: background,\n theme: theme,\n rippleColor: rippleColor\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.container, style],\n pointerEvents: \"none\"\n }, isLeading && radioButton, /*#__PURE__*/React.createElement(Text, {\n variant: labelVariant,\n style: [styles.label, !theme.isV3 && styles.font, computedStyle, labelStyle],\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier\n }, label), !isLeading && radioButton));\n });\n};\nRadioButtonItem.displayName = 'RadioButton.Item';\nexport default RadioButtonItem;\n\n// @component-docs ignore-next-line\nexport { RadioButtonItem };\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'space-between',\n paddingVertical: 8,\n paddingHorizontal: 16\n },\n label: {\n flexShrink: 1,\n flexGrow: 1\n },\n font: {\n fontSize: 16\n }\n});\n//# sourceMappingURL=RadioButtonItem.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { I18nManager, Platform, StyleSheet, TextInput, View } from 'react-native';\nimport color from 'color';\nimport ActivityIndicator from './ActivityIndicator';\nimport Divider from './Divider';\nimport IconButton from './IconButton/IconButton';\nimport MaterialCommunityIcon from './MaterialCommunityIcon';\nimport Surface from './Surface';\nimport { useInternalTheme } from '../core/theming';\nimport { forwardRef } from '../utils/forwardRef';\n/**\n * Searchbar is a simple input box where users can type search queries.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Searchbar } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [searchQuery, setSearchQuery] = React.useState('');\n *\n * return (\n * \n * );\n * };\n *\n * export default MyComponent;\n\n * ```\n */\nconst Searchbar = forwardRef((_ref, ref) => {\n var _theme$colors, _theme$colors2;\n let {\n icon,\n iconColor: customIconColor,\n rippleColor: customRippleColor,\n onIconPress,\n searchAccessibilityLabel = 'search',\n clearIcon,\n clearAccessibilityLabel = 'clear',\n onClearIconPress,\n traileringIcon,\n traileringIconColor,\n traileringIconAccessibilityLabel,\n traileringRippleColor: customTraileringRippleColor,\n onTraileringIconPress,\n right,\n mode = 'bar',\n showDivider = true,\n inputStyle,\n placeholder,\n elevation = 0,\n style,\n theme: themeOverrides,\n value,\n loading = false,\n testID = 'search-bar',\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const root = React.useRef(null);\n React.useImperativeHandle(ref, () => {\n const input = root.current;\n if (input) {\n return {\n focus: () => input.focus(),\n clear: () => input.clear(),\n setNativeProps: args => input.setNativeProps(args),\n isFocused: () => input.isFocused(),\n blur: () => input.blur()\n };\n }\n const noop = () => {\n throw new Error('TextInput is not available');\n };\n return {\n focus: noop,\n clear: noop,\n setNativeProps: noop,\n isFocused: noop,\n blur: noop\n };\n });\n const handleClearPress = e => {\n var _root$current, _rest$onChangeText;\n (_root$current = root.current) === null || _root$current === void 0 ? void 0 : _root$current.clear();\n (_rest$onChangeText = rest.onChangeText) === null || _rest$onChangeText === void 0 ? void 0 : _rest$onChangeText.call(rest, '');\n onClearIconPress === null || onClearIconPress === void 0 ? void 0 : onClearIconPress(e);\n };\n const {\n roundness,\n dark,\n isV3,\n fonts\n } = theme;\n const placeholderTextColor = isV3 ? theme.colors.onSurface : (_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.placeholder;\n const textColor = isV3 ? theme.colors.onSurfaceVariant : theme.colors.text;\n const md2IconColor = dark ? textColor : color(textColor).alpha(0.54).rgb().string();\n const iconColor = customIconColor || (isV3 ? theme.colors.onSurfaceVariant : md2IconColor);\n const rippleColor = customRippleColor || color(textColor).alpha(0.32).rgb().string();\n const traileringRippleColor = customTraileringRippleColor || color(textColor).alpha(0.32).rgb().string();\n const font = isV3 ? {\n ...fonts.bodyLarge,\n lineHeight: Platform.select({\n ios: 0,\n default: fonts.bodyLarge.lineHeight\n })\n } : theme.fonts.regular;\n const isBarMode = isV3 && mode === 'bar';\n const shouldRenderTraileringIcon = isBarMode && traileringIcon && !loading && (!value || right !== undefined);\n return /*#__PURE__*/React.createElement(Surface, _extends({\n style: [{\n borderRadius: roundness\n }, !isV3 && styles.elevation, isV3 && {\n backgroundColor: theme.colors.elevation.level3,\n borderRadius: roundness * (isBarMode ? 7 : 0)\n }, styles.container, style],\n testID: `${testID}-container`\n }, theme.isV3 && {\n elevation\n }, {\n theme: theme\n }), /*#__PURE__*/React.createElement(IconButton, {\n accessibilityRole: \"button\",\n borderless: true,\n rippleColor: rippleColor,\n onPress: onIconPress,\n iconColor: iconColor,\n icon: icon || (_ref2 => {\n let {\n size,\n color\n } = _ref2;\n return /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"magnify\",\n color: color,\n size: size,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n });\n }),\n theme: theme,\n accessibilityLabel: searchAccessibilityLabel,\n testID: `${testID}-icon`\n }), /*#__PURE__*/React.createElement(TextInput, _extends({\n style: [styles.input, {\n color: textColor,\n ...font,\n ...Platform.select({\n web: {\n outline: 'none'\n }\n })\n }, isV3 && (isBarMode ? styles.barModeInput : styles.viewModeInput), inputStyle],\n placeholder: placeholder || '',\n placeholderTextColor: placeholderTextColor,\n selectionColor: (_theme$colors2 = theme.colors) === null || _theme$colors2 === void 0 ? void 0 : _theme$colors2.primary,\n underlineColorAndroid: \"transparent\",\n returnKeyType: \"search\",\n keyboardAppearance: dark ? 'dark' : 'light',\n accessibilityRole: \"search\",\n ref: root,\n value: value,\n testID: testID\n }, rest)), loading ? /*#__PURE__*/React.createElement(ActivityIndicator, {\n testID: \"activity-indicator\",\n style: isV3 ? styles.v3Loader : styles.loader\n }) :\n /*#__PURE__*/\n // Clear icon should be always rendered within Searchbar – it's transparent,\n // without touch events, when there is no value. It's done to avoid issues\n // with the abruptly stopping ripple effect and changing bar width on web,\n // when clearing the value.\n React.createElement(View, {\n pointerEvents: value ? 'auto' : 'none',\n testID: `${testID}-icon-wrapper`,\n style: [isV3 && !value && styles.v3ClearIcon, isV3 && right !== undefined && styles.v3ClearIconHidden]\n }, /*#__PURE__*/React.createElement(IconButton, {\n borderless: true,\n accessibilityLabel: clearAccessibilityLabel,\n iconColor: value ? iconColor : 'rgba(255, 255, 255, 0)',\n rippleColor: rippleColor,\n onPress: handleClearPress,\n icon: clearIcon || (_ref3 => {\n let {\n size,\n color\n } = _ref3;\n return /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: isV3 ? 'close' : 'close-circle-outline',\n color: color,\n size: size,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n });\n }),\n testID: `${testID}-clear-icon`,\n accessibilityRole: \"button\",\n theme: theme\n })), shouldRenderTraileringIcon ? /*#__PURE__*/React.createElement(IconButton, {\n accessibilityRole: \"button\",\n borderless: true,\n onPress: onTraileringIconPress,\n iconColor: traileringIconColor || theme.colors.onSurfaceVariant,\n rippleColor: traileringRippleColor,\n icon: traileringIcon,\n accessibilityLabel: traileringIconAccessibilityLabel,\n testID: `${testID}-trailering-icon`\n }) : null, isBarMode && (right === null || right === void 0 ? void 0 : right({\n color: textColor,\n style: styles.rightStyle,\n testID\n })), isV3 && !isBarMode && showDivider && /*#__PURE__*/React.createElement(Divider, {\n bold: true,\n style: [styles.divider, {\n backgroundColor: theme.colors.outline\n }],\n testID: `${testID}-divider`\n }));\n});\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n alignItems: 'center'\n },\n input: {\n flex: 1,\n fontSize: 18,\n paddingLeft: 8,\n alignSelf: 'stretch',\n textAlign: I18nManager.getConstants().isRTL ? 'right' : 'left',\n minWidth: 0\n },\n barModeInput: {\n paddingLeft: 0,\n minHeight: 56\n },\n viewModeInput: {\n paddingLeft: 0,\n minHeight: 72\n },\n elevation: {\n elevation: 4\n },\n loader: {\n margin: 10\n },\n v3Loader: {\n marginHorizontal: 16\n },\n rightStyle: {\n marginRight: 16\n },\n v3ClearIcon: {\n position: 'absolute',\n right: 0,\n marginLeft: 16\n },\n v3ClearIconHidden: {\n display: 'none'\n },\n divider: {\n position: 'absolute',\n bottom: 0,\n width: '100%'\n }\n});\nexport default Searchbar;\n//# sourceMappingURL=Searchbar.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, Easing, I18nManager, StyleSheet, View } from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport useLatestCallback from 'use-latest-callback';\nimport Button from './Button/Button';\nimport IconButton from './IconButton/IconButton';\nimport MaterialCommunityIcon from './MaterialCommunityIcon';\nimport Surface from './Surface';\nimport Text from './Typography/Text';\nimport { useInternalTheme } from '../core/theming';\nconst DURATION_SHORT = 4000;\nconst DURATION_MEDIUM = 7000;\nconst DURATION_LONG = 10000;\n\n/**\n * Snackbars provide brief feedback about an operation through a message rendered at the bottom of the container in which it's wrapped.\n *\n * Note: To display it as a popup, regardless of the parent's position, wrap it with a `Portal` component – refer to the example in the \"More Examples` section.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { View, StyleSheet } from 'react-native';\n * import { Button, Snackbar } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [visible, setVisible] = React.useState(false);\n *\n * const onToggleSnackBar = () => setVisible(!visible);\n *\n * const onDismissSnackBar = () => setVisible(false);\n *\n * return (\n * \n * \n * {\n * // Do something\n * },\n * }}>\n * Hey there! I'm a Snackbar.\n * \n * \n * );\n * };\n *\n * const styles = StyleSheet.create({\n * container: {\n * flex: 1,\n * justifyContent: 'space-between',\n * },\n * });\n *\n * export default MyComponent;\n * ```\n */\nconst Snackbar = _ref => {\n let {\n visible,\n action,\n icon,\n onIconPress,\n iconAccessibilityLabel = 'Close icon',\n duration = DURATION_MEDIUM,\n onDismiss,\n children,\n elevation = 2,\n wrapperStyle,\n style,\n theme: themeOverrides,\n maxFontSizeMultiplier,\n rippleColor,\n testID,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n bottom,\n right,\n left\n } = useSafeAreaInsets();\n const {\n current: opacity\n } = React.useRef(new Animated.Value(0.0));\n const hideTimeout = React.useRef(undefined);\n const [hidden, setHidden] = React.useState(!visible);\n const {\n scale\n } = theme.animation;\n const animateShow = useLatestCallback(() => {\n if (hideTimeout.current) clearTimeout(hideTimeout.current);\n Animated.timing(opacity, {\n toValue: 1,\n duration: 200 * scale,\n easing: Easing.out(Easing.ease),\n useNativeDriver: true\n }).start(_ref2 => {\n let {\n finished\n } = _ref2;\n if (finished) {\n const isInfinity = duration === Number.POSITIVE_INFINITY || duration === Number.NEGATIVE_INFINITY;\n if (!isInfinity) {\n hideTimeout.current = setTimeout(onDismiss, duration);\n }\n }\n });\n });\n const handleOnVisible = useLatestCallback(() => {\n // show\n setHidden(false);\n });\n const handleOnHidden = useLatestCallback(() => {\n // hide\n if (hideTimeout.current) {\n clearTimeout(hideTimeout.current);\n }\n Animated.timing(opacity, {\n toValue: 0,\n duration: 100 * scale,\n useNativeDriver: true\n }).start(_ref3 => {\n let {\n finished\n } = _ref3;\n if (finished) {\n setHidden(true);\n }\n });\n });\n React.useEffect(() => {\n if (!hidden) {\n animateShow();\n }\n }, [animateShow, hidden]);\n React.useEffect(() => {\n return () => {\n if (hideTimeout.current) clearTimeout(hideTimeout.current);\n };\n }, []);\n React.useLayoutEffect(() => {\n if (visible) {\n handleOnVisible();\n } else {\n handleOnHidden();\n }\n }, [visible, handleOnVisible, handleOnHidden]);\n const {\n colors,\n roundness,\n isV3\n } = theme;\n if (hidden) {\n return null;\n }\n const {\n style: actionStyle,\n label: actionLabel,\n onPress: onPressAction,\n rippleColor: actionRippleColor,\n ...actionProps\n } = action || {};\n const buttonTextColor = isV3 ? colors.inversePrimary : colors.accent;\n const textColor = isV3 ? colors.inverseOnSurface : colors === null || colors === void 0 ? void 0 : colors.surface;\n const backgroundColor = isV3 ? colors.inverseSurface : colors === null || colors === void 0 ? void 0 : colors.onSurface;\n const isIconButton = isV3 && onIconPress;\n const marginLeft = action ? -12 : -16;\n const wrapperPaddings = {\n paddingBottom: bottom,\n paddingHorizontal: Math.max(left, right)\n };\n const renderChildrenWithWrapper = () => {\n if (typeof children === 'string') {\n return /*#__PURE__*/React.createElement(Text, {\n variant: \"bodyMedium\",\n style: [styles.content, {\n color: textColor\n }],\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }, children);\n }\n return /*#__PURE__*/React.createElement(View, {\n style: styles.content\n }, /*#__PURE__*/React.createElement(View, null, children));\n };\n return /*#__PURE__*/React.createElement(View, {\n pointerEvents: \"box-none\",\n style: [styles.wrapper, wrapperPaddings, wrapperStyle]\n }, /*#__PURE__*/React.createElement(Surface, _extends({\n pointerEvents: \"box-none\",\n accessibilityLiveRegion: \"polite\",\n theme: theme,\n style: [!isV3 && styles.elevation, styles.container, {\n backgroundColor,\n borderRadius: roundness,\n opacity: opacity,\n transform: [{\n scale: visible ? opacity.interpolate({\n inputRange: [0, 1],\n outputRange: [0.9, 1]\n }) : 1\n }]\n }, style],\n testID: testID\n }, isV3 && {\n elevation\n }, rest), renderChildrenWithWrapper(), (action || isIconButton) && /*#__PURE__*/React.createElement(View, {\n style: [styles.actionsContainer, {\n marginLeft\n }]\n }, action ? /*#__PURE__*/React.createElement(Button, _extends({\n onPress: event => {\n onPressAction === null || onPressAction === void 0 ? void 0 : onPressAction(event);\n onDismiss();\n },\n style: [styles.button, actionStyle],\n textColor: buttonTextColor,\n compact: !isV3,\n mode: \"text\",\n theme: theme,\n rippleColor: actionRippleColor\n }, actionProps), actionLabel) : null, isIconButton ? /*#__PURE__*/React.createElement(IconButton, {\n accessibilityRole: \"button\",\n borderless: true,\n onPress: onIconPress,\n iconColor: theme.colors.inverseOnSurface,\n rippleColor: rippleColor,\n theme: theme,\n icon: icon || (_ref4 => {\n let {\n size,\n color\n } = _ref4;\n return /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"close\",\n color: color,\n size: size,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n });\n }),\n accessibilityLabel: iconAccessibilityLabel,\n style: styles.icon,\n testID: `${testID}-icon`\n }) : null)));\n};\n\n/**\n * Show the Snackbar for a short duration.\n */\nSnackbar.DURATION_SHORT = DURATION_SHORT;\n\n/**\n * Show the Snackbar for a medium duration.\n */\nSnackbar.DURATION_MEDIUM = DURATION_MEDIUM;\n\n/**\n * Show the Snackbar for a long duration.\n */\nSnackbar.DURATION_LONG = DURATION_LONG;\nconst styles = StyleSheet.create({\n wrapper: {\n position: 'absolute',\n bottom: 0,\n width: '100%'\n },\n container: {\n flexDirection: 'row',\n justifyContent: 'space-between',\n margin: 8,\n borderRadius: 4,\n minHeight: 48\n },\n content: {\n marginHorizontal: 16,\n marginVertical: 14,\n flex: 1\n },\n actionsContainer: {\n flexDirection: 'row',\n justifyContent: 'flex-end',\n alignItems: 'center',\n minHeight: 48\n },\n button: {\n marginRight: 8,\n marginLeft: 4\n },\n elevation: {\n elevation: 6\n },\n icon: {\n width: 40,\n height: 40,\n margin: 0\n }\n});\nexport default Snackbar;\n//# sourceMappingURL=Snackbar.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { NativeModules, Platform, Switch as NativeSwitch } from 'react-native';\nimport { getSwitchColor } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nconst version = NativeModules.PlatformConstants ? NativeModules.PlatformConstants.reactNativeVersion : undefined;\n/**\n * Switch is a visual toggle between two mutually exclusive states — on and off.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Switch } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [isSwitchOn, setIsSwitchOn] = React.useState(false);\n *\n * const onToggleSwitch = () => setIsSwitchOn(!isSwitchOn);\n *\n * return ;\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst Switch = _ref => {\n let {\n value,\n disabled,\n onValueChange,\n color,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n checkedColor,\n onTintColor,\n thumbTintColor\n } = getSwitchColor({\n theme,\n disabled,\n value,\n color\n });\n const props = version && version.major === 0 && version.minor <= 56 ? {\n onTintColor,\n thumbTintColor\n } : Platform.OS === 'web' ? {\n activeTrackColor: onTintColor,\n thumbColor: thumbTintColor,\n activeThumbColor: checkedColor\n } : {\n thumbColor: thumbTintColor,\n trackColor: {\n true: onTintColor,\n false: onTintColor\n }\n };\n return /*#__PURE__*/React.createElement(NativeSwitch, _extends({\n value: value,\n disabled: disabled,\n onValueChange: disabled ? undefined : onValueChange\n }, props, rest));\n};\nexport default Switch;\n//# sourceMappingURL=Switch.js.map","import { Platform } from 'react-native';\nimport setColor from 'color';\nimport { grey400, grey800, grey50, grey700, white, black } from '../../styles/themes/v2/colors';\nconst getCheckedColor = _ref => {\n let {\n theme,\n color\n } = _ref;\n if (color) {\n return color;\n }\n if (theme.isV3) {\n return theme.colors.primary;\n }\n return theme.colors.accent;\n};\nconst getThumbTintColor = _ref2 => {\n let {\n theme,\n disabled,\n value,\n checkedColor\n } = _ref2;\n const isIOS = Platform.OS === 'ios';\n if (isIOS) {\n return undefined;\n }\n if (disabled) {\n if (theme.dark) {\n return grey800;\n }\n return grey400;\n }\n if (value) {\n return checkedColor;\n }\n if (theme.dark) {\n return grey400;\n }\n return grey50;\n};\nconst getOnTintColor = _ref3 => {\n let {\n theme,\n disabled,\n value,\n checkedColor\n } = _ref3;\n const isIOS = Platform.OS === 'ios';\n if (isIOS) {\n return checkedColor;\n }\n if (disabled) {\n if (theme.dark) {\n if (theme.isV3) {\n return setColor(white).alpha(0.06).rgb().string();\n }\n return setColor(white).alpha(0.1).rgb().string();\n }\n return setColor(black).alpha(0.12).rgb().string();\n }\n if (value) {\n return setColor(checkedColor).alpha(0.5).rgb().string();\n }\n if (theme.dark) {\n return grey700;\n }\n return 'rgb(178, 175, 177)';\n};\nexport const getSwitchColor = _ref4 => {\n let {\n theme,\n disabled,\n value,\n color\n } = _ref4;\n const checkedColor = getCheckedColor({\n theme,\n color\n });\n return {\n onTintColor: getOnTintColor({\n theme,\n disabled,\n value,\n checkedColor\n }),\n thumbTintColor: getThumbTintColor({\n theme,\n disabled,\n value,\n checkedColor\n }),\n checkedColor\n };\n};\n//# sourceMappingURL=utils.js.map","import AppbarComponent from './Appbar';\nimport AppbarAction from './AppbarAction';\nimport AppbarBackAction from './AppbarBackAction';\nimport AppbarContent from './AppbarContent';\nimport AppbarHeader from './AppbarHeader';\nconst Appbar = Object.assign(\n// @component ./Appbar.tsx\nAppbarComponent, {\n // @component ./AppbarContent.tsx\n Content: AppbarContent,\n // @component ./AppbarAction.tsx\n Action: AppbarAction,\n // @component ./AppbarBackAction.tsx\n BackAction: AppbarBackAction,\n // @component ./AppbarHeader.tsx\n Header: AppbarHeader\n});\nexport default Appbar;\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Platform, StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport AppbarContent from './AppbarContent';\nimport { DEFAULT_APPBAR_HEIGHT, getAppbarBackgroundColor, modeAppbarHeight, renderAppbarContent } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport Surface from '../Surface';\n/**\n * A component to display action items in a bar. It can be placed at the top or bottom.\n * The top bar usually contains the screen title, controls such as navigation buttons, menu button etc.\n * The bottom bar usually provides access to a drawer and up to four actions.\n *\n * By default Appbar uses primary color as a background, in dark theme with `adaptive` mode it will use surface colour instead.\n * See [Dark Theme](https://callstack.github.io/react-native-paper/docs/guides/theming#dark-theme) for more informations\n *\n * ## Usage\n * ### Top bar\n * ```js\n * import * as React from 'react';\n * import { Appbar } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * {}} />\n * \n * {}} />\n * {}} />\n * \n * );\n *\n * export default MyComponent;\n * ```\n *\n * ### Bottom bar\n * ```js\n * import * as React from 'react';\n * import { StyleSheet } from 'react-native';\n * import { Appbar, FAB, useTheme } from 'react-native-paper';\n * import { useSafeAreaInsets } from 'react-native-safe-area-context';\n *\n * const BOTTOM_APPBAR_HEIGHT = 80;\n * const MEDIUM_FAB_HEIGHT = 56;\n *\n * const MyComponent = () => {\n * const { bottom } = useSafeAreaInsets();\n * const theme = useTheme();\n *\n * return (\n * \n * {}} />\n * {}} />\n * {}} />\n * {}} />\n * {}}\n * style={[\n * styles.fab,\n * { top: (BOTTOM_APPBAR_HEIGHT - MEDIUM_FAB_HEIGHT) / 2 },\n * ]}\n * />\n * \n * );\n * };\n *\n * const styles = StyleSheet.create({\n * bottom: {\n * backgroundColor: 'aquamarine',\n * position: 'absolute',\n * left: 0,\n * right: 0,\n * bottom: 0,\n * },\n * fab: {\n * position: 'absolute',\n * right: 16,\n * },\n * });\n *\n * export default MyComponent;\n * ```\n */\nconst Appbar = _ref => {\n let {\n children,\n dark,\n style,\n mode = 'small',\n elevated,\n safeAreaInsets,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3\n } = theme;\n const flattenedStyle = StyleSheet.flatten(style);\n const {\n backgroundColor: customBackground,\n elevation = isV3 ? elevated ? 2 : 0 : 4,\n ...restStyle\n } = flattenedStyle || {};\n const backgroundColor = getAppbarBackgroundColor(theme, elevation, customBackground, elevated);\n const isMode = modeToCompare => {\n return isV3 && mode === modeToCompare;\n };\n let isDark = false;\n if (typeof dark === 'boolean') {\n isDark = dark;\n } else if (!isV3) {\n isDark = backgroundColor === 'transparent' ? false : typeof backgroundColor === 'string' ? !color(backgroundColor).isLight() : true;\n }\n const isV3CenterAlignedMode = isV3 && isMode('center-aligned');\n let shouldCenterContent = false;\n let shouldAddLeftSpacing = false;\n let shouldAddRightSpacing = false;\n if (!isV3 && Platform.OS === 'ios' || isV3CenterAlignedMode) {\n let hasAppbarContent = false;\n let leftItemsCount = 0;\n let rightItemsCount = 0;\n React.Children.forEach(children, child => {\n if ( /*#__PURE__*/React.isValidElement(child)) {\n if (child.type === AppbarContent) {\n hasAppbarContent = true;\n } else if (hasAppbarContent) {\n rightItemsCount++;\n } else {\n leftItemsCount++;\n }\n }\n });\n shouldCenterContent = hasAppbarContent && leftItemsCount < 2 && rightItemsCount < (isV3 ? 3 : 2);\n shouldAddLeftSpacing = shouldCenterContent && leftItemsCount === 0;\n shouldAddRightSpacing = shouldCenterContent && rightItemsCount === 0;\n }\n const filterAppbarActions = React.useCallback(function () {\n let isLeading = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n return React.Children.toArray(children).filter(child =>\n // @ts-expect-error: TypeScript complains about the type of type but it doesn't matter\n isLeading ? child.props.isLeading : !child.props.isLeading);\n }, [children]);\n const spacingStyle = isV3 ? styles.v3Spacing : styles.spacing;\n const insets = {\n paddingBottom: safeAreaInsets === null || safeAreaInsets === void 0 ? void 0 : safeAreaInsets.bottom,\n paddingTop: safeAreaInsets === null || safeAreaInsets === void 0 ? void 0 : safeAreaInsets.top,\n paddingLeft: safeAreaInsets === null || safeAreaInsets === void 0 ? void 0 : safeAreaInsets.left,\n paddingRight: safeAreaInsets === null || safeAreaInsets === void 0 ? void 0 : safeAreaInsets.right\n };\n return /*#__PURE__*/React.createElement(Surface, _extends({\n style: [{\n backgroundColor\n }, styles.appbar, {\n height: isV3 ? modeAppbarHeight[mode] : DEFAULT_APPBAR_HEIGHT\n }, insets, restStyle, !theme.isV3 && {\n elevation\n }],\n elevation: elevation\n }, rest), shouldAddLeftSpacing ? /*#__PURE__*/React.createElement(View, {\n style: spacingStyle\n }) : null, (!isV3 || isMode('small') || isMode('center-aligned')) && renderAppbarContent({\n children,\n isDark,\n theme,\n isV3,\n shouldCenterContent: isV3CenterAlignedMode || shouldCenterContent\n }), (isMode('medium') || isMode('large')) && /*#__PURE__*/React.createElement(View, {\n style: [styles.columnContainer, isMode('center-aligned') && styles.centerAlignedContainer]\n }, /*#__PURE__*/React.createElement(View, {\n style: styles.controlsRow\n }, renderAppbarContent({\n children,\n isDark,\n isV3,\n renderOnly: ['Appbar.BackAction'],\n mode\n }), renderAppbarContent({\n children: filterAppbarActions(true),\n isDark,\n isV3,\n renderOnly: ['Appbar.Action'],\n mode\n }), /*#__PURE__*/React.createElement(View, {\n style: styles.rightActionControls\n }, renderAppbarContent({\n children: filterAppbarActions(false),\n isDark,\n isV3,\n renderExcept: ['Appbar', 'Appbar.BackAction', 'Appbar.Content', 'Appbar.Header'],\n mode\n }))), renderAppbarContent({\n children,\n isDark,\n isV3,\n renderOnly: ['Appbar.Content'],\n mode\n })), shouldAddRightSpacing ? /*#__PURE__*/React.createElement(View, {\n style: spacingStyle\n }) : null);\n};\nconst styles = StyleSheet.create({\n appbar: {\n flexDirection: 'row',\n alignItems: 'center',\n paddingHorizontal: 4\n },\n spacing: {\n width: 48\n },\n v3Spacing: {\n width: 52\n },\n controlsRow: {\n flex: 1,\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'space-between'\n },\n rightActionControls: {\n flexDirection: 'row',\n flex: 1,\n justifyContent: 'flex-end'\n },\n columnContainer: {\n flexDirection: 'column',\n flex: 1,\n paddingTop: 8\n },\n centerAlignedContainer: {\n paddingTop: 0\n }\n});\nexport default Appbar;\n\n// @component-docs ignore-next-line\nexport { Appbar };\n//# sourceMappingURL=Appbar.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Platform, StyleSheet, Pressable, View } from 'react-native';\nimport color from 'color';\nimport { modeTextVariant } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { white } from '../../styles/themes/v2/colors';\nimport Text from '../Typography/Text';\n/**\n * A component used to display a title and optional subtitle in an appbar.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Appbar } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * \n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst AppbarContent = _ref => {\n let {\n color: titleColor,\n subtitle,\n subtitleStyle,\n onPress,\n disabled,\n style,\n titleRef,\n titleStyle,\n title,\n titleMaxFontSizeMultiplier,\n mode = 'small',\n theme: themeOverrides,\n testID = 'appbar-content',\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3,\n colors\n } = theme;\n const titleTextColor = titleColor ? titleColor : isV3 ? colors.onSurface : white;\n const subtitleColor = color(titleTextColor).alpha(0.7).rgb().string();\n const modeContainerStyles = {\n small: styles.v3DefaultContainer,\n medium: styles.v3MediumContainer,\n large: styles.v3LargeContainer,\n 'center-aligned': styles.v3DefaultContainer\n };\n const variant = modeTextVariant[mode];\n const contentWrapperProps = {\n pointerEvents: 'box-none',\n style: [styles.container, isV3 && modeContainerStyles[mode], style],\n testID,\n ...rest\n };\n const content = /*#__PURE__*/React.createElement(React.Fragment, null, typeof title === 'string' ? /*#__PURE__*/React.createElement(Text, _extends({}, isV3 && {\n variant\n }, {\n ref: titleRef,\n style: [{\n color: titleTextColor,\n ...(isV3 ? theme.fonts[variant] : Platform.OS === 'ios' ? theme.fonts.regular : theme.fonts.medium)\n }, !isV3 && styles.title, titleStyle],\n numberOfLines: 1,\n accessible: true,\n accessibilityRole: onPress ? 'none' : Platform.OS === 'web' ? 'heading' : 'header'\n // @ts-expect-error We keep old a11y props for backwards compat with old RN versions\n ,\n accessibilityTraits: \"header\",\n testID: `${testID}-title-text`,\n maxFontSizeMultiplier: titleMaxFontSizeMultiplier\n }), title) : title, !isV3 && subtitle ? /*#__PURE__*/React.createElement(Text, {\n style: [styles.subtitle, {\n color: subtitleColor\n }, subtitleStyle],\n numberOfLines: 1\n }, subtitle) : null);\n if (onPress) {\n return (\n /*#__PURE__*/\n // eslint-disable-next-line react-native-a11y/has-accessibility-props\n React.createElement(Pressable, _extends({\n accessibilityRole: touchableRole\n // @ts-expect-error We keep old a11y props for backwards compat with old RN versions\n ,\n accessibilityTraits: touchableRole,\n accessibilityComponentType: \"button\",\n onPress: onPress,\n disabled: disabled\n }, contentWrapperProps), content)\n );\n }\n return /*#__PURE__*/React.createElement(View, contentWrapperProps, content);\n};\nAppbarContent.displayName = 'Appbar.Content';\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n paddingHorizontal: 12\n },\n v3DefaultContainer: {\n paddingHorizontal: 0\n },\n v3MediumContainer: {\n paddingHorizontal: 0,\n justifyContent: 'flex-end',\n paddingBottom: 24\n },\n v3LargeContainer: {\n paddingHorizontal: 0,\n paddingTop: 36,\n justifyContent: 'flex-end',\n paddingBottom: 28\n },\n title: {\n fontSize: Platform.OS === 'ios' ? 17 : 20\n },\n subtitle: {\n fontSize: Platform.OS === 'ios' ? 11 : 14\n }\n});\nconst iosTouchableRole = ['button', 'header'];\nconst touchableRole = Platform.select({\n ios: iosTouchableRole,\n default: iosTouchableRole[0]\n});\nexport default AppbarContent;\n\n// @component-docs ignore-next-line\nexport { AppbarContent };\n//# sourceMappingURL=AppbarContent.js.map","import React from 'react';\nimport { StyleSheet } from 'react-native';\nimport overlay from '../../styles/overlay';\nimport { black, white } from '../../styles/themes/v2/colors';\nconst borderStyleProperties = ['borderRadius', 'borderTopLeftRadius', 'borderTopRightRadius', 'borderBottomRightRadius', 'borderBottomLeftRadius'];\nexport const getAppbarBackgroundColor = (theme, elevation, customBackground, elevated) => {\n const {\n isV3,\n dark: isDarkTheme,\n mode,\n colors\n } = theme;\n const isAdaptiveMode = mode === 'adaptive';\n if (customBackground) {\n return customBackground;\n }\n if (!isV3) {\n if (isDarkTheme && isAdaptiveMode) {\n return overlay(elevation, colors === null || colors === void 0 ? void 0 : colors.surface);\n }\n return colors.primary;\n }\n if (elevated) {\n return theme.colors.elevation.level2;\n }\n return colors.surface;\n};\nexport const getAppbarColor = _ref => {\n let {\n color,\n isDark,\n isV3\n } = _ref;\n if (typeof color !== 'undefined') {\n return color;\n }\n if (isDark) {\n return white;\n }\n if (isV3) {\n return undefined;\n }\n return black;\n};\nexport const getAppbarBorders = style => {\n const borders = {};\n for (const property of borderStyleProperties) {\n const value = style[property];\n if (value) {\n borders[property] = value;\n }\n }\n return borders;\n};\nexport const DEFAULT_APPBAR_HEIGHT = 56;\nconst MD3_DEFAULT_APPBAR_HEIGHT = 64;\nexport const modeAppbarHeight = {\n small: MD3_DEFAULT_APPBAR_HEIGHT,\n medium: 112,\n large: 152,\n 'center-aligned': MD3_DEFAULT_APPBAR_HEIGHT\n};\nexport const modeTextVariant = {\n small: 'titleLarge',\n medium: 'headlineSmall',\n large: 'headlineMedium',\n 'center-aligned': 'titleLarge'\n};\nexport const renderAppbarContent = _ref2 => {\n let {\n children,\n isDark,\n shouldCenterContent = false,\n isV3,\n renderOnly,\n renderExcept,\n mode = 'small',\n theme\n } = _ref2;\n return React.Children.toArray(children).filter(child => child != null && typeof child !== 'boolean').filter(child =>\n // @ts-expect-error: TypeScript complains about the type of type but it doesn't matter\n renderExcept ? !renderExcept.includes(child.type.displayName) : child).filter(child =>\n // @ts-expect-error: TypeScript complains about the type of type but it doesn't matter\n renderOnly ? renderOnly.includes(child.type.displayName) : child).map((child, i) => {\n if (! /*#__PURE__*/React.isValidElement(child) || !['Appbar.Content', 'Appbar.Action', 'Appbar.BackAction', 'Tooltip'].includes(\n // @ts-expect-error: TypeScript complains about the type of type but it doesn't matter\n child.type.displayName)) {\n return child;\n }\n const props = {\n theme,\n color: getAppbarColor({\n color: child.props.color,\n isDark,\n isV3\n })\n };\n\n // @ts-expect-error: TypeScript complains about the type of type but it doesn't matter\n if (child.type.displayName === 'Appbar.Content') {\n props.mode = mode;\n props.style = [isV3 ? i === 0 && !shouldCenterContent && styles.v3Spacing : i !== 0 && styles.v2Spacing, shouldCenterContent && styles.centerAlignedContent, child.props.style];\n props.color;\n }\n return /*#__PURE__*/React.cloneElement(child, props);\n });\n};\nconst styles = StyleSheet.create({\n centerAlignedContent: {\n alignItems: 'center'\n },\n v2Spacing: {\n marginLeft: 8\n },\n v3Spacing: {\n marginLeft: 12\n }\n});\n//# sourceMappingURL=utils.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport color from 'color';\nimport { useInternalTheme } from '../../core/theming';\nimport { black } from '../../styles/themes/v2/colors';\nimport { forwardRef } from '../../utils/forwardRef';\nimport IconButton from '../IconButton/IconButton';\n/**\n * A component used to display an action item in the appbar.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Appbar } from 'react-native-paper';\n * import { Platform } from 'react-native';\n *\n * const MORE_ICON = Platform.OS === 'ios' ? 'dots-horizontal' : 'dots-vertical';\n *\n * const MyComponent = () => (\n * \n * \n * {}} />\n * {}} />\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst AppbarAction = forwardRef((_ref, ref) => {\n let {\n size = 24,\n color: iconColor,\n icon,\n disabled,\n onPress,\n accessibilityLabel,\n isLeading,\n theme: themeOverrides,\n rippleColor,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const actionIconColor = iconColor ? iconColor : theme.isV3 ? isLeading ? theme.colors.onSurface : theme.colors.onSurfaceVariant : color(black).alpha(0.54).rgb().string();\n return /*#__PURE__*/React.createElement(IconButton, _extends({\n size: size,\n onPress: onPress,\n iconColor: actionIconColor,\n icon: icon,\n disabled: disabled,\n accessibilityLabel: accessibilityLabel,\n animated: true,\n ref: ref,\n rippleColor: rippleColor\n }, rest));\n});\nAppbarAction.displayName = 'Appbar.Action';\nexport default AppbarAction;\n\n// @component-docs ignore-next-line\nexport { AppbarAction };\n//# sourceMappingURL=AppbarAction.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport AppbarAction from './AppbarAction';\nimport AppbarBackIcon from './AppbarBackIcon';\nimport { forwardRef } from '../../utils/forwardRef';\n/**\n * A component used to display a back button in the appbar.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Appbar } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * {}} />\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst AppbarBackAction = forwardRef((_ref, ref) => {\n let {\n accessibilityLabel = 'Back',\n ...rest\n } = _ref;\n return /*#__PURE__*/React.createElement(AppbarAction, _extends({\n accessibilityLabel: accessibilityLabel\n }, rest, {\n icon: AppbarBackIcon,\n isLeading: true,\n ref: ref\n }));\n});\nAppbarBackAction.displayName = 'Appbar.BackAction';\nexport default AppbarBackAction;\n\n// @component-docs ignore-next-line\nexport { AppbarBackAction };\n//# sourceMappingURL=AppbarBackAction.js.map","import * as React from 'react';\nimport { Platform, I18nManager, View, Image, StyleSheet } from 'react-native';\nimport MaterialCommunityIcon from '../MaterialCommunityIcon';\nconst AppbarBackIcon = _ref => {\n let {\n size,\n color\n } = _ref;\n const iosIconSize = size - 3;\n return Platform.OS === 'ios' ? /*#__PURE__*/React.createElement(View, {\n style: [styles.wrapper, {\n width: size,\n height: size,\n transform: [{\n scaleX: I18nManager.getConstants().isRTL ? -1 : 1\n }]\n }]\n }, /*#__PURE__*/React.createElement(Image, {\n source: require('../../assets/back-chevron.png'),\n style: [styles.icon, {\n tintColor: color,\n width: iosIconSize,\n height: iosIconSize\n }],\n accessibilityIgnoresInvertColors: true\n })) : /*#__PURE__*/React.createElement(MaterialCommunityIcon, {\n name: \"arrow-left\",\n color: color,\n size: size,\n direction: I18nManager.getConstants().isRTL ? 'rtl' : 'ltr'\n });\n};\nconst styles = StyleSheet.create({\n wrapper: {\n alignItems: 'center',\n justifyContent: 'center'\n },\n icon: {\n resizeMode: 'contain'\n }\n});\nexport default AppbarBackIcon;\n\n// @component-docs ignore-next-line\nexport { AppbarBackIcon };\n//# sourceMappingURL=AppbarBackIcon.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Platform, StyleSheet, View } from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport { Appbar } from './Appbar';\nimport { DEFAULT_APPBAR_HEIGHT, getAppbarBackgroundColor, modeAppbarHeight, getAppbarBorders } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport shadow from '../../styles/shadow';\n/**\n * A component to use as a header at the top of the screen.\n * It can contain the screen title, controls such as navigation buttons, menu button etc.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Appbar } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const _goBack = () => console.log('Went back');\n *\n * const _handleSearch = () => console.log('Searching');\n *\n * const _handleMore = () => console.log('Shown more');\n *\n * return (\n * \n * \n * \n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\nconst AppbarHeader = _ref => {\n let {\n // Don't use default props since we check it to know whether we should use SafeAreaView\n statusBarHeight,\n style,\n dark,\n mode = Platform.OS === 'ios' ? 'center-aligned' : 'small',\n elevated = false,\n theme: themeOverrides,\n testID = 'appbar-header',\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const {\n isV3\n } = theme;\n const flattenedStyle = StyleSheet.flatten(style);\n const {\n height = isV3 ? modeAppbarHeight[mode] : DEFAULT_APPBAR_HEIGHT,\n elevation = isV3 ? elevated ? 2 : 0 : 4,\n backgroundColor: customBackground,\n zIndex = isV3 && elevated ? 1 : 0,\n ...restStyle\n } = flattenedStyle || {};\n const borderRadius = getAppbarBorders(restStyle);\n const backgroundColor = getAppbarBackgroundColor(theme, elevation, customBackground, elevated);\n const {\n top,\n left,\n right\n } = useSafeAreaInsets();\n return /*#__PURE__*/React.createElement(View, {\n testID: `${testID}-root-layer`,\n style: [{\n backgroundColor,\n zIndex,\n elevation,\n paddingTop: statusBarHeight ?? top,\n paddingHorizontal: Math.max(left, right)\n }, borderRadius, shadow(elevation)]\n }, /*#__PURE__*/React.createElement(Appbar, _extends({\n testID: testID,\n style: [{\n height,\n backgroundColor\n }, styles.appbar, restStyle],\n dark: dark\n }, isV3 && {\n mode\n }, rest, {\n theme: theme\n })));\n};\nAppbarHeader.displayName = 'Appbar.Header';\nconst styles = StyleSheet.create({\n appbar: {\n elevation: 0\n }\n});\nexport default AppbarHeader;\n\n// @component-docs ignore-next-line\nexport { AppbarHeader };\n//# sourceMappingURL=AppbarHeader.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, TextInput as NativeTextInput } from 'react-native';\nimport TextInputAffix from './Adornment/TextInputAffix';\nimport TextInputIcon from './Adornment/TextInputIcon';\nimport TextInputFlat from './TextInputFlat';\nimport TextInputOutlined from './TextInputOutlined';\nimport { useInternalTheme } from '../../core/theming';\nimport { forwardRef } from '../../utils/forwardRef';\nimport { roundLayoutSize } from '../../utils/roundLayoutSize';\nconst BLUR_ANIMATION_DURATION = 180;\nconst FOCUS_ANIMATION_DURATION = 150;\nconst DefaultRenderer = props => /*#__PURE__*/React.createElement(NativeTextInput, props);\n\n/**\n * A component to allow users to input text.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { TextInput } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [text, setText] = React.useState(\"\");\n *\n * return (\n * setText(text)}\n * />\n * );\n * };\n *\n * export default MyComponent;\n * ```\n *\n * @extends TextInput props https://reactnative.dev/docs/textinput#props\n */\nconst TextInput = forwardRef((_ref, ref) => {\n let {\n mode = 'flat',\n dense = false,\n disabled = false,\n error: errorProp = false,\n multiline = false,\n editable = true,\n contentStyle,\n render = DefaultRenderer,\n theme: themeOverrides,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const isControlled = rest.value !== undefined;\n const validInputValue = isControlled ? rest.value : rest.defaultValue;\n const {\n current: labeled\n } = React.useRef(new Animated.Value(validInputValue ? 0 : 1));\n const {\n current: error\n } = React.useRef(new Animated.Value(errorProp ? 1 : 0));\n const [focused, setFocused] = React.useState(false);\n const [placeholder, setPlaceholder] = React.useState(' ');\n const [uncontrolledValue, setUncontrolledValue] = React.useState(validInputValue);\n // Use value from props instead of local state when input is controlled\n const value = isControlled ? rest.value : uncontrolledValue;\n const [labelTextLayout, setLabelTextLayout] = React.useState({\n width: 33\n });\n const [inputContainerLayout, setInputContainerLayout] = React.useState({\n width: 65\n });\n const [labelLayout, setLabelLayout] = React.useState({\n measured: false,\n width: 0,\n height: 0\n });\n const [leftLayout, setLeftLayout] = React.useState({\n width: null,\n height: null\n });\n const [rightLayout, setRightLayout] = React.useState({\n width: null,\n height: null\n });\n const timer = React.useRef();\n const root = React.useRef();\n const {\n scale\n } = theme.animation;\n React.useImperativeHandle(ref, () => ({\n focus: () => {\n var _root$current;\n return (_root$current = root.current) === null || _root$current === void 0 ? void 0 : _root$current.focus();\n },\n clear: () => {\n var _root$current2;\n return (_root$current2 = root.current) === null || _root$current2 === void 0 ? void 0 : _root$current2.clear();\n },\n setNativeProps: args => {\n var _root$current3;\n return (_root$current3 = root.current) === null || _root$current3 === void 0 ? void 0 : _root$current3.setNativeProps(args);\n },\n isFocused: () => {\n var _root$current4;\n return ((_root$current4 = root.current) === null || _root$current4 === void 0 ? void 0 : _root$current4.isFocused()) || false;\n },\n blur: () => {\n var _root$current5;\n return (_root$current5 = root.current) === null || _root$current5 === void 0 ? void 0 : _root$current5.blur();\n },\n forceFocus: () => {\n var _root$current6;\n return (_root$current6 = root.current) === null || _root$current6 === void 0 ? void 0 : _root$current6.focus();\n }\n }));\n React.useEffect(() => {\n // When the input has an error, we wiggle the label and apply error styles\n if (errorProp) {\n // show error\n Animated.timing(error, {\n toValue: 1,\n duration: FOCUS_ANIMATION_DURATION * scale,\n // To prevent this - https://github.com/callstack/react-native-paper/issues/941\n useNativeDriver: true\n }).start();\n } else {\n // hide error\n {\n Animated.timing(error, {\n toValue: 0,\n duration: BLUR_ANIMATION_DURATION * scale,\n // To prevent this - https://github.com/callstack/react-native-paper/issues/941\n useNativeDriver: true\n }).start();\n }\n }\n }, [errorProp, scale, error]);\n React.useEffect(() => {\n // Show placeholder text only if the input is focused, or there's no label\n // We don't show placeholder if there's a label because the label acts as placeholder\n // When focused, the label moves up, so we can show a placeholder\n if (focused || !rest.label) {\n // If the user wants to use the contextMenu, when changing the placeholder, the contextMenu is closed\n // This is a workaround to mitigate this behavior in scenarios where the placeholder is not specified.\n if (rest.placeholder) {\n // Set the placeholder in a delay to offset the label animation\n // If we show it immediately, they'll overlap and look ugly\n timer.current = setTimeout(() => setPlaceholder(rest.placeholder), 50);\n }\n } else {\n // hidePlaceholder\n\n // Issue: https://github.com/callstack/react-native-paper/issues/3138\n // Description: Changing the placeholder text value dynamically,\n // within multiline input on iOS, doesn't work properly –\n // the placeholder is not displayed initially.\n // Root cause: Placeholder initial value, which has length 0.\n // More context: The issue was also reproduced in react-native, using its own TextInput.\n // Workaround: Set an empty space character in the default value.\n setPlaceholder(' ');\n }\n return () => {\n if (timer.current) {\n clearTimeout(timer.current);\n }\n };\n }, [focused, rest.label, rest.placeholder]);\n React.useEffect(() => {\n labeled.stopAnimation();\n // The label should be minimized if the text input is focused, or has text\n // In minimized mode, the label moves up and becomes small\n // workaround for animated regression for react native > 0.61\n // https://github.com/callstack/react-native-paper/pull/1440\n if (value || focused) {\n // minimize label\n Animated.timing(labeled, {\n toValue: 0,\n duration: BLUR_ANIMATION_DURATION * scale,\n // To prevent this - https://github.com/callstack/react-native-paper/issues/941\n useNativeDriver: true\n }).start();\n } else {\n // restore label\n Animated.timing(labeled, {\n toValue: 1,\n duration: FOCUS_ANIMATION_DURATION * scale,\n // To prevent this - https://github.com/callstack/react-native-paper/issues/941\n useNativeDriver: true\n }).start();\n }\n }, [focused, value, labeled, scale]);\n const onLeftAffixLayoutChange = React.useCallback(event => {\n const height = roundLayoutSize(event.nativeEvent.layout.height);\n const width = roundLayoutSize(event.nativeEvent.layout.width);\n if (width !== leftLayout.width || height !== leftLayout.height) {\n setLeftLayout({\n width,\n height\n });\n }\n }, [leftLayout.height, leftLayout.width]);\n const onRightAffixLayoutChange = React.useCallback(event => {\n const width = roundLayoutSize(event.nativeEvent.layout.width);\n const height = roundLayoutSize(event.nativeEvent.layout.height);\n if (width !== rightLayout.width || height !== rightLayout.height) {\n setRightLayout({\n width,\n height\n });\n }\n }, [rightLayout.height, rightLayout.width]);\n const handleFocus = args => {\n var _rest$onFocus;\n if (disabled || !editable) {\n return;\n }\n setFocused(true);\n (_rest$onFocus = rest.onFocus) === null || _rest$onFocus === void 0 ? void 0 : _rest$onFocus.call(rest, args);\n };\n const handleBlur = args => {\n var _rest$onBlur;\n if (!editable) {\n return;\n }\n setFocused(false);\n (_rest$onBlur = rest.onBlur) === null || _rest$onBlur === void 0 ? void 0 : _rest$onBlur.call(rest, args);\n };\n const handleChangeText = value => {\n var _rest$onChangeText;\n if (!editable || disabled) {\n return;\n }\n if (!isControlled) {\n // Keep track of value in local state when input is not controlled\n setUncontrolledValue(value);\n }\n (_rest$onChangeText = rest.onChangeText) === null || _rest$onChangeText === void 0 ? void 0 : _rest$onChangeText.call(rest, value);\n };\n const handleLayoutAnimatedText = React.useCallback(e => {\n const width = roundLayoutSize(e.nativeEvent.layout.width);\n const height = roundLayoutSize(e.nativeEvent.layout.height);\n if (width !== labelLayout.width || height !== labelLayout.height) {\n setLabelLayout({\n width,\n height,\n measured: true\n });\n }\n }, [labelLayout.height, labelLayout.width]);\n const handleLabelTextLayout = React.useCallback(_ref2 => {\n let {\n nativeEvent\n } = _ref2;\n setLabelTextLayout({\n width: nativeEvent.lines.reduce((acc, line) => acc + Math.ceil(line.width), 0)\n });\n }, []);\n const handleInputContainerLayout = React.useCallback(_ref3 => {\n let {\n nativeEvent: {\n layout\n }\n } = _ref3;\n setInputContainerLayout({\n width: layout.width\n });\n }, []);\n const forceFocus = React.useCallback(() => {\n var _root$current7;\n return (_root$current7 = root.current) === null || _root$current7 === void 0 ? void 0 : _root$current7.focus();\n }, []);\n const {\n maxFontSizeMultiplier = 1.5\n } = rest;\n const scaledLabel = !!(value || focused);\n if (mode === 'outlined') {\n return /*#__PURE__*/React.createElement(TextInputOutlined, _extends({\n dense: dense,\n disabled: disabled,\n error: errorProp,\n multiline: multiline,\n editable: editable,\n render: render\n }, rest, {\n theme: theme,\n value: value,\n parentState: {\n labeled,\n error,\n focused,\n placeholder,\n value,\n labelTextLayout,\n labelLayout,\n leftLayout,\n rightLayout,\n inputContainerLayout\n },\n innerRef: ref => {\n root.current = ref;\n },\n onFocus: handleFocus,\n forceFocus: forceFocus,\n onBlur: handleBlur,\n onChangeText: handleChangeText,\n onLayoutAnimatedText: handleLayoutAnimatedText,\n onInputLayout: handleInputContainerLayout,\n onLabelTextLayout: handleLabelTextLayout,\n onLeftAffixLayoutChange: onLeftAffixLayoutChange,\n onRightAffixLayoutChange: onRightAffixLayoutChange,\n maxFontSizeMultiplier: maxFontSizeMultiplier,\n contentStyle: contentStyle,\n scaledLabel: scaledLabel\n }));\n }\n return /*#__PURE__*/React.createElement(TextInputFlat, _extends({\n dense: dense,\n disabled: disabled,\n error: errorProp,\n multiline: multiline,\n editable: editable,\n render: render\n }, rest, {\n theme: theme,\n value: value,\n parentState: {\n labeled,\n error,\n focused,\n placeholder,\n value,\n labelTextLayout,\n labelLayout,\n leftLayout,\n rightLayout,\n inputContainerLayout\n },\n innerRef: ref => {\n root.current = ref;\n },\n onFocus: handleFocus,\n forceFocus: forceFocus,\n onBlur: handleBlur,\n onInputLayout: handleInputContainerLayout,\n onChangeText: handleChangeText,\n onLayoutAnimatedText: handleLayoutAnimatedText,\n onLabelTextLayout: handleLabelTextLayout,\n onLeftAffixLayoutChange: onLeftAffixLayoutChange,\n onRightAffixLayoutChange: onRightAffixLayoutChange,\n maxFontSizeMultiplier: maxFontSizeMultiplier,\n contentStyle: contentStyle,\n scaledLabel: scaledLabel\n }));\n});\n// @component ./Adornment/TextInputIcon.tsx\nTextInput.Icon = TextInputIcon;\n\n// @component ./Adornment/TextInputAffix.tsx\n// @ts-ignore Types of property 'theme' are incompatible.\nTextInput.Affix = TextInputAffix;\nexport default TextInput;\n//# sourceMappingURL=TextInput.js.map","import React from 'react';\nimport { Animated, Pressable, StyleSheet, Text } from 'react-native';\nimport { AdornmentSide } from './enums';\nimport { getTextColor } from './utils';\nimport { useInternalTheme } from '../../../core/theming';\nimport { getConstants } from '../helpers';\nconst AffixContext = /*#__PURE__*/React.createContext({\n textStyle: {\n fontFamily: '',\n color: ''\n },\n topPosition: null,\n side: AdornmentSide.Left\n});\nconst AffixAdornment = _ref => {\n let {\n affix,\n side,\n textStyle,\n topPosition,\n onLayout,\n visible,\n paddingHorizontal,\n maxFontSizeMultiplier,\n testID,\n disabled\n } = _ref;\n return /*#__PURE__*/React.createElement(AffixContext.Provider, {\n value: {\n side,\n textStyle,\n topPosition,\n onLayout,\n visible,\n paddingHorizontal,\n maxFontSizeMultiplier,\n testID,\n disabled\n }\n }, affix);\n};\n\n/**\n * A component to render a leading / trailing text in the TextInput\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { TextInput } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [text, setText] = React.useState('');\n *\n * return (\n * }\n * />\n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\n\nconst TextInputAffix = _ref2 => {\n let {\n text,\n textStyle: labelStyle,\n theme: themeOverrides,\n onLayout: onTextLayout,\n onPress,\n accessibilityLabel = text\n } = _ref2;\n const theme = useInternalTheme(themeOverrides);\n const {\n AFFIX_OFFSET\n } = getConstants(theme.isV3);\n const {\n textStyle,\n onLayout,\n topPosition,\n side,\n visible,\n paddingHorizontal,\n maxFontSizeMultiplier,\n testID,\n disabled\n } = React.useContext(AffixContext);\n const offset = typeof paddingHorizontal === 'number' ? paddingHorizontal : AFFIX_OFFSET;\n const style = {\n top: topPosition,\n [side]: offset\n };\n const textColor = getTextColor({\n theme,\n disabled\n });\n const content = /*#__PURE__*/React.createElement(Text, {\n maxFontSizeMultiplier: maxFontSizeMultiplier,\n style: [{\n color: textColor\n }, textStyle, labelStyle],\n onLayout: onTextLayout,\n testID: `${testID}-text`\n }, text);\n return /*#__PURE__*/React.createElement(Animated.View, {\n style: [styles.container, style, {\n opacity: (visible === null || visible === void 0 ? void 0 : visible.interpolate({\n inputRange: [0, 1],\n outputRange: [1, 0]\n })) || 1\n }],\n onLayout: onLayout,\n testID: testID\n }, onPress ? /*#__PURE__*/React.createElement(Pressable, {\n onPress: onPress,\n accessibilityRole: \"button\",\n accessibilityLabel: accessibilityLabel\n }, content) : content);\n};\nTextInputAffix.displayName = 'TextInput.Affix';\nconst styles = StyleSheet.create({\n container: {\n position: 'absolute',\n justifyContent: 'center',\n alignItems: 'center'\n }\n});\nexport default TextInputAffix;\n\n// @component-docs ignore-next-line\nexport { TextInputAffix, AffixAdornment };\n//# sourceMappingURL=TextInputAffix.js.map","export let AdornmentType = /*#__PURE__*/function (AdornmentType) {\n AdornmentType[\"Icon\"] = \"icon\";\n AdornmentType[\"Affix\"] = \"affix\";\n return AdornmentType;\n}({});\nexport let AdornmentSide = /*#__PURE__*/function (AdornmentSide) {\n AdornmentSide[\"Right\"] = \"right\";\n AdornmentSide[\"Left\"] = \"left\";\n return AdornmentSide;\n}({});\nexport let InputMode = /*#__PURE__*/function (InputMode) {\n InputMode[\"Outlined\"] = \"outlined\";\n InputMode[\"Flat\"] = \"flat\";\n return InputMode;\n}({});\n//# sourceMappingURL=enums.js.map","import color from 'color';\nexport function getTextColor(_ref) {\n var _theme$colors;\n let {\n theme,\n disabled\n } = _ref;\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n return theme.colors.onSurfaceVariant;\n }\n return color((_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.text).alpha(theme.dark ? 0.7 : 0.54).rgb().string();\n}\nexport function getIconColor(_ref2) {\n let {\n theme,\n isTextInputFocused,\n disabled,\n customColor\n } = _ref2;\n if (typeof customColor === 'function') {\n return customColor(isTextInputFocused);\n }\n if (customColor) {\n return customColor;\n }\n if (!theme.isV3) {\n return theme.colors.text;\n }\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n return theme.colors.onSurfaceVariant;\n}\n//# sourceMappingURL=utils.js.map","import { Platform } from 'react-native';\nimport color from 'color';\nimport { AdornmentSide, AdornmentType } from './Adornment/enums';\nimport { MIN_WIDTH, ADORNMENT_SIZE, MD2_ADORNMENT_OFFSET, MD2_AFFIX_OFFSET, MD2_FLAT_INPUT_OFFSET, MD2_ICON_OFFSET, MD2_INPUT_PADDING_HORIZONTAL, MD2_LABEL_PADDING_HORIZONTAL, MD2_LABEL_PADDING_TOP, MD2_MIN_HEIGHT, MD2_OUTLINED_INPUT_OFFSET, MD3_ADORNMENT_OFFSET, MD3_AFFIX_OFFSET, MD3_FLAT_INPUT_OFFSET, MD3_ICON_OFFSET, MD3_INPUT_PADDING_HORIZONTAL, MD3_LABEL_PADDING_HORIZONTAL, MD3_LABEL_PADDING_TOP, MD3_MIN_HEIGHT, MD3_OUTLINED_INPUT_OFFSET } from './constants';\nexport const calculateLabelTopPosition = function (labelHeight) {\n let height = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n let optionalPadding = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;\n const customHeight = height > 0 ? height : 0;\n return Math.floor((customHeight - labelHeight) / 2 + optionalPadding);\n};\nexport const calculateInputHeight = function (labelHeight) {\n let height = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n let minHeight = arguments.length > 2 ? arguments[2] : undefined;\n const finalHeight = height > 0 ? height : labelHeight;\n if (height > 0) return height;\n return finalHeight < minHeight ? minHeight : finalHeight;\n};\nexport const calculatePadding = props => {\n const {\n height,\n multiline = false\n } = props;\n let result = 0;\n if (multiline) {\n if (height && multiline) {\n result = calculateTextAreaPadding(props);\n } else {\n result = calculateInputPadding(props);\n }\n }\n return Math.max(0, result);\n};\nconst calculateTextAreaPadding = props => {\n const {\n dense\n } = props;\n return dense ? 10 : 20;\n};\nconst calculateInputPadding = _ref => {\n let {\n topPosition,\n fontSize,\n multiline,\n scale,\n dense,\n offset,\n isAndroid\n } = _ref;\n const refFontSize = scale * fontSize;\n let result = Math.floor(topPosition / 2);\n result = result + Math.floor((refFontSize - fontSize) / 2) - (scale < 1 ? offset / 2 : 0);\n if (multiline && isAndroid) result = Math.min(dense ? offset / 2 : offset, result);\n return result;\n};\nexport const adjustPaddingOut = _ref2 => {\n let {\n pad,\n multiline,\n label,\n scale,\n height,\n fontSize,\n lineHeight,\n dense,\n offset,\n isAndroid\n } = _ref2;\n const fontHeight = lineHeight ?? fontSize;\n const refFontHeight = scale * fontSize;\n let result = pad;\n if (!isAndroid && height && !multiline) {\n return {\n paddingTop: Math.max(0, (height - fontHeight) / 2),\n paddingBottom: Math.max(0, (height - fontHeight) / 2)\n };\n }\n if (!isAndroid && multiline) {\n if (dense) {\n if (label) {\n result += scale < 1 ? Math.min(offset, refFontHeight / 2 * scale) : 0;\n } else {\n result += 0;\n }\n }\n if (!dense) {\n if (label) {\n result += scale < 1 ? Math.min(offset, refFontHeight * scale) : Math.min(offset / 2, refFontHeight * scale);\n } else {\n result += scale < 1 ? Math.min(offset / 2, refFontHeight * scale) : 0;\n }\n }\n result = Math.floor(result);\n }\n return {\n paddingTop: result,\n paddingBottom: result\n };\n};\nexport const adjustPaddingFlat = _ref3 => {\n let {\n pad,\n scale,\n multiline,\n label,\n height,\n offset,\n dense,\n fontSize,\n isAndroid,\n styles\n } = _ref3;\n let result = pad;\n let topResult = result;\n let bottomResult = result;\n const {\n paddingTop,\n paddingBottom\n } = styles;\n const refFontSize = scale * fontSize;\n if (!multiline) {\n // do not modify padding if input is not multiline\n if (label) {\n // return const style for flat input with label\n return {\n paddingTop,\n paddingBottom\n };\n }\n // return pad for flat input without label\n return {\n paddingTop: result,\n paddingBottom: result\n };\n }\n if (label) {\n // add paddings passed from styles\n topResult = paddingTop;\n bottomResult = paddingBottom;\n\n // adjust top padding for iOS\n if (!isAndroid) {\n if (dense) {\n topResult += scale < 1 ? Math.min(result, refFontSize * scale) - result / 2 : Math.min(result, refFontSize * scale) - result / 2;\n }\n if (!dense) {\n topResult += scale < 1 ? Math.min(offset / 2, refFontSize * scale) : Math.min(result, refFontSize * scale) - offset / 2;\n }\n }\n topResult = Math.floor(topResult);\n } else {\n if (height) {\n // center text when height is passed\n return {\n paddingTop: Math.max(0, (height - fontSize) / 2),\n paddingBottom: Math.max(0, (height - fontSize) / 2)\n };\n }\n // adjust paddings for iOS if no label\n if (!isAndroid) {\n if (dense) {\n result += scale < 1 ? Math.min(offset / 2, fontSize / 2 * scale) : Math.min(offset / 2, scale);\n }\n if (!dense) {\n result += scale < 1 ? Math.min(offset, fontSize * scale) : Math.min(fontSize, offset / 2 * scale);\n }\n result = Math.floor(result);\n topResult = result;\n bottomResult = result;\n }\n }\n return {\n paddingTop: Math.max(0, topResult),\n paddingBottom: Math.max(0, bottomResult)\n };\n};\nexport function calculateFlatAffixTopPosition(_ref4) {\n let {\n height,\n paddingTop,\n paddingBottom,\n affixHeight\n } = _ref4;\n const inputHeightWithoutPadding = height - paddingTop - paddingBottom;\n const halfOfTheInputHeightDecreasedByAffixHeight = (inputHeightWithoutPadding - affixHeight) / 2;\n return paddingTop + halfOfTheInputHeightDecreasedByAffixHeight;\n}\nexport function calculateOutlinedIconAndAffixTopPosition(_ref5) {\n let {\n height,\n affixHeight,\n labelYOffset\n } = _ref5;\n return (height - affixHeight + labelYOffset) / 2;\n}\nexport const calculateFlatInputHorizontalPadding = _ref6 => {\n let {\n adornmentConfig,\n isV3\n } = _ref6;\n const {\n LABEL_PADDING_HORIZONTAL,\n ADORNMENT_OFFSET,\n FLAT_INPUT_OFFSET\n } = getConstants(isV3);\n let paddingLeft = LABEL_PADDING_HORIZONTAL;\n let paddingRight = LABEL_PADDING_HORIZONTAL;\n adornmentConfig.forEach(_ref7 => {\n let {\n type,\n side\n } = _ref7;\n if (type === AdornmentType.Icon && side === AdornmentSide.Left) {\n paddingLeft = ADORNMENT_SIZE + ADORNMENT_OFFSET + FLAT_INPUT_OFFSET;\n } else if (side === AdornmentSide.Right) {\n if (type === AdornmentType.Affix) {\n paddingRight = ADORNMENT_SIZE + ADORNMENT_OFFSET + FLAT_INPUT_OFFSET;\n } else if (type === AdornmentType.Icon) {\n paddingRight = ADORNMENT_SIZE + ADORNMENT_OFFSET + FLAT_INPUT_OFFSET;\n }\n }\n });\n return {\n paddingLeft,\n paddingRight\n };\n};\nconst getInputTextColor = _ref8 => {\n let {\n theme,\n textColor,\n disabled\n } = _ref8;\n if (textColor) {\n return textColor;\n }\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n return theme.colors.onSurface;\n }\n if (disabled) {\n return color(theme.colors.text).alpha(0.54).rgb().string();\n }\n return theme.colors.text;\n};\nconst getActiveColor = _ref9 => {\n let {\n theme,\n disabled,\n error,\n activeUnderlineColor,\n activeOutlineColor,\n mode\n } = _ref9;\n const isFlat = mode === 'flat';\n const modeColor = isFlat ? activeUnderlineColor : activeOutlineColor;\n if (error) {\n return theme.colors.error;\n }\n if (modeColor) {\n return modeColor;\n }\n if (disabled) {\n if (theme.isV3) {\n return theme.colors.onSurfaceDisabled;\n }\n return color(theme.colors.text).alpha(0.54).rgb().string();\n }\n return theme.colors.primary;\n};\nconst getPlaceholderColor = _ref10 => {\n let {\n theme,\n disabled\n } = _ref10;\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n return theme.colors.onSurfaceVariant;\n }\n if (disabled) {\n return theme.colors.disabled;\n }\n return theme.colors.placeholder;\n};\nconst getSelectionColor = _ref11 => {\n let {\n activeColor,\n customSelectionColor\n } = _ref11;\n if (typeof customSelectionColor !== 'undefined') {\n return customSelectionColor;\n }\n if (Platform.OS === 'android') {\n return color(activeColor).alpha(0.54).rgb().string();\n }\n return activeColor;\n};\nconst getFlatBackgroundColor = _ref12 => {\n var _theme$colors, _theme$colors2;\n let {\n theme,\n disabled\n } = _ref12;\n if (theme.isV3) {\n if (disabled) {\n return color(theme.colors.onSurface).alpha(0.04).rgb().string();\n } else {\n return theme.colors.surfaceVariant;\n }\n }\n if (disabled) {\n return undefined;\n }\n return theme.dark ? color((_theme$colors = theme.colors) === null || _theme$colors === void 0 ? void 0 : _theme$colors.background).lighten(0.24).rgb().string() : color((_theme$colors2 = theme.colors) === null || _theme$colors2 === void 0 ? void 0 : _theme$colors2.background).darken(0.06).rgb().string();\n};\nconst getFlatUnderlineColor = _ref13 => {\n let {\n theme,\n disabled,\n underlineColor\n } = _ref13;\n if (!disabled && underlineColor) {\n return underlineColor;\n }\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n return theme.colors.onSurfaceVariant;\n }\n if (disabled) {\n return 'transparent';\n }\n return theme.colors.disabled;\n};\nconst getOutlinedOutlineInputColor = _ref14 => {\n let {\n theme,\n disabled,\n customOutlineColor\n } = _ref14;\n const isTransparent = color(customOutlineColor).alpha() === 0;\n if (!disabled && customOutlineColor) {\n return customOutlineColor;\n }\n if (theme.isV3) {\n if (disabled) {\n if (theme.dark) {\n return 'transparent';\n }\n return theme.colors.surfaceDisabled;\n }\n return theme.colors.outline;\n }\n if (disabled) {\n if (isTransparent) {\n return customOutlineColor;\n }\n return theme.colors.disabled;\n }\n return theme.colors.placeholder;\n};\nexport const getFlatInputColors = _ref15 => {\n let {\n underlineColor,\n activeUnderlineColor,\n customSelectionColor,\n textColor,\n disabled,\n error,\n theme\n } = _ref15;\n const baseFlatColorProps = {\n theme,\n disabled\n };\n const activeColor = getActiveColor({\n ...baseFlatColorProps,\n error,\n activeUnderlineColor,\n mode: 'flat'\n });\n return {\n inputTextColor: getInputTextColor({\n ...baseFlatColorProps,\n textColor\n }),\n activeColor,\n underlineColorCustom: getFlatUnderlineColor({\n ...baseFlatColorProps,\n underlineColor\n }),\n placeholderColor: getPlaceholderColor(baseFlatColorProps),\n selectionColor: getSelectionColor({\n activeColor,\n customSelectionColor\n }),\n errorColor: theme.colors.error,\n backgroundColor: getFlatBackgroundColor(baseFlatColorProps)\n };\n};\nexport const getOutlinedInputColors = _ref16 => {\n let {\n activeOutlineColor,\n customOutlineColor,\n customSelectionColor,\n textColor,\n disabled,\n error,\n theme\n } = _ref16;\n const baseOutlinedColorProps = {\n theme,\n disabled\n };\n const activeColor = getActiveColor({\n ...baseOutlinedColorProps,\n error,\n activeOutlineColor,\n mode: 'outlined'\n });\n return {\n inputTextColor: getInputTextColor({\n ...baseOutlinedColorProps,\n textColor\n }),\n activeColor,\n outlineColor: getOutlinedOutlineInputColor({\n ...baseOutlinedColorProps,\n customOutlineColor\n }),\n placeholderColor: getPlaceholderColor(baseOutlinedColorProps),\n selectionColor: getSelectionColor({\n activeColor,\n customSelectionColor\n }),\n errorColor: theme.colors.error\n };\n};\nexport const getConstants = isV3 => {\n // Text input affix\n let AFFIX_OFFSET;\n // Text input icon\n let ICON_OFFSET;\n //Text input flat\n let LABEL_PADDING_TOP;\n let LABEL_PADDING_HORIZONTAL;\n let FLAT_INPUT_OFFSET;\n let MIN_HEIGHT;\n // Text input outlined;\n let INPUT_PADDING_HORIZONTAL;\n let ADORNMENT_OFFSET;\n let OUTLINED_INPUT_OFFSET;\n if (isV3) {\n AFFIX_OFFSET = MD3_AFFIX_OFFSET;\n ICON_OFFSET = MD3_ICON_OFFSET;\n LABEL_PADDING_TOP = MD3_LABEL_PADDING_TOP;\n LABEL_PADDING_HORIZONTAL = MD3_LABEL_PADDING_HORIZONTAL;\n FLAT_INPUT_OFFSET = MD3_FLAT_INPUT_OFFSET;\n MIN_HEIGHT = MD3_MIN_HEIGHT;\n INPUT_PADDING_HORIZONTAL = MD3_INPUT_PADDING_HORIZONTAL;\n ADORNMENT_OFFSET = MD3_ADORNMENT_OFFSET;\n OUTLINED_INPUT_OFFSET = MD3_OUTLINED_INPUT_OFFSET;\n } else {\n AFFIX_OFFSET = MD2_AFFIX_OFFSET;\n ICON_OFFSET = MD2_ICON_OFFSET;\n LABEL_PADDING_TOP = MD2_LABEL_PADDING_TOP;\n LABEL_PADDING_HORIZONTAL = MD2_LABEL_PADDING_HORIZONTAL;\n FLAT_INPUT_OFFSET = MD2_FLAT_INPUT_OFFSET;\n MIN_HEIGHT = MD2_MIN_HEIGHT;\n INPUT_PADDING_HORIZONTAL = MD2_INPUT_PADDING_HORIZONTAL;\n ADORNMENT_OFFSET = MD2_ADORNMENT_OFFSET;\n OUTLINED_INPUT_OFFSET = MD2_OUTLINED_INPUT_OFFSET;\n }\n return {\n AFFIX_OFFSET,\n ICON_OFFSET,\n LABEL_PADDING_TOP,\n LABEL_PADDING_HORIZONTAL,\n FLAT_INPUT_OFFSET,\n MIN_HEIGHT,\n INPUT_PADDING_HORIZONTAL,\n ADORNMENT_OFFSET,\n OUTLINED_INPUT_OFFSET,\n MIN_WIDTH\n };\n};\n//# sourceMappingURL=helpers.js.map","export const MAXIMIZED_LABEL_FONT_SIZE = 16;\nexport const MINIMIZED_LABEL_FONT_SIZE = 12;\nexport const LABEL_WIGGLE_X_OFFSET = 4;\nexport const ADORNMENT_SIZE = 24;\nexport const MIN_WIDTH = 100;\n\n//Text input affix offset\nexport const MD2_AFFIX_OFFSET = 12;\nexport const MD3_AFFIX_OFFSET = 16;\n\n// Text input icon\nexport const ICON_SIZE = 24;\nexport const MD2_ICON_OFFSET = 12;\nexport const MD3_ICON_OFFSET = 16;\n\n// Text input common\nexport const MD2_MIN_HEIGHT = 64;\nexport const MD3_MIN_HEIGHT = 56;\nexport const MD3_ADORNMENT_OFFSET = 16;\nexport const MD2_ADORNMENT_OFFSET = 12;\nexport const LABEL_PADDING_TOP_DENSE = 24;\nexport const LABEL_PADDING_TOP = 8;\n\n// Text input flat\nexport const MD2_LABEL_PADDING_TOP = 30;\nexport const MD3_LABEL_PADDING_TOP = 26;\nexport const MD2_LABEL_PADDING_HORIZONTAL = 12;\nexport const MD3_LABEL_PADDING_HORIZONTAL = 16;\nexport const MD2_FLAT_INPUT_OFFSET = 8;\nexport const MD3_FLAT_INPUT_OFFSET = 16;\nexport const MINIMIZED_LABEL_Y_OFFSET = -18;\nexport const MIN_DENSE_HEIGHT_WL = 52;\nexport const MIN_DENSE_HEIGHT = 40;\n\n// Text input outlined\nexport const MD2_INPUT_PADDING_HORIZONTAL = 14;\nexport const MD3_INPUT_PADDING_HORIZONTAL = 16;\n\n// extra space to avoid overlapping input's text and icon\nexport const MD2_OUTLINED_INPUT_OFFSET = 8;\nexport const MD3_OUTLINED_INPUT_OFFSET = 16;\nexport const OUTLINE_MINIMIZED_LABEL_Y_OFFSET = -6;\nexport const MIN_DENSE_HEIGHT_OUTLINED = 48;\n//# sourceMappingURL=constants.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { getIconColor } from './utils';\nimport { useInternalTheme } from '../../../core/theming';\nimport IconButton from '../../IconButton/IconButton';\nimport { ICON_SIZE } from '../constants';\nimport { getConstants } from '../helpers';\nconst StyleContext = /*#__PURE__*/React.createContext({\n style: {},\n isTextInputFocused: false,\n forceFocus: () => {},\n testID: ''\n});\nconst IconAdornment = _ref => {\n let {\n icon,\n topPosition,\n side,\n isTextInputFocused,\n forceFocus,\n testID,\n theme: themeOverrides,\n disabled\n } = _ref;\n const {\n isV3\n } = useInternalTheme(themeOverrides);\n const {\n ICON_OFFSET\n } = getConstants(isV3);\n const style = {\n top: topPosition,\n [side]: ICON_OFFSET\n };\n const contextState = {\n style,\n isTextInputFocused,\n forceFocus,\n testID,\n disabled\n };\n return /*#__PURE__*/React.createElement(StyleContext.Provider, {\n value: contextState\n }, icon);\n};\n\n/**\n * A component to render a leading / trailing icon in the TextInput\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { TextInput } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [text, setText] = React.useState('');\n *\n * return (\n * }\n * />\n * );\n * };\n *\n * export default MyComponent;\n * ```\n */\n\nconst TextInputIcon = _ref2 => {\n let {\n icon,\n onPress,\n forceTextInputFocus = true,\n color: customColor,\n theme: themeOverrides,\n rippleColor,\n ...rest\n } = _ref2;\n const {\n style,\n isTextInputFocused,\n forceFocus,\n testID,\n disabled\n } = React.useContext(StyleContext);\n const onPressWithFocusControl = React.useCallback(e => {\n if (forceTextInputFocus && !isTextInputFocused) {\n forceFocus();\n }\n onPress === null || onPress === void 0 ? void 0 : onPress(e);\n }, [forceTextInputFocus, forceFocus, isTextInputFocused, onPress]);\n const theme = useInternalTheme(themeOverrides);\n const iconColor = getIconColor({\n theme,\n disabled,\n isTextInputFocused,\n customColor\n });\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.container, style]\n }, /*#__PURE__*/React.createElement(IconButton, _extends({\n icon: icon,\n style: styles.iconButton,\n size: ICON_SIZE,\n onPress: onPressWithFocusControl,\n iconColor: iconColor,\n testID: testID,\n theme: themeOverrides,\n rippleColor: rippleColor\n }, rest)));\n};\nTextInputIcon.displayName = 'TextInput.Icon';\nconst styles = StyleSheet.create({\n container: {\n position: 'absolute',\n width: ICON_SIZE,\n height: ICON_SIZE,\n justifyContent: 'center',\n alignItems: 'center'\n },\n iconButton: {\n margin: 0\n }\n});\nexport default TextInputIcon;\n\n// @component-docs ignore-next-line\nexport { IconAdornment };\n//# sourceMappingURL=TextInputIcon.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { I18nManager, Platform, StyleSheet, TextInput as NativeTextInput, View, Animated } from 'react-native';\nimport { Underline } from './Addons/Underline';\nimport { AdornmentSide, AdornmentType, InputMode } from './Adornment/enums';\nimport TextInputAdornment from './Adornment/TextInputAdornment';\nimport { getAdornmentConfig, getAdornmentStyleAdjustmentForNativeInput } from './Adornment/TextInputAdornment';\nimport { ADORNMENT_SIZE, LABEL_PADDING_TOP_DENSE, LABEL_WIGGLE_X_OFFSET, MAXIMIZED_LABEL_FONT_SIZE, MINIMIZED_LABEL_FONT_SIZE, MINIMIZED_LABEL_Y_OFFSET, MIN_DENSE_HEIGHT, MIN_DENSE_HEIGHT_WL } from './constants';\nimport { adjustPaddingFlat, calculateFlatAffixTopPosition, calculateFlatInputHorizontalPadding, calculateInputHeight, calculateLabelTopPosition, calculatePadding, getConstants, getFlatInputColors } from './helpers';\nimport InputLabel from './Label/InputLabel';\nconst TextInputFlat = _ref => {\n let {\n disabled = false,\n editable = true,\n label,\n error = false,\n selectionColor: customSelectionColor,\n cursorColor,\n underlineColor,\n underlineStyle,\n activeUnderlineColor,\n textColor,\n dense,\n style,\n theme,\n render = props => /*#__PURE__*/React.createElement(NativeTextInput, props),\n multiline = false,\n parentState,\n innerRef,\n onFocus,\n forceFocus,\n onBlur,\n onChangeText,\n onLayoutAnimatedText,\n onLabelTextLayout,\n onLeftAffixLayoutChange,\n onRightAffixLayoutChange,\n onInputLayout,\n left,\n right,\n placeholderTextColor,\n testID = 'text-input-flat',\n contentStyle,\n scaledLabel,\n ...rest\n } = _ref;\n const isAndroid = Platform.OS === 'android';\n const {\n colors,\n isV3,\n roundness\n } = theme;\n const font = isV3 ? theme.fonts.bodyLarge : theme.fonts.regular;\n const hasActiveOutline = parentState.focused || error;\n const {\n LABEL_PADDING_TOP,\n FLAT_INPUT_OFFSET,\n MIN_HEIGHT,\n MIN_WIDTH\n } = getConstants(isV3);\n const {\n fontSize: fontSizeStyle,\n lineHeight: lineHeightStyle,\n fontWeight,\n height,\n paddingHorizontal,\n textAlign,\n ...viewStyle\n } = StyleSheet.flatten(style) || {};\n const fontSize = fontSizeStyle || MAXIMIZED_LABEL_FONT_SIZE;\n const lineHeight = lineHeightStyle || (Platform.OS === 'web' ? fontSize * 1.2 : undefined);\n const isPaddingHorizontalPassed = paddingHorizontal !== undefined && typeof paddingHorizontal === 'number';\n const adornmentConfig = getAdornmentConfig({\n left,\n right\n });\n let {\n paddingLeft,\n paddingRight\n } = calculateFlatInputHorizontalPadding({\n adornmentConfig,\n isV3\n });\n if (isPaddingHorizontalPassed) {\n paddingLeft = paddingHorizontal;\n paddingRight = paddingHorizontal;\n }\n const {\n leftLayout,\n rightLayout\n } = parentState;\n const rightAffixWidth = right ? rightLayout.width || ADORNMENT_SIZE : ADORNMENT_SIZE;\n const leftAffixWidth = left ? leftLayout.width || ADORNMENT_SIZE : ADORNMENT_SIZE;\n const adornmentStyleAdjustmentForNativeInput = getAdornmentStyleAdjustmentForNativeInput({\n adornmentConfig,\n rightAffixWidth,\n leftAffixWidth,\n paddingHorizontal,\n inputOffset: FLAT_INPUT_OFFSET,\n mode: InputMode.Flat,\n isV3\n });\n const {\n inputTextColor,\n activeColor,\n underlineColorCustom,\n placeholderColor,\n errorColor,\n backgroundColor,\n selectionColor\n } = getFlatInputColors({\n underlineColor,\n activeUnderlineColor,\n customSelectionColor,\n textColor,\n disabled,\n error,\n theme\n });\n const containerStyle = {\n backgroundColor,\n borderTopLeftRadius: theme.roundness,\n borderTopRightRadius: theme.roundness\n };\n const labelScale = MINIMIZED_LABEL_FONT_SIZE / fontSize;\n const fontScale = MAXIMIZED_LABEL_FONT_SIZE / fontSize;\n const labelWidth = parentState.labelLayout.width;\n const labelHeight = parentState.labelLayout.height;\n const labelHalfWidth = labelWidth / 2;\n const labelHalfHeight = labelHeight / 2;\n const baseLabelTranslateX = (I18nManager.getConstants().isRTL ? 1 : -1) * (labelHalfWidth - labelScale * labelWidth / 2) + (1 - labelScale) * (I18nManager.getConstants().isRTL ? -1 : 1) * paddingLeft;\n const minInputHeight = dense ? (label ? MIN_DENSE_HEIGHT_WL : MIN_DENSE_HEIGHT) - LABEL_PADDING_TOP_DENSE : MIN_HEIGHT - LABEL_PADDING_TOP;\n const inputHeight = calculateInputHeight(labelHeight, height, minInputHeight);\n const topPosition = calculateLabelTopPosition(labelHeight, inputHeight, multiline && height ? 0 : !height ? minInputHeight / 2 : 0);\n if (height && typeof height !== 'number') {\n // eslint-disable-next-line\n console.warn('Currently we support only numbers in height prop');\n }\n const paddingSettings = {\n height: height ? +height : null,\n labelHalfHeight,\n offset: FLAT_INPUT_OFFSET,\n multiline: multiline ? multiline : null,\n dense: dense ? dense : null,\n topPosition,\n fontSize,\n lineHeight,\n label,\n scale: fontScale,\n isAndroid,\n styles: StyleSheet.flatten(dense ? styles.inputFlatDense : styles.inputFlat)\n };\n const pad = calculatePadding(paddingSettings);\n const paddingFlat = adjustPaddingFlat({\n ...paddingSettings,\n pad\n });\n const baseLabelTranslateY = -labelHalfHeight - (topPosition + MINIMIZED_LABEL_Y_OFFSET);\n const {\n current: placeholderOpacityAnims\n } = React.useRef([new Animated.Value(0), new Animated.Value(1)]);\n const placeholderOpacity = hasActiveOutline ? parentState.labeled : placeholderOpacityAnims[parentState.labelLayout.measured ? 1 : 0];\n const minHeight = height || (dense ? label ? MIN_DENSE_HEIGHT_WL : MIN_DENSE_HEIGHT : MIN_HEIGHT);\n const flatHeight = inputHeight + (!height ? dense ? LABEL_PADDING_TOP_DENSE : LABEL_PADDING_TOP : 0);\n const iconTopPosition = (flatHeight - ADORNMENT_SIZE) / 2;\n const leftAffixTopPosition = leftLayout.height ? calculateFlatAffixTopPosition({\n height: flatHeight,\n ...paddingFlat,\n affixHeight: leftLayout.height\n }) : null;\n const rightAffixTopPosition = rightLayout.height ? calculateFlatAffixTopPosition({\n height: flatHeight,\n ...paddingFlat,\n affixHeight: rightLayout.height\n }) : null;\n const labelProps = {\n label,\n onLayoutAnimatedText,\n onLabelTextLayout,\n placeholderOpacity,\n labelError: error,\n placeholderStyle: styles.placeholder,\n baseLabelTranslateY,\n baseLabelTranslateX,\n font,\n fontSize,\n lineHeight,\n fontWeight,\n labelScale,\n wiggleOffsetX: LABEL_WIGGLE_X_OFFSET,\n topPosition,\n paddingLeft: isAndroid ? I18nManager.isRTL ? paddingRight : paddingLeft : paddingLeft,\n paddingRight: isAndroid ? I18nManager.isRTL ? paddingLeft : paddingRight : paddingRight,\n hasActiveOutline,\n activeColor,\n placeholderColor,\n errorColor,\n roundness,\n maxFontSizeMultiplier: rest.maxFontSizeMultiplier,\n testID,\n contentStyle,\n inputContainerLayout: parentState.inputContainerLayout,\n labelTextLayout: parentState.labelTextLayout,\n opacity: parentState.value || parentState.focused ? parentState.labelLayout.measured ? 1 : 0 : 1,\n isV3\n };\n const affixTopPosition = {\n [AdornmentSide.Left]: leftAffixTopPosition,\n [AdornmentSide.Right]: rightAffixTopPosition\n };\n const onAffixChange = {\n [AdornmentSide.Left]: onLeftAffixLayoutChange,\n [AdornmentSide.Right]: onRightAffixLayoutChange\n };\n let adornmentProps = {\n paddingHorizontal,\n adornmentConfig,\n forceFocus,\n topPosition: {\n [AdornmentType.Affix]: affixTopPosition,\n [AdornmentType.Icon]: iconTopPosition\n },\n onAffixChange,\n isTextInputFocused: parentState.focused,\n maxFontSizeMultiplier: rest.maxFontSizeMultiplier,\n disabled\n };\n if (adornmentConfig.length) {\n adornmentProps = {\n ...adornmentProps,\n left,\n right,\n textStyle: {\n ...font,\n fontSize,\n lineHeight,\n fontWeight\n },\n visible: parentState.labeled\n };\n }\n return /*#__PURE__*/React.createElement(View, {\n style: [containerStyle, viewStyle]\n }, /*#__PURE__*/React.createElement(Underline, {\n style: underlineStyle,\n hasActiveOutline: hasActiveOutline,\n parentState: parentState,\n underlineColorCustom: underlineColorCustom,\n error: error,\n colors: colors,\n activeColor: activeColor,\n theme: theme\n }), /*#__PURE__*/React.createElement(View, {\n onLayout: onInputLayout,\n style: [styles.labelContainer, {\n minHeight\n }]\n }, !isAndroid && multiline && !!label && !disabled &&\n /*#__PURE__*/\n // Workaround for: https://github.com/callstack/react-native-paper/issues/2799\n // Patch for a multiline TextInput with fixed height, which allow to avoid covering input label with its value.\n React.createElement(View, {\n testID: \"patch-container\",\n pointerEvents: \"none\",\n style: [StyleSheet.absoluteFill, dense ? styles.densePatchContainer : styles.patchContainer, {\n backgroundColor: viewStyle.backgroundColor || containerStyle.backgroundColor,\n left: paddingLeft,\n right: paddingRight\n }]\n }), label ? /*#__PURE__*/React.createElement(InputLabel, _extends({\n labeled: parentState.labeled,\n error: parentState.error,\n focused: parentState.focused,\n scaledLabel: scaledLabel,\n wiggle: Boolean(parentState.value && labelProps.labelError),\n labelLayoutMeasured: parentState.labelLayout.measured,\n labelLayoutWidth: parentState.labelLayout.width,\n labelLayoutHeight: parentState.labelLayout.height\n }, labelProps)) : null, render === null || render === void 0 ? void 0 : render({\n ...rest,\n ref: innerRef,\n onChangeText,\n placeholder: label ? parentState.placeholder : rest.placeholder,\n editable: !disabled && editable,\n selectionColor,\n cursorColor: typeof cursorColor === 'undefined' ? activeColor : cursorColor,\n placeholderTextColor: placeholderTextColor ?? placeholderColor,\n onFocus,\n onBlur,\n underlineColorAndroid: 'transparent',\n multiline,\n style: [styles.input, multiline && height ? {\n height: flatHeight\n } : {}, paddingFlat, {\n paddingLeft,\n paddingRight,\n ...font,\n fontSize,\n lineHeight,\n fontWeight,\n color: inputTextColor,\n textAlignVertical: multiline ? 'top' : 'center',\n textAlign: textAlign ? textAlign : I18nManager.getConstants().isRTL ? 'right' : 'left',\n minWidth: Math.min(parentState.labelTextLayout.width + 2 * FLAT_INPUT_OFFSET, MIN_WIDTH)\n }, Platform.OS === 'web' && {\n outline: 'none'\n }, adornmentStyleAdjustmentForNativeInput, contentStyle],\n testID\n })), /*#__PURE__*/React.createElement(TextInputAdornment, adornmentProps));\n};\nexport default TextInputFlat;\nconst styles = StyleSheet.create({\n placeholder: {\n position: 'absolute',\n left: 0\n },\n labelContainer: {\n paddingTop: 0,\n paddingBottom: 0,\n flexGrow: 1\n },\n input: {\n margin: 0,\n flexGrow: 1\n },\n inputFlat: {\n paddingTop: 24,\n paddingBottom: 4\n },\n inputFlatDense: {\n paddingTop: 22,\n paddingBottom: 2\n },\n patchContainer: {\n height: 24,\n zIndex: 2\n },\n densePatchContainer: {\n height: 22,\n zIndex: 2\n }\n});\n//# sourceMappingURL=TextInputFlat.js.map","import * as React from 'react';\nimport { Animated, StyleSheet } from 'react-native';\nimport { useInternalTheme } from '../../../core/theming';\nexport const Underline = _ref => {\n let {\n parentState,\n error,\n colors,\n activeColor,\n underlineColorCustom,\n hasActiveOutline,\n style,\n theme: themeOverrides\n } = _ref;\n const {\n isV3\n } = useInternalTheme(themeOverrides);\n let backgroundColor = parentState.focused ? activeColor : underlineColorCustom;\n if (error) backgroundColor = colors === null || colors === void 0 ? void 0 : colors.error;\n const activeScale = isV3 ? 2 : 1;\n return /*#__PURE__*/React.createElement(Animated.View, {\n testID: \"text-input-underline\",\n style: [styles.underline, isV3 && styles.md3Underline, {\n backgroundColor,\n // Underlines is thinner when input is not focused\n transform: [{\n scaleY: (isV3 ? hasActiveOutline : parentState.focused) ? activeScale : 0.5\n }]\n }, style]\n });\n};\nconst styles = StyleSheet.create({\n underline: {\n position: 'absolute',\n left: 0,\n right: 0,\n bottom: 0,\n height: 2,\n zIndex: 1\n },\n md3Underline: {\n height: 1\n }\n});\n//# sourceMappingURL=Underline.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport React from 'react';\nimport { AdornmentSide, AdornmentType, InputMode } from './enums';\nimport TextInputAffix, { AffixAdornment } from './TextInputAffix';\nimport TextInputIcon, { IconAdornment } from './TextInputIcon';\nimport { getConstants } from '../helpers';\nexport function getAdornmentConfig(_ref) {\n let {\n left,\n right\n } = _ref;\n let adornmentConfig = [];\n if (left || right) {\n [{\n side: AdornmentSide.Left,\n adornment: left\n }, {\n side: AdornmentSide.Right,\n adornment: right\n }].forEach(_ref2 => {\n let {\n side,\n adornment\n } = _ref2;\n if (adornment && /*#__PURE__*/React.isValidElement(adornment)) {\n let type;\n if (adornment.type === TextInputAffix) {\n type = AdornmentType.Affix;\n } else if (adornment.type === TextInputIcon) {\n type = AdornmentType.Icon;\n }\n adornmentConfig.push({\n side,\n type\n });\n }\n });\n }\n return adornmentConfig;\n}\nexport function getAdornmentStyleAdjustmentForNativeInput(_ref3) {\n let {\n adornmentConfig,\n leftAffixWidth,\n rightAffixWidth,\n paddingHorizontal,\n inputOffset = 0,\n mode,\n isV3\n } = _ref3;\n const {\n OUTLINED_INPUT_OFFSET,\n ADORNMENT_OFFSET\n } = getConstants(isV3);\n if (adornmentConfig.length) {\n const adornmentStyleAdjustmentForNativeInput = adornmentConfig.map(_ref4 => {\n let {\n type,\n side\n } = _ref4;\n const isLeftSide = side === AdornmentSide.Left;\n const inputModeAdornemntOffset = mode === InputMode.Outlined ? ADORNMENT_OFFSET + OUTLINED_INPUT_OFFSET : ADORNMENT_OFFSET;\n const paddingKey = `padding${captalize(side)}`;\n const affixWidth = isLeftSide ? leftAffixWidth : rightAffixWidth;\n const padding = typeof paddingHorizontal === 'number' ? paddingHorizontal : inputModeAdornemntOffset;\n const offset = affixWidth + padding;\n const isAffix = type === AdornmentType.Affix;\n const marginKey = `margin${captalize(side)}`;\n return {\n [marginKey]: isAffix ? 0 : offset,\n [paddingKey]: isAffix ? offset : inputOffset\n };\n });\n const allStyleAdjustmentsMerged = adornmentStyleAdjustmentForNativeInput.reduce((mergedStyles, currentStyle) => {\n return {\n ...mergedStyles,\n ...currentStyle\n };\n }, {});\n return allStyleAdjustmentsMerged;\n } else {\n return [{}];\n }\n}\nconst captalize = text => text.charAt(0).toUpperCase() + text.slice(1);\nconst TextInputAdornment = _ref5 => {\n let {\n adornmentConfig,\n left,\n right,\n onAffixChange,\n textStyle,\n visible,\n topPosition,\n isTextInputFocused,\n forceFocus,\n paddingHorizontal,\n maxFontSizeMultiplier,\n theme,\n disabled\n } = _ref5;\n if (adornmentConfig.length) {\n return /*#__PURE__*/React.createElement(React.Fragment, null, adornmentConfig.map(_ref6 => {\n let {\n type,\n side\n } = _ref6;\n let inputAdornmentComponent;\n if (side === AdornmentSide.Left) {\n inputAdornmentComponent = left;\n } else if (side === AdornmentSide.Right) {\n inputAdornmentComponent = right;\n }\n const commonProps = {\n side: side,\n testID: `${side}-${type}-adornment`,\n isTextInputFocused,\n paddingHorizontal,\n disabled\n };\n if (type === AdornmentType.Icon) {\n return /*#__PURE__*/React.createElement(IconAdornment, _extends({}, commonProps, {\n theme: theme,\n key: side,\n icon: inputAdornmentComponent,\n topPosition: topPosition[AdornmentType.Icon],\n forceFocus: forceFocus\n }));\n } else if (type === AdornmentType.Affix) {\n return /*#__PURE__*/React.createElement(AffixAdornment, _extends({}, commonProps, {\n key: side,\n topPosition: topPosition[AdornmentType.Affix][side],\n affix: inputAdornmentComponent,\n textStyle: textStyle,\n onLayout: onAffixChange[side],\n visible: visible,\n maxFontSizeMultiplier: maxFontSizeMultiplier\n }));\n } else {\n return null;\n }\n }));\n } else {\n return null;\n }\n};\nexport default TextInputAdornment;\n//# sourceMappingURL=TextInputAdornment.js.map","import React from 'react';\nimport { Animated, Platform, StyleSheet, useWindowDimensions, View } from 'react-native';\nimport AnimatedText from '../../Typography/AnimatedText';\nimport { getConstants } from '../helpers';\nconst InputLabel = props => {\n const {\n labeled,\n wiggle,\n error,\n focused,\n opacity,\n labelLayoutWidth,\n labelLayoutHeight,\n labelBackground,\n label,\n labelError,\n onLayoutAnimatedText,\n onLabelTextLayout,\n hasActiveOutline,\n activeColor,\n placeholderStyle,\n baseLabelTranslateX,\n baseLabelTranslateY,\n font,\n fontSize,\n lineHeight,\n fontWeight,\n placeholderOpacity,\n wiggleOffsetX,\n labelScale,\n topPosition,\n paddingLeft,\n paddingRight,\n backgroundColor,\n roundness,\n placeholderColor,\n errorColor,\n labelTranslationXOffset,\n maxFontSizeMultiplier,\n testID,\n isV3,\n inputContainerLayout,\n scaledLabel\n } = props;\n const {\n INPUT_PADDING_HORIZONTAL\n } = getConstants(isV3);\n const {\n width\n } = useWindowDimensions();\n const paddingOffset = paddingLeft && paddingRight ? {\n paddingLeft,\n paddingRight\n } : {};\n const labelTranslationX = {\n transform: [{\n // Offset label scale since RN doesn't support transform origin\n translateX: labeled.interpolate({\n inputRange: [0, 1],\n outputRange: [baseLabelTranslateX, labelTranslationXOffset || 0]\n })\n }]\n };\n const labelStyle = {\n ...font,\n fontSize,\n lineHeight,\n fontWeight,\n opacity: labeled.interpolate({\n inputRange: [0, 1],\n outputRange: [hasActiveOutline ? 1 : 0, 0]\n }),\n transform: [{\n // Wiggle the label when there's an error\n translateX: wiggle ? error.interpolate({\n inputRange: [0, 0.5, 1],\n outputRange: [0, wiggleOffsetX, 0]\n }) : 0\n }, {\n // Move label to top\n translateY: baseLabelTranslateY !== 0 ? labeled.interpolate({\n inputRange: [0, 1],\n outputRange: [baseLabelTranslateY, 0]\n }) : 0\n }, {\n // Make label smaller\n scale: labelScale !== 0 ? labeled.interpolate({\n inputRange: [0, 1],\n outputRange: [labelScale, 1]\n }) : labeled\n }]\n };\n const labelWidth = (inputContainerLayout.width + INPUT_PADDING_HORIZONTAL / 2) / (scaledLabel ? labelScale : 1);\n const commonStyles = [placeholderStyle, {\n top: topPosition\n }, {\n maxWidth: labelWidth\n }, labelStyle, paddingOffset || {}];\n const textColor = labelError && errorColor ? errorColor : placeholderColor;\n return (\n /*#__PURE__*/\n // Position colored placeholder and gray placeholder on top of each other and crossfade them\n // This gives the effect of animating the color, but allows us to use native driver\n React.createElement(View, {\n pointerEvents: \"none\",\n style: [StyleSheet.absoluteFill, styles.overflow]\n }, /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: \"none\",\n style: [StyleSheet.absoluteFill, styles.labelContainer, Platform.OS !== 'web' && {\n width\n }, {\n opacity\n }, labelTranslationX]\n }, /*#__PURE__*/React.createElement(View, {\n style: {\n width: labelWidth\n }\n }, labelBackground === null || labelBackground === void 0 ? void 0 : labelBackground({\n labeled,\n labelLayoutWidth,\n labelLayoutHeight,\n labelStyle,\n placeholderStyle,\n baseLabelTranslateX,\n topPosition,\n label,\n backgroundColor,\n roundness,\n maxFontSizeMultiplier: maxFontSizeMultiplier,\n testID\n }), /*#__PURE__*/React.createElement(AnimatedText, {\n variant: \"bodySmall\",\n onLayout: onLayoutAnimatedText,\n onTextLayout: onLabelTextLayout,\n style: [commonStyles, {\n color: activeColor\n }],\n numberOfLines: 1,\n maxFontSizeMultiplier: maxFontSizeMultiplier,\n testID: `${testID}-label-active`\n }, label), /*#__PURE__*/React.createElement(AnimatedText, {\n variant: focused ? 'bodyLarge' : 'bodySmall',\n style: [commonStyles, {\n color: textColor,\n opacity: placeholderOpacity\n }],\n numberOfLines: 1,\n maxFontSizeMultiplier: maxFontSizeMultiplier,\n testID: `${testID}-label-inactive`\n }, label))))\n );\n};\nconst styles = StyleSheet.create({\n overflow: {\n overflow: 'hidden'\n },\n labelContainer: {\n zIndex: 3\n }\n});\nexport default /*#__PURE__*/React.memo(InputLabel);\n//# sourceMappingURL=InputLabel.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Animated, View, TextInput as NativeTextInput, StyleSheet, I18nManager, Platform } from 'react-native';\nimport { Outline } from './Addons/Outline';\nimport { AdornmentType, AdornmentSide } from './Adornment/enums';\nimport TextInputAdornment, { getAdornmentConfig, getAdornmentStyleAdjustmentForNativeInput } from './Adornment/TextInputAdornment';\nimport { MAXIMIZED_LABEL_FONT_SIZE, MINIMIZED_LABEL_FONT_SIZE, LABEL_WIGGLE_X_OFFSET, ADORNMENT_SIZE, OUTLINE_MINIMIZED_LABEL_Y_OFFSET, LABEL_PADDING_TOP, MIN_DENSE_HEIGHT_OUTLINED, LABEL_PADDING_TOP_DENSE } from './constants';\nimport { calculateLabelTopPosition, calculateInputHeight, calculatePadding, adjustPaddingOut, calculateOutlinedIconAndAffixTopPosition, getOutlinedInputColors, getConstants } from './helpers';\nimport InputLabel from './Label/InputLabel';\nimport LabelBackground from './Label/LabelBackground';\nconst TextInputOutlined = _ref => {\n let {\n disabled = false,\n editable = true,\n label,\n error = false,\n selectionColor: customSelectionColor,\n cursorColor,\n underlineColor: _underlineColor,\n outlineColor: customOutlineColor,\n activeOutlineColor,\n outlineStyle,\n textColor,\n dense,\n style,\n theme,\n render = props => /*#__PURE__*/React.createElement(NativeTextInput, props),\n multiline = false,\n parentState,\n innerRef,\n onFocus,\n forceFocus,\n onBlur,\n onChangeText,\n onLayoutAnimatedText,\n onLabelTextLayout,\n onLeftAffixLayoutChange,\n onRightAffixLayoutChange,\n onInputLayout,\n onLayout,\n left,\n right,\n placeholderTextColor,\n testID = 'text-input-outlined',\n contentStyle,\n scaledLabel,\n ...rest\n } = _ref;\n const adornmentConfig = getAdornmentConfig({\n left,\n right\n });\n const {\n colors,\n isV3,\n roundness\n } = theme;\n const font = isV3 ? theme.fonts.bodyLarge : theme.fonts.regular;\n const hasActiveOutline = parentState.focused || error;\n const {\n INPUT_PADDING_HORIZONTAL,\n MIN_HEIGHT,\n ADORNMENT_OFFSET,\n MIN_WIDTH\n } = getConstants(isV3);\n const {\n fontSize: fontSizeStyle,\n fontWeight,\n lineHeight: lineHeightStyle,\n height,\n backgroundColor = colors === null || colors === void 0 ? void 0 : colors.background,\n textAlign,\n ...viewStyle\n } = StyleSheet.flatten(style) || {};\n const fontSize = fontSizeStyle || MAXIMIZED_LABEL_FONT_SIZE;\n const lineHeight = lineHeightStyle || (Platform.OS === 'web' ? fontSize * 1.2 : undefined);\n const {\n inputTextColor,\n activeColor,\n outlineColor,\n placeholderColor,\n errorColor,\n selectionColor\n } = getOutlinedInputColors({\n activeOutlineColor,\n customOutlineColor,\n customSelectionColor,\n textColor,\n disabled,\n error,\n theme\n });\n const densePaddingTop = label ? LABEL_PADDING_TOP_DENSE : 0;\n const paddingTop = label ? LABEL_PADDING_TOP : 0;\n const yOffset = label ? OUTLINE_MINIMIZED_LABEL_Y_OFFSET : 0;\n const labelScale = MINIMIZED_LABEL_FONT_SIZE / fontSize;\n const fontScale = MAXIMIZED_LABEL_FONT_SIZE / fontSize;\n const labelWidth = parentState.labelLayout.width;\n const labelHeight = parentState.labelLayout.height;\n const labelHalfWidth = labelWidth / 2;\n const labelHalfHeight = labelHeight / 2;\n const baseLabelTranslateX = (I18nManager.getConstants().isRTL ? 1 : -1) * (labelHalfWidth - labelScale * labelWidth / 2 - (fontSize - MINIMIZED_LABEL_FONT_SIZE) * labelScale);\n let labelTranslationXOffset = 0;\n const isAdornmentLeftIcon = adornmentConfig.some(_ref2 => {\n let {\n side,\n type\n } = _ref2;\n return side === AdornmentSide.Left && type === AdornmentType.Icon;\n });\n const isAdornmentRightIcon = adornmentConfig.some(_ref3 => {\n let {\n side,\n type\n } = _ref3;\n return side === AdornmentSide.Right && type === AdornmentType.Icon;\n });\n if (isAdornmentLeftIcon) {\n labelTranslationXOffset = (I18nManager.getConstants().isRTL ? -1 : 1) * (ADORNMENT_SIZE + ADORNMENT_OFFSET - (isV3 ? 0 : 8));\n }\n const minInputHeight = (dense ? MIN_DENSE_HEIGHT_OUTLINED : MIN_HEIGHT) - paddingTop;\n const inputHeight = calculateInputHeight(labelHeight, height, minInputHeight);\n const topPosition = calculateLabelTopPosition(labelHeight, inputHeight, paddingTop);\n if (height && typeof height !== 'number') {\n // eslint-disable-next-line\n console.warn('Currently we support only numbers in height prop');\n }\n const paddingSettings = {\n height: height ? +height : null,\n labelHalfHeight,\n offset: paddingTop,\n multiline: multiline ? multiline : null,\n dense: dense ? dense : null,\n topPosition,\n fontSize,\n lineHeight,\n label,\n scale: fontScale,\n isAndroid: Platform.OS === 'android',\n styles: StyleSheet.flatten(dense ? styles.inputOutlinedDense : styles.inputOutlined)\n };\n const pad = calculatePadding(paddingSettings);\n const paddingOut = adjustPaddingOut({\n ...paddingSettings,\n pad\n });\n const baseLabelTranslateY = -labelHalfHeight - (topPosition + yOffset);\n const {\n current: placeholderOpacityAnims\n } = React.useRef([new Animated.Value(0), new Animated.Value(1)]);\n const placeholderOpacity = hasActiveOutline ? parentState.labeled : placeholderOpacityAnims[parentState.labelLayout.measured ? 1 : 0];\n const placeholderStyle = {\n position: 'absolute',\n left: 0,\n paddingHorizontal: INPUT_PADDING_HORIZONTAL\n };\n const labelBackgroundColor = backgroundColor === 'transparent' ? theme.colors.background : backgroundColor;\n const labelProps = {\n label,\n onLayoutAnimatedText,\n onLabelTextLayout,\n placeholderOpacity,\n labelError: error,\n placeholderStyle,\n baseLabelTranslateY,\n baseLabelTranslateX,\n font,\n fontSize,\n lineHeight,\n fontWeight,\n labelScale,\n wiggleOffsetX: LABEL_WIGGLE_X_OFFSET,\n topPosition,\n hasActiveOutline,\n activeColor,\n placeholderColor,\n backgroundColor: labelBackgroundColor,\n errorColor,\n labelTranslationXOffset,\n roundness,\n maxFontSizeMultiplier: rest.maxFontSizeMultiplier,\n testID,\n contentStyle,\n inputContainerLayout: {\n width: parentState.inputContainerLayout.width + (isAdornmentRightIcon || isAdornmentLeftIcon ? INPUT_PADDING_HORIZONTAL : 0)\n },\n opacity: parentState.value || parentState.focused ? parentState.labelLayout.measured ? 1 : 0 : 1,\n isV3\n };\n const onLayoutChange = React.useCallback(e => {\n onInputLayout(e);\n onLayout === null || onLayout === void 0 ? void 0 : onLayout(e);\n }, [onLayout, onInputLayout]);\n const minHeight = height || (dense ? MIN_DENSE_HEIGHT_OUTLINED : MIN_HEIGHT);\n const outlinedHeight = inputHeight + (dense ? densePaddingTop / 2 : paddingTop);\n const {\n leftLayout,\n rightLayout\n } = parentState;\n const leftAffixTopPosition = calculateOutlinedIconAndAffixTopPosition({\n height: outlinedHeight,\n affixHeight: leftLayout.height || 0,\n labelYOffset: -yOffset\n });\n const rightAffixTopPosition = calculateOutlinedIconAndAffixTopPosition({\n height: outlinedHeight,\n affixHeight: rightLayout.height || 0,\n labelYOffset: -yOffset\n });\n const iconTopPosition = calculateOutlinedIconAndAffixTopPosition({\n height: outlinedHeight,\n affixHeight: ADORNMENT_SIZE,\n labelYOffset: -yOffset\n });\n const rightAffixWidth = right ? rightLayout.width || ADORNMENT_SIZE : ADORNMENT_SIZE;\n const leftAffixWidth = left ? leftLayout.width || ADORNMENT_SIZE : ADORNMENT_SIZE;\n const adornmentStyleAdjustmentForNativeInput = getAdornmentStyleAdjustmentForNativeInput({\n adornmentConfig,\n rightAffixWidth,\n leftAffixWidth,\n mode: 'outlined',\n isV3\n });\n const affixTopPosition = {\n [AdornmentSide.Left]: leftAffixTopPosition,\n [AdornmentSide.Right]: rightAffixTopPosition\n };\n const onAffixChange = {\n [AdornmentSide.Left]: onLeftAffixLayoutChange,\n [AdornmentSide.Right]: onRightAffixLayoutChange\n };\n let adornmentProps = {\n adornmentConfig,\n forceFocus,\n topPosition: {\n [AdornmentType.Icon]: iconTopPosition,\n [AdornmentType.Affix]: affixTopPosition\n },\n onAffixChange,\n isTextInputFocused: parentState.focused,\n maxFontSizeMultiplier: rest.maxFontSizeMultiplier,\n disabled\n };\n if (adornmentConfig.length) {\n adornmentProps = {\n ...adornmentProps,\n left,\n right,\n textStyle: {\n ...font,\n fontSize,\n lineHeight,\n fontWeight\n },\n visible: parentState.labeled\n };\n }\n return /*#__PURE__*/React.createElement(View, {\n style: viewStyle\n }, /*#__PURE__*/React.createElement(Outline, {\n isV3: isV3,\n style: outlineStyle,\n label: label,\n roundness: roundness,\n hasActiveOutline: hasActiveOutline,\n focused: parentState.focused,\n activeColor: activeColor,\n outlineColor: outlineColor,\n backgroundColor: backgroundColor\n }), /*#__PURE__*/React.createElement(View, {\n style: [styles.labelContainer, {\n paddingTop,\n minHeight\n }]\n }, label ? /*#__PURE__*/React.createElement(InputLabel, _extends({\n labeled: parentState.labeled,\n error: parentState.error,\n focused: parentState.focused,\n scaledLabel: scaledLabel,\n wiggle: Boolean(parentState.value && labelProps.labelError),\n labelLayoutMeasured: parentState.labelLayout.measured,\n labelLayoutWidth: parentState.labelLayout.width,\n labelLayoutHeight: parentState.labelLayout.height\n }, labelProps, {\n labelBackground: LabelBackground,\n maxFontSizeMultiplier: rest.maxFontSizeMultiplier\n })) : null, render === null || render === void 0 ? void 0 : render({\n ...rest,\n ref: innerRef,\n onLayout: onLayoutChange,\n onChangeText,\n placeholder: label ? parentState.placeholder : rest.placeholder,\n editable: !disabled && editable,\n selectionColor,\n cursorColor: typeof cursorColor === 'undefined' ? activeColor : cursorColor,\n placeholderTextColor: placeholderTextColor || placeholderColor,\n onFocus,\n onBlur,\n underlineColorAndroid: 'transparent',\n multiline,\n style: [styles.input, !multiline || multiline && height ? {\n height: inputHeight\n } : {}, paddingOut, {\n ...font,\n fontSize,\n lineHeight,\n fontWeight,\n color: inputTextColor,\n textAlignVertical: multiline ? 'top' : 'center',\n textAlign: textAlign ? textAlign : I18nManager.getConstants().isRTL ? 'right' : 'left',\n paddingHorizontal: INPUT_PADDING_HORIZONTAL,\n minWidth: Math.min(parentState.labelTextLayout.width + 2 * INPUT_PADDING_HORIZONTAL, MIN_WIDTH)\n }, Platform.OS === 'web' && {\n outline: 'none'\n }, adornmentStyleAdjustmentForNativeInput, contentStyle],\n testID\n })), /*#__PURE__*/React.createElement(TextInputAdornment, adornmentProps));\n};\nexport default TextInputOutlined;\nconst styles = StyleSheet.create({\n labelContainer: {\n paddingBottom: 0,\n flexGrow: 1\n },\n input: {\n margin: 0,\n flexGrow: 1\n },\n inputOutlined: {\n paddingTop: 8,\n paddingBottom: 8\n },\n inputOutlinedDense: {\n paddingTop: 4,\n paddingBottom: 4\n }\n});\n//# sourceMappingURL=TextInputOutlined.js.map","import * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nexport const Outline = _ref => {\n let {\n isV3,\n label,\n activeColor,\n backgroundColor,\n hasActiveOutline,\n focused,\n outlineColor,\n roundness,\n style\n } = _ref;\n return /*#__PURE__*/React.createElement(View, {\n testID: \"text-input-outline\",\n pointerEvents: \"none\",\n style: [styles.outline, !label && styles.noLabelOutline,\n // eslint-disable-next-line react-native/no-inline-styles\n {\n backgroundColor,\n borderRadius: roundness,\n borderWidth: (isV3 ? hasActiveOutline : focused) ? 2 : 1,\n borderColor: hasActiveOutline ? activeColor : outlineColor\n }, style]\n });\n};\nconst styles = StyleSheet.create({\n outline: {\n position: 'absolute',\n left: 0,\n right: 0,\n top: 6,\n bottom: 0\n },\n noLabelOutline: {\n top: 0\n }\n});\n//# sourceMappingURL=Outline.js.map","import * as React from 'react';\nimport { Animated, StyleSheet } from 'react-native';\nimport AnimatedText from '../../Typography/AnimatedText';\nconst LabelBackground = _ref => {\n let {\n labeled,\n labelLayoutWidth,\n labelLayoutHeight,\n placeholderStyle,\n baseLabelTranslateX,\n topPosition,\n backgroundColor,\n roundness,\n labelStyle,\n maxFontSizeMultiplier,\n testID\n } = _ref;\n const opacity = labeled.interpolate({\n inputRange: [0, 0.6],\n outputRange: [1, 0]\n });\n const labelTranslationX = {\n translateX: labeled.interpolate({\n inputRange: [0, 1],\n outputRange: [-baseLabelTranslateX, 0]\n })\n };\n const labelTextScaleY = {\n scaleY: labeled.interpolate({\n inputRange: [0, 1],\n outputRange: [0.2, 1]\n })\n };\n const labelTextTransform = [...labelStyle.transform, labelTextScaleY];\n const isRounded = roundness > 6;\n const roundedEdgeCover = isRounded ? /*#__PURE__*/React.createElement(Animated.View, {\n key: \"labelBackground-view\",\n pointerEvents: \"none\",\n style: [StyleSheet.absoluteFill, styles.view, {\n backgroundColor,\n maxHeight: Math.max(roundness / 3, 2),\n bottom: Math.max(roundness, 2),\n transform: [labelTranslationX],\n opacity\n }]\n }) : null;\n return [roundedEdgeCover, /*#__PURE__*/React.createElement(AnimatedText, {\n key: \"labelBackground-text\",\n testID: `${testID}-label-background`,\n style: [placeholderStyle, labelStyle, styles.outlinedLabel, {\n top: topPosition + 1,\n width: labelLayoutWidth - placeholderStyle.paddingHorizontal,\n height: labelLayoutHeight,\n backgroundColor,\n opacity,\n transform: labelTextTransform\n }],\n numberOfLines: 1,\n maxFontSizeMultiplier: maxFontSizeMultiplier\n })];\n};\nexport default LabelBackground;\nconst styles = StyleSheet.create({\n view: {\n position: 'absolute',\n top: 6,\n left: 10,\n width: 12\n },\n // eslint-disable-next-line react-native/no-color-literals\n outlinedLabel: {\n position: 'absolute',\n left: 8,\n paddingHorizontal: 0,\n color: 'transparent'\n }\n});\n//# sourceMappingURL=LabelBackground.js.map","export const roundLayoutSize = size => Math.round(size * 1000) / 1000;\n//# sourceMappingURL=roundLayoutSize.js.map","import ToggleButtonComponent from './ToggleButton';\nimport ToggleButtonGroup from './ToggleButtonGroup';\nimport ToggleButtonRow from './ToggleButtonRow';\nconst ToggleButton = Object.assign(\n// @component ./ToggleButton.tsx\nToggleButtonComponent, {\n // @component ./ToggleButtonGroup.tsx\n Group: ToggleButtonGroup,\n // @component ./ToggleButtonRow.tsx\n Row: ToggleButtonRow\n});\nexport default ToggleButton;\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport color from 'color';\nimport { ToggleButtonGroupContext } from './ToggleButtonGroup';\nimport { getToggleButtonColor } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { black, white } from '../../styles/themes/v2/colors';\nimport { forwardRef } from '../../utils/forwardRef';\nimport IconButton from '../IconButton/IconButton';\n/**\n * Toggle buttons can be used to group related options. To emphasize groups of related toggle buttons,\n * a group should share a common container.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { ToggleButton } from 'react-native-paper';\n *\n * const ToggleButtonExample = () => {\n * const [status, setStatus] = React.useState('checked');\n *\n * const onButtonToggle = value => {\n * setStatus(status === 'checked' ? 'unchecked' : 'checked');\n * };\n *\n * return (\n * \n * );\n * };\n *\n * export default ToggleButtonExample;\n *\n * ```\n */\nconst ToggleButton = forwardRef((_ref, ref) => {\n let {\n icon,\n size,\n theme: themeOverrides,\n accessibilityLabel,\n disabled,\n style,\n value,\n status,\n onPress,\n rippleColor,\n ...rest\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const borderRadius = theme.roundness;\n return /*#__PURE__*/React.createElement(ToggleButtonGroupContext.Consumer, null, context => {\n const checked = context && context.value === value || status === 'checked';\n const backgroundColor = getToggleButtonColor({\n theme,\n checked\n });\n const borderColor = theme.isV3 ? theme.colors.outline : color(theme.dark ? white : black).alpha(0.29).rgb().string();\n return /*#__PURE__*/React.createElement(IconButton, _extends({\n borderless: false,\n icon: icon,\n onPress: e => {\n if (onPress) {\n onPress(e);\n }\n if (context) {\n context.onValueChange(!checked ? value : null);\n }\n },\n size: size,\n accessibilityLabel: accessibilityLabel,\n accessibilityState: {\n disabled,\n selected: checked\n },\n disabled: disabled,\n style: [styles.content, {\n backgroundColor,\n borderRadius,\n borderColor\n }, style],\n ref: ref,\n theme: theme,\n rippleColor: rippleColor\n }, rest));\n });\n});\nconst styles = StyleSheet.create({\n content: {\n width: 42,\n height: 42,\n margin: 0\n }\n});\nexport default ToggleButton;\n\n// @component-docs ignore-next-line\nexport { ToggleButton };\n//# sourceMappingURL=ToggleButton.js.map","import * as React from 'react';\nexport const ToggleButtonGroupContext =\n/*#__PURE__*/\n//@ts-expect-error: TS can't ensure the type from Group to children\nReact.createContext(null);\n\n/**\n * Toggle group allows to control a group of toggle buttons.
\n * It doesn't change the appearance of the toggle buttons. If you want to group them in a row, check out [ToggleButton.Row](ToggleButtonRow).\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { ToggleButton } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [value, setValue] = React.useState('left');\n *\n * return (\n * setValue(value)}\n * value={value}>\n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n *```\n */\nconst ToggleButtonGroup = _ref => {\n let {\n value,\n onValueChange,\n children\n } = _ref;\n return /*#__PURE__*/React.createElement(ToggleButtonGroupContext.Provider, {\n value: {\n value,\n onValueChange\n }\n }, children);\n};\nToggleButtonGroup.displayName = 'ToggleButton.Group';\nexport default ToggleButtonGroup;\n\n// @component-docs ignore-next-line\nexport { ToggleButtonGroup };\n//# sourceMappingURL=ToggleButtonGroup.js.map","import color from 'color';\nimport { tokens } from '../../styles/themes/v3/tokens';\nexport const getToggleButtonColor = _ref => {\n let {\n theme,\n checked\n } = _ref;\n if (checked) {\n if (theme.isV3) {\n return color(theme.colors.onSecondaryContainer).alpha(tokens.md.ref.opacity.level2).rgb().string();\n }\n if (theme.dark) {\n return 'rgba(255, 255, 255, .12)';\n }\n return 'rgba(0, 0, 0, .08)';\n }\n return 'transparent';\n};\n//# sourceMappingURL=utils.js.map","import * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport ToggleButton from './ToggleButton';\nimport ToggleButtonGroup from './ToggleButtonGroup';\n/**\n * Toggle button row renders a group of toggle buttons in a row.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { ToggleButton } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [value, setValue] = React.useState('left');\n *\n * return (\n * setValue(value)} value={value}>\n * \n * \n * \n * );\n * };\n *\n * export default MyComponent;\n *\n *```\n */\nconst ToggleButtonRow = _ref => {\n let {\n value,\n onValueChange,\n children,\n style\n } = _ref;\n const count = React.Children.count(children);\n return /*#__PURE__*/React.createElement(ToggleButtonGroup, {\n value: value,\n onValueChange: onValueChange\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.row, style]\n }, React.Children.map(children, (child, i) => {\n // @ts-expect-error: TypeScript complains about child.type but it doesn't matter\n if (child && child.type === ToggleButton) {\n // @ts-expect-error: We're sure that child is a React Element\n return /*#__PURE__*/React.cloneElement(child, {\n style: [styles.button, i === 0 ? styles.first : i === count - 1 ? styles.last : styles.middle,\n // @ts-expect-error: We're sure that child is a React Element\n child.props.style]\n });\n }\n return child;\n })));\n};\nToggleButtonRow.displayName = 'ToggleButton.Row';\nconst styles = StyleSheet.create({\n row: {\n flexDirection: 'row'\n },\n button: {\n borderWidth: StyleSheet.hairlineWidth\n },\n first: {\n borderTopRightRadius: 0,\n borderBottomRightRadius: 0\n },\n middle: {\n borderRadius: 0,\n borderLeftWidth: 0\n },\n last: {\n borderLeftWidth: 0,\n borderTopLeftRadius: 0,\n borderBottomLeftRadius: 0\n }\n});\nexport default ToggleButtonRow;\n\n// @component-docs ignore-next-line\nexport { ToggleButtonRow };\n//# sourceMappingURL=ToggleButtonRow.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport SegmentedButtonItem from './SegmentedButtonItem';\nimport { getDisabledSegmentedButtonStyle } from './utils';\nimport { useInternalTheme } from '../../core/theming';\n/**\n * Segmented buttons can be used to select options, switch views or sort elements.
\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { SafeAreaView, StyleSheet } from 'react-native';\n * import { SegmentedButtons } from 'react-native-paper';\n *\n * const MyComponent = () => {\n * const [value, setValue] = React.useState('');\n *\n * return (\n * \n * \n * \n * );\n * };\n *\n * const styles = StyleSheet.create({\n * container: {\n * flex: 1,\n * alignItems: 'center',\n * },\n * });\n *\n * export default MyComponent;\n *```\n */\nconst SegmentedButtons = _ref => {\n let {\n value,\n onValueChange,\n buttons,\n multiSelect,\n density,\n style,\n theme: themeOverrides\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n return /*#__PURE__*/React.createElement(View, {\n style: [styles.row, style]\n }, buttons.map((item, i) => {\n const disabledChildStyle = getDisabledSegmentedButtonStyle({\n theme,\n buttons,\n index: i\n });\n const segment = i === 0 ? 'first' : i === buttons.length - 1 ? 'last' : undefined;\n const checked = multiSelect && Array.isArray(value) ? value.includes(item.value) : value === item.value;\n const onPress = e => {\n var _item$onPress;\n (_item$onPress = item.onPress) === null || _item$onPress === void 0 ? void 0 : _item$onPress.call(item, e);\n const nextValue = multiSelect && Array.isArray(value) ? checked ? value.filter(val => item.value !== val) : [...value, item.value] : item.value;\n\n // @ts-expect-error: TS doesn't preserve types after destructuring, so the type isn't inferred correctly\n onValueChange(nextValue);\n };\n return /*#__PURE__*/React.createElement(SegmentedButtonItem, _extends({}, item, {\n key: i,\n checked: checked,\n segment: segment,\n density: density,\n onPress: onPress,\n style: [item.style, disabledChildStyle],\n labelStyle: item.labelStyle,\n theme: theme\n }));\n }));\n};\nconst styles = StyleSheet.create({\n row: {\n flexDirection: 'row'\n }\n});\nexport default SegmentedButtons;\n\n// @component-docs ignore-next-line\nexport { SegmentedButtons };\n//# sourceMappingURL=SegmentedButtons.js.map","import * as React from 'react';\nimport { Animated, StyleSheet, View } from 'react-native';\nimport color from 'color';\nimport { getSegmentedButtonBorderRadius, getSegmentedButtonColors, getSegmentedButtonDensityPadding } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport Icon from '../Icon';\nimport TouchableRipple from '../TouchableRipple/TouchableRipple';\nimport Text from '../Typography/Text';\nconst SegmentedButtonItem = _ref => {\n let {\n checked,\n accessibilityLabel,\n disabled,\n style,\n labelStyle,\n showSelectedCheck,\n checkedColor,\n uncheckedColor,\n rippleColor: customRippleColor,\n background,\n icon,\n testID,\n label,\n onPress,\n segment,\n density = 'regular',\n theme: themeOverrides,\n labelMaxFontSizeMultiplier\n } = _ref;\n const theme = useInternalTheme(themeOverrides);\n const checkScale = React.useRef(new Animated.Value(0)).current;\n React.useEffect(() => {\n if (!showSelectedCheck) {\n return;\n }\n if (checked) {\n Animated.spring(checkScale, {\n toValue: 1,\n useNativeDriver: true\n }).start();\n } else {\n Animated.spring(checkScale, {\n toValue: 0,\n useNativeDriver: true\n }).start();\n }\n }, [checked, checkScale, showSelectedCheck]);\n const {\n roundness,\n isV3\n } = theme;\n const {\n borderColor,\n textColor,\n borderWidth,\n backgroundColor\n } = getSegmentedButtonColors({\n checked,\n theme,\n disabled,\n checkedColor,\n uncheckedColor\n });\n const borderRadius = (isV3 ? 5 : 1) * roundness;\n const segmentBorderRadius = getSegmentedButtonBorderRadius({\n theme,\n segment\n });\n const rippleColor = customRippleColor || color(textColor).alpha(0.12).rgb().string();\n const showIcon = !icon ? false : label && checked ? !showSelectedCheck : true;\n const showCheckedIcon = checked && showSelectedCheck;\n const iconSize = isV3 ? 18 : 16;\n const iconStyle = {\n marginRight: label ? 5 : showCheckedIcon ? 3 : 0,\n ...(label && {\n transform: [{\n scale: checkScale.interpolate({\n inputRange: [0, 1],\n outputRange: [1, 0]\n })\n }]\n })\n };\n const buttonStyle = {\n backgroundColor,\n borderColor,\n borderWidth,\n borderRadius,\n ...segmentBorderRadius\n };\n const paddingVertical = getSegmentedButtonDensityPadding({\n density\n });\n const rippleStyle = {\n borderRadius,\n ...segmentBorderRadius\n };\n const labelTextStyle = {\n ...(!isV3 ? {\n textTransform: 'uppercase',\n fontWeight: '500'\n } : theme.fonts.labelLarge),\n color: textColor\n };\n return /*#__PURE__*/React.createElement(View, {\n style: [buttonStyle, styles.button, style]\n }, /*#__PURE__*/React.createElement(TouchableRipple, {\n borderless: true,\n onPress: onPress,\n accessibilityLabel: accessibilityLabel,\n accessibilityState: {\n disabled,\n checked\n },\n accessibilityRole: \"button\",\n disabled: disabled,\n rippleColor: rippleColor,\n testID: testID,\n style: rippleStyle,\n background: background,\n theme: theme\n }, /*#__PURE__*/React.createElement(View, {\n style: [styles.content, {\n paddingVertical\n }]\n }, showCheckedIcon ? /*#__PURE__*/React.createElement(Animated.View, {\n testID: `${testID}-check-icon`,\n style: [iconStyle, {\n transform: [{\n scale: checkScale\n }]\n }]\n }, /*#__PURE__*/React.createElement(Icon, {\n source: 'check',\n size: iconSize,\n color: textColor\n })) : null, showIcon ? /*#__PURE__*/React.createElement(Animated.View, {\n testID: `${testID}-icon`,\n style: iconStyle\n }, /*#__PURE__*/React.createElement(Icon, {\n source: icon,\n size: iconSize,\n color: textColor\n })) : null, /*#__PURE__*/React.createElement(Text, {\n variant: \"labelLarge\",\n style: [styles.label, labelTextStyle, labelStyle],\n selectable: false,\n numberOfLines: 1,\n maxFontSizeMultiplier: labelMaxFontSizeMultiplier,\n testID: `${testID}-label`\n }, label))));\n};\nconst styles = StyleSheet.create({\n button: {\n flex: 1,\n minWidth: 76,\n borderStyle: 'solid'\n },\n label: {\n textAlign: 'center'\n },\n content: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center',\n paddingVertical: 9,\n paddingHorizontal: 16\n }\n});\nexport default SegmentedButtonItem;\nexport { SegmentedButtonItem as SegmentedButton };\n//# sourceMappingURL=SegmentedButtonItem.js.map","import { StyleSheet } from 'react-native';\nimport color from 'color';\nimport { black, white } from '../../styles/themes/v2/colors';\nconst DEFAULT_PADDING = 9;\nexport const getSegmentedButtonDensityPadding = _ref => {\n let {\n density\n } = _ref;\n let padding = DEFAULT_PADDING;\n switch (density) {\n case 'small':\n return padding - 2;\n case 'medium':\n return padding - 4;\n case 'high':\n return padding - 8;\n default:\n return padding;\n }\n};\nexport const getDisabledSegmentedButtonStyle = _ref2 => {\n var _buttons$index, _buttons;\n let {\n theme,\n index,\n buttons\n } = _ref2;\n const width = getSegmentedButtonBorderWidth({\n theme\n });\n const isDisabled = (_buttons$index = buttons[index]) === null || _buttons$index === void 0 ? void 0 : _buttons$index.disabled;\n const isNextDisabled = (_buttons = buttons[index + 1]) === null || _buttons === void 0 ? void 0 : _buttons.disabled;\n if (!isDisabled && isNextDisabled) {\n return {\n borderRightWidth: width\n };\n }\n return {};\n};\nexport const getSegmentedButtonBorderRadius = _ref3 => {\n let {\n segment,\n theme\n } = _ref3;\n if (segment === 'first') {\n return {\n borderTopRightRadius: 0,\n borderBottomRightRadius: 0,\n ...(theme.isV3 && {\n borderRightWidth: 0\n })\n };\n } else if (segment === 'last') {\n return {\n borderTopLeftRadius: 0,\n borderBottomLeftRadius: 0\n };\n } else {\n return {\n borderRadius: 0,\n ...(theme.isV3 && {\n borderRightWidth: 0\n })\n };\n }\n};\nconst getSegmentedButtonBackgroundColor = _ref4 => {\n let {\n checked,\n theme\n } = _ref4;\n if (checked) {\n if (theme.isV3) {\n return theme.colors.secondaryContainer;\n } else {\n return color(theme.colors.primary).alpha(0.12).rgb().string();\n }\n }\n return 'transparent';\n};\nconst getSegmentedButtonBorderColor = _ref5 => {\n let {\n theme,\n disabled,\n checked\n } = _ref5;\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.surfaceDisabled;\n }\n return theme.colors.outline;\n }\n if (checked) {\n return theme.colors.primary;\n }\n return color(theme.dark ? white : black).alpha(0.29).rgb().string();\n};\nconst getSegmentedButtonBorderWidth = _ref6 => {\n let {\n theme\n } = _ref6;\n if (theme.isV3) {\n return 1;\n }\n return StyleSheet.hairlineWidth;\n};\nconst getSegmentedButtonTextColor = _ref7 => {\n let {\n theme,\n disabled,\n checked,\n checkedColor,\n uncheckedColor\n } = _ref7;\n if (theme.isV3) {\n if (disabled) {\n return theme.colors.onSurfaceDisabled;\n }\n if (checked) {\n return checkedColor ?? theme.colors.onSecondaryContainer;\n }\n return uncheckedColor ?? theme.colors.onSurface;\n }\n if (disabled) {\n return theme.colors.disabled;\n }\n // Primary color is used for checked state too.\n return theme.colors.primary;\n};\nexport const getSegmentedButtonColors = _ref8 => {\n let {\n theme,\n disabled,\n checked,\n checkedColor,\n uncheckedColor\n } = _ref8;\n const backgroundColor = getSegmentedButtonBackgroundColor({\n theme,\n checked\n });\n const borderColor = getSegmentedButtonBorderColor({\n theme,\n disabled,\n checked\n });\n const textColor = getSegmentedButtonTextColor({\n theme,\n disabled,\n checked,\n checkedColor,\n uncheckedColor\n });\n const borderWidth = getSegmentedButtonBorderWidth({\n theme\n });\n return {\n backgroundColor,\n borderColor,\n textColor,\n borderWidth\n };\n};\n//# sourceMappingURL=utils.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { Dimensions, View, StyleSheet, Platform, Pressable } from 'react-native';\nimport { getTooltipPosition } from './utils';\nimport { useInternalTheme } from '../../core/theming';\nimport { addEventListener } from '../../utils/addEventListener';\nimport Portal from '../Portal/Portal';\nimport Text from '../Typography/Text';\n/**\n * Tooltips display informative text when users hover over, focus on, or tap an element.\n *\n * Plain tooltips, when activated, display a text label identifying an element, such as a description of its function. Tooltips should include only short, descriptive text and avoid restating visible UI text.\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { IconButton, Tooltip } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * \n * {}} />\n * \n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Tooltip = _ref => {\n let {\n children,\n enterTouchDelay = 500,\n leaveTouchDelay = 1500,\n title,\n theme: themeOverrides,\n titleMaxFontSizeMultiplier,\n ...rest\n } = _ref;\n const isWeb = Platform.OS === 'web';\n const theme = useInternalTheme(themeOverrides);\n const [visible, setVisible] = React.useState(false);\n const [measurement, setMeasurement] = React.useState({\n children: {},\n tooltip: {},\n measured: false\n });\n const showTooltipTimer = React.useRef([]);\n const hideTooltipTimer = React.useRef([]);\n const childrenWrapperRef = React.useRef();\n const touched = React.useRef(false);\n React.useEffect(() => {\n return () => {\n if (showTooltipTimer.current.length) {\n showTooltipTimer.current.forEach(t => clearTimeout(t));\n showTooltipTimer.current = [];\n }\n if (hideTooltipTimer.current.length) {\n hideTooltipTimer.current.forEach(t => clearTimeout(t));\n hideTooltipTimer.current = [];\n }\n };\n }, []);\n React.useEffect(() => {\n const subscription = addEventListener(Dimensions, 'change', () => setVisible(false));\n return () => subscription.remove();\n }, []);\n const handleOnLayout = _ref2 => {\n let {\n nativeEvent: {\n layout\n }\n } = _ref2;\n childrenWrapperRef.current.measure((_x, _y, width, height, pageX, pageY) => {\n setMeasurement({\n children: {\n pageX,\n pageY,\n height,\n width\n },\n tooltip: {\n ...layout\n },\n measured: true\n });\n });\n };\n const handleTouchStart = () => {\n if (hideTooltipTimer.current.length) {\n hideTooltipTimer.current.forEach(t => clearTimeout(t));\n hideTooltipTimer.current = [];\n }\n if (isWeb) {\n let id = setTimeout(() => {\n touched.current = true;\n setVisible(true);\n }, enterTouchDelay);\n showTooltipTimer.current.push(id);\n } else {\n touched.current = true;\n setVisible(true);\n }\n };\n const handleTouchEnd = () => {\n touched.current = false;\n if (showTooltipTimer.current.length) {\n showTooltipTimer.current.forEach(t => clearTimeout(t));\n showTooltipTimer.current = [];\n }\n let id = setTimeout(() => {\n setVisible(false);\n setMeasurement({\n children: {},\n tooltip: {},\n measured: false\n });\n }, leaveTouchDelay);\n hideTooltipTimer.current.push(id);\n };\n const mobilePressProps = {\n onPress: React.useCallback(() => {\n if (touched.current) {\n return null;\n } else {\n var _children$props$onPre, _children$props;\n if (children.props.disabled) return null;\n return (_children$props$onPre = (_children$props = children.props).onPress) === null || _children$props$onPre === void 0 ? void 0 : _children$props$onPre.call(_children$props);\n }\n }, [children.props]),\n onLongPress: () => handleTouchStart(),\n onPressOut: () => handleTouchEnd(),\n delayLongPress: enterTouchDelay\n };\n const webPressProps = {\n onHoverIn: () => {\n var _children$props$onHov, _children$props2;\n handleTouchStart();\n (_children$props$onHov = (_children$props2 = children.props).onHoverIn) === null || _children$props$onHov === void 0 ? void 0 : _children$props$onHov.call(_children$props2);\n },\n onHoverOut: () => {\n var _children$props$onHov2, _children$props3;\n handleTouchEnd();\n (_children$props$onHov2 = (_children$props3 = children.props).onHoverOut) === null || _children$props$onHov2 === void 0 ? void 0 : _children$props$onHov2.call(_children$props3);\n }\n };\n return /*#__PURE__*/React.createElement(React.Fragment, null, visible && /*#__PURE__*/React.createElement(Portal, null, /*#__PURE__*/React.createElement(View, {\n onLayout: handleOnLayout,\n style: [styles.tooltip, {\n backgroundColor: theme.isV3 ? theme.colors.onSurface : theme.colors.tooltip,\n ...getTooltipPosition(measurement, children),\n borderRadius: theme.roundness,\n ...(measurement.measured ? styles.visible : styles.hidden)\n }],\n testID: \"tooltip-container\"\n }, /*#__PURE__*/React.createElement(Text, {\n accessibilityLiveRegion: \"polite\",\n numberOfLines: 1,\n selectable: false,\n variant: \"labelLarge\",\n style: {\n color: theme.colors.surface\n },\n maxFontSizeMultiplier: titleMaxFontSizeMultiplier\n }, title))), /*#__PURE__*/React.createElement(Pressable, _extends({\n ref: childrenWrapperRef,\n style: styles.pressContainer\n }, isWeb ? webPressProps : mobilePressProps), /*#__PURE__*/React.cloneElement(children, {\n ...rest,\n ...(isWeb ? webPressProps : mobilePressProps)\n })));\n};\nTooltip.displayName = 'Tooltip';\nconst styles = StyleSheet.create({\n tooltip: {\n alignSelf: 'flex-start',\n justifyContent: 'center',\n paddingHorizontal: 16,\n height: 32,\n maxHeight: 32\n },\n visible: {\n opacity: 1\n },\n hidden: {\n opacity: 0\n },\n pressContainer: {\n ...(Platform.OS === 'web' && {\n cursor: 'default'\n })\n }\n});\nexport default Tooltip;\n//# sourceMappingURL=Tooltip.js.map","import { Dimensions } from 'react-native';\n/**\n * Return true when the tooltip center x-coordinate relative to the wrapped element is negative.\n * The tooltip will be placed at the starting x-coordinate from the wrapped element.\n */\nconst overflowLeft = center => {\n return center < 0;\n};\n\n/**\n * Return true when the tooltip center x-coordinate + tooltip width is greater than the layout width\n * The tooltip width will grow from right to left relative to the wrapped element.\n */\nconst overflowRight = (center, tooltipWidth) => {\n const {\n width: layoutWidth\n } = Dimensions.get('window');\n return center + tooltipWidth > layoutWidth;\n};\n\n/**\n * Return true when the children y-coordinate + its height + tooltip height is greater than the layout height.\n * The tooltip will be placed at the top of the wrapped element.\n */\nconst overflowBottom = (childrenY, childrenHeight, tooltipHeight) => {\n const {\n height: layoutHeight\n } = Dimensions.get('window');\n return childrenY + childrenHeight + tooltipHeight > layoutHeight;\n};\nconst getTooltipXPosition = (_ref, _ref2) => {\n let {\n pageX: childrenX,\n width: childrenWidth\n } = _ref;\n let {\n width: tooltipWidth\n } = _ref2;\n // when the children use position absolute the childrenWidth is measured as 0,\n // so it's best to anchor the tooltip at the start of the children\n const center = childrenWidth > 0 ? childrenX + (childrenWidth - tooltipWidth) / 2 : childrenX;\n if (overflowLeft(center)) return childrenX;\n if (overflowRight(center, tooltipWidth)) return childrenX + childrenWidth - tooltipWidth;\n return center;\n};\nconst getTooltipYPosition = (_ref3, _ref4) => {\n let {\n pageY: childrenY,\n height: childrenHeight\n } = _ref3;\n let {\n height: tooltipHeight\n } = _ref4;\n if (overflowBottom(childrenY, childrenHeight, tooltipHeight)) return childrenY - tooltipHeight;\n return childrenY + childrenHeight;\n};\nconst getChildrenMeasures = (style, measures) => {\n const {\n position,\n top,\n bottom,\n left,\n right\n } = Array.isArray(style) ? style.reduce((acc, current) => ({\n ...acc,\n ...current\n })) : style;\n if (position === 'absolute') {\n let pageX = 0;\n let pageY = measures.pageY;\n let height = 0;\n let width = 0;\n if (typeof left === 'number') {\n pageX = left;\n width = 0;\n }\n if (typeof right === 'number') {\n pageX = measures.width - right;\n width = 0;\n }\n if (typeof top === 'number') {\n pageY = pageY + top;\n }\n if (typeof bottom === 'number') {\n pageY = pageY - bottom;\n }\n return {\n pageX,\n pageY,\n width,\n height\n };\n }\n return measures;\n};\nexport const getTooltipPosition = (_ref5, component) => {\n let {\n children,\n tooltip,\n measured\n } = _ref5;\n if (!measured) return {};\n let measures = children;\n if (component.props.style) {\n measures = getChildrenMeasures(component.props.style, children);\n }\n return {\n left: getTooltipXPosition(measures, tooltip),\n top: getTooltipYPosition(measures, tooltip)\n };\n};\n//# sourceMappingURL=utils.js.map","export { default as Caption } from './Caption';\nexport { default as Headline } from './Headline';\nexport { default as Paragraph } from './Paragraph';\nexport { default as Subheading } from './Subheading';\nexport { default as Title } from './Title';\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport StyledText from './StyledText';\n// @component-group Typography\n/**\n * Typography component for showing a headline.\n *\n *
\n * \n *
\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Headline } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * Headline\n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Headline = props => {\n return /*#__PURE__*/React.createElement(StyledText, _extends({}, props, {\n alpha: 0.87,\n family: \"regular\",\n style: [styles.text, props.style]\n }));\n};\nexport default Headline;\nconst styles = StyleSheet.create({\n text: {\n fontSize: 24,\n lineHeight: 32,\n marginVertical: 2,\n letterSpacing: 0\n }\n});\n//# sourceMappingURL=Headline.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport StyledText from './StyledText';\n// @component-group Typography\n/**\n * Typography component for showing a paragraph.\n *\n *
\n * \n *
\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Paragraph } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * Paragraph\n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Paragraph = props => /*#__PURE__*/React.createElement(StyledText, _extends({}, props, {\n alpha: 0.87,\n family: \"regular\",\n style: [styles.text, props.style]\n}));\nexport default Paragraph;\nconst styles = StyleSheet.create({\n text: {\n fontSize: 14,\n lineHeight: 20,\n marginVertical: 2,\n letterSpacing: 0.25\n }\n});\n//# sourceMappingURL=Paragraph.js.map","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from 'react';\nimport { StyleSheet } from 'react-native';\nimport StyledText from './StyledText';\n// @component-group Typography\n/**\n * Typography component for showing a subheading.\n *\n *
\n * \n *
\n *\n * ## Usage\n * ```js\n * import * as React from 'react';\n * import { Subheading } from 'react-native-paper';\n *\n * const MyComponent = () => (\n * Subheading\n * );\n *\n * export default MyComponent;\n * ```\n */\nconst Subheading = props => /*#__PURE__*/React.createElement(StyledText, _extends({}, props, {\n alpha: 0.87,\n family: \"regular\",\n style: [styles.text, props.style]\n}));\nexport default Subheading;\nconst styles = StyleSheet.create({\n text: {\n fontSize: 16,\n lineHeight: 24,\n marginVertical: 2,\n letterSpacing: 0.5\n }\n});\n//# sourceMappingURL=Subheading.js.map","module.exports = require('./lib/axios');","'use strict';\n\nvar utils = require('./utils');\nvar bind = require('./helpers/bind');\nvar Axios = require('./core/Axios');\nvar mergeConfig = require('./core/mergeConfig');\nvar defaults = require('./defaults');\n\n/**\n * Create an instance of Axios\n *\n * @param {Object} defaultConfig The default config for the instance\n * @return {Axios} A new instance of Axios\n */\nfunction createInstance(defaultConfig) {\n var context = new Axios(defaultConfig);\n var instance = bind(Axios.prototype.request, context);\n\n // Copy axios.prototype to instance\n utils.extend(instance, Axios.prototype, context);\n\n // Copy context to instance\n utils.extend(instance, context);\n\n return instance;\n}\n\n// Create the default instance to be exported\nvar axios = createInstance(defaults);\n\n// Expose Axios class to allow class inheritance\naxios.Axios = Axios;\n\n// Factory for creating new instances\naxios.create = function create(instanceConfig) {\n return createInstance(mergeConfig(axios.defaults, instanceConfig));\n};\n\n// Expose Cancel & CancelToken\naxios.Cancel = require('./cancel/Cancel');\naxios.CancelToken = require('./cancel/CancelToken');\naxios.isCancel = require('./cancel/isCancel');\n\n// Expose all/spread\naxios.all = function all(promises) {\n return Promise.all(promises);\n};\naxios.spread = require('./helpers/spread');\n\n// Expose isAxiosError\naxios.isAxiosError = require('./helpers/isAxiosError');\n\nmodule.exports = axios;\n\n// Allow use of default import syntax in TypeScript\nmodule.exports.default = axios;\n","'use strict';\n\nvar bind = require('./helpers/bind');\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n return (typeof FormData !== 'undefined') && (val instanceof FormData);\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n var result;\n if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n result = ArrayBuffer.isView(val);\n } else {\n result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);\n }\n return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n return val !== null && typeof val === 'object';\n}\n\n/**\n * Determine if a value is a plain Object\n *\n * @param {Object} val The value to test\n * @return {boolean} True if value is a plain Object, otherwise false\n */\nfunction isPlainObject(val) {\n if (toString.call(val) !== '[object Object]') {\n return false;\n }\n\n var prototype = Object.getPrototypeOf(val);\n return prototype === null || prototype === Object.prototype;\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n return str.trim ? str.trim() : str.replace(/^\\s+|\\s+$/g, '');\n}\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n * typeof window -> undefined\n * typeof document -> undefined\n *\n * react-native:\n * navigator.product -> 'ReactNative'\n * nativescript\n * navigator.product -> 'NativeScript' or 'NS'\n */\nfunction isStandardBrowserEnv() {\n if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' ||\n navigator.product === 'NativeScript' ||\n navigator.product === 'NS')) {\n return false;\n }\n return (\n typeof window !== 'undefined' &&\n typeof document !== 'undefined'\n );\n}\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n */\nfunction forEach(obj, fn) {\n // Don't bother if no value provided\n if (obj === null || typeof obj === 'undefined') {\n return;\n }\n\n // Force an array if not already something iterable\n if (typeof obj !== 'object') {\n /*eslint no-param-reassign:0*/\n obj = [obj];\n }\n\n if (isArray(obj)) {\n // Iterate over array values\n for (var i = 0, l = obj.length; i < l; i++) {\n fn.call(null, obj[i], i, obj);\n }\n } else {\n // Iterate over object keys\n for (var key in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, key)) {\n fn.call(null, obj[key], key, obj);\n }\n }\n }\n}\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n var result = {};\n function assignValue(val, key) {\n if (isPlainObject(result[key]) && isPlainObject(val)) {\n result[key] = merge(result[key], val);\n } else if (isPlainObject(val)) {\n result[key] = merge({}, val);\n } else if (isArray(val)) {\n result[key] = val.slice();\n } else {\n result[key] = val;\n }\n }\n\n for (var i = 0, l = arguments.length; i < l; i++) {\n forEach(arguments[i], assignValue);\n }\n return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n forEach(b, function assignValue(val, key) {\n if (thisArg && typeof val === 'function') {\n a[key] = bind(val, thisArg);\n } else {\n a[key] = val;\n }\n });\n return a;\n}\n\n/**\n * Remove byte order marker. This catches EF BB BF (the UTF-8 BOM)\n *\n * @param {string} content with BOM\n * @return {string} content value without BOM\n */\nfunction stripBOM(content) {\n if (content.charCodeAt(0) === 0xFEFF) {\n content = content.slice(1);\n }\n return content;\n}\n\nmodule.exports = {\n isArray: isArray,\n isArrayBuffer: isArrayBuffer,\n isBuffer: isBuffer,\n isFormData: isFormData,\n isArrayBufferView: isArrayBufferView,\n isString: isString,\n isNumber: isNumber,\n isObject: isObject,\n isPlainObject: isPlainObject,\n isUndefined: isUndefined,\n isDate: isDate,\n isFile: isFile,\n isBlob: isBlob,\n isFunction: isFunction,\n isStream: isStream,\n isURLSearchParams: isURLSearchParams,\n isStandardBrowserEnv: isStandardBrowserEnv,\n forEach: forEach,\n merge: merge,\n extend: extend,\n trim: trim,\n stripBOM: stripBOM\n};\n","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n return function wrap() {\n var args = new Array(arguments.length);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i];\n }\n return fn.apply(thisArg, args);\n };\n};\n","'use strict';\n\nvar utils = require('./../utils');\nvar buildURL = require('../helpers/buildURL');\nvar InterceptorManager = require('./InterceptorManager');\nvar dispatchRequest = require('./dispatchRequest');\nvar mergeConfig = require('./mergeConfig');\nvar validator = require('../helpers/validator');\n\nvar validators = validator.validators;\n/**\n * Create a new instance of Axios\n *\n * @param {Object} instanceConfig The default config for the instance\n */\nfunction Axios(instanceConfig) {\n this.defaults = instanceConfig;\n this.interceptors = {\n request: new InterceptorManager(),\n response: new InterceptorManager()\n };\n}\n\n/**\n * Dispatch a request\n *\n * @param {Object} config The config specific for this request (merged with this.defaults)\n */\nAxios.prototype.request = function request(config) {\n /*eslint no-param-reassign:0*/\n // Allow for axios('example/url'[, config]) a la fetch API\n if (typeof config === 'string') {\n config = arguments[1] || {};\n config.url = arguments[0];\n } else {\n config = config || {};\n }\n\n config = mergeConfig(this.defaults, config);\n\n // Set config.method\n if (config.method) {\n config.method = config.method.toLowerCase();\n } else if (this.defaults.method) {\n config.method = this.defaults.method.toLowerCase();\n } else {\n config.method = 'get';\n }\n\n var transitional = config.transitional;\n\n if (transitional !== undefined) {\n validator.assertOptions(transitional, {\n silentJSONParsing: validators.transitional(validators.boolean, '1.0.0'),\n forcedJSONParsing: validators.transitional(validators.boolean, '1.0.0'),\n clarifyTimeoutError: validators.transitional(validators.boolean, '1.0.0')\n }, false);\n }\n\n // filter out skipped interceptors\n var requestInterceptorChain = [];\n var synchronousRequestInterceptors = true;\n this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {\n if (typeof interceptor.runWhen === 'function' && interceptor.runWhen(config) === false) {\n return;\n }\n\n synchronousRequestInterceptors = synchronousRequestInterceptors && interceptor.synchronous;\n\n requestInterceptorChain.unshift(interceptor.fulfilled, interceptor.rejected);\n });\n\n var responseInterceptorChain = [];\n this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {\n responseInterceptorChain.push(interceptor.fulfilled, interceptor.rejected);\n });\n\n var promise;\n\n if (!synchronousRequestInterceptors) {\n var chain = [dispatchRequest, undefined];\n\n Array.prototype.unshift.apply(chain, requestInterceptorChain);\n chain = chain.concat(responseInterceptorChain);\n\n promise = Promise.resolve(config);\n while (chain.length) {\n promise = promise.then(chain.shift(), chain.shift());\n }\n\n return promise;\n }\n\n\n var newConfig = config;\n while (requestInterceptorChain.length) {\n var onFulfilled = requestInterceptorChain.shift();\n var onRejected = requestInterceptorChain.shift();\n try {\n newConfig = onFulfilled(newConfig);\n } catch (error) {\n onRejected(error);\n break;\n }\n }\n\n try {\n promise = dispatchRequest(newConfig);\n } catch (error) {\n return Promise.reject(error);\n }\n\n while (responseInterceptorChain.length) {\n promise = promise.then(responseInterceptorChain.shift(), responseInterceptorChain.shift());\n }\n\n return promise;\n};\n\nAxios.prototype.getUri = function getUri(config) {\n config = mergeConfig(this.defaults, config);\n return buildURL(config.url, config.params, config.paramsSerializer).replace(/^\\?/, '');\n};\n\n// Provide aliases for supported request methods\nutils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {\n /*eslint func-names:0*/\n Axios.prototype[method] = function(url, config) {\n return this.request(mergeConfig(config || {}, {\n method: method,\n url: url,\n data: (config || {}).data\n }));\n };\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n /*eslint func-names:0*/\n Axios.prototype[method] = function(url, data, config) {\n return this.request(mergeConfig(config || {}, {\n method: method,\n url: url,\n data: data\n }));\n };\n});\n\nmodule.exports = Axios;\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction encode(val) {\n return encodeURIComponent(val).\n replace(/%3A/gi, ':').\n replace(/%24/g, '$').\n replace(/%2C/gi, ',').\n replace(/%20/g, '+').\n replace(/%5B/gi, '[').\n replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n /*eslint no-param-reassign:0*/\n if (!params) {\n return url;\n }\n\n var serializedParams;\n if (paramsSerializer) {\n serializedParams = paramsSerializer(params);\n } else if (utils.isURLSearchParams(params)) {\n serializedParams = params.toString();\n } else {\n var parts = [];\n\n utils.forEach(params, function serialize(val, key) {\n if (val === null || typeof val === 'undefined') {\n return;\n }\n\n if (utils.isArray(val)) {\n key = key + '[]';\n } else {\n val = [val];\n }\n\n utils.forEach(val, function parseValue(v) {\n if (utils.isDate(v)) {\n v = v.toISOString();\n } else if (utils.isObject(v)) {\n v = JSON.stringify(v);\n }\n parts.push(encode(key) + '=' + encode(v));\n });\n });\n\n serializedParams = parts.join('&');\n }\n\n if (serializedParams) {\n var hashmarkIndex = url.indexOf('#');\n if (hashmarkIndex !== -1) {\n url = url.slice(0, hashmarkIndex);\n }\n\n url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n }\n\n return url;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction InterceptorManager() {\n this.handlers = [];\n}\n\n/**\n * Add a new interceptor to the stack\n *\n * @param {Function} fulfilled The function to handle `then` for a `Promise`\n * @param {Function} rejected The function to handle `reject` for a `Promise`\n *\n * @return {Number} An ID used to remove interceptor later\n */\nInterceptorManager.prototype.use = function use(fulfilled, rejected, options) {\n this.handlers.push({\n fulfilled: fulfilled,\n rejected: rejected,\n synchronous: options ? options.synchronous : false,\n runWhen: options ? options.runWhen : null\n });\n return this.handlers.length - 1;\n};\n\n/**\n * Remove an interceptor from the stack\n *\n * @param {Number} id The ID that was returned by `use`\n */\nInterceptorManager.prototype.eject = function eject(id) {\n if (this.handlers[id]) {\n this.handlers[id] = null;\n }\n};\n\n/**\n * Iterate over all the registered interceptors\n *\n * This method is particularly useful for skipping over any\n * interceptors that may have become `null` calling `eject`.\n *\n * @param {Function} fn The function to call for each interceptor\n */\nInterceptorManager.prototype.forEach = function forEach(fn) {\n utils.forEach(this.handlers, function forEachHandler(h) {\n if (h !== null) {\n fn(h);\n }\n });\n};\n\nmodule.exports = InterceptorManager;\n","'use strict';\n\nvar utils = require('./../utils');\nvar transformData = require('./transformData');\nvar isCancel = require('../cancel/isCancel');\nvar defaults = require('../defaults');\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nfunction throwIfCancellationRequested(config) {\n if (config.cancelToken) {\n config.cancelToken.throwIfRequested();\n }\n}\n\n/**\n * Dispatch a request to the server using the configured adapter.\n *\n * @param {object} config The config that is to be used for the request\n * @returns {Promise} The Promise to be fulfilled\n */\nmodule.exports = function dispatchRequest(config) {\n throwIfCancellationRequested(config);\n\n // Ensure headers exist\n config.headers = config.headers || {};\n\n // Transform request data\n config.data = transformData.call(\n config,\n config.data,\n config.headers,\n config.transformRequest\n );\n\n // Flatten headers\n config.headers = utils.merge(\n config.headers.common || {},\n config.headers[config.method] || {},\n config.headers\n );\n\n utils.forEach(\n ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],\n function cleanHeaderConfig(method) {\n delete config.headers[method];\n }\n );\n\n var adapter = config.adapter || defaults.adapter;\n\n return adapter(config).then(function onAdapterResolution(response) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n response.data = transformData.call(\n config,\n response.data,\n response.headers,\n config.transformResponse\n );\n\n return response;\n }, function onAdapterRejection(reason) {\n if (!isCancel(reason)) {\n throwIfCancellationRequested(config);\n\n // Transform response data\n if (reason && reason.response) {\n reason.response.data = transformData.call(\n config,\n reason.response.data,\n reason.response.headers,\n config.transformResponse\n );\n }\n }\n\n return Promise.reject(reason);\n });\n};\n","'use strict';\n\nvar utils = require('./../utils');\nvar defaults = require('./../defaults');\n\n/**\n * Transform the data for a request or a response\n *\n * @param {Object|String} data The data to be transformed\n * @param {Array} headers The headers for the request or response\n * @param {Array|Function} fns A single function or Array of functions\n * @returns {*} The resulting transformed data\n */\nmodule.exports = function transformData(data, headers, fns) {\n var context = this || defaults;\n /*eslint no-param-reassign:0*/\n utils.forEach(fns, function transform(fn) {\n data = fn.call(context, data, headers);\n });\n\n return data;\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\nvar enhanceError = require('./core/enhanceError');\n\nvar DEFAULT_CONTENT_TYPE = {\n 'Content-Type': 'application/x-www-form-urlencoded'\n};\n\nfunction setContentTypeIfUnset(headers, value) {\n if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n headers['Content-Type'] = value;\n }\n}\n\nfunction getDefaultAdapter() {\n var adapter;\n if (typeof XMLHttpRequest !== 'undefined') {\n // For browsers use XHR adapter\n adapter = require('./adapters/xhr');\n } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n // For node use HTTP adapter\n adapter = require('./adapters/http');\n }\n return adapter;\n}\n\nfunction stringifySafely(rawValue, parser, encoder) {\n if (utils.isString(rawValue)) {\n try {\n (parser || JSON.parse)(rawValue);\n return utils.trim(rawValue);\n } catch (e) {\n if (e.name !== 'SyntaxError') {\n throw e;\n }\n }\n }\n\n return (encoder || JSON.stringify)(rawValue);\n}\n\nvar defaults = {\n\n transitional: {\n silentJSONParsing: true,\n forcedJSONParsing: true,\n clarifyTimeoutError: false\n },\n\n adapter: getDefaultAdapter(),\n\n transformRequest: [function transformRequest(data, headers) {\n normalizeHeaderName(headers, 'Accept');\n normalizeHeaderName(headers, 'Content-Type');\n\n if (utils.isFormData(data) ||\n utils.isArrayBuffer(data) ||\n utils.isBuffer(data) ||\n utils.isStream(data) ||\n utils.isFile(data) ||\n utils.isBlob(data)\n ) {\n return data;\n }\n if (utils.isArrayBufferView(data)) {\n return data.buffer;\n }\n if (utils.isURLSearchParams(data)) {\n setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n return data.toString();\n }\n if (utils.isObject(data) || (headers && headers['Content-Type'] === 'application/json')) {\n setContentTypeIfUnset(headers, 'application/json');\n return stringifySafely(data);\n }\n return data;\n }],\n\n transformResponse: [function transformResponse(data) {\n var transitional = this.transitional;\n var silentJSONParsing = transitional && transitional.silentJSONParsing;\n var forcedJSONParsing = transitional && transitional.forcedJSONParsing;\n var strictJSONParsing = !silentJSONParsing && this.responseType === 'json';\n\n if (strictJSONParsing || (forcedJSONParsing && utils.isString(data) && data.length)) {\n try {\n return JSON.parse(data);\n } catch (e) {\n if (strictJSONParsing) {\n if (e.name === 'SyntaxError') {\n throw enhanceError(e, this, 'E_JSON_PARSE');\n }\n throw e;\n }\n }\n }\n\n return data;\n }],\n\n /**\n * A timeout in milliseconds to abort a request. If set to 0 (default) a\n * timeout is not created.\n */\n timeout: 0,\n\n xsrfCookieName: 'XSRF-TOKEN',\n xsrfHeaderName: 'X-XSRF-TOKEN',\n\n maxContentLength: -1,\n maxBodyLength: -1,\n\n validateStatus: function validateStatus(status) {\n return status >= 200 && status < 300;\n }\n};\n\ndefaults.headers = {\n common: {\n 'Accept': 'application/json, text/plain, */*'\n }\n};\n\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n defaults.headers[method] = {};\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\n\nmodule.exports = defaults;\n","'use strict';\n\nvar utils = require('../utils');\n\nmodule.exports = function normalizeHeaderName(headers, normalizedName) {\n utils.forEach(headers, function processHeader(value, name) {\n if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {\n headers[normalizedName] = value;\n delete headers[name];\n }\n });\n};\n","'use strict';\n\n/**\n * Update an Error with the specified config, error code, and response.\n *\n * @param {Error} error The error to update.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The error.\n */\nmodule.exports = function enhanceError(error, config, code, request, response) {\n error.config = config;\n if (code) {\n error.code = code;\n }\n\n error.request = request;\n error.response = response;\n error.isAxiosError = true;\n\n error.toJSON = function toJSON() {\n return {\n // Standard\n message: this.message,\n name: this.name,\n // Microsoft\n description: this.description,\n number: this.number,\n // Mozilla\n fileName: this.fileName,\n lineNumber: this.lineNumber,\n columnNumber: this.columnNumber,\n stack: this.stack,\n // Axios\n config: this.config,\n code: this.code\n };\n };\n return error;\n};\n","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar cookies = require('./../helpers/cookies');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\n\nmodule.exports = function xhrAdapter(config) {\n return new Promise(function dispatchXhrRequest(resolve, reject) {\n var requestData = config.data;\n var requestHeaders = config.headers;\n var responseType = config.responseType;\n\n if (utils.isFormData(requestData)) {\n delete requestHeaders['Content-Type']; // Let the browser set it\n }\n\n var request = new XMLHttpRequest();\n\n // HTTP basic authentication\n if (config.auth) {\n var username = config.auth.username || '';\n var password = config.auth.password ? unescape(encodeURIComponent(config.auth.password)) : '';\n requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n }\n\n var fullPath = buildFullPath(config.baseURL, config.url);\n request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n // Set the request timeout in MS\n request.timeout = config.timeout;\n\n function onloadend() {\n if (!request) {\n return;\n }\n // Prepare the response\n var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n var responseData = !responseType || responseType === 'text' || responseType === 'json' ?\n request.responseText : request.response;\n var response = {\n data: responseData,\n status: request.status,\n statusText: request.statusText,\n headers: responseHeaders,\n config: config,\n request: request\n };\n\n settle(resolve, reject, response);\n\n // Clean up request\n request = null;\n }\n\n if ('onloadend' in request) {\n // Use onloadend if available\n request.onloadend = onloadend;\n } else {\n // Listen for ready state to emulate onloadend\n request.onreadystatechange = function handleLoad() {\n if (!request || request.readyState !== 4) {\n return;\n }\n\n // The request errored out and we didn't get a response, this will be\n // handled by onerror instead\n // With one exception: request that using file: protocol, most browsers\n // will return status as 0 even though it's a successful request\n if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n return;\n }\n // readystate handler is calling before onerror or ontimeout handlers,\n // so we should call onloadend on the next 'tick'\n setTimeout(onloadend);\n };\n }\n\n // Handle browser request cancellation (as opposed to a manual cancellation)\n request.onabort = function handleAbort() {\n if (!request) {\n return;\n }\n\n reject(createError('Request aborted', config, 'ECONNABORTED', request));\n\n // Clean up request\n request = null;\n };\n\n // Handle low level network errors\n request.onerror = function handleError() {\n // Real errors are hidden from us by the browser\n // onerror should only fire if it's a network error\n reject(createError('Network Error', config, null, request));\n\n // Clean up request\n request = null;\n };\n\n // Handle timeout\n request.ontimeout = function handleTimeout() {\n var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n if (config.timeoutErrorMessage) {\n timeoutErrorMessage = config.timeoutErrorMessage;\n }\n reject(createError(\n timeoutErrorMessage,\n config,\n config.transitional && config.transitional.clarifyTimeoutError ? 'ETIMEDOUT' : 'ECONNABORTED',\n request));\n\n // Clean up request\n request = null;\n };\n\n // Add xsrf header\n // This is only done if running in a standard browser environment.\n // Specifically not if we're in a web worker, or react-native.\n if (utils.isStandardBrowserEnv()) {\n // Add xsrf header\n var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ?\n cookies.read(config.xsrfCookieName) :\n undefined;\n\n if (xsrfValue) {\n requestHeaders[config.xsrfHeaderName] = xsrfValue;\n }\n }\n\n // Add headers to the request\n if ('setRequestHeader' in request) {\n utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n // Remove Content-Type if data is undefined\n delete requestHeaders[key];\n } else {\n // Otherwise add header to the request\n request.setRequestHeader(key, val);\n }\n });\n }\n\n // Add withCredentials to request if needed\n if (!utils.isUndefined(config.withCredentials)) {\n request.withCredentials = !!config.withCredentials;\n }\n\n // Add responseType to request if needed\n if (responseType && responseType !== 'json') {\n request.responseType = config.responseType;\n }\n\n // Handle progress if needed\n if (typeof config.onDownloadProgress === 'function') {\n request.addEventListener('progress', config.onDownloadProgress);\n }\n\n // Not all browsers support upload events\n if (typeof config.onUploadProgress === 'function' && request.upload) {\n request.upload.addEventListener('progress', config.onUploadProgress);\n }\n\n if (config.cancelToken) {\n // Handle cancellation\n config.cancelToken.promise.then(function onCanceled(cancel) {\n if (!request) {\n return;\n }\n\n request.abort();\n reject(cancel);\n // Clean up request\n request = null;\n });\n }\n\n if (!requestData) {\n requestData = null;\n }\n\n // Send the request\n request.send(requestData);\n });\n};\n","'use strict';\n\nvar createError = require('./createError');\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n */\nmodule.exports = function settle(resolve, reject, response) {\n var validateStatus = response.config.validateStatus;\n if (!response.status || !validateStatus || validateStatus(response.status)) {\n resolve(response);\n } else {\n reject(createError(\n 'Request failed with status code ' + response.status,\n response.config,\n null,\n response.request,\n response\n ));\n }\n};\n","'use strict';\n\nvar enhanceError = require('./enhanceError');\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n var error = new Error(message);\n return enhanceError(error, config, code, request, response);\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs support document.cookie\n (function standardBrowserEnv() {\n return {\n write: function write(name, value, expires, path, domain, secure) {\n var cookie = [];\n cookie.push(name + '=' + encodeURIComponent(value));\n\n if (utils.isNumber(expires)) {\n cookie.push('expires=' + new Date(expires).toGMTString());\n }\n\n if (utils.isString(path)) {\n cookie.push('path=' + path);\n }\n\n if (utils.isString(domain)) {\n cookie.push('domain=' + domain);\n }\n\n if (secure === true) {\n cookie.push('secure');\n }\n\n document.cookie = cookie.join('; ');\n },\n\n read: function read(name) {\n var match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n return (match ? decodeURIComponent(match[3]) : null);\n },\n\n remove: function remove(name) {\n this.write(name, '', Date.now() - 86400000);\n }\n };\n })() :\n\n // Non standard browser env (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return {\n write: function write() {},\n read: function read() { return null; },\n remove: function remove() {}\n };\n })()\n);\n","'use strict';\n\nvar isAbsoluteURL = require('../helpers/isAbsoluteURL');\nvar combineURLs = require('../helpers/combineURLs');\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n * @returns {string} The combined full path\n */\nmodule.exports = function buildFullPath(baseURL, requestedURL) {\n if (baseURL && !isAbsoluteURL(requestedURL)) {\n return combineURLs(baseURL, requestedURL);\n }\n return requestedURL;\n};\n","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nmodule.exports = function isAbsoluteURL(url) {\n // A URL is considered absolute if it begins with \"://\" or \"//\" (protocol-relative URL).\n // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n // by any combination of letters, digits, plus, period, or hyphen.\n return /^([a-z][a-z\\d\\+\\-\\.]*:)?\\/\\//i.test(url);\n};\n","'use strict';\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n * @returns {string} The combined URL\n */\nmodule.exports = function combineURLs(baseURL, relativeURL) {\n return relativeURL\n ? baseURL.replace(/\\/+$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n : baseURL;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n// Headers whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nvar ignoreDuplicateOf = [\n 'age', 'authorization', 'content-length', 'content-type', 'etag',\n 'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n 'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n 'referer', 'retry-after', 'user-agent'\n];\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} headers Headers needing to be parsed\n * @returns {Object} Headers parsed into an object\n */\nmodule.exports = function parseHeaders(headers) {\n var parsed = {};\n var key;\n var val;\n var i;\n\n if (!headers) { return parsed; }\n\n utils.forEach(headers.split('\\n'), function parser(line) {\n i = line.indexOf(':');\n key = utils.trim(line.substr(0, i)).toLowerCase();\n val = utils.trim(line.substr(i + 1));\n\n if (key) {\n if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {\n return;\n }\n if (key === 'set-cookie') {\n parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);\n } else {\n parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n }\n }\n });\n\n return parsed;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n utils.isStandardBrowserEnv() ?\n\n // Standard browser envs have full support of the APIs needed to test\n // whether the request URL is of the same origin as current location.\n (function standardBrowserEnv() {\n var msie = /(msie|trident)/i.test(navigator.userAgent);\n var urlParsingNode = document.createElement('a');\n var originURL;\n\n /**\n * Parse a URL to discover it's components\n *\n * @param {String} url The URL to be parsed\n * @returns {Object}\n */\n function resolveURL(url) {\n var href = url;\n\n if (msie) {\n // IE needs attribute set twice to normalize properties\n urlParsingNode.setAttribute('href', href);\n href = urlParsingNode.href;\n }\n\n urlParsingNode.setAttribute('href', href);\n\n // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils\n return {\n href: urlParsingNode.href,\n protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',\n host: urlParsingNode.host,\n search: urlParsingNode.search ? urlParsingNode.search.replace(/^\\?/, '') : '',\n hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',\n hostname: urlParsingNode.hostname,\n port: urlParsingNode.port,\n pathname: (urlParsingNode.pathname.charAt(0) === '/') ?\n urlParsingNode.pathname :\n '/' + urlParsingNode.pathname\n };\n }\n\n originURL = resolveURL(window.location.href);\n\n /**\n * Determine if a URL shares the same origin as the current location\n *\n * @param {String} requestURL The URL to test\n * @returns {boolean} True if URL shares the same origin, otherwise false\n */\n return function isURLSameOrigin(requestURL) {\n var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;\n return (parsed.protocol === originURL.protocol &&\n parsed.host === originURL.host);\n };\n })() :\n\n // Non standard browser envs (web workers, react-native) lack needed support.\n (function nonStandardBrowserEnv() {\n return function isURLSameOrigin() {\n return true;\n };\n })()\n);\n","'use strict';\n\nmodule.exports = function isCancel(value) {\n return !!(value && value.__CANCEL__);\n};\n","'use strict';\n\nvar utils = require('../utils');\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n // eslint-disable-next-line no-param-reassign\n config2 = config2 || {};\n var config = {};\n\n var valueFromConfig2Keys = ['url', 'method', 'data'];\n var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy', 'params'];\n var defaultToConfig2Keys = [\n 'baseURL', 'transformRequest', 'transformResponse', 'paramsSerializer',\n 'timeout', 'timeoutMessage', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName',\n 'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress', 'decompress',\n 'maxContentLength', 'maxBodyLength', 'maxRedirects', 'transport', 'httpAgent',\n 'httpsAgent', 'cancelToken', 'socketPath', 'responseEncoding'\n ];\n var directMergeKeys = ['validateStatus'];\n\n function getMergedValue(target, source) {\n if (utils.isPlainObject(target) && utils.isPlainObject(source)) {\n return utils.merge(target, source);\n } else if (utils.isPlainObject(source)) {\n return utils.merge({}, source);\n } else if (utils.isArray(source)) {\n return source.slice();\n }\n return source;\n }\n\n function mergeDeepProperties(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(config1[prop], config2[prop]);\n } else if (!utils.isUndefined(config1[prop])) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n }\n\n utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(undefined, config2[prop]);\n }\n });\n\n utils.forEach(mergeDeepPropertiesKeys, mergeDeepProperties);\n\n utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n if (!utils.isUndefined(config2[prop])) {\n config[prop] = getMergedValue(undefined, config2[prop]);\n } else if (!utils.isUndefined(config1[prop])) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n });\n\n utils.forEach(directMergeKeys, function merge(prop) {\n if (prop in config2) {\n config[prop] = getMergedValue(config1[prop], config2[prop]);\n } else if (prop in config1) {\n config[prop] = getMergedValue(undefined, config1[prop]);\n }\n });\n\n var axiosKeys = valueFromConfig2Keys\n .concat(mergeDeepPropertiesKeys)\n .concat(defaultToConfig2Keys)\n .concat(directMergeKeys);\n\n var otherKeys = Object\n .keys(config1)\n .concat(Object.keys(config2))\n .filter(function filterAxiosKeys(key) {\n return axiosKeys.indexOf(key) === -1;\n });\n\n utils.forEach(otherKeys, mergeDeepProperties);\n\n return config;\n};\n","'use strict';\n\nvar pkg = require('./../../package.json');\n\nvar validators = {};\n\n// eslint-disable-next-line func-names\n['object', 'boolean', 'number', 'function', 'string', 'symbol'].forEach(function(type, i) {\n validators[type] = function validator(thing) {\n return typeof thing === type || 'a' + (i < 1 ? 'n ' : ' ') + type;\n };\n});\n\nvar deprecatedWarnings = {};\nvar currentVerArr = pkg.version.split('.');\n\n/**\n * Compare package versions\n * @param {string} version\n * @param {string?} thanVersion\n * @returns {boolean}\n */\nfunction isOlderVersion(version, thanVersion) {\n var pkgVersionArr = thanVersion ? thanVersion.split('.') : currentVerArr;\n var destVer = version.split('.');\n for (var i = 0; i < 3; i++) {\n if (pkgVersionArr[i] > destVer[i]) {\n return true;\n } else if (pkgVersionArr[i] < destVer[i]) {\n return false;\n }\n }\n return false;\n}\n\n/**\n * Transitional option validator\n * @param {function|boolean?} validator\n * @param {string?} version\n * @param {string} message\n * @returns {function}\n */\nvalidators.transitional = function transitional(validator, version, message) {\n var isDeprecated = version && isOlderVersion(version);\n\n function formatMessage(opt, desc) {\n return '[Axios v' + pkg.version + '] Transitional option \\'' + opt + '\\'' + desc + (message ? '. ' + message : '');\n }\n\n // eslint-disable-next-line func-names\n return function(value, opt, opts) {\n if (validator === false) {\n throw new Error(formatMessage(opt, ' has been removed in ' + version));\n }\n\n if (isDeprecated && !deprecatedWarnings[opt]) {\n deprecatedWarnings[opt] = true;\n // eslint-disable-next-line no-console\n console.warn(\n formatMessage(\n opt,\n ' has been deprecated since v' + version + ' and will be removed in the near future'\n )\n );\n }\n\n return validator ? validator(value, opt, opts) : true;\n };\n};\n\n/**\n * Assert object's properties type\n * @param {object} options\n * @param {object} schema\n * @param {boolean?} allowUnknown\n */\n\nfunction assertOptions(options, schema, allowUnknown) {\n if (typeof options !== 'object') {\n throw new TypeError('options must be an object');\n }\n var keys = Object.keys(options);\n var i = keys.length;\n while (i-- > 0) {\n var opt = keys[i];\n var validator = schema[opt];\n if (validator) {\n var value = options[opt];\n var result = value === undefined || validator(value, opt, options);\n if (result !== true) {\n throw new TypeError('option ' + opt + ' must be ' + result);\n }\n continue;\n }\n if (allowUnknown !== true) {\n throw Error('Unknown option ' + opt);\n }\n }\n}\n\nmodule.exports = {\n isOlderVersion: isOlderVersion,\n assertOptions: assertOptions,\n validators: validators\n};\n","{\n \"name\": \"axios\",\n \"version\": \"0.21.4\",\n \"description\": \"Promise based HTTP client for the browser and node.js\",\n \"main\": \"index.js\",\n \"scripts\": {\n \"test\": \"grunt test\",\n \"start\": \"node ./sandbox/server.js\",\n \"build\": \"NODE_ENV=production grunt build\",\n \"preversion\": \"npm test\",\n \"version\": \"npm run build && grunt version && git add -A dist && git add CHANGELOG.md bower.json package.json\",\n \"postversion\": \"git push && git push --tags\",\n \"examples\": \"node ./examples/server.js\",\n \"coveralls\": \"cat coverage/lcov.info | ./node_modules/coveralls/bin/coveralls.js\",\n \"fix\": \"eslint --fix lib/**/*.js\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/axios/axios.git\"\n },\n \"keywords\": [\n \"xhr\",\n \"http\",\n \"ajax\",\n \"promise\",\n \"node\"\n ],\n \"author\": \"Matt Zabriskie\",\n \"license\": \"MIT\",\n \"bugs\": {\n \"url\": \"https://github.com/axios/axios/issues\"\n },\n \"homepage\": \"https://axios-http.com\",\n \"devDependencies\": {\n \"coveralls\": \"^3.0.0\",\n \"es6-promise\": \"^4.2.4\",\n \"grunt\": \"^1.3.0\",\n \"grunt-banner\": \"^0.6.0\",\n \"grunt-cli\": \"^1.2.0\",\n \"grunt-contrib-clean\": \"^1.1.0\",\n \"grunt-contrib-watch\": \"^1.0.0\",\n \"grunt-eslint\": \"^23.0.0\",\n \"grunt-karma\": \"^4.0.0\",\n \"grunt-mocha-test\": \"^0.13.3\",\n \"grunt-ts\": \"^6.0.0-beta.19\",\n \"grunt-webpack\": \"^4.0.2\",\n \"istanbul-instrumenter-loader\": \"^1.0.0\",\n \"jasmine-core\": \"^2.4.1\",\n \"karma\": \"^6.3.2\",\n \"karma-chrome-launcher\": \"^3.1.0\",\n \"karma-firefox-launcher\": \"^2.1.0\",\n \"karma-jasmine\": \"^1.1.1\",\n \"karma-jasmine-ajax\": \"^0.1.13\",\n \"karma-safari-launcher\": \"^1.0.0\",\n \"karma-sauce-launcher\": \"^4.3.6\",\n \"karma-sinon\": \"^1.0.5\",\n \"karma-sourcemap-loader\": \"^0.3.8\",\n \"karma-webpack\": \"^4.0.2\",\n \"load-grunt-tasks\": \"^3.5.2\",\n \"minimist\": \"^1.2.0\",\n \"mocha\": \"^8.2.1\",\n \"sinon\": \"^4.5.0\",\n \"terser-webpack-plugin\": \"^4.2.3\",\n \"typescript\": \"^4.0.5\",\n \"url-search-params\": \"^0.10.0\",\n \"webpack\": \"^4.44.2\",\n \"webpack-dev-server\": \"^3.11.0\"\n },\n \"browser\": {\n \"./lib/adapters/http.js\": \"./lib/adapters/xhr.js\"\n },\n \"jsdelivr\": \"dist/axios.min.js\",\n \"unpkg\": \"dist/axios.min.js\",\n \"typings\": \"./index.d.ts\",\n \"dependencies\": {\n \"follow-redirects\": \"^1.14.0\"\n },\n \"bundlesize\": [\n {\n \"path\": \"./dist/axios.min.js\",\n \"threshold\": \"5kB\"\n }\n ]\n}\n","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n this.message = message;\n}\n\nCancel.prototype.toString = function toString() {\n return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\n\nCancel.prototype.__CANCEL__ = true;\n\nmodule.exports = Cancel;\n","'use strict';\n\nvar Cancel = require('./Cancel');\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @class\n * @param {Function} executor The executor function.\n */\nfunction CancelToken(executor) {\n if (typeof executor !== 'function') {\n throw new TypeError('executor must be a function.');\n }\n\n var resolvePromise;\n this.promise = new Promise(function promiseExecutor(resolve) {\n resolvePromise = resolve;\n });\n\n var token = this;\n executor(function cancel(message) {\n if (token.reason) {\n // Cancellation has already been requested\n return;\n }\n\n token.reason = new Cancel(message);\n resolvePromise(token.reason);\n });\n}\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nCancelToken.prototype.throwIfRequested = function throwIfRequested() {\n if (this.reason) {\n throw this.reason;\n }\n};\n\n/**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\nCancelToken.source = function source() {\n var cancel;\n var token = new CancelToken(function executor(c) {\n cancel = c;\n });\n return {\n token: token,\n cancel: cancel\n };\n};\n\nmodule.exports = CancelToken;\n","'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n * ```js\n * function f(x, y, z) {}\n * var args = [1, 2, 3];\n * f.apply(null, args);\n * ```\n *\n * With `spread` this example can be re-written.\n *\n * ```js\n * spread(function(x, y, z) {})([1, 2, 3]);\n * ```\n *\n * @param {Function} callback\n * @returns {Function}\n */\nmodule.exports = function spread(callback) {\n return function wrap(arr) {\n return callback.apply(null, arr);\n };\n};\n","'use strict';\n\n/**\n * Determines whether the payload is an error thrown by Axios\n *\n * @param {*} payload The value to test\n * @returns {boolean} True if the payload is an error thrown by Axios, otherwise false\n */\nmodule.exports = function isAxiosError(payload) {\n return (typeof payload === 'object') && (payload.isAxiosError === true);\n};\n","export * from './exports';\nimport { unstable_batchedUpdates as batch } from './utils/reactBatchedUpdates';\nimport { setBatch } from './utils/batch'; // Enable batched updates in our subscriptions for use\n// with standard React renderers (ReactDOM, React Native)\n\nsetBatch(batch);\nexport { batch };","import Provider from './components/Provider';\nimport connectAdvanced from './components/connectAdvanced';\nimport { ReactReduxContext } from './components/Context';\nimport connect from './connect/connect';\nimport { useDispatch, createDispatchHook } from './hooks/useDispatch';\nimport { useSelector, createSelectorHook } from './hooks/useSelector';\nimport { useStore, createStoreHook } from './hooks/useStore';\nimport shallowEqual from './utils/shallowEqual';\nexport { Provider, connectAdvanced, ReactReduxContext, connect, useDispatch, createDispatchHook, useSelector, createSelectorHook, useStore, createStoreHook, shallowEqual };","import React, { useMemo } from 'react';\nimport PropTypes from 'prop-types';\nimport { ReactReduxContext } from './Context';\nimport { createSubscription } from '../utils/Subscription';\nimport { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect';\n\nfunction Provider(_ref) {\n var store = _ref.store,\n context = _ref.context,\n children = _ref.children;\n var contextValue = useMemo(function () {\n var subscription = createSubscription(store);\n return {\n store: store,\n subscription: subscription\n };\n }, [store]);\n var previousState = useMemo(function () {\n return store.getState();\n }, [store]);\n useIsomorphicLayoutEffect(function () {\n var subscription = contextValue.subscription;\n subscription.onStateChange = subscription.notifyNestedSubs;\n subscription.trySubscribe();\n\n if (previousState !== store.getState()) {\n subscription.notifyNestedSubs();\n }\n\n return function () {\n subscription.tryUnsubscribe();\n subscription.onStateChange = null;\n };\n }, [contextValue, previousState]);\n var Context = context || ReactReduxContext;\n return /*#__PURE__*/React.createElement(Context.Provider, {\n value: contextValue\n }, children);\n}\n\nif (process.env.NODE_ENV !== 'production') {\n Provider.propTypes = {\n store: PropTypes.shape({\n subscribe: PropTypes.func.isRequired,\n dispatch: PropTypes.func.isRequired,\n getState: PropTypes.func.isRequired\n }),\n context: PropTypes.object,\n children: PropTypes.any\n };\n}\n\nexport default Provider;","import React from 'react';\nexport var ReactReduxContext = /*#__PURE__*/React.createContext(null);\n\nif (process.env.NODE_ENV !== 'production') {\n ReactReduxContext.displayName = 'ReactRedux';\n}\n\nexport default ReactReduxContext;","import { getBatch } from './batch'; // encapsulates the subscription logic for connecting a component to the redux store, as\n// well as nesting subscriptions of descendant components, so that we can ensure the\n// ancestor components re-render before descendants\n\nfunction createListenerCollection() {\n var batch = getBatch();\n var first = null;\n var last = null;\n return {\n clear: function clear() {\n first = null;\n last = null;\n },\n notify: function notify() {\n batch(function () {\n var listener = first;\n\n while (listener) {\n listener.callback();\n listener = listener.next;\n }\n });\n },\n get: function get() {\n var listeners = [];\n var listener = first;\n\n while (listener) {\n listeners.push(listener);\n listener = listener.next;\n }\n\n return listeners;\n },\n subscribe: function subscribe(callback) {\n var isSubscribed = true;\n var listener = last = {\n callback: callback,\n next: null,\n prev: last\n };\n\n if (listener.prev) {\n listener.prev.next = listener;\n } else {\n first = listener;\n }\n\n return function unsubscribe() {\n if (!isSubscribed || first === null) return;\n isSubscribed = false;\n\n if (listener.next) {\n listener.next.prev = listener.prev;\n } else {\n last = listener.prev;\n }\n\n if (listener.prev) {\n listener.prev.next = listener.next;\n } else {\n first = listener.next;\n }\n };\n }\n };\n}\n\nvar nullListeners = {\n notify: function notify() {},\n get: function get() {\n return [];\n }\n};\nexport function createSubscription(store, parentSub) {\n var unsubscribe;\n var listeners = nullListeners;\n\n function addNestedSub(listener) {\n trySubscribe();\n return listeners.subscribe(listener);\n }\n\n function notifyNestedSubs() {\n listeners.notify();\n }\n\n function handleChangeWrapper() {\n if (subscription.onStateChange) {\n subscription.onStateChange();\n }\n }\n\n function isSubscribed() {\n return Boolean(unsubscribe);\n }\n\n function trySubscribe() {\n if (!unsubscribe) {\n unsubscribe = parentSub ? parentSub.addNestedSub(handleChangeWrapper) : store.subscribe(handleChangeWrapper);\n listeners = createListenerCollection();\n }\n }\n\n function tryUnsubscribe() {\n if (unsubscribe) {\n unsubscribe();\n unsubscribe = undefined;\n listeners.clear();\n listeners = nullListeners;\n }\n }\n\n var subscription = {\n addNestedSub: addNestedSub,\n notifyNestedSubs: notifyNestedSubs,\n handleChangeWrapper: handleChangeWrapper,\n isSubscribed: isSubscribed,\n trySubscribe: trySubscribe,\n tryUnsubscribe: tryUnsubscribe,\n getListeners: function getListeners() {\n return listeners;\n }\n };\n return subscription;\n}","// Default to a dummy \"batch\" implementation that just runs the callback\nfunction defaultNoopBatch(callback) {\n callback();\n}\n\nvar batch = defaultNoopBatch; // Allow injecting another batching function later\n\nexport var setBatch = function setBatch(newBatch) {\n return batch = newBatch;\n}; // Supply a getter just to skip dealing with ESM bindings\n\nexport var getBatch = function getBatch() {\n return batch;\n};","import { useEffect, useLayoutEffect } from 'react'; // React currently throws a warning when using useLayoutEffect on the server.\n// To get around it, we can conditionally useEffect on the server (no-op) and\n// useLayoutEffect in the browser. We need useLayoutEffect to ensure the store\n// subscription callback always has the selector from the latest render commit\n// available, otherwise a store update may happen between render and the effect,\n// which may cause missed updates; we also must ensure the store subscription\n// is created synchronously, otherwise a store update may occur before the\n// subscription is created and an inconsistent state may be observed\n\nexport var useIsomorphicLayoutEffect = typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined' ? useLayoutEffect : useEffect;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"getDisplayName\", \"methodName\", \"renderCountProp\", \"shouldHandleStateChanges\", \"storeKey\", \"withRef\", \"forwardRef\", \"context\"],\n _excluded2 = [\"reactReduxForwardedRef\"];\nimport hoistStatics from 'hoist-non-react-statics';\nimport React, { useContext, useMemo, useRef, useReducer } from 'react';\nimport { isValidElementType, isContextConsumer } from 'react-is';\nimport { createSubscription } from '../utils/Subscription';\nimport { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect';\nimport { ReactReduxContext } from './Context'; // Define some constant arrays just to avoid re-creating these\n\nvar EMPTY_ARRAY = [];\nvar NO_SUBSCRIPTION_ARRAY = [null, null];\n\nvar stringifyComponent = function stringifyComponent(Comp) {\n try {\n return JSON.stringify(Comp);\n } catch (err) {\n return String(Comp);\n }\n};\n\nfunction storeStateUpdatesReducer(state, action) {\n var updateCount = state[1];\n return [action.payload, updateCount + 1];\n}\n\nfunction useIsomorphicLayoutEffectWithArgs(effectFunc, effectArgs, dependencies) {\n useIsomorphicLayoutEffect(function () {\n return effectFunc.apply(void 0, effectArgs);\n }, dependencies);\n}\n\nfunction captureWrapperProps(lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, actualChildProps, childPropsFromStoreUpdate, notifyNestedSubs) {\n // We want to capture the wrapper props and child props we used for later comparisons\n lastWrapperProps.current = wrapperProps;\n lastChildProps.current = actualChildProps;\n renderIsScheduled.current = false; // If the render was from a store update, clear out that reference and cascade the subscriber update\n\n if (childPropsFromStoreUpdate.current) {\n childPropsFromStoreUpdate.current = null;\n notifyNestedSubs();\n }\n}\n\nfunction subscribeUpdates(shouldHandleStateChanges, store, subscription, childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, childPropsFromStoreUpdate, notifyNestedSubs, forceComponentUpdateDispatch) {\n // If we're not subscribed to the store, nothing to do here\n if (!shouldHandleStateChanges) return; // Capture values for checking if and when this component unmounts\n\n var didUnsubscribe = false;\n var lastThrownError = null; // We'll run this callback every time a store subscription update propagates to this component\n\n var checkForUpdates = function checkForUpdates() {\n if (didUnsubscribe) {\n // Don't run stale listeners.\n // Redux doesn't guarantee unsubscriptions happen until next dispatch.\n return;\n }\n\n var latestStoreState = store.getState();\n var newChildProps, error;\n\n try {\n // Actually run the selector with the most recent store state and wrapper props\n // to determine what the child props should be\n newChildProps = childPropsSelector(latestStoreState, lastWrapperProps.current);\n } catch (e) {\n error = e;\n lastThrownError = e;\n }\n\n if (!error) {\n lastThrownError = null;\n } // If the child props haven't changed, nothing to do here - cascade the subscription update\n\n\n if (newChildProps === lastChildProps.current) {\n if (!renderIsScheduled.current) {\n notifyNestedSubs();\n }\n } else {\n // Save references to the new child props. Note that we track the \"child props from store update\"\n // as a ref instead of a useState/useReducer because we need a way to determine if that value has\n // been processed. If this went into useState/useReducer, we couldn't clear out the value without\n // forcing another re-render, which we don't want.\n lastChildProps.current = newChildProps;\n childPropsFromStoreUpdate.current = newChildProps;\n renderIsScheduled.current = true; // If the child props _did_ change (or we caught an error), this wrapper component needs to re-render\n\n forceComponentUpdateDispatch({\n type: 'STORE_UPDATED',\n payload: {\n error: error\n }\n });\n }\n }; // Actually subscribe to the nearest connected ancestor (or store)\n\n\n subscription.onStateChange = checkForUpdates;\n subscription.trySubscribe(); // Pull data from the store after first render in case the store has\n // changed since we began.\n\n checkForUpdates();\n\n var unsubscribeWrapper = function unsubscribeWrapper() {\n didUnsubscribe = true;\n subscription.tryUnsubscribe();\n subscription.onStateChange = null;\n\n if (lastThrownError) {\n // It's possible that we caught an error due to a bad mapState function, but the\n // parent re-rendered without this component and we're about to unmount.\n // This shouldn't happen as long as we do top-down subscriptions correctly, but\n // if we ever do those wrong, this throw will surface the error in our tests.\n // In that case, throw the error from here so it doesn't get lost.\n throw lastThrownError;\n }\n };\n\n return unsubscribeWrapper;\n}\n\nvar initStateUpdates = function initStateUpdates() {\n return [null, 0];\n};\n\nexport default function connectAdvanced(\n/*\r\n selectorFactory is a func that is responsible for returning the selector function used to\r\n compute new props from state, props, and dispatch. For example:\r\n export default connectAdvanced((dispatch, options) => (state, props) => ({\r\n thing: state.things[props.thingId],\r\n saveThing: fields => dispatch(actionCreators.saveThing(props.thingId, fields)),\r\n }))(YourComponent)\r\n Access to dispatch is provided to the factory so selectorFactories can bind actionCreators\r\n outside of their selector as an optimization. Options passed to connectAdvanced are passed to\r\n the selectorFactory, along with displayName and WrappedComponent, as the second argument.\r\n Note that selectorFactory is responsible for all caching/memoization of inbound and outbound\r\n props. Do not use connectAdvanced directly without memoizing results between calls to your\r\n selector, otherwise the Connect component will re-render on every state or props change.\r\n*/\nselectorFactory, // options object:\n_ref) {\n if (_ref === void 0) {\n _ref = {};\n }\n\n var _ref2 = _ref,\n _ref2$getDisplayName = _ref2.getDisplayName,\n getDisplayName = _ref2$getDisplayName === void 0 ? function (name) {\n return \"ConnectAdvanced(\" + name + \")\";\n } : _ref2$getDisplayName,\n _ref2$methodName = _ref2.methodName,\n methodName = _ref2$methodName === void 0 ? 'connectAdvanced' : _ref2$methodName,\n _ref2$renderCountProp = _ref2.renderCountProp,\n renderCountProp = _ref2$renderCountProp === void 0 ? undefined : _ref2$renderCountProp,\n _ref2$shouldHandleSta = _ref2.shouldHandleStateChanges,\n shouldHandleStateChanges = _ref2$shouldHandleSta === void 0 ? true : _ref2$shouldHandleSta,\n _ref2$storeKey = _ref2.storeKey,\n storeKey = _ref2$storeKey === void 0 ? 'store' : _ref2$storeKey,\n _ref2$withRef = _ref2.withRef,\n withRef = _ref2$withRef === void 0 ? false : _ref2$withRef,\n _ref2$forwardRef = _ref2.forwardRef,\n forwardRef = _ref2$forwardRef === void 0 ? false : _ref2$forwardRef,\n _ref2$context = _ref2.context,\n context = _ref2$context === void 0 ? ReactReduxContext : _ref2$context,\n connectOptions = _objectWithoutPropertiesLoose(_ref2, _excluded);\n\n if (process.env.NODE_ENV !== 'production') {\n if (renderCountProp !== undefined) {\n throw new Error(\"renderCountProp is removed. render counting is built into the latest React Dev Tools profiling extension\");\n }\n\n if (withRef) {\n throw new Error('withRef is removed. To access the wrapped instance, use a ref on the connected component');\n }\n\n var customStoreWarningMessage = 'To use a custom Redux store for specific components, create a custom React context with ' + \"React.createContext(), and pass the context object to React Redux's Provider and specific components\" + ' like: . ' + 'You may also pass a {context : MyContext} option to connect';\n\n if (storeKey !== 'store') {\n throw new Error('storeKey has been removed and does not do anything. ' + customStoreWarningMessage);\n }\n }\n\n var Context = context;\n return function wrapWithConnect(WrappedComponent) {\n if (process.env.NODE_ENV !== 'production' && !isValidElementType(WrappedComponent)) {\n throw new Error(\"You must pass a component to the function returned by \" + (methodName + \". Instead received \" + stringifyComponent(WrappedComponent)));\n }\n\n var wrappedComponentName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\n var displayName = getDisplayName(wrappedComponentName);\n\n var selectorFactoryOptions = _extends({}, connectOptions, {\n getDisplayName: getDisplayName,\n methodName: methodName,\n renderCountProp: renderCountProp,\n shouldHandleStateChanges: shouldHandleStateChanges,\n storeKey: storeKey,\n displayName: displayName,\n wrappedComponentName: wrappedComponentName,\n WrappedComponent: WrappedComponent\n });\n\n var pure = connectOptions.pure;\n\n function createChildSelector(store) {\n return selectorFactory(store.dispatch, selectorFactoryOptions);\n } // If we aren't running in \"pure\" mode, we don't want to memoize values.\n // To avoid conditionally calling hooks, we fall back to a tiny wrapper\n // that just executes the given callback immediately.\n\n\n var usePureOnlyMemo = pure ? useMemo : function (callback) {\n return callback();\n };\n\n function ConnectFunction(props) {\n var _useMemo = useMemo(function () {\n // Distinguish between actual \"data\" props that were passed to the wrapper component,\n // and values needed to control behavior (forwarded refs, alternate context instances).\n // To maintain the wrapperProps object reference, memoize this destructuring.\n var reactReduxForwardedRef = props.reactReduxForwardedRef,\n wrapperProps = _objectWithoutPropertiesLoose(props, _excluded2);\n\n return [props.context, reactReduxForwardedRef, wrapperProps];\n }, [props]),\n propsContext = _useMemo[0],\n reactReduxForwardedRef = _useMemo[1],\n wrapperProps = _useMemo[2];\n\n var ContextToUse = useMemo(function () {\n // Users may optionally pass in a custom context instance to use instead of our ReactReduxContext.\n // Memoize the check that determines which context instance we should use.\n return propsContext && propsContext.Consumer && isContextConsumer( /*#__PURE__*/React.createElement(propsContext.Consumer, null)) ? propsContext : Context;\n }, [propsContext, Context]); // Retrieve the store and ancestor subscription via context, if available\n\n var contextValue = useContext(ContextToUse); // The store _must_ exist as either a prop or in context.\n // We'll check to see if it _looks_ like a Redux store first.\n // This allows us to pass through a `store` prop that is just a plain value.\n\n var didStoreComeFromProps = Boolean(props.store) && Boolean(props.store.getState) && Boolean(props.store.dispatch);\n var didStoreComeFromContext = Boolean(contextValue) && Boolean(contextValue.store);\n\n if (process.env.NODE_ENV !== 'production' && !didStoreComeFromProps && !didStoreComeFromContext) {\n throw new Error(\"Could not find \\\"store\\\" in the context of \" + (\"\\\"\" + displayName + \"\\\". Either wrap the root component in a , \") + \"or pass a custom React context provider to and the corresponding \" + (\"React context consumer to \" + displayName + \" in connect options.\"));\n } // Based on the previous check, one of these must be true\n\n\n var store = didStoreComeFromProps ? props.store : contextValue.store;\n var childPropsSelector = useMemo(function () {\n // The child props selector needs the store reference as an input.\n // Re-create this selector whenever the store changes.\n return createChildSelector(store);\n }, [store]);\n\n var _useMemo2 = useMemo(function () {\n if (!shouldHandleStateChanges) return NO_SUBSCRIPTION_ARRAY; // This Subscription's source should match where store came from: props vs. context. A component\n // connected to the store via props shouldn't use subscription from context, or vice versa.\n\n // This Subscription's source should match where store came from: props vs. context. A component\n // connected to the store via props shouldn't use subscription from context, or vice versa.\n var subscription = createSubscription(store, didStoreComeFromProps ? null : contextValue.subscription); // `notifyNestedSubs` is duplicated to handle the case where the component is unmounted in\n // the middle of the notification loop, where `subscription` will then be null. This can\n // probably be avoided if Subscription's listeners logic is changed to not call listeners\n // that have been unsubscribed in the middle of the notification loop.\n\n // `notifyNestedSubs` is duplicated to handle the case where the component is unmounted in\n // the middle of the notification loop, where `subscription` will then be null. This can\n // probably be avoided if Subscription's listeners logic is changed to not call listeners\n // that have been unsubscribed in the middle of the notification loop.\n var notifyNestedSubs = subscription.notifyNestedSubs.bind(subscription);\n return [subscription, notifyNestedSubs];\n }, [store, didStoreComeFromProps, contextValue]),\n subscription = _useMemo2[0],\n notifyNestedSubs = _useMemo2[1]; // Determine what {store, subscription} value should be put into nested context, if necessary,\n // and memoize that value to avoid unnecessary context updates.\n\n\n var overriddenContextValue = useMemo(function () {\n if (didStoreComeFromProps) {\n // This component is directly subscribed to a store from props.\n // We don't want descendants reading from this store - pass down whatever\n // the existing context value is from the nearest connected ancestor.\n return contextValue;\n } // Otherwise, put this component's subscription instance into context, so that\n // connected descendants won't update until after this component is done\n\n\n return _extends({}, contextValue, {\n subscription: subscription\n });\n }, [didStoreComeFromProps, contextValue, subscription]); // We need to force this wrapper component to re-render whenever a Redux store update\n // causes a change to the calculated child component props (or we caught an error in mapState)\n\n var _useReducer = useReducer(storeStateUpdatesReducer, EMPTY_ARRAY, initStateUpdates),\n _useReducer$ = _useReducer[0],\n previousStateUpdateResult = _useReducer$[0],\n forceComponentUpdateDispatch = _useReducer[1]; // Propagate any mapState/mapDispatch errors upwards\n\n\n if (previousStateUpdateResult && previousStateUpdateResult.error) {\n throw previousStateUpdateResult.error;\n } // Set up refs to coordinate values between the subscription effect and the render logic\n\n\n var lastChildProps = useRef();\n var lastWrapperProps = useRef(wrapperProps);\n var childPropsFromStoreUpdate = useRef();\n var renderIsScheduled = useRef(false);\n var actualChildProps = usePureOnlyMemo(function () {\n // Tricky logic here:\n // - This render may have been triggered by a Redux store update that produced new child props\n // - However, we may have gotten new wrapper props after that\n // If we have new child props, and the same wrapper props, we know we should use the new child props as-is.\n // But, if we have new wrapper props, those might change the child props, so we have to recalculate things.\n // So, we'll use the child props from store update only if the wrapper props are the same as last time.\n if (childPropsFromStoreUpdate.current && wrapperProps === lastWrapperProps.current) {\n return childPropsFromStoreUpdate.current;\n } // TODO We're reading the store directly in render() here. Bad idea?\n // This will likely cause Bad Things (TM) to happen in Concurrent Mode.\n // Note that we do this because on renders _not_ caused by store updates, we need the latest store state\n // to determine what the child props should be.\n\n\n return childPropsSelector(store.getState(), wrapperProps);\n }, [store, previousStateUpdateResult, wrapperProps]); // We need this to execute synchronously every time we re-render. However, React warns\n // about useLayoutEffect in SSR, so we try to detect environment and fall back to\n // just useEffect instead to avoid the warning, since neither will run anyway.\n\n useIsomorphicLayoutEffectWithArgs(captureWrapperProps, [lastWrapperProps, lastChildProps, renderIsScheduled, wrapperProps, actualChildProps, childPropsFromStoreUpdate, notifyNestedSubs]); // Our re-subscribe logic only runs when the store/subscription setup changes\n\n useIsomorphicLayoutEffectWithArgs(subscribeUpdates, [shouldHandleStateChanges, store, subscription, childPropsSelector, lastWrapperProps, lastChildProps, renderIsScheduled, childPropsFromStoreUpdate, notifyNestedSubs, forceComponentUpdateDispatch], [store, subscription, childPropsSelector]); // Now that all that's done, we can finally try to actually render the child component.\n // We memoize the elements for the rendered child component as an optimization.\n\n var renderedWrappedComponent = useMemo(function () {\n return /*#__PURE__*/React.createElement(WrappedComponent, _extends({}, actualChildProps, {\n ref: reactReduxForwardedRef\n }));\n }, [reactReduxForwardedRef, WrappedComponent, actualChildProps]); // If React sees the exact same element reference as last time, it bails out of re-rendering\n // that child, same as if it was wrapped in React.memo() or returned false from shouldComponentUpdate.\n\n var renderedChild = useMemo(function () {\n if (shouldHandleStateChanges) {\n // If this component is subscribed to store updates, we need to pass its own\n // subscription instance down to our descendants. That means rendering the same\n // Context instance, and putting a different value into the context.\n return /*#__PURE__*/React.createElement(ContextToUse.Provider, {\n value: overriddenContextValue\n }, renderedWrappedComponent);\n }\n\n return renderedWrappedComponent;\n }, [ContextToUse, renderedWrappedComponent, overriddenContextValue]);\n return renderedChild;\n } // If we're in \"pure\" mode, ensure our wrapper component only re-renders when incoming props have changed.\n\n\n var Connect = pure ? React.memo(ConnectFunction) : ConnectFunction;\n Connect.WrappedComponent = WrappedComponent;\n Connect.displayName = ConnectFunction.displayName = displayName;\n\n if (forwardRef) {\n var forwarded = React.forwardRef(function forwardConnectRef(props, ref) {\n return /*#__PURE__*/React.createElement(Connect, _extends({}, props, {\n reactReduxForwardedRef: ref\n }));\n });\n forwarded.displayName = displayName;\n forwarded.WrappedComponent = WrappedComponent;\n return hoistStatics(forwarded, WrappedComponent);\n }\n\n return hoistStatics(Connect, WrappedComponent);\n };\n}","export default function _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","/** @license React v17.0.2\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var b=60103,c=60106,d=60107,e=60108,f=60114,g=60109,h=60110,k=60112,l=60113,m=60120,n=60115,p=60116,q=60121,r=60122,u=60117,v=60129,w=60131;\nif(\"function\"===typeof Symbol&&Symbol.for){var x=Symbol.for;b=x(\"react.element\");c=x(\"react.portal\");d=x(\"react.fragment\");e=x(\"react.strict_mode\");f=x(\"react.profiler\");g=x(\"react.provider\");h=x(\"react.context\");k=x(\"react.forward_ref\");l=x(\"react.suspense\");m=x(\"react.suspense_list\");n=x(\"react.memo\");p=x(\"react.lazy\");q=x(\"react.block\");r=x(\"react.server.block\");u=x(\"react.fundamental\");v=x(\"react.debug_trace_mode\");w=x(\"react.legacy_hidden\")}\nfunction y(a){if(\"object\"===typeof a&&null!==a){var t=a.$$typeof;switch(t){case b:switch(a=a.type,a){case d:case f:case e:case l:case m:return a;default:switch(a=a&&a.$$typeof,a){case h:case k:case p:case n:case g:return a;default:return t}}case c:return t}}}var z=g,A=b,B=k,C=d,D=p,E=n,F=c,G=f,H=e,I=l;exports.ContextConsumer=h;exports.ContextProvider=z;exports.Element=A;exports.ForwardRef=B;exports.Fragment=C;exports.Lazy=D;exports.Memo=E;exports.Portal=F;exports.Profiler=G;exports.StrictMode=H;\nexports.Suspense=I;exports.isAsyncMode=function(){return!1};exports.isConcurrentMode=function(){return!1};exports.isContextConsumer=function(a){return y(a)===h};exports.isContextProvider=function(a){return y(a)===g};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===b};exports.isForwardRef=function(a){return y(a)===k};exports.isFragment=function(a){return y(a)===d};exports.isLazy=function(a){return y(a)===p};exports.isMemo=function(a){return y(a)===n};\nexports.isPortal=function(a){return y(a)===c};exports.isProfiler=function(a){return y(a)===f};exports.isStrictMode=function(a){return y(a)===e};exports.isSuspense=function(a){return y(a)===l};exports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===d||a===f||a===v||a===e||a===l||a===m||a===w||\"object\"===typeof a&&null!==a&&(a.$$typeof===p||a.$$typeof===n||a.$$typeof===g||a.$$typeof===h||a.$$typeof===k||a.$$typeof===u||a.$$typeof===q||a[0]===r)?!0:!1};\nexports.typeOf=y;\n","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"pure\", \"areStatesEqual\", \"areOwnPropsEqual\", \"areStatePropsEqual\", \"areMergedPropsEqual\"];\nimport connectAdvanced from '../components/connectAdvanced';\nimport shallowEqual from '../utils/shallowEqual';\nimport defaultMapDispatchToPropsFactories from './mapDispatchToProps';\nimport defaultMapStateToPropsFactories from './mapStateToProps';\nimport defaultMergePropsFactories from './mergeProps';\nimport defaultSelectorFactory from './selectorFactory';\n/*\r\n connect is a facade over connectAdvanced. It turns its args into a compatible\r\n selectorFactory, which has the signature:\r\n\r\n (dispatch, options) => (nextState, nextOwnProps) => nextFinalProps\r\n \r\n connect passes its args to connectAdvanced as options, which will in turn pass them to\r\n selectorFactory each time a Connect component instance is instantiated or hot reloaded.\r\n\r\n selectorFactory returns a final props selector from its mapStateToProps,\r\n mapStateToPropsFactories, mapDispatchToProps, mapDispatchToPropsFactories, mergeProps,\r\n mergePropsFactories, and pure args.\r\n\r\n The resulting final props selector is called by the Connect component instance whenever\r\n it receives new props or store state.\r\n */\n\nfunction match(arg, factories, name) {\n for (var i = factories.length - 1; i >= 0; i--) {\n var result = factories[i](arg);\n if (result) return result;\n }\n\n return function (dispatch, options) {\n throw new Error(\"Invalid value of type \" + typeof arg + \" for \" + name + \" argument when connecting component \" + options.wrappedComponentName + \".\");\n };\n}\n\nfunction strictEqual(a, b) {\n return a === b;\n} // createConnect with default args builds the 'official' connect behavior. Calling it with\n// different options opens up some testing and extensibility scenarios\n\n\nexport function createConnect(_temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n _ref$connectHOC = _ref.connectHOC,\n connectHOC = _ref$connectHOC === void 0 ? connectAdvanced : _ref$connectHOC,\n _ref$mapStateToPropsF = _ref.mapStateToPropsFactories,\n mapStateToPropsFactories = _ref$mapStateToPropsF === void 0 ? defaultMapStateToPropsFactories : _ref$mapStateToPropsF,\n _ref$mapDispatchToPro = _ref.mapDispatchToPropsFactories,\n mapDispatchToPropsFactories = _ref$mapDispatchToPro === void 0 ? defaultMapDispatchToPropsFactories : _ref$mapDispatchToPro,\n _ref$mergePropsFactor = _ref.mergePropsFactories,\n mergePropsFactories = _ref$mergePropsFactor === void 0 ? defaultMergePropsFactories : _ref$mergePropsFactor,\n _ref$selectorFactory = _ref.selectorFactory,\n selectorFactory = _ref$selectorFactory === void 0 ? defaultSelectorFactory : _ref$selectorFactory;\n\n return function connect(mapStateToProps, mapDispatchToProps, mergeProps, _ref2) {\n if (_ref2 === void 0) {\n _ref2 = {};\n }\n\n var _ref3 = _ref2,\n _ref3$pure = _ref3.pure,\n pure = _ref3$pure === void 0 ? true : _ref3$pure,\n _ref3$areStatesEqual = _ref3.areStatesEqual,\n areStatesEqual = _ref3$areStatesEqual === void 0 ? strictEqual : _ref3$areStatesEqual,\n _ref3$areOwnPropsEqua = _ref3.areOwnPropsEqual,\n areOwnPropsEqual = _ref3$areOwnPropsEqua === void 0 ? shallowEqual : _ref3$areOwnPropsEqua,\n _ref3$areStatePropsEq = _ref3.areStatePropsEqual,\n areStatePropsEqual = _ref3$areStatePropsEq === void 0 ? shallowEqual : _ref3$areStatePropsEq,\n _ref3$areMergedPropsE = _ref3.areMergedPropsEqual,\n areMergedPropsEqual = _ref3$areMergedPropsE === void 0 ? shallowEqual : _ref3$areMergedPropsE,\n extraOptions = _objectWithoutPropertiesLoose(_ref3, _excluded);\n\n var initMapStateToProps = match(mapStateToProps, mapStateToPropsFactories, 'mapStateToProps');\n var initMapDispatchToProps = match(mapDispatchToProps, mapDispatchToPropsFactories, 'mapDispatchToProps');\n var initMergeProps = match(mergeProps, mergePropsFactories, 'mergeProps');\n return connectHOC(selectorFactory, _extends({\n // used in error messages\n methodName: 'connect',\n // used to compute Connect's displayName from the wrapped component's displayName.\n getDisplayName: function getDisplayName(name) {\n return \"Connect(\" + name + \")\";\n },\n // if mapStateToProps is falsy, the Connect component doesn't subscribe to store state changes\n shouldHandleStateChanges: Boolean(mapStateToProps),\n // passed through to selectorFactory\n initMapStateToProps: initMapStateToProps,\n initMapDispatchToProps: initMapDispatchToProps,\n initMergeProps: initMergeProps,\n pure: pure,\n areStatesEqual: areStatesEqual,\n areOwnPropsEqual: areOwnPropsEqual,\n areStatePropsEqual: areStatePropsEqual,\n areMergedPropsEqual: areMergedPropsEqual\n }, extraOptions));\n };\n}\nexport default /*#__PURE__*/createConnect();","function is(x, y) {\n if (x === y) {\n return x !== 0 || y !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\n\nexport default function shallowEqual(objA, objB) {\n if (is(objA, objB)) return true;\n\n if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) {\n return false;\n }\n\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n if (keysA.length !== keysB.length) return false;\n\n for (var i = 0; i < keysA.length; i++) {\n if (!Object.prototype.hasOwnProperty.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n return false;\n }\n }\n\n return true;\n}","import bindActionCreators from '../utils/bindActionCreators';\nimport { wrapMapToPropsConstant, wrapMapToPropsFunc } from './wrapMapToProps';\nexport function whenMapDispatchToPropsIsFunction(mapDispatchToProps) {\n return typeof mapDispatchToProps === 'function' ? wrapMapToPropsFunc(mapDispatchToProps, 'mapDispatchToProps') : undefined;\n}\nexport function whenMapDispatchToPropsIsMissing(mapDispatchToProps) {\n return !mapDispatchToProps ? wrapMapToPropsConstant(function (dispatch) {\n return {\n dispatch: dispatch\n };\n }) : undefined;\n}\nexport function whenMapDispatchToPropsIsObject(mapDispatchToProps) {\n return mapDispatchToProps && typeof mapDispatchToProps === 'object' ? wrapMapToPropsConstant(function (dispatch) {\n return bindActionCreators(mapDispatchToProps, dispatch);\n }) : undefined;\n}\nexport default [whenMapDispatchToPropsIsFunction, whenMapDispatchToPropsIsMissing, whenMapDispatchToPropsIsObject];","export default function bindActionCreators(actionCreators, dispatch) {\n var boundActionCreators = {};\n\n var _loop = function _loop(key) {\n var actionCreator = actionCreators[key];\n\n if (typeof actionCreator === 'function') {\n boundActionCreators[key] = function () {\n return dispatch(actionCreator.apply(void 0, arguments));\n };\n }\n };\n\n for (var key in actionCreators) {\n _loop(key);\n }\n\n return boundActionCreators;\n}","import verifyPlainObject from '../utils/verifyPlainObject';\nexport function wrapMapToPropsConstant(getConstant) {\n return function initConstantSelector(dispatch, options) {\n var constant = getConstant(dispatch, options);\n\n function constantSelector() {\n return constant;\n }\n\n constantSelector.dependsOnOwnProps = false;\n return constantSelector;\n };\n} // dependsOnOwnProps is used by createMapToPropsProxy to determine whether to pass props as args\n// to the mapToProps function being wrapped. It is also used by makePurePropsSelector to determine\n// whether mapToProps needs to be invoked when props have changed.\n//\n// A length of one signals that mapToProps does not depend on props from the parent component.\n// A length of zero is assumed to mean mapToProps is getting args via arguments or ...args and\n// therefore not reporting its length accurately..\n\nexport function getDependsOnOwnProps(mapToProps) {\n return mapToProps.dependsOnOwnProps !== null && mapToProps.dependsOnOwnProps !== undefined ? Boolean(mapToProps.dependsOnOwnProps) : mapToProps.length !== 1;\n} // Used by whenMapStateToPropsIsFunction and whenMapDispatchToPropsIsFunction,\n// this function wraps mapToProps in a proxy function which does several things:\n//\n// * Detects whether the mapToProps function being called depends on props, which\n// is used by selectorFactory to decide if it should reinvoke on props changes.\n//\n// * On first call, handles mapToProps if returns another function, and treats that\n// new function as the true mapToProps for subsequent calls.\n//\n// * On first call, verifies the first result is a plain object, in order to warn\n// the developer that their mapToProps function is not returning a valid result.\n//\n\nexport function wrapMapToPropsFunc(mapToProps, methodName) {\n return function initProxySelector(dispatch, _ref) {\n var displayName = _ref.displayName;\n\n var proxy = function mapToPropsProxy(stateOrDispatch, ownProps) {\n return proxy.dependsOnOwnProps ? proxy.mapToProps(stateOrDispatch, ownProps) : proxy.mapToProps(stateOrDispatch);\n }; // allow detectFactoryAndVerify to get ownProps\n\n\n proxy.dependsOnOwnProps = true;\n\n proxy.mapToProps = function detectFactoryAndVerify(stateOrDispatch, ownProps) {\n proxy.mapToProps = mapToProps;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(mapToProps);\n var props = proxy(stateOrDispatch, ownProps);\n\n if (typeof props === 'function') {\n proxy.mapToProps = props;\n proxy.dependsOnOwnProps = getDependsOnOwnProps(props);\n props = proxy(stateOrDispatch, ownProps);\n }\n\n if (process.env.NODE_ENV !== 'production') verifyPlainObject(props, displayName, methodName);\n return props;\n };\n\n return proxy;\n };\n}","import isPlainObject from './isPlainObject';\nimport warning from './warning';\nexport default function verifyPlainObject(value, displayName, methodName) {\n if (!isPlainObject(value)) {\n warning(methodName + \"() in \" + displayName + \" must return a plain object. Instead received \" + value + \".\");\n }\n}","/**\r\n * @param {any} obj The object to inspect.\r\n * @returns {boolean} True if the argument appears to be a plain object.\r\n */\nexport default function isPlainObject(obj) {\n if (typeof obj !== 'object' || obj === null) return false;\n var proto = Object.getPrototypeOf(obj);\n if (proto === null) return true;\n var baseProto = proto;\n\n while (Object.getPrototypeOf(baseProto) !== null) {\n baseProto = Object.getPrototypeOf(baseProto);\n }\n\n return proto === baseProto;\n}","/**\r\n * Prints a warning in the console if it exists.\r\n *\r\n * @param {String} message The warning message.\r\n * @returns {void}\r\n */\nexport default function warning(message) {\n /* eslint-disable no-console */\n if (typeof console !== 'undefined' && typeof console.error === 'function') {\n console.error(message);\n }\n /* eslint-enable no-console */\n\n\n try {\n // This error was thrown as a convenience so that if you enable\n // \"break on all exceptions\" in your console,\n // it would pause the execution at this line.\n throw new Error(message);\n /* eslint-disable no-empty */\n } catch (e) {}\n /* eslint-enable no-empty */\n\n}","import { wrapMapToPropsConstant, wrapMapToPropsFunc } from './wrapMapToProps';\nexport function whenMapStateToPropsIsFunction(mapStateToProps) {\n return typeof mapStateToProps === 'function' ? wrapMapToPropsFunc(mapStateToProps, 'mapStateToProps') : undefined;\n}\nexport function whenMapStateToPropsIsMissing(mapStateToProps) {\n return !mapStateToProps ? wrapMapToPropsConstant(function () {\n return {};\n }) : undefined;\n}\nexport default [whenMapStateToPropsIsFunction, whenMapStateToPropsIsMissing];","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport verifyPlainObject from '../utils/verifyPlainObject';\nexport function defaultMergeProps(stateProps, dispatchProps, ownProps) {\n return _extends({}, ownProps, stateProps, dispatchProps);\n}\nexport function wrapMergePropsFunc(mergeProps) {\n return function initMergePropsProxy(dispatch, _ref) {\n var displayName = _ref.displayName,\n pure = _ref.pure,\n areMergedPropsEqual = _ref.areMergedPropsEqual;\n var hasRunOnce = false;\n var mergedProps;\n return function mergePropsProxy(stateProps, dispatchProps, ownProps) {\n var nextMergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n\n if (hasRunOnce) {\n if (!pure || !areMergedPropsEqual(nextMergedProps, mergedProps)) mergedProps = nextMergedProps;\n } else {\n hasRunOnce = true;\n mergedProps = nextMergedProps;\n if (process.env.NODE_ENV !== 'production') verifyPlainObject(mergedProps, displayName, 'mergeProps');\n }\n\n return mergedProps;\n };\n };\n}\nexport function whenMergePropsIsFunction(mergeProps) {\n return typeof mergeProps === 'function' ? wrapMergePropsFunc(mergeProps) : undefined;\n}\nexport function whenMergePropsIsOmitted(mergeProps) {\n return !mergeProps ? function () {\n return defaultMergeProps;\n } : undefined;\n}\nexport default [whenMergePropsIsFunction, whenMergePropsIsOmitted];","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"initMapStateToProps\", \"initMapDispatchToProps\", \"initMergeProps\"];\nimport verifySubselectors from './verifySubselectors';\nexport function impureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch) {\n return function impureFinalPropsSelector(state, ownProps) {\n return mergeProps(mapStateToProps(state, ownProps), mapDispatchToProps(dispatch, ownProps), ownProps);\n };\n}\nexport function pureFinalPropsSelectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, _ref) {\n var areStatesEqual = _ref.areStatesEqual,\n areOwnPropsEqual = _ref.areOwnPropsEqual,\n areStatePropsEqual = _ref.areStatePropsEqual;\n var hasRunAtLeastOnce = false;\n var state;\n var ownProps;\n var stateProps;\n var dispatchProps;\n var mergedProps;\n\n function handleFirstCall(firstState, firstOwnProps) {\n state = firstState;\n ownProps = firstOwnProps;\n stateProps = mapStateToProps(state, ownProps);\n dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n hasRunAtLeastOnce = true;\n return mergedProps;\n }\n\n function handleNewPropsAndNewState() {\n stateProps = mapStateToProps(state, ownProps);\n if (mapDispatchToProps.dependsOnOwnProps) dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n\n function handleNewProps() {\n if (mapStateToProps.dependsOnOwnProps) stateProps = mapStateToProps(state, ownProps);\n if (mapDispatchToProps.dependsOnOwnProps) dispatchProps = mapDispatchToProps(dispatch, ownProps);\n mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n\n function handleNewState() {\n var nextStateProps = mapStateToProps(state, ownProps);\n var statePropsChanged = !areStatePropsEqual(nextStateProps, stateProps);\n stateProps = nextStateProps;\n if (statePropsChanged) mergedProps = mergeProps(stateProps, dispatchProps, ownProps);\n return mergedProps;\n }\n\n function handleSubsequentCalls(nextState, nextOwnProps) {\n var propsChanged = !areOwnPropsEqual(nextOwnProps, ownProps);\n var stateChanged = !areStatesEqual(nextState, state, nextOwnProps, ownProps);\n state = nextState;\n ownProps = nextOwnProps;\n if (propsChanged && stateChanged) return handleNewPropsAndNewState();\n if (propsChanged) return handleNewProps();\n if (stateChanged) return handleNewState();\n return mergedProps;\n }\n\n return function pureFinalPropsSelector(nextState, nextOwnProps) {\n return hasRunAtLeastOnce ? handleSubsequentCalls(nextState, nextOwnProps) : handleFirstCall(nextState, nextOwnProps);\n };\n} // TODO: Add more comments\n// If pure is true, the selector returned by selectorFactory will memoize its results,\n// allowing connectAdvanced's shouldComponentUpdate to return false if final\n// props have not changed. If false, the selector will always return a new\n// object and shouldComponentUpdate will always return true.\n\nexport default function finalPropsSelectorFactory(dispatch, _ref2) {\n var initMapStateToProps = _ref2.initMapStateToProps,\n initMapDispatchToProps = _ref2.initMapDispatchToProps,\n initMergeProps = _ref2.initMergeProps,\n options = _objectWithoutPropertiesLoose(_ref2, _excluded);\n\n var mapStateToProps = initMapStateToProps(dispatch, options);\n var mapDispatchToProps = initMapDispatchToProps(dispatch, options);\n var mergeProps = initMergeProps(dispatch, options);\n\n if (process.env.NODE_ENV !== 'production') {\n verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps, options.displayName);\n }\n\n var selectorFactory = options.pure ? pureFinalPropsSelectorFactory : impureFinalPropsSelectorFactory;\n return selectorFactory(mapStateToProps, mapDispatchToProps, mergeProps, dispatch, options);\n}","import warning from '../utils/warning';\n\nfunction verify(selector, methodName, displayName) {\n if (!selector) {\n throw new Error(\"Unexpected value for \" + methodName + \" in \" + displayName + \".\");\n } else if (methodName === 'mapStateToProps' || methodName === 'mapDispatchToProps') {\n if (!Object.prototype.hasOwnProperty.call(selector, 'dependsOnOwnProps')) {\n warning(\"The selector for \" + methodName + \" of \" + displayName + \" did not specify a value for dependsOnOwnProps.\");\n }\n }\n}\n\nexport default function verifySubselectors(mapStateToProps, mapDispatchToProps, mergeProps, displayName) {\n verify(mapStateToProps, 'mapStateToProps', displayName);\n verify(mapDispatchToProps, 'mapDispatchToProps', displayName);\n verify(mergeProps, 'mergeProps', displayName);\n}","import { ReactReduxContext } from '../components/Context';\nimport { useStore as useDefaultStore, createStoreHook } from './useStore';\n/**\r\n * Hook factory, which creates a `useDispatch` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useDispatch` hook bound to the specified context.\r\n */\n\nexport function createDispatchHook(context) {\n if (context === void 0) {\n context = ReactReduxContext;\n }\n\n var useStore = context === ReactReduxContext ? useDefaultStore : createStoreHook(context);\n return function useDispatch() {\n var store = useStore();\n return store.dispatch;\n };\n}\n/**\r\n * A hook to access the redux `dispatch` function.\r\n *\r\n * @returns {any|function} redux store's `dispatch` function\r\n *\r\n * @example\r\n *\r\n * import React, { useCallback } from 'react'\r\n * import { useDispatch } from 'react-redux'\r\n *\r\n * export const CounterComponent = ({ value }) => {\r\n * const dispatch = useDispatch()\r\n * const increaseCounter = useCallback(() => dispatch({ type: 'increase-counter' }), [])\r\n * return (\r\n *
\r\n * {value}\r\n * \r\n *
\r\n * )\r\n * }\r\n */\n\nexport var useDispatch = /*#__PURE__*/createDispatchHook();","import { useContext } from 'react';\nimport { ReactReduxContext } from '../components/Context';\nimport { useReduxContext as useDefaultReduxContext } from './useReduxContext';\n/**\r\n * Hook factory, which creates a `useStore` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useStore` hook bound to the specified context.\r\n */\n\nexport function createStoreHook(context) {\n if (context === void 0) {\n context = ReactReduxContext;\n }\n\n var useReduxContext = context === ReactReduxContext ? useDefaultReduxContext : function () {\n return useContext(context);\n };\n return function useStore() {\n var _useReduxContext = useReduxContext(),\n store = _useReduxContext.store;\n\n return store;\n };\n}\n/**\r\n * A hook to access the redux store.\r\n *\r\n * @returns {any} the redux store\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useStore } from 'react-redux'\r\n *\r\n * export const ExampleComponent = () => {\r\n * const store = useStore()\r\n * return
{store.getState()}
\r\n * }\r\n */\n\nexport var useStore = /*#__PURE__*/createStoreHook();","import { useContext } from 'react';\nimport { ReactReduxContext } from '../components/Context';\n/**\r\n * A hook to access the value of the `ReactReduxContext`. This is a low-level\r\n * hook that you should usually not need to call directly.\r\n *\r\n * @returns {any} the value of the `ReactReduxContext`\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useReduxContext } from 'react-redux'\r\n *\r\n * export const CounterComponent = ({ value }) => {\r\n * const { store } = useReduxContext()\r\n * return
{store.getState()}
\r\n * }\r\n */\n\nexport function useReduxContext() {\n var contextValue = useContext(ReactReduxContext);\n\n if (process.env.NODE_ENV !== 'production' && !contextValue) {\n throw new Error('could not find react-redux context value; please ensure the component is wrapped in a ');\n }\n\n return contextValue;\n}","import { useReducer, useRef, useMemo, useContext, useDebugValue } from 'react';\nimport { useReduxContext as useDefaultReduxContext } from './useReduxContext';\nimport { createSubscription } from '../utils/Subscription';\nimport { useIsomorphicLayoutEffect } from '../utils/useIsomorphicLayoutEffect';\nimport { ReactReduxContext } from '../components/Context';\n\nvar refEquality = function refEquality(a, b) {\n return a === b;\n};\n\nfunction useSelectorWithStoreAndSubscription(selector, equalityFn, store, contextSub) {\n var _useReducer = useReducer(function (s) {\n return s + 1;\n }, 0),\n forceRender = _useReducer[1];\n\n var subscription = useMemo(function () {\n return createSubscription(store, contextSub);\n }, [store, contextSub]);\n var latestSubscriptionCallbackError = useRef();\n var latestSelector = useRef();\n var latestStoreState = useRef();\n var latestSelectedState = useRef();\n var storeState = store.getState();\n var selectedState;\n\n try {\n if (selector !== latestSelector.current || storeState !== latestStoreState.current || latestSubscriptionCallbackError.current) {\n var newSelectedState = selector(storeState); // ensure latest selected state is reused so that a custom equality function can result in identical references\n\n if (latestSelectedState.current === undefined || !equalityFn(newSelectedState, latestSelectedState.current)) {\n selectedState = newSelectedState;\n } else {\n selectedState = latestSelectedState.current;\n }\n } else {\n selectedState = latestSelectedState.current;\n }\n } catch (err) {\n if (latestSubscriptionCallbackError.current) {\n err.message += \"\\nThe error may be correlated with this previous error:\\n\" + latestSubscriptionCallbackError.current.stack + \"\\n\\n\";\n }\n\n throw err;\n }\n\n useIsomorphicLayoutEffect(function () {\n latestSelector.current = selector;\n latestStoreState.current = storeState;\n latestSelectedState.current = selectedState;\n latestSubscriptionCallbackError.current = undefined;\n });\n useIsomorphicLayoutEffect(function () {\n function checkForUpdates() {\n try {\n var newStoreState = store.getState(); // Avoid calling selector multiple times if the store's state has not changed\n\n if (newStoreState === latestStoreState.current) {\n return;\n }\n\n var _newSelectedState = latestSelector.current(newStoreState);\n\n if (equalityFn(_newSelectedState, latestSelectedState.current)) {\n return;\n }\n\n latestSelectedState.current = _newSelectedState;\n latestStoreState.current = newStoreState;\n } catch (err) {\n // we ignore all errors here, since when the component\n // is re-rendered, the selectors are called again, and\n // will throw again, if neither props nor store state\n // changed\n latestSubscriptionCallbackError.current = err;\n }\n\n forceRender();\n }\n\n subscription.onStateChange = checkForUpdates;\n subscription.trySubscribe();\n checkForUpdates();\n return function () {\n return subscription.tryUnsubscribe();\n };\n }, [store, subscription]);\n return selectedState;\n}\n/**\r\n * Hook factory, which creates a `useSelector` hook bound to a given context.\r\n *\r\n * @param {React.Context} [context=ReactReduxContext] Context passed to your ``.\r\n * @returns {Function} A `useSelector` hook bound to the specified context.\r\n */\n\n\nexport function createSelectorHook(context) {\n if (context === void 0) {\n context = ReactReduxContext;\n }\n\n var useReduxContext = context === ReactReduxContext ? useDefaultReduxContext : function () {\n return useContext(context);\n };\n return function useSelector(selector, equalityFn) {\n if (equalityFn === void 0) {\n equalityFn = refEquality;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (!selector) {\n throw new Error(\"You must pass a selector to useSelector\");\n }\n\n if (typeof selector !== 'function') {\n throw new Error(\"You must pass a function as a selector to useSelector\");\n }\n\n if (typeof equalityFn !== 'function') {\n throw new Error(\"You must pass a function as an equality function to useSelector\");\n }\n }\n\n var _useReduxContext = useReduxContext(),\n store = _useReduxContext.store,\n contextSub = _useReduxContext.subscription;\n\n var selectedState = useSelectorWithStoreAndSubscription(selector, equalityFn, store, contextSub);\n useDebugValue(selectedState);\n return selectedState;\n };\n}\n/**\r\n * A hook to access the redux store's state. This hook takes a selector function\r\n * as an argument. The selector is called with the store state.\r\n *\r\n * This hook takes an optional equality comparison function as the second parameter\r\n * that allows you to customize the way the selected state is compared to determine\r\n * whether the component needs to be re-rendered.\r\n *\r\n * @param {Function} selector the selector function\r\n * @param {Function=} equalityFn the function that will be used to determine equality\r\n *\r\n * @returns {any} the selected state\r\n *\r\n * @example\r\n *\r\n * import React from 'react'\r\n * import { useSelector } from 'react-redux'\r\n *\r\n * export const CounterComponent = () => {\r\n * const counter = useSelector(state => state.counter)\r\n * return
{counter}
\r\n * }\r\n */\n\nexport var useSelector = /*#__PURE__*/createSelectorHook();","/* eslint-disable import/no-unresolved */\nexport { unstable_batchedUpdates } from 'react-dom';","// ** Redux, Thunk & Root Reducer Imports\nimport thunk from 'redux-thunk'\nimport createDebounce from 'redux-debounced'\nimport rootReducer from '../reducers/rootReducer'\nimport {applyMiddleware, compose, createStore} from 'redux'\n// ** redux-persist wrappers\nimport {persistReducer, persistStore} from 'redux-persist'\n// ** the local storage we'll be using to persist data\nimport AsyncStorage from '@react-native-async-storage/async-storage'\n// ** redux-persist merge level\nimport autoMergeLevel2 from 'redux-persist/lib/stateReconciler/autoMergeLevel2'\n\n\n// persist config\nconst persistConfig = {\n key: 'root',\n storage: AsyncStorage,\n stateReconciler: autoMergeLevel2,\n whitelist: ['data', 'camera', 'liveMode'],\n};\n// wrap persist API around root reducer and store\nconst persistedReducer = persistReducer(persistConfig, rootReducer);\n\n// ** init middleware\nconst middleware = [thunk, createDebounce()]\n\n// ** Dev Tools\nconst composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ || compose\n\n// ** CreateM store\nconst store = createStore(persistedReducer, {}, composeEnhancers(applyMiddleware(...middleware)))\nconst persistor = persistStore(store);\n\n\nexport {store, persistor}","function createThunkMiddleware(extraArgument) {\n return function (_ref) {\n var dispatch = _ref.dispatch,\n getState = _ref.getState;\n return function (next) {\n return function (action) {\n if (typeof action === 'function') {\n return action(dispatch, getState, extraArgument);\n }\n\n return next(action);\n };\n };\n };\n}\n\nvar thunk = createThunkMiddleware();\nthunk.withExtraArgument = createThunkMiddleware;\n\nexport default thunk;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n\nexports.default = function () {\n var timers = {};\n\n var middleware = function middleware() {\n return function (dispatch) {\n return function (action) {\n var _action$meta = action.meta;\n _action$meta = _action$meta === undefined ? {} : _action$meta;\n var _action$meta$debounce = _action$meta.debounce,\n debounce = _action$meta$debounce === undefined ? {} : _action$meta$debounce,\n type = action.type;\n var time = debounce.time,\n _debounce$key = debounce.key,\n key = _debounce$key === undefined ? type : _debounce$key,\n _debounce$cancel = debounce.cancel,\n cancel = _debounce$cancel === undefined ? false : _debounce$cancel,\n _debounce$leading = debounce.leading,\n leading = _debounce$leading === undefined ? false : _debounce$leading,\n _debounce$trailing = debounce.trailing,\n trailing = _debounce$trailing === undefined ? true : _debounce$trailing;\n\n\n var shouldDebounce = (time && key || cancel && key) && (trailing || leading);\n var dispatchNow = leading && !timers[key];\n\n var later = function later(resolve) {\n return function () {\n if (trailing && !dispatchNow) {\n resolve(dispatch(action));\n }\n timers[key] = null;\n };\n };\n\n if (!shouldDebounce) {\n return dispatch(action);\n }\n\n if (timers[key]) {\n clearTimeout(timers[key]);\n timers[key] = null;\n }\n\n if (!cancel) {\n return new Promise(function (resolve) {\n if (dispatchNow) {\n resolve(dispatch(action));\n }\n timers[key] = setTimeout(later(resolve), time);\n });\n }\n };\n };\n };\n\n middleware._timers = timers;\n\n return middleware;\n};","// ** Redux Imports\nimport {combineReducers} from 'redux'\n\n// ** Reducers Imports\nimport alert from './alert'\nimport data from \"./data\"\nimport offlineMode from \"./offlineMode\"\nimport liveMode from \"./liveMode\"\nimport camera from \"./camera\"\nimport api from \"./api\"\nimport notifications from \"./notifications\";\nimport activity from \"@data/redux/reducers/activity\";\nimport navigation from \"@data/redux/reducers/navigation\";\nimport index from \"@data/redux/reducers/liveKitRoom\";\n\n\nconst rootReducer = combineReducers({\n alert,\n data, // persisted\n api,\n offlineMode,\n liveMode,\n camera,\n notifications,\n activity,\n navigation,\n liveKitRoom: index\n})\n\nexport default rootReducer\n","import $$observable from 'symbol-observable';\n\n/**\n * These are private action types reserved by Redux.\n * For any unknown actions, you must return the current state.\n * If the current state is undefined, you must return the initial state.\n * Do not reference these action types directly in your code.\n */\nvar randomString = function randomString() {\n return Math.random().toString(36).substring(7).split('').join('.');\n};\n\nvar ActionTypes = {\n INIT: \"@@redux/INIT\" + randomString(),\n REPLACE: \"@@redux/REPLACE\" + randomString(),\n PROBE_UNKNOWN_ACTION: function PROBE_UNKNOWN_ACTION() {\n return \"@@redux/PROBE_UNKNOWN_ACTION\" + randomString();\n }\n};\n\n/**\n * @param {any} obj The object to inspect.\n * @returns {boolean} True if the argument appears to be a plain object.\n */\nfunction isPlainObject(obj) {\n if (typeof obj !== 'object' || obj === null) return false;\n var proto = obj;\n\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n\n return Object.getPrototypeOf(obj) === proto;\n}\n\n/**\n * Creates a Redux store that holds the state tree.\n * The only way to change the data in the store is to call `dispatch()` on it.\n *\n * There should only be a single store in your app. To specify how different\n * parts of the state tree respond to actions, you may combine several reducers\n * into a single reducer function by using `combineReducers`.\n *\n * @param {Function} reducer A function that returns the next state tree, given\n * the current state tree and the action to handle.\n *\n * @param {any} [preloadedState] The initial state. You may optionally specify it\n * to hydrate the state from the server in universal apps, or to restore a\n * previously serialized user session.\n * If you use `combineReducers` to produce the root reducer function, this must be\n * an object with the same shape as `combineReducers` keys.\n *\n * @param {Function} [enhancer] The store enhancer. You may optionally specify it\n * to enhance the store with third-party capabilities such as middleware,\n * time travel, persistence, etc. The only store enhancer that ships with Redux\n * is `applyMiddleware()`.\n *\n * @returns {Store} A Redux store that lets you read the state, dispatch actions\n * and subscribe to changes.\n */\n\nfunction createStore(reducer, preloadedState, enhancer) {\n var _ref2;\n\n if (typeof preloadedState === 'function' && typeof enhancer === 'function' || typeof enhancer === 'function' && typeof arguments[3] === 'function') {\n throw new Error('It looks like you are passing several store enhancers to ' + 'createStore(). This is not supported. Instead, compose them ' + 'together to a single function.');\n }\n\n if (typeof preloadedState === 'function' && typeof enhancer === 'undefined') {\n enhancer = preloadedState;\n preloadedState = undefined;\n }\n\n if (typeof enhancer !== 'undefined') {\n if (typeof enhancer !== 'function') {\n throw new Error('Expected the enhancer to be a function.');\n }\n\n return enhancer(createStore)(reducer, preloadedState);\n }\n\n if (typeof reducer !== 'function') {\n throw new Error('Expected the reducer to be a function.');\n }\n\n var currentReducer = reducer;\n var currentState = preloadedState;\n var currentListeners = [];\n var nextListeners = currentListeners;\n var isDispatching = false;\n /**\n * This makes a shallow copy of currentListeners so we can use\n * nextListeners as a temporary list while dispatching.\n *\n * This prevents any bugs around consumers calling\n * subscribe/unsubscribe in the middle of a dispatch.\n */\n\n function ensureCanMutateNextListeners() {\n if (nextListeners === currentListeners) {\n nextListeners = currentListeners.slice();\n }\n }\n /**\n * Reads the state tree managed by the store.\n *\n * @returns {any} The current state tree of your application.\n */\n\n\n function getState() {\n if (isDispatching) {\n throw new Error('You may not call store.getState() while the reducer is executing. ' + 'The reducer has already received the state as an argument. ' + 'Pass it down from the top reducer instead of reading it from the store.');\n }\n\n return currentState;\n }\n /**\n * Adds a change listener. It will be called any time an action is dispatched,\n * and some part of the state tree may potentially have changed. You may then\n * call `getState()` to read the current state tree inside the callback.\n *\n * You may call `dispatch()` from a change listener, with the following\n * caveats:\n *\n * 1. The subscriptions are snapshotted just before every `dispatch()` call.\n * If you subscribe or unsubscribe while the listeners are being invoked, this\n * will not have any effect on the `dispatch()` that is currently in progress.\n * However, the next `dispatch()` call, whether nested or not, will use a more\n * recent snapshot of the subscription list.\n *\n * 2. The listener should not expect to see all state changes, as the state\n * might have been updated multiple times during a nested `dispatch()` before\n * the listener is called. It is, however, guaranteed that all subscribers\n * registered before the `dispatch()` started will be called with the latest\n * state by the time it exits.\n *\n * @param {Function} listener A callback to be invoked on every dispatch.\n * @returns {Function} A function to remove this change listener.\n */\n\n\n function subscribe(listener) {\n if (typeof listener !== 'function') {\n throw new Error('Expected the listener to be a function.');\n }\n\n if (isDispatching) {\n throw new Error('You may not call store.subscribe() while the reducer is executing. ' + 'If you would like to be notified after the store has been updated, subscribe from a ' + 'component and invoke store.getState() in the callback to access the latest state. ' + 'See https://redux.js.org/api-reference/store#subscribelistener for more details.');\n }\n\n var isSubscribed = true;\n ensureCanMutateNextListeners();\n nextListeners.push(listener);\n return function unsubscribe() {\n if (!isSubscribed) {\n return;\n }\n\n if (isDispatching) {\n throw new Error('You may not unsubscribe from a store listener while the reducer is executing. ' + 'See https://redux.js.org/api-reference/store#subscribelistener for more details.');\n }\n\n isSubscribed = false;\n ensureCanMutateNextListeners();\n var index = nextListeners.indexOf(listener);\n nextListeners.splice(index, 1);\n currentListeners = null;\n };\n }\n /**\n * Dispatches an action. It is the only way to trigger a state change.\n *\n * The `reducer` function, used to create the store, will be called with the\n * current state tree and the given `action`. Its return value will\n * be considered the **next** state of the tree, and the change listeners\n * will be notified.\n *\n * The base implementation only supports plain object actions. If you want to\n * dispatch a Promise, an Observable, a thunk, or something else, you need to\n * wrap your store creating function into the corresponding middleware. For\n * example, see the documentation for the `redux-thunk` package. Even the\n * middleware will eventually dispatch plain object actions using this method.\n *\n * @param {Object} action A plain object representing “what changed”. It is\n * a good idea to keep actions serializable so you can record and replay user\n * sessions, or use the time travelling `redux-devtools`. An action must have\n * a `type` property which may not be `undefined`. It is a good idea to use\n * string constants for action types.\n *\n * @returns {Object} For convenience, the same action object you dispatched.\n *\n * Note that, if you use a custom middleware, it may wrap `dispatch()` to\n * return something else (for example, a Promise you can await).\n */\n\n\n function dispatch(action) {\n if (!isPlainObject(action)) {\n throw new Error('Actions must be plain objects. ' + 'Use custom middleware for async actions.');\n }\n\n if (typeof action.type === 'undefined') {\n throw new Error('Actions may not have an undefined \"type\" property. ' + 'Have you misspelled a constant?');\n }\n\n if (isDispatching) {\n throw new Error('Reducers may not dispatch actions.');\n }\n\n try {\n isDispatching = true;\n currentState = currentReducer(currentState, action);\n } finally {\n isDispatching = false;\n }\n\n var listeners = currentListeners = nextListeners;\n\n for (var i = 0; i < listeners.length; i++) {\n var listener = listeners[i];\n listener();\n }\n\n return action;\n }\n /**\n * Replaces the reducer currently used by the store to calculate the state.\n *\n * You might need this if your app implements code splitting and you want to\n * load some of the reducers dynamically. You might also need this if you\n * implement a hot reloading mechanism for Redux.\n *\n * @param {Function} nextReducer The reducer for the store to use instead.\n * @returns {void}\n */\n\n\n function replaceReducer(nextReducer) {\n if (typeof nextReducer !== 'function') {\n throw new Error('Expected the nextReducer to be a function.');\n }\n\n currentReducer = nextReducer; // This action has a similiar effect to ActionTypes.INIT.\n // Any reducers that existed in both the new and old rootReducer\n // will receive the previous state. This effectively populates\n // the new state tree with any relevant data from the old one.\n\n dispatch({\n type: ActionTypes.REPLACE\n });\n }\n /**\n * Interoperability point for observable/reactive libraries.\n * @returns {observable} A minimal observable of state changes.\n * For more information, see the observable proposal:\n * https://github.com/tc39/proposal-observable\n */\n\n\n function observable() {\n var _ref;\n\n var outerSubscribe = subscribe;\n return _ref = {\n /**\n * The minimal observable subscription method.\n * @param {Object} observer Any object that can be used as an observer.\n * The observer object should have a `next` method.\n * @returns {subscription} An object with an `unsubscribe` method that can\n * be used to unsubscribe the observable from the store, and prevent further\n * emission of values from the observable.\n */\n subscribe: function subscribe(observer) {\n if (typeof observer !== 'object' || observer === null) {\n throw new TypeError('Expected the observer to be an object.');\n }\n\n function observeState() {\n if (observer.next) {\n observer.next(getState());\n }\n }\n\n observeState();\n var unsubscribe = outerSubscribe(observeState);\n return {\n unsubscribe: unsubscribe\n };\n }\n }, _ref[$$observable] = function () {\n return this;\n }, _ref;\n } // When a store is created, an \"INIT\" action is dispatched so that every\n // reducer returns their initial state. This effectively populates\n // the initial state tree.\n\n\n dispatch({\n type: ActionTypes.INIT\n });\n return _ref2 = {\n dispatch: dispatch,\n subscribe: subscribe,\n getState: getState,\n replaceReducer: replaceReducer\n }, _ref2[$$observable] = observable, _ref2;\n}\n\n/**\n * Prints a warning in the console if it exists.\n *\n * @param {String} message The warning message.\n * @returns {void}\n */\nfunction warning(message) {\n /* eslint-disable no-console */\n if (typeof console !== 'undefined' && typeof console.error === 'function') {\n console.error(message);\n }\n /* eslint-enable no-console */\n\n\n try {\n // This error was thrown as a convenience so that if you enable\n // \"break on all exceptions\" in your console,\n // it would pause the execution at this line.\n throw new Error(message);\n } catch (e) {} // eslint-disable-line no-empty\n\n}\n\nfunction getUndefinedStateErrorMessage(key, action) {\n var actionType = action && action.type;\n var actionDescription = actionType && \"action \\\"\" + String(actionType) + \"\\\"\" || 'an action';\n return \"Given \" + actionDescription + \", reducer \\\"\" + key + \"\\\" returned undefined. \" + \"To ignore an action, you must explicitly return the previous state. \" + \"If you want this reducer to hold no value, you can return null instead of undefined.\";\n}\n\nfunction getUnexpectedStateShapeWarningMessage(inputState, reducers, action, unexpectedKeyCache) {\n var reducerKeys = Object.keys(reducers);\n var argumentName = action && action.type === ActionTypes.INIT ? 'preloadedState argument passed to createStore' : 'previous state received by the reducer';\n\n if (reducerKeys.length === 0) {\n return 'Store does not have a valid reducer. Make sure the argument passed ' + 'to combineReducers is an object whose values are reducers.';\n }\n\n if (!isPlainObject(inputState)) {\n return \"The \" + argumentName + \" has unexpected type of \\\"\" + {}.toString.call(inputState).match(/\\s([a-z|A-Z]+)/)[1] + \"\\\". Expected argument to be an object with the following \" + (\"keys: \\\"\" + reducerKeys.join('\", \"') + \"\\\"\");\n }\n\n var unexpectedKeys = Object.keys(inputState).filter(function (key) {\n return !reducers.hasOwnProperty(key) && !unexpectedKeyCache[key];\n });\n unexpectedKeys.forEach(function (key) {\n unexpectedKeyCache[key] = true;\n });\n if (action && action.type === ActionTypes.REPLACE) return;\n\n if (unexpectedKeys.length > 0) {\n return \"Unexpected \" + (unexpectedKeys.length > 1 ? 'keys' : 'key') + \" \" + (\"\\\"\" + unexpectedKeys.join('\", \"') + \"\\\" found in \" + argumentName + \". \") + \"Expected to find one of the known reducer keys instead: \" + (\"\\\"\" + reducerKeys.join('\", \"') + \"\\\". Unexpected keys will be ignored.\");\n }\n}\n\nfunction assertReducerShape(reducers) {\n Object.keys(reducers).forEach(function (key) {\n var reducer = reducers[key];\n var initialState = reducer(undefined, {\n type: ActionTypes.INIT\n });\n\n if (typeof initialState === 'undefined') {\n throw new Error(\"Reducer \\\"\" + key + \"\\\" returned undefined during initialization. \" + \"If the state passed to the reducer is undefined, you must \" + \"explicitly return the initial state. The initial state may \" + \"not be undefined. If you don't want to set a value for this reducer, \" + \"you can use null instead of undefined.\");\n }\n\n if (typeof reducer(undefined, {\n type: ActionTypes.PROBE_UNKNOWN_ACTION()\n }) === 'undefined') {\n throw new Error(\"Reducer \\\"\" + key + \"\\\" returned undefined when probed with a random type. \" + (\"Don't try to handle \" + ActionTypes.INIT + \" or other actions in \\\"redux/*\\\" \") + \"namespace. They are considered private. Instead, you must return the \" + \"current state for any unknown actions, unless it is undefined, \" + \"in which case you must return the initial state, regardless of the \" + \"action type. The initial state may not be undefined, but can be null.\");\n }\n });\n}\n/**\n * Turns an object whose values are different reducer functions, into a single\n * reducer function. It will call every child reducer, and gather their results\n * into a single state object, whose keys correspond to the keys of the passed\n * reducer functions.\n *\n * @param {Object} reducers An object whose values correspond to different\n * reducer functions that need to be combined into one. One handy way to obtain\n * it is to use ES6 `import * as reducers` syntax. The reducers may never return\n * undefined for any action. Instead, they should return their initial state\n * if the state passed to them was undefined, and the current state for any\n * unrecognized action.\n *\n * @returns {Function} A reducer function that invokes every reducer inside the\n * passed object, and builds a state object with the same shape.\n */\n\n\nfunction combineReducers(reducers) {\n var reducerKeys = Object.keys(reducers);\n var finalReducers = {};\n\n for (var i = 0; i < reducerKeys.length; i++) {\n var key = reducerKeys[i];\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof reducers[key] === 'undefined') {\n warning(\"No reducer provided for key \\\"\" + key + \"\\\"\");\n }\n }\n\n if (typeof reducers[key] === 'function') {\n finalReducers[key] = reducers[key];\n }\n }\n\n var finalReducerKeys = Object.keys(finalReducers); // This is used to make sure we don't warn about the same\n // keys multiple times.\n\n var unexpectedKeyCache;\n\n if (process.env.NODE_ENV !== 'production') {\n unexpectedKeyCache = {};\n }\n\n var shapeAssertionError;\n\n try {\n assertReducerShape(finalReducers);\n } catch (e) {\n shapeAssertionError = e;\n }\n\n return function combination(state, action) {\n if (state === void 0) {\n state = {};\n }\n\n if (shapeAssertionError) {\n throw shapeAssertionError;\n }\n\n if (process.env.NODE_ENV !== 'production') {\n var warningMessage = getUnexpectedStateShapeWarningMessage(state, finalReducers, action, unexpectedKeyCache);\n\n if (warningMessage) {\n warning(warningMessage);\n }\n }\n\n var hasChanged = false;\n var nextState = {};\n\n for (var _i = 0; _i < finalReducerKeys.length; _i++) {\n var _key = finalReducerKeys[_i];\n var reducer = finalReducers[_key];\n var previousStateForKey = state[_key];\n var nextStateForKey = reducer(previousStateForKey, action);\n\n if (typeof nextStateForKey === 'undefined') {\n var errorMessage = getUndefinedStateErrorMessage(_key, action);\n throw new Error(errorMessage);\n }\n\n nextState[_key] = nextStateForKey;\n hasChanged = hasChanged || nextStateForKey !== previousStateForKey;\n }\n\n hasChanged = hasChanged || finalReducerKeys.length !== Object.keys(state).length;\n return hasChanged ? nextState : state;\n };\n}\n\nfunction bindActionCreator(actionCreator, dispatch) {\n return function () {\n return dispatch(actionCreator.apply(this, arguments));\n };\n}\n/**\n * Turns an object whose values are action creators, into an object with the\n * same keys, but with every function wrapped into a `dispatch` call so they\n * may be invoked directly. This is just a convenience method, as you can call\n * `store.dispatch(MyActionCreators.doSomething())` yourself just fine.\n *\n * For convenience, you can also pass an action creator as the first argument,\n * and get a dispatch wrapped function in return.\n *\n * @param {Function|Object} actionCreators An object whose values are action\n * creator functions. One handy way to obtain it is to use ES6 `import * as`\n * syntax. You may also pass a single function.\n *\n * @param {Function} dispatch The `dispatch` function available on your Redux\n * store.\n *\n * @returns {Function|Object} The object mimicking the original object, but with\n * every action creator wrapped into the `dispatch` call. If you passed a\n * function as `actionCreators`, the return value will also be a single\n * function.\n */\n\n\nfunction bindActionCreators(actionCreators, dispatch) {\n if (typeof actionCreators === 'function') {\n return bindActionCreator(actionCreators, dispatch);\n }\n\n if (typeof actionCreators !== 'object' || actionCreators === null) {\n throw new Error(\"bindActionCreators expected an object or a function, instead received \" + (actionCreators === null ? 'null' : typeof actionCreators) + \". \" + \"Did you write \\\"import ActionCreators from\\\" instead of \\\"import * as ActionCreators from\\\"?\");\n }\n\n var boundActionCreators = {};\n\n for (var key in actionCreators) {\n var actionCreator = actionCreators[key];\n\n if (typeof actionCreator === 'function') {\n boundActionCreators[key] = bindActionCreator(actionCreator, dispatch);\n }\n }\n\n return boundActionCreators;\n}\n\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n keys.push.apply(keys, Object.getOwnPropertySymbols(object));\n }\n\n if (enumerableOnly) keys = keys.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n return keys;\n}\n\nfunction _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i] != null ? arguments[i] : {};\n\n if (i % 2) {\n ownKeys(source, true).forEach(function (key) {\n _defineProperty(target, key, source[key]);\n });\n } else if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(source).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n }\n\n return target;\n}\n\n/**\n * Composes single-argument functions from right to left. The rightmost\n * function can take multiple arguments as it provides the signature for\n * the resulting composite function.\n *\n * @param {...Function} funcs The functions to compose.\n * @returns {Function} A function obtained by composing the argument functions\n * from right to left. For example, compose(f, g, h) is identical to doing\n * (...args) => f(g(h(...args))).\n */\nfunction compose() {\n for (var _len = arguments.length, funcs = new Array(_len), _key = 0; _key < _len; _key++) {\n funcs[_key] = arguments[_key];\n }\n\n if (funcs.length === 0) {\n return function (arg) {\n return arg;\n };\n }\n\n if (funcs.length === 1) {\n return funcs[0];\n }\n\n return funcs.reduce(function (a, b) {\n return function () {\n return a(b.apply(void 0, arguments));\n };\n });\n}\n\n/**\n * Creates a store enhancer that applies middleware to the dispatch method\n * of the Redux store. This is handy for a variety of tasks, such as expressing\n * asynchronous actions in a concise manner, or logging every action payload.\n *\n * See `redux-thunk` package as an example of the Redux middleware.\n *\n * Because middleware is potentially asynchronous, this should be the first\n * store enhancer in the composition chain.\n *\n * Note that each middleware will be given the `dispatch` and `getState` functions\n * as named arguments.\n *\n * @param {...Function} middlewares The middleware chain to be applied.\n * @returns {Function} A store enhancer applying the middleware.\n */\n\nfunction applyMiddleware() {\n for (var _len = arguments.length, middlewares = new Array(_len), _key = 0; _key < _len; _key++) {\n middlewares[_key] = arguments[_key];\n }\n\n return function (createStore) {\n return function () {\n var store = createStore.apply(void 0, arguments);\n\n var _dispatch = function dispatch() {\n throw new Error('Dispatching while constructing your middleware is not allowed. ' + 'Other middleware would not be applied to this dispatch.');\n };\n\n var middlewareAPI = {\n getState: store.getState,\n dispatch: function dispatch() {\n return _dispatch.apply(void 0, arguments);\n }\n };\n var chain = middlewares.map(function (middleware) {\n return middleware(middlewareAPI);\n });\n _dispatch = compose.apply(void 0, chain)(store.dispatch);\n return _objectSpread2({}, store, {\n dispatch: _dispatch\n });\n };\n };\n}\n\n/*\n * This is a dummy function to check if the function name has been altered by minification.\n * If the function has been minified and NODE_ENV !== 'production', warn the user.\n */\n\nfunction isCrushed() {}\n\nif (process.env.NODE_ENV !== 'production' && typeof isCrushed.name === 'string' && isCrushed.name !== 'isCrushed') {\n warning('You are currently using minified code outside of NODE_ENV === \"production\". ' + 'This means that you are running a slower development build of Redux. ' + 'You can use loose-envify (https://github.com/zertosh/loose-envify) for browserify ' + 'or setting mode to production in webpack (https://webpack.js.org/concepts/mode/) ' + 'to ensure you have the correct code for your production build.');\n}\n\nexport { ActionTypes as __DO_NOT_USE__ActionTypes, applyMiddleware, bindActionCreators, combineReducers, compose, createStore };\n","/* global window */\nimport ponyfill from './ponyfill.js';\n\nvar root;\n\nif (typeof self !== 'undefined') {\n root = self;\n} else if (typeof window !== 'undefined') {\n root = window;\n} else if (typeof global !== 'undefined') {\n root = global;\n} else if (typeof module !== 'undefined') {\n root = module;\n} else {\n root = Function('return this')();\n}\n\nvar result = ponyfill(root);\nexport default result;\n","export default function symbolObservablePonyfill(root) {\n\tvar result;\n\tvar Symbol = root.Symbol;\n\n\tif (typeof Symbol === 'function') {\n\t\tif (Symbol.observable) {\n\t\t\tresult = Symbol.observable;\n\t\t} else {\n\t\t\tresult = Symbol('observable');\n\t\t\tSymbol.observable = result;\n\t\t}\n\t} else {\n\t\tresult = '@@observable';\n\t}\n\n\treturn result;\n};\n","import { alertConstants } from '../../../constants/alertConstants'\n\nexport default function alert(state = {}, action) {\n switch (action.type) {\n case alertConstants.SUCCESS:\n return {\n type: 'success',\n message: action.message\n }\n case alertConstants.ERROR:\n return {\n type: 'error',\n message: action.message\n }\n case alertConstants.CLEAR:\n return {}\n default:\n return state\n }\n}\n","export const alertConstants = {\n SUCCESS: 'ALERT_SUCCESS',\n ERROR: 'ALERT_ERROR',\n CLEAR: 'ALERT_CLEAR'\n}\n","import chapters from \"@data/redux/reducers/data/chapters\"\nimport interviewReports from \"@data/redux/reducers/data/interviewReports\"\nimport { liveReports } from \"@data/redux/reducers/data/liveReports\"\nimport liveSessions from \"@data/redux/reducers/data/liveSessions\"\nimport materials from \"@data/redux/reducers/data/materials\"\nimport referrals from \"@data/redux/reducers/data/referrals\"\nimport schools from \"@data/redux/reducers/data/schools\"\nimport studyPrograms from \"@data/redux/reducers/data/studyPrograms\"\nimport { combineReducers } from \"redux\"\nimport backOffice from \"./backOffice\"\nimport { currentUser } from \"./currentUser\"\nimport formData from \"./formData\"\nimport reviewer from \"./reviewer\"\nimport schoolCardReport from \"./schoolCardReport\"\nimport { session } from \"./session\"\nimport { staticData } from \"./staticData\"\nimport suggestions from \"./suggestions\"\nimport tutors from \"./tutors\"\nimport users from \"./users\"\nimport videoCall from \"./videoCall\"\n\nconst dataReducers = combineReducers({\n currentUser,\n suggestions,\n reviewer,\n session,\n tutors,\n users,\n staticData,\n formData,\n videoCall,\n backOffice,\n referrals,\n liveReports,\n chapters,\n schools,\n interviewReports,\n studyPrograms,\n materials,\n liveSessions,\n schoolCardReport, \n})\n\nexport default dataReducers\n","import {apiConstants} from \"@data/constants/apiConstants\";\nimport {chaptersService} from \"@data/services/chaptersService\";\n\nconst initialState = {\n chaptersList: []\n}\n\nexport default function chapters(state = initialState, action) {\n switch (action.type) {\n case chaptersService.getChaptersAsStudent.name + apiConstants._SUCCESS:\n case chaptersService.getChaptersAsAdmin.name + apiConstants._SUCCESS:\n case chaptersService.getChaptersForStudents.name + apiConstants._SUCCESS:\n case chaptersService.getChaptersAsTutor.name + apiConstants._SUCCESS :\n let chaptersList = []\n if (action.data?.meta?.current_page === 1) {\n chaptersList = action.data?.chapters\n } else {\n chaptersList = state.chaptersList.concat(action.data?.chapters)\n }\n return {\n ...state,\n chaptersList: chaptersList\n }\n case chaptersService.newChapter.name + apiConstants._SUCCESS:\n return {\n ...state,\n chaptersList: [action.data, ...state.chaptersList]\n }\n\n default:\n return state\n }\n}\n","import Constants from \"expo-constants\";\nimport {IS_WEB} from \"@common/utils/mobileUtils\";\n\nexport const apiConstants = {\n _IDLE: \"_IDLE\",\n _REQUEST: \"_REQUEST\",\n _SUCCESS: \"_SUCCESS\",\n _FAILURE: \"_FAILURE\",\n NETWORK_ON: \"NETWORK_ON\",\n NETWORK_OFF: \"NETWORK_OFF\",\n};\n\nconst API_URLS = {\n // development: \"http://10.170.3.29:8000\",\n development: \"http://192.168.98.5:8000\",\n integration: \"https://api-integration.masteur.com\",\n staging: \"https://api-staging.masteur.com\",\n production: \"https://api.masteur.com\",\n}; //when modifying here for server environments, you must also modify same const in app.config.js\n\nexport const VAPOR_FILE_UPLOAD = \"VAPOR_FILE_UPLOAD\";\n\nconst apiURLWeb = \"http://localhost:8000\";\n// const apiURLWeb = \"https://8e15-165-51-68-13.ngrok-free.app\";\nconst apiURLMobile = API_URLS.development;\n\nconst devServerMode = false // change this to true to use integration servers in dev environment\n\nconst devServer = \"integration\"; // indicate here the server you want to use in dev environment (staging, integration, development)\n\nexport const API_URL = __DEV__\n ? devServerMode\n ? API_URLS[devServer]\n : IS_WEB\n ? apiURLWeb\n : apiURLMobile\n : Constants.expoConfig.extra.apiUrl;\n\nexport const cleanMediaUrl = (mediaUrl) =>\n mediaUrl?.replace(\"https://api.masteur.test\", API_URL) ?? null;\n","import { CodedError, requireOptionalNativeModule } from 'expo-modules-core';\nimport { Platform, NativeModules } from 'react-native';\nimport { AppOwnership, ExecutionEnvironment, UserInterfaceIdiom, } from './Constants.types';\nimport ExponentConstants from './ExponentConstants';\nexport { AppOwnership, ExecutionEnvironment, UserInterfaceIdiom, };\nif (!ExponentConstants) {\n console.warn(\"No native ExponentConstants module found, are you sure the expo-constants's module is linked properly?\");\n}\nconst ExpoUpdates = requireOptionalNativeModule('ExpoUpdates');\nlet rawUpdatesManifest = null;\n// If expo-updates defines a non-empty manifest, prefer that one\nif (ExpoUpdates) {\n let updatesManifest;\n if (ExpoUpdates.manifest) {\n updatesManifest = ExpoUpdates.manifest;\n }\n else if (ExpoUpdates.manifestString) {\n updatesManifest = JSON.parse(ExpoUpdates.manifestString);\n }\n if (updatesManifest && Object.keys(updatesManifest).length > 0) {\n rawUpdatesManifest = updatesManifest;\n }\n}\n// If dev-launcher defines a non-empty manifest, prefer that one\nlet rawDevLauncherManifest = null;\nif (NativeModules.EXDevLauncher) {\n let devLauncherManifest;\n if (NativeModules.EXDevLauncher.manifestString) {\n devLauncherManifest = JSON.parse(NativeModules.EXDevLauncher.manifestString);\n }\n if (devLauncherManifest && Object.keys(devLauncherManifest).length > 0) {\n rawDevLauncherManifest = devLauncherManifest;\n }\n}\n// Fall back to ExponentConstants.manifest if we don't have one from Updates\nlet rawAppConfig = null;\nif (ExponentConstants && ExponentConstants.manifest) {\n const appConfig = ExponentConstants.manifest;\n // On Android we pass the manifest in JSON form so this step is necessary\n if (typeof appConfig === 'string') {\n rawAppConfig = JSON.parse(appConfig);\n }\n else {\n rawAppConfig = appConfig;\n }\n}\nlet rawManifest = rawUpdatesManifest ?? rawDevLauncherManifest ?? rawAppConfig;\nconst { name, appOwnership, ...nativeConstants } = (ExponentConstants || {});\nconst constants = {\n ...nativeConstants,\n // Ensure this is null in bare workflow\n appOwnership: appOwnership ?? null,\n};\nObject.defineProperties(constants, {\n /**\n * Use `manifest` property by default.\n * This property is only used for internal purposes.\n * It behaves similarly to the original one, but suppresses warning upon no manifest available.\n * `expo-asset` uses it to prevent users from seeing mentioned warning.\n */\n __unsafeNoWarnManifest: {\n get() {\n const maybeManifest = getManifest(true);\n if (!maybeManifest || !isEmbeddedManifest(maybeManifest)) {\n return null;\n }\n return maybeManifest;\n },\n enumerable: false,\n },\n __unsafeNoWarnManifest2: {\n get() {\n const maybeManifest = getManifest(true);\n if (!maybeManifest || !isExpoUpdatesManifest(maybeManifest)) {\n return null;\n }\n return maybeManifest;\n },\n enumerable: false,\n },\n manifest: {\n get() {\n const maybeManifest = getManifest();\n if (!maybeManifest || !isEmbeddedManifest(maybeManifest)) {\n return null;\n }\n return maybeManifest;\n },\n enumerable: true,\n },\n manifest2: {\n get() {\n const maybeManifest = getManifest();\n if (!maybeManifest || !isExpoUpdatesManifest(maybeManifest)) {\n return null;\n }\n return maybeManifest;\n },\n enumerable: true,\n },\n expoConfig: {\n get() {\n const maybeManifest = getManifest(true);\n if (!maybeManifest) {\n return null;\n }\n // if running an embedded update, maybeManifest is a EmbeddedManifest which doesn't have\n // the expo config. Instead, the embedded expo-constants app.config should be used.\n if (ExpoUpdates && ExpoUpdates.isEmbeddedLaunch) {\n return rawAppConfig;\n }\n if (isExpoUpdatesManifest(maybeManifest)) {\n return maybeManifest.extra?.expoClient ?? null;\n }\n else if (isEmbeddedManifest(maybeManifest)) {\n return maybeManifest;\n }\n return null;\n },\n enumerable: true,\n },\n expoGoConfig: {\n get() {\n const maybeManifest = getManifest(true);\n if (!maybeManifest) {\n return null;\n }\n if (isExpoUpdatesManifest(maybeManifest)) {\n return maybeManifest.extra?.expoGo ?? null;\n }\n else if (isEmbeddedManifest(maybeManifest)) {\n return maybeManifest;\n }\n return null;\n },\n enumerable: true,\n },\n easConfig: {\n get() {\n const maybeManifest = getManifest(true);\n if (!maybeManifest) {\n return null;\n }\n if (isExpoUpdatesManifest(maybeManifest)) {\n return maybeManifest.extra?.eas ?? null;\n }\n else if (isEmbeddedManifest(maybeManifest)) {\n return maybeManifest;\n }\n return null;\n },\n enumerable: true,\n },\n __rawManifest_TEST: {\n get() {\n return rawManifest;\n },\n set(value) {\n rawManifest = value;\n },\n enumerable: false,\n },\n});\nfunction isEmbeddedManifest(manifest) {\n return !isExpoUpdatesManifest(manifest);\n}\nfunction isExpoUpdatesManifest(manifest) {\n return 'metadata' in manifest;\n}\nfunction getManifest(suppressWarning = false) {\n if (!rawManifest) {\n const invalidManifestType = rawManifest === null ? 'null' : 'undefined';\n if (nativeConstants.executionEnvironment === ExecutionEnvironment.Bare &&\n Platform.OS !== 'web') {\n if (!suppressWarning) {\n console.warn(`Constants.manifest is ${invalidManifestType} because the embedded app.config could not be read. Ensure that you have installed the expo-constants build scripts if you need to read from Constants.manifest.`);\n }\n }\n else if (nativeConstants.executionEnvironment === ExecutionEnvironment.StoreClient ||\n nativeConstants.executionEnvironment === ExecutionEnvironment.Standalone) {\n // If we somehow get here, this is a truly exceptional state to be in.\n // Constants.manifest should *always* be defined in those contexts.\n throw new CodedError('ERR_CONSTANTS_MANIFEST_UNAVAILABLE', `Constants.manifest is ${invalidManifestType}, must be an object.`);\n }\n }\n return rawManifest;\n}\nexport default constants;\n//# sourceMappingURL=Constants.js.map","export var AppOwnership;\n(function (AppOwnership) {\n /**\n * The experience is running inside of the Expo Go app.\n */\n AppOwnership[\"Expo\"] = \"expo\";\n})(AppOwnership || (AppOwnership = {}));\n// @docsMissing\nexport var ExecutionEnvironment;\n(function (ExecutionEnvironment) {\n ExecutionEnvironment[\"Bare\"] = \"bare\";\n ExecutionEnvironment[\"Standalone\"] = \"standalone\";\n ExecutionEnvironment[\"StoreClient\"] = \"storeClient\";\n})(ExecutionEnvironment || (ExecutionEnvironment = {}));\n// @needsAudit\n/**\n * Current supported values are `handset`, `tablet`, `desktop` and `tv`. CarPlay will show up\n * as `unsupported`.\n */\nexport var UserInterfaceIdiom;\n(function (UserInterfaceIdiom) {\n UserInterfaceIdiom[\"Handset\"] = \"handset\";\n UserInterfaceIdiom[\"Tablet\"] = \"tablet\";\n UserInterfaceIdiom[\"Desktop\"] = \"desktop\";\n UserInterfaceIdiom[\"TV\"] = \"tv\";\n UserInterfaceIdiom[\"Unsupported\"] = \"unsupported\";\n})(UserInterfaceIdiom || (UserInterfaceIdiom = {}));\n//# sourceMappingURL=Constants.types.js.map","import { ExecutionEnvironment } from './Constants.types';\nconst _sessionId = (Date.now() + '-' + Math.floor(Math.random() * 1000000000)).toString();\nfunction getBrowserName() {\n if (typeof navigator !== 'undefined' && typeof navigator.userAgent === 'string') {\n const agent = navigator.userAgent.toLowerCase();\n if (agent.includes('edge')) {\n return 'Edge';\n }\n else if (agent.includes('edg')) {\n return 'Chromium Edge';\n }\n else if (agent.includes('opr') && !!window['opr']) {\n return 'Opera';\n }\n else if (agent.includes('chrome') && !!window['chrome']) {\n return 'Chrome';\n }\n else if (agent.includes('trident')) {\n return 'IE';\n }\n else if (agent.includes('firefox')) {\n return 'Firefox';\n }\n else if (agent.includes('safari')) {\n return 'Safari';\n }\n }\n return undefined;\n}\nexport default {\n get appOwnership() {\n return null;\n },\n get executionEnvironment() {\n return ExecutionEnvironment.Bare;\n },\n get sessionId() {\n return _sessionId;\n },\n get isHeadless() {\n if (typeof navigator === 'undefined')\n return true;\n return /\\bHeadlessChrome\\//.test(navigator.userAgent);\n },\n get expoVersion() {\n return this.manifest.sdkVersion || null;\n },\n get linkingUri() {\n if (typeof location !== 'undefined') {\n // On native this is `exp://`\n // On web we should use the protocol and hostname (location.origin)\n return location.origin;\n }\n else {\n return '';\n }\n },\n get expoRuntimeVersion() {\n return this.expoVersion;\n },\n get deviceName() {\n return getBrowserName();\n },\n get systemFonts() {\n // TODO: Bacon: Maybe possible.\n return [];\n },\n get statusBarHeight() {\n return 0;\n },\n get deviceYearClass() {\n // TODO: Bacon: The android version isn't very accurate either, maybe we could try and guess this value.\n return null;\n },\n get manifest() {\n // This is defined by @expo/webpack-config or babel-preset-expo.\n // If your site is bundled with a different config then you may not have access to the app.json automatically.\n return process.env.APP_MANIFEST || {};\n },\n get manifest2() {\n return null;\n },\n get experienceUrl() {\n if (typeof location !== 'undefined') {\n return location.origin;\n }\n else {\n return '';\n }\n },\n get debugMode() {\n return __DEV__;\n },\n async getWebViewUserAgentAsync() {\n if (typeof navigator !== 'undefined') {\n return navigator.userAgent;\n }\n else {\n return null;\n }\n },\n};\n//# sourceMappingURL=ExponentConstants.web.js.map","import {Dimensions, Platform} from \"react-native\";\nimport {createContext} from \"react\";\nimport DeviceInfo from \"react-native-device-info\";\n\nexport const WINDOW_WIDTH = Platform.OS !== 'web' ? Dimensions.get('window').width : Dimensions.get('window').width > 800 ? Dimensions.get('window').width * 2 / 3 : Dimensions.get('window').width;\nexport const WINDOW_HEIGHT = Dimensions.get('window').height;\n\nexport const IS_WEB = Platform.OS === \"web\"\nexport const IS_CALLKEEP_COMPATIBLE = !IS_WEB // && (Platform.OS === \"ios\" || !!DeviceInfo.getCarrier())\nexport const IS_BIG = Dimensions.get('window').width > 800\nexport const isWebMobile = () => {\n\n let details = navigator.userAgent;\n let regexp = /android|iphone|kindle|ipad/i;\n\n return regexp.test(details)\n}\nexport const isSafari = () => {\n const userAgent = navigator.userAgent.toLowerCase();\n return userAgent.includes('safari') && !userAgent.includes('chrome');\n};\n\nexport const isChrome = () => {\n const userAgent = navigator.userAgent.toLowerCase();\n return userAgent.includes('chrome') && !userAgent.includes('opr') && !userAgent.includes('edg');\n};\n\nexport const NavigationRefContext = createContext()\n\nexport const DimensionsContext = createContext()\nexport const isMobile = () => {\n\n let details = navigator.userAgent;\n let regexp = /android|iphone|kindle|ipad/i;\n\n return regexp.test(details)\n}","import { useCallback, useEffect, useState } from 'react';\nimport { Dimensions, NativeEventEmitter, NativeModules, Platform } from 'react-native';\nimport { useOnEvent, useOnMount } from './internal/asyncHookWrappers';\nimport devicesWithDynamicIsland from './internal/devicesWithDynamicIsland';\nimport devicesWithNotch from './internal/devicesWithNotch';\nimport RNDeviceInfo from './internal/nativeInterface';\nimport { getSupportedPlatformInfoAsync, getSupportedPlatformInfoFunctions, getSupportedPlatformInfoSync } from './internal/supported-platform-info';\nexport const [getUniqueId, getUniqueIdSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'uniqueId',\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.getUniqueId(),\n syncGetter: () => RNDeviceInfo.getUniqueIdSync(),\n defaultValue: 'unknown'\n});\nlet uniqueId;\nexport async function syncUniqueId() {\n if (Platform.OS === 'ios') {\n uniqueId = await RNDeviceInfo.syncUniqueId();\n } else {\n uniqueId = await getUniqueId();\n }\n\n return uniqueId;\n}\nexport const [getInstanceId, getInstanceIdSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'instanceId',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getInstanceId(),\n syncGetter: () => RNDeviceInfo.getInstanceIdSync(),\n defaultValue: 'unknown'\n});\nexport const [getSerialNumber, getSerialNumberSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'serialNumber',\n supportedPlatforms: ['android', 'windows'],\n getter: () => RNDeviceInfo.getSerialNumber(),\n syncGetter: () => RNDeviceInfo.getSerialNumberSync(),\n defaultValue: 'unknown'\n});\nexport const [getAndroidId, getAndroidIdSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'androidId',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getAndroidId(),\n syncGetter: () => RNDeviceInfo.getAndroidIdSync(),\n defaultValue: 'unknown'\n});\nexport const [getIpAddress, getIpAddressSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.getIpAddress(),\n syncGetter: () => RNDeviceInfo.getIpAddressSync(),\n defaultValue: 'unknown'\n});\nexport const [isCameraPresent, isCameraPresentSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'windows', 'web'],\n getter: () => RNDeviceInfo.isCameraPresent(),\n syncGetter: () => RNDeviceInfo.isCameraPresentSync(),\n defaultValue: false\n});\nexport async function getMacAddress() {\n if (Platform.OS === 'android') {\n return RNDeviceInfo.getMacAddress();\n } else if (Platform.OS === 'ios') {\n return '02:00:00:00:00:00';\n }\n\n return 'unknown';\n}\nexport function getMacAddressSync() {\n if (Platform.OS === 'android') {\n return RNDeviceInfo.getMacAddressSync();\n } else if (Platform.OS === 'ios') {\n return '02:00:00:00:00:00';\n }\n\n return 'unknown';\n}\nexport const getDeviceId = () => getSupportedPlatformInfoSync({\n defaultValue: 'unknown',\n memoKey: 'deviceId',\n getter: () => RNDeviceInfo.deviceId,\n supportedPlatforms: ['android', 'ios', 'windows']\n});\nexport const [getManufacturer, getManufacturerSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'manufacturer',\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => Platform.OS == 'ios' ? Promise.resolve('Apple') : RNDeviceInfo.getSystemManufacturer(),\n syncGetter: () => Platform.OS == 'ios' ? 'Apple' : RNDeviceInfo.getSystemManufacturerSync(),\n defaultValue: 'unknown'\n});\nexport const getModel = () => getSupportedPlatformInfoSync({\n memoKey: 'model',\n defaultValue: 'unknown',\n supportedPlatforms: ['ios', 'android', 'windows'],\n getter: () => RNDeviceInfo.model\n});\nexport const getBrand = () => getSupportedPlatformInfoSync({\n memoKey: 'brand',\n supportedPlatforms: ['android', 'ios', 'windows'],\n defaultValue: 'unknown',\n getter: () => RNDeviceInfo.brand\n});\nexport const getSystemName = () => getSupportedPlatformInfoSync({\n defaultValue: 'unknown',\n supportedPlatforms: ['ios', 'android', 'windows'],\n memoKey: 'systemName',\n getter: () => Platform.select({\n ios: RNDeviceInfo.systemName,\n android: 'Android',\n windows: 'Windows',\n default: 'unknown'\n })\n});\nexport const getSystemVersion = () => getSupportedPlatformInfoSync({\n defaultValue: 'unknown',\n getter: () => RNDeviceInfo.systemVersion,\n supportedPlatforms: ['android', 'ios', 'windows'],\n memoKey: 'systemVersion'\n});\nexport const [getBuildId, getBuildIdSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'buildId',\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.getBuildId(),\n syncGetter: () => RNDeviceInfo.getBuildIdSync(),\n defaultValue: 'unknown'\n});\nexport const [getApiLevel, getApiLevelSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'apiLevel',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getApiLevel(),\n syncGetter: () => RNDeviceInfo.getApiLevelSync(),\n defaultValue: -1\n});\nexport const getBundleId = () => getSupportedPlatformInfoSync({\n memoKey: 'bundleId',\n supportedPlatforms: ['android', 'ios', 'windows'],\n defaultValue: 'unknown',\n getter: () => RNDeviceInfo.bundleId\n});\nexport const [getInstallerPackageName, getInstallerPackageNameSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'installerPackageName',\n supportedPlatforms: ['android', 'windows', 'ios'],\n getter: () => RNDeviceInfo.getInstallerPackageName(),\n syncGetter: () => RNDeviceInfo.getInstallerPackageNameSync(),\n defaultValue: 'unknown'\n});\nexport const getApplicationName = () => getSupportedPlatformInfoSync({\n memoKey: 'appName',\n defaultValue: 'unknown',\n getter: () => RNDeviceInfo.appName,\n supportedPlatforms: ['android', 'ios', 'windows']\n});\nexport const getBuildNumber = () => getSupportedPlatformInfoSync({\n memoKey: 'buildNumber',\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.buildNumber,\n defaultValue: 'unknown'\n});\nexport const getVersion = () => getSupportedPlatformInfoSync({\n memoKey: 'version',\n defaultValue: 'unknown',\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.appVersion\n});\nexport function getReadableVersion() {\n return getVersion() + '.' + getBuildNumber();\n}\nexport const [getDeviceName, getDeviceNameSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.getDeviceName(),\n syncGetter: () => RNDeviceInfo.getDeviceNameSync(),\n defaultValue: 'unknown'\n});\nexport const [getUsedMemory, getUsedMemorySync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows', 'web'],\n getter: () => RNDeviceInfo.getUsedMemory(),\n syncGetter: () => RNDeviceInfo.getUsedMemorySync(),\n defaultValue: -1\n});\nexport const getUserAgent = () => getSupportedPlatformInfoAsync({\n memoKey: 'userAgent',\n defaultValue: 'unknown',\n supportedPlatforms: ['android', 'ios', 'web'],\n getter: () => RNDeviceInfo.getUserAgent()\n});\nexport const getUserAgentSync = () => getSupportedPlatformInfoSync({\n memoKey: 'userAgentSync',\n defaultValue: 'unknown',\n supportedPlatforms: ['android', 'web'],\n getter: () => RNDeviceInfo.getUserAgentSync()\n});\nexport const [getFontScale, getFontScaleSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.getFontScale(),\n syncGetter: () => RNDeviceInfo.getFontScaleSync(),\n defaultValue: -1\n});\nexport const [getBootloader, getBootloaderSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'bootloader',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getBootloader(),\n syncGetter: () => RNDeviceInfo.getBootloaderSync(),\n defaultValue: 'unknown'\n});\nexport const [getDevice, getDeviceSync] = getSupportedPlatformInfoFunctions({\n getter: () => RNDeviceInfo.getDevice(),\n syncGetter: () => RNDeviceInfo.getDeviceSync(),\n defaultValue: 'unknown',\n memoKey: 'device',\n supportedPlatforms: ['android']\n});\nexport const [getDisplay, getDisplaySync] = getSupportedPlatformInfoFunctions({\n memoKey: 'display',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getDisplay(),\n syncGetter: () => RNDeviceInfo.getDisplaySync(),\n defaultValue: 'unknown'\n});\nexport const [getFingerprint, getFingerprintSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'fingerprint',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getFingerprint(),\n syncGetter: () => RNDeviceInfo.getFingerprintSync(),\n defaultValue: 'unknown'\n});\nexport const [getHardware, getHardwareSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'hardware',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getHardware(),\n syncGetter: () => RNDeviceInfo.getHardwareSync(),\n defaultValue: 'unknown'\n});\nexport const [getHost, getHostSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'host',\n supportedPlatforms: ['android', 'windows'],\n getter: () => RNDeviceInfo.getHost(),\n syncGetter: () => RNDeviceInfo.getHostSync(),\n defaultValue: 'unknown'\n});\nexport const [getHostNames, getHostNamesSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'hostNames',\n supportedPlatforms: ['windows'],\n getter: () => RNDeviceInfo.getHostNames(),\n syncGetter: () => RNDeviceInfo.getHostNamesSync(),\n defaultValue: []\n});\nexport const [getProduct, getProductSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'product',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getProduct(),\n syncGetter: () => RNDeviceInfo.getProductSync(),\n defaultValue: 'unknown'\n});\nexport const [getTags, getTagsSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'tags',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getTags(),\n syncGetter: () => RNDeviceInfo.getTagsSync(),\n defaultValue: 'unknown'\n});\nexport const [getType, getTypeSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'type',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getType(),\n syncGetter: () => RNDeviceInfo.getTypeSync(),\n defaultValue: 'unknown'\n});\nexport const [getBaseOs, getBaseOsSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'baseOs',\n supportedPlatforms: ['android', 'web', 'windows'],\n getter: () => RNDeviceInfo.getBaseOs(),\n syncGetter: () => RNDeviceInfo.getBaseOsSync(),\n defaultValue: 'unknown'\n});\nexport const [getPreviewSdkInt, getPreviewSdkIntSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'previewSdkInt',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getPreviewSdkInt(),\n syncGetter: () => RNDeviceInfo.getPreviewSdkIntSync(),\n defaultValue: -1\n});\nexport const [getSecurityPatch, getSecurityPatchSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'securityPatch',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getSecurityPatch(),\n syncGetter: () => RNDeviceInfo.getSecurityPatchSync(),\n defaultValue: 'unknown'\n});\nexport const [getCodename, getCodenameSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'codeName',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getCodename(),\n syncGetter: () => RNDeviceInfo.getCodenameSync(),\n defaultValue: 'unknown'\n});\nexport const [getIncremental, getIncrementalSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'incremental',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getIncremental(),\n syncGetter: () => RNDeviceInfo.getIncrementalSync(),\n defaultValue: 'unknown'\n});\nexport const [isEmulator, isEmulatorSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'emulator',\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.isEmulator(),\n syncGetter: () => RNDeviceInfo.isEmulatorSync(),\n defaultValue: false\n});\nexport const isTablet = () => getSupportedPlatformInfoSync({\n defaultValue: false,\n supportedPlatforms: ['android', 'ios', 'windows'],\n memoKey: 'tablet',\n getter: () => RNDeviceInfo.isTablet\n});\nexport const isLowRamDevice = () => getSupportedPlatformInfoSync({\n defaultValue: false,\n supportedPlatforms: ['android'],\n memoKey: 'lowRam',\n getter: () => RNDeviceInfo.isLowRamDevice\n});\nexport const isDisplayZoomed = () => getSupportedPlatformInfoSync({\n defaultValue: false,\n supportedPlatforms: ['ios'],\n memoKey: 'zoomed',\n getter: () => RNDeviceInfo.isDisplayZoomed\n});\nexport const [isPinOrFingerprintSet, isPinOrFingerprintSetSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.isPinOrFingerprintSet(),\n syncGetter: () => RNDeviceInfo.isPinOrFingerprintSetSync(),\n defaultValue: false\n});\nlet notch;\nexport function hasNotch() {\n if (notch === undefined) {\n let _brand = getBrand();\n\n let _model = getModel();\n\n notch = devicesWithNotch.findIndex(item => item.brand.toLowerCase() === _brand.toLowerCase() && item.model.toLowerCase() === _model.toLowerCase()) !== -1;\n }\n\n return notch;\n}\nlet dynamicIsland;\nexport function hasDynamicIsland() {\n if (dynamicIsland === undefined) {\n let _brand = getBrand();\n\n let _model = getModel();\n\n dynamicIsland = devicesWithDynamicIsland.findIndex(item => item.brand.toLowerCase() === _brand.toLowerCase() && item.model.toLowerCase() === _model.toLowerCase()) !== -1;\n }\n\n return dynamicIsland;\n}\nexport const [hasGms, hasGmsSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.hasGms(),\n syncGetter: () => RNDeviceInfo.hasGmsSync(),\n defaultValue: false\n});\nexport const [hasHms, hasHmsSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.hasHms(),\n syncGetter: () => RNDeviceInfo.hasHmsSync(),\n defaultValue: false\n});\nexport const [getFirstInstallTime, getFirstInstallTimeSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'firstInstallTime',\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.getFirstInstallTime(),\n syncGetter: () => RNDeviceInfo.getFirstInstallTimeSync(),\n defaultValue: -1\n});\nexport const [getInstallReferrer, getInstallReferrerSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'installReferrer',\n supportedPlatforms: ['android', 'windows', 'web'],\n getter: () => RNDeviceInfo.getInstallReferrer(),\n syncGetter: () => RNDeviceInfo.getInstallReferrerSync(),\n defaultValue: 'unknown'\n});\nexport const [getLastUpdateTime, getLastUpdateTimeSync] = getSupportedPlatformInfoFunctions({\n memoKey: 'lastUpdateTime',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getLastUpdateTime(),\n syncGetter: () => RNDeviceInfo.getLastUpdateTimeSync(),\n defaultValue: -1\n});\nexport const [getCarrier, getCarrierSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios'],\n getter: () => RNDeviceInfo.getCarrier(),\n syncGetter: () => RNDeviceInfo.getCarrierSync(),\n defaultValue: 'unknown'\n});\nexport const [getTotalMemory, getTotalMemorySync] = getSupportedPlatformInfoFunctions({\n memoKey: 'totalMemory',\n supportedPlatforms: ['android', 'ios', 'windows', 'web'],\n getter: () => RNDeviceInfo.getTotalMemory(),\n syncGetter: () => RNDeviceInfo.getTotalMemorySync(),\n defaultValue: -1\n});\nexport const [getMaxMemory, getMaxMemorySync] = getSupportedPlatformInfoFunctions({\n memoKey: 'maxMemory',\n supportedPlatforms: ['android', 'windows', 'web'],\n getter: () => RNDeviceInfo.getMaxMemory(),\n syncGetter: () => RNDeviceInfo.getMaxMemorySync(),\n defaultValue: -1\n});\nexport const [getTotalDiskCapacity, getTotalDiskCapacitySync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows', 'web'],\n getter: () => RNDeviceInfo.getTotalDiskCapacity(),\n syncGetter: () => RNDeviceInfo.getTotalDiskCapacitySync(),\n defaultValue: -1\n});\nexport async function getTotalDiskCapacityOld() {\n if (Platform.OS === 'android') {\n return RNDeviceInfo.getTotalDiskCapacityOld();\n }\n\n if (Platform.OS === 'ios' || Platform.OS === 'windows' || Platform.OS === 'web') {\n return getTotalDiskCapacity();\n }\n\n return -1;\n}\nexport function getTotalDiskCapacityOldSync() {\n if (Platform.OS === 'android') {\n return RNDeviceInfo.getTotalDiskCapacityOldSync();\n }\n\n if (Platform.OS === 'ios' || Platform.OS === 'windows' || Platform.OS === 'web') {\n return getTotalDiskCapacitySync();\n }\n\n return -1;\n}\nexport const [getFreeDiskStorage, getFreeDiskStorageSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows', 'web'],\n getter: (storageType = 'total') => {\n if (Platform.OS === 'ios') {\n return RNDeviceInfo.getFreeDiskStorage(storageType);\n } else {\n return RNDeviceInfo.getFreeDiskStorage();\n }\n },\n syncGetter: (storageType = 'total') => {\n if (Platform.OS === 'ios') {\n return RNDeviceInfo.getFreeDiskStorageSync(storageType);\n } else {\n return RNDeviceInfo.getFreeDiskStorageSync();\n }\n },\n defaultValue: -1\n});\nexport async function getFreeDiskStorageOld() {\n if (Platform.OS === 'android') {\n return RNDeviceInfo.getFreeDiskStorageOld();\n }\n\n if (Platform.OS === 'ios' || Platform.OS === 'windows' || Platform.OS === 'web') {\n return getFreeDiskStorage();\n }\n\n return -1;\n}\nexport function getFreeDiskStorageOldSync() {\n if (Platform.OS === 'android') {\n return RNDeviceInfo.getFreeDiskStorageOldSync();\n }\n\n if (Platform.OS === 'ios' || Platform.OS === 'windows' || Platform.OS === 'web') {\n return getFreeDiskStorageSync();\n }\n\n return -1;\n}\nexport const [getBatteryLevel, getBatteryLevelSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows', 'web'],\n getter: () => RNDeviceInfo.getBatteryLevel(),\n syncGetter: () => RNDeviceInfo.getBatteryLevelSync(),\n defaultValue: -1\n});\nexport const [getPowerState, getPowerStateSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['ios', 'android', 'windows', 'web'],\n getter: () => RNDeviceInfo.getPowerState(),\n syncGetter: () => RNDeviceInfo.getPowerStateSync(),\n defaultValue: {}\n});\nexport const [isBatteryCharging, isBatteryChargingSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'windows', 'web'],\n getter: () => RNDeviceInfo.isBatteryCharging(),\n syncGetter: () => RNDeviceInfo.isBatteryChargingSync(),\n defaultValue: false\n});\nexport async function isLandscape() {\n return Promise.resolve(isLandscapeSync());\n}\nexport function isLandscapeSync() {\n const {\n height,\n width\n } = Dimensions.get('window');\n return width >= height;\n}\nexport const [isAirplaneMode, isAirplaneModeSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'web'],\n getter: () => RNDeviceInfo.isAirplaneMode(),\n syncGetter: () => RNDeviceInfo.isAirplaneModeSync(),\n defaultValue: false\n});\nexport const getDeviceType = () => {\n return getSupportedPlatformInfoSync({\n memoKey: 'deviceType',\n supportedPlatforms: ['android', 'ios', 'windows'],\n defaultValue: 'unknown',\n getter: () => RNDeviceInfo.deviceType\n });\n};\nexport const getDeviceTypeSync = () => {\n return getSupportedPlatformInfoSync({\n memoKey: 'deviceType',\n supportedPlatforms: ['android', 'ios', 'windows'],\n defaultValue: 'unknown',\n getter: () => RNDeviceInfo.deviceType\n });\n};\nexport const [supportedAbis, supportedAbisSync] = getSupportedPlatformInfoFunctions({\n memoKey: '_supportedAbis',\n supportedPlatforms: ['android', 'ios', 'windows'],\n getter: () => RNDeviceInfo.getSupportedAbis(),\n syncGetter: () => RNDeviceInfo.getSupportedAbisSync(),\n defaultValue: []\n});\nexport const [supported32BitAbis, supported32BitAbisSync] = getSupportedPlatformInfoFunctions({\n memoKey: '_supported32BitAbis',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getSupported32BitAbis(),\n syncGetter: () => RNDeviceInfo.getSupported32BitAbisSync(),\n defaultValue: []\n});\nexport const [supported64BitAbis, supported64BitAbisSync] = getSupportedPlatformInfoFunctions({\n memoKey: '_supported64BitAbis',\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getSupported64BitAbis(),\n syncGetter: () => RNDeviceInfo.getSupported64BitAbisSync(),\n defaultValue: []\n});\nexport async function hasSystemFeature(feature) {\n if (Platform.OS === 'android') {\n return RNDeviceInfo.hasSystemFeature(feature);\n }\n\n return false;\n}\nexport function hasSystemFeatureSync(feature) {\n if (Platform.OS === 'android') {\n return RNDeviceInfo.hasSystemFeatureSync(feature);\n }\n\n return false;\n}\nexport function isLowBatteryLevel(level) {\n if (Platform.OS === 'android') {\n return level < 0.15;\n }\n\n return level < 0.2;\n}\nexport const [getSystemAvailableFeatures, getSystemAvailableFeaturesSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getSystemAvailableFeatures(),\n syncGetter: () => RNDeviceInfo.getSystemAvailableFeaturesSync(),\n defaultValue: []\n});\nexport const [isLocationEnabled, isLocationEnabledSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios', 'web'],\n getter: () => RNDeviceInfo.isLocationEnabled(),\n syncGetter: () => RNDeviceInfo.isLocationEnabledSync(),\n defaultValue: false\n});\nexport const [isHeadphonesConnected, isHeadphonesConnectedSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios'],\n getter: () => RNDeviceInfo.isHeadphonesConnected(),\n syncGetter: () => RNDeviceInfo.isHeadphonesConnectedSync(),\n defaultValue: false\n});\nexport const [isWiredHeadphonesConnected, isWiredHeadphonesConnectedSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios'],\n getter: () => RNDeviceInfo.isWiredHeadphonesConnected(),\n syncGetter: () => RNDeviceInfo.isWiredHeadphonesConnectedSync(),\n defaultValue: false\n});\nexport const [isBluetoothHeadphonesConnected, isBluetoothHeadphonesConnectedSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios'],\n getter: () => RNDeviceInfo.isBluetoothHeadphonesConnected(),\n syncGetter: () => RNDeviceInfo.isBluetoothHeadphonesConnectedSync(),\n defaultValue: false\n});\nexport const [isMouseConnected, isMouseConnectedSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['windows'],\n getter: () => RNDeviceInfo.isMouseConnected(),\n syncGetter: () => RNDeviceInfo.isMouseConnectedSync(),\n defaultValue: false\n});\nexport const [isKeyboardConnected, isKeyboardConnectedSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['windows'],\n getter: () => RNDeviceInfo.isKeyboardConnected(),\n syncGetter: () => RNDeviceInfo.isKeyboardConnectedSync(),\n defaultValue: false\n});\nexport const [getSupportedMediaTypeList, getSupportedMediaTypeListSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android'],\n getter: () => RNDeviceInfo.getSupportedMediaTypeList(),\n syncGetter: () => RNDeviceInfo.getSupportedMediaTypeListSync(),\n defaultValue: []\n});\nexport const isTabletMode = () => getSupportedPlatformInfoAsync({\n supportedPlatforms: ['windows'],\n getter: () => RNDeviceInfo.isTabletMode(),\n defaultValue: false\n});\nexport const [getAvailableLocationProviders, getAvailableLocationProvidersSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['android', 'ios'],\n getter: () => RNDeviceInfo.getAvailableLocationProviders(),\n syncGetter: () => RNDeviceInfo.getAvailableLocationProvidersSync(),\n defaultValue: {}\n});\nexport const [getBrightness, getBrightnessSync] = getSupportedPlatformInfoFunctions({\n supportedPlatforms: ['ios'],\n getter: () => RNDeviceInfo.getBrightness(),\n syncGetter: () => RNDeviceInfo.getBrightnessSync(),\n defaultValue: -1\n});\nexport async function getDeviceToken() {\n if (Platform.OS === 'ios') {\n return RNDeviceInfo.getDeviceToken();\n }\n\n return 'unknown';\n}\nconst deviceInfoEmitter = new NativeEventEmitter(NativeModules.RNDeviceInfo);\nexport function useBatteryLevel() {\n const [batteryLevel, setBatteryLevel] = useState(null);\n useEffect(() => {\n const setInitialValue = async () => {\n const initialValue = await getBatteryLevel();\n setBatteryLevel(initialValue);\n };\n\n const onChange = level => {\n setBatteryLevel(level);\n };\n\n setInitialValue();\n const subscription = deviceInfoEmitter.addListener('RNDeviceInfo_batteryLevelDidChange', onChange);\n return () => subscription.remove();\n }, []);\n return batteryLevel;\n}\nexport function useBatteryLevelIsLow() {\n const [batteryLevelIsLow, setBatteryLevelIsLow] = useState(null);\n useEffect(() => {\n const setInitialValue = async () => {\n const initialValue = await getBatteryLevel();\n isLowBatteryLevel(initialValue) && setBatteryLevelIsLow(initialValue);\n };\n\n setInitialValue();\n\n const onChange = level => {\n setBatteryLevelIsLow(level);\n };\n\n const subscription = deviceInfoEmitter.addListener('RNDeviceInfo_batteryLevelIsLow', onChange);\n return () => subscription.remove();\n }, []);\n return batteryLevelIsLow;\n}\nexport function usePowerState() {\n const [powerState, setPowerState] = useState({});\n useEffect(() => {\n const setInitialValue = async () => {\n const initialValue = await getPowerState();\n setPowerState(initialValue);\n };\n\n const onChange = state => {\n setPowerState(state);\n };\n\n setInitialValue();\n const subscription = deviceInfoEmitter.addListener('RNDeviceInfo_powerStateDidChange', onChange);\n return () => subscription.remove();\n }, []);\n return powerState;\n}\nexport function useIsHeadphonesConnected() {\n return useOnEvent('RNDeviceInfo_headphoneConnectionDidChange', isHeadphonesConnected, false);\n}\nexport function useIsWiredHeadphonesConnected() {\n return useOnEvent('RNDeviceInfo_headphoneWiredConnectionDidChange', isWiredHeadphonesConnected, false);\n}\nexport function useIsBluetoothHeadphonesConnected() {\n return useOnEvent('RNDeviceInfo_headphoneBluetoothConnectionDidChange', isBluetoothHeadphonesConnected, false);\n}\nexport function useFirstInstallTime() {\n return useOnMount(getFirstInstallTime, -1);\n}\nexport function useDeviceName() {\n return useOnMount(getDeviceName, 'unknown');\n}\nexport function useHasSystemFeature(feature) {\n const asyncGetter = useCallback(() => hasSystemFeature(feature), [feature]);\n return useOnMount(asyncGetter, false);\n}\nexport function useIsEmulator() {\n return useOnMount(isEmulator, false);\n}\nexport function useManufacturer() {\n return useOnMount(getManufacturer, 'unknown');\n}\nexport function useBrightness() {\n const [brightness, setBrightness] = useState(null);\n useEffect(() => {\n const setInitialValue = async () => {\n const initialValue = await getBrightness();\n setBrightness(initialValue);\n };\n\n const onChange = value => {\n setBrightness(value);\n };\n\n setInitialValue();\n const subscription = deviceInfoEmitter.addListener('RNDeviceInfo_brightnessDidChange', onChange);\n return () => subscription.remove();\n }, []);\n return brightness;\n}\nconst DeviceInfo = {\n getAndroidId,\n getAndroidIdSync,\n getApiLevel,\n getApiLevelSync,\n getApplicationName,\n getAvailableLocationProviders,\n getAvailableLocationProvidersSync,\n getBaseOs,\n getBaseOsSync,\n getBatteryLevel,\n getBatteryLevelSync,\n getBootloader,\n getBootloaderSync,\n getBrand,\n getBuildId,\n getBuildIdSync,\n getBuildNumber,\n getBundleId,\n getCarrier,\n getCarrierSync,\n getCodename,\n getCodenameSync,\n getDevice,\n getDeviceId,\n getDeviceName,\n getDeviceNameSync,\n getDeviceSync,\n getDeviceToken,\n getDeviceType,\n getDisplay,\n getDisplaySync,\n getFingerprint,\n getFingerprintSync,\n getFirstInstallTime,\n getFirstInstallTimeSync,\n getFontScale,\n getFontScaleSync,\n getFreeDiskStorage,\n getFreeDiskStorageOld,\n getFreeDiskStorageSync,\n getFreeDiskStorageOldSync,\n getHardware,\n getHardwareSync,\n getHost,\n getHostSync,\n getHostNames,\n getHostNamesSync,\n getIncremental,\n getIncrementalSync,\n getInstallerPackageName,\n getInstallerPackageNameSync,\n getInstallReferrer,\n getInstallReferrerSync,\n getInstanceId,\n getInstanceIdSync,\n getIpAddress,\n getIpAddressSync,\n getLastUpdateTime,\n getLastUpdateTimeSync,\n getMacAddress,\n getMacAddressSync,\n getManufacturer,\n getManufacturerSync,\n getMaxMemory,\n getMaxMemorySync,\n getModel,\n getPowerState,\n getPowerStateSync,\n getPreviewSdkInt,\n getPreviewSdkIntSync,\n getProduct,\n getProductSync,\n getReadableVersion,\n getSecurityPatch,\n getSecurityPatchSync,\n getSerialNumber,\n getSerialNumberSync,\n getSystemAvailableFeatures,\n getSystemAvailableFeaturesSync,\n getSystemName,\n getSystemVersion,\n getTags,\n getTagsSync,\n getTotalDiskCapacity,\n getTotalDiskCapacityOld,\n getTotalDiskCapacitySync,\n getTotalDiskCapacityOldSync,\n getTotalMemory,\n getTotalMemorySync,\n getType,\n getTypeSync,\n getUniqueId,\n getUniqueIdSync,\n getUsedMemory,\n getUsedMemorySync,\n getUserAgent,\n getUserAgentSync,\n getVersion,\n getBrightness,\n getBrightnessSync,\n hasGms,\n hasGmsSync,\n hasHms,\n hasHmsSync,\n hasNotch,\n hasDynamicIsland,\n hasSystemFeature,\n hasSystemFeatureSync,\n isAirplaneMode,\n isAirplaneModeSync,\n isBatteryCharging,\n isBatteryChargingSync,\n isCameraPresent,\n isCameraPresentSync,\n isEmulator,\n isEmulatorSync,\n isHeadphonesConnected,\n isHeadphonesConnectedSync,\n isWiredHeadphonesConnected,\n isWiredHeadphonesConnectedSync,\n isBluetoothHeadphonesConnected,\n isBluetoothHeadphonesConnectedSync,\n isLandscape,\n isLandscapeSync,\n isLocationEnabled,\n isLocationEnabledSync,\n isPinOrFingerprintSet,\n isPinOrFingerprintSetSync,\n isMouseConnected,\n isMouseConnectedSync,\n isKeyboardConnected,\n isKeyboardConnectedSync,\n isTabletMode,\n isTablet,\n isLowRamDevice,\n isDisplayZoomed,\n supported32BitAbis,\n supported32BitAbisSync,\n supported64BitAbis,\n supported64BitAbisSync,\n supportedAbis,\n supportedAbisSync,\n syncUniqueId,\n useBatteryLevel,\n useBatteryLevelIsLow,\n useDeviceName,\n useFirstInstallTime,\n useHasSystemFeature,\n useIsEmulator,\n usePowerState,\n useManufacturer,\n useIsHeadphonesConnected,\n useIsWiredHeadphonesConnected,\n useIsBluetoothHeadphonesConnected,\n useBrightness,\n getSupportedMediaTypeList,\n getSupportedMediaTypeListSync\n};\nexport default DeviceInfo;\n//# sourceMappingURL=index.js.map","import { useState, useEffect, useMemo } from 'react';\nimport { NativeEventEmitter, NativeModules } from 'react-native';\n\n/**\n * simple hook wrapper for async functions for 'on-mount / componentDidMount' that only need to fired once\n * @param asyncGetter async function that 'gets' something\n * @param initialResult -1 | false | 'unknown'\n */\nexport function useOnMount(asyncGetter, initialResult) {\n const [response, setResponse] = useState({\n loading: true,\n result: initialResult\n });\n useEffect(() => {\n // async function cuz react complains if useEffect's effect param is an async function\n const getAsync = async () => {\n const result = await asyncGetter();\n setResponse({\n loading: false,\n result\n });\n };\n\n getAsync();\n }, [asyncGetter]);\n return response;\n}\nexport const deviceInfoEmitter = new NativeEventEmitter(NativeModules.RNDeviceInfo);\n/**\n * simple hook wrapper for handling events\n * @param eventName\n * @param initialValueAsyncGetter\n * @param defaultValue\n */\n\nexport function useOnEvent(eventName, initialValueAsyncGetter, defaultValue) {\n const {\n loading,\n result: initialResult\n } = useOnMount(initialValueAsyncGetter, defaultValue);\n const [result, setResult] = useState(defaultValue); // sets the result to what the intial value is on mount\n\n useEffect(() => {\n setResult(initialResult);\n }, [initialResult]); // - set up the event listener to set the result\n // - set up the clean up function to remove subscription on unmount\n\n useEffect(() => {\n const subscription = deviceInfoEmitter.addListener(eventName, setResult);\n return () => subscription.remove();\n }, [eventName]); // loading will only be true while getting the inital value. After that, it will always be false, but a new result may occur\n\n return useMemo(() => ({\n loading,\n result\n }), [loading, result]);\n}\n//# sourceMappingURL=asyncHookWrappers.js.map","const devicesWithDynamicIsland = [{\n brand: 'Apple',\n model: 'iPhone 16'\n}, {\n brand: 'Apple',\n model: 'iPhone 16 Plus'\n}, {\n brand: 'Apple',\n model: 'iPhone 16 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 16 Pro Max'\n}, {\n brand: 'Apple',\n model: 'iPhone 15'\n}, {\n brand: 'Apple',\n model: 'iPhone 15 Plus'\n}, {\n brand: 'Apple',\n model: 'iPhone 15 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 15 Pro Max'\n}, {\n brand: 'Apple',\n model: 'iPhone 14 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 14 Pro Max'\n}];\nexport default devicesWithDynamicIsland;\n//# sourceMappingURL=devicesWithDynamicIsland.js.map","const devicesWithNotch = [{\n brand: 'Apple',\n model: 'iPhone 16'\n}, {\n brand: 'Apple',\n model: 'iPhone 16 Plus'\n}, {\n brand: 'Apple',\n model: 'iPhone 16 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 16 Pro Max'\n}, {\n brand: 'Apple',\n model: 'iPhone 15'\n}, {\n brand: 'Apple',\n model: 'iPhone 15 Plus'\n}, {\n brand: 'Apple',\n model: 'iPhone 15 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 15 Pro Max'\n}, {\n brand: 'Apple',\n model: 'iPhone 14'\n}, {\n brand: 'Apple',\n model: 'iPhone 14 Plus'\n}, {\n brand: 'Apple',\n model: 'iPhone 14 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 14 Pro Max'\n}, {\n brand: 'Apple',\n model: 'iPhone 13 mini'\n}, {\n brand: 'Apple',\n model: 'iPhone 13'\n}, {\n brand: 'Apple',\n model: 'iPhone 13 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 13 Pro Max'\n}, {\n brand: 'Apple',\n model: 'iPhone 12 mini'\n}, {\n brand: 'Apple',\n model: 'iPhone 12'\n}, {\n brand: 'Apple',\n model: 'iPhone 12 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 12 Pro Max'\n}, {\n brand: 'Apple',\n model: 'iPhone 11'\n}, {\n brand: 'Apple',\n model: 'iPhone 11 Pro'\n}, {\n brand: 'Apple',\n model: 'iPhone 11 Pro Max'\n}, {\n brand: 'Apple',\n model: 'iPhone X'\n}, {\n brand: 'Apple',\n model: 'iPhone XS'\n}, {\n brand: 'Apple',\n model: 'iPhone XS Max'\n}, {\n brand: 'Apple',\n model: 'iPhone XR'\n}, {\n brand: 'Asus',\n model: 'ZenFone 5'\n}, {\n brand: 'Asus',\n model: 'ZenFone 5z'\n}, {\n brand: 'google',\n model: 'Pixel 3 XL'\n}, {\n brand: 'google',\n model: 'Pixel 4a'\n}, {\n brand: 'Huawei',\n model: 'P20'\n}, {\n brand: 'Huawei',\n model: 'P20 Plus'\n}, {\n brand: 'Huawei',\n model: 'P20 Lite'\n}, {\n brand: 'Huawei',\n model: 'ANE-LX1'\n}, {\n brand: 'Huawei',\n model: 'INE-LX1'\n}, {\n brand: 'Huawei',\n model: 'POT-LX1'\n}, {\n brand: 'Huawei',\n model: 'Honor Play'\n}, {\n brand: 'Huawei',\n model: 'Honor 10'\n}, {\n brand: 'Huawei',\n model: 'Mate 20 Lite'\n}, {\n brand: 'Huawei',\n model: 'Mate 20 Pro'\n}, {\n brand: 'Huawei',\n model: 'ELE-L29' // P30\n\n}, {\n brand: 'Huawei',\n model: 'P30 Lite'\n}, {\n brand: 'Huawei',\n model: 'P30 Pro'\n}, {\n brand: 'Huawei',\n model: 'JNY-LX1' // P40 Lite\n\n}, {\n brand: 'Huawei',\n model: 'Nova 3'\n}, {\n brand: 'Huawei',\n model: 'Nova 3i'\n}, {\n brand: 'Leagoo',\n model: 'S9'\n}, {\n brand: 'LG',\n model: 'G7'\n}, {\n brand: 'LG',\n model: 'G7 ThinQ'\n}, {\n brand: 'LG',\n model: 'G7+ ThinQ'\n}, {\n brand: 'LG',\n model: 'LM-Q910' //G7 One\n\n}, {\n brand: 'LG',\n model: 'LM-G710' //G7 ThinQ\n\n}, {\n brand: 'LG',\n model: 'LM-V405' //V40 ThinQ\n\n}, {\n brand: 'Motorola',\n model: 'Moto g7 Play'\n}, {\n brand: 'Motorola',\n model: 'Moto g7 Power'\n}, {\n brand: 'Motorola',\n model: 'One'\n}, {\n brand: 'Motorola',\n model: 'Motorola One Vision'\n}, {\n brand: 'Nokia',\n model: '5.1 Plus'\n}, {\n brand: 'Nokia',\n model: 'Nokia 6.1 Plus'\n}, {\n brand: 'Nokia',\n model: '7.1'\n}, {\n brand: 'Nokia',\n model: '8.1'\n}, {\n brand: 'OnePlus',\n model: '6'\n}, {\n brand: 'OnePlus',\n model: 'A6003'\n}, {\n brand: 'ONEPLUS',\n model: 'A6000'\n}, {\n brand: 'OnePlus',\n model: 'OnePlus A6003'\n}, {\n brand: 'OnePlus',\n model: 'ONEPLUS A6010'\n}, {\n brand: 'OnePlus',\n model: 'ONEPLUS A6013'\n}, {\n brand: 'OnePlus',\n model: 'ONEPLUS A6000'\n}, {\n brand: 'Oppo',\n model: 'R15'\n}, {\n brand: 'Oppo',\n model: 'R15 Pro'\n}, {\n brand: 'Oppo',\n model: 'F7'\n}, {\n brand: 'Oukitel',\n model: 'U18'\n}, {\n brand: 'Redmi',\n model: 'M2004J19C'\n}, {\n brand: 'Sharp',\n model: 'Aquos S3'\n}, {\n brand: 'Vivo',\n model: 'V9'\n}, {\n brand: 'Vivo',\n model: 'X21'\n}, {\n brand: 'Vivo',\n model: 'X21 UD'\n}, {\n brand: 'xiaomi',\n model: 'MI 8'\n}, {\n brand: 'xiaomi',\n model: 'MI 8 Explorer Edition'\n}, {\n brand: 'xiaomi',\n model: 'MI 8 SE'\n}, {\n brand: 'xiaomi',\n model: 'MI 8 UD'\n}, {\n brand: 'xiaomi',\n model: 'MI 8 Lite'\n}, {\n brand: 'xiaomi',\n model: 'Mi 9'\n}, {\n brand: 'xiaomi',\n model: 'POCO F1'\n}, {\n brand: 'xiaomi',\n model: 'POCOPHONE F1'\n}, {\n brand: 'xiaomi',\n model: 'Redmi 6 Pro'\n}, {\n brand: 'xiaomi',\n model: 'Redmi Note 7'\n}, {\n brand: 'xiaomi',\n model: 'Redmi 7'\n}, {\n brand: 'xiaomi',\n model: 'Redmi Note 8'\n}, {\n brand: 'xiaomi',\n model: 'Redmi Note 8 Pro'\n}, {\n brand: 'xiaomi',\n model: 'Mi A2 Lite'\n}, {\n brand: 'Blackview',\n model: 'A30'\n}, {\n brand: 'Samsung',\n model: 'SM-A202F'\n}, {\n brand: 'Samsung',\n model: 'SM-A217F'\n}, {\n brand: 'Samsung',\n model: 'SM-A715F'\n}];\nexport default devicesWithNotch;\n//# sourceMappingURL=devicesWithNotch.js.map","import { Platform, NativeModules } from 'react-native';\nlet RNDeviceInfo = NativeModules.RNDeviceInfo; // @ts-ignore\n\nif (Platform.OS === 'web' || Platform.OS === 'dom') {\n RNDeviceInfo = require('../web');\n}\n\nif (!RNDeviceInfo) {\n // Produce an error if we don't have the native module\n if (Platform.OS === 'android' || Platform.OS === 'ios' || Platform.OS === 'web' || // @ts-ignore\n Platform.OS === 'dom') {\n throw new Error(`react-native-device-info: NativeModule.RNDeviceInfo is null. To fix this issue try these steps:\n • For react-native <= 0.59: Run \\`react-native link react-native-device-info\\` in the project root.\n • Rebuild and re-run the app.\n • If you are using CocoaPods on iOS, run \\`pod install\\` in the \\`ios\\` directory and then rebuild and re-run the app. You may also need to re-open Xcode to get the new pods.\n If none of these fix the issue, please open an issue on the Github repository: https://github.com/react-native-device-info/react-native-device-info`);\n }\n}\n\nexport default RNDeviceInfo;\n//# sourceMappingURL=nativeInterface.js.map","import { NativeEventEmitter, NativeModules } from 'react-native';\nconst deviceInfoEmitter = new NativeEventEmitter(NativeModules.RNDeviceInfo);\nlet batteryCharging = false,\n batteryLevel = -1,\n powerState = {};\n\nconst _readPowerState = battery => {\n const {\n level,\n charging,\n chargingtime,\n dischargingtime\n } = battery;\n return {\n batteryLevel: level,\n lowPowerMode: false,\n batteryState: level === 1 ? 'full' : charging ? 'charging' : 'unplugged',\n chargingtime,\n dischargingtime\n };\n};\n\nexport const getMaxMemorySync = () => {\n if (window.performance && window.performance.memory) {\n return window.performance.memory.jsHeapSizeLimit;\n }\n\n return -1;\n};\nexport const getInstallReferrerSync = () => {\n return document.referrer;\n};\nexport const isAirplaneModeSync = () => {\n return !!navigator.onLine;\n};\nexport const getUserAgentSync = () => {\n return window.navigator.userAgent;\n};\nexport const isLocationEnabledSync = () => {\n return !!navigator.geolocation;\n};\nexport const getTotalMemorySync = () => {\n if (navigator.deviceMemory) {\n return navigator.deviceMemory * 1000000000;\n }\n\n return -1;\n};\nexport const getUsedMemorySync = () => {\n if (window.performance && window.performance.memory) {\n return window.performance.memory.usedJSHeapSize;\n }\n\n return -1;\n};\n\nconst init = () => {\n if (typeof navigator === 'undefined' || !navigator.getBattery) return;\n navigator.getBattery().then(battery => {\n batteryCharging = battery.charging;\n battery.addEventListener('chargingchange', () => {\n const {\n charging\n } = battery;\n batteryCharging = charging;\n powerState = _readPowerState(battery);\n deviceInfoEmitter.emit('RNDeviceInfo_powerStateDidChange', powerState);\n });\n battery.addEventListener('levelchange', () => {\n const {\n level\n } = battery;\n batteryLevel = level;\n powerState = _readPowerState(battery);\n deviceInfoEmitter.emit('RNDeviceInfo_batteryLevelDidChange', level);\n\n if (level < 0.2) {\n deviceInfoEmitter.emit('RNDeviceInfo_batteryLevelIsLow', level);\n }\n });\n });\n};\n\nconst getBaseOsSync = () => {\n const userAgent = window.navigator.userAgent,\n platform = window.navigator.platform,\n macosPlatforms = ['Macintosh', 'MacIntel', 'MacPPC', 'Mac68K'],\n windowsPlatforms = ['Win32', 'Win64', 'Windows', 'WinCE'],\n iosPlatforms = ['iPhone', 'iPad', 'iPod'];\n let os = platform;\n\n if (macosPlatforms.indexOf(platform) !== -1) {\n os = 'Mac OS';\n } else if (iosPlatforms.indexOf(platform) !== -1) {\n os = 'iOS';\n } else if (windowsPlatforms.indexOf(platform) !== -1) {\n os = 'Windows';\n } else if (/Android/.test(userAgent)) {\n os = 'Android';\n } else if (!os && /Linux/.test(platform)) {\n os = 'Linux';\n }\n\n return os;\n};\n\ninit();\n/**\n * react-native-web empty polyfill.\n */\n\nexport const getInstallReferrer = async () => {\n return getInstallReferrerSync();\n};\nexport const getUserAgent = async () => {\n return getUserAgentSync();\n};\nexport const isBatteryCharging = async () => {\n if (navigator.getBattery) {\n return navigator.getBattery().then(battery => battery.charging);\n }\n\n return false;\n};\nexport const isBatteryChargingSync = () => {\n return batteryCharging;\n};\nexport const isCameraPresent = async () => {\n if (navigator.mediaDevices && navigator.mediaDevices.enumerateDevices) {\n return navigator.mediaDevices.enumerateDevices().then(devices => {\n return !!devices.find(d => d.kind === 'videoinput');\n });\n }\n\n return false;\n};\nexport const isCameraPresentSync = () => {\n console.log('[react-native-device-info] isCameraPresentSync not supported - please use isCameraPresent');\n return false;\n};\nexport const getBatteryLevel = async () => {\n if (navigator.getBattery) {\n return navigator.getBattery().then(battery => battery.level);\n }\n\n return -1;\n};\nexport const getBatteryLevelSync = () => {\n return batteryLevel;\n};\nexport const isLocationEnabled = async () => {\n return isLocationEnabledSync();\n};\nexport const isAirplaneMode = async () => {\n return isAirplaneModeSync();\n};\nexport const getBaseOs = async () => {\n return getBaseOsSync();\n};\nexport const getTotalDiskCapacity = async () => {\n if (navigator.storage && navigator.storage.estimate) {\n return navigator.storage.estimate().then(({\n quota\n }) => quota);\n }\n\n return -1;\n};\nexport const getTotalDiskCapacitySync = () => {\n console.log('[react-native-device-info] getTotalDiskCapacitySync not supported - please use getTotalDiskCapacity');\n return -1;\n};\nexport const getFreeDiskStorage = async () => {\n if (navigator.storage && navigator.storage.estimate) {\n return navigator.storage.estimate().then(({\n quota,\n usage\n }) => quota - usage);\n }\n\n return -1;\n};\nexport const getFreeDiskStorageSync = () => {\n console.log('[react-native-device-info] getFreeDiskStorageSync not supported - please use getFreeDiskStorage');\n return -1;\n};\nexport const getMaxMemory = async () => {\n return getMaxMemorySync();\n};\nexport const getUsedMemory = async () => {\n return getUsedMemorySync();\n};\nexport const getTotalMemory = async () => {\n return getTotalMemorySync();\n};\nexport const getPowerState = async () => {\n if (navigator.getBattery) {\n return navigator.getBattery().then(battery => _readPowerState(battery));\n }\n\n return {};\n};\nexport const getPowerStateSync = () => {\n return powerState;\n};\n//# sourceMappingURL=index.js.map","import { Platform } from 'react-native';\n// centralized memo object\nlet memo = {};\nexport function clearMemo() {\n memo = {};\n}\n/**\n * function returns the proper getter based current platform X supported platforms\n * @param supportedPlatforms array of supported platforms (OS)\n * @param getter desired function used to get info\n * @param defaultGetter getter that returns a default value if desired getter is not supported by current platform\n */\n\nfunction getSupportedFunction(supportedPlatforms, getter, defaultGetter) {\n let supportedMap = {};\n supportedPlatforms.filter(key => Platform.OS == key).forEach(key => supportedMap[key] = getter);\n return Platform.select({ ...supportedMap,\n default: defaultGetter\n });\n}\n/**\n * function used to get desired info synchronously — with optional memoization\n * @param param0\n */\n\n\nexport function getSupportedPlatformInfoSync({\n getter,\n supportedPlatforms,\n defaultValue,\n memoKey\n}) {\n if (memoKey && memo[memoKey] != undefined) {\n return memo[memoKey];\n } else {\n const output = getSupportedFunction(supportedPlatforms, getter, () => defaultValue)();\n\n if (memoKey) {\n memo[memoKey] = output;\n }\n\n return output;\n }\n}\n/**\n * function used to get desired info asynchronously — with optional memoization\n * @param param0\n */\n\nexport async function getSupportedPlatformInfoAsync({\n getter,\n supportedPlatforms,\n defaultValue,\n memoKey\n}) {\n if (memoKey && memo[memoKey] != undefined) {\n return memo[memoKey];\n } else {\n const output = await getSupportedFunction(supportedPlatforms, getter, () => Promise.resolve(defaultValue))();\n\n if (memoKey) {\n memo[memoKey] = output;\n }\n\n return output;\n }\n}\n/**\n * function that returns array of getter functions [async, sync]\n * @param param0\n */\n\nexport function getSupportedPlatformInfoFunctions({\n syncGetter,\n ...asyncParams\n}) {\n return [(...args) => getSupportedPlatformInfoAsync({ ...asyncParams,\n getter: () => asyncParams.getter(...args)\n }), (...args) => getSupportedPlatformInfoSync({ ...asyncParams,\n getter: () => syncGetter(...args)\n })];\n}\n//# sourceMappingURL=supported-platform-info.js.map","import axios from \"axios\"\n\nfunction getChaptersAsStudent({}, {}, params) {\n return axios.get(`api/v1/chapters`, {params})\n}\n\nfunction getChaptersAsTutor({id}, {}, params) {\n if (!id)\n return axios.get(`/api/v1/students/chapters`, {params})\n else\n return axios.get(`/api/v1/students/${id}/chapters`, {params})\n}\n\nfunction getChaptersForStudents({}, {}, params) {\n return axios.get(`/api/v1/students/chapters`, {params})\n}\n\nfunction getChaptersAsAdmin({}, {}, params) {\n return axios.get(`/api/backoffice/chapters`, {params})\n}\n\nfunction newChapter({}, data) {\n return axios.post(`/api/backoffice/chapters`, data)\n}\n\nfunction studentChapterFeelings({id}, data) {\n return axios.post(`/api/v1/student-chapters/${id}/fill-quiz`, data)\n}\n\nexport const chaptersService = {\n getChaptersAsStudent,\n getChaptersAsTutor,\n getChaptersAsAdmin,\n studentChapterFeelings,\n newChapter,\n getChaptersForStudents\n}\n\n","import {apiConstants} from \"@data/constants/apiConstants\";\nimport {interviewReportService} from \"@data/services/interviewReportService\";\nimport {gradesService} from \"@data/services/gradesService\";\n\nconst initialState = {\n interviewReportsList: [],\n prioritizedSchoolSubjects: [],\n interviewStats: {}\n}\n\nexport default function interviewReports(state = initialState, action) {\n switch (action.type) {\n case interviewReportService.getStudentInterviewReports.name + apiConstants._SUCCESS:\n let interviewReportsList = []\n if (action.data?.meta?.current_page === 1) {\n interviewReportsList = action.data?.interview_reports\n } else {\n interviewReportsList = state.interviewReportsList.concat(action.data?.interview_reports)\n }\n return {\n ...state,\n interviewReportsList: interviewReportsList,\n prioritizedSchoolSubjects: action.data?.prioritized_school_subjects\n }\n case interviewReportService.getInterviewReport.name + apiConstants._SUCCESS:\n case interviewReportService.newInterviewReport.name + apiConstants._SUCCESS:\n return {\n ...state,\n interviewReportsList: [action.data, ...state.interviewReportsList]\n }\n case interviewReportService.getPrioritizedSchoolSubjects.name + apiConstants._SUCCESS:\n return {\n ...state,\n prioritizedSchoolSubjects: action.data\n }\n case gradesService.newGrade.name + apiConstants._SUCCESS:\n // console.log(action)\n return {\n ...state,\n prioritizedSchoolSubjects: state.prioritizedSchoolSubjects.map((schoolSubject) => {\n if (schoolSubject?.id === action.data?.school_subject_id) {\n if (schoolSubject?.last_grades?.length < 5) {\n schoolSubject.last_grades = schoolSubject.last_grades.concat(action.data).sort((a, b) => {\n // if dates are equal sort by created_at\n if (new Date(b?.date) - new Date(a?.date) === 0) {\n return new Date(b?.created_at) - new Date(a?.created_at);\n }\n return new Date(b?.date) - new Date(a?.date);\n })\n // console.log(schoolSubject.last_grades)\n } else {\n // if grade date is more recent than the earliest grade date add it to the list and remove the earliest grade\n if (new Date(action.data?.date) > new Date(schoolSubject.last_grades[4]?.date)) {\n schoolSubject.last_grades = schoolSubject.last_grades.concat(action.data).sort((a, b) => {\n // if dates are equal sort by created_at\n if (new Date(b?.date) - new Date(a?.date) === 0) {\n return new Date(b?.created_at) - new Date(a?.created_at);\n }\n return new Date(b?.date) - new Date(a?.date);\n })\n schoolSubject.last_grades.pop()\n } else if (action.data?.date === schoolSubject.last_grades[0]?.date) {\n // shift the list and add the new grade\n schoolSubject.last_grades.unshift(action.data)\n schoolSubject.last_grades.pop()\n }\n }\n }\n return schoolSubject\n })\n }\n case gradesService.deleteGrade.name + apiConstants._SUCCESS:\n // console.log(action.data)\n return {\n ...state,\n prioritizedSchoolSubjects: state.prioritizedSchoolSubjects.map((schoolSubject) => {\n schoolSubject.last_grades = schoolSubject.last_grades.filter((grade) => grade?.id !== action?.routeParams?.id)\n return schoolSubject\n })\n }\n case gradesService.updateGrade.name + apiConstants._SUCCESS:\n // console.log(action.data)\n return {\n ...state,\n prioritizedSchoolSubjects: state.prioritizedSchoolSubjects.map((schoolSubject) => {\n schoolSubject.last_grades = schoolSubject.last_grades.map((grade) => {\n if (grade?.id === action.data?.id) {\n return action.data\n }\n return grade\n }).sort((a, b) => {\n return new Date(b?.date) - new Date(a?.date);\n })\n return schoolSubject\n })\n }\n case interviewReportService.getInterviewStatistics.name + apiConstants._SUCCESS:\n // console.log(action.data)\n return {\n ...state,\n interviewStats: action.data?.statistics\n }\n case interviewReportService.addPrioritizedSchoolSubjects.name + apiConstants._SUCCESS:\n // console.log(action.data)\n return {\n ...state,\n prioritizedSchoolSubjects: state.prioritizedSchoolSubjects.concat(action.data)\n }\n case interviewReportService.removePrioritizedSchoolSubject.name + apiConstants._SUCCESS:\n // console.log(action)\n return {\n ...state,\n prioritizedSchoolSubjects: state.prioritizedSchoolSubjects.filter((schoolSubject) => schoolSubject?.id !== action?.data?.school_subject_id)\n }\n default:\n return state\n }\n}\n","import axios from \"axios\"\n\nfunction getStudentInterviewReports({id}) {\n return axios.get(`api/v1/students/${id}/interview-reports`)\n}\n\nfunction getInterviewReport({hash}) {\n return axios.get(`api/v1/interview-reports/${hash}`)\n}\n\nfunction newInterviewReport({studentId}, formData) {\n return axios.post(`api/v1/students/${studentId}/interview-reports`, formData)\n}\n\nfunction getPrioritizedSchoolSubjects({studentId}) {\n return axios.get(`api/v1/students/${studentId}/prioritized-school-subjects`)\n}\n\nfunction getInterviewStatistics({studentId}, {}, params) {\n return axios.get(`api/v1/students/${studentId}/interview-stats`, {params})\n}\n\nfunction sendParentSatisfaction({id}, formData) {\n return axios.post(`api/v1/interview-reports/${id}/parent-satisfaction`, formData)\n}\n\nfunction addPrioritizedSchoolSubjects({studentId}, formData) {\n return axios.post(`api/v1/students/${studentId}/add-prioritized`, formData)\n}\n\nfunction removePrioritizedSchoolSubject({studentId}, formData) {\n return axios.post(`api/v1/students/${studentId}/remove-prioritized`, formData)\n}\n\nfunction getDefaultStartDate({studentId}) {\n return axios.get(`api/v1/students/${studentId}/default-start-date`)\n}\n\nexport const interviewReportService = {\n getStudentInterviewReports,\n getInterviewReport,\n getPrioritizedSchoolSubjects,\n getInterviewStatistics,\n newInterviewReport,\n sendParentSatisfaction,\n addPrioritizedSchoolSubjects,\n removePrioritizedSchoolSubject,\n getDefaultStartDate\n}\n\n","import axios from \"axios\"\n\nfunction newGrade({id}, formData) {\n return axios.post(`/api/v1/students/${id}/grades`, formData)\n}\n\nfunction deleteGrade({id}) {\n return axios.delete(`/api/v1/grades/${id}`)\n}\n\nfunction updateGrade({id}, formData) {\n return axios.put(`/api/v1/grades/${id}`, formData)\n}\n\nexport const gradesService = {\n newGrade,\n deleteGrade,\n updateGrade\n}\n\n","import {apiConstants} from \"@data/constants/apiConstants\"\nimport {liveReportService} from \"@data/services/liveReportService\";\n\n// ** Initial State\nconst initialState = {\n liveReports: []\n}\n\nexport function liveReports(state = initialState, action) {\n switch (action.type) {\n case liveReportService.getStudentLiveReports.name + apiConstants._SUCCESS:\n let liveReports = []\n if (action.data?.meta?.current_page === 1) {\n liveReports = action.data?.live_reports\n } else {\n liveReports = state.liveReports?.concat(action.data?.live_reports)\n }\n return {\n ...state,\n liveReports: liveReports\n }\n\n default:\n return state\n }\n}\n\nexport default liveReports\n","import axios from \"axios\";\n\nfunction getLiveReport({ hash }) {\n return axios.get(`api/v1/live-reports/${hash}`);\n}\n\nfunction getStudentLiveReports({ id }, {}, params) {\n return axios.get(`api/v1/students/${id}/live-reports`, { params });\n}\n\nfunction sendStudentComment({ id }, data) {\n return axios.post(\n `api/v1/live-reports/${id}/student-comment?_method=PUT`,\n data\n );\n}\n\nfunction deleteCommentRecord({ id }, data) {\n return axios.post(`api/v1/live-reports/${id}/delete-comment-record`);\n}\n\nexport const liveReportService = {\n getLiveReport,\n getStudentLiveReports,\n sendStudentComment,\n deleteCommentRecord,\n};\n","import {apiConstants} from \"@data/constants/apiConstants\"\nimport {referralService} from \"@data/services/referralService\";\nimport {roomService} from \"@data/services/roomService\";\nimport {liveService} from \"@data/services/liveService\";\nimport {attendanceFlagsService} from \"@data/services/attendanceFlagsService\";\n\n// ** Initial State\nconst initialState = {\n full_list: [],\n list: [],\n attendance_flags_to_be_recovered: []\n}\n\nexport function liveSessions(state = initialState, action) {\n switch (action.type) {\n\n case liveService.getAllMyNextLiveSessionsAsParent.name + apiConstants._SUCCESS:\n case liveService.getAllMyNextLiveSessions.name + apiConstants._SUCCESS:\n\n const hasLiveRoom = action?.urlParams?.live_room_id !== undefined\n const listKey = hasLiveRoom ? \"list\" : \"full_list\"\n\n return {\n ...state,\n [listKey]: action?.data?.live_sessions,\n attendance_flags_to_be_recovered: action?.data?.attendance_flags_to_be_recovered\n }\n\n case attendanceFlagsService.cancelAbsenceAsParent.name + apiConstants._SUCCESS:\n case attendanceFlagsService.cancelAbsenceAsStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n list: state.list.map(session => ({\n ...session,\n attendance_flags: session.attendance_flags.filter(flag => flag.id !== action?.routeParams?.id)\n })),\n full_list: state.full_list.map(session => ({\n ...session,\n attendance_flags: session.attendance_flags.filter(flag => flag.id !== action?.routeParams?.id)\n }))\n };\n case liveService.reportAbsenceAsParent.name + apiConstants._SUCCESS:\n case liveService.reportAbsenceAsStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n list: state.list.map(session => ({\n ...session,\n attendance_flags: action.data?.id === session?.id ? action.data?.attendance_flags : session?.attendance_flags,\n })),\n full_list: state.full_list.map(session => ({\n ...session,\n attendance_flags: action.data?.id === session?.id ? action.data?.attendance_flags : session?.attendance_flags,\n }))\n };\n\n default:\n return state\n }\n}\n\nexport default liveSessions\n","import axios from \"axios\"\n\nfunction indexPaginatedReferralCodes({}, {}, params) {\n return axios.get(`api/v1/referral-codes`, {params})\n}\nfunction createReferralCode({}, formData) {\n return axios.post(`api/v1/referral-codes`, formData)\n}\nfunction showReferralCodeByHash({hash}) {\n return axios.get(`api/v1/referral-codes/${hash}`)\n}\nfunction updateReferralCode({id}, formData) {\n return axios.put(`api/v1/referral-codes/${id}`, formData)\n}\nfunction deleteReferralCode({id}) {\n return axios.delete(`api/v1/referral-codes/${id}`)\n}\nfunction markDueAsPaid({id}) {\n return axios.post(`api/v1/referral-codes/${id}/mark-due-as-paid`)\n}\nfunction incrementClicks({code}) {\n return axios.post(`api/v1/referral-codes/${code}/increment-clicks`)\n}\n\nfunction getReferralCode() {\n return axios.get(`api/v1/referral-code` )\n}\n\nfunction sendUrl({id}, formData) {\n return axios.post(`api/v1/referral-codes/${id}/send-url`, formData)\n}\n\nfunction getUrl({id}) {\n return axios.get(`api/v1/referral-codes/${id}/url`)\n}\n\nexport const referralService = {\n indexPaginatedReferralCodes,\n createReferralCode,\n showReferralCodeByHash,\n updateReferralCode,\n deleteReferralCode,\n markDueAsPaid,\n incrementClicks,\n getReferralCode,\n sendUrl,\n getUrl\n}\n","import axios from \"axios\"\n\nfunction getRooms({}, {}, params) {\n return axios.get(`api/backoffice/live-rooms`, {params})\n}\n\nfunction newRoom({}, data) {\n return axios.post(`/api/backoffice/live-rooms`, data)\n}\n\nfunction editRoom({id}, data) {\n return axios.put(`/api/backoffice/live-rooms/${id}`, data)\n}\n\nfunction deleteRoom({id}) {\n return axios.delete(`/api/backoffice/live-rooms/${id}`)\n}\n\nfunction addMembersToSessions({id}, data) {\n return axios.post(`/api/backoffice/live-rooms/${id}/add-users`, data)\n}\n\nfunction addMultipleSessions({}, data) {\n return axios.post(`/api/backoffice/live-sessions/multiple`, data)\n}\n\nexport const roomService = {\n getRooms,\n newRoom,\n editRoom,\n deleteRoom,\n addMembersToSessions,\n addMultipleSessions\n}\n\n","import axios from \"axios\";\n\nfunction getLiveSession({id}) {\n return axios.get(`api/v1/live-sessions/${id}`);\n}\n\nfunction getCall({id}) {\n return axios.get(`api/v1/live-sessions/${id}/call`);\n}\n\nfunction makeCall({id}, value) {\n return axios.post(`api/v1/live-sessions/${id}/call`, value);\n}\n\nfunction joinCall({id}) {\n return axios.post(`api/v1/live-sessions/${id}/call/join`);\n}\n\nfunction leaveCall({id}) {\n return axios.post(`api/v1/live-sessions/${id}/call/leave`);\n}\n\nfunction callKeepAlive({id}) {\n return axios.post(`api/v1/live-sessions/${id}/call/keep-alive`);\n}\n\nfunction raiseHand({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/raise-hand`, data);\n}\n\nfunction lowerHands({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/lower-hands`, data);\n}\n\nfunction lowerAllHands({id}) {\n return axios.post(`api/v1/live-sessions/${id}/lower-all-hands`);\n}\n\nfunction leaveLiveSession({id}) {\n return axios.post(`api/v1/live-sessions/${id}/leave`);\n}\n\nfunction finalizeLiveSession({id}) {\n return axios.post(`api/v1/live-sessions/${id}/finalize`);\n}\n\nfunction sendSatisfaction({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/send-satisfaction`, data);\n}\n\nfunction sendLiveQuality({id}, data) {\n return axios.post(\n `api/v1/live-occurrences/${id}/send-quality?_method=PUT`,\n data\n );\n}\n\nfunction sendStudentComment({id}, data) {\n return axios.put(`api/v1/live-sessions/${id}/send-student-comment`, data);\n}\n\nfunction getTodayLiveReports({id}) {\n return axios.get(`api/v1/live-sessions/${id}/today-live-reports`);\n}\n\nfunction getTodayLiveReport({id}) {\n return axios.get(`api/v1/live-sessions/${id}/today-live-report`);\n}\n\nfunction getTodayLiveOccurrence({id}) {\n return axios.get(`api/v1/live-sessions/${id}/today-live-occurrence`);\n}\n\nfunction getLiveOccurrence({id}) {\n return axios.get(`api/v1/live-occurrences/${id}`);\n}\n\nfunction setSoundMode({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/sound-mode`, data);\n}\n\nfunction setCamMode({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/camonoff`, data);\n}\n\nfunction setVoiceRecordingActivity({id}, data) {\n return axios.post(\n `api/v1/live-sessions/${id}/voice-recording-activity`,\n data\n );\n}\n\nfunction getLiveSessions() {\n return axios.get(`api/v1/live-sessions`);\n}\n\nfunction moveSession({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/move-session`, data);\n}\n\nfunction reportAbsence({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/report-absence`, data\n );\n}\n\nfunction reportAbsenceAsStudent({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/manage-attendance-flag`, data\n );\n}\n\nfunction reportAbsenceAsParent({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/new-attendance-flag`, data\n );\n}\n\nfunction recoverAbsenceAsStudent({id}, data) {\n return axios.post(`api/v1/attendance-flags/${id}/recover`, data\n );\n}\n\nfunction recoverAbsenceAsParent({id}, data) {\n return axios.post(`api/v1/attendance-flags/${id}/recover-as-parent`, data\n );\n}\n\nfunction getAllMyNextLiveSessions({}, {}, params) {\n return axios.get(`api/v1/next-live-sessions`, {params});\n}\n\nfunction getAllMyNextLiveSessionsAsParent({}, {}, params) {\n return axios.get(`api/v1/user/next-live-sessions`, {params});\n}\n\nfunction getRecoveryPossibilities({}, {}, params) {\n return axios.get(`api/v1/recovery-possibilities`, {params});\n}\n\nfunction getRecoveryPossibilitiesAsParent({}, {}, params) {\n return axios.get(`api/v1/user/recovery-possibilities`, {params});\n}\n\nexport const liveService = {\n getLiveSession,\n getCall,\n makeCall,\n joinCall,\n leaveCall,\n raiseHand,\n lowerHands,\n lowerAllHands,\n setSoundMode,\n setCamMode,\n setVoiceRecordingActivity,\n callKeepAlive,\n leaveLiveSession,\n finalizeLiveSession,\n sendSatisfaction,\n getTodayLiveReports,\n getTodayLiveReport,\n sendLiveQuality,\n sendStudentComment,\n getLiveSessions,\n moveSession,\n reportAbsence,\n getTodayLiveOccurrence,\n getLiveOccurrence,\n reportAbsenceAsStudent,\n reportAbsenceAsParent,\n recoverAbsenceAsStudent,\n recoverAbsenceAsParent,\n getAllMyNextLiveSessions,\n getAllMyNextLiveSessionsAsParent,\n getRecoveryPossibilities,\n getRecoveryPossibilitiesAsParent\n};\n","import axios from \"axios\"\n\n\nfunction cancelAbsenceAsStudent({id}) {\n return axios.delete(`/api/v1/attendance-flags/${id}`)\n}\n\nfunction cancelAbsenceAsParent({id}) {\n return axios.post(`/api/v1/attendance-flags/${id}/cancel-attendance-flag`)\n}\n\n\nexport const attendanceFlagsService = {\n cancelAbsenceAsStudent,\n cancelAbsenceAsParent\n}\n\n","import {apiConstants} from \"@data/constants/apiConstants\";\nimport {activitiesService} from \"@data/services/activitiesService\";\n\nconst initialState = {\n materialsList: []\n}\n\nexport default function materials(state = initialState, action) {\n switch (action.type) {\n case activitiesService.materialsSearch.name + apiConstants._SUCCESS:\n let materialsList = []\n if (action.data?.meta?.current_page === 1) {\n materialsList = action.data?.materials\n } else {\n materialsList = state.materialsList.concat(action.data?.materials)\n }\n return {\n ...state,\n materialsList: materialsList\n }\n default:\n return state\n }\n}\n","import axios from \"axios\";\n\nfunction getActivities({}, {}, params) {\n return axios.get(`api/activities`, { params });\n}\n\nfunction getFinishedActivities({}, {}, params) {\n return axios.get(`api/activities/finished`, { params });\n}\n\nfunction getStudentFinishedActivities({ id }, {}, params) {\n return axios.get(`api/students/${id}/activities/finished`, { params });\n}\n\nfunction initActivity({}, formData, urlParams, onUploadProgress) {\n return axios.post(`api/activities`, formData, {\n // headers: {\n // \"Content-Type\": \"multipart/form-data\",\n // },\n onUploadProgress,\n });\n}\n\nfunction postActivityLogs({ id }, formData, urlParams, onUploadProgress) {\n return axios.post(`api/activities/${id}/logs`, formData, {\n // headers: {\n // \"Content-Type\": \"multipart/form-data\",\n // },\n onUploadProgress,\n });\n}\n\nfunction postActivityLog({ id }, formData, urlParams, onUploadProgress) {\n // console.log(id)\n // console.log(formData)\n return axios.post(`api/activities/${id}/log`, formData, {\n headers: {\n \"Content-Type\": \"multipart/form-data\",\n },\n onUploadProgress,\n });\n}\n\nfunction postActivityLogV1({ id }, formData, urlParams, onUploadProgress) {\n // console.log(id)\n // console.log(formData)\n return axios.post(`api/v1/activities/${id}/log`, formData, {\n headers: {\n \"Content-Type\": \"multipart/form-data\",\n },\n onUploadProgress,\n });\n}\n\nfunction deleteActivityLog({ id }, formData) {\n // console.log(id)\n // console.log(formData)\n return axios.delete(`api/activity-logs/${id}`, { data: formData });\n}\n\nfunction finalizeActivity({ id }, formData = {}, urlParams, onUploadProgress) {\n return axios.post(\n `api/activities/${id}/finalize`,\n formData,\n {\n // headers: {\n // \"Content-Type\": \"multipart/form-data\",\n // },\n onUploadProgress,\n }\n );\n}\n\nfunction tutorValidateActivity({ id }) {\n return axios.post(\n `api/activities/${id}/validate`\n );\n}\n\n\nfunction readReview({ id }) {\n return axios.post(`api/activities/${id}/read-review`);\n}\n\nfunction getActivitiesForReview({}, {}, params) {\n return axios.get(`api/activities/for-review`, { params });\n}\n\nfunction reviewActivity({ id }, formData) {\n return axios.post(`api/v1/activities/${id}/review`, formData);\n}\n\nfunction reviewLock({ id }) {\n return axios.post(`api/v1/activities/${id}/review-lock`);\n}\n\nfunction postMaterial({ activity_id }, formData) {\n return axios.post(`api/activities/${activity_id}/material`, formData);\n}\n\nfunction putMaterial({ id }, formData) {\n return axios.put(`api/materials/${id}`, formData);\n}\n\nfunction deleteMaterial({ id }) {\n return axios.delete(`api/materials/${id}`);\n}\n\nfunction materialsSearch({}, {}, params) {\n return axios.get(`api/materials`, { params });\n}\n\nfunction lockActivity({ id }, formData) {\n return axios.post(`api/v1/activities/${id}/lock`, formData);\n}\n\nfunction getActivity({ id }) {\n return axios.get(`api/v1/activities/${id}`);\n}\n\nfunction activityTodoAsStudent({}, formData, {}, onUploadProgress) {\n return axios.post(`api/v2/activities/todo`, formData, {\n onUploadProgress,\n });\n}\n\nfunction activityTodoAsTutor({ id }, formData, {}, onUploadProgress) {\n return axios.post(`api/v2/students/${id}/activities/todo`, formData, {\n onUploadProgress,\n });\n}\n\nfunction activityTodoForStudents({}, formData, {}, onUploadProgress) {\n return axios.post(`api/v1/students/activities/todo`, formData, {\n onUploadProgress,\n });\n}\n\nfunction updateActivityTodo({ id }, formData, {}, onUploadProgress) {\n return axios.put(`api/v1/activities/${id}/todo`, formData, {\n onUploadProgress,\n });\n}\n\nfunction activityTodoIndexesAsStudent({}, formData) {\n return axios.put(`api/v1/activities/todo/indexes`, formData);\n}\n\nfunction activityTodoIndexesAsTutor({ id }, formData) {\n return axios.put(`api/v1/students/${id}/activities/todo/indexes`, formData);\n}\n\nfunction deleteActivityTodo({ id }) {\n return axios.delete(`api/v1/activities/${id}/todo`);\n}\n\nfunction deleteActivitiesTodoAsStudent() {\n return axios.delete(`api/v1/activities/todo`);\n}\n\nfunction deleteActivitiesTodoAsTutor({ id }) {\n return axios.delete(`api/v1/students/${id}/activities/todo`);\n}\n\nfunction deleteCommonActivityTodo({}, {}, params) {\n return axios.delete(`api/v1/students/activities/todo`, { params });\n}\n\nfunction lockActivityV2({ id }, formData) {\n return axios.post(`api/v2/activities/${id}/lock`, formData);\n}\n\nfunction updateChrono({ id }, formData) {\n return axios.post(`api/activities/${id}/update-chrono`, formData);\n}\n\nexport const activitiesService = {\n getActivities,\n getFinishedActivities,\n readReview,\n getStudentFinishedActivities,\n initActivity,\n postActivityLogs,\n postActivityLog,\n postActivityLogV1,\n finalizeActivity,\n getActivitiesForReview,\n reviewActivity,\n reviewLock,\n activityTodoAsStudent,\n activityTodoAsTutor,\n activityTodoForStudents,\n updateActivityTodo,\n activityTodoIndexesAsStudent,\n activityTodoIndexesAsTutor,\n deleteActivityTodo,\n deleteCommonActivityTodo,\n postMaterial,\n putMaterial,\n deleteMaterial,\n lockActivity,\n getActivity,\n deleteActivitiesTodoAsStudent,\n deleteActivitiesTodoAsTutor,\n lockActivityV2,\n updateChrono,\n deleteActivityLog,\n materialsSearch,\n tutorValidateActivity,\n};\n","import {apiConstants} from \"@data/constants/apiConstants\"\nimport {referralService} from \"@data/services/referralService\";\nimport {roomService} from \"@data/services/roomService\";\n\n// ** Initial State\nconst initialState = {\n referralCodes: []\n}\n\nexport function referrals(state = initialState, action) {\n switch (action.type) {\n\n case referralService.createReferralCode.name + apiConstants._SUCCESS:\n return {\n ...state,\n referralCodes: [...state.referralCodes, action?.data]\n }\n case referralService.updateReferralCode.name + apiConstants._SUCCESS:\n return {\n ...state,\n referralCodes: state.referralCodes.map((x) => {\n if (x?.id === action?.data?.id) {\n return action?.data\n }\n return x\n })\n }\n\n case referralService.deleteReferralCode.name + apiConstants._SUCCESS:\n return {\n ...state,\n referralCodes: state.referralCodes.filter((x) => x?.id !== action?.routeParams?.id)\n }\n\n case referralService.indexPaginatedReferralCodes.name + apiConstants._SUCCESS:\n let referralCodes = []\n if (action.data?.meta?.current_page === 1) {\n referralCodes = action.data?.referral_codes\n } else {\n referralCodes = state.referralCodes?.concat(action.data?.referral_codes)\n }\n return {\n ...state,\n referralCodes: referralCodes\n }\n\n\n default:\n return state\n }\n}\n\nexport default referrals\n","import {apiConstants} from \"@data/constants/apiConstants\";\nimport {schoolsService} from \"@data/services/schoolsService\";\n\n// ** Initial State\nconst initialState = {\n list: []\n};\n\nfunction schools(state = initialState, action) {\n switch (action.type) {\n case schoolsService.getSchool.name + apiConstants._SUCCESS:\n\n return {\n ...state,\n list: state?.list?.find(s => s.id === action.data?.id) ? state?.list?.map(s => s.id === action.data?.id ? action.data : s) : state?.list?.concat(action.data)\n }\n\n case schoolsService.getSchools.name + apiConstants._SUCCESS:\n let list = [];\n if (action.data?.meta?.current_page === 1) {\n list = action.data?.schools;\n } else {\n list = state.list?.concat(\n action.data?.schools\n );\n }\n return {\n ...state,\n list\n };\n default:\n return state;\n }\n}\n\nexport default schools;\n","import axios from \"axios\"\n\nfunction getSchools() {\n return axios.get('/api/schools')\n\n}\n\nfunction getSchool({id}, {}, params) {\n return axios.get(`api/schools/${id}`, {\n params\n })\n}\n\nfunction searchUser({id}, {}, params) {\n return axios.get(`api/schools/${id}/users`, {\n params\n })\n}\n\nfunction getClassrooms() {\n return axios.get('/api/classrooms')\n\n}\n\nfunction getClassroom({id}, {}, params) {\n return axios.get(`api/classrooms/${id}`, {\n params\n })\n}\n\nfunction postClassroom({}, formData) {\n return axios.post(`api/classrooms`, formData)\n}\n\nfunction putClassroom({id}, formData) {\n return axios.put(`api/classrooms/${id}`, formData)\n}\n\nfunction deleteClassroom({id}) {\n return axios.delete(`api/classrooms/${id}`)\n}\n\nfunction joinClassroom({}, formData) {\n return axios.post(`api/classrooms/join`, formData)\n}\n\nfunction joinSchool({}, formData) {\n return axios.post(`api/schools/join`, formData)\n}\n\nfunction removeStudentFromClassroom({id}, formData) {\n return axios.post(`api/classrooms/${id}/remove-student`, {\n ...formData,\n include_history_since_last_interview: 1\n })\n}\n\nfunction postTeacherChallenge({id}, formData) {\n return axios.post(`api/classrooms/${id}/challenges`, {\n ...formData,\n include_history_since_last_interview: 1\n })\n}\n\nexport const schoolsService = {\n removeStudentFromClassroom,\n postTeacherChallenge,\n getSchools,\n getSchool,\n searchUser,\n getClassrooms,\n getClassroom,\n postClassroom,\n putClassroom,\n deleteClassroom,\n joinClassroom,\n joinSchool,\n}\n\n","import {apiConstants} from \"@data/constants/apiConstants\"\nimport {studyProgramsService} from \"@data/services/studyProgramsService\";\n\n// ** Initial State\nconst initialState = {\n studyPrograms: [],\n}\n\nfunction studyPrograms(state = initialState, action) {\n switch (action.type) {\n\n case studyProgramsService.getStudyProgramsAsStudent.name + apiConstants._SUCCESS:\n case studyProgramsService.getStudyProgramsAsTutor.name + apiConstants._SUCCESS:\n return {\n ...state,\n studyPrograms: action.data\n }\n case studyProgramsService.indexPaginatedStudyPrograms.name + apiConstants._SUCCESS:\n let studyPrograms = []\n if (action.data?.meta?.current_page === 1) {\n studyPrograms = action.data?.study_programs\n } else {\n studyPrograms = state.studyPrograms?.concat(action.data?.study_programs)\n }\n return {\n ...state,\n studyPrograms: studyPrograms\n }\n case studyProgramsService.deleteStudyProgram.name + apiConstants._SUCCESS:\n return {\n ...state,\n studyPrograms: state.studyPrograms.filter(x => x.id !== action.routeParams.id)\n }\n case studyProgramsService.newStudyProgram.name + apiConstants._SUCCESS:\n case studyProgramsService.replicateStudyProgram.name + apiConstants._SUCCESS:\n return {\n ...state,\n studyPrograms: [action.data, ...state.studyPrograms]\n }\n case studyProgramsService.updateStudyProgram.name + apiConstants._SUCCESS:\n return {\n ...state,\n studyPrograms: state.studyPrograms.map(x => x.id === action.routeParams.id ? action.data : x)\n }\n default:\n return state\n }\n}\n\nexport default studyPrograms\n","import axios from \"axios\"\n\nfunction getStudyProgramsAsStudent() {\n return axios.get('/api/v1/study-programs')\n}\n\nfunction getStudyProgramsAsTutor({id}, {}, params) {\n if (!id)\n return axios.get(`/api/v1/students/study-programs`, {params})\n else\n return axios.get(`/api/v1/students/${id}/study-programs`, {params})\n}\n\nfunction indexPaginatedStudyPrograms() {\n return axios.get(`/api/backoffice/study-programs`)\n}\n\nfunction deleteStudyProgram({id}) {\n return axios.delete(`/api/backoffice/study-programs/${id}`)\n}\n\nfunction newStudyProgram({}, formData) {\n return axios.post(`/api/backoffice/study-programs`, formData)\n}\n\nfunction updateStudyProgram({id}, formData) {\n return axios.put(`/api/backoffice/study-programs/${id}`, formData)\n}\n\nfunction replicateStudyProgram({id}, formData) {\n return axios.post(`/api/backoffice/study-programs/${id}/replicate`, formData)\n}\n\nexport const studyProgramsService = {\n getStudyProgramsAsStudent,\n getStudyProgramsAsTutor,\n indexPaginatedStudyPrograms,\n deleteStudyProgram,\n newStudyProgram,\n updateStudyProgram,\n replicateStudyProgram\n}\n","import {apiConstants} from \"../../../constants/apiConstants\";\nimport {backOfficeService} from \"../../../services/backOfficeService\";\nimport {roomService} from \"@data/services/roomService\";\nimport {trialSessionsService} from \"@data/services/trialSessionsService\";\n\n// ** Initial State\nconst initialState = {\n liveReports: [],\n liveOccurrences: [],\n liveSessions: [],\n liveSession: {},\n rooms: [],\n appStats: null,\n pendingStudents: {},\n trialSessionsSlots: []\n};\n\nexport function backOffice(state = initialState, action) {\n switch (action.type) {\n case trialSessionsService.getTrialSessionSlots.name + apiConstants._SUCCESS:\n case trialSessionsService.newTrialSessionSlot.name + apiConstants._SUCCESS:\n case trialSessionsService.putTrialSessionSlot.name + apiConstants._SUCCESS:\n case trialSessionsService.deleteTrialSessionSlot.name + apiConstants._SUCCESS:\n return {\n ...state,\n trialSessionsSlots: action?.data,\n };\n case backOfficeService.getUsersStats.name + apiConstants._SUCCESS:\n return {\n ...state,\n pendingStudents: action?.data?.statistics?.pending_students,\n };\n case backOfficeService.deleteOccurrence.name + apiConstants._SUCCESS:\n return {\n ...state,\n liveOccurrences: state?.liveOccurrences?.filter(\n (occurrence) => occurrence?.id !== action?.routeParams?.id\n ),\n };\n case backOfficeService.editBilling.name + apiConstants._SUCCESS:\n return {\n ...state,\n liveOccurrences: state.liveOccurrences.map((occurrence) => {\n if (occurrence?.id === action?.data?.id) {\n return action?.data;\n }\n return occurrence;\n }),\n };\n case backOfficeService.getLiveOccurrences.name + apiConstants._SUCCESS:\n let liveOccurrences = [];\n if (action.data?.meta?.current_page === 1) {\n liveOccurrences = action.data?.live_occurrences;\n } else {\n liveOccurrences = state.liveOccurrences?.concat(\n action.data?.live_occurrences\n );\n }\n return {\n ...state,\n liveOccurrences,\n };\n case backOfficeService.getLiveReports.name + apiConstants._SUCCESS:\n let liveReports = [];\n if (action.data?.meta?.current_page === 1) {\n liveReports = action.data?.live_reports;\n } else {\n liveReports = state.liveReports?.concat(action.data?.live_reports);\n }\n return {\n ...state,\n liveReports: liveReports,\n };\n\n case backOfficeService.getApplicationStatistics.name +\n apiConstants._SUCCESS:\n return {\n ...state,\n appStats: action?.data,\n };\n case backOfficeService.newLiveSession.name + apiConstants._SUCCESS:\n case roomService.addMultipleSessions.name + apiConstants._SUCCESS:\n return {\n ...state,\n liveSessions: action?.data?.live_sessions ?? [\n ...state.liveSessions,\n action?.data,\n ],\n };\n\n case backOfficeService.getLiveSessions.name + apiConstants._SUCCESS:\n let sessions = [];\n // console.log(\"meta\", action.data)\n if (action.data?.meta?.current_page === 1) {\n // refresh\n sessions = action.data?.live_sessions;\n } else {\n // concat\n sessions = state.liveSessions.concat(action.data?.live_sessions);\n }\n return {\n ...state,\n liveSessions: sessions,\n };\n\n case backOfficeService.deleteLiveSession.name + apiConstants._SUCCESS:\n return {\n ...state,\n rooms: state?.rooms?.map((room) => {\n return {\n ...room,\n live_sessions: room?.live_sessions?.filter(\n (session) => action.routeParams?.id !== session?.id\n ),\n };\n }),\n };\n /* case backOfficeService.addUsersLive.name + apiConstants._SUCCESS:\n case backOfficeService.deleteUsersFromLive.name + apiConstants._SUCCESS:\n const count = action?.data?.students_count ?? action?.data?.live_session?.students_count\n return {\n ...state,\n liveSession: action?.data?.live_session ?? action?.data,\n liveSessions: state.liveSessions.map((session) => {\n if (session?.id === (action?.data?.live_session?.id ?? action?.data?.id)) {\n return action?.data?.live_session ?? action?.data\n }\n return session\n }),\n rooms: state?.rooms?.map((room) => {\n if (room?.live_sessions?.find((session) => session?.id === (action?.data?.live_session?.id ?? action?.data?.id)))\n return {\n ...room,\n students_count: room?.students_count + (count - room?.live_sessions?.find((session) => session?.id === (action?.data?.live_session?.id ?? action?.data?.id))?.students_count),\n live_sessions: room?.live_sessions?.map((session) => {\n if (session?.id === (action?.data?.live_session?.id ?? action?.data?.id)) {\n return action?.data?.live_session ?? action?.data\n }\n return session\n })\n }\n return room\n })\n }*/\n case backOfficeService.reschedule.name + apiConstants._SUCCESS:\n case backOfficeService.replaceCurrentTutor.name + apiConstants._SUCCESS:\n case backOfficeService.resetReschedulingsForLiveSession.name + apiConstants._SUCCESS:\n return {\n ...state,\n liveSession: action?.data,\n };\n case backOfficeService.requestSubstitution.name + apiConstants._SUCCESS:\n case backOfficeService.acceptSubstitution.name + apiConstants._SUCCESS:\n const sub = state?.liveSession?.substitutions?.find(\n (substitution) => substitution?.id === action?.data?.id\n );\n return {\n ...state,\n liveSession: {\n ...state?.liveSession,\n substitutions: sub\n ? state?.liveSession?.substitutions?.map((substitution) => {\n if (substitution?.id === action?.data?.id) {\n return action?.data;\n }\n return substitution;\n })\n : state?.liveSession?.substitutions?.concat(action?.data),\n next_occurrences: state?.liveSession?.next_occurrences?.map(\n (occurrence) => {\n if (occurrence?.date === action?.data?.date?.slice(0, -3)) {\n return {\n ...occurrence,\n substitution_id: action?.data?.id,\n };\n }\n return occurrence;\n }\n ),\n },\n };\n case backOfficeService.addUsersLive.name + apiConstants._SUCCESS:\n case backOfficeService.deleteUsersFromLive.name + apiConstants._SUCCESS:\n case backOfficeService.getLiveSessionAdmin.name + apiConstants._SUCCESS:\n case backOfficeService.updateLiveSession.name + apiConstants._SUCCESS:\n case backOfficeService.removeSubstitution.name + apiConstants._SUCCESS:\n case backOfficeService.cancelTemporaryUser.name + apiConstants._SUCCESS:\n return {\n ...state,\n liveSession: action?.data?.live_session ?? action?.data,\n liveSessions: state.liveSessions.map((session) => {\n if (\n session?.id === (action?.data?.live_session?.id ?? action?.data?.id)\n ) {\n return action?.data?.live_session ?? action?.data;\n }\n return session;\n }),\n rooms: state?.rooms?.map((room) => {\n return {\n ...room,\n live_sessions: room?.live_sessions?.map((session) => {\n if (\n session?.id ===\n (action?.data?.live_session?.id ?? action?.data?.id)\n ) {\n return action?.data?.live_session ?? action?.data;\n }\n return session;\n }),\n };\n }),\n };\n case roomService.getRooms.name + apiConstants._SUCCESS:\n let rooms = [];\n if (action.data?.meta?.current_page === 1) {\n rooms = action.data?.live_rooms;\n } else {\n rooms = state.rooms.concat(action.data?.live_rooms);\n }\n return {\n ...state,\n rooms: rooms,\n };\n case roomService.newRoom.name + apiConstants._SUCCESS:\n return {\n ...state,\n rooms: action?.data?.live_rooms ?? [...state.rooms, action?.data],\n };\n case roomService.editRoom.name + apiConstants._SUCCESS:\n case roomService.addMembersToSessions.name + apiConstants._SUCCESS:\n case roomService.deleteRoom.name + apiConstants._SUCCESS:\n return {\n ...state,\n rooms: state.rooms.map((room) => {\n if (room?.id === (action?.data?.live_room?.id ?? action?.data?.id)) {\n return action?.data?.live_room ?? action?.data;\n }\n return room;\n }),\n };\n default:\n return state;\n }\n}\n\nexport default backOffice;\n","import axios from \"axios\";\n\nfunction getAllUsers() {\n return axios.get(`api/users`);\n}\n\nfunction getUserBackoffice({id}) {\n return axios.get(`/api/users/${id}`);\n}\n\nfunction updateStudent({routeParams}, {formattedValues}) {\n return axios.put(`/api/users/${routeParams}/profile`, formattedValues);\n}\n\nfunction deleteUser({id}) {\n return axios.delete(`/api/users/${id}`)\n}\n\nfunction resetPasswordForUser({id}) {\n return axios.post(`/api/users/${id}/reset-password`)\n}\n\nfunction exportData({slug}) {\n return axios.get(`/api/v1/backoffice/export/${slug}`)\n}\n\nfunction postNewTrialLiveSessionChoiceBackoffice({id}, values) {\n return axios.post(`/api/users/${id}/trial-slots`, values)\n}\n\nfunction updateTutor({routeParams}, {values}) {\n return axios.put(`/api/users/${routeParams}/profile`, values);\n}\n\nfunction updateSlotTutor({routeParams}, {formattedValues}) {\n return axios.put(\n `/api/users/${routeParams}/interview-slots`,\n formattedValues\n );\n}\n\nfunction validateTutor({id}) {\n return axios.post(`api/tutors/${id}/validate`);\n}\n\nfunction updateUserBackoffice({routeParams}, values) {\n return axios.post(`/api/users/${routeParams}?_method=PUT`, values);\n}\n\nfunction updateStudentSlotForTutor({tutorId, slotId}, formattedValues) {\n return axios.put(\n `/api/users/${tutorId}/interview-slots/${slotId}`,\n formattedValues\n );\n}\n\nfunction updateSlotsTutor({routeParams}, {formattedValues}) {\n return axios.put(\n `/api/users/${routeParams}/interview-slots`,\n formattedValues\n );\n}\n\nfunction getTutors(params) {\n return axios.get(\"/api/tutors\", {params});\n}\n\nfunction assignTutorAndSlot({user_id}, data) {\n return axios.post(`/api/users/${user_id}/assign-tutor-and-slot`, data);\n}\n\nfunction assignTutorAndLiveSlots({user_id}, data) {\n return axios.post(`/api/users/${user_id}/assign-tutor-and-lives`, data);\n}\n\nfunction assignTutor({id}, data) {\n return axios.put(`/api/users/${id}/tutor`, data);\n}\n\nfunction changePrivileges({id}, data) {\n return axios.put(`/api/users/${id}/privileges`, data);\n}\n\nfunction updatePrioritizedSchoolSubjects({id}, data) {\n return axios.put(`/api/users/${id}/prioritized-school-subjects`, data);\n}\n\nfunction updateChannel({id}, data) {\n return axios.put(`/api/users/${id}/channel`, data);\n}\n\nfunction updateAutonomyLevel({id}, data) {\n return axios.put(`/api/users/${id}/autonomy-level`, data);\n}\n\nfunction setTrialConfirmed({id}, data) {\n return axios.put(`/api/users/${id}/trial-confirmed`, data);\n}\n\nfunction creditAbsenceRecovery({id}, data) {\n return axios.post(`/api/users/${id}/credit-absence-recovery`, data);\n}\n\nfunction putStudentAccount({user_id}, values) {\n return axios.put(`api/backoffice/users/${user_id}/student-account`, values);\n}\n\nfunction getAnalytics({}, {}, params) {\n return axios.get(`api/analytics`, {params});\n}\n\nfunction getLiveSessions({}, {}, params) {\n return axios.get(`api/backoffice/live-sessions`, {params});\n}\n\nfunction getLiveSessionAdmin({id}, {}, params) {\n return axios.get(`api/backoffice/live-sessions/${id}`, {\n params\n });\n}\n\nfunction newLiveSession({}, formData) {\n return axios.post(`api/backoffice/live-sessions`, formData);\n}\n\nfunction updateLiveSession({id}, formData) {\n return axios.put(`api/backoffice/live-sessions/${id}`, formData);\n}\n\nfunction deleteLiveSession({id}) {\n return axios.delete(`api/backoffice/live-sessions/${id}`);\n}\n\nfunction resetReschedulingsForLiveSession({id}) {\n return axios.post(`api/backoffice/live-sessions/${id}/reset-reschedulings`);\n}\n\nfunction deleteUsersFromLive({id}, formData) {\n return axios.post(\n `api/backoffice/live-sessions/${id}/delete-users`,\n formData\n );\n}\n\nfunction addUsersLive({id}, formData) {\n return axios.post(`api/backoffice/live-sessions/${id}/add-users`, formData);\n}\n\nfunction searchUser({}, {}, params) {\n return axios.get(`api/backoffice/users`, {params});\n}\n\nfunction searchUserFormStep({}, {}, params) {\n return axios.get(`api/backoffice/users`, {params});\n}\n\nfunction searchAdmins({}, {}, params) {\n return axios.get(`api/backoffice/users?roles=admin`, {params});\n}\n\nfunction searchTutors({}, {}, params) {\n return axios.get(`api/backoffice/users?roles=tutor`, {params});\n}\n\nfunction putTutorAccount({user_id}, values) {\n return axios.put(`api/backoffice/users/${user_id}/tutor-account`, values);\n}\n\nfunction getAppreciation({user_id}) {\n return axios.post(`api/users/${user_id}/generate-weekly-comment`);\n}\n\nfunction createWeeklyReport({user_id}, values) {\n return axios.post(`api/users/${user_id}/weekly-report`, values);\n}\n\nfunction sendWeeklyReport({report_id}, values) {\n return axios.post(`/api/weekly-reports/${report_id}/send`, values);\n}\n\nfunction newStudent({}, values) {\n return axios.post(`/api/v1/backoffice/users`, values);\n}\n\nfunction updateTutorSlots({user_id}, values) {\n return axios.put(`/api/backoffice/${user_id}/interview-slots`, values);\n}\n\nfunction updateSalary({id}, values) {\n return axios.post(`/api/tutors/${id}/update-salary`, values);\n}\n\nfunction updateMaxStudentsPerLive({id}, values) {\n return axios.post(`/api/tutors/${id}/max-students-per-live`, values);\n}\n\nfunction acceptNewStudents({id}, values) {\n return axios.post(`/api/tutors/${id}/accept-new-students`, values);\n}\n\nfunction assignAdmin({id}, values) {\n return axios.post(`/api/tutors/${id}/assign-admin`, values);\n}\n\nfunction reschedule({id}, values) {\n return axios.post(`/api/backoffice/live-sessions/${id}/reschedule`, values);\n}\n\nfunction requestSubstitution({id}, values) {\n return axios.post(\n `/api/backoffice/live-sessions/${id}/request-substitution`,\n values\n );\n}\n\nfunction acceptSubstitution({id}, values) {\n return axios.post(\n `/api/backoffice/substitutions/${id}/accept-substitution`,\n values\n );\n}\n\nfunction removeSubstitution({id}) {\n return axios.delete(`/api/backoffice/substitutions/${id}`);\n}\n\nfunction getApplicationStatistics({}, {}, params) {\n return axios.get(`api/backoffice/app-statistics`, {params});\n}\n\nfunction getLiveReports({}, {}, params) {\n return axios.get(`api/v1/backoffice/live-reports`, {params});\n}\n\nfunction getLiveOccurrences({}, {}, params) {\n return axios.get(`api/backoffice/live-occurrences`, {params});\n}\n\nfunction editBilling({id}, values) {\n return axios.put(`/api/backoffice/live-occurrences/${id}`, values);\n}\n\nfunction deleteOccurrence({id}) {\n return axios.delete(`/api/backoffice/live-occurrences/${id}`);\n}\n\nfunction getUsersStats({}, {}) {\n return axios.get(`api/backoffice/users/statistics`);\n}\n\nfunction replaceCurrentTutor({id}, values) {\n return axios.post(`/api/backoffice/live-sessions/${id}/replace-current-tutor`, values)\n}\n\nfunction cancelTemporaryUser({id}) {\n return axios.delete(`/api/backoffice/temporary-live-assignments/${id}`)\n}\n\nfunction assignStudentsToTutor({}, data) {\n return axios.post(`/api/v1/backoffice/assign-students-to-tutor`, data);\n}\n\nfunction newStudentSubscription({ id }, values) {\n return axios.post(`/api/backoffice/users/${id}/create-subscription`, values);\n}\n\nfunction updateStudentSubscription({ id }, values) {\n return axios.post(`/api/backoffice/users/${id}/update-subscription`, values);\n}\n\nfunction cancelStudentSubscription({ id }, values) {\n return axios.post(`/api/backoffice/users/${id}/cancel-subscription`, values);\n}\n\nfunction updateStudentBalance({ id }, values) {\n return axios.post(`/api/backoffice/users/${id}/update-balance`, values);\n}\n\nfunction getSubscriptionInvoicePreview({ id }, {}, params) {\n return axios.get(`/api/backoffice/users/${id}/subscription-invoice-preview`, { params });\n}\n\nexport const backOfficeService = {\n updateSlotsTutor,\n validateTutor,\n getAllUsers,\n deleteUser,\n postNewTrialLiveSessionChoiceBackoffice,\n getUserBackoffice,\n updateSlotTutor,\n updateStudent,\n updateTutor,\n updateUserBackoffice,\n updateStudentSlotForTutor,\n assignTutorAndSlot,\n getTutors,\n putStudentAccount,\n putTutorAccount,\n getAppreciation,\n createWeeklyReport,\n sendWeeklyReport,\n getAnalytics,\n getLiveSessions,\n newLiveSession,\n getLiveSessionAdmin,\n deleteUsersFromLive,\n updateLiveSession,\n deleteLiveSession,\n resetReschedulingsForLiveSession,\n searchUser,\n searchUserFormStep,\n addUsersLive,\n assignTutorAndLiveSlots,\n updateTutorSlots,\n newStudent,\n assignTutor,\n changePrivileges,\n updatePrioritizedSchoolSubjects,\n updateChannel,\n updateAutonomyLevel,\n setTrialConfirmed,\n creditAbsenceRecovery,\n searchAdmins,\n searchTutors,\n updateSalary,\n acceptNewStudents,\n assignAdmin,\n reschedule,\n requestSubstitution,\n acceptSubstitution,\n updateMaxStudentsPerLive,\n removeSubstitution,\n getApplicationStatistics,\n getLiveReports,\n getLiveOccurrences,\n editBilling,\n deleteOccurrence,\n exportData,\n getUsersStats,\n replaceCurrentTutor,\n cancelTemporaryUser,\n assignStudentsToTutor,\n newStudentSubscription,\n cancelStudentSubscription,\n updateStudentBalance,\n getSubscriptionInvoicePreview,\n updateStudentSubscription,\n resetPasswordForUser\n};","import axios from \"axios\";\n\nfunction getTrialSessionSlots() {\n return axios.get(`api/v1/backoffice/trial-session-slots`);\n}\n\nfunction putTrialSessionSlot({id}, data) {\n return axios.post(\n `api/v1/backoffice/trial-session-slots/${id}?_method=PUT`,\n data\n );\n}\n\nfunction newTrialSessionSlot({id}, data) {\n return axios.post(\n `api/v1/backoffice/trial-session-slots`,\n data\n );\n}\n\nfunction deleteTrialSessionSlot({id}) {\n return axios.post(`api/v1/backoffice/trial-session-slots/${id}?_method=DELETE `);\n}\n\nexport const trialSessionsService = {\n getTrialSessionSlots,\n putTrialSessionSlot,\n newTrialSessionSlot,\n deleteTrialSessionSlot\n};\n","import { authService } from \"../../../services/authService\"\nimport { apiConstants } from \"../../../constants/apiConstants\"\nimport { tutorsService } from \"../../../services/tutorsService\"\nimport { studentsService } from \"../../../services/studentsService\"\nimport { activitiesService } from \"../../../services/activitiesService\"\nimport { interviewsService } from \"../../../services/interviewsService\"\nimport { findKeyByValue, updateDataKeys } from \"../../../utility/Utils\"\nimport { authConstants } from \"../../../constants/authConstants\"\nimport { challengesService } from \"../../../services/challengesService\"\nimport { achievementsService } from \"../../../services/achievementsService\"\nimport { schoolSubjectsService } from \"../../../services/schoolSubjectsService\"\nimport { shopService } from \"../../../services/shopService\"\nimport { RESET_ACTIVITIES_HISTORY } from \"../../../constants/activitiesConstants\"\nimport { schoolsService } from \"../../../services/schoolsService\"\nimport { subscriptionService } from \"../../../services/subscriptionService\"\nimport { messengerConstants } from \"../../../constants/messengerConstants\"\nimport { messengerService } from \"../../../services/messengerService\"\nimport { skillSetsService } from \"../../../services/skillSetsService\"\nimport { liveModeConstants } from \"../../../constants/liveModeConstants\"\nimport { SET_TODO_ACTIVITIES } from \"@data/constants/activitiesConstants\"\nimport { liveService } from \"@data/services/liveService\"\nimport { chaptersService } from \"@data/services/chaptersService\"\nimport { substitutionProposalsService } from \"@data/services/substitutionProposalsService\"\nimport { liveServiceV2 } from \"@data/services/liveServiceV2\"\nimport { attendanceFlagsService } from \"@data/services/attendanceFlagsService\"\n\nconst initialState = {}\n\nexport function currentUser(state = initialState, action) {\n switch (action.type) {\n\n case liveService.getAllMyNextLiveSessionsAsParent.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object?.live_sessions?.map(session => {\n const newSession = action.data?.live_sessions?.find(newSession => newSession.id === session.id)\n return newSession ? newSession : session\n }),\n },\n }\n case liveService.reportAbsenceAsStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object.live_sessions.map(session => ({\n ...session,\n attendance_flags: action.data?.id === session?.id ? action.data?.attendance_flags : session?.attendance_flags,\n })),\n },\n }\n case attendanceFlagsService.cancelAbsenceAsStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object.live_sessions.map(session => ({\n ...session,\n attendance_flags: session.attendance_flags.filter(flag => flag.id !== action?.routeParams?.id),\n })),\n },\n }\n case substitutionProposalsService.updateStatus.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n substitution_proposals: state.object?.substitution_proposals?.filter(\n (x) => x.id !== action.routeParams?.id,\n ),\n },\n }\n case liveService.moveSession.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object?.live_sessions?.map((session) => {\n return session.id === action.routeParams?.id\n ? {\n ...action.data,\n live_room: session.live_room,\n students: session.students,\n }\n : session\n }),\n },\n }\n\n case messengerConstants.IN_LIVE_MESSENGER_NOT_READ_COUNT:\n\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object?.live_sessions?.map(session => {\n const id = findKeyByValue(session.thread_ids, action.threadId)\n const currentCount = session.unread_private_messages_count[action.threadId === session.thread_id ? 0 : id]\n\n return action.threadId === session.thread_id ? {\n ...session,\n unread_messages_count: action?.data === 0 ? 0 : session.unread_messages_count + 1,\n } : id ? {\n ...session,\n unread_private_messages_count: {\n ...session.unread_private_messages_count,\n [id]: action?.data === 0 ? 0 : currentCount + 1,\n },\n } : session\n\n }),\n },\n }\n\n case liveModeConstants.ACTIVITY_FINALIZED:\n let userObject = null\n const session0 = state.object?.live_sessions?.find(\n (s) => s.id === action.sessionId,\n )\n\n // session0?.users?.map((u) => {\n // if (u.id === action?.studentId) {\n // userObject = {\n // ...u,\n // statistics: {\n // ...u.statistics,\n // today: {\n // ...u.statistics?.today,\n // activities: {\n // ...u.statistics?.today?.activities,\n // count: u.statistics?.today?.activities?.count + 1\n // }\n // }\n // }\n // };\n // return userObject;\n // //console.log(userObject)\n // }\n // });\n // const tab =\n // state.object.sessions?.length > 0\n // ? state.object.sessions\n // : state.object?.live_sessions;\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object?.live_sessions?.map((session) => {\n if (session?.id === action?.sessionId) {\n let users = session.users?.map((u) => {\n if (u?.id === action?.studentId) {\n return {\n ...u,\n statistics: {\n ...u.statistics,\n today: {\n ...u.statistics?.today,\n activities: {\n ...u.statistics?.today?.activities,\n count: u.statistics?.today?.activities?.count + 1,\n },\n },\n },\n }\n //console.log(userObject)\n }\n return u\n })\n return {\n ...session,\n users: users,\n }\n }\n return session\n }),\n },\n }\n case messengerConstants.IN_CHAT_MESSENGER_NOT_READ_COUNT:\n return {\n ...state,\n object: {\n ...state.object,\n unreadInChatMessagesCount:\n action?.data === 0\n ? 0\n : state.object?.unreadInChatMessagesCount + 1,\n },\n }\n // case messengerConstants.RESET_LIVE_MESSAGES_COUNT:\n // return {\n // ...state,\n // object: {\n // ...state.object,\n // //messages: state.object.messages?.concat([action.data])\n // // messages: [action.data]?.concat(state.object.messages),\n // live_sessions: state.object?.live_sessions.map(session => {\n // if (session.thread_id === action.threadId) {\n // return {\n // ...session,\n // unread_messages_count: 0\n // };\n // }\n //\n // return session;\n // })\n // }\n // }\n case messengerConstants.NEW_MESSAGE:\n return {\n ...state,\n object: {\n ...state.object,\n //messages: state.object.messages?.concat([action.data])\n new_message: action.data,\n // live_sessions: state.object?.live_sessions.map(session => {\n // if (session.thread_id === action.data.thread_id) {\n // // console.log(\"action.data.owner_id\", action.data.owner_id)\n // // console.log(\"state.object.id\", state.object.id)\n // return {\n // ...session,\n // unread_messages_count: (session.unread_messages_count ?? 0) + (action.data.owner_id !== state.object.id ? 1 : 0)\n // };\n // }\n //\n // return session;\n // })\n },\n }\n\n case authConstants.LOGOUT_401:\n case authService.logout.name + apiConstants._SUCCESS:\n case authService.revokeSanctumToken.name + apiConstants._SUCCESS:\n case authService.deleteAccount.name + apiConstants._SUCCESS:\n return {}\n\n case authService.registerV2.name + apiConstants._SUCCESS:\n case authService.registerTrialV2.name + apiConstants._SUCCESS:\n case authService.registerSpecialV2.name + apiConstants._SUCCESS:\n case authService.registerAndGetSanctumToken.name + apiConstants._SUCCESS:\n case authService.getSanctumToken.name + apiConstants._SUCCESS:\n return {\n // object: user\n object: !state.object ? action.data.user : updateDataKeys(action.data.user, state.object),\n }\n case challengesService.abandonChallenge.name + apiConstants._SUCCESS:\n case schoolSubjectsService.removeSchoolSubject.name + apiConstants._SUCCESS:\n case schoolSubjectsService.chooseSchoolSubject.name + apiConstants._SUCCESS:\n case authService.postNewTrialLiveSessionChoice.name + apiConstants._SUCCESS:\n case authService.postPrioritizedSchoolSubjects.name + apiConstants._SUCCESS:\n case authService.postStudentEvaluation.name + apiConstants._SUCCESS:\n case authService.postPrepareForTrial.name + apiConstants._SUCCESS:\n return {\n // object: user\n object: !state.object ? action.data : updateDataKeys(action.data, state.object),\n }\n\n case authService.emailVerify.name + apiConstants._SUCCESS:\n return {\n object: !state.object ? null : {\n ...state.object,\n is_verified: true,\n },\n }\n\n case shopService.purchase.name + apiConstants._SUCCESS:\n case authService.updateAvatarSelected.name + apiConstants._SUCCESS:\n case authService.updateUserProfile.name + apiConstants._SUCCESS:\n case authService.updateProfile.name + apiConstants._SUCCESS:\n case authService.updateStudentAccount.name + apiConstants._SUCCESS:\n case authService.updateTutorAccount.name + apiConstants._SUCCESS:\n case authService.onboardingViewed.name + apiConstants._SUCCESS:\n case authService.championIntroViewed.name + apiConstants._SUCCESS:\n case authService.getUser.name + apiConstants._SUCCESS:\n case authService.updateUser.name + apiConstants._SUCCESS:\n case authService.updateClass.name + apiConstants._SUCCESS:\n // case authService.resetPassword.name + apiConstants._SUCCESS:\n case authService.login.name + apiConstants._SUCCESS:\n case authService.register.name + apiConstants._SUCCESS:\n case authService.updateTitleSkillSet.name + apiConstants._SUCCESS:\n case tutorsService.updateSlot.name + apiConstants._SUCCESS:\n case authService.updateSlots.name + apiConstants._SUCCESS:\n case authService.updateStudentSlot.name + apiConstants._SUCCESS:\n case subscriptionService.subscribeToTrial.name + apiConstants._SUCCESS:\n case subscriptionService.subscribeToTrialV2.name + apiConstants._SUCCESS:\n case subscriptionService.submitTrialSlots.name + apiConstants._SUCCESS:\n case schoolsService.joinSchool.name + apiConstants._SUCCESS:\n case tutorsService.submitPersonalInfos.name + apiConstants._SUCCESS:\n case tutorsService.submitCompleteProfile.name + apiConstants._SUCCESS:\n\n // update each key that was sent by server\n const user = { ...state.object }\n Object.keys(action.data).map(key => {\n if (key === \"live_sessions\") { // hack for getUser that comes after getLiveSession, to keep all keys\n user[key] = action.data?.[key].map(session => {\n const previousSession = user?.[key]?.find(s => s.id === session.id) ?? {}\n return {\n ...previousSession,\n ...session,\n }\n })\n } else {\n user[key] = action.data[key]\n }\n })\n // console.log(action.data)\n\n return {\n object: user,\n // object: !state.object ? action.data : updateDataKeys(action.data, state.object)\n }\n\n // case messengerService.postMessages.name + apiConstants._SUCCESS:\n //\n // return {\n // ...state,\n // object: {\n // ...state.object,\n // messages: (state.object?.messages ?? [])?.concat([action.all_data])\n //\n //\n // }\n // }\n case tutorsService.updateNote.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object?.live_sessions.map(session => {\n session?.users?.forEach((user) => {\n user?.tutor_notes?.map(n => n.id === action.data?.id ? action.data : n)\n })\n return session\n }),\n tutor_notes: state.object?.tutor_notes?.map(n => n.id === action.data?.id ? action.data : n),\n },\n }\n case tutorsService.deleteNote.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object?.live_sessions.map(session => {\n session?.users?.forEach((user) => {\n //user?.tutor_notes?.filter(n => n?.id !== action.routeParams?.id)\n user?.tutor_notes?.filter(n => n?.id !== action.routeParams?.id)\n })\n return session\n }),\n tutor_notes: state.object?.tutor_notes?.filter(n => n?.id !== action.routeParams?.id),\n },\n }\n case tutorsService.postNote.name + apiConstants._SUCCESS:\n let sessions = []\n sessions = state.object?.live_sessions.map(session => {\n session?.users?.forEach(user => {\n if (user?.id === action?.data?.student_id) {\n user?.tutor_notes?.push(action?.data)\n }\n })\n return session\n })\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: sessions,\n tutor_notes: [action?.data].concat(state.object?.tutor_notes),\n },\n }\n case tutorsService.getNotes.name + apiConstants._SUCCESS:\n\n let newNotes = []\n\n if (action.data?.meta?.current_page === 1) { // refresh\n newNotes = action.data?.tutor_notes\n\n // console.log(\"page 1 reducer\", action.data?.meta)\n } else { // concat\n newNotes = state?.notes.concat(action.data?.tutor_notes)\n // console.log(\"page + reducer\", action.data?.meta)\n }\n\n return {\n ...state,\n object: {\n ...state.object,\n tutor_notes: newNotes,\n },\n }\n\n case liveService.getLiveSession.name + apiConstants._SUCCESS:\n case liveServiceV2.getLiveSessionV2.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n // conference_token: action.data?.conference_token,\n live_sessions: state.object?.live_sessions?.map(currentSession => {\n\n // hack to keep all keys for activities of users of each live session\n\n\n if (currentSession.id === action.data?.live_session?.id) {\n\n return {\n ...currentSession,\n ...action.data?.live_session,\n\n // concat or delete users according to action.data.live_session.users\n users: (currentSession.users?.filter(u => !!u && action.data?.live_session?.users?.map(x => x.id)?.includes(u.id))\n ?.map(currentUser => {\n\n const user = action.data?.live_session?.users?.find(user => user.id === currentUser.id)\n return {\n ...currentUser,\n ...user,\n todo_activities: currentUser?.todo_activities?.filter(a => !!a && user?.todo_activities?.map(x => x.id)?.includes(a.id))\n ?.map(a => {\n const activity = user?.todo_activities?.find(activity => activity.id === a.id)\n return {\n ...a,\n ...activity,\n }\n })?.concat(user?.todo_activities?.filter(a => !currentUser?.todo_activities?.map(x => x.id)?.includes(a.id)) ?? []),\n activities: currentUser?.activities?.filter(a => !!a && user?.activities?.map(x => x.id)?.includes(a.id))\n ?.map(a => {\n const activity = user?.activities?.find(activity => activity.id === a.id)\n return {\n ...a,\n ...activity,\n }\n })?.concat(user?.activities?.filter(a => !currentUser?.activities?.map(x => x.id)?.includes(a.id)) ?? []),\n }\n }) ?? [])?.concat((action.data?.live_session?.users?.filter(u => !(currentSession?.users ?? [])?.map(x => x.id)?.includes(u.id))) ?? []),\n }\n }\n\n return currentSession\n }),\n },\n }\n case schoolsService.getClassroom.name + apiConstants._SUCCESS:\n case schoolsService.putClassroom.name + apiConstants._SUCCESS:\n case schoolsService.removeStudentFromClassroom.name + apiConstants._SUCCESS:\n case schoolsService.postTeacherChallenge.name + apiConstants._SUCCESS:\n\n return {\n ...state,\n object: {\n ...state.object,\n classrooms: (state.object?.classrooms ?? [{ id: action.data?.id }])?.map(c => ((c?.id === action.data?.id) ? action.data : c)),\n },\n }\n\n case schoolsService.getClassrooms.name + apiConstants._SUCCESS:\n case schoolsService.deleteClassroom.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n classrooms: action.data,\n },\n }\n\n case schoolsService.postClassroom.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n classrooms: (state.object?.classrooms ?? [])?.concat([action.data]),\n },\n\n }\n\n case skillSetsService.getSkillSets.name + apiConstants._SUCCESS:\n case skillSetsService.markSkillSetEvolutionAsRead.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n skill_sets: action.data,\n },\n\n }\n\n case messengerConstants.INCREMENT_STUDENT_MESSENGER_NOT_READ_COUNT:\n\n return {\n ...state,\n object: {\n ...state.object,\n students: state.object.students?.map(st => {\n // console.log(action.studentId, st?.id?.toString)\n\n return action.studentId?.toString() !== st?.id?.toString() ? st : {\n ...st,\n student_messenger_not_read_count: (st?.student_messenger_not_read_count ?? 0) + 1,\n }\n }),\n },\n }\n\n\n case messengerConstants.INCREMENT_TUTOR_MESSENGER_NOT_READ_COUNT:\n return {\n ...state,\n object: {\n ...state.object,\n tutor_messenger_not_read_count: (state.object?.tutor_messenger_not_read_count ?? 0) + 1,\n },\n }\n\n case messengerService.getMarkRead.name + apiConstants._SUCCESS:\n\n // console.log(\"action.routeParams?.threadId\", action.routeParams?.threadId)\n\n return {\n ...state,\n object: {\n ...state.object,\n // the user is a student : check if it is the thread with his own tutor\n tutor_messenger_not_read_count: state.object?.tutor_messenger_thread_id === action.routeParams?.threadId\n ? 0\n : state.object?.tutor_messenger_thread_id,\n // the user is a tutor, update the thread with the student if found\n students: state.object?.students?.map(st => {\n return action.routeParams?.threadId !== st?.tutor_messenger_thread_id ? st : {\n ...st,\n student_messenger_not_read_count: 0,\n }\n }),\n // user or tutor, update the thread if found in live session\n live_sessions: state.object?.live_sessions?.map(session => {\n if (session.thread_id === action.routeParams?.threadId) {\n return {\n ...session,\n unread_messages_count: 0,\n }\n } else {\n const userId = findKeyByValue(session.thread_ids, action.routeParams?.threadId)\n\n return userId ? {\n ...session,\n unread_private_messages_count: {\n ...session?.unread_private_messages_count,\n [userId]: 0,\n },\n } : session\n }\n }),\n },\n }\n case challengesService.postChallengeAsTutor.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n students: state.object.students?.map(student => {\n\n return (student.id === action.routeParams?.studentId) ? {\n ...student,\n challenges: student?.challenges.concat([action.data?.new_challenge]),\n activities: student?.activities?.concat(action.data?.new_activities),\n } : student\n }),\n },\n\n }\n case liveModeConstants.SET_MESSAGES:\n return {\n ...state,\n object: {\n messages: state?.object?.messages?.push(action.newState),\n },\n\n }\n\n case messengerService.postImage.name + apiConstants._SUCCESS:\n case messengerService.postAudio.name + apiConstants._SUCCESS:\n case messengerService.getPageMessages.name + apiConstants._SUCCESS:\n case messengerService.getMessages.name + apiConstants._SUCCESS:\n\n let messenger = []\n const threadId = action.routeParams?.threadId\n if (action.all_data?.meta?.page_id === null) { // refresh\n messenger = action.data\n\n } else { // concat\n\n messenger = (state.object?.messages[threadId] ?? [])?.concat(action.data)\n }\n\n\n return {\n ...state,\n object: {\n ...state.object,\n messages: {\n ...state.object?.messages,\n [threadId]: messenger,\n },\n messageMeta: {\n ...state.object?.messageMeta,\n ...action.all_data?.meta,\n },\n },\n }\n\n // case schoolsService.joinSchool.name + apiConstants._SUCCESS:\n // return {\n // ...state,\n // object: {\n // ...state.object,\n // schools: (state.object?.schools ?? [])?.concat([action.data])\n // }\n //\n // }\n\n case schoolsService.joinClassroom.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n classrooms: (state.object?.classrooms ?? [])?.concat([action.data]),\n },\n\n }\n\n case studentsService.getStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n students: state.object.students?.map(student => student.id)?.includes(action.data.id)\n ? state.object.students?.map(student => {\n\n const u = student\n const user = action.data\n\n return (student.id === action.data.id)\n ? {\n ...u,\n ...user,\n todo_activities: (u?.todo_activities ?? [])?.filter(a => !!a && user?.todo_activities?.map(x => x.id)?.includes(a.id))\n ?.map(a => {\n const activity = user?.todo_activities?.find(activity => activity.id === a.id)\n return {\n ...a,\n ...activity,\n }\n })?.concat(user?.todo_activities?.filter(a => !u?.todo_activities?.map(x => x.id)?.includes(a.id)) ?? []) ?? [],\n activities: (u?.activities ?? [])?.filter(a => !!a && user?.activities?.map(x => x.id)?.includes(a.id))\n ?.map(a => {\n const activity = user?.activities?.find(activity => activity.id === a.id)\n return {\n ...a,\n ...activity,\n }\n })?.concat(user?.activities?.filter(a => !u?.activities?.map(x => x.id)?.includes(a.id)) ?? []) ?? [],\n }\n : student\n })\n : !state.object.students\n ? [action.data]\n : state.object.students?.concat([action.data]),\n live_sessions: state.object?.live_sessions?.map(session => {\n\n const user = action.data\n return {\n ...session,\n users: session.users?.map(u => u.id === action.data.id ? {\n ...u,\n ...user,\n todo_activities: (u?.todo_activities ?? [])?.filter(a => !!a && user?.todo_activities.map(x => x.id)?.includes(a.id))\n ?.map(a => {\n const activity = user?.todo_activities?.find(activity => activity.id === a.id)\n return {\n ...a,\n ...activity,\n }\n })?.concat(user?.todo_activities?.filter(a => !u?.todo_activities?.map(x => x.id)?.includes(a.id)) ?? []),\n activities: u?.activities?.filter(a => !!a && user?.activities.map(x => x.id)?.includes(a.id))\n ?.map(a => {\n const activity = user?.activities?.find(activity => activity.id === a.id)\n return {\n ...a,\n ...activity,\n }\n })?.concat(user?.activities?.filter(a => !u?.activities?.map(x => x.id)?.includes(a.id)) ?? []),\n } : u),\n }\n }),\n },\n }\n\n case challengesService.postChallengeAsStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n champion_intros_viewed_at: {\n ...state.object?.champion_intros_viewed_at,\n zoe: state.object?.champion_intros_viewed_at?.zoe ?? true,\n },\n challenges: (state.object?.challenges ?? [])?.concat([action.data?.new_challenge]),\n activities: (state.object?.activities ?? [])?.concat(action.data?.new_activities),\n },\n }\n\n case challengesService.getChallengeHistory.name + apiConstants._SUCCESS:\n case challengesService.getStudentChallengeHistory.name + apiConstants._SUCCESS:\n\n const studentId = action.routeParams?.id\n let challengeHistory = []\n let activityHistory = []\n\n if (action.data?.meta?.current_page === 1) { // refresh\n challengeHistory = action.data?.challenges\n activityHistory = action.data?.activities\n\n } else { // concat\n challengeHistory = state.object?.history?.challenges.concat(action.data?.challenges)\n activityHistory = state.object?.history?.activities.concat(action.data?.activities)\n }\n\n return {\n ...state,\n object: {\n ...state.object,\n history: {\n ...state.object.history,\n challenges: challengeHistory,\n activities: activityHistory,\n },\n students: state.object?.students?.map(s => {\n return s.id !== studentId ? s : {\n ...s,\n history: {\n ...state.object.history,\n challenges: challengeHistory,\n activities: activityHistory,\n },\n }\n }),\n },\n }\n\n case schoolSubjectsService.getSchoolSubjectHistory.name + apiConstants._SUCCESS:\n case schoolSubjectsService.getStudentSchoolSubjectHistory.name + apiConstants._SUCCESS:\n\n const stId = action.routeParams?.id\n let ssHistory = []\n let aHistory = []\n\n if (action.data?.meta?.current_page === 1) { // refresh\n ssHistory = action.data?.school_subjects\n aHistory = action.data?.activities\n\n } else { // concat\n ssHistory = state.object?.history?.school_subjects.concat(action.data?.school_subjects)\n aHistory = state.object?.history?.activities.concat(action.data?.activities)\n }\n\n return {\n ...state,\n object: {\n ...state.object,\n history: {\n ...state.object.history,\n school_subjects: ssHistory,\n activities: aHistory,\n },\n students: state.object?.students?.map(s => {\n return s.id !== stId ? s : {\n ...s,\n history: {\n ...state.object.history,\n school_subjects: ssHistory,\n activities: aHistory,\n },\n }\n }),\n },\n }\n\n\n case activitiesService.getFinishedActivities.name + apiConstants._SUCCESS:\n case activitiesService.getStudentFinishedActivities.name + apiConstants._SUCCESS:\n\n const stuId = action.routeParams?.id\n let finishedActivities = []\n let challenges = []\n\n // console.log(action.data?.meta?.current_page)\n\n if (action.data?.meta?.current_page === 1) { // refresh\n finishedActivities = action.data?.activities\n challenges = action.data?.challenges\n\n // console.log(\"page 1 reducer\", action.data?.meta)\n } else { // concat\n finishedActivities = state.object?.history?.activities.concat(action.data?.activities)\n challenges = state.object?.history?.challenges.concat(action.data?.challenges)\n\n // console.log(\"page + reducer\", action.data?.meta)\n }\n\n return {\n ...state,\n object: {\n ...state.object,\n history: {\n ...state.object.history,\n activities: finishedActivities,\n challenges: challenges,\n },\n students: state.object?.students?.map(s => {\n return s.id !== stuId ? s : {\n ...s,\n history: {\n ...state.object.history,\n activities: finishedActivities,\n challenges: challenges,\n },\n }\n }),\n live_sessions: state.object?.live_sessions?.map(session => {\n return {\n ...session,\n users: session.users?.map(u => {\n return u.id !== stuId ? u : {\n ...u,\n history: {\n ...state.object.history,\n activities: finishedActivities,\n challenges: challenges,\n },\n }\n }),\n }\n }),\n },\n }\n\n case RESET_ACTIVITIES_HISTORY:\n\n const sId = action?.studentId ?? null\n\n return {\n ...state,\n object: {\n ...state.object,\n history: {\n ...state.object.history,\n activities: [],\n },\n students: state.object?.students?.map(s => {\n return s.id !== sId ? s : {\n ...s,\n history: {\n ...state.object.history,\n activities: [],\n },\n }\n }),\n },\n }\n\n case activitiesService.getActivitiesForReview.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n pending_reviews_count: action.data?.pending_reviews_count,\n },\n }\n\n case activitiesService.reviewActivity.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n pending_reviews_count: state.object?.pending_reviews_count > 0 ? state.object?.pending_reviews_count - 1 : 0,\n },\n }\n\n //** TO DO\n case SET_TODO_ACTIVITIES:\n\n const todoStudentId = action?.todoActivities?.[0]?.student_id\n\n return {\n ...state,\n object: {\n ...state.object,\n todo_activities: action.todoActivities,\n students: state.object?.students?.map((s) => (s?.id !== todoStudentId) ? s : {\n ...s,\n todo_activities: action.todoActivities,\n }),\n live_sessions: state.object?.live_sessions?.map((ls) => !ls?.users?.map(u => u?.id)?.includes(todoStudentId) ? ls : {\n ...ls,\n users: ls?.users?.map(u => u?.id !== todoStudentId ? u : {\n ...u,\n todo_activities: action.todoActivities,\n }),\n }),\n },\n }\n case activitiesService.updateActivityTodo.name + apiConstants._SUCCESS:\n case activitiesService.getActivity.name + apiConstants._SUCCESS:\n case activitiesService.lockActivity.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n todo_activities: state.object.todo_activities?.map(todo => ((todo?.id === action?.data?.id) ? action?.data : todo)),\n students: state.object?.students?.map((s) => (s.id !== action?.data?.student_id) ? s : {\n ...s,\n todo_activities: s?.todo_activities?.map(todo => ((todo?.id === action?.data?.id) ? action?.data : todo)),\n }),\n live_sessions: state.object?.live_sessions?.map((ls) => {\n return !ls?.users?.map(u => u?.id)?.includes(action?.data?.student_id) ? ls : {\n ...ls,\n users: ls?.users?.map(u => u?.id !== action?.data?.student_id ? u : {\n ...u,\n todo_activities: u?.todo_activities?.map(todo => ((todo?.id === action?.data?.id) ? action?.data : todo)),\n }),\n }\n }),\n },\n }\n\n case chaptersService.studentChapterFeelings.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n ongoing_student_chapters: state.object?.ongoing_student_chapters?.map(x => x?.id === action?.data?.id ? action?.data : x),\n\n },\n }\n\n case activitiesService.activityTodoAsTutor.name + apiConstants._SUCCESS:\n case messengerService.postActivity.name + apiConstants._SUCCESS:\n case messengerService.postActivityStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n students: state.object.students.map((s) => (s.id !== action?.data?.student_id) ? s : {\n ...s,\n todo_activities: s?.todo_activities?.concat(action?.data),\n ongoing_student_chapters: s?.ongoing_student_chapters?.map(x => x?.id)?.includes(action?.data?.student_chapter?.id) ? s?.ongoing_student_chapters : s?.ongoing_student_chapters?.concat(action?.data?.student_chapter),\n }),\n live_sessions: state.object?.live_sessions?.map((ls) => {\n return !ls?.users?.map(u => u?.id)?.includes(action?.data?.student_id) ? ls : {\n ...ls,\n users: ls?.users?.map(u => u?.id !== action?.data?.student_id ? u : {\n ...u,\n todo_activities: u?.todo_activities?.concat(action?.data),\n ongoing_student_chapters: u?.ongoing_student_chapters?.map(x => x?.id)?.includes(action?.data?.student_chapter?.id) ? u?.ongoing_student_chapters : u?.ongoing_student_chapters?.concat(action?.data?.student_chapter),\n }),\n }\n }),\n },\n }\n case activitiesService.deleteCommonActivityTodo.name + apiConstants._SUCCESS:\n case activitiesService.activityTodoForStudents.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n live_sessions: state.object?.live_sessions.map(session => {\n if (session.id === action.data.live_session.id) {\n return action.data.live_session\n }\n\n return session\n }),\n },\n }\n case activitiesService.activityTodoAsStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n todo_activities: state.object.todo_activities?.concat(action?.data),\n ongoing_student_chapters: state.object?.ongoing_student_chapters?.map(x => x?.id)?.includes(action?.data?.student_chapter?.id) ? state.object?.ongoing_student_chapters : state.object?.ongoing_student_chapters?.concat(action?.data?.student_chapter),\n },\n }\n case activitiesService.deleteActivityTodo.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n todo_activities: state.object?.todo_activities?.filter(todo => todo?.id !== action.routeParams?.id),\n students: state.object?.students?.map((s) => {\n return {\n ...s,\n todo_activities: s.todo_activities?.filter(todo => todo?.id !== action.routeParams?.id),\n }\n }),\n live_sessions: state.object?.live_sessions?.map((ls) => {\n return {\n ...ls,\n users: ls?.users?.map(u => {\n return {\n ...u,\n todo_activities: u?.todo_activities?.filter(todo => todo?.id !== action.routeParams?.id),\n }\n }),\n }\n }),\n },\n }\n case activitiesService.deleteActivitiesTodoAsStudent.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n todo_activities: state.object?.todo_activities?.filter(todo => !action.data?.deleted_activity_ids?.includes(todo?.id)),\n },\n }\n case activitiesService.deleteActivitiesTodoAsTutor.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n students: state.object?.students?.map((s) => {\n return {\n ...s,\n todo_activities: s.todo_activities?.filter(todo => !action.data?.deleted_activity_ids?.includes(todo?.id)),\n }\n }),\n live_sessions: state.object?.live_sessions?.map((ls) => {\n return {\n ...ls,\n users: ls?.users?.map(u => {\n return {\n ...u,\n todo_activities: u?.todo_activities?.filter(todo => !action.data?.deleted_activity_ids?.includes(todo?.id)),\n }\n }),\n }\n }),\n },\n }\n case activitiesService.deleteActivityLog.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n todo_activities: state.object?.todo_activities?.map(activity => {\n return {\n ...activity,\n activity_logs: activity?.activity_logs?.filter(log => log?.id !== action.routeParams?.id),\n }\n }),\n },\n }\n case activitiesService.lockActivityV2.name + apiConstants._SUCCESS:\n case activitiesService.postActivityLogV1.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n todo_activities: state.object?.todo_activities?.map(activity => {\n return activity.id === action.data?.id ? action.data : activity\n }),\n },\n }\n case activitiesService.activityTodoIndexesAsStudent.name + apiConstants._SUCCESS:\n case activitiesService.activityTodoIndexesAsTutor.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n todo_activities: action?.data,\n },\n }\n case activitiesService.getActivities.name + apiConstants._SUCCESS:\n\n // console.log(action?.data)\n\n const updateActivityIfFoundInResponse = a => {\n return action.data?.find(x => x?.id === a?.id) ?? a\n }\n\n // console.log('activity',action.data)\n // console.log('new activities',newActivities)\n\n return {\n ...state,\n object: {\n ...state.object,\n activities: state.object?.activities?.map(updateActivityIfFoundInResponse),\n history: {\n ...state.object.history,\n activities: state.object?.history?.activities?.map(updateActivityIfFoundInResponse),\n },\n students: state.object?.students?.map(s => {\n return !action.data?.find(x => x?.student_id === s?.id) ? s : {\n ...s,\n activities: s?.activities?.map(updateActivityIfFoundInResponse),\n todo_activities: s?.todo_activities?.map(updateActivityIfFoundInResponse),\n history: {\n ...s?.history,\n activities: s?.history?.activities?.map(updateActivityIfFoundInResponse),\n },\n }\n }),\n live_sessions: state.object?.live_sessions?.map((ls) => {\n return !ls?.users?.map(u => u?.id)?.includes(action?.data?.[0]?.student_id) ? ls : {\n ...ls,\n users: ls?.users?.map(u => u?.id !== action?.data?.[0]?.student_id ? u : {\n ...u,\n activities: u?.activities?.map(updateActivityIfFoundInResponse),\n todo_activities: u?.todo_activities?.map(updateActivityIfFoundInResponse),\n history: {\n ...u?.history,\n activities: u?.history?.activities?.map(updateActivityIfFoundInResponse),\n },\n }),\n }\n }),\n },\n }\n\n case activitiesService.initActivity.name + apiConstants._SUCCESS:\n\n // if there is no user in the response, it is a true init success, else, it is like finalize\n if (!action.data?.user?.id) {\n const updateSingleActivity = activity => {\n return activity.id === action.data?.id ? action.data : activity\n }\n let newActivities = []\n const stateActivity = state.object?.activities?.find(x => x.id === action.data?.id)\n if (stateActivity) {\n newActivities = state.object?.activities?.map(updateSingleActivity)\n } else {\n newActivities = [...state.object?.activities]\n newActivities.push(action.data)\n }\n\n // console.log('activity',action.data)\n // console.log('new activities',newActivities)\n\n return {\n ...state,\n object: {\n ...state.object,\n activities: newActivities,\n },\n }\n }\n\n\n case activitiesService.readReview.name + apiConstants._SUCCESS:\n case activitiesService.finalizeActivity.name + apiConstants._SUCCESS:\n\n const u = { ...state.object }\n Object.keys(action.data?.user).map(key => {\n if (key !== \"live_sessions\") { // prevent bug during live session where live session data is erased\n u[key] = action.data?.user[key]\n }\n })\n\n const updateActivity = activity => {\n return activity.id === action.data?.activity?.id ? action.data?.activity : activity\n }\n\n const updateChallenge = challenge => {\n return challenge.id === action.data?.challenge?.id ? action.data?.challenge : challenge\n }\n\n return {\n object: {\n ...u,\n history: {\n ...u?.history,\n activities: [],\n challenges: u?.history?.challenges?.map(updateChallenge),\n },\n activities: action.data.user?.activities?.map(updateActivity),\n todo_activities: action.data.user?.todo_activities?.filter(activity => activity.id !== action.data?.activity?.id),\n skill_sets: action.data?.skill_sets,\n },\n // object: !state.object ? action.data : updateDataKeys(action.data, state.object)\n }\n\n case achievementsService.markAsRead.name + apiConstants._SUCCESS:\n // console.log(action.data)\n const updateAchievement = achievement => {\n return achievement.id === action.data?.id ? action.data : achievement\n }\n return {\n ...state,\n object: {\n ...state.object,\n achievements: state.object?.achievements?.map(updateAchievement),\n },\n }\n\n case tutorsService.chooseTutor.name + apiConstants._SUCCESS:\n return {\n object: action.data,\n }\n\n case studentsService.getStudents.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n students: action?.data?.map((s) => {\n return {\n ...s,\n todo_activities: state.object?.students?.find((student) => student?.id === s.id)?.todo_activities,\n challenges: state.object?.students?.find((student) => student?.id === s.id)?.challenges,\n }\n }),\n },\n }\n\n case challengesService.abandonChallengeAsTutor.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n students: state.object.students?.map(student => {\n\n return (student.id === action.routeParams?.studentId) ? action.data : student\n }),\n },\n\n }\n\n case interviewsService.interviewWeekComments.name + apiConstants._SUCCESS:\n case interviewsService.interviewGlobalComment.name + apiConstants._SUCCESS:\n case interviewsService.interviewFinalize.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n students: state.object?.students?.map(student => {\n return student?.id === action.data.student_id ? {\n ...student,\n interviews: student?.interviews.map(interview => {\n return interview?.id === action.data.id ? action.data : interview\n }),\n } : student\n\n }),\n },\n }\n case activitiesService.postMaterial.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n activities: state.object?.activities?.map(a => {\n return a?.id === action?.routeParams?.activity_id ? { ...a, material: action?.data } : a\n }),\n todo_activities: state.object?.todo_activities?.map(a => {\n return a?.id === action?.routeParams?.activity_id ? { ...a, material: action?.data } : a\n }),\n },\n }\n\n case activitiesService.putMaterial.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n activities: state.object?.activities?.map(a => {\n return a?.material?.id === action?.data?.id ? { ...a, material: action?.data } : a\n }),\n todo_activities: state.object?.todo_activities?.map(a => {\n return a?.material?.id === action?.data?.id ? { ...a, material: action?.data } : a\n }),\n },\n }\n\n case activitiesService.deleteMaterial.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n activities: state.object?.activities?.map(a => {\n return a?.material?.id === action?.routeParams?.id ? { ...a, material: null } : a\n }),\n todo_activities: state.object?.todo_activities?.map(a => {\n return a?.material?.id === action?.routeParams?.id ? { ...a, material: null } : a\n }),\n },\n }\n\n case authService.hasMobileSession.name + apiConstants._SUCCESS:\n return {\n ...state,\n object: {\n ...state.object,\n has_mobile_session: action.data?.has_mobile_session\n }\n }\n\n default:\n return state\n }\n}\n","import axios from \"axios\"\n\nfunction subscribeToNotifications(routeParams, {expo_token}) {\n\n return axios.post('api/exponent/devices/subscribe', {\n expo_token: expo_token\n })\n}\n\nfunction unsubscribeFromNotifications(routeParams, {expo_token}) {\n\n return axios.post('api/exponent/devices/unsubscribe', {\n expo_token: expo_token\n })\n}\n\nfunction getCsrfToken() {\n\n return axios.get('sanctum/csrf-cookie')\n\n}\n\nfunction getSanctumToken(routeParams, values) {\n\n return axios.post('api/sanctum/token', {\n email: values.email,\n password: values.password,\n device_name: values.device_name\n })\n}\n\nfunction onboardingViewed() {\n\n return axios.post('api/user/onboarding-viewed')\n}\n\nfunction sendMessageToTutor({ id }, formData, urlParams, onUploadProgress) {\n // console.log(\"urlParams : \",urlParams);\n // console.log(\"formData : \",formData);\n return axios.post(`api/v1/user/send-message-to-tutor`, formData, {\n // headers: {\n // \"Content-Type\": \"multipart/form-data\",\n // },\n onUploadProgress,\n });\n }\n\nfunction championIntroViewed({}, data) {\n\n return axios.post('api/user/champion-intro-viewed', data)\n}\n\nfunction registerAndGetSanctumToken(routeParams, values) {\n return axios.post('api/v1/register/token', values)\n}\n\nfunction registerV2(routeParams, values) {\n return axios.post('api/v2/register', values)\n}\n\nfunction registerTrialV2(routeParams, values) {\n return axios.post('api/v2/register-trial', values)\n}\n\nfunction registerSpecialV2(routeParams, values) {\n return axios.post('api/v2/register-special', values)\n}\n\nfunction registerWorkshopV2(routeParams, values) {\n return axios.post('api/v2/register-workshop', values)\n}\n\nfunction revokeSanctumToken(routeParams, values) {\n\n return axios.post('api/sanctum/token/revoke', {})\n}\n\nfunction login(routeParams, values) {\n\n return axios.post('api/login', {\n email: values.email,\n password: values.password,\n remember: values.remember\n }).then((response) => {\n\n return response\n\n })\n}\n\nfunction logout() {\n\n return axios.post('api/logout').then((data) => {\n // console.log(\"LOGOUT\")\n\n return data\n })\n}\n\nfunction register(routeParams, values) {\n return axios.post('api/register', values).then((response) => {\n // console.log('server response'+ response);\n\n return response\n })\n}\n\n\nfunction checkEmailAddress({}, values) {\n return axios.post('api/check-email-address', values)\n}\n\nfunction checkEmailAddressAuth({}, values) {\n return axios.post('api/check-email-address-auth', values)\n}\n\nfunction emailVerify({id, hash}, data, params) {\n\n return axios.get(`api/email/verify/${id}/${hash}`, {params})\n\n}\n\nfunction emailResend() {\n\n return axios.post('api/email/resend')\n\n}\n\nfunction sendResetPasswordLink(routeParams, {email}) {\n\n return axios.post('api/password/email', {\n email\n })\n\n}\n\nfunction resetPassword(routeParams, values) {\n\n return axios.post('api/password/reset', values)\n}\n\nfunction updateUser(routeParams, values) {\n\n return axios.post(`api/user?_method=PUT`, values)\n\n .then((response) => {\n\n return response\n })\n\n}\n\nfunction updateStudentAccount(routeParams, values) {\n return axios.put(`api/user/student-account`, values)\n}\n\nfunction updateTutorAccount(routeParams, values) {\n return axios.put(`api/user/tutor-account`, values)\n}\n\n\nfunction getUser() {\n\n return axios.get(`api/user`)\n\n}\n\nfunction updateProfile(routeParams, values, urlParams, onUploadProgress) {\n\n return axios.post(`api/user/profile?_method=PUT`, values, {\n headers: {\n \"Content-Type\": \"multipart/form-data\"\n },\n onUploadProgress\n })\n\n}\n\nfunction updateUserProfile(routeParams, values) {\n\n return axios.put(`api/user/profile`, values)\n .then((response) => {\n\n return response\n })\n\n}\n\nfunction updatePassword(routeParams, values) {\n return axios.put('api/user/password', values)\n}\n\nfunction updateAvatarSelected(routeParams, values) {\n return axios.post('api/user/avatar-selected?_method=PUT', values)\n}\n\nfunction deleteAccount() {\n return axios.delete('api/user')\n}\n\nfunction updateTitleSkillSet(routeParams, values) {\n return axios.put('api/v1/user/title-skill-set', values)\n}\n\nfunction updateSlots(routeParams, values) {\n return axios.put('/api/user/interview-slots', values)\n}\n\nfunction updateStudentSlot({slotId}, values) {\n return axios.put(`/api/user/interview-slots/${slotId}`, values)\n}\n\nfunction updateEmail({}, values) {\n return axios.put(`/api/user/email`, values)\n}\n\nfunction updateClass({}, values) {\n return axios.put(`/api/user/class`, values)\n}\n\nfunction hasMobileSession() {\n return axios.get(`/api/user/has-mobile-session`)\n}\n\nfunction getAvailableTrialLiveSessions() {\n return axios.get(`/api/v1/user/trial-slots`)\n}\n\nfunction postNewTrialLiveSessionChoice({}, values) {\n return axios.post(`/api/v1/user/trial-slots`, values)\n}\n\nfunction postConfirmTrial({}, values) {\n return axios.post(`/api/v1/user/confirm-trial`, values)\n}\n\nfunction postPrioritizedSchoolSubjects({}, values) {\n return axios.post(`/api/v1/user/prioritized-school-subjects?_method=PUT`, values)\n}\n\nfunction postStudentEvaluation({}, values) {\n return axios.post(`/api/v1/user/student-evaluation`, values)\n}\n\nfunction postPrepareForTrial({}, values) {\n return axios.post(`/api/v1/user/prepare-for-trial`, values)\n}\n\nexport const authService = {\n updateSlots,\n updateClass,\n championIntroViewed,\n subscribeToNotifications,\n unsubscribeFromNotifications,\n getCsrfToken,\n login,\n logout,\n register,\n checkEmailAddress,\n checkEmailAddressAuth,\n emailVerify,\n emailResend,\n sendResetPasswordLink,\n resetPassword,\n updateUser,\n updateProfile,\n updateUserProfile,\n updatePassword,\n updateStudentAccount,\n updateTutorAccount,\n updateAvatarSelected,\n getSanctumToken,\n registerAndGetSanctumToken,\n registerV2,\n registerTrialV2,\n registerSpecialV2,\n registerWorkshopV2,\n revokeSanctumToken,\n getUser,\n onboardingViewed,\n deleteAccount,\n updateTitleSkillSet,\n updateStudentSlot,\n updateEmail,\n getAvailableTrialLiveSessions,\n postNewTrialLiveSessionChoice,\n postConfirmTrial,\n postPrioritizedSchoolSubjects,\n postStudentEvaluation,\n postPrepareForTrial,\n hasMobileSession,\n sendMessageToTutor\n}\n","import axios from \"axios\"\n\nfunction getTutors() {\n return axios.get('/api/tutors')\n}\n\nfunction chooseTutor({tutor_id}, data) {\n return axios.post(`/api/tutors/${tutor_id}/choose`, data)\n}\n\nfunction updateSlot(values) {\n\n return axios.put('/api/user/interview-slots', values)\n\n}\n\nfunction postNote({id}, values) {\n\n return axios.post(`/api/v1/users/${id}/tutor-notes`, values)\n\n}\n\nfunction getNotes({id}) {\n\n return axios.get(`/api/v1/users/${id}/tutor-notes`)\n\n}\n\nfunction updateNote({id}, values) {\n\n return axios.put(`/api/v1/tutor-notes/${id}`, values)\n\n}\n\nfunction deleteNote({id}) {\n\n return axios.delete(`/api/v1/tutor-notes/${id}`)\n\n}\n\n\nfunction getTestAnswers({id}) {\n\n return axios.get(`/api/tutor-candidates/${id}/test-answers`)\n\n}\n\nfunction submitApplicationEvaluation({id}, data) {\n\n return axios.post(`/api/tutor-candidates/${id}/submit-application-evaluation`, data)\n\n}\n\nfunction submitPersonalInfos({}, data) {\n\n return axios.put(`/api/v1/personal-infos`, data)\n\n}\n\nfunction submitCompleteProfile({}, data) {\n\n return axios.put(`/api/v1/update-tutor-profile`, data)\n\n}\n\nfunction getTestQuestions({}, {}, params) {\n\n return axios.get(`/api/v1/test-questions`, {params})\n\n}\n\nfunction submitTestAnswer({id}, data) {\n\n return axios.post(`/api/v1/app-questions/${id}/submit-answer`, data)\n\n\n}\n\nfunction submitQuestionViewed({id}) {\n\n return axios.post(`/api/v1/app-questions/${id}/submit-view`)\n\n\n}\n\nfunction getTutoringInvoices() {\n\n return axios.get(`/api/v2/tutoring-invoices`)\n\n}\n\nfunction acceptTrials({id}, data) {\n\n return axios.post(`/api/tutors/${id}/accept-trials`, data)\n\n}\n\nfunction getTutorLiveOccurrences({}, {}, params) {\n return axios.get(`api/v1/tutors/live-occurrences`, {params});\n}\n\nexport const tutorsService = {\n getTutors,\n chooseTutor,\n updateSlot,\n postNote,\n getNotes,\n updateNote,\n deleteNote,\n submitPersonalInfos,\n getTestQuestions,\n submitTestAnswer,\n submitQuestionViewed,\n getTestAnswers,\n submitApplicationEvaluation,\n submitCompleteProfile,\n getTutoringInvoices,\n acceptTrials,\n getTutorLiveOccurrences\n}\n","import axios from \"axios\"\n\nfunction getStudents() {\n return axios.get('/api/students')\n\n}\n\nfunction getStudent({id}) {\n return axios.get(`api/students/${id}`)\n //console.log(axios.get(`api/students/${ id_student }`))\n}\n\nfunction studentSurvey() {\n return axios.get('/api/student-survey')\n}\n\nfunction studentChangePaymentCollectionDay({}, data) {\n return axios.put(`/api/v2/subscribe/student-change-payment-collection-day`, data)\n}\n\nfunction addStudentSurvey(value) {\n return axios.post(`api/student-survey`, {...value})\n}\n\nexport const studentsService = {\n getStudents,\n getStudent,\n studentSurvey,\n addStudentSurvey,\n studentChangePaymentCollectionDay\n}\n","import axios from \"axios\"\n\nfunction interviewWeekComments({id}, formData) {\n return axios.post(`api/interviews/${id}/week-comments`, formData)\n}\n\nfunction interviewGlobalComment({id}, formData) {\n return axios.post(`api/interviews/${id}/global-comment`, formData)\n}\n\nfunction interviewFinalize({id}, formData) {\n return axios.post(`api/interviews/${id}/finalize`, formData)\n}\nfunction interviewTutorConnected({id}) {\n return axios.post(`api/interviews/${id}/tutor-connected`)\n}\n\nexport const interviewsService = {\n interviewWeekComments,\n interviewGlobalComment,\n interviewFinalize,\n interviewTutorConnected\n}\n\n","import { daysOptions } from \"@data/constants/formConstants\"\nimport moment from \"moment\"\nimport \"moment/locale/fr\"\nimport {\n congratsList,\n stepErrorList,\n stepFinishedList,\n} from \"../constants/activitiesConstants\"\n\n// compare app versions\nexport function versionCompare(v1, v2, options) {\n var lexicographical = options && options.lexicographical,\n zeroExtend = options && options.zeroExtend,\n v1parts = v1?.split(\".\"),\n v2parts = v2?.split(\".\")\n\n function isValidPart(x) {\n return (lexicographical ? /^\\d+[A-Za-z]*$/ : /^\\d+$/).test(x)\n }\n\n if (!v1parts.every(isValidPart) || !v2parts.every(isValidPart)) {\n return NaN\n }\n\n if (zeroExtend) {\n while (v1parts.length < v2parts.length) v1parts.push(\"0\")\n while (v2parts.length < v1parts.length) v2parts.push(\"0\")\n }\n\n if (!lexicographical) {\n v1parts = v1parts.map(Number)\n v2parts = v2parts.map(Number)\n }\n\n for (var i = 0; i < v1parts.length; ++i) {\n if (v2parts.length == i) {\n return 1\n }\n\n if (v1parts[i] == v2parts[i]) {\n continue\n } else if (v1parts[i] > v2parts[i]) {\n return 1\n } else {\n return -1\n }\n }\n\n if (v1parts.length != v2parts.length) {\n return -1\n }\n\n return 0\n}\n\n// ** Random int in interval\nexport function randomIntFromInterval(min, max) {\n // min and max included\n return Math.floor(Math.random() * (max - min + 1) + min)\n}\n\n// ** Gets unique items for a string array\nexport const uniq = (a) => {\n if (!a) return null\n\n return a.sort().filter(function (item, pos, ary) {\n return !pos || item !== ary[pos - 1]\n })\n}\n\n// ** Gets unique items for an array on for key\nexport const uniqWithKey = (a, key) => {\n if (!a) return null\n\n return a.sort().filter(function (item, pos, ary) {\n return !pos || item[key] !== ary[pos - 1][key]\n })\n}\n\n// ** Check what type of object it is\nexport const whatIsIt = (object) => {\n const stringConstructor = \"test\".constructor\n const arrayConstructor = [].constructor\n const objectConstructor = {}.constructor\n\n if (object === null) {\n return \"null\"\n }\n if (object === undefined) {\n return \"undefined\"\n }\n if (object.constructor === stringConstructor) {\n return \"String\"\n }\n if (object.constructor === arrayConstructor) {\n return \"Array\"\n }\n if (object.constructor === objectConstructor) {\n return \"Object\"\n }\n return \"Other\"\n}\n\n//find the key of a given value\nexport function findKeyByValue(obj, value) {\n for (let key in obj) {\n if (obj.hasOwnProperty(key) && obj[key] === value) {\n return key\n }\n }\n return null // Key not found for the given value\n}\n\n// ** Updates data keys smartly (without removing keys that are not in newObject)\nexport const updateDataKeys = (newObject, previousObject) => {\n const returnedObject = { ...previousObject }\n\n Object.keys(newObject).forEach((key) => {\n // console.log(`entered loop with key : ${key}`)\n\n if (whatIsIt(newObject[key]) === \"Array\") {\n // console.log(`key : ${key} is array`)\n\n returnedObject[key] = []\n\n newObject[key].forEach((newItem) => {\n let returnedItem\n\n if (\n whatIsIt(newObject[key]) !== \"Array\" &&\n whatIsIt(newItem) === \"Object\"\n ) {\n const prevItem = previousObject[key]?.find(\n (x) => x.id === newItem.id\n )\n if (prevItem)\n returnedItem = updateDataKeys(newItem, prevItem)\n else returnedItem = newItem\n } else {\n returnedItem = newItem\n }\n\n returnedObject[key].push(returnedItem)\n })\n } else if (whatIsIt(newObject[key]) === \"Object\") {\n // console.log(`key : ${key} is object`)\n returnedObject[key] = updateDataKeys(\n newObject[key],\n previousObject[key]\n )\n } else {\n // console.log(`key : ${key} is other`)\n returnedObject[key] = newObject[key]\n }\n })\n\n return returnedObject\n}\n\n// ** Average of array\nexport const calculateAverage = (a) => {\n if (a === null) return 0\n if (a?.length === 0) return 0\n\n let sum = 0\n for (let i = 0; i < a?.length; i++) {\n sum += parseInt(a[i], 10) //don't forget to add the base\n }\n\n return Math.round((sum / a?.length) * 10) / 10\n}\n\n// ** Checks if an object is empty (returns boolean)\nexport const isObjEmpty = (obj) => Object.keys(obj).length === 0\n\n// ** Returns K format from a number\nexport const kFormatter = (num) =>\n num > 999 ? `${(num / 1000).toFixed(1)}k` : num\n\n// ** Converts HTML to string\nexport const htmlToString = (html) => html.replace(/<\\/?[^>]+(>|$)/g, \"\")\n\n// ** Checks if the passed date is today\nconst isToday = (date) => {\n const today = new Date()\n return (\n /* eslint-disable operator-linebreak */\n date.getDate() === today.getDate() &&\n date.getMonth() === today.getMonth() &&\n date.getFullYear() === today.getFullYear()\n /* eslint-enable */\n )\n}\n\n// ** String truncation\nexport const truncateString = (str, num) => {\n // If the length of str is less than or equal to num\n // just return str--don't truncate it.\n if (str.length <= num) {\n return str\n }\n // Return str truncated with '...' concatenated to the end of str.\n return `${str.slice(0, num)}...`\n}\n\n// ** Capitalize\nexport const capitalize = (s) => {\n if (typeof s !== \"string\") return \"\"\n return s?.charAt(0).toUpperCase() + s?.slice(1)\n}\n\n// ** Return date options in period for Challenge form\nexport const dateOptionsInPeriod = (min, max) => {\n const currentMoment = moment().add(min, \"days\")\n\n const dateArray = []\n\n for (let i = min; i < max; i++) {\n currentMoment.add(1, \"day\")\n dateArray.push({\n value: currentMoment.format(\"YYYY-MM-DD\"),\n label: \"Dans \" + (i + 1) + \" jour\" + (i > 0 ? \"s\" : \"\"),\n description: capitalize(currentMoment.format(\"ddd DD MMMM\")),\n })\n }\n\n return dateArray\n}\n\n/**\n ** Format and return date in Humanize format\n ** Intl docs: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/format\n ** Intl Constructor: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat\n * @param {String|Moment} value date to format\n */\nexport const formatDate = (value) => {\n if (!value) return \"-\"\n\n if (typeof value === \"string\") return moment(value).format(\"DD MMMM YYYY\")\n\n return value.format(\"DD MMMM YYYY\")\n // return new Intl.DateTimeFormat('fr-FR', formatting).format(new Date(value))\n}\n// format minutes to hours and minutes\nexport const formatMinutes = (minutes) => {\n const hours = Math.floor(minutes / 60)\n const remainingMinutes = minutes % 60\n\n if (hours === 0) {\n return `${remainingMinutes} min`\n } else if (remainingMinutes === 0) {\n return `${hours}h`\n } else {\n return `${hours}h${padToTwo(remainingMinutes)}`\n }\n}\n// ** Returns short month of passed date\nexport const formatDateToMonthShort = (value, toTimeForCurrentDay = true) => {\n const date = new Date(value)\n let formatting = { month: \"short\", day: \"numeric\" }\n\n if (toTimeForCurrentDay && isToday(date)) {\n formatting = { hour: \"numeric\", minute: \"numeric\" }\n }\n\n return new Intl.DateTimeFormat(\"fr-FR\", formatting).format(new Date(value))\n}\n\n// ** Format relativeDate\nexport const formatRelativeDateTime = (value, dayMode = false) => {\n moment.locale(\"fr\")\n // const now = dayMode ? moment().startOf('day') : moment()\n const now = moment()\n // const date = dayMode ? moment(value).startOf('day') : moment(value)\n const date = moment(value)\n const diff = dayMode ? now.diff(date, \"days\") : now.diff(date, \"hours\")\n\n if (dayMode) {\n return date.fromNow()\n // else if (diff === -1) return \"Demain\"\n // else if (diff === 1) return \"Hier\"\n // else return \"Aujourd'hui\"\n } else {\n if (diff < 22) return date.fromNow()\n else return date.calendar()\n }\n}\n\n// ** Format as calendar day\nexport const formatCalendarMoment = (value, withTime = false) => {\n const withTimeAddendum = withTime ? \" [à] HH:mm\" : \"\"\n\n moment.locale(\"fr\")\n\n return capitalize(\n moment(value).calendar(null, {\n sameDay: \"HH:mm\",\n nextDay: \"[Demain]\",\n nextWeek: \"dddd [prochain]\",\n lastDay: \"[Hier]\" + withTimeAddendum,\n lastWeek: \"dddd [dernier]\" + withTimeAddendum,\n sameElse: \"dddd DD/MM\" + withTimeAddendum,\n })\n )\n}\n\n// ** Format full date time\nexport const formatFullDateTime = (value) => {\n moment.locale(\"fr\")\n const date = moment(value)\n const dayFormat = date.isSame(moment(), \"day\")\n ? \"[aujourd'hui à]\"\n : \"dddd D MMMM [à]\"\n\n return capitalize(date.format(`${dayFormat} HH:mm`))\n}\n\n// ** Format full date time\nexport const formatTime = (value) => {\n moment.locale(\"fr\")\n const date = moment(value)\n\n return date.format(\"HH:mm\")\n}\n\n// ** get week day from date\nexport const weekDayFromDate = (value) => {\n const date = moment(value)\n\n return date.locale(\"en\").format(\"dddd\")\n}\n\n// ** check if date is passed\nexport const isPassedDate = (value) => {\n const date = moment(value)\n\n return date.diff(moment()) <= 0\n}\n\n// ** check if we are in the weekend\nexport const isItWeekend = () => {\n const todayWeekDay = moment().format(\"dddd\")\n return todayWeekDay === \"samedi\" || todayWeekDay === \"dimanche\"\n}\n\n// ** React Select Theme Colors\nexport const selectThemeColors = (theme) => ({\n ...theme,\n colors: {\n ...theme.colors,\n primary25: \"#ffc80a1a\", // for option hover bg-color\n primary: \"#ffc80a\", // for selected option bg-color\n neutral10: \"#ffc80a\", // for tags bg-color\n neutral20: \"#ededed\", // for input border-color\n neutral30: \"#ededed\", // for input hover border-color\n },\n})\n\n// ** convert dataURL to file\nexport function dataURLtoFile(dataurl, filename) {\n const arr = dataurl?.split(\",\")\n const mime = arr[0].match(/:(.*?);/)[1]\n const bstr = atob(arr[1])\n let n = bstr.length\n const u8arr = new Uint8Array(n)\n\n while (n--) {\n u8arr[n] = bstr.charCodeAt(n)\n }\n\n console.error(new File([u8arr], filename, { type: mime }))\n\n return new File([u8arr], filename, { type: mime })\n}\n\n// ** Return random congrats message\nexport const congratsMessage = (task) => {\n const num = task?.id % congratsList.length\n return congratsList[num] ?? \"Terminé\"\n}\n\nexport const stepFinishedMessage = (index) => {\n const num = index % stepFinishedList.length\n return stepFinishedList[num] ?? \"Bravo !\"\n}\n\nexport const stepErrorMessage = (index) => {\n const num = index % stepErrorList.length\n return stepErrorList[num] ?? \"Raté !\"\n}\n\n// ** Pad to two digits for timer\nexport const padToTwo = (number) =>\n number <= 9 && number?.toString()?.length < 2 ? `0${number}` : number\nexport const displayTimeSecondsNoPad = (seconds) => {\n let minutes = 0\n if (seconds < 0) {\n seconds = 0\n }\n\n if (seconds < 60) {\n // return `00:${padToTwo(seconds)}:${(remainDeciseconds)}`;\n return `0:${seconds}`\n }\n let remainSeconds = seconds % 60\n minutes = (seconds - remainSeconds) / 60\n // return `${padToTwo(minutes)}:${padToTwo(remainSeconds)}:${(remainDeciseconds)}`;\n return `${minutes}:${remainSeconds}`\n}\n\nexport const hoursMinutesAndSecondsFromSeconds = (seconds) => {\n const duration = moment.duration(seconds, \"seconds\")\n const hours = duration.hours()\n const minutes = duration.minutes()\n const secondsLeft = duration.seconds()\n return [hours, minutes, secondsLeft]\n}\n\n// ** Display time based on seconds for timer\nexport const displayTimeSeconds = (seconds) => {\n let minutes = 0\n if (seconds < 0) {\n seconds = 0\n }\n\n if (seconds < 60) {\n // return `00:${padToTwo(seconds)}:${(remainDeciseconds)}`;\n return `00:${padToTwo(seconds)}`\n }\n let remainSeconds = seconds % 60\n minutes = (seconds - remainSeconds) / 60\n // return `${padToTwo(minutes)}:${padToTwo(remainSeconds)}:${(remainDeciseconds)}`;\n return `${padToTwo(minutes)}:${padToTwo(remainSeconds)}`\n}\n\nexport const toTimeString = (totalSeconds) => {\n const totalMs = totalSeconds * 1000\n const result = new Date(totalMs).toISOString().slice(11, 19)\n\n return result\n}\n\n// ** Make copy of time from object\nexport const copyObjectWithCurrentTimeAttribute = (attribute, obj) => {\n const copy = Object.assign({}, obj)\n copy[attribute] = moment().format(\"YYYY-MM-DD HH:mm:ss\")\n // console.log(copy)\n return copy\n}\n\n// ** Add timestamp to useForm field\nexport const addTimestampToField = (field, step, action, stepData = null) => {\n // console.log(\"step data passed \", stepData)\n\n field?.onChange([\n ...field?.value?.filter(\n (v) => v?.action !== action || v?.step !== step\n ),\n {\n action: action,\n step: step,\n created_at: moment().format(\"YYYY-MM-DD HH:mm:ss\"),\n step_data: stepData,\n },\n ])\n\n // console.log(\"timestamp \", field.value)\n}\n\n// ** Add form data to useForm field\nexport const addFormDataToField = (\n field,\n step,\n formData,\n action = \"step_form_sent\"\n) => {\n // console.log(field, step, formData, action)\n\n field?.onChange([\n ...field?.value?.filter(\n (v) => v?.action !== action || v?.step !== step\n ),\n {\n action: action,\n step: step,\n created_at: moment().format(\"YYYY-MM-DD HH:mm:ss\"),\n step_data: formData,\n },\n {\n action: \"step_finished\",\n step: step,\n created_at: moment().format(\"YYYY-MM-DD HH:mm:ss\"),\n // step_data: null\n },\n ])\n\n // console.log(field.value)\n}\n\n// ** Add work attachment to useForm field\nexport const addWorkAttachmentToField = (\n field,\n step,\n media = [],\n userId,\n type = \"jpg\",\n action = \"step_media_sent\"\n) => {\n // clean existing images\n let newFieldValue = [...field?.value]?.filter(\n (x) => x?.step !== step || x?.action !== action\n )\n\n media.forEach((x) => {\n newFieldValue = [\n ...newFieldValue,\n {\n action: action,\n step: step,\n work_attachment: {\n name: userId + \"_wa_\" + moment().format() + \".\" + type,\n type: type === \"jpg\" ? \"image/jpg\" : \"audio/m4a\",\n // uri: Platform.OS === 'ios' ? x.uri.replace('file://', '') : x.uri,\n uri: x?.uri,\n width: x?.width,\n height: x?.height,\n },\n created_at: moment().format(\"YYYY-MM-DD HH:mm:ss\"),\n },\n ]\n\n // console.log(\"media \", field.value)\n })\n\n field?.onChange(newFieldValue)\n}\n\n// ** Add media to useForm field\nexport const addMediaToField = (\n field,\n media = [],\n overwrite = false,\n prefix = null,\n type = \"png\"\n) => {\n // let newFieldValue = overwrite ? {file_keys: []} : {...field?.value}\n //\n // media.forEach(x => {\n //\n // const newKey = field?.name + \"_\" + newFieldValue?.file_keys?.length\n //\n // newFieldValue = {\n // ...newFieldValue,\n // file_keys: [...newFieldValue?.file_keys, newKey]\n // }\n // newFieldValue[newKey] = {\n // name: (prefix ?? newKey) + \"_\" + moment().format() + \".\" + type,\n // type: type === \"jpg\" ? \"image/jpg\" : \"audio/m4a\",\n // height: x?.height,\n // width: x?.width,\n // uri: x?.uri\n // }\n // })\n\n field?.onChange(\n media?.map((file) => {\n return {\n type: type === \"png\" ? \"image/png\" : \"audio/m4a\",\n height: file?.height,\n width: file?.width,\n uri: file?.uri,\n }\n })\n )\n}\n\n//display time mm:ss\nexport function secondsToHMS(seconds) {\n const minutes = Math.floor((seconds % 3600) / 60)\n const remainingSeconds = seconds % 60\n\n const mm = minutes < 10 ? `0${minutes}` : minutes\n const ss = remainingSeconds < 10 ? `0${remainingSeconds}` : remainingSeconds\n\n return `${mm} min ${ss} s`\n}\n\n// ** Display time nicely\nexport function niceTimeFromSeconds(duration) {\n if (duration < 3600)\n return [\n Math.floor(duration / 60),\n plr(\"minute\", Math.floor(duration / 60)),\n ]\n else {\n const hours = Math.floor(duration / 3600)\n const minutes =\n Math.floor((duration - hours * 3600) / 60) > 0\n ? Math.floor((duration - hours * 3600) / 60)\n : \"\"\n return [duration ? `${hours}h${minutes}` : \"0\", \"temps\"]\n }\n}\n\n// ** Get last item of an array\nexport function lastItem(mArray) {\n return mArray?.[mArray?.length - 1]\n}\n\nexport function createArray(start, end, step = 1) {\n return Array.from(\n { length: end - start + 1 },\n (_, index) => start + index * step\n )\n}\n\n// ** Get path to array\nfunction leaf(obj, path) {\n path = path.split(\".\")\n let res = obj\n for (let i = 0; i < path.length; i++) res = res?.[path[i]]\n return res\n}\n\n// ** Check arrays items equality at path\nexport const areArraysEqualAtPath = (arrayA, arrayB, pathA, pathB) => {\n arrayA?.forEach((itemA, index) => {\n if (leaf(itemA, pathA) !== leaf(arrayB?.[index], pathB)) return false\n })\n return true\n}\n\n// ** Check arrays items equality\nexport const isSameArray = (arrayA, arrayB) => {\n return arrayA?.sort().join(\",\") === arrayB?.sort().join(\",\")\n}\n\nexport const allOptionsFromSectionOptions = (options) =>\n options\n ?.map((option) => option?.data ?? option)\n ?.flat()\n ?.map((d) => d?.value)\n\n// ** Pluralize string based on count\nexport const plr = (textString, cnt, character = \"s\") =>\n cnt > 1 ? textString + character : textString\n\nexport const readableDayTime = (\n day_time,\n durationInMinutes = 60,\n roomType = \"biweekly\"\n) => {\n const dayMatch = day_time?.split(\" \")?.[0]\n const readableDay = daysOptions\n ?.find((d) => d.value === dayMatch)\n ?.label?.toLowerCase()\n\n const additionalHours = Math.floor(durationInMinutes / 60)\n const additionalMinutes = durationInMinutes % 60\n\n const timeMatch = day_time?.split(\" \")?.[1]\n const timeMatchHour = timeMatch?.substring(0, 2)\n const timeMatchMinutes = timeMatch?.substring(3, 5)\n const readableMinutes = timeMatchMinutes === \"00\" ? \"\" : timeMatchMinutes\n\n const readableEndHours = parseInt(timeMatchHour) + additionalHours\n const readableEndMinutes =\n parseInt(timeMatchMinutes) + additionalMinutes === 0\n ? \"\"\n : parseInt(timeMatchMinutes) + additionalMinutes\n\n const additionalHoursPlus = Math.floor(readableEndMinutes / 60)\n const additionalMinutesPlus = readableEndMinutes % 60\n\n const finalEndHours = readableEndHours + additionalHoursPlus\n const finalEndMinutes =\n additionalMinutesPlus === 0 ? \"\" : additionalMinutesPlus\n\n const readableTime =\n parseInt(timeMatchHour) +\n \"h\" +\n readableMinutes +\n \"-\" +\n finalEndHours +\n \"h\" +\n finalEndMinutes\n\n // if (roomType === \"holiday_course\")\n return capitalize(readableDay) + \" \" + readableTime\n\n // return \"Tous les \" + readableDay + \"s \" + readableTime\n}\n\nexport function string_to_slug(str) {\n str = str.replace(/^\\s+|\\s+$/g, \"\") // trim\n str = str.toLowerCase()\n\n // remove accents, swap ñ for n, etc\n var from = \"àáäâèéëêìíïîòóöôùúüûñç·/_,:;\"\n var to = \"aaaaeeeeiiiioooouuuunc------\"\n for (var i = 0, l = from.length; i < l; i++) {\n str = str.replace(new RegExp(from.charAt(i), \"g\"), to.charAt(i))\n }\n\n str = str\n .replace(/[^a-z0-9 -]/g, \"\") // remove invalid chars\n .replace(/\\s+/g, \"-\") // collapse whitespace and replace by -\n .replace(/-+/g, \"-\") // collapse dashes\n\n return str\n}\n\nexport function isArraySubset(mainArray, subArray) {\n return subArray.every((element) => mainArray.includes(element))\n}\n\nexport const formatOccurrenceDate = (date) =>\n capitalize(moment(date)?.format(\"dddd\" + \" DD MMMM [à] HH:mm\"))\n","// Radio fields data\nimport { theme } from '@common/theme/theme';\nimport moment from 'moment';\n\nexport const studentClasses = [\n 'CM1',\n 'CM2',\n '6ème',\n '5ème',\n '4ème',\n '3ème',\n '2nde',\n '1ère',\n 'Tle',\n 'Autre',\n]\nexport const sectionStudentClasses = [\n {\n title: 'Primaire',\n options: ['CM1', 'CM2'],\n },\n {\n title: 'Collège',\n options: ['6ème', '5ème', '4ème', '3ème'],\n },\n {\n title: 'Lycée',\n options: ['2nde', '1ère', 'Tle'],\n },\n {\n title: 'Autre',\n options: ['Autre'],\n },\n]\n\nexport const activityStatuses = [\n {\n label: 'Validé',\n value: 'validated',\n },\n {\n label: 'Rejeté',\n value: 'rejected',\n },\n {\n label: 'Fait',\n value: 'not_reviewed',\n },\n {\n label: 'En attente',\n value: 'pending_review',\n },\n]\n\nexport const days = [\n { value: 'Monday', label: 'L' },\n { value: 'Tuesday', label: 'Ma' },\n { value: 'Wednesday', label: 'Me' },\n { value: 'Thursday', label: 'J' },\n { value: 'Friday', label: 'V' },\n { value: 'Saturday', label: 'S' },\n { value: 'Sunday', label: 'D' },\n]\n\nexport const daysOptions = [\n { value: 'Monday', label: 'Lundi' },\n { value: 'Tuesday', label: 'Mardi' },\n { value: 'Wednesday', label: 'Mercredi' },\n { value: 'Thursday', label: 'Jeudi' },\n { value: 'Friday', label: 'Vendredi' },\n { value: 'Saturday', label: 'Samedi' },\n { value: 'Sunday', label: 'Dimanche' },\n]\nexport const roomTypes = [\n { value: 'study_group', label: 'Groupe - Aide aux devoirs' },\n { value: 'biweekly', label: 'Groupe - Indiv. optimisée' },\n { value: 'individual', label: 'Individuel' },\n { value: 'holiday_course', label: 'Stage' },\n { value: 'holiday_workbook', label: 'Révisions d\\'été' },\n { value: 'trial', label: 'Essai' },\n { value: 'custom', label: 'Custom' },\n]\n// Gender\nexport const gender = ['Masculin', 'Féminin']\n\n// interviewDays\nexport const interviewDays = ['Saturday', 'Sunday']\n\nexport const channels = [\n { label: 'Famille/amis', value: 'Famille/amis' },\n { label: 'Actualités/article/blog', value: 'Actualités/article/blog' },\n { label: 'Facebook/Instagram', value: 'Facebook/Instagram' },\n { label: 'Recherche Google', value: 'Recherche Google' },\n { label: 'Partenaire', value: 'Partenaire' },\n { label: 'Autre', value: 'Autre' },\n]\nexport const favorite_subjects = [\n { value: 'Maths', label: 'Maths' },\n { value: 'Physique-Chimie', label: 'Physique-Chimie' },\n { value: 'SVT', label: 'SVT' },\n { value: 'Français,', label: 'Français' },\n { value: 'Anglais,', label: 'Anglais' },\n { value: 'Espagnol,', label: 'Espagnol' },\n { value: 'Allemand,', label: 'Allemand' },\n { value: 'Histoire-Géographie,', label: 'Histoire-Géographie' },\n { value: 'Musique,', label: 'Musique' },\n { value: 'Sport,', label: 'Sport' },\n]\n\nexport const subjectPriorities = [\n { label: 'Scientifiques (Maths, Physique...)', value: 'scientific' },\n { label: 'Littéraires (Français, Histoire-Géo, SES...)', value: 'literary' },\n // {label: 'Langues (Anglais, Espagnol, Allemand...)', value: 'language'}\n // {label: 'Autre', value: 'other'}\n]\n\nexport const subjectPrioritiesSing = [\n { label: 'Scientifique (Maths, Physique...)', value: 'scientific' },\n { label: 'Littéraire (Français, Histoire-Géo, SES...)', value: 'literary' },\n // {label: 'Langues (Anglais, Espagnol, Allemand...)', value: 'language'}\n // {label: 'Autre', value: 'other'}\n]\n\nexport const subjectPrioritiesSingWithNullOption = [\n { label: 'Scientifique (Maths, Physique...)', value: 'scientific' },\n { label: 'Littéraire (Français, Histoire-Géo, SES...)', value: 'literary' },\n { label: 'Aide aux devoirs toutes matières', value: null },\n]\n\nexport const subjectPrioritiesSingLight = [\n { label: 'Scientifique', value: 'scientific' },\n { label: 'Littéraire', value: 'literary' },\n // {label: 'Langues (Anglais, Espagnol, Allemand...)', value: 'language'}\n // {label: 'Autre', value: 'other'}\n]\n\nexport const subjectPrioritiesSingLightWithNullOption = [\n { label: 'Scientifique', value: 'scientific' },\n { label: 'Littéraire', value: 'literary' },\n { label: 'Aide aux devoirs toutes matières', value: null },\n]\n\nexport const subjectPrioritiesSubjectsDisplay = {\n scientific: ['Maths', 'Physique', '+3'],\n literary: ['Français', 'SES', '+2'],\n 'scientific,literary': ['Maths', 'Français', '+5'],\n 'literary,scientific': ['Maths', 'Français', '+5'],\n}\n\nexport const slotsPossibleOptions = [\n { label: 'Lundi 18h-20h', value: 'Lundi 18h-20h' },\n { label: 'Mardi 18h-20h', value: 'Mardi 18h-20h' },\n { label: 'Mercredi 14h-16h', value: 'Mercredi 14h-16h' },\n { label: 'Mercredi 16h-18h', value: 'Mercredi 16h-18h' },\n { label: 'Mercredi 18h-20h', value: 'Mercredi 18h-20h' },\n { label: 'Jeudi 18h-20h', value: 'Jeudi 18h-20h' },\n { label: 'Vendredi 18h-20h', value: 'Vendredi 18h-20h' },\n { label: 'Samedi 8h-10h', value: 'Samedi 8h-10h' },\n { label: 'Samedi 10h-12h', value: 'Samedi 10h-12h' },\n { label: 'Samedi 14h-16h', value: 'Samedi 14h-16h' },\n { label: 'Samedi 16h-18h', value: 'Samedi 16h-18h' },\n { label: 'Samedi 18h-20h', value: 'Samedi 18h-20h' },\n { label: 'Dimanche 8h-10h', value: 'Dimanche 8h-10h' },\n { label: 'Dimanche 10h-12h', value: 'Dimanche 10h-12h' },\n { label: 'Dimanche 14h-16h', value: 'Dimanche 14h-16h' },\n { label: 'Dimanche 16h-18h', value: 'Dimanche 16h-18h' },\n { label: 'Dimanche 18h-20h', value: 'Dimanche 18h-20h' },\n]\nexport const slotsPossibleWeekendOptions = [\n { label: 'Samedi 8h-10h', value: 'Samedi 8h-10h' },\n { label: 'Samedi 10h-12h', value: 'Samedi 10h-12h' },\n { label: 'Samedi 14h-16h', value: 'Samedi 14h-16h' },\n { label: 'Samedi 16h-18h', value: 'Samedi 16h-18h' },\n { label: 'Samedi 18h-20h', value: 'Samedi 18h-20h' },\n { label: 'Dimanche 8h-10h', value: 'Dimanche 8h-10h' },\n { label: 'Dimanche 10h-12h', value: 'Dimanche 10h-12h' },\n { label: 'Dimanche 14h-16h', value: 'Dimanche 14h-16h' },\n { label: 'Dimanche 16h-18h', value: 'Dimanche 16h-18h' },\n { label: 'Dimanche 18h-20h', value: 'Dimanche 18h-20h' },\n]\nexport const slotsPossibleRegularDaysOptions = [\n { label: 'Lundi 18h-20h', value: 'Lundi 18h-20h' },\n { label: 'Mardi 18h-20h', value: 'Mardi 18h-20h' },\n { label: 'Mercredi 14h-16h', value: 'Mercredi 14h-16h' },\n { label: 'Mercredi 16h-18h', value: 'Mercredi 16h-18h' },\n { label: 'Mercredi 18h-20h', value: 'Mercredi 18h-20h' },\n { label: 'Jeudi 18h-20h', value: 'Jeudi 18h-20h' },\n { label: 'Vendredi 18h-20h', value: 'Vendredi 18h-20h' },\n]\nexport const qualities = [\n { value: 'Ambitieux', label: 'Ambitieux' },\n { value: 'Aventurier', label: 'Aventurier' },\n { value: 'Bienveillant', label: 'Bienveillant' },\n { value: 'Conciliant', label: 'Conciliant' },\n { value: 'Volontaire', label: 'Volontaire' },\n { value: 'Travailleur', label: 'Travailleur' },\n { value: 'Sympathique', label: 'Sympathique' },\n { value: 'Souple', label: 'Souple' },\n { value: 'Sociable', label: 'Sociable' },\n { value: 'Sobre', label: 'Sobre' },\n { value: 'Serviable', label: 'Serviable' },\n { value: 'Rusé', label: 'Rusé' },\n { value: 'Respectueux', label: 'Respectueux' },\n { value: 'Prévoyant', label: 'Prévoyant' },\n { value: 'Ponctuel', label: 'Ponctuel' },\n { value: 'Patient', label: 'Patient' },\n { value: 'Organisé', label: 'Organisé' },\n { value: 'Modeste', label: 'Modeste' },\n { value: 'Minutieux', label: 'Minutieux' },\n { value: 'Mature', label: 'Mature' },\n { value: 'Leader', label: 'Leader' },\n { value: 'Intuitif', label: 'Intuitif' },\n { value: 'Ingénieux', label: 'Ingénieux' },\n { value: 'Généreux', label: 'Généreux' },\n { value: 'Enthousiaste', label: 'Enthousiaste' },\n { value: 'Discipliné', label: 'Discipliné' },\n { value: 'Diplomate', label: 'Diplomate' },\n { value: 'Diplomate', label: 'Diplomate' },\n { value: 'Déterminé', label: 'Déterminé' },\n { value: 'Curieux', label: 'Curieux' },\n { value: 'Créatif', label: 'Créatif' },\n { value: 'Courageux', label: 'Courageux' },\n]\n\n//profession\nexport const professionalSituation = ['Etudiant', 'Professionnel']\nexport const productColors = {\n integral: theme.colors.material.secondary?.['900'],\n essential: theme.colors.material.secondary?.['600'],\n initial: theme.colors.material.secondary?.['300'],\n holidaycourse: theme.colors.material.secondary?.['600'],\n premium: theme.colors.warning,\n plus: theme.colors.accent,\n basic: theme.colors.lightMore,\n}\n\nexport const subscriptionStatusColors = {\n recurring: theme.colors.successDark,\n past_due: theme.colors.error,\n on_grace_period: theme.colors.accent,\n on_grace_period_before_pause: theme.colors.warning,\n on_trial: theme.colors.successDark,\n paused: theme.colors.light,\n planned: theme.colors.success,\n ended: theme.colors.light,\n on_generic_trial: theme.colors.success,\n expired_trial: theme.colors.light,\n}\n\nexport const subscriptionStatusNames = {\n recurring: 'RÉCURRENT',\n past_due: 'EN RETARD',\n on_grace_period: 'ACTIF AVEC ÉCHÉANCE',\n on_grace_period_before_pause: 'PAUSE PLANIFIÉE',\n on_trial: 'ESSAI PRÉ-ABO',\n paused: 'MIS EN PAUSE',\n planned: 'PLANIFIÉ',\n ended: 'TERMINÉ',\n on_generic_trial: 'ESSAI GRATUIT',\n expired_trial: 'ESSAI EXPIRÉ',\n}\n\nexport const subscribedProductNames = {\n initial: 'Offre Initiale',\n essential: 'Offre Essentielle',\n integral: 'Offre Intégrale',\n}\n\nexport const subscribedProducts = [\n {\n title: 'Sélectionner tout',\n data: [\n {\n label: 'Intégrale',\n value: 'integral-student',\n },\n {\n label: 'Essentielle',\n value: 'essential-student',\n },\n {\n label: 'Initiale',\n value: 'initial-student',\n },\n {\n label: 'Stage',\n value: 'holidaycourse-student',\n },\n {\n label: 'Premium',\n value: 'premium-student',\n },\n {\n label: 'Plus',\n value: 'plus-student',\n },\n {\n label: 'Basic',\n value: 'student',\n },\n ],\n },\n]\n\nexport const subscriptionStates = [\n {\n title: 'Sélectionner tout',\n data: [\n {\n label: 'Essai gratuit <=7',\n value: 'on_generic_trial_<=7',\n },\n {\n label: 'Essai gratuit >7',\n value: 'on_generic_trial_>7',\n },\n {\n label: 'Abonné',\n value: 'subscribed',\n },\n {\n label: 'Abonnement terminé',\n value: 'ended',\n },\n {\n label: 'Jamais abonné',\n value: 'never_subscribed',\n },\n ],\n },\n]\n\nexport const roomTypesFilter = [\n {\n title: 'Sélectionner tout',\n data: roomTypes,\n },\n]\n\nexport const liveDaysFilter = [\n {\n title: 'Sélectionner tout',\n data: daysOptions,\n },\n]\n\nexport const availabilityFilter = [\n {\n title: 'Sélectionner tout',\n data: [\n {\n label: 'Complet',\n value: 'full',\n },\n {\n label: 'Place(s) disponible(s)',\n value: 'available',\n },\n ],\n },\n]\n\nexport const liveOccurrenceDatesFilter = [\n {\n title: 'Sélectionner tout',\n data: [\n {\n label: moment().format('ddd DD/MM'),\n value: moment().format('YYYY-MM-DD'),\n },\n {\n label: moment().add(1, 'days').format('ddd DD/MM'),\n value: moment().add(1, 'days').format('YYYY-MM-DD'),\n },\n {\n label: moment().add(2, 'days').format('ddd DD/MM'),\n value: moment().add(2, 'days').format('YYYY-MM-DD'),\n },\n {\n label: moment().add(3, 'days').format('ddd DD/MM'),\n value: moment().add(3, 'days').format('YYYY-MM-DD'),\n },\n {\n label: moment().add(4, 'days').format('ddd DD/MM'),\n value: moment().add(4, 'days').format('YYYY-MM-DD'),\n },\n {\n label: moment().add(5, 'days').format('ddd DD/MM'),\n value: moment().add(5, 'days').format('YYYY-MM-DD'),\n },\n {\n label: moment().add(6, 'days').format('ddd DD/MM'),\n value: moment().add(6, 'days').format('YYYY-MM-DD'),\n },\n ],\n },\n]\n\nconst nbStudentsOptions = [\n { value: '0', label: '0' },\n { value: '1', label: '1' },\n { value: '2', label: '2' },\n { value: '3', label: '3' },\n { value: '3_plus', label: '3+' },\n]\n\nexport const nbStudentsFilter = [\n {\n title: 'Sélectionner tout',\n data: nbStudentsOptions,\n },\n]\n\nconst tutorDomains = [\n { value: 'literary', label: 'littéraire' },\n { value: 'scientific', label: 'scientifique' },\n]\n\nexport const tutorDomainsFilter = [\n {\n title: 'Sélectionner tout',\n data: tutorDomains,\n },\n]\n\nconst studentClassesOptions = [\n { value: 'CM1', label: 'CM1' },\n { value: 'CM2', label: 'CM2' },\n { value: '6ème', label: '6ème' },\n { value: '5ème', label: '5ème' },\n { value: '4ème', label: '4ème' },\n { value: '3ème', label: '3ème' },\n { value: '2nde', label: '2nde' },\n { value: '1ère', label: '1ère' },\n { value: 'Tle', label: 'Tle' },\n { value: 'Autre', label: 'Autre' },\n]\n\nexport const studentClassesFilter = [\n {\n title: 'Sélectionner tout',\n data: studentClassesOptions,\n },\n]\n\nexport const interviewReportState = [\n {\n title: 'Sélectionner tout',\n data: [\n {\n label: 'À jour (d<=26)',\n value: 'ok',\n },\n {\n label: 'À traiter (2629), au moins un rapport',\n value: 'late',\n },\n {\n label: 'En retard (2960), aucun rapport',\n value: 'late_never_old',\n },\n ],\n },\n]\n\nexport const yesNo = [\n {\n title: 'Sélectionner tout',\n data: [\n {\n label: 'Oui',\n value: '1',\n },\n {\n label: 'Non',\n value: '0',\n },\n ],\n },\n]\n\nexport const candidaturesStatus = [\n {\n title: 'Sélectionner tout',\n data: [\n {\n label: 'Validée',\n value: 'validated',\n },\n {\n label: 'Refusée',\n value: 'rejected',\n },\n {\n label: 'En attente',\n value: 'pending',\n },\n ],\n },\n]\n\nexport const skillSetIds = [\n {\n label: 'Je maîtrise l’art de l’organisation',\n value: 101,\n },\n {\n label: 'Je maîtrise l’art de la concentration',\n value: 102,\n },\n {\n label: 'Je maîtrise l’art de l’expression',\n value: 103,\n },\n {\n label: 'Je maîtrise l’art de la coopération',\n value: 104,\n },\n]\n\n// Result\nexport const resultBooster = [\n {\n value: 'Rendu très satisfaisant',\n text: 'Rendu très satisfaisant',\n color: 'success',\n },\n {\n value: 'Rendu satisfaisant',\n text: 'Rendu satisfaisant',\n color: 'warning',\n },\n {\n value: 'Rendu insatisfaisant',\n text: 'Rendu insatisfaisant',\n color: 'danger',\n },\n]\nexport const ResponseResult = [\n {\n value: 'Pas du tout d\\'accord',\n text: 'Pas du tout d\\'accord',\n },\n {\n value: 'Pas tout à fait d\\'accord',\n text: 'Pas tout à fait d\\'accord',\n },\n {\n value: 'Plutôt d\\'accord',\n text: 'Plutôt d\\'accord',\n },\n {\n value: 'Tout à fait d\\'accord',\n text: 'Tout à fait d\\'accord',\n },\n]\n\n// Survey response\nexport const surveyResponse = [\n 'Pas du tout d\\'accord',\n 'Pas tout à fait d\\'accord',\n 'Plutôt d\\'accord',\n 'Tout à fait d\\'accord',\n]\n\nexport const formIds = {\n ACTIVITY: \"activity\",\n COMPLETE_PROFILE: \"complete_profile\",\n NEW_MATERIAL: \"new-material\",\n SEND_TUTOR_MESSAGE: \"send-tutor-message\",\n LIVE_REPORT_COMMENT: \"live-report-comment\"\n};\n\nexport const liveOccurrenceStatuses = [\n {\n value: 'todo',\n label: 'À faire',\n },\n {\n value: 'pending_review',\n label: 'En attente',\n },\n {\n value: 'validated',\n label: 'Accepté',\n },\n {\n value: 'canceled',\n label: 'Annulé',\n },\n]\n\nexport const extendedStudentClasses = [\n { label: \"6ème\", value: \"6ème\" },\n { label: \"5ème\", value: \"5ème\" },\n { label: \"4ème\", value: \"4ème\" },\n { label: \"3ème\", value: \"3ème\" },\n { label: \"2nde\", value: \"2nde\" },\n { label: \"1ère\", value: \"1ère\" },\n { label: \"Tle\", value: \"Tle\" },\n]","//! moment.js\n//! version : 2.29.4\n//! authors : Tim Wood, Iskren Chernev, Moment.js contributors\n//! license : MIT\n//! momentjs.com\n\n;(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n global.moment = factory()\n}(this, (function () { 'use strict';\n\n var hookCallback;\n\n function hooks() {\n return hookCallback.apply(null, arguments);\n }\n\n // This is done to register the method called with moment()\n // without creating circular dependencies.\n function setHookCallback(callback) {\n hookCallback = callback;\n }\n\n function isArray(input) {\n return (\n input instanceof Array ||\n Object.prototype.toString.call(input) === '[object Array]'\n );\n }\n\n function isObject(input) {\n // IE8 will treat undefined and null as object if it wasn't for\n // input != null\n return (\n input != null &&\n Object.prototype.toString.call(input) === '[object Object]'\n );\n }\n\n function hasOwnProp(a, b) {\n return Object.prototype.hasOwnProperty.call(a, b);\n }\n\n function isObjectEmpty(obj) {\n if (Object.getOwnPropertyNames) {\n return Object.getOwnPropertyNames(obj).length === 0;\n } else {\n var k;\n for (k in obj) {\n if (hasOwnProp(obj, k)) {\n return false;\n }\n }\n return true;\n }\n }\n\n function isUndefined(input) {\n return input === void 0;\n }\n\n function isNumber(input) {\n return (\n typeof input === 'number' ||\n Object.prototype.toString.call(input) === '[object Number]'\n );\n }\n\n function isDate(input) {\n return (\n input instanceof Date ||\n Object.prototype.toString.call(input) === '[object Date]'\n );\n }\n\n function map(arr, fn) {\n var res = [],\n i,\n arrLen = arr.length;\n for (i = 0; i < arrLen; ++i) {\n res.push(fn(arr[i], i));\n }\n return res;\n }\n\n function extend(a, b) {\n for (var i in b) {\n if (hasOwnProp(b, i)) {\n a[i] = b[i];\n }\n }\n\n if (hasOwnProp(b, 'toString')) {\n a.toString = b.toString;\n }\n\n if (hasOwnProp(b, 'valueOf')) {\n a.valueOf = b.valueOf;\n }\n\n return a;\n }\n\n function createUTC(input, format, locale, strict) {\n return createLocalOrUTC(input, format, locale, strict, true).utc();\n }\n\n function defaultParsingFlags() {\n // We need to deep clone this object.\n return {\n empty: false,\n unusedTokens: [],\n unusedInput: [],\n overflow: -2,\n charsLeftOver: 0,\n nullInput: false,\n invalidEra: null,\n invalidMonth: null,\n invalidFormat: false,\n userInvalidated: false,\n iso: false,\n parsedDateParts: [],\n era: null,\n meridiem: null,\n rfc2822: false,\n weekdayMismatch: false,\n };\n }\n\n function getParsingFlags(m) {\n if (m._pf == null) {\n m._pf = defaultParsingFlags();\n }\n return m._pf;\n }\n\n var some;\n if (Array.prototype.some) {\n some = Array.prototype.some;\n } else {\n some = function (fun) {\n var t = Object(this),\n len = t.length >>> 0,\n i;\n\n for (i = 0; i < len; i++) {\n if (i in t && fun.call(this, t[i], i, t)) {\n return true;\n }\n }\n\n return false;\n };\n }\n\n function isValid(m) {\n if (m._isValid == null) {\n var flags = getParsingFlags(m),\n parsedParts = some.call(flags.parsedDateParts, function (i) {\n return i != null;\n }),\n isNowValid =\n !isNaN(m._d.getTime()) &&\n flags.overflow < 0 &&\n !flags.empty &&\n !flags.invalidEra &&\n !flags.invalidMonth &&\n !flags.invalidWeekday &&\n !flags.weekdayMismatch &&\n !flags.nullInput &&\n !flags.invalidFormat &&\n !flags.userInvalidated &&\n (!flags.meridiem || (flags.meridiem && parsedParts));\n\n if (m._strict) {\n isNowValid =\n isNowValid &&\n flags.charsLeftOver === 0 &&\n flags.unusedTokens.length === 0 &&\n flags.bigHour === undefined;\n }\n\n if (Object.isFrozen == null || !Object.isFrozen(m)) {\n m._isValid = isNowValid;\n } else {\n return isNowValid;\n }\n }\n return m._isValid;\n }\n\n function createInvalid(flags) {\n var m = createUTC(NaN);\n if (flags != null) {\n extend(getParsingFlags(m), flags);\n } else {\n getParsingFlags(m).userInvalidated = true;\n }\n\n return m;\n }\n\n // Plugins that add properties should also add the key here (null value),\n // so we can properly clone ourselves.\n var momentProperties = (hooks.momentProperties = []),\n updateInProgress = false;\n\n function copyConfig(to, from) {\n var i,\n prop,\n val,\n momentPropertiesLen = momentProperties.length;\n\n if (!isUndefined(from._isAMomentObject)) {\n to._isAMomentObject = from._isAMomentObject;\n }\n if (!isUndefined(from._i)) {\n to._i = from._i;\n }\n if (!isUndefined(from._f)) {\n to._f = from._f;\n }\n if (!isUndefined(from._l)) {\n to._l = from._l;\n }\n if (!isUndefined(from._strict)) {\n to._strict = from._strict;\n }\n if (!isUndefined(from._tzm)) {\n to._tzm = from._tzm;\n }\n if (!isUndefined(from._isUTC)) {\n to._isUTC = from._isUTC;\n }\n if (!isUndefined(from._offset)) {\n to._offset = from._offset;\n }\n if (!isUndefined(from._pf)) {\n to._pf = getParsingFlags(from);\n }\n if (!isUndefined(from._locale)) {\n to._locale = from._locale;\n }\n\n if (momentPropertiesLen > 0) {\n for (i = 0; i < momentPropertiesLen; i++) {\n prop = momentProperties[i];\n val = from[prop];\n if (!isUndefined(val)) {\n to[prop] = val;\n }\n }\n }\n\n return to;\n }\n\n // Moment prototype object\n function Moment(config) {\n copyConfig(this, config);\n this._d = new Date(config._d != null ? config._d.getTime() : NaN);\n if (!this.isValid()) {\n this._d = new Date(NaN);\n }\n // Prevent infinite loop in case updateOffset creates new moment\n // objects.\n if (updateInProgress === false) {\n updateInProgress = true;\n hooks.updateOffset(this);\n updateInProgress = false;\n }\n }\n\n function isMoment(obj) {\n return (\n obj instanceof Moment || (obj != null && obj._isAMomentObject != null)\n );\n }\n\n function warn(msg) {\n if (\n hooks.suppressDeprecationWarnings === false &&\n typeof console !== 'undefined' &&\n console.warn\n ) {\n console.warn('Deprecation warning: ' + msg);\n }\n }\n\n function deprecate(msg, fn) {\n var firstTime = true;\n\n return extend(function () {\n if (hooks.deprecationHandler != null) {\n hooks.deprecationHandler(null, msg);\n }\n if (firstTime) {\n var args = [],\n arg,\n i,\n key,\n argLen = arguments.length;\n for (i = 0; i < argLen; i++) {\n arg = '';\n if (typeof arguments[i] === 'object') {\n arg += '\\n[' + i + '] ';\n for (key in arguments[0]) {\n if (hasOwnProp(arguments[0], key)) {\n arg += key + ': ' + arguments[0][key] + ', ';\n }\n }\n arg = arg.slice(0, -2); // Remove trailing comma and space\n } else {\n arg = arguments[i];\n }\n args.push(arg);\n }\n warn(\n msg +\n '\\nArguments: ' +\n Array.prototype.slice.call(args).join('') +\n '\\n' +\n new Error().stack\n );\n firstTime = false;\n }\n return fn.apply(this, arguments);\n }, fn);\n }\n\n var deprecations = {};\n\n function deprecateSimple(name, msg) {\n if (hooks.deprecationHandler != null) {\n hooks.deprecationHandler(name, msg);\n }\n if (!deprecations[name]) {\n warn(msg);\n deprecations[name] = true;\n }\n }\n\n hooks.suppressDeprecationWarnings = false;\n hooks.deprecationHandler = null;\n\n function isFunction(input) {\n return (\n (typeof Function !== 'undefined' && input instanceof Function) ||\n Object.prototype.toString.call(input) === '[object Function]'\n );\n }\n\n function set(config) {\n var prop, i;\n for (i in config) {\n if (hasOwnProp(config, i)) {\n prop = config[i];\n if (isFunction(prop)) {\n this[i] = prop;\n } else {\n this['_' + i] = prop;\n }\n }\n }\n this._config = config;\n // Lenient ordinal parsing accepts just a number in addition to\n // number + (possibly) stuff coming from _dayOfMonthOrdinalParse.\n // TODO: Remove \"ordinalParse\" fallback in next major release.\n this._dayOfMonthOrdinalParseLenient = new RegExp(\n (this._dayOfMonthOrdinalParse.source || this._ordinalParse.source) +\n '|' +\n /\\d{1,2}/.source\n );\n }\n\n function mergeConfigs(parentConfig, childConfig) {\n var res = extend({}, parentConfig),\n prop;\n for (prop in childConfig) {\n if (hasOwnProp(childConfig, prop)) {\n if (isObject(parentConfig[prop]) && isObject(childConfig[prop])) {\n res[prop] = {};\n extend(res[prop], parentConfig[prop]);\n extend(res[prop], childConfig[prop]);\n } else if (childConfig[prop] != null) {\n res[prop] = childConfig[prop];\n } else {\n delete res[prop];\n }\n }\n }\n for (prop in parentConfig) {\n if (\n hasOwnProp(parentConfig, prop) &&\n !hasOwnProp(childConfig, prop) &&\n isObject(parentConfig[prop])\n ) {\n // make sure changes to properties don't modify parent config\n res[prop] = extend({}, res[prop]);\n }\n }\n return res;\n }\n\n function Locale(config) {\n if (config != null) {\n this.set(config);\n }\n }\n\n var keys;\n\n if (Object.keys) {\n keys = Object.keys;\n } else {\n keys = function (obj) {\n var i,\n res = [];\n for (i in obj) {\n if (hasOwnProp(obj, i)) {\n res.push(i);\n }\n }\n return res;\n };\n }\n\n var defaultCalendar = {\n sameDay: '[Today at] LT',\n nextDay: '[Tomorrow at] LT',\n nextWeek: 'dddd [at] LT',\n lastDay: '[Yesterday at] LT',\n lastWeek: '[Last] dddd [at] LT',\n sameElse: 'L',\n };\n\n function calendar(key, mom, now) {\n var output = this._calendar[key] || this._calendar['sameElse'];\n return isFunction(output) ? output.call(mom, now) : output;\n }\n\n function zeroFill(number, targetLength, forceSign) {\n var absNumber = '' + Math.abs(number),\n zerosToFill = targetLength - absNumber.length,\n sign = number >= 0;\n return (\n (sign ? (forceSign ? '+' : '') : '-') +\n Math.pow(10, Math.max(0, zerosToFill)).toString().substr(1) +\n absNumber\n );\n }\n\n var formattingTokens =\n /(\\[[^\\[]*\\])|(\\\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|N{1,5}|YYYYYY|YYYYY|YYYY|YY|y{2,4}|yo?|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|kk?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g,\n localFormattingTokens = /(\\[[^\\[]*\\])|(\\\\)?(LTS|LT|LL?L?L?|l{1,4})/g,\n formatFunctions = {},\n formatTokenFunctions = {};\n\n // token: 'M'\n // padded: ['MM', 2]\n // ordinal: 'Mo'\n // callback: function () { this.month() + 1 }\n function addFormatToken(token, padded, ordinal, callback) {\n var func = callback;\n if (typeof callback === 'string') {\n func = function () {\n return this[callback]();\n };\n }\n if (token) {\n formatTokenFunctions[token] = func;\n }\n if (padded) {\n formatTokenFunctions[padded[0]] = function () {\n return zeroFill(func.apply(this, arguments), padded[1], padded[2]);\n };\n }\n if (ordinal) {\n formatTokenFunctions[ordinal] = function () {\n return this.localeData().ordinal(\n func.apply(this, arguments),\n token\n );\n };\n }\n }\n\n function removeFormattingTokens(input) {\n if (input.match(/\\[[\\s\\S]/)) {\n return input.replace(/^\\[|\\]$/g, '');\n }\n return input.replace(/\\\\/g, '');\n }\n\n function makeFormatFunction(format) {\n var array = format.match(formattingTokens),\n i,\n length;\n\n for (i = 0, length = array.length; i < length; i++) {\n if (formatTokenFunctions[array[i]]) {\n array[i] = formatTokenFunctions[array[i]];\n } else {\n array[i] = removeFormattingTokens(array[i]);\n }\n }\n\n return function (mom) {\n var output = '',\n i;\n for (i = 0; i < length; i++) {\n output += isFunction(array[i])\n ? array[i].call(mom, format)\n : array[i];\n }\n return output;\n };\n }\n\n // format date using native date object\n function formatMoment(m, format) {\n if (!m.isValid()) {\n return m.localeData().invalidDate();\n }\n\n format = expandFormat(format, m.localeData());\n formatFunctions[format] =\n formatFunctions[format] || makeFormatFunction(format);\n\n return formatFunctions[format](m);\n }\n\n function expandFormat(format, locale) {\n var i = 5;\n\n function replaceLongDateFormatTokens(input) {\n return locale.longDateFormat(input) || input;\n }\n\n localFormattingTokens.lastIndex = 0;\n while (i >= 0 && localFormattingTokens.test(format)) {\n format = format.replace(\n localFormattingTokens,\n replaceLongDateFormatTokens\n );\n localFormattingTokens.lastIndex = 0;\n i -= 1;\n }\n\n return format;\n }\n\n var defaultLongDateFormat = {\n LTS: 'h:mm:ss A',\n LT: 'h:mm A',\n L: 'MM/DD/YYYY',\n LL: 'MMMM D, YYYY',\n LLL: 'MMMM D, YYYY h:mm A',\n LLLL: 'dddd, MMMM D, YYYY h:mm A',\n };\n\n function longDateFormat(key) {\n var format = this._longDateFormat[key],\n formatUpper = this._longDateFormat[key.toUpperCase()];\n\n if (format || !formatUpper) {\n return format;\n }\n\n this._longDateFormat[key] = formatUpper\n .match(formattingTokens)\n .map(function (tok) {\n if (\n tok === 'MMMM' ||\n tok === 'MM' ||\n tok === 'DD' ||\n tok === 'dddd'\n ) {\n return tok.slice(1);\n }\n return tok;\n })\n .join('');\n\n return this._longDateFormat[key];\n }\n\n var defaultInvalidDate = 'Invalid date';\n\n function invalidDate() {\n return this._invalidDate;\n }\n\n var defaultOrdinal = '%d',\n defaultDayOfMonthOrdinalParse = /\\d{1,2}/;\n\n function ordinal(number) {\n return this._ordinal.replace('%d', number);\n }\n\n var defaultRelativeTime = {\n future: 'in %s',\n past: '%s ago',\n s: 'a few seconds',\n ss: '%d seconds',\n m: 'a minute',\n mm: '%d minutes',\n h: 'an hour',\n hh: '%d hours',\n d: 'a day',\n dd: '%d days',\n w: 'a week',\n ww: '%d weeks',\n M: 'a month',\n MM: '%d months',\n y: 'a year',\n yy: '%d years',\n };\n\n function relativeTime(number, withoutSuffix, string, isFuture) {\n var output = this._relativeTime[string];\n return isFunction(output)\n ? output(number, withoutSuffix, string, isFuture)\n : output.replace(/%d/i, number);\n }\n\n function pastFuture(diff, output) {\n var format = this._relativeTime[diff > 0 ? 'future' : 'past'];\n return isFunction(format) ? format(output) : format.replace(/%s/i, output);\n }\n\n var aliases = {};\n\n function addUnitAlias(unit, shorthand) {\n var lowerCase = unit.toLowerCase();\n aliases[lowerCase] = aliases[lowerCase + 's'] = aliases[shorthand] = unit;\n }\n\n function normalizeUnits(units) {\n return typeof units === 'string'\n ? aliases[units] || aliases[units.toLowerCase()]\n : undefined;\n }\n\n function normalizeObjectUnits(inputObject) {\n var normalizedInput = {},\n normalizedProp,\n prop;\n\n for (prop in inputObject) {\n if (hasOwnProp(inputObject, prop)) {\n normalizedProp = normalizeUnits(prop);\n if (normalizedProp) {\n normalizedInput[normalizedProp] = inputObject[prop];\n }\n }\n }\n\n return normalizedInput;\n }\n\n var priorities = {};\n\n function addUnitPriority(unit, priority) {\n priorities[unit] = priority;\n }\n\n function getPrioritizedUnits(unitsObj) {\n var units = [],\n u;\n for (u in unitsObj) {\n if (hasOwnProp(unitsObj, u)) {\n units.push({ unit: u, priority: priorities[u] });\n }\n }\n units.sort(function (a, b) {\n return a.priority - b.priority;\n });\n return units;\n }\n\n function isLeapYear(year) {\n return (year % 4 === 0 && year % 100 !== 0) || year % 400 === 0;\n }\n\n function absFloor(number) {\n if (number < 0) {\n // -0 -> 0\n return Math.ceil(number) || 0;\n } else {\n return Math.floor(number);\n }\n }\n\n function toInt(argumentForCoercion) {\n var coercedNumber = +argumentForCoercion,\n value = 0;\n\n if (coercedNumber !== 0 && isFinite(coercedNumber)) {\n value = absFloor(coercedNumber);\n }\n\n return value;\n }\n\n function makeGetSet(unit, keepTime) {\n return function (value) {\n if (value != null) {\n set$1(this, unit, value);\n hooks.updateOffset(this, keepTime);\n return this;\n } else {\n return get(this, unit);\n }\n };\n }\n\n function get(mom, unit) {\n return mom.isValid()\n ? mom._d['get' + (mom._isUTC ? 'UTC' : '') + unit]()\n : NaN;\n }\n\n function set$1(mom, unit, value) {\n if (mom.isValid() && !isNaN(value)) {\n if (\n unit === 'FullYear' &&\n isLeapYear(mom.year()) &&\n mom.month() === 1 &&\n mom.date() === 29\n ) {\n value = toInt(value);\n mom._d['set' + (mom._isUTC ? 'UTC' : '') + unit](\n value,\n mom.month(),\n daysInMonth(value, mom.month())\n );\n } else {\n mom._d['set' + (mom._isUTC ? 'UTC' : '') + unit](value);\n }\n }\n }\n\n // MOMENTS\n\n function stringGet(units) {\n units = normalizeUnits(units);\n if (isFunction(this[units])) {\n return this[units]();\n }\n return this;\n }\n\n function stringSet(units, value) {\n if (typeof units === 'object') {\n units = normalizeObjectUnits(units);\n var prioritized = getPrioritizedUnits(units),\n i,\n prioritizedLen = prioritized.length;\n for (i = 0; i < prioritizedLen; i++) {\n this[prioritized[i].unit](units[prioritized[i].unit]);\n }\n } else {\n units = normalizeUnits(units);\n if (isFunction(this[units])) {\n return this[units](value);\n }\n }\n return this;\n }\n\n var match1 = /\\d/, // 0 - 9\n match2 = /\\d\\d/, // 00 - 99\n match3 = /\\d{3}/, // 000 - 999\n match4 = /\\d{4}/, // 0000 - 9999\n match6 = /[+-]?\\d{6}/, // -999999 - 999999\n match1to2 = /\\d\\d?/, // 0 - 99\n match3to4 = /\\d\\d\\d\\d?/, // 999 - 9999\n match5to6 = /\\d\\d\\d\\d\\d\\d?/, // 99999 - 999999\n match1to3 = /\\d{1,3}/, // 0 - 999\n match1to4 = /\\d{1,4}/, // 0 - 9999\n match1to6 = /[+-]?\\d{1,6}/, // -999999 - 999999\n matchUnsigned = /\\d+/, // 0 - inf\n matchSigned = /[+-]?\\d+/, // -inf - inf\n matchOffset = /Z|[+-]\\d\\d:?\\d\\d/gi, // +00:00 -00:00 +0000 -0000 or Z\n matchShortOffset = /Z|[+-]\\d\\d(?::?\\d\\d)?/gi, // +00 -00 +00:00 -00:00 +0000 -0000 or Z\n matchTimestamp = /[+-]?\\d+(\\.\\d{1,3})?/, // 123456789 123456789.123\n // any word (or two) characters or numbers including two/three word month in arabic.\n // includes scottish gaelic two word and hyphenated months\n matchWord =\n /[0-9]{0,256}['a-z\\u00A0-\\u05FF\\u0700-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFF07\\uFF10-\\uFFEF]{1,256}|[\\u0600-\\u06FF\\/]{1,256}(\\s*?[\\u0600-\\u06FF]{1,256}){1,2}/i,\n regexes;\n\n regexes = {};\n\n function addRegexToken(token, regex, strictRegex) {\n regexes[token] = isFunction(regex)\n ? regex\n : function (isStrict, localeData) {\n return isStrict && strictRegex ? strictRegex : regex;\n };\n }\n\n function getParseRegexForToken(token, config) {\n if (!hasOwnProp(regexes, token)) {\n return new RegExp(unescapeFormat(token));\n }\n\n return regexes[token](config._strict, config._locale);\n }\n\n // Code from http://stackoverflow.com/questions/3561493/is-there-a-regexp-escape-function-in-javascript\n function unescapeFormat(s) {\n return regexEscape(\n s\n .replace('\\\\', '')\n .replace(\n /\\\\(\\[)|\\\\(\\])|\\[([^\\]\\[]*)\\]|\\\\(.)/g,\n function (matched, p1, p2, p3, p4) {\n return p1 || p2 || p3 || p4;\n }\n )\n );\n }\n\n function regexEscape(s) {\n return s.replace(/[-\\/\\\\^$*+?.()|[\\]{}]/g, '\\\\$&');\n }\n\n var tokens = {};\n\n function addParseToken(token, callback) {\n var i,\n func = callback,\n tokenLen;\n if (typeof token === 'string') {\n token = [token];\n }\n if (isNumber(callback)) {\n func = function (input, array) {\n array[callback] = toInt(input);\n };\n }\n tokenLen = token.length;\n for (i = 0; i < tokenLen; i++) {\n tokens[token[i]] = func;\n }\n }\n\n function addWeekParseToken(token, callback) {\n addParseToken(token, function (input, array, config, token) {\n config._w = config._w || {};\n callback(input, config._w, config, token);\n });\n }\n\n function addTimeToArrayFromToken(token, input, config) {\n if (input != null && hasOwnProp(tokens, token)) {\n tokens[token](input, config._a, config, token);\n }\n }\n\n var YEAR = 0,\n MONTH = 1,\n DATE = 2,\n HOUR = 3,\n MINUTE = 4,\n SECOND = 5,\n MILLISECOND = 6,\n WEEK = 7,\n WEEKDAY = 8;\n\n function mod(n, x) {\n return ((n % x) + x) % x;\n }\n\n var indexOf;\n\n if (Array.prototype.indexOf) {\n indexOf = Array.prototype.indexOf;\n } else {\n indexOf = function (o) {\n // I know\n var i;\n for (i = 0; i < this.length; ++i) {\n if (this[i] === o) {\n return i;\n }\n }\n return -1;\n };\n }\n\n function daysInMonth(year, month) {\n if (isNaN(year) || isNaN(month)) {\n return NaN;\n }\n var modMonth = mod(month, 12);\n year += (month - modMonth) / 12;\n return modMonth === 1\n ? isLeapYear(year)\n ? 29\n : 28\n : 31 - ((modMonth % 7) % 2);\n }\n\n // FORMATTING\n\n addFormatToken('M', ['MM', 2], 'Mo', function () {\n return this.month() + 1;\n });\n\n addFormatToken('MMM', 0, 0, function (format) {\n return this.localeData().monthsShort(this, format);\n });\n\n addFormatToken('MMMM', 0, 0, function (format) {\n return this.localeData().months(this, format);\n });\n\n // ALIASES\n\n addUnitAlias('month', 'M');\n\n // PRIORITY\n\n addUnitPriority('month', 8);\n\n // PARSING\n\n addRegexToken('M', match1to2);\n addRegexToken('MM', match1to2, match2);\n addRegexToken('MMM', function (isStrict, locale) {\n return locale.monthsShortRegex(isStrict);\n });\n addRegexToken('MMMM', function (isStrict, locale) {\n return locale.monthsRegex(isStrict);\n });\n\n addParseToken(['M', 'MM'], function (input, array) {\n array[MONTH] = toInt(input) - 1;\n });\n\n addParseToken(['MMM', 'MMMM'], function (input, array, config, token) {\n var month = config._locale.monthsParse(input, token, config._strict);\n // if we didn't find a month name, mark the date as invalid.\n if (month != null) {\n array[MONTH] = month;\n } else {\n getParsingFlags(config).invalidMonth = input;\n }\n });\n\n // LOCALES\n\n var defaultLocaleMonths =\n 'January_February_March_April_May_June_July_August_September_October_November_December'.split(\n '_'\n ),\n defaultLocaleMonthsShort =\n 'Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec'.split('_'),\n MONTHS_IN_FORMAT = /D[oD]?(\\[[^\\[\\]]*\\]|\\s)+MMMM?/,\n defaultMonthsShortRegex = matchWord,\n defaultMonthsRegex = matchWord;\n\n function localeMonths(m, format) {\n if (!m) {\n return isArray(this._months)\n ? this._months\n : this._months['standalone'];\n }\n return isArray(this._months)\n ? this._months[m.month()]\n : this._months[\n (this._months.isFormat || MONTHS_IN_FORMAT).test(format)\n ? 'format'\n : 'standalone'\n ][m.month()];\n }\n\n function localeMonthsShort(m, format) {\n if (!m) {\n return isArray(this._monthsShort)\n ? this._monthsShort\n : this._monthsShort['standalone'];\n }\n return isArray(this._monthsShort)\n ? this._monthsShort[m.month()]\n : this._monthsShort[\n MONTHS_IN_FORMAT.test(format) ? 'format' : 'standalone'\n ][m.month()];\n }\n\n function handleStrictParse(monthName, format, strict) {\n var i,\n ii,\n mom,\n llc = monthName.toLocaleLowerCase();\n if (!this._monthsParse) {\n // this is not used\n this._monthsParse = [];\n this._longMonthsParse = [];\n this._shortMonthsParse = [];\n for (i = 0; i < 12; ++i) {\n mom = createUTC([2000, i]);\n this._shortMonthsParse[i] = this.monthsShort(\n mom,\n ''\n ).toLocaleLowerCase();\n this._longMonthsParse[i] = this.months(mom, '').toLocaleLowerCase();\n }\n }\n\n if (strict) {\n if (format === 'MMM') {\n ii = indexOf.call(this._shortMonthsParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._longMonthsParse, llc);\n return ii !== -1 ? ii : null;\n }\n } else {\n if (format === 'MMM') {\n ii = indexOf.call(this._shortMonthsParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._longMonthsParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._longMonthsParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortMonthsParse, llc);\n return ii !== -1 ? ii : null;\n }\n }\n }\n\n function localeMonthsParse(monthName, format, strict) {\n var i, mom, regex;\n\n if (this._monthsParseExact) {\n return handleStrictParse.call(this, monthName, format, strict);\n }\n\n if (!this._monthsParse) {\n this._monthsParse = [];\n this._longMonthsParse = [];\n this._shortMonthsParse = [];\n }\n\n // TODO: add sorting\n // Sorting makes sure if one month (or abbr) is a prefix of another\n // see sorting in computeMonthsParse\n for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n if (strict && !this._longMonthsParse[i]) {\n this._longMonthsParse[i] = new RegExp(\n '^' + this.months(mom, '').replace('.', '') + '$',\n 'i'\n );\n this._shortMonthsParse[i] = new RegExp(\n '^' + this.monthsShort(mom, '').replace('.', '') + '$',\n 'i'\n );\n }\n if (!strict && !this._monthsParse[i]) {\n regex =\n '^' + this.months(mom, '') + '|^' + this.monthsShort(mom, '');\n this._monthsParse[i] = new RegExp(regex.replace('.', ''), 'i');\n }\n // test the regex\n if (\n strict &&\n format === 'MMMM' &&\n this._longMonthsParse[i].test(monthName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'MMM' &&\n this._shortMonthsParse[i].test(monthName)\n ) {\n return i;\n } else if (!strict && this._monthsParse[i].test(monthName)) {\n return i;\n }\n }\n }\n\n // MOMENTS\n\n function setMonth(mom, value) {\n var dayOfMonth;\n\n if (!mom.isValid()) {\n // No op\n return mom;\n }\n\n if (typeof value === 'string') {\n if (/^\\d+$/.test(value)) {\n value = toInt(value);\n } else {\n value = mom.localeData().monthsParse(value);\n // TODO: Another silent failure?\n if (!isNumber(value)) {\n return mom;\n }\n }\n }\n\n dayOfMonth = Math.min(mom.date(), daysInMonth(mom.year(), value));\n mom._d['set' + (mom._isUTC ? 'UTC' : '') + 'Month'](value, dayOfMonth);\n return mom;\n }\n\n function getSetMonth(value) {\n if (value != null) {\n setMonth(this, value);\n hooks.updateOffset(this, true);\n return this;\n } else {\n return get(this, 'Month');\n }\n }\n\n function getDaysInMonth() {\n return daysInMonth(this.year(), this.month());\n }\n\n function monthsShortRegex(isStrict) {\n if (this._monthsParseExact) {\n if (!hasOwnProp(this, '_monthsRegex')) {\n computeMonthsParse.call(this);\n }\n if (isStrict) {\n return this._monthsShortStrictRegex;\n } else {\n return this._monthsShortRegex;\n }\n } else {\n if (!hasOwnProp(this, '_monthsShortRegex')) {\n this._monthsShortRegex = defaultMonthsShortRegex;\n }\n return this._monthsShortStrictRegex && isStrict\n ? this._monthsShortStrictRegex\n : this._monthsShortRegex;\n }\n }\n\n function monthsRegex(isStrict) {\n if (this._monthsParseExact) {\n if (!hasOwnProp(this, '_monthsRegex')) {\n computeMonthsParse.call(this);\n }\n if (isStrict) {\n return this._monthsStrictRegex;\n } else {\n return this._monthsRegex;\n }\n } else {\n if (!hasOwnProp(this, '_monthsRegex')) {\n this._monthsRegex = defaultMonthsRegex;\n }\n return this._monthsStrictRegex && isStrict\n ? this._monthsStrictRegex\n : this._monthsRegex;\n }\n }\n\n function computeMonthsParse() {\n function cmpLenRev(a, b) {\n return b.length - a.length;\n }\n\n var shortPieces = [],\n longPieces = [],\n mixedPieces = [],\n i,\n mom;\n for (i = 0; i < 12; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, i]);\n shortPieces.push(this.monthsShort(mom, ''));\n longPieces.push(this.months(mom, ''));\n mixedPieces.push(this.months(mom, ''));\n mixedPieces.push(this.monthsShort(mom, ''));\n }\n // Sorting makes sure if one month (or abbr) is a prefix of another it\n // will match the longer piece.\n shortPieces.sort(cmpLenRev);\n longPieces.sort(cmpLenRev);\n mixedPieces.sort(cmpLenRev);\n for (i = 0; i < 12; i++) {\n shortPieces[i] = regexEscape(shortPieces[i]);\n longPieces[i] = regexEscape(longPieces[i]);\n }\n for (i = 0; i < 24; i++) {\n mixedPieces[i] = regexEscape(mixedPieces[i]);\n }\n\n this._monthsRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._monthsShortRegex = this._monthsRegex;\n this._monthsStrictRegex = new RegExp(\n '^(' + longPieces.join('|') + ')',\n 'i'\n );\n this._monthsShortStrictRegex = new RegExp(\n '^(' + shortPieces.join('|') + ')',\n 'i'\n );\n }\n\n // FORMATTING\n\n addFormatToken('Y', 0, 0, function () {\n var y = this.year();\n return y <= 9999 ? zeroFill(y, 4) : '+' + y;\n });\n\n addFormatToken(0, ['YY', 2], 0, function () {\n return this.year() % 100;\n });\n\n addFormatToken(0, ['YYYY', 4], 0, 'year');\n addFormatToken(0, ['YYYYY', 5], 0, 'year');\n addFormatToken(0, ['YYYYYY', 6, true], 0, 'year');\n\n // ALIASES\n\n addUnitAlias('year', 'y');\n\n // PRIORITIES\n\n addUnitPriority('year', 1);\n\n // PARSING\n\n addRegexToken('Y', matchSigned);\n addRegexToken('YY', match1to2, match2);\n addRegexToken('YYYY', match1to4, match4);\n addRegexToken('YYYYY', match1to6, match6);\n addRegexToken('YYYYYY', match1to6, match6);\n\n addParseToken(['YYYYY', 'YYYYYY'], YEAR);\n addParseToken('YYYY', function (input, array) {\n array[YEAR] =\n input.length === 2 ? hooks.parseTwoDigitYear(input) : toInt(input);\n });\n addParseToken('YY', function (input, array) {\n array[YEAR] = hooks.parseTwoDigitYear(input);\n });\n addParseToken('Y', function (input, array) {\n array[YEAR] = parseInt(input, 10);\n });\n\n // HELPERS\n\n function daysInYear(year) {\n return isLeapYear(year) ? 366 : 365;\n }\n\n // HOOKS\n\n hooks.parseTwoDigitYear = function (input) {\n return toInt(input) + (toInt(input) > 68 ? 1900 : 2000);\n };\n\n // MOMENTS\n\n var getSetYear = makeGetSet('FullYear', true);\n\n function getIsLeapYear() {\n return isLeapYear(this.year());\n }\n\n function createDate(y, m, d, h, M, s, ms) {\n // can't just apply() to create a date:\n // https://stackoverflow.com/q/181348\n var date;\n // the date constructor remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n date = new Date(y + 400, m, d, h, M, s, ms);\n if (isFinite(date.getFullYear())) {\n date.setFullYear(y);\n }\n } else {\n date = new Date(y, m, d, h, M, s, ms);\n }\n\n return date;\n }\n\n function createUTCDate(y) {\n var date, args;\n // the Date.UTC function remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n args = Array.prototype.slice.call(arguments);\n // preserve leap years using a full 400 year cycle, then reset\n args[0] = y + 400;\n date = new Date(Date.UTC.apply(null, args));\n if (isFinite(date.getUTCFullYear())) {\n date.setUTCFullYear(y);\n }\n } else {\n date = new Date(Date.UTC.apply(null, arguments));\n }\n\n return date;\n }\n\n // start-of-first-week - start-of-year\n function firstWeekOffset(year, dow, doy) {\n var // first-week day -- which january is always in the first week (4 for iso, 1 for other)\n fwd = 7 + dow - doy,\n // first-week day local weekday -- which local weekday is fwd\n fwdlw = (7 + createUTCDate(year, 0, fwd).getUTCDay() - dow) % 7;\n\n return -fwdlw + fwd - 1;\n }\n\n // https://en.wikipedia.org/wiki/ISO_week_date#Calculating_a_date_given_the_year.2C_week_number_and_weekday\n function dayOfYearFromWeeks(year, week, weekday, dow, doy) {\n var localWeekday = (7 + weekday - dow) % 7,\n weekOffset = firstWeekOffset(year, dow, doy),\n dayOfYear = 1 + 7 * (week - 1) + localWeekday + weekOffset,\n resYear,\n resDayOfYear;\n\n if (dayOfYear <= 0) {\n resYear = year - 1;\n resDayOfYear = daysInYear(resYear) + dayOfYear;\n } else if (dayOfYear > daysInYear(year)) {\n resYear = year + 1;\n resDayOfYear = dayOfYear - daysInYear(year);\n } else {\n resYear = year;\n resDayOfYear = dayOfYear;\n }\n\n return {\n year: resYear,\n dayOfYear: resDayOfYear,\n };\n }\n\n function weekOfYear(mom, dow, doy) {\n var weekOffset = firstWeekOffset(mom.year(), dow, doy),\n week = Math.floor((mom.dayOfYear() - weekOffset - 1) / 7) + 1,\n resWeek,\n resYear;\n\n if (week < 1) {\n resYear = mom.year() - 1;\n resWeek = week + weeksInYear(resYear, dow, doy);\n } else if (week > weeksInYear(mom.year(), dow, doy)) {\n resWeek = week - weeksInYear(mom.year(), dow, doy);\n resYear = mom.year() + 1;\n } else {\n resYear = mom.year();\n resWeek = week;\n }\n\n return {\n week: resWeek,\n year: resYear,\n };\n }\n\n function weeksInYear(year, dow, doy) {\n var weekOffset = firstWeekOffset(year, dow, doy),\n weekOffsetNext = firstWeekOffset(year + 1, dow, doy);\n return (daysInYear(year) - weekOffset + weekOffsetNext) / 7;\n }\n\n // FORMATTING\n\n addFormatToken('w', ['ww', 2], 'wo', 'week');\n addFormatToken('W', ['WW', 2], 'Wo', 'isoWeek');\n\n // ALIASES\n\n addUnitAlias('week', 'w');\n addUnitAlias('isoWeek', 'W');\n\n // PRIORITIES\n\n addUnitPriority('week', 5);\n addUnitPriority('isoWeek', 5);\n\n // PARSING\n\n addRegexToken('w', match1to2);\n addRegexToken('ww', match1to2, match2);\n addRegexToken('W', match1to2);\n addRegexToken('WW', match1to2, match2);\n\n addWeekParseToken(\n ['w', 'ww', 'W', 'WW'],\n function (input, week, config, token) {\n week[token.substr(0, 1)] = toInt(input);\n }\n );\n\n // HELPERS\n\n // LOCALES\n\n function localeWeek(mom) {\n return weekOfYear(mom, this._week.dow, this._week.doy).week;\n }\n\n var defaultLocaleWeek = {\n dow: 0, // Sunday is the first day of the week.\n doy: 6, // The week that contains Jan 6th is the first week of the year.\n };\n\n function localeFirstDayOfWeek() {\n return this._week.dow;\n }\n\n function localeFirstDayOfYear() {\n return this._week.doy;\n }\n\n // MOMENTS\n\n function getSetWeek(input) {\n var week = this.localeData().week(this);\n return input == null ? week : this.add((input - week) * 7, 'd');\n }\n\n function getSetISOWeek(input) {\n var week = weekOfYear(this, 1, 4).week;\n return input == null ? week : this.add((input - week) * 7, 'd');\n }\n\n // FORMATTING\n\n addFormatToken('d', 0, 'do', 'day');\n\n addFormatToken('dd', 0, 0, function (format) {\n return this.localeData().weekdaysMin(this, format);\n });\n\n addFormatToken('ddd', 0, 0, function (format) {\n return this.localeData().weekdaysShort(this, format);\n });\n\n addFormatToken('dddd', 0, 0, function (format) {\n return this.localeData().weekdays(this, format);\n });\n\n addFormatToken('e', 0, 0, 'weekday');\n addFormatToken('E', 0, 0, 'isoWeekday');\n\n // ALIASES\n\n addUnitAlias('day', 'd');\n addUnitAlias('weekday', 'e');\n addUnitAlias('isoWeekday', 'E');\n\n // PRIORITY\n addUnitPriority('day', 11);\n addUnitPriority('weekday', 11);\n addUnitPriority('isoWeekday', 11);\n\n // PARSING\n\n addRegexToken('d', match1to2);\n addRegexToken('e', match1to2);\n addRegexToken('E', match1to2);\n addRegexToken('dd', function (isStrict, locale) {\n return locale.weekdaysMinRegex(isStrict);\n });\n addRegexToken('ddd', function (isStrict, locale) {\n return locale.weekdaysShortRegex(isStrict);\n });\n addRegexToken('dddd', function (isStrict, locale) {\n return locale.weekdaysRegex(isStrict);\n });\n\n addWeekParseToken(['dd', 'ddd', 'dddd'], function (input, week, config, token) {\n var weekday = config._locale.weekdaysParse(input, token, config._strict);\n // if we didn't get a weekday name, mark the date as invalid\n if (weekday != null) {\n week.d = weekday;\n } else {\n getParsingFlags(config).invalidWeekday = input;\n }\n });\n\n addWeekParseToken(['d', 'e', 'E'], function (input, week, config, token) {\n week[token] = toInt(input);\n });\n\n // HELPERS\n\n function parseWeekday(input, locale) {\n if (typeof input !== 'string') {\n return input;\n }\n\n if (!isNaN(input)) {\n return parseInt(input, 10);\n }\n\n input = locale.weekdaysParse(input);\n if (typeof input === 'number') {\n return input;\n }\n\n return null;\n }\n\n function parseIsoWeekday(input, locale) {\n if (typeof input === 'string') {\n return locale.weekdaysParse(input) % 7 || 7;\n }\n return isNaN(input) ? null : input;\n }\n\n // LOCALES\n function shiftWeekdays(ws, n) {\n return ws.slice(n, 7).concat(ws.slice(0, n));\n }\n\n var defaultLocaleWeekdays =\n 'Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday'.split('_'),\n defaultLocaleWeekdaysShort = 'Sun_Mon_Tue_Wed_Thu_Fri_Sat'.split('_'),\n defaultLocaleWeekdaysMin = 'Su_Mo_Tu_We_Th_Fr_Sa'.split('_'),\n defaultWeekdaysRegex = matchWord,\n defaultWeekdaysShortRegex = matchWord,\n defaultWeekdaysMinRegex = matchWord;\n\n function localeWeekdays(m, format) {\n var weekdays = isArray(this._weekdays)\n ? this._weekdays\n : this._weekdays[\n m && m !== true && this._weekdays.isFormat.test(format)\n ? 'format'\n : 'standalone'\n ];\n return m === true\n ? shiftWeekdays(weekdays, this._week.dow)\n : m\n ? weekdays[m.day()]\n : weekdays;\n }\n\n function localeWeekdaysShort(m) {\n return m === true\n ? shiftWeekdays(this._weekdaysShort, this._week.dow)\n : m\n ? this._weekdaysShort[m.day()]\n : this._weekdaysShort;\n }\n\n function localeWeekdaysMin(m) {\n return m === true\n ? shiftWeekdays(this._weekdaysMin, this._week.dow)\n : m\n ? this._weekdaysMin[m.day()]\n : this._weekdaysMin;\n }\n\n function handleStrictParse$1(weekdayName, format, strict) {\n var i,\n ii,\n mom,\n llc = weekdayName.toLocaleLowerCase();\n if (!this._weekdaysParse) {\n this._weekdaysParse = [];\n this._shortWeekdaysParse = [];\n this._minWeekdaysParse = [];\n\n for (i = 0; i < 7; ++i) {\n mom = createUTC([2000, 1]).day(i);\n this._minWeekdaysParse[i] = this.weekdaysMin(\n mom,\n ''\n ).toLocaleLowerCase();\n this._shortWeekdaysParse[i] = this.weekdaysShort(\n mom,\n ''\n ).toLocaleLowerCase();\n this._weekdaysParse[i] = this.weekdays(mom, '').toLocaleLowerCase();\n }\n }\n\n if (strict) {\n if (format === 'dddd') {\n ii = indexOf.call(this._weekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else if (format === 'ddd') {\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n }\n } else {\n if (format === 'dddd') {\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else if (format === 'ddd') {\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._minWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n } else {\n ii = indexOf.call(this._minWeekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._weekdaysParse, llc);\n if (ii !== -1) {\n return ii;\n }\n ii = indexOf.call(this._shortWeekdaysParse, llc);\n return ii !== -1 ? ii : null;\n }\n }\n }\n\n function localeWeekdaysParse(weekdayName, format, strict) {\n var i, mom, regex;\n\n if (this._weekdaysParseExact) {\n return handleStrictParse$1.call(this, weekdayName, format, strict);\n }\n\n if (!this._weekdaysParse) {\n this._weekdaysParse = [];\n this._minWeekdaysParse = [];\n this._shortWeekdaysParse = [];\n this._fullWeekdaysParse = [];\n }\n\n for (i = 0; i < 7; i++) {\n // make the regex if we don't have it already\n\n mom = createUTC([2000, 1]).day(i);\n if (strict && !this._fullWeekdaysParse[i]) {\n this._fullWeekdaysParse[i] = new RegExp(\n '^' + this.weekdays(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n this._shortWeekdaysParse[i] = new RegExp(\n '^' + this.weekdaysShort(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n this._minWeekdaysParse[i] = new RegExp(\n '^' + this.weekdaysMin(mom, '').replace('.', '\\\\.?') + '$',\n 'i'\n );\n }\n if (!this._weekdaysParse[i]) {\n regex =\n '^' +\n this.weekdays(mom, '') +\n '|^' +\n this.weekdaysShort(mom, '') +\n '|^' +\n this.weekdaysMin(mom, '');\n this._weekdaysParse[i] = new RegExp(regex.replace('.', ''), 'i');\n }\n // test the regex\n if (\n strict &&\n format === 'dddd' &&\n this._fullWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'ddd' &&\n this._shortWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (\n strict &&\n format === 'dd' &&\n this._minWeekdaysParse[i].test(weekdayName)\n ) {\n return i;\n } else if (!strict && this._weekdaysParse[i].test(weekdayName)) {\n return i;\n }\n }\n }\n\n // MOMENTS\n\n function getSetDayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n var day = this._isUTC ? this._d.getUTCDay() : this._d.getDay();\n if (input != null) {\n input = parseWeekday(input, this.localeData());\n return this.add(input - day, 'd');\n } else {\n return day;\n }\n }\n\n function getSetLocaleDayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n var weekday = (this.day() + 7 - this.localeData()._week.dow) % 7;\n return input == null ? weekday : this.add(input - weekday, 'd');\n }\n\n function getSetISODayOfWeek(input) {\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n\n // behaves the same as moment#day except\n // as a getter, returns 7 instead of 0 (1-7 range instead of 0-6)\n // as a setter, sunday should belong to the previous week.\n\n if (input != null) {\n var weekday = parseIsoWeekday(input, this.localeData());\n return this.day(this.day() % 7 ? weekday : weekday - 7);\n } else {\n return this.day() || 7;\n }\n }\n\n function weekdaysRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysStrictRegex;\n } else {\n return this._weekdaysRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n this._weekdaysRegex = defaultWeekdaysRegex;\n }\n return this._weekdaysStrictRegex && isStrict\n ? this._weekdaysStrictRegex\n : this._weekdaysRegex;\n }\n }\n\n function weekdaysShortRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysShortStrictRegex;\n } else {\n return this._weekdaysShortRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysShortRegex')) {\n this._weekdaysShortRegex = defaultWeekdaysShortRegex;\n }\n return this._weekdaysShortStrictRegex && isStrict\n ? this._weekdaysShortStrictRegex\n : this._weekdaysShortRegex;\n }\n }\n\n function weekdaysMinRegex(isStrict) {\n if (this._weekdaysParseExact) {\n if (!hasOwnProp(this, '_weekdaysRegex')) {\n computeWeekdaysParse.call(this);\n }\n if (isStrict) {\n return this._weekdaysMinStrictRegex;\n } else {\n return this._weekdaysMinRegex;\n }\n } else {\n if (!hasOwnProp(this, '_weekdaysMinRegex')) {\n this._weekdaysMinRegex = defaultWeekdaysMinRegex;\n }\n return this._weekdaysMinStrictRegex && isStrict\n ? this._weekdaysMinStrictRegex\n : this._weekdaysMinRegex;\n }\n }\n\n function computeWeekdaysParse() {\n function cmpLenRev(a, b) {\n return b.length - a.length;\n }\n\n var minPieces = [],\n shortPieces = [],\n longPieces = [],\n mixedPieces = [],\n i,\n mom,\n minp,\n shortp,\n longp;\n for (i = 0; i < 7; i++) {\n // make the regex if we don't have it already\n mom = createUTC([2000, 1]).day(i);\n minp = regexEscape(this.weekdaysMin(mom, ''));\n shortp = regexEscape(this.weekdaysShort(mom, ''));\n longp = regexEscape(this.weekdays(mom, ''));\n minPieces.push(minp);\n shortPieces.push(shortp);\n longPieces.push(longp);\n mixedPieces.push(minp);\n mixedPieces.push(shortp);\n mixedPieces.push(longp);\n }\n // Sorting makes sure if one weekday (or abbr) is a prefix of another it\n // will match the longer piece.\n minPieces.sort(cmpLenRev);\n shortPieces.sort(cmpLenRev);\n longPieces.sort(cmpLenRev);\n mixedPieces.sort(cmpLenRev);\n\n this._weekdaysRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._weekdaysShortRegex = this._weekdaysRegex;\n this._weekdaysMinRegex = this._weekdaysRegex;\n\n this._weekdaysStrictRegex = new RegExp(\n '^(' + longPieces.join('|') + ')',\n 'i'\n );\n this._weekdaysShortStrictRegex = new RegExp(\n '^(' + shortPieces.join('|') + ')',\n 'i'\n );\n this._weekdaysMinStrictRegex = new RegExp(\n '^(' + minPieces.join('|') + ')',\n 'i'\n );\n }\n\n // FORMATTING\n\n function hFormat() {\n return this.hours() % 12 || 12;\n }\n\n function kFormat() {\n return this.hours() || 24;\n }\n\n addFormatToken('H', ['HH', 2], 0, 'hour');\n addFormatToken('h', ['hh', 2], 0, hFormat);\n addFormatToken('k', ['kk', 2], 0, kFormat);\n\n addFormatToken('hmm', 0, 0, function () {\n return '' + hFormat.apply(this) + zeroFill(this.minutes(), 2);\n });\n\n addFormatToken('hmmss', 0, 0, function () {\n return (\n '' +\n hFormat.apply(this) +\n zeroFill(this.minutes(), 2) +\n zeroFill(this.seconds(), 2)\n );\n });\n\n addFormatToken('Hmm', 0, 0, function () {\n return '' + this.hours() + zeroFill(this.minutes(), 2);\n });\n\n addFormatToken('Hmmss', 0, 0, function () {\n return (\n '' +\n this.hours() +\n zeroFill(this.minutes(), 2) +\n zeroFill(this.seconds(), 2)\n );\n });\n\n function meridiem(token, lowercase) {\n addFormatToken(token, 0, 0, function () {\n return this.localeData().meridiem(\n this.hours(),\n this.minutes(),\n lowercase\n );\n });\n }\n\n meridiem('a', true);\n meridiem('A', false);\n\n // ALIASES\n\n addUnitAlias('hour', 'h');\n\n // PRIORITY\n addUnitPriority('hour', 13);\n\n // PARSING\n\n function matchMeridiem(isStrict, locale) {\n return locale._meridiemParse;\n }\n\n addRegexToken('a', matchMeridiem);\n addRegexToken('A', matchMeridiem);\n addRegexToken('H', match1to2);\n addRegexToken('h', match1to2);\n addRegexToken('k', match1to2);\n addRegexToken('HH', match1to2, match2);\n addRegexToken('hh', match1to2, match2);\n addRegexToken('kk', match1to2, match2);\n\n addRegexToken('hmm', match3to4);\n addRegexToken('hmmss', match5to6);\n addRegexToken('Hmm', match3to4);\n addRegexToken('Hmmss', match5to6);\n\n addParseToken(['H', 'HH'], HOUR);\n addParseToken(['k', 'kk'], function (input, array, config) {\n var kInput = toInt(input);\n array[HOUR] = kInput === 24 ? 0 : kInput;\n });\n addParseToken(['a', 'A'], function (input, array, config) {\n config._isPm = config._locale.isPM(input);\n config._meridiem = input;\n });\n addParseToken(['h', 'hh'], function (input, array, config) {\n array[HOUR] = toInt(input);\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('hmm', function (input, array, config) {\n var pos = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos));\n array[MINUTE] = toInt(input.substr(pos));\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('hmmss', function (input, array, config) {\n var pos1 = input.length - 4,\n pos2 = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos1));\n array[MINUTE] = toInt(input.substr(pos1, 2));\n array[SECOND] = toInt(input.substr(pos2));\n getParsingFlags(config).bigHour = true;\n });\n addParseToken('Hmm', function (input, array, config) {\n var pos = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos));\n array[MINUTE] = toInt(input.substr(pos));\n });\n addParseToken('Hmmss', function (input, array, config) {\n var pos1 = input.length - 4,\n pos2 = input.length - 2;\n array[HOUR] = toInt(input.substr(0, pos1));\n array[MINUTE] = toInt(input.substr(pos1, 2));\n array[SECOND] = toInt(input.substr(pos2));\n });\n\n // LOCALES\n\n function localeIsPM(input) {\n // IE8 Quirks Mode & IE7 Standards Mode do not allow accessing strings like arrays\n // Using charAt should be more compatible.\n return (input + '').toLowerCase().charAt(0) === 'p';\n }\n\n var defaultLocaleMeridiemParse = /[ap]\\.?m?\\.?/i,\n // Setting the hour should keep the time, because the user explicitly\n // specified which hour they want. So trying to maintain the same hour (in\n // a new timezone) makes sense. Adding/subtracting hours does not follow\n // this rule.\n getSetHour = makeGetSet('Hours', true);\n\n function localeMeridiem(hours, minutes, isLower) {\n if (hours > 11) {\n return isLower ? 'pm' : 'PM';\n } else {\n return isLower ? 'am' : 'AM';\n }\n }\n\n var baseConfig = {\n calendar: defaultCalendar,\n longDateFormat: defaultLongDateFormat,\n invalidDate: defaultInvalidDate,\n ordinal: defaultOrdinal,\n dayOfMonthOrdinalParse: defaultDayOfMonthOrdinalParse,\n relativeTime: defaultRelativeTime,\n\n months: defaultLocaleMonths,\n monthsShort: defaultLocaleMonthsShort,\n\n week: defaultLocaleWeek,\n\n weekdays: defaultLocaleWeekdays,\n weekdaysMin: defaultLocaleWeekdaysMin,\n weekdaysShort: defaultLocaleWeekdaysShort,\n\n meridiemParse: defaultLocaleMeridiemParse,\n };\n\n // internal storage for locale config files\n var locales = {},\n localeFamilies = {},\n globalLocale;\n\n function commonPrefix(arr1, arr2) {\n var i,\n minl = Math.min(arr1.length, arr2.length);\n for (i = 0; i < minl; i += 1) {\n if (arr1[i] !== arr2[i]) {\n return i;\n }\n }\n return minl;\n }\n\n function normalizeLocale(key) {\n return key ? key.toLowerCase().replace('_', '-') : key;\n }\n\n // pick the locale from the array\n // try ['en-au', 'en-gb'] as 'en-au', 'en-gb', 'en', as in move through the list trying each\n // substring from most specific to least, but move to the next array item if it's a more specific variant than the current root\n function chooseLocale(names) {\n var i = 0,\n j,\n next,\n locale,\n split;\n\n while (i < names.length) {\n split = normalizeLocale(names[i]).split('-');\n j = split.length;\n next = normalizeLocale(names[i + 1]);\n next = next ? next.split('-') : null;\n while (j > 0) {\n locale = loadLocale(split.slice(0, j).join('-'));\n if (locale) {\n return locale;\n }\n if (\n next &&\n next.length >= j &&\n commonPrefix(split, next) >= j - 1\n ) {\n //the next array item is better than a shallower substring of this one\n break;\n }\n j--;\n }\n i++;\n }\n return globalLocale;\n }\n\n function isLocaleNameSane(name) {\n // Prevent names that look like filesystem paths, i.e contain '/' or '\\'\n return name.match('^[^/\\\\\\\\]*$') != null;\n }\n\n function loadLocale(name) {\n var oldLocale = null,\n aliasedRequire;\n // TODO: Find a better way to register and load all the locales in Node\n if (\n locales[name] === undefined &&\n typeof module !== 'undefined' &&\n module &&\n module.exports &&\n isLocaleNameSane(name)\n ) {\n try {\n oldLocale = globalLocale._abbr;\n aliasedRequire = require;\n aliasedRequire('./locale/' + name);\n getSetGlobalLocale(oldLocale);\n } catch (e) {\n // mark as not found to avoid repeating expensive file require call causing high CPU\n // when trying to find en-US, en_US, en-us for every format call\n locales[name] = null; // null means not found\n }\n }\n return locales[name];\n }\n\n // This function will load locale and then set the global locale. If\n // no arguments are passed in, it will simply return the current global\n // locale key.\n function getSetGlobalLocale(key, values) {\n var data;\n if (key) {\n if (isUndefined(values)) {\n data = getLocale(key);\n } else {\n data = defineLocale(key, values);\n }\n\n if (data) {\n // moment.duration._locale = moment._locale = data;\n globalLocale = data;\n } else {\n if (typeof console !== 'undefined' && console.warn) {\n //warn user if arguments are passed but the locale could not be set\n console.warn(\n 'Locale ' + key + ' not found. Did you forget to load it?'\n );\n }\n }\n }\n\n return globalLocale._abbr;\n }\n\n function defineLocale(name, config) {\n if (config !== null) {\n var locale,\n parentConfig = baseConfig;\n config.abbr = name;\n if (locales[name] != null) {\n deprecateSimple(\n 'defineLocaleOverride',\n 'use moment.updateLocale(localeName, config) to change ' +\n 'an existing locale. moment.defineLocale(localeName, ' +\n 'config) should only be used for creating a new locale ' +\n 'See http://momentjs.com/guides/#/warnings/define-locale/ for more info.'\n );\n parentConfig = locales[name]._config;\n } else if (config.parentLocale != null) {\n if (locales[config.parentLocale] != null) {\n parentConfig = locales[config.parentLocale]._config;\n } else {\n locale = loadLocale(config.parentLocale);\n if (locale != null) {\n parentConfig = locale._config;\n } else {\n if (!localeFamilies[config.parentLocale]) {\n localeFamilies[config.parentLocale] = [];\n }\n localeFamilies[config.parentLocale].push({\n name: name,\n config: config,\n });\n return null;\n }\n }\n }\n locales[name] = new Locale(mergeConfigs(parentConfig, config));\n\n if (localeFamilies[name]) {\n localeFamilies[name].forEach(function (x) {\n defineLocale(x.name, x.config);\n });\n }\n\n // backwards compat for now: also set the locale\n // make sure we set the locale AFTER all child locales have been\n // created, so we won't end up with the child locale set.\n getSetGlobalLocale(name);\n\n return locales[name];\n } else {\n // useful for testing\n delete locales[name];\n return null;\n }\n }\n\n function updateLocale(name, config) {\n if (config != null) {\n var locale,\n tmpLocale,\n parentConfig = baseConfig;\n\n if (locales[name] != null && locales[name].parentLocale != null) {\n // Update existing child locale in-place to avoid memory-leaks\n locales[name].set(mergeConfigs(locales[name]._config, config));\n } else {\n // MERGE\n tmpLocale = loadLocale(name);\n if (tmpLocale != null) {\n parentConfig = tmpLocale._config;\n }\n config = mergeConfigs(parentConfig, config);\n if (tmpLocale == null) {\n // updateLocale is called for creating a new locale\n // Set abbr so it will have a name (getters return\n // undefined otherwise).\n config.abbr = name;\n }\n locale = new Locale(config);\n locale.parentLocale = locales[name];\n locales[name] = locale;\n }\n\n // backwards compat for now: also set the locale\n getSetGlobalLocale(name);\n } else {\n // pass null for config to unupdate, useful for tests\n if (locales[name] != null) {\n if (locales[name].parentLocale != null) {\n locales[name] = locales[name].parentLocale;\n if (name === getSetGlobalLocale()) {\n getSetGlobalLocale(name);\n }\n } else if (locales[name] != null) {\n delete locales[name];\n }\n }\n }\n return locales[name];\n }\n\n // returns locale data\n function getLocale(key) {\n var locale;\n\n if (key && key._locale && key._locale._abbr) {\n key = key._locale._abbr;\n }\n\n if (!key) {\n return globalLocale;\n }\n\n if (!isArray(key)) {\n //short-circuit everything else\n locale = loadLocale(key);\n if (locale) {\n return locale;\n }\n key = [key];\n }\n\n return chooseLocale(key);\n }\n\n function listLocales() {\n return keys(locales);\n }\n\n function checkOverflow(m) {\n var overflow,\n a = m._a;\n\n if (a && getParsingFlags(m).overflow === -2) {\n overflow =\n a[MONTH] < 0 || a[MONTH] > 11\n ? MONTH\n : a[DATE] < 1 || a[DATE] > daysInMonth(a[YEAR], a[MONTH])\n ? DATE\n : a[HOUR] < 0 ||\n a[HOUR] > 24 ||\n (a[HOUR] === 24 &&\n (a[MINUTE] !== 0 ||\n a[SECOND] !== 0 ||\n a[MILLISECOND] !== 0))\n ? HOUR\n : a[MINUTE] < 0 || a[MINUTE] > 59\n ? MINUTE\n : a[SECOND] < 0 || a[SECOND] > 59\n ? SECOND\n : a[MILLISECOND] < 0 || a[MILLISECOND] > 999\n ? MILLISECOND\n : -1;\n\n if (\n getParsingFlags(m)._overflowDayOfYear &&\n (overflow < YEAR || overflow > DATE)\n ) {\n overflow = DATE;\n }\n if (getParsingFlags(m)._overflowWeeks && overflow === -1) {\n overflow = WEEK;\n }\n if (getParsingFlags(m)._overflowWeekday && overflow === -1) {\n overflow = WEEKDAY;\n }\n\n getParsingFlags(m).overflow = overflow;\n }\n\n return m;\n }\n\n // iso 8601 regex\n // 0000-00-00 0000-W00 or 0000-W00-0 + T + 00 or 00:00 or 00:00:00 or 00:00:00.000 + +00:00 or +0000 or +00)\n var extendedIsoRegex =\n /^\\s*((?:[+-]\\d{6}|\\d{4})-(?:\\d\\d-\\d\\d|W\\d\\d-\\d|W\\d\\d|\\d\\d\\d|\\d\\d))(?:(T| )(\\d\\d(?::\\d\\d(?::\\d\\d(?:[.,]\\d+)?)?)?)([+-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/,\n basicIsoRegex =\n /^\\s*((?:[+-]\\d{6}|\\d{4})(?:\\d\\d\\d\\d|W\\d\\d\\d|W\\d\\d|\\d\\d\\d|\\d\\d|))(?:(T| )(\\d\\d(?:\\d\\d(?:\\d\\d(?:[.,]\\d+)?)?)?)([+-]\\d\\d(?::?\\d\\d)?|\\s*Z)?)?$/,\n tzRegex = /Z|[+-]\\d\\d(?::?\\d\\d)?/,\n isoDates = [\n ['YYYYYY-MM-DD', /[+-]\\d{6}-\\d\\d-\\d\\d/],\n ['YYYY-MM-DD', /\\d{4}-\\d\\d-\\d\\d/],\n ['GGGG-[W]WW-E', /\\d{4}-W\\d\\d-\\d/],\n ['GGGG-[W]WW', /\\d{4}-W\\d\\d/, false],\n ['YYYY-DDD', /\\d{4}-\\d{3}/],\n ['YYYY-MM', /\\d{4}-\\d\\d/, false],\n ['YYYYYYMMDD', /[+-]\\d{10}/],\n ['YYYYMMDD', /\\d{8}/],\n ['GGGG[W]WWE', /\\d{4}W\\d{3}/],\n ['GGGG[W]WW', /\\d{4}W\\d{2}/, false],\n ['YYYYDDD', /\\d{7}/],\n ['YYYYMM', /\\d{6}/, false],\n ['YYYY', /\\d{4}/, false],\n ],\n // iso time formats and regexes\n isoTimes = [\n ['HH:mm:ss.SSSS', /\\d\\d:\\d\\d:\\d\\d\\.\\d+/],\n ['HH:mm:ss,SSSS', /\\d\\d:\\d\\d:\\d\\d,\\d+/],\n ['HH:mm:ss', /\\d\\d:\\d\\d:\\d\\d/],\n ['HH:mm', /\\d\\d:\\d\\d/],\n ['HHmmss.SSSS', /\\d\\d\\d\\d\\d\\d\\.\\d+/],\n ['HHmmss,SSSS', /\\d\\d\\d\\d\\d\\d,\\d+/],\n ['HHmmss', /\\d\\d\\d\\d\\d\\d/],\n ['HHmm', /\\d\\d\\d\\d/],\n ['HH', /\\d\\d/],\n ],\n aspNetJsonRegex = /^\\/?Date\\((-?\\d+)/i,\n // RFC 2822 regex: For details see https://tools.ietf.org/html/rfc2822#section-3.3\n rfc2822 =\n /^(?:(Mon|Tue|Wed|Thu|Fri|Sat|Sun),?\\s)?(\\d{1,2})\\s(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\\s(\\d{2,4})\\s(\\d\\d):(\\d\\d)(?::(\\d\\d))?\\s(?:(UT|GMT|[ECMP][SD]T)|([Zz])|([+-]\\d{4}))$/,\n obsOffsets = {\n UT: 0,\n GMT: 0,\n EDT: -4 * 60,\n EST: -5 * 60,\n CDT: -5 * 60,\n CST: -6 * 60,\n MDT: -6 * 60,\n MST: -7 * 60,\n PDT: -7 * 60,\n PST: -8 * 60,\n };\n\n // date from iso format\n function configFromISO(config) {\n var i,\n l,\n string = config._i,\n match = extendedIsoRegex.exec(string) || basicIsoRegex.exec(string),\n allowTime,\n dateFormat,\n timeFormat,\n tzFormat,\n isoDatesLen = isoDates.length,\n isoTimesLen = isoTimes.length;\n\n if (match) {\n getParsingFlags(config).iso = true;\n for (i = 0, l = isoDatesLen; i < l; i++) {\n if (isoDates[i][1].exec(match[1])) {\n dateFormat = isoDates[i][0];\n allowTime = isoDates[i][2] !== false;\n break;\n }\n }\n if (dateFormat == null) {\n config._isValid = false;\n return;\n }\n if (match[3]) {\n for (i = 0, l = isoTimesLen; i < l; i++) {\n if (isoTimes[i][1].exec(match[3])) {\n // match[2] should be 'T' or space\n timeFormat = (match[2] || ' ') + isoTimes[i][0];\n break;\n }\n }\n if (timeFormat == null) {\n config._isValid = false;\n return;\n }\n }\n if (!allowTime && timeFormat != null) {\n config._isValid = false;\n return;\n }\n if (match[4]) {\n if (tzRegex.exec(match[4])) {\n tzFormat = 'Z';\n } else {\n config._isValid = false;\n return;\n }\n }\n config._f = dateFormat + (timeFormat || '') + (tzFormat || '');\n configFromStringAndFormat(config);\n } else {\n config._isValid = false;\n }\n }\n\n function extractFromRFC2822Strings(\n yearStr,\n monthStr,\n dayStr,\n hourStr,\n minuteStr,\n secondStr\n ) {\n var result = [\n untruncateYear(yearStr),\n defaultLocaleMonthsShort.indexOf(monthStr),\n parseInt(dayStr, 10),\n parseInt(hourStr, 10),\n parseInt(minuteStr, 10),\n ];\n\n if (secondStr) {\n result.push(parseInt(secondStr, 10));\n }\n\n return result;\n }\n\n function untruncateYear(yearStr) {\n var year = parseInt(yearStr, 10);\n if (year <= 49) {\n return 2000 + year;\n } else if (year <= 999) {\n return 1900 + year;\n }\n return year;\n }\n\n function preprocessRFC2822(s) {\n // Remove comments and folding whitespace and replace multiple-spaces with a single space\n return s\n .replace(/\\([^()]*\\)|[\\n\\t]/g, ' ')\n .replace(/(\\s\\s+)/g, ' ')\n .replace(/^\\s\\s*/, '')\n .replace(/\\s\\s*$/, '');\n }\n\n function checkWeekday(weekdayStr, parsedInput, config) {\n if (weekdayStr) {\n // TODO: Replace the vanilla JS Date object with an independent day-of-week check.\n var weekdayProvided = defaultLocaleWeekdaysShort.indexOf(weekdayStr),\n weekdayActual = new Date(\n parsedInput[0],\n parsedInput[1],\n parsedInput[2]\n ).getDay();\n if (weekdayProvided !== weekdayActual) {\n getParsingFlags(config).weekdayMismatch = true;\n config._isValid = false;\n return false;\n }\n }\n return true;\n }\n\n function calculateOffset(obsOffset, militaryOffset, numOffset) {\n if (obsOffset) {\n return obsOffsets[obsOffset];\n } else if (militaryOffset) {\n // the only allowed military tz is Z\n return 0;\n } else {\n var hm = parseInt(numOffset, 10),\n m = hm % 100,\n h = (hm - m) / 100;\n return h * 60 + m;\n }\n }\n\n // date and time from ref 2822 format\n function configFromRFC2822(config) {\n var match = rfc2822.exec(preprocessRFC2822(config._i)),\n parsedArray;\n if (match) {\n parsedArray = extractFromRFC2822Strings(\n match[4],\n match[3],\n match[2],\n match[5],\n match[6],\n match[7]\n );\n if (!checkWeekday(match[1], parsedArray, config)) {\n return;\n }\n\n config._a = parsedArray;\n config._tzm = calculateOffset(match[8], match[9], match[10]);\n\n config._d = createUTCDate.apply(null, config._a);\n config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);\n\n getParsingFlags(config).rfc2822 = true;\n } else {\n config._isValid = false;\n }\n }\n\n // date from 1) ASP.NET, 2) ISO, 3) RFC 2822 formats, or 4) optional fallback if parsing isn't strict\n function configFromString(config) {\n var matched = aspNetJsonRegex.exec(config._i);\n if (matched !== null) {\n config._d = new Date(+matched[1]);\n return;\n }\n\n configFromISO(config);\n if (config._isValid === false) {\n delete config._isValid;\n } else {\n return;\n }\n\n configFromRFC2822(config);\n if (config._isValid === false) {\n delete config._isValid;\n } else {\n return;\n }\n\n if (config._strict) {\n config._isValid = false;\n } else {\n // Final attempt, use Input Fallback\n hooks.createFromInputFallback(config);\n }\n }\n\n hooks.createFromInputFallback = deprecate(\n 'value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), ' +\n 'which is not reliable across all browsers and versions. Non RFC2822/ISO date formats are ' +\n 'discouraged. Please refer to http://momentjs.com/guides/#/warnings/js-date/ for more info.',\n function (config) {\n config._d = new Date(config._i + (config._useUTC ? ' UTC' : ''));\n }\n );\n\n // Pick the first defined of two or three arguments.\n function defaults(a, b, c) {\n if (a != null) {\n return a;\n }\n if (b != null) {\n return b;\n }\n return c;\n }\n\n function currentDateArray(config) {\n // hooks is actually the exported moment object\n var nowValue = new Date(hooks.now());\n if (config._useUTC) {\n return [\n nowValue.getUTCFullYear(),\n nowValue.getUTCMonth(),\n nowValue.getUTCDate(),\n ];\n }\n return [nowValue.getFullYear(), nowValue.getMonth(), nowValue.getDate()];\n }\n\n // convert an array to a date.\n // the array should mirror the parameters below\n // note: all values past the year are optional and will default to the lowest possible value.\n // [year, month, day , hour, minute, second, millisecond]\n function configFromArray(config) {\n var i,\n date,\n input = [],\n currentDate,\n expectedWeekday,\n yearToUse;\n\n if (config._d) {\n return;\n }\n\n currentDate = currentDateArray(config);\n\n //compute day of the year from weeks and weekdays\n if (config._w && config._a[DATE] == null && config._a[MONTH] == null) {\n dayOfYearFromWeekInfo(config);\n }\n\n //if the day of the year is set, figure out what it is\n if (config._dayOfYear != null) {\n yearToUse = defaults(config._a[YEAR], currentDate[YEAR]);\n\n if (\n config._dayOfYear > daysInYear(yearToUse) ||\n config._dayOfYear === 0\n ) {\n getParsingFlags(config)._overflowDayOfYear = true;\n }\n\n date = createUTCDate(yearToUse, 0, config._dayOfYear);\n config._a[MONTH] = date.getUTCMonth();\n config._a[DATE] = date.getUTCDate();\n }\n\n // Default to current date.\n // * if no year, month, day of month are given, default to today\n // * if day of month is given, default month and year\n // * if month is given, default only year\n // * if year is given, don't default anything\n for (i = 0; i < 3 && config._a[i] == null; ++i) {\n config._a[i] = input[i] = currentDate[i];\n }\n\n // Zero out whatever was not defaulted, including time\n for (; i < 7; i++) {\n config._a[i] = input[i] =\n config._a[i] == null ? (i === 2 ? 1 : 0) : config._a[i];\n }\n\n // Check for 24:00:00.000\n if (\n config._a[HOUR] === 24 &&\n config._a[MINUTE] === 0 &&\n config._a[SECOND] === 0 &&\n config._a[MILLISECOND] === 0\n ) {\n config._nextDay = true;\n config._a[HOUR] = 0;\n }\n\n config._d = (config._useUTC ? createUTCDate : createDate).apply(\n null,\n input\n );\n expectedWeekday = config._useUTC\n ? config._d.getUTCDay()\n : config._d.getDay();\n\n // Apply timezone offset from input. The actual utcOffset can be changed\n // with parseZone.\n if (config._tzm != null) {\n config._d.setUTCMinutes(config._d.getUTCMinutes() - config._tzm);\n }\n\n if (config._nextDay) {\n config._a[HOUR] = 24;\n }\n\n // check for mismatching day of week\n if (\n config._w &&\n typeof config._w.d !== 'undefined' &&\n config._w.d !== expectedWeekday\n ) {\n getParsingFlags(config).weekdayMismatch = true;\n }\n }\n\n function dayOfYearFromWeekInfo(config) {\n var w, weekYear, week, weekday, dow, doy, temp, weekdayOverflow, curWeek;\n\n w = config._w;\n if (w.GG != null || w.W != null || w.E != null) {\n dow = 1;\n doy = 4;\n\n // TODO: We need to take the current isoWeekYear, but that depends on\n // how we interpret now (local, utc, fixed offset). So create\n // a now version of current config (take local/utc/offset flags, and\n // create now).\n weekYear = defaults(\n w.GG,\n config._a[YEAR],\n weekOfYear(createLocal(), 1, 4).year\n );\n week = defaults(w.W, 1);\n weekday = defaults(w.E, 1);\n if (weekday < 1 || weekday > 7) {\n weekdayOverflow = true;\n }\n } else {\n dow = config._locale._week.dow;\n doy = config._locale._week.doy;\n\n curWeek = weekOfYear(createLocal(), dow, doy);\n\n weekYear = defaults(w.gg, config._a[YEAR], curWeek.year);\n\n // Default to current week.\n week = defaults(w.w, curWeek.week);\n\n if (w.d != null) {\n // weekday -- low day numbers are considered next week\n weekday = w.d;\n if (weekday < 0 || weekday > 6) {\n weekdayOverflow = true;\n }\n } else if (w.e != null) {\n // local weekday -- counting starts from beginning of week\n weekday = w.e + dow;\n if (w.e < 0 || w.e > 6) {\n weekdayOverflow = true;\n }\n } else {\n // default to beginning of week\n weekday = dow;\n }\n }\n if (week < 1 || week > weeksInYear(weekYear, dow, doy)) {\n getParsingFlags(config)._overflowWeeks = true;\n } else if (weekdayOverflow != null) {\n getParsingFlags(config)._overflowWeekday = true;\n } else {\n temp = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy);\n config._a[YEAR] = temp.year;\n config._dayOfYear = temp.dayOfYear;\n }\n }\n\n // constant that refers to the ISO standard\n hooks.ISO_8601 = function () {};\n\n // constant that refers to the RFC 2822 form\n hooks.RFC_2822 = function () {};\n\n // date from string and format string\n function configFromStringAndFormat(config) {\n // TODO: Move this to another part of the creation flow to prevent circular deps\n if (config._f === hooks.ISO_8601) {\n configFromISO(config);\n return;\n }\n if (config._f === hooks.RFC_2822) {\n configFromRFC2822(config);\n return;\n }\n config._a = [];\n getParsingFlags(config).empty = true;\n\n // This array is used to make a Date, either with `new Date` or `Date.UTC`\n var string = '' + config._i,\n i,\n parsedInput,\n tokens,\n token,\n skipped,\n stringLength = string.length,\n totalParsedInputLength = 0,\n era,\n tokenLen;\n\n tokens =\n expandFormat(config._f, config._locale).match(formattingTokens) || [];\n tokenLen = tokens.length;\n for (i = 0; i < tokenLen; i++) {\n token = tokens[i];\n parsedInput = (string.match(getParseRegexForToken(token, config)) ||\n [])[0];\n if (parsedInput) {\n skipped = string.substr(0, string.indexOf(parsedInput));\n if (skipped.length > 0) {\n getParsingFlags(config).unusedInput.push(skipped);\n }\n string = string.slice(\n string.indexOf(parsedInput) + parsedInput.length\n );\n totalParsedInputLength += parsedInput.length;\n }\n // don't parse if it's not a known token\n if (formatTokenFunctions[token]) {\n if (parsedInput) {\n getParsingFlags(config).empty = false;\n } else {\n getParsingFlags(config).unusedTokens.push(token);\n }\n addTimeToArrayFromToken(token, parsedInput, config);\n } else if (config._strict && !parsedInput) {\n getParsingFlags(config).unusedTokens.push(token);\n }\n }\n\n // add remaining unparsed input length to the string\n getParsingFlags(config).charsLeftOver =\n stringLength - totalParsedInputLength;\n if (string.length > 0) {\n getParsingFlags(config).unusedInput.push(string);\n }\n\n // clear _12h flag if hour is <= 12\n if (\n config._a[HOUR] <= 12 &&\n getParsingFlags(config).bigHour === true &&\n config._a[HOUR] > 0\n ) {\n getParsingFlags(config).bigHour = undefined;\n }\n\n getParsingFlags(config).parsedDateParts = config._a.slice(0);\n getParsingFlags(config).meridiem = config._meridiem;\n // handle meridiem\n config._a[HOUR] = meridiemFixWrap(\n config._locale,\n config._a[HOUR],\n config._meridiem\n );\n\n // handle era\n era = getParsingFlags(config).era;\n if (era !== null) {\n config._a[YEAR] = config._locale.erasConvertYear(era, config._a[YEAR]);\n }\n\n configFromArray(config);\n checkOverflow(config);\n }\n\n function meridiemFixWrap(locale, hour, meridiem) {\n var isPm;\n\n if (meridiem == null) {\n // nothing to do\n return hour;\n }\n if (locale.meridiemHour != null) {\n return locale.meridiemHour(hour, meridiem);\n } else if (locale.isPM != null) {\n // Fallback\n isPm = locale.isPM(meridiem);\n if (isPm && hour < 12) {\n hour += 12;\n }\n if (!isPm && hour === 12) {\n hour = 0;\n }\n return hour;\n } else {\n // this is not supposed to happen\n return hour;\n }\n }\n\n // date from string and array of format strings\n function configFromStringAndArray(config) {\n var tempConfig,\n bestMoment,\n scoreToBeat,\n i,\n currentScore,\n validFormatFound,\n bestFormatIsValid = false,\n configfLen = config._f.length;\n\n if (configfLen === 0) {\n getParsingFlags(config).invalidFormat = true;\n config._d = new Date(NaN);\n return;\n }\n\n for (i = 0; i < configfLen; i++) {\n currentScore = 0;\n validFormatFound = false;\n tempConfig = copyConfig({}, config);\n if (config._useUTC != null) {\n tempConfig._useUTC = config._useUTC;\n }\n tempConfig._f = config._f[i];\n configFromStringAndFormat(tempConfig);\n\n if (isValid(tempConfig)) {\n validFormatFound = true;\n }\n\n // if there is any input that was not parsed add a penalty for that format\n currentScore += getParsingFlags(tempConfig).charsLeftOver;\n\n //or tokens\n currentScore += getParsingFlags(tempConfig).unusedTokens.length * 10;\n\n getParsingFlags(tempConfig).score = currentScore;\n\n if (!bestFormatIsValid) {\n if (\n scoreToBeat == null ||\n currentScore < scoreToBeat ||\n validFormatFound\n ) {\n scoreToBeat = currentScore;\n bestMoment = tempConfig;\n if (validFormatFound) {\n bestFormatIsValid = true;\n }\n }\n } else {\n if (currentScore < scoreToBeat) {\n scoreToBeat = currentScore;\n bestMoment = tempConfig;\n }\n }\n }\n\n extend(config, bestMoment || tempConfig);\n }\n\n function configFromObject(config) {\n if (config._d) {\n return;\n }\n\n var i = normalizeObjectUnits(config._i),\n dayOrDate = i.day === undefined ? i.date : i.day;\n config._a = map(\n [i.year, i.month, dayOrDate, i.hour, i.minute, i.second, i.millisecond],\n function (obj) {\n return obj && parseInt(obj, 10);\n }\n );\n\n configFromArray(config);\n }\n\n function createFromConfig(config) {\n var res = new Moment(checkOverflow(prepareConfig(config)));\n if (res._nextDay) {\n // Adding is smart enough around DST\n res.add(1, 'd');\n res._nextDay = undefined;\n }\n\n return res;\n }\n\n function prepareConfig(config) {\n var input = config._i,\n format = config._f;\n\n config._locale = config._locale || getLocale(config._l);\n\n if (input === null || (format === undefined && input === '')) {\n return createInvalid({ nullInput: true });\n }\n\n if (typeof input === 'string') {\n config._i = input = config._locale.preparse(input);\n }\n\n if (isMoment(input)) {\n return new Moment(checkOverflow(input));\n } else if (isDate(input)) {\n config._d = input;\n } else if (isArray(format)) {\n configFromStringAndArray(config);\n } else if (format) {\n configFromStringAndFormat(config);\n } else {\n configFromInput(config);\n }\n\n if (!isValid(config)) {\n config._d = null;\n }\n\n return config;\n }\n\n function configFromInput(config) {\n var input = config._i;\n if (isUndefined(input)) {\n config._d = new Date(hooks.now());\n } else if (isDate(input)) {\n config._d = new Date(input.valueOf());\n } else if (typeof input === 'string') {\n configFromString(config);\n } else if (isArray(input)) {\n config._a = map(input.slice(0), function (obj) {\n return parseInt(obj, 10);\n });\n configFromArray(config);\n } else if (isObject(input)) {\n configFromObject(config);\n } else if (isNumber(input)) {\n // from milliseconds\n config._d = new Date(input);\n } else {\n hooks.createFromInputFallback(config);\n }\n }\n\n function createLocalOrUTC(input, format, locale, strict, isUTC) {\n var c = {};\n\n if (format === true || format === false) {\n strict = format;\n format = undefined;\n }\n\n if (locale === true || locale === false) {\n strict = locale;\n locale = undefined;\n }\n\n if (\n (isObject(input) && isObjectEmpty(input)) ||\n (isArray(input) && input.length === 0)\n ) {\n input = undefined;\n }\n // object construction must be done this way.\n // https://github.com/moment/moment/issues/1423\n c._isAMomentObject = true;\n c._useUTC = c._isUTC = isUTC;\n c._l = locale;\n c._i = input;\n c._f = format;\n c._strict = strict;\n\n return createFromConfig(c);\n }\n\n function createLocal(input, format, locale, strict) {\n return createLocalOrUTC(input, format, locale, strict, false);\n }\n\n var prototypeMin = deprecate(\n 'moment().min is deprecated, use moment.max instead. http://momentjs.com/guides/#/warnings/min-max/',\n function () {\n var other = createLocal.apply(null, arguments);\n if (this.isValid() && other.isValid()) {\n return other < this ? this : other;\n } else {\n return createInvalid();\n }\n }\n ),\n prototypeMax = deprecate(\n 'moment().max is deprecated, use moment.min instead. http://momentjs.com/guides/#/warnings/min-max/',\n function () {\n var other = createLocal.apply(null, arguments);\n if (this.isValid() && other.isValid()) {\n return other > this ? this : other;\n } else {\n return createInvalid();\n }\n }\n );\n\n // Pick a moment m from moments so that m[fn](other) is true for all\n // other. This relies on the function fn to be transitive.\n //\n // moments should either be an array of moment objects or an array, whose\n // first element is an array of moment objects.\n function pickBy(fn, moments) {\n var res, i;\n if (moments.length === 1 && isArray(moments[0])) {\n moments = moments[0];\n }\n if (!moments.length) {\n return createLocal();\n }\n res = moments[0];\n for (i = 1; i < moments.length; ++i) {\n if (!moments[i].isValid() || moments[i][fn](res)) {\n res = moments[i];\n }\n }\n return res;\n }\n\n // TODO: Use [].sort instead?\n function min() {\n var args = [].slice.call(arguments, 0);\n\n return pickBy('isBefore', args);\n }\n\n function max() {\n var args = [].slice.call(arguments, 0);\n\n return pickBy('isAfter', args);\n }\n\n var now = function () {\n return Date.now ? Date.now() : +new Date();\n };\n\n var ordering = [\n 'year',\n 'quarter',\n 'month',\n 'week',\n 'day',\n 'hour',\n 'minute',\n 'second',\n 'millisecond',\n ];\n\n function isDurationValid(m) {\n var key,\n unitHasDecimal = false,\n i,\n orderLen = ordering.length;\n for (key in m) {\n if (\n hasOwnProp(m, key) &&\n !(\n indexOf.call(ordering, key) !== -1 &&\n (m[key] == null || !isNaN(m[key]))\n )\n ) {\n return false;\n }\n }\n\n for (i = 0; i < orderLen; ++i) {\n if (m[ordering[i]]) {\n if (unitHasDecimal) {\n return false; // only allow non-integers for smallest unit\n }\n if (parseFloat(m[ordering[i]]) !== toInt(m[ordering[i]])) {\n unitHasDecimal = true;\n }\n }\n }\n\n return true;\n }\n\n function isValid$1() {\n return this._isValid;\n }\n\n function createInvalid$1() {\n return createDuration(NaN);\n }\n\n function Duration(duration) {\n var normalizedInput = normalizeObjectUnits(duration),\n years = normalizedInput.year || 0,\n quarters = normalizedInput.quarter || 0,\n months = normalizedInput.month || 0,\n weeks = normalizedInput.week || normalizedInput.isoWeek || 0,\n days = normalizedInput.day || 0,\n hours = normalizedInput.hour || 0,\n minutes = normalizedInput.minute || 0,\n seconds = normalizedInput.second || 0,\n milliseconds = normalizedInput.millisecond || 0;\n\n this._isValid = isDurationValid(normalizedInput);\n\n // representation for dateAddRemove\n this._milliseconds =\n +milliseconds +\n seconds * 1e3 + // 1000\n minutes * 6e4 + // 1000 * 60\n hours * 1000 * 60 * 60; //using 1000 * 60 * 60 instead of 36e5 to avoid floating point rounding errors https://github.com/moment/moment/issues/2978\n // Because of dateAddRemove treats 24 hours as different from a\n // day when working around DST, we need to store them separately\n this._days = +days + weeks * 7;\n // It is impossible to translate months into days without knowing\n // which months you are are talking about, so we have to store\n // it separately.\n this._months = +months + quarters * 3 + years * 12;\n\n this._data = {};\n\n this._locale = getLocale();\n\n this._bubble();\n }\n\n function isDuration(obj) {\n return obj instanceof Duration;\n }\n\n function absRound(number) {\n if (number < 0) {\n return Math.round(-1 * number) * -1;\n } else {\n return Math.round(number);\n }\n }\n\n // compare two arrays, return the number of differences\n function compareArrays(array1, array2, dontConvert) {\n var len = Math.min(array1.length, array2.length),\n lengthDiff = Math.abs(array1.length - array2.length),\n diffs = 0,\n i;\n for (i = 0; i < len; i++) {\n if (\n (dontConvert && array1[i] !== array2[i]) ||\n (!dontConvert && toInt(array1[i]) !== toInt(array2[i]))\n ) {\n diffs++;\n }\n }\n return diffs + lengthDiff;\n }\n\n // FORMATTING\n\n function offset(token, separator) {\n addFormatToken(token, 0, 0, function () {\n var offset = this.utcOffset(),\n sign = '+';\n if (offset < 0) {\n offset = -offset;\n sign = '-';\n }\n return (\n sign +\n zeroFill(~~(offset / 60), 2) +\n separator +\n zeroFill(~~offset % 60, 2)\n );\n });\n }\n\n offset('Z', ':');\n offset('ZZ', '');\n\n // PARSING\n\n addRegexToken('Z', matchShortOffset);\n addRegexToken('ZZ', matchShortOffset);\n addParseToken(['Z', 'ZZ'], function (input, array, config) {\n config._useUTC = true;\n config._tzm = offsetFromString(matchShortOffset, input);\n });\n\n // HELPERS\n\n // timezone chunker\n // '+10:00' > ['10', '00']\n // '-1530' > ['-15', '30']\n var chunkOffset = /([\\+\\-]|\\d\\d)/gi;\n\n function offsetFromString(matcher, string) {\n var matches = (string || '').match(matcher),\n chunk,\n parts,\n minutes;\n\n if (matches === null) {\n return null;\n }\n\n chunk = matches[matches.length - 1] || [];\n parts = (chunk + '').match(chunkOffset) || ['-', 0, 0];\n minutes = +(parts[1] * 60) + toInt(parts[2]);\n\n return minutes === 0 ? 0 : parts[0] === '+' ? minutes : -minutes;\n }\n\n // Return a moment from input, that is local/utc/zone equivalent to model.\n function cloneWithOffset(input, model) {\n var res, diff;\n if (model._isUTC) {\n res = model.clone();\n diff =\n (isMoment(input) || isDate(input)\n ? input.valueOf()\n : createLocal(input).valueOf()) - res.valueOf();\n // Use low-level api, because this fn is low-level api.\n res._d.setTime(res._d.valueOf() + diff);\n hooks.updateOffset(res, false);\n return res;\n } else {\n return createLocal(input).local();\n }\n }\n\n function getDateOffset(m) {\n // On Firefox.24 Date#getTimezoneOffset returns a floating point.\n // https://github.com/moment/moment/pull/1871\n return -Math.round(m._d.getTimezoneOffset());\n }\n\n // HOOKS\n\n // This function will be called whenever a moment is mutated.\n // It is intended to keep the offset in sync with the timezone.\n hooks.updateOffset = function () {};\n\n // MOMENTS\n\n // keepLocalTime = true means only change the timezone, without\n // affecting the local hour. So 5:31:26 +0300 --[utcOffset(2, true)]-->\n // 5:31:26 +0200 It is possible that 5:31:26 doesn't exist with offset\n // +0200, so we adjust the time as needed, to be valid.\n //\n // Keeping the time actually adds/subtracts (one hour)\n // from the actual represented time. That is why we call updateOffset\n // a second time. In case it wants us to change the offset again\n // _changeInProgress == true case, then we have to adjust, because\n // there is no such time in the given timezone.\n function getSetOffset(input, keepLocalTime, keepMinutes) {\n var offset = this._offset || 0,\n localAdjust;\n if (!this.isValid()) {\n return input != null ? this : NaN;\n }\n if (input != null) {\n if (typeof input === 'string') {\n input = offsetFromString(matchShortOffset, input);\n if (input === null) {\n return this;\n }\n } else if (Math.abs(input) < 16 && !keepMinutes) {\n input = input * 60;\n }\n if (!this._isUTC && keepLocalTime) {\n localAdjust = getDateOffset(this);\n }\n this._offset = input;\n this._isUTC = true;\n if (localAdjust != null) {\n this.add(localAdjust, 'm');\n }\n if (offset !== input) {\n if (!keepLocalTime || this._changeInProgress) {\n addSubtract(\n this,\n createDuration(input - offset, 'm'),\n 1,\n false\n );\n } else if (!this._changeInProgress) {\n this._changeInProgress = true;\n hooks.updateOffset(this, true);\n this._changeInProgress = null;\n }\n }\n return this;\n } else {\n return this._isUTC ? offset : getDateOffset(this);\n }\n }\n\n function getSetZone(input, keepLocalTime) {\n if (input != null) {\n if (typeof input !== 'string') {\n input = -input;\n }\n\n this.utcOffset(input, keepLocalTime);\n\n return this;\n } else {\n return -this.utcOffset();\n }\n }\n\n function setOffsetToUTC(keepLocalTime) {\n return this.utcOffset(0, keepLocalTime);\n }\n\n function setOffsetToLocal(keepLocalTime) {\n if (this._isUTC) {\n this.utcOffset(0, keepLocalTime);\n this._isUTC = false;\n\n if (keepLocalTime) {\n this.subtract(getDateOffset(this), 'm');\n }\n }\n return this;\n }\n\n function setOffsetToParsedOffset() {\n if (this._tzm != null) {\n this.utcOffset(this._tzm, false, true);\n } else if (typeof this._i === 'string') {\n var tZone = offsetFromString(matchOffset, this._i);\n if (tZone != null) {\n this.utcOffset(tZone);\n } else {\n this.utcOffset(0, true);\n }\n }\n return this;\n }\n\n function hasAlignedHourOffset(input) {\n if (!this.isValid()) {\n return false;\n }\n input = input ? createLocal(input).utcOffset() : 0;\n\n return (this.utcOffset() - input) % 60 === 0;\n }\n\n function isDaylightSavingTime() {\n return (\n this.utcOffset() > this.clone().month(0).utcOffset() ||\n this.utcOffset() > this.clone().month(5).utcOffset()\n );\n }\n\n function isDaylightSavingTimeShifted() {\n if (!isUndefined(this._isDSTShifted)) {\n return this._isDSTShifted;\n }\n\n var c = {},\n other;\n\n copyConfig(c, this);\n c = prepareConfig(c);\n\n if (c._a) {\n other = c._isUTC ? createUTC(c._a) : createLocal(c._a);\n this._isDSTShifted =\n this.isValid() && compareArrays(c._a, other.toArray()) > 0;\n } else {\n this._isDSTShifted = false;\n }\n\n return this._isDSTShifted;\n }\n\n function isLocal() {\n return this.isValid() ? !this._isUTC : false;\n }\n\n function isUtcOffset() {\n return this.isValid() ? this._isUTC : false;\n }\n\n function isUtc() {\n return this.isValid() ? this._isUTC && this._offset === 0 : false;\n }\n\n // ASP.NET json date format regex\n var aspNetRegex = /^(-|\\+)?(?:(\\d*)[. ])?(\\d+):(\\d+)(?::(\\d+)(\\.\\d*)?)?$/,\n // from http://docs.closure-library.googlecode.com/git/closure_goog_date_date.js.source.html\n // somewhat more in line with 4.4.3.2 2004 spec, but allows decimal anywhere\n // and further modified to allow for strings containing both week and day\n isoRegex =\n /^(-|\\+)?P(?:([-+]?[0-9,.]*)Y)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)W)?(?:([-+]?[0-9,.]*)D)?(?:T(?:([-+]?[0-9,.]*)H)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)S)?)?$/;\n\n function createDuration(input, key) {\n var duration = input,\n // matching against regexp is expensive, do it on demand\n match = null,\n sign,\n ret,\n diffRes;\n\n if (isDuration(input)) {\n duration = {\n ms: input._milliseconds,\n d: input._days,\n M: input._months,\n };\n } else if (isNumber(input) || !isNaN(+input)) {\n duration = {};\n if (key) {\n duration[key] = +input;\n } else {\n duration.milliseconds = +input;\n }\n } else if ((match = aspNetRegex.exec(input))) {\n sign = match[1] === '-' ? -1 : 1;\n duration = {\n y: 0,\n d: toInt(match[DATE]) * sign,\n h: toInt(match[HOUR]) * sign,\n m: toInt(match[MINUTE]) * sign,\n s: toInt(match[SECOND]) * sign,\n ms: toInt(absRound(match[MILLISECOND] * 1000)) * sign, // the millisecond decimal point is included in the match\n };\n } else if ((match = isoRegex.exec(input))) {\n sign = match[1] === '-' ? -1 : 1;\n duration = {\n y: parseIso(match[2], sign),\n M: parseIso(match[3], sign),\n w: parseIso(match[4], sign),\n d: parseIso(match[5], sign),\n h: parseIso(match[6], sign),\n m: parseIso(match[7], sign),\n s: parseIso(match[8], sign),\n };\n } else if (duration == null) {\n // checks for null or undefined\n duration = {};\n } else if (\n typeof duration === 'object' &&\n ('from' in duration || 'to' in duration)\n ) {\n diffRes = momentsDifference(\n createLocal(duration.from),\n createLocal(duration.to)\n );\n\n duration = {};\n duration.ms = diffRes.milliseconds;\n duration.M = diffRes.months;\n }\n\n ret = new Duration(duration);\n\n if (isDuration(input) && hasOwnProp(input, '_locale')) {\n ret._locale = input._locale;\n }\n\n if (isDuration(input) && hasOwnProp(input, '_isValid')) {\n ret._isValid = input._isValid;\n }\n\n return ret;\n }\n\n createDuration.fn = Duration.prototype;\n createDuration.invalid = createInvalid$1;\n\n function parseIso(inp, sign) {\n // We'd normally use ~~inp for this, but unfortunately it also\n // converts floats to ints.\n // inp may be undefined, so careful calling replace on it.\n var res = inp && parseFloat(inp.replace(',', '.'));\n // apply sign while we're at it\n return (isNaN(res) ? 0 : res) * sign;\n }\n\n function positiveMomentsDifference(base, other) {\n var res = {};\n\n res.months =\n other.month() - base.month() + (other.year() - base.year()) * 12;\n if (base.clone().add(res.months, 'M').isAfter(other)) {\n --res.months;\n }\n\n res.milliseconds = +other - +base.clone().add(res.months, 'M');\n\n return res;\n }\n\n function momentsDifference(base, other) {\n var res;\n if (!(base.isValid() && other.isValid())) {\n return { milliseconds: 0, months: 0 };\n }\n\n other = cloneWithOffset(other, base);\n if (base.isBefore(other)) {\n res = positiveMomentsDifference(base, other);\n } else {\n res = positiveMomentsDifference(other, base);\n res.milliseconds = -res.milliseconds;\n res.months = -res.months;\n }\n\n return res;\n }\n\n // TODO: remove 'name' arg after deprecation is removed\n function createAdder(direction, name) {\n return function (val, period) {\n var dur, tmp;\n //invert the arguments, but complain about it\n if (period !== null && !isNaN(+period)) {\n deprecateSimple(\n name,\n 'moment().' +\n name +\n '(period, number) is deprecated. Please use moment().' +\n name +\n '(number, period). ' +\n 'See http://momentjs.com/guides/#/warnings/add-inverted-param/ for more info.'\n );\n tmp = val;\n val = period;\n period = tmp;\n }\n\n dur = createDuration(val, period);\n addSubtract(this, dur, direction);\n return this;\n };\n }\n\n function addSubtract(mom, duration, isAdding, updateOffset) {\n var milliseconds = duration._milliseconds,\n days = absRound(duration._days),\n months = absRound(duration._months);\n\n if (!mom.isValid()) {\n // No op\n return;\n }\n\n updateOffset = updateOffset == null ? true : updateOffset;\n\n if (months) {\n setMonth(mom, get(mom, 'Month') + months * isAdding);\n }\n if (days) {\n set$1(mom, 'Date', get(mom, 'Date') + days * isAdding);\n }\n if (milliseconds) {\n mom._d.setTime(mom._d.valueOf() + milliseconds * isAdding);\n }\n if (updateOffset) {\n hooks.updateOffset(mom, days || months);\n }\n }\n\n var add = createAdder(1, 'add'),\n subtract = createAdder(-1, 'subtract');\n\n function isString(input) {\n return typeof input === 'string' || input instanceof String;\n }\n\n // type MomentInput = Moment | Date | string | number | (number | string)[] | MomentInputObject | void; // null | undefined\n function isMomentInput(input) {\n return (\n isMoment(input) ||\n isDate(input) ||\n isString(input) ||\n isNumber(input) ||\n isNumberOrStringArray(input) ||\n isMomentInputObject(input) ||\n input === null ||\n input === undefined\n );\n }\n\n function isMomentInputObject(input) {\n var objectTest = isObject(input) && !isObjectEmpty(input),\n propertyTest = false,\n properties = [\n 'years',\n 'year',\n 'y',\n 'months',\n 'month',\n 'M',\n 'days',\n 'day',\n 'd',\n 'dates',\n 'date',\n 'D',\n 'hours',\n 'hour',\n 'h',\n 'minutes',\n 'minute',\n 'm',\n 'seconds',\n 'second',\n 's',\n 'milliseconds',\n 'millisecond',\n 'ms',\n ],\n i,\n property,\n propertyLen = properties.length;\n\n for (i = 0; i < propertyLen; i += 1) {\n property = properties[i];\n propertyTest = propertyTest || hasOwnProp(input, property);\n }\n\n return objectTest && propertyTest;\n }\n\n function isNumberOrStringArray(input) {\n var arrayTest = isArray(input),\n dataTypeTest = false;\n if (arrayTest) {\n dataTypeTest =\n input.filter(function (item) {\n return !isNumber(item) && isString(input);\n }).length === 0;\n }\n return arrayTest && dataTypeTest;\n }\n\n function isCalendarSpec(input) {\n var objectTest = isObject(input) && !isObjectEmpty(input),\n propertyTest = false,\n properties = [\n 'sameDay',\n 'nextDay',\n 'lastDay',\n 'nextWeek',\n 'lastWeek',\n 'sameElse',\n ],\n i,\n property;\n\n for (i = 0; i < properties.length; i += 1) {\n property = properties[i];\n propertyTest = propertyTest || hasOwnProp(input, property);\n }\n\n return objectTest && propertyTest;\n }\n\n function getCalendarFormat(myMoment, now) {\n var diff = myMoment.diff(now, 'days', true);\n return diff < -6\n ? 'sameElse'\n : diff < -1\n ? 'lastWeek'\n : diff < 0\n ? 'lastDay'\n : diff < 1\n ? 'sameDay'\n : diff < 2\n ? 'nextDay'\n : diff < 7\n ? 'nextWeek'\n : 'sameElse';\n }\n\n function calendar$1(time, formats) {\n // Support for single parameter, formats only overload to the calendar function\n if (arguments.length === 1) {\n if (!arguments[0]) {\n time = undefined;\n formats = undefined;\n } else if (isMomentInput(arguments[0])) {\n time = arguments[0];\n formats = undefined;\n } else if (isCalendarSpec(arguments[0])) {\n formats = arguments[0];\n time = undefined;\n }\n }\n // We want to compare the start of today, vs this.\n // Getting start-of-today depends on whether we're local/utc/offset or not.\n var now = time || createLocal(),\n sod = cloneWithOffset(now, this).startOf('day'),\n format = hooks.calendarFormat(this, sod) || 'sameElse',\n output =\n formats &&\n (isFunction(formats[format])\n ? formats[format].call(this, now)\n : formats[format]);\n\n return this.format(\n output || this.localeData().calendar(format, this, createLocal(now))\n );\n }\n\n function clone() {\n return new Moment(this);\n }\n\n function isAfter(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input);\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() > localInput.valueOf();\n } else {\n return localInput.valueOf() < this.clone().startOf(units).valueOf();\n }\n }\n\n function isBefore(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input);\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() < localInput.valueOf();\n } else {\n return this.clone().endOf(units).valueOf() < localInput.valueOf();\n }\n }\n\n function isBetween(from, to, units, inclusivity) {\n var localFrom = isMoment(from) ? from : createLocal(from),\n localTo = isMoment(to) ? to : createLocal(to);\n if (!(this.isValid() && localFrom.isValid() && localTo.isValid())) {\n return false;\n }\n inclusivity = inclusivity || '()';\n return (\n (inclusivity[0] === '('\n ? this.isAfter(localFrom, units)\n : !this.isBefore(localFrom, units)) &&\n (inclusivity[1] === ')'\n ? this.isBefore(localTo, units)\n : !this.isAfter(localTo, units))\n );\n }\n\n function isSame(input, units) {\n var localInput = isMoment(input) ? input : createLocal(input),\n inputMs;\n if (!(this.isValid() && localInput.isValid())) {\n return false;\n }\n units = normalizeUnits(units) || 'millisecond';\n if (units === 'millisecond') {\n return this.valueOf() === localInput.valueOf();\n } else {\n inputMs = localInput.valueOf();\n return (\n this.clone().startOf(units).valueOf() <= inputMs &&\n inputMs <= this.clone().endOf(units).valueOf()\n );\n }\n }\n\n function isSameOrAfter(input, units) {\n return this.isSame(input, units) || this.isAfter(input, units);\n }\n\n function isSameOrBefore(input, units) {\n return this.isSame(input, units) || this.isBefore(input, units);\n }\n\n function diff(input, units, asFloat) {\n var that, zoneDelta, output;\n\n if (!this.isValid()) {\n return NaN;\n }\n\n that = cloneWithOffset(input, this);\n\n if (!that.isValid()) {\n return NaN;\n }\n\n zoneDelta = (that.utcOffset() - this.utcOffset()) * 6e4;\n\n units = normalizeUnits(units);\n\n switch (units) {\n case 'year':\n output = monthDiff(this, that) / 12;\n break;\n case 'month':\n output = monthDiff(this, that);\n break;\n case 'quarter':\n output = monthDiff(this, that) / 3;\n break;\n case 'second':\n output = (this - that) / 1e3;\n break; // 1000\n case 'minute':\n output = (this - that) / 6e4;\n break; // 1000 * 60\n case 'hour':\n output = (this - that) / 36e5;\n break; // 1000 * 60 * 60\n case 'day':\n output = (this - that - zoneDelta) / 864e5;\n break; // 1000 * 60 * 60 * 24, negate dst\n case 'week':\n output = (this - that - zoneDelta) / 6048e5;\n break; // 1000 * 60 * 60 * 24 * 7, negate dst\n default:\n output = this - that;\n }\n\n return asFloat ? output : absFloor(output);\n }\n\n function monthDiff(a, b) {\n if (a.date() < b.date()) {\n // end-of-month calculations work correct when the start month has more\n // days than the end month.\n return -monthDiff(b, a);\n }\n // difference in months\n var wholeMonthDiff = (b.year() - a.year()) * 12 + (b.month() - a.month()),\n // b is in (anchor - 1 month, anchor + 1 month)\n anchor = a.clone().add(wholeMonthDiff, 'months'),\n anchor2,\n adjust;\n\n if (b - anchor < 0) {\n anchor2 = a.clone().add(wholeMonthDiff - 1, 'months');\n // linear across the month\n adjust = (b - anchor) / (anchor - anchor2);\n } else {\n anchor2 = a.clone().add(wholeMonthDiff + 1, 'months');\n // linear across the month\n adjust = (b - anchor) / (anchor2 - anchor);\n }\n\n //check for negative zero, return zero if negative zero\n return -(wholeMonthDiff + adjust) || 0;\n }\n\n hooks.defaultFormat = 'YYYY-MM-DDTHH:mm:ssZ';\n hooks.defaultFormatUtc = 'YYYY-MM-DDTHH:mm:ss[Z]';\n\n function toString() {\n return this.clone().locale('en').format('ddd MMM DD YYYY HH:mm:ss [GMT]ZZ');\n }\n\n function toISOString(keepOffset) {\n if (!this.isValid()) {\n return null;\n }\n var utc = keepOffset !== true,\n m = utc ? this.clone().utc() : this;\n if (m.year() < 0 || m.year() > 9999) {\n return formatMoment(\n m,\n utc\n ? 'YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]'\n : 'YYYYYY-MM-DD[T]HH:mm:ss.SSSZ'\n );\n }\n if (isFunction(Date.prototype.toISOString)) {\n // native implementation is ~50x faster, use it when we can\n if (utc) {\n return this.toDate().toISOString();\n } else {\n return new Date(this.valueOf() + this.utcOffset() * 60 * 1000)\n .toISOString()\n .replace('Z', formatMoment(m, 'Z'));\n }\n }\n return formatMoment(\n m,\n utc ? 'YYYY-MM-DD[T]HH:mm:ss.SSS[Z]' : 'YYYY-MM-DD[T]HH:mm:ss.SSSZ'\n );\n }\n\n /**\n * Return a human readable representation of a moment that can\n * also be evaluated to get a new moment which is the same\n *\n * @link https://nodejs.org/dist/latest/docs/api/util.html#util_custom_inspect_function_on_objects\n */\n function inspect() {\n if (!this.isValid()) {\n return 'moment.invalid(/* ' + this._i + ' */)';\n }\n var func = 'moment',\n zone = '',\n prefix,\n year,\n datetime,\n suffix;\n if (!this.isLocal()) {\n func = this.utcOffset() === 0 ? 'moment.utc' : 'moment.parseZone';\n zone = 'Z';\n }\n prefix = '[' + func + '(\"]';\n year = 0 <= this.year() && this.year() <= 9999 ? 'YYYY' : 'YYYYYY';\n datetime = '-MM-DD[T]HH:mm:ss.SSS';\n suffix = zone + '[\")]';\n\n return this.format(prefix + year + datetime + suffix);\n }\n\n function format(inputString) {\n if (!inputString) {\n inputString = this.isUtc()\n ? hooks.defaultFormatUtc\n : hooks.defaultFormat;\n }\n var output = formatMoment(this, inputString);\n return this.localeData().postformat(output);\n }\n\n function from(time, withoutSuffix) {\n if (\n this.isValid() &&\n ((isMoment(time) && time.isValid()) || createLocal(time).isValid())\n ) {\n return createDuration({ to: this, from: time })\n .locale(this.locale())\n .humanize(!withoutSuffix);\n } else {\n return this.localeData().invalidDate();\n }\n }\n\n function fromNow(withoutSuffix) {\n return this.from(createLocal(), withoutSuffix);\n }\n\n function to(time, withoutSuffix) {\n if (\n this.isValid() &&\n ((isMoment(time) && time.isValid()) || createLocal(time).isValid())\n ) {\n return createDuration({ from: this, to: time })\n .locale(this.locale())\n .humanize(!withoutSuffix);\n } else {\n return this.localeData().invalidDate();\n }\n }\n\n function toNow(withoutSuffix) {\n return this.to(createLocal(), withoutSuffix);\n }\n\n // If passed a locale key, it will set the locale for this\n // instance. Otherwise, it will return the locale configuration\n // variables for this instance.\n function locale(key) {\n var newLocaleData;\n\n if (key === undefined) {\n return this._locale._abbr;\n } else {\n newLocaleData = getLocale(key);\n if (newLocaleData != null) {\n this._locale = newLocaleData;\n }\n return this;\n }\n }\n\n var lang = deprecate(\n 'moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.',\n function (key) {\n if (key === undefined) {\n return this.localeData();\n } else {\n return this.locale(key);\n }\n }\n );\n\n function localeData() {\n return this._locale;\n }\n\n var MS_PER_SECOND = 1000,\n MS_PER_MINUTE = 60 * MS_PER_SECOND,\n MS_PER_HOUR = 60 * MS_PER_MINUTE,\n MS_PER_400_YEARS = (365 * 400 + 97) * 24 * MS_PER_HOUR;\n\n // actual modulo - handles negative numbers (for dates before 1970):\n function mod$1(dividend, divisor) {\n return ((dividend % divisor) + divisor) % divisor;\n }\n\n function localStartOfDate(y, m, d) {\n // the date constructor remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n return new Date(y + 400, m, d) - MS_PER_400_YEARS;\n } else {\n return new Date(y, m, d).valueOf();\n }\n }\n\n function utcStartOfDate(y, m, d) {\n // Date.UTC remaps years 0-99 to 1900-1999\n if (y < 100 && y >= 0) {\n // preserve leap years using a full 400 year cycle, then reset\n return Date.UTC(y + 400, m, d) - MS_PER_400_YEARS;\n } else {\n return Date.UTC(y, m, d);\n }\n }\n\n function startOf(units) {\n var time, startOfDate;\n units = normalizeUnits(units);\n if (units === undefined || units === 'millisecond' || !this.isValid()) {\n return this;\n }\n\n startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;\n\n switch (units) {\n case 'year':\n time = startOfDate(this.year(), 0, 1);\n break;\n case 'quarter':\n time = startOfDate(\n this.year(),\n this.month() - (this.month() % 3),\n 1\n );\n break;\n case 'month':\n time = startOfDate(this.year(), this.month(), 1);\n break;\n case 'week':\n time = startOfDate(\n this.year(),\n this.month(),\n this.date() - this.weekday()\n );\n break;\n case 'isoWeek':\n time = startOfDate(\n this.year(),\n this.month(),\n this.date() - (this.isoWeekday() - 1)\n );\n break;\n case 'day':\n case 'date':\n time = startOfDate(this.year(), this.month(), this.date());\n break;\n case 'hour':\n time = this._d.valueOf();\n time -= mod$1(\n time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),\n MS_PER_HOUR\n );\n break;\n case 'minute':\n time = this._d.valueOf();\n time -= mod$1(time, MS_PER_MINUTE);\n break;\n case 'second':\n time = this._d.valueOf();\n time -= mod$1(time, MS_PER_SECOND);\n break;\n }\n\n this._d.setTime(time);\n hooks.updateOffset(this, true);\n return this;\n }\n\n function endOf(units) {\n var time, startOfDate;\n units = normalizeUnits(units);\n if (units === undefined || units === 'millisecond' || !this.isValid()) {\n return this;\n }\n\n startOfDate = this._isUTC ? utcStartOfDate : localStartOfDate;\n\n switch (units) {\n case 'year':\n time = startOfDate(this.year() + 1, 0, 1) - 1;\n break;\n case 'quarter':\n time =\n startOfDate(\n this.year(),\n this.month() - (this.month() % 3) + 3,\n 1\n ) - 1;\n break;\n case 'month':\n time = startOfDate(this.year(), this.month() + 1, 1) - 1;\n break;\n case 'week':\n time =\n startOfDate(\n this.year(),\n this.month(),\n this.date() - this.weekday() + 7\n ) - 1;\n break;\n case 'isoWeek':\n time =\n startOfDate(\n this.year(),\n this.month(),\n this.date() - (this.isoWeekday() - 1) + 7\n ) - 1;\n break;\n case 'day':\n case 'date':\n time = startOfDate(this.year(), this.month(), this.date() + 1) - 1;\n break;\n case 'hour':\n time = this._d.valueOf();\n time +=\n MS_PER_HOUR -\n mod$1(\n time + (this._isUTC ? 0 : this.utcOffset() * MS_PER_MINUTE),\n MS_PER_HOUR\n ) -\n 1;\n break;\n case 'minute':\n time = this._d.valueOf();\n time += MS_PER_MINUTE - mod$1(time, MS_PER_MINUTE) - 1;\n break;\n case 'second':\n time = this._d.valueOf();\n time += MS_PER_SECOND - mod$1(time, MS_PER_SECOND) - 1;\n break;\n }\n\n this._d.setTime(time);\n hooks.updateOffset(this, true);\n return this;\n }\n\n function valueOf() {\n return this._d.valueOf() - (this._offset || 0) * 60000;\n }\n\n function unix() {\n return Math.floor(this.valueOf() / 1000);\n }\n\n function toDate() {\n return new Date(this.valueOf());\n }\n\n function toArray() {\n var m = this;\n return [\n m.year(),\n m.month(),\n m.date(),\n m.hour(),\n m.minute(),\n m.second(),\n m.millisecond(),\n ];\n }\n\n function toObject() {\n var m = this;\n return {\n years: m.year(),\n months: m.month(),\n date: m.date(),\n hours: m.hours(),\n minutes: m.minutes(),\n seconds: m.seconds(),\n milliseconds: m.milliseconds(),\n };\n }\n\n function toJSON() {\n // new Date(NaN).toJSON() === null\n return this.isValid() ? this.toISOString() : null;\n }\n\n function isValid$2() {\n return isValid(this);\n }\n\n function parsingFlags() {\n return extend({}, getParsingFlags(this));\n }\n\n function invalidAt() {\n return getParsingFlags(this).overflow;\n }\n\n function creationData() {\n return {\n input: this._i,\n format: this._f,\n locale: this._locale,\n isUTC: this._isUTC,\n strict: this._strict,\n };\n }\n\n addFormatToken('N', 0, 0, 'eraAbbr');\n addFormatToken('NN', 0, 0, 'eraAbbr');\n addFormatToken('NNN', 0, 0, 'eraAbbr');\n addFormatToken('NNNN', 0, 0, 'eraName');\n addFormatToken('NNNNN', 0, 0, 'eraNarrow');\n\n addFormatToken('y', ['y', 1], 'yo', 'eraYear');\n addFormatToken('y', ['yy', 2], 0, 'eraYear');\n addFormatToken('y', ['yyy', 3], 0, 'eraYear');\n addFormatToken('y', ['yyyy', 4], 0, 'eraYear');\n\n addRegexToken('N', matchEraAbbr);\n addRegexToken('NN', matchEraAbbr);\n addRegexToken('NNN', matchEraAbbr);\n addRegexToken('NNNN', matchEraName);\n addRegexToken('NNNNN', matchEraNarrow);\n\n addParseToken(\n ['N', 'NN', 'NNN', 'NNNN', 'NNNNN'],\n function (input, array, config, token) {\n var era = config._locale.erasParse(input, token, config._strict);\n if (era) {\n getParsingFlags(config).era = era;\n } else {\n getParsingFlags(config).invalidEra = input;\n }\n }\n );\n\n addRegexToken('y', matchUnsigned);\n addRegexToken('yy', matchUnsigned);\n addRegexToken('yyy', matchUnsigned);\n addRegexToken('yyyy', matchUnsigned);\n addRegexToken('yo', matchEraYearOrdinal);\n\n addParseToken(['y', 'yy', 'yyy', 'yyyy'], YEAR);\n addParseToken(['yo'], function (input, array, config, token) {\n var match;\n if (config._locale._eraYearOrdinalRegex) {\n match = input.match(config._locale._eraYearOrdinalRegex);\n }\n\n if (config._locale.eraYearOrdinalParse) {\n array[YEAR] = config._locale.eraYearOrdinalParse(input, match);\n } else {\n array[YEAR] = parseInt(input, 10);\n }\n });\n\n function localeEras(m, format) {\n var i,\n l,\n date,\n eras = this._eras || getLocale('en')._eras;\n for (i = 0, l = eras.length; i < l; ++i) {\n switch (typeof eras[i].since) {\n case 'string':\n // truncate time\n date = hooks(eras[i].since).startOf('day');\n eras[i].since = date.valueOf();\n break;\n }\n\n switch (typeof eras[i].until) {\n case 'undefined':\n eras[i].until = +Infinity;\n break;\n case 'string':\n // truncate time\n date = hooks(eras[i].until).startOf('day').valueOf();\n eras[i].until = date.valueOf();\n break;\n }\n }\n return eras;\n }\n\n function localeErasParse(eraName, format, strict) {\n var i,\n l,\n eras = this.eras(),\n name,\n abbr,\n narrow;\n eraName = eraName.toUpperCase();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n name = eras[i].name.toUpperCase();\n abbr = eras[i].abbr.toUpperCase();\n narrow = eras[i].narrow.toUpperCase();\n\n if (strict) {\n switch (format) {\n case 'N':\n case 'NN':\n case 'NNN':\n if (abbr === eraName) {\n return eras[i];\n }\n break;\n\n case 'NNNN':\n if (name === eraName) {\n return eras[i];\n }\n break;\n\n case 'NNNNN':\n if (narrow === eraName) {\n return eras[i];\n }\n break;\n }\n } else if ([name, abbr, narrow].indexOf(eraName) >= 0) {\n return eras[i];\n }\n }\n }\n\n function localeErasConvertYear(era, year) {\n var dir = era.since <= era.until ? +1 : -1;\n if (year === undefined) {\n return hooks(era.since).year();\n } else {\n return hooks(era.since).year() + (year - era.offset) * dir;\n }\n }\n\n function getEraName() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].name;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].name;\n }\n }\n\n return '';\n }\n\n function getEraNarrow() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].narrow;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].narrow;\n }\n }\n\n return '';\n }\n\n function getEraAbbr() {\n var i,\n l,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (eras[i].since <= val && val <= eras[i].until) {\n return eras[i].abbr;\n }\n if (eras[i].until <= val && val <= eras[i].since) {\n return eras[i].abbr;\n }\n }\n\n return '';\n }\n\n function getEraYear() {\n var i,\n l,\n dir,\n val,\n eras = this.localeData().eras();\n for (i = 0, l = eras.length; i < l; ++i) {\n dir = eras[i].since <= eras[i].until ? +1 : -1;\n\n // truncate time\n val = this.clone().startOf('day').valueOf();\n\n if (\n (eras[i].since <= val && val <= eras[i].until) ||\n (eras[i].until <= val && val <= eras[i].since)\n ) {\n return (\n (this.year() - hooks(eras[i].since).year()) * dir +\n eras[i].offset\n );\n }\n }\n\n return this.year();\n }\n\n function erasNameRegex(isStrict) {\n if (!hasOwnProp(this, '_erasNameRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasNameRegex : this._erasRegex;\n }\n\n function erasAbbrRegex(isStrict) {\n if (!hasOwnProp(this, '_erasAbbrRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasAbbrRegex : this._erasRegex;\n }\n\n function erasNarrowRegex(isStrict) {\n if (!hasOwnProp(this, '_erasNarrowRegex')) {\n computeErasParse.call(this);\n }\n return isStrict ? this._erasNarrowRegex : this._erasRegex;\n }\n\n function matchEraAbbr(isStrict, locale) {\n return locale.erasAbbrRegex(isStrict);\n }\n\n function matchEraName(isStrict, locale) {\n return locale.erasNameRegex(isStrict);\n }\n\n function matchEraNarrow(isStrict, locale) {\n return locale.erasNarrowRegex(isStrict);\n }\n\n function matchEraYearOrdinal(isStrict, locale) {\n return locale._eraYearOrdinalRegex || matchUnsigned;\n }\n\n function computeErasParse() {\n var abbrPieces = [],\n namePieces = [],\n narrowPieces = [],\n mixedPieces = [],\n i,\n l,\n eras = this.eras();\n\n for (i = 0, l = eras.length; i < l; ++i) {\n namePieces.push(regexEscape(eras[i].name));\n abbrPieces.push(regexEscape(eras[i].abbr));\n narrowPieces.push(regexEscape(eras[i].narrow));\n\n mixedPieces.push(regexEscape(eras[i].name));\n mixedPieces.push(regexEscape(eras[i].abbr));\n mixedPieces.push(regexEscape(eras[i].narrow));\n }\n\n this._erasRegex = new RegExp('^(' + mixedPieces.join('|') + ')', 'i');\n this._erasNameRegex = new RegExp('^(' + namePieces.join('|') + ')', 'i');\n this._erasAbbrRegex = new RegExp('^(' + abbrPieces.join('|') + ')', 'i');\n this._erasNarrowRegex = new RegExp(\n '^(' + narrowPieces.join('|') + ')',\n 'i'\n );\n }\n\n // FORMATTING\n\n addFormatToken(0, ['gg', 2], 0, function () {\n return this.weekYear() % 100;\n });\n\n addFormatToken(0, ['GG', 2], 0, function () {\n return this.isoWeekYear() % 100;\n });\n\n function addWeekYearFormatToken(token, getter) {\n addFormatToken(0, [token, token.length], 0, getter);\n }\n\n addWeekYearFormatToken('gggg', 'weekYear');\n addWeekYearFormatToken('ggggg', 'weekYear');\n addWeekYearFormatToken('GGGG', 'isoWeekYear');\n addWeekYearFormatToken('GGGGG', 'isoWeekYear');\n\n // ALIASES\n\n addUnitAlias('weekYear', 'gg');\n addUnitAlias('isoWeekYear', 'GG');\n\n // PRIORITY\n\n addUnitPriority('weekYear', 1);\n addUnitPriority('isoWeekYear', 1);\n\n // PARSING\n\n addRegexToken('G', matchSigned);\n addRegexToken('g', matchSigned);\n addRegexToken('GG', match1to2, match2);\n addRegexToken('gg', match1to2, match2);\n addRegexToken('GGGG', match1to4, match4);\n addRegexToken('gggg', match1to4, match4);\n addRegexToken('GGGGG', match1to6, match6);\n addRegexToken('ggggg', match1to6, match6);\n\n addWeekParseToken(\n ['gggg', 'ggggg', 'GGGG', 'GGGGG'],\n function (input, week, config, token) {\n week[token.substr(0, 2)] = toInt(input);\n }\n );\n\n addWeekParseToken(['gg', 'GG'], function (input, week, config, token) {\n week[token] = hooks.parseTwoDigitYear(input);\n });\n\n // MOMENTS\n\n function getSetWeekYear(input) {\n return getSetWeekYearHelper.call(\n this,\n input,\n this.week(),\n this.weekday(),\n this.localeData()._week.dow,\n this.localeData()._week.doy\n );\n }\n\n function getSetISOWeekYear(input) {\n return getSetWeekYearHelper.call(\n this,\n input,\n this.isoWeek(),\n this.isoWeekday(),\n 1,\n 4\n );\n }\n\n function getISOWeeksInYear() {\n return weeksInYear(this.year(), 1, 4);\n }\n\n function getISOWeeksInISOWeekYear() {\n return weeksInYear(this.isoWeekYear(), 1, 4);\n }\n\n function getWeeksInYear() {\n var weekInfo = this.localeData()._week;\n return weeksInYear(this.year(), weekInfo.dow, weekInfo.doy);\n }\n\n function getWeeksInWeekYear() {\n var weekInfo = this.localeData()._week;\n return weeksInYear(this.weekYear(), weekInfo.dow, weekInfo.doy);\n }\n\n function getSetWeekYearHelper(input, week, weekday, dow, doy) {\n var weeksTarget;\n if (input == null) {\n return weekOfYear(this, dow, doy).year;\n } else {\n weeksTarget = weeksInYear(input, dow, doy);\n if (week > weeksTarget) {\n week = weeksTarget;\n }\n return setWeekAll.call(this, input, week, weekday, dow, doy);\n }\n }\n\n function setWeekAll(weekYear, week, weekday, dow, doy) {\n var dayOfYearData = dayOfYearFromWeeks(weekYear, week, weekday, dow, doy),\n date = createUTCDate(dayOfYearData.year, 0, dayOfYearData.dayOfYear);\n\n this.year(date.getUTCFullYear());\n this.month(date.getUTCMonth());\n this.date(date.getUTCDate());\n return this;\n }\n\n // FORMATTING\n\n addFormatToken('Q', 0, 'Qo', 'quarter');\n\n // ALIASES\n\n addUnitAlias('quarter', 'Q');\n\n // PRIORITY\n\n addUnitPriority('quarter', 7);\n\n // PARSING\n\n addRegexToken('Q', match1);\n addParseToken('Q', function (input, array) {\n array[MONTH] = (toInt(input) - 1) * 3;\n });\n\n // MOMENTS\n\n function getSetQuarter(input) {\n return input == null\n ? Math.ceil((this.month() + 1) / 3)\n : this.month((input - 1) * 3 + (this.month() % 3));\n }\n\n // FORMATTING\n\n addFormatToken('D', ['DD', 2], 'Do', 'date');\n\n // ALIASES\n\n addUnitAlias('date', 'D');\n\n // PRIORITY\n addUnitPriority('date', 9);\n\n // PARSING\n\n addRegexToken('D', match1to2);\n addRegexToken('DD', match1to2, match2);\n addRegexToken('Do', function (isStrict, locale) {\n // TODO: Remove \"ordinalParse\" fallback in next major release.\n return isStrict\n ? locale._dayOfMonthOrdinalParse || locale._ordinalParse\n : locale._dayOfMonthOrdinalParseLenient;\n });\n\n addParseToken(['D', 'DD'], DATE);\n addParseToken('Do', function (input, array) {\n array[DATE] = toInt(input.match(match1to2)[0]);\n });\n\n // MOMENTS\n\n var getSetDayOfMonth = makeGetSet('Date', true);\n\n // FORMATTING\n\n addFormatToken('DDD', ['DDDD', 3], 'DDDo', 'dayOfYear');\n\n // ALIASES\n\n addUnitAlias('dayOfYear', 'DDD');\n\n // PRIORITY\n addUnitPriority('dayOfYear', 4);\n\n // PARSING\n\n addRegexToken('DDD', match1to3);\n addRegexToken('DDDD', match3);\n addParseToken(['DDD', 'DDDD'], function (input, array, config) {\n config._dayOfYear = toInt(input);\n });\n\n // HELPERS\n\n // MOMENTS\n\n function getSetDayOfYear(input) {\n var dayOfYear =\n Math.round(\n (this.clone().startOf('day') - this.clone().startOf('year')) / 864e5\n ) + 1;\n return input == null ? dayOfYear : this.add(input - dayOfYear, 'd');\n }\n\n // FORMATTING\n\n addFormatToken('m', ['mm', 2], 0, 'minute');\n\n // ALIASES\n\n addUnitAlias('minute', 'm');\n\n // PRIORITY\n\n addUnitPriority('minute', 14);\n\n // PARSING\n\n addRegexToken('m', match1to2);\n addRegexToken('mm', match1to2, match2);\n addParseToken(['m', 'mm'], MINUTE);\n\n // MOMENTS\n\n var getSetMinute = makeGetSet('Minutes', false);\n\n // FORMATTING\n\n addFormatToken('s', ['ss', 2], 0, 'second');\n\n // ALIASES\n\n addUnitAlias('second', 's');\n\n // PRIORITY\n\n addUnitPriority('second', 15);\n\n // PARSING\n\n addRegexToken('s', match1to2);\n addRegexToken('ss', match1to2, match2);\n addParseToken(['s', 'ss'], SECOND);\n\n // MOMENTS\n\n var getSetSecond = makeGetSet('Seconds', false);\n\n // FORMATTING\n\n addFormatToken('S', 0, 0, function () {\n return ~~(this.millisecond() / 100);\n });\n\n addFormatToken(0, ['SS', 2], 0, function () {\n return ~~(this.millisecond() / 10);\n });\n\n addFormatToken(0, ['SSS', 3], 0, 'millisecond');\n addFormatToken(0, ['SSSS', 4], 0, function () {\n return this.millisecond() * 10;\n });\n addFormatToken(0, ['SSSSS', 5], 0, function () {\n return this.millisecond() * 100;\n });\n addFormatToken(0, ['SSSSSS', 6], 0, function () {\n return this.millisecond() * 1000;\n });\n addFormatToken(0, ['SSSSSSS', 7], 0, function () {\n return this.millisecond() * 10000;\n });\n addFormatToken(0, ['SSSSSSSS', 8], 0, function () {\n return this.millisecond() * 100000;\n });\n addFormatToken(0, ['SSSSSSSSS', 9], 0, function () {\n return this.millisecond() * 1000000;\n });\n\n // ALIASES\n\n addUnitAlias('millisecond', 'ms');\n\n // PRIORITY\n\n addUnitPriority('millisecond', 16);\n\n // PARSING\n\n addRegexToken('S', match1to3, match1);\n addRegexToken('SS', match1to3, match2);\n addRegexToken('SSS', match1to3, match3);\n\n var token, getSetMillisecond;\n for (token = 'SSSS'; token.length <= 9; token += 'S') {\n addRegexToken(token, matchUnsigned);\n }\n\n function parseMs(input, array) {\n array[MILLISECOND] = toInt(('0.' + input) * 1000);\n }\n\n for (token = 'S'; token.length <= 9; token += 'S') {\n addParseToken(token, parseMs);\n }\n\n getSetMillisecond = makeGetSet('Milliseconds', false);\n\n // FORMATTING\n\n addFormatToken('z', 0, 0, 'zoneAbbr');\n addFormatToken('zz', 0, 0, 'zoneName');\n\n // MOMENTS\n\n function getZoneAbbr() {\n return this._isUTC ? 'UTC' : '';\n }\n\n function getZoneName() {\n return this._isUTC ? 'Coordinated Universal Time' : '';\n }\n\n var proto = Moment.prototype;\n\n proto.add = add;\n proto.calendar = calendar$1;\n proto.clone = clone;\n proto.diff = diff;\n proto.endOf = endOf;\n proto.format = format;\n proto.from = from;\n proto.fromNow = fromNow;\n proto.to = to;\n proto.toNow = toNow;\n proto.get = stringGet;\n proto.invalidAt = invalidAt;\n proto.isAfter = isAfter;\n proto.isBefore = isBefore;\n proto.isBetween = isBetween;\n proto.isSame = isSame;\n proto.isSameOrAfter = isSameOrAfter;\n proto.isSameOrBefore = isSameOrBefore;\n proto.isValid = isValid$2;\n proto.lang = lang;\n proto.locale = locale;\n proto.localeData = localeData;\n proto.max = prototypeMax;\n proto.min = prototypeMin;\n proto.parsingFlags = parsingFlags;\n proto.set = stringSet;\n proto.startOf = startOf;\n proto.subtract = subtract;\n proto.toArray = toArray;\n proto.toObject = toObject;\n proto.toDate = toDate;\n proto.toISOString = toISOString;\n proto.inspect = inspect;\n if (typeof Symbol !== 'undefined' && Symbol.for != null) {\n proto[Symbol.for('nodejs.util.inspect.custom')] = function () {\n return 'Moment<' + this.format() + '>';\n };\n }\n proto.toJSON = toJSON;\n proto.toString = toString;\n proto.unix = unix;\n proto.valueOf = valueOf;\n proto.creationData = creationData;\n proto.eraName = getEraName;\n proto.eraNarrow = getEraNarrow;\n proto.eraAbbr = getEraAbbr;\n proto.eraYear = getEraYear;\n proto.year = getSetYear;\n proto.isLeapYear = getIsLeapYear;\n proto.weekYear = getSetWeekYear;\n proto.isoWeekYear = getSetISOWeekYear;\n proto.quarter = proto.quarters = getSetQuarter;\n proto.month = getSetMonth;\n proto.daysInMonth = getDaysInMonth;\n proto.week = proto.weeks = getSetWeek;\n proto.isoWeek = proto.isoWeeks = getSetISOWeek;\n proto.weeksInYear = getWeeksInYear;\n proto.weeksInWeekYear = getWeeksInWeekYear;\n proto.isoWeeksInYear = getISOWeeksInYear;\n proto.isoWeeksInISOWeekYear = getISOWeeksInISOWeekYear;\n proto.date = getSetDayOfMonth;\n proto.day = proto.days = getSetDayOfWeek;\n proto.weekday = getSetLocaleDayOfWeek;\n proto.isoWeekday = getSetISODayOfWeek;\n proto.dayOfYear = getSetDayOfYear;\n proto.hour = proto.hours = getSetHour;\n proto.minute = proto.minutes = getSetMinute;\n proto.second = proto.seconds = getSetSecond;\n proto.millisecond = proto.milliseconds = getSetMillisecond;\n proto.utcOffset = getSetOffset;\n proto.utc = setOffsetToUTC;\n proto.local = setOffsetToLocal;\n proto.parseZone = setOffsetToParsedOffset;\n proto.hasAlignedHourOffset = hasAlignedHourOffset;\n proto.isDST = isDaylightSavingTime;\n proto.isLocal = isLocal;\n proto.isUtcOffset = isUtcOffset;\n proto.isUtc = isUtc;\n proto.isUTC = isUtc;\n proto.zoneAbbr = getZoneAbbr;\n proto.zoneName = getZoneName;\n proto.dates = deprecate(\n 'dates accessor is deprecated. Use date instead.',\n getSetDayOfMonth\n );\n proto.months = deprecate(\n 'months accessor is deprecated. Use month instead',\n getSetMonth\n );\n proto.years = deprecate(\n 'years accessor is deprecated. Use year instead',\n getSetYear\n );\n proto.zone = deprecate(\n 'moment().zone is deprecated, use moment().utcOffset instead. http://momentjs.com/guides/#/warnings/zone/',\n getSetZone\n );\n proto.isDSTShifted = deprecate(\n 'isDSTShifted is deprecated. See http://momentjs.com/guides/#/warnings/dst-shifted/ for more information',\n isDaylightSavingTimeShifted\n );\n\n function createUnix(input) {\n return createLocal(input * 1000);\n }\n\n function createInZone() {\n return createLocal.apply(null, arguments).parseZone();\n }\n\n function preParsePostFormat(string) {\n return string;\n }\n\n var proto$1 = Locale.prototype;\n\n proto$1.calendar = calendar;\n proto$1.longDateFormat = longDateFormat;\n proto$1.invalidDate = invalidDate;\n proto$1.ordinal = ordinal;\n proto$1.preparse = preParsePostFormat;\n proto$1.postformat = preParsePostFormat;\n proto$1.relativeTime = relativeTime;\n proto$1.pastFuture = pastFuture;\n proto$1.set = set;\n proto$1.eras = localeEras;\n proto$1.erasParse = localeErasParse;\n proto$1.erasConvertYear = localeErasConvertYear;\n proto$1.erasAbbrRegex = erasAbbrRegex;\n proto$1.erasNameRegex = erasNameRegex;\n proto$1.erasNarrowRegex = erasNarrowRegex;\n\n proto$1.months = localeMonths;\n proto$1.monthsShort = localeMonthsShort;\n proto$1.monthsParse = localeMonthsParse;\n proto$1.monthsRegex = monthsRegex;\n proto$1.monthsShortRegex = monthsShortRegex;\n proto$1.week = localeWeek;\n proto$1.firstDayOfYear = localeFirstDayOfYear;\n proto$1.firstDayOfWeek = localeFirstDayOfWeek;\n\n proto$1.weekdays = localeWeekdays;\n proto$1.weekdaysMin = localeWeekdaysMin;\n proto$1.weekdaysShort = localeWeekdaysShort;\n proto$1.weekdaysParse = localeWeekdaysParse;\n\n proto$1.weekdaysRegex = weekdaysRegex;\n proto$1.weekdaysShortRegex = weekdaysShortRegex;\n proto$1.weekdaysMinRegex = weekdaysMinRegex;\n\n proto$1.isPM = localeIsPM;\n proto$1.meridiem = localeMeridiem;\n\n function get$1(format, index, field, setter) {\n var locale = getLocale(),\n utc = createUTC().set(setter, index);\n return locale[field](utc, format);\n }\n\n function listMonthsImpl(format, index, field) {\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n\n if (index != null) {\n return get$1(format, index, field, 'month');\n }\n\n var i,\n out = [];\n for (i = 0; i < 12; i++) {\n out[i] = get$1(format, i, field, 'month');\n }\n return out;\n }\n\n // ()\n // (5)\n // (fmt, 5)\n // (fmt)\n // (true)\n // (true, 5)\n // (true, fmt, 5)\n // (true, fmt)\n function listWeekdaysImpl(localeSorted, format, index, field) {\n if (typeof localeSorted === 'boolean') {\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n } else {\n format = localeSorted;\n index = format;\n localeSorted = false;\n\n if (isNumber(format)) {\n index = format;\n format = undefined;\n }\n\n format = format || '';\n }\n\n var locale = getLocale(),\n shift = localeSorted ? locale._week.dow : 0,\n i,\n out = [];\n\n if (index != null) {\n return get$1(format, (index + shift) % 7, field, 'day');\n }\n\n for (i = 0; i < 7; i++) {\n out[i] = get$1(format, (i + shift) % 7, field, 'day');\n }\n return out;\n }\n\n function listMonths(format, index) {\n return listMonthsImpl(format, index, 'months');\n }\n\n function listMonthsShort(format, index) {\n return listMonthsImpl(format, index, 'monthsShort');\n }\n\n function listWeekdays(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdays');\n }\n\n function listWeekdaysShort(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdaysShort');\n }\n\n function listWeekdaysMin(localeSorted, format, index) {\n return listWeekdaysImpl(localeSorted, format, index, 'weekdaysMin');\n }\n\n getSetGlobalLocale('en', {\n eras: [\n {\n since: '0001-01-01',\n until: +Infinity,\n offset: 1,\n name: 'Anno Domini',\n narrow: 'AD',\n abbr: 'AD',\n },\n {\n since: '0000-12-31',\n until: -Infinity,\n offset: 1,\n name: 'Before Christ',\n narrow: 'BC',\n abbr: 'BC',\n },\n ],\n dayOfMonthOrdinalParse: /\\d{1,2}(th|st|nd|rd)/,\n ordinal: function (number) {\n var b = number % 10,\n output =\n toInt((number % 100) / 10) === 1\n ? 'th'\n : b === 1\n ? 'st'\n : b === 2\n ? 'nd'\n : b === 3\n ? 'rd'\n : 'th';\n return number + output;\n },\n });\n\n // Side effect imports\n\n hooks.lang = deprecate(\n 'moment.lang is deprecated. Use moment.locale instead.',\n getSetGlobalLocale\n );\n hooks.langData = deprecate(\n 'moment.langData is deprecated. Use moment.localeData instead.',\n getLocale\n );\n\n var mathAbs = Math.abs;\n\n function abs() {\n var data = this._data;\n\n this._milliseconds = mathAbs(this._milliseconds);\n this._days = mathAbs(this._days);\n this._months = mathAbs(this._months);\n\n data.milliseconds = mathAbs(data.milliseconds);\n data.seconds = mathAbs(data.seconds);\n data.minutes = mathAbs(data.minutes);\n data.hours = mathAbs(data.hours);\n data.months = mathAbs(data.months);\n data.years = mathAbs(data.years);\n\n return this;\n }\n\n function addSubtract$1(duration, input, value, direction) {\n var other = createDuration(input, value);\n\n duration._milliseconds += direction * other._milliseconds;\n duration._days += direction * other._days;\n duration._months += direction * other._months;\n\n return duration._bubble();\n }\n\n // supports only 2.0-style add(1, 's') or add(duration)\n function add$1(input, value) {\n return addSubtract$1(this, input, value, 1);\n }\n\n // supports only 2.0-style subtract(1, 's') or subtract(duration)\n function subtract$1(input, value) {\n return addSubtract$1(this, input, value, -1);\n }\n\n function absCeil(number) {\n if (number < 0) {\n return Math.floor(number);\n } else {\n return Math.ceil(number);\n }\n }\n\n function bubble() {\n var milliseconds = this._milliseconds,\n days = this._days,\n months = this._months,\n data = this._data,\n seconds,\n minutes,\n hours,\n years,\n monthsFromDays;\n\n // if we have a mix of positive and negative values, bubble down first\n // check: https://github.com/moment/moment/issues/2166\n if (\n !(\n (milliseconds >= 0 && days >= 0 && months >= 0) ||\n (milliseconds <= 0 && days <= 0 && months <= 0)\n )\n ) {\n milliseconds += absCeil(monthsToDays(months) + days) * 864e5;\n days = 0;\n months = 0;\n }\n\n // The following code bubbles up values, see the tests for\n // examples of what that means.\n data.milliseconds = milliseconds % 1000;\n\n seconds = absFloor(milliseconds / 1000);\n data.seconds = seconds % 60;\n\n minutes = absFloor(seconds / 60);\n data.minutes = minutes % 60;\n\n hours = absFloor(minutes / 60);\n data.hours = hours % 24;\n\n days += absFloor(hours / 24);\n\n // convert days to months\n monthsFromDays = absFloor(daysToMonths(days));\n months += monthsFromDays;\n days -= absCeil(monthsToDays(monthsFromDays));\n\n // 12 months -> 1 year\n years = absFloor(months / 12);\n months %= 12;\n\n data.days = days;\n data.months = months;\n data.years = years;\n\n return this;\n }\n\n function daysToMonths(days) {\n // 400 years have 146097 days (taking into account leap year rules)\n // 400 years have 12 months === 4800\n return (days * 4800) / 146097;\n }\n\n function monthsToDays(months) {\n // the reverse of daysToMonths\n return (months * 146097) / 4800;\n }\n\n function as(units) {\n if (!this.isValid()) {\n return NaN;\n }\n var days,\n months,\n milliseconds = this._milliseconds;\n\n units = normalizeUnits(units);\n\n if (units === 'month' || units === 'quarter' || units === 'year') {\n days = this._days + milliseconds / 864e5;\n months = this._months + daysToMonths(days);\n switch (units) {\n case 'month':\n return months;\n case 'quarter':\n return months / 3;\n case 'year':\n return months / 12;\n }\n } else {\n // handle milliseconds separately because of floating point math errors (issue #1867)\n days = this._days + Math.round(monthsToDays(this._months));\n switch (units) {\n case 'week':\n return days / 7 + milliseconds / 6048e5;\n case 'day':\n return days + milliseconds / 864e5;\n case 'hour':\n return days * 24 + milliseconds / 36e5;\n case 'minute':\n return days * 1440 + milliseconds / 6e4;\n case 'second':\n return days * 86400 + milliseconds / 1000;\n // Math.floor prevents floating point math errors here\n case 'millisecond':\n return Math.floor(days * 864e5) + milliseconds;\n default:\n throw new Error('Unknown unit ' + units);\n }\n }\n }\n\n // TODO: Use this.as('ms')?\n function valueOf$1() {\n if (!this.isValid()) {\n return NaN;\n }\n return (\n this._milliseconds +\n this._days * 864e5 +\n (this._months % 12) * 2592e6 +\n toInt(this._months / 12) * 31536e6\n );\n }\n\n function makeAs(alias) {\n return function () {\n return this.as(alias);\n };\n }\n\n var asMilliseconds = makeAs('ms'),\n asSeconds = makeAs('s'),\n asMinutes = makeAs('m'),\n asHours = makeAs('h'),\n asDays = makeAs('d'),\n asWeeks = makeAs('w'),\n asMonths = makeAs('M'),\n asQuarters = makeAs('Q'),\n asYears = makeAs('y');\n\n function clone$1() {\n return createDuration(this);\n }\n\n function get$2(units) {\n units = normalizeUnits(units);\n return this.isValid() ? this[units + 's']() : NaN;\n }\n\n function makeGetter(name) {\n return function () {\n return this.isValid() ? this._data[name] : NaN;\n };\n }\n\n var milliseconds = makeGetter('milliseconds'),\n seconds = makeGetter('seconds'),\n minutes = makeGetter('minutes'),\n hours = makeGetter('hours'),\n days = makeGetter('days'),\n months = makeGetter('months'),\n years = makeGetter('years');\n\n function weeks() {\n return absFloor(this.days() / 7);\n }\n\n var round = Math.round,\n thresholds = {\n ss: 44, // a few seconds to seconds\n s: 45, // seconds to minute\n m: 45, // minutes to hour\n h: 22, // hours to day\n d: 26, // days to month/week\n w: null, // weeks to month\n M: 11, // months to year\n };\n\n // helper function for moment.fn.from, moment.fn.fromNow, and moment.duration.fn.humanize\n function substituteTimeAgo(string, number, withoutSuffix, isFuture, locale) {\n return locale.relativeTime(number || 1, !!withoutSuffix, string, isFuture);\n }\n\n function relativeTime$1(posNegDuration, withoutSuffix, thresholds, locale) {\n var duration = createDuration(posNegDuration).abs(),\n seconds = round(duration.as('s')),\n minutes = round(duration.as('m')),\n hours = round(duration.as('h')),\n days = round(duration.as('d')),\n months = round(duration.as('M')),\n weeks = round(duration.as('w')),\n years = round(duration.as('y')),\n a =\n (seconds <= thresholds.ss && ['s', seconds]) ||\n (seconds < thresholds.s && ['ss', seconds]) ||\n (minutes <= 1 && ['m']) ||\n (minutes < thresholds.m && ['mm', minutes]) ||\n (hours <= 1 && ['h']) ||\n (hours < thresholds.h && ['hh', hours]) ||\n (days <= 1 && ['d']) ||\n (days < thresholds.d && ['dd', days]);\n\n if (thresholds.w != null) {\n a =\n a ||\n (weeks <= 1 && ['w']) ||\n (weeks < thresholds.w && ['ww', weeks]);\n }\n a = a ||\n (months <= 1 && ['M']) ||\n (months < thresholds.M && ['MM', months]) ||\n (years <= 1 && ['y']) || ['yy', years];\n\n a[2] = withoutSuffix;\n a[3] = +posNegDuration > 0;\n a[4] = locale;\n return substituteTimeAgo.apply(null, a);\n }\n\n // This function allows you to set the rounding function for relative time strings\n function getSetRelativeTimeRounding(roundingFunction) {\n if (roundingFunction === undefined) {\n return round;\n }\n if (typeof roundingFunction === 'function') {\n round = roundingFunction;\n return true;\n }\n return false;\n }\n\n // This function allows you to set a threshold for relative time strings\n function getSetRelativeTimeThreshold(threshold, limit) {\n if (thresholds[threshold] === undefined) {\n return false;\n }\n if (limit === undefined) {\n return thresholds[threshold];\n }\n thresholds[threshold] = limit;\n if (threshold === 's') {\n thresholds.ss = limit - 1;\n }\n return true;\n }\n\n function humanize(argWithSuffix, argThresholds) {\n if (!this.isValid()) {\n return this.localeData().invalidDate();\n }\n\n var withSuffix = false,\n th = thresholds,\n locale,\n output;\n\n if (typeof argWithSuffix === 'object') {\n argThresholds = argWithSuffix;\n argWithSuffix = false;\n }\n if (typeof argWithSuffix === 'boolean') {\n withSuffix = argWithSuffix;\n }\n if (typeof argThresholds === 'object') {\n th = Object.assign({}, thresholds, argThresholds);\n if (argThresholds.s != null && argThresholds.ss == null) {\n th.ss = argThresholds.s - 1;\n }\n }\n\n locale = this.localeData();\n output = relativeTime$1(this, !withSuffix, th, locale);\n\n if (withSuffix) {\n output = locale.pastFuture(+this, output);\n }\n\n return locale.postformat(output);\n }\n\n var abs$1 = Math.abs;\n\n function sign(x) {\n return (x > 0) - (x < 0) || +x;\n }\n\n function toISOString$1() {\n // for ISO strings we do not use the normal bubbling rules:\n // * milliseconds bubble up until they become hours\n // * days do not bubble at all\n // * months bubble up until they become years\n // This is because there is no context-free conversion between hours and days\n // (think of clock changes)\n // and also not between days and months (28-31 days per month)\n if (!this.isValid()) {\n return this.localeData().invalidDate();\n }\n\n var seconds = abs$1(this._milliseconds) / 1000,\n days = abs$1(this._days),\n months = abs$1(this._months),\n minutes,\n hours,\n years,\n s,\n total = this.asSeconds(),\n totalSign,\n ymSign,\n daysSign,\n hmsSign;\n\n if (!total) {\n // this is the same as C#'s (Noda) and python (isodate)...\n // but not other JS (goog.date)\n return 'P0D';\n }\n\n // 3600 seconds -> 60 minutes -> 1 hour\n minutes = absFloor(seconds / 60);\n hours = absFloor(minutes / 60);\n seconds %= 60;\n minutes %= 60;\n\n // 12 months -> 1 year\n years = absFloor(months / 12);\n months %= 12;\n\n // inspired by https://github.com/dordille/moment-isoduration/blob/master/moment.isoduration.js\n s = seconds ? seconds.toFixed(3).replace(/\\.?0+$/, '') : '';\n\n totalSign = total < 0 ? '-' : '';\n ymSign = sign(this._months) !== sign(total) ? '-' : '';\n daysSign = sign(this._days) !== sign(total) ? '-' : '';\n hmsSign = sign(this._milliseconds) !== sign(total) ? '-' : '';\n\n return (\n totalSign +\n 'P' +\n (years ? ymSign + years + 'Y' : '') +\n (months ? ymSign + months + 'M' : '') +\n (days ? daysSign + days + 'D' : '') +\n (hours || minutes || seconds ? 'T' : '') +\n (hours ? hmsSign + hours + 'H' : '') +\n (minutes ? hmsSign + minutes + 'M' : '') +\n (seconds ? hmsSign + s + 'S' : '')\n );\n }\n\n var proto$2 = Duration.prototype;\n\n proto$2.isValid = isValid$1;\n proto$2.abs = abs;\n proto$2.add = add$1;\n proto$2.subtract = subtract$1;\n proto$2.as = as;\n proto$2.asMilliseconds = asMilliseconds;\n proto$2.asSeconds = asSeconds;\n proto$2.asMinutes = asMinutes;\n proto$2.asHours = asHours;\n proto$2.asDays = asDays;\n proto$2.asWeeks = asWeeks;\n proto$2.asMonths = asMonths;\n proto$2.asQuarters = asQuarters;\n proto$2.asYears = asYears;\n proto$2.valueOf = valueOf$1;\n proto$2._bubble = bubble;\n proto$2.clone = clone$1;\n proto$2.get = get$2;\n proto$2.milliseconds = milliseconds;\n proto$2.seconds = seconds;\n proto$2.minutes = minutes;\n proto$2.hours = hours;\n proto$2.days = days;\n proto$2.weeks = weeks;\n proto$2.months = months;\n proto$2.years = years;\n proto$2.humanize = humanize;\n proto$2.toISOString = toISOString$1;\n proto$2.toString = toISOString$1;\n proto$2.toJSON = toISOString$1;\n proto$2.locale = locale;\n proto$2.localeData = localeData;\n\n proto$2.toIsoString = deprecate(\n 'toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)',\n toISOString$1\n );\n proto$2.lang = lang;\n\n // FORMATTING\n\n addFormatToken('X', 0, 0, 'unix');\n addFormatToken('x', 0, 0, 'valueOf');\n\n // PARSING\n\n addRegexToken('x', matchSigned);\n addRegexToken('X', matchTimestamp);\n addParseToken('X', function (input, array, config) {\n config._d = new Date(parseFloat(input) * 1000);\n });\n addParseToken('x', function (input, array, config) {\n config._d = new Date(toInt(input));\n });\n\n //! moment.js\n\n hooks.version = '2.29.4';\n\n setHookCallback(createLocal);\n\n hooks.fn = proto;\n hooks.min = min;\n hooks.max = max;\n hooks.now = now;\n hooks.utc = createUTC;\n hooks.unix = createUnix;\n hooks.months = listMonths;\n hooks.isDate = isDate;\n hooks.locale = getSetGlobalLocale;\n hooks.invalid = createInvalid;\n hooks.duration = createDuration;\n hooks.isMoment = isMoment;\n hooks.weekdays = listWeekdays;\n hooks.parseZone = createInZone;\n hooks.localeData = getLocale;\n hooks.isDuration = isDuration;\n hooks.monthsShort = listMonthsShort;\n hooks.weekdaysMin = listWeekdaysMin;\n hooks.defineLocale = defineLocale;\n hooks.updateLocale = updateLocale;\n hooks.locales = listLocales;\n hooks.weekdaysShort = listWeekdaysShort;\n hooks.normalizeUnits = normalizeUnits;\n hooks.relativeTimeRounding = getSetRelativeTimeRounding;\n hooks.relativeTimeThreshold = getSetRelativeTimeThreshold;\n hooks.calendarFormat = getCalendarFormat;\n hooks.prototype = proto;\n\n // currently HTML5 input type only supports 24-hour formats\n hooks.HTML5_FMT = {\n DATETIME_LOCAL: 'YYYY-MM-DDTHH:mm', // \n DATETIME_LOCAL_SECONDS: 'YYYY-MM-DDTHH:mm:ss', // \n DATETIME_LOCAL_MS: 'YYYY-MM-DDTHH:mm:ss.SSS', // \n DATE: 'YYYY-MM-DD', // \n TIME: 'HH:mm', // \n TIME_SECONDS: 'HH:mm:ss', // \n TIME_MS: 'HH:mm:ss.SSS', // \n WEEK: 'GGGG-[W]WW', // \n MONTH: 'YYYY-MM', // \n };\n\n return hooks;\n\n})));\n","//! moment.js locale configuration\n//! locale : French [fr]\n//! author : John Fischer : https://github.com/jfroffice\n\n;(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined'\n && typeof require === 'function' ? factory(require('../moment')) :\n typeof define === 'function' && define.amd ? define(['../moment'], factory) :\n factory(global.moment)\n}(this, (function (moment) { 'use strict';\n\n //! moment.js locale configuration\n\n var monthsStrictRegex =\n /^(janvier|février|mars|avril|mai|juin|juillet|août|septembre|octobre|novembre|décembre)/i,\n monthsShortStrictRegex =\n /(janv\\.?|févr\\.?|mars|avr\\.?|mai|juin|juil\\.?|août|sept\\.?|oct\\.?|nov\\.?|déc\\.?)/i,\n monthsRegex =\n /(janv\\.?|févr\\.?|mars|avr\\.?|mai|juin|juil\\.?|août|sept\\.?|oct\\.?|nov\\.?|déc\\.?|janvier|février|mars|avril|mai|juin|juillet|août|septembre|octobre|novembre|décembre)/i,\n monthsParse = [\n /^janv/i,\n /^févr/i,\n /^mars/i,\n /^avr/i,\n /^mai/i,\n /^juin/i,\n /^juil/i,\n /^août/i,\n /^sept/i,\n /^oct/i,\n /^nov/i,\n /^déc/i,\n ];\n\n var fr = moment.defineLocale('fr', {\n months: 'janvier_février_mars_avril_mai_juin_juillet_août_septembre_octobre_novembre_décembre'.split(\n '_'\n ),\n monthsShort:\n 'janv._févr._mars_avr._mai_juin_juil._août_sept._oct._nov._déc.'.split(\n '_'\n ),\n monthsRegex: monthsRegex,\n monthsShortRegex: monthsRegex,\n monthsStrictRegex: monthsStrictRegex,\n monthsShortStrictRegex: monthsShortStrictRegex,\n monthsParse: monthsParse,\n longMonthsParse: monthsParse,\n shortMonthsParse: monthsParse,\n weekdays: 'dimanche_lundi_mardi_mercredi_jeudi_vendredi_samedi'.split('_'),\n weekdaysShort: 'dim._lun._mar._mer._jeu._ven._sam.'.split('_'),\n weekdaysMin: 'di_lu_ma_me_je_ve_sa'.split('_'),\n weekdaysParseExact: true,\n longDateFormat: {\n LT: 'HH:mm',\n LTS: 'HH:mm:ss',\n L: 'DD/MM/YYYY',\n LL: 'D MMMM YYYY',\n LLL: 'D MMMM YYYY HH:mm',\n LLLL: 'dddd D MMMM YYYY HH:mm',\n },\n calendar: {\n sameDay: '[Aujourd’hui à] LT',\n nextDay: '[Demain à] LT',\n nextWeek: 'dddd [à] LT',\n lastDay: '[Hier à] LT',\n lastWeek: 'dddd [dernier à] LT',\n sameElse: 'L',\n },\n relativeTime: {\n future: 'dans %s',\n past: 'il y a %s',\n s: 'quelques secondes',\n ss: '%d secondes',\n m: 'une minute',\n mm: '%d minutes',\n h: 'une heure',\n hh: '%d heures',\n d: 'un jour',\n dd: '%d jours',\n w: 'une semaine',\n ww: '%d semaines',\n M: 'un mois',\n MM: '%d mois',\n y: 'un an',\n yy: '%d ans',\n },\n dayOfMonthOrdinalParse: /\\d{1,2}(er|)/,\n ordinal: function (number, period) {\n switch (period) {\n // TODO: Return 'e' when day of month > 1. Move this case inside\n // block for masculine words below.\n // See https://github.com/moment/moment/issues/3375\n case 'D':\n return number + (number === 1 ? 'er' : '');\n\n // Words with masculine grammatical gender: mois, trimestre, jour\n default:\n case 'M':\n case 'Q':\n case 'DDD':\n case 'd':\n return number + (number === 1 ? 'er' : 'e');\n\n // Words with feminine grammatical gender: semaine\n case 'w':\n case 'W':\n return number + (number === 1 ? 're' : 'e');\n }\n },\n week: {\n dow: 1, // Monday is the first day of the week.\n doy: 4, // The week that contains Jan 4th is the first week of the year.\n },\n });\n\n return fr;\n\n})));\n","import moment from \"moment\"\n\nexport const activitiesConstants = {\n PAUSE_ACTIVITY: 'PAUSE_ACTIVITY',\n ONGOING_ACTIVITY: 'ONGOING_ACTIVITY',\n SET_CAMERA_STATUS: 'SET_CAMERA_STATUS',\n AUDIO_STATUS: 'AUDIO_STATUS',\n UPDATE_ACTIVITY_CHRONO: 'UPDATE_ACTIVITY_CHRONO',\n}\nexport const RESET_ACTIVITIES_HISTORY = \"RESET_ACTIVITIES_HISTORY\"\nexport const SET_ACTIVITIES_REVIEW_FILTER = \"SET_ACTIVITIES_REVIEW_FILTER\"\nexport const SET_TODO_ACTIVITIES = \"SET_TODO_ACTIVITIES\"\n\nexport const categoryColors = {\n write: 'info',\n speak: 'warning',\n play: 'primary',\n form: 'light'\n}\n\nexport const congratsList = [\n \"Activité terminée !\",\n \"Bien joué !\",\n \"Mission accomplie !\",\n \"Ça, c'est fait !\"\n]\n\nexport const stepFinishedList = [\n \"Bien joué !\",\n \"Formidable !\",\n \"Super !\",\n \"Génial !\",\n \"Bien !\",\n \"Très bien !\",\n \"Fantastique !\",\n \"Yay !\",\n \"Bravo !\",\n \"Splendide !\"\n]\n\nexport const stepErrorList = [\n \"Raté\",\n \"Mauvaise réponse\",\n \"Faux\",\n \"Dommage\",\n]\n\n// export const activityCategories = [\n// 'Savoir',\n// 'Motivation',\n// 'Bien-Être',\n// 'Organisation',\n// 'Evènement'\n// ]\n\nexport const weekDaysObject = {\n Monday: 'Lundi',\n Tuesday: 'Mardi',\n Wednesday: 'Mercredi',\n Thursday: 'Jeudi',\n Friday: 'Vendredi',\n Saturday: 'Samedi',\n Sunday: 'Dimanche'\n}\n\nexport const weekDays = Object.keys(weekDaysObject)\n\nexport const startDates = [\n {value: moment().format(\"YYYY-MM-DD\"), label: `Aujourd'hui, le ${moment().format(\"DD/MM\")}`},\n {value: moment().add(1, 'day').format(\"YYYY-MM-DD\"), label: `Demain, le ${moment().add(1, 'day').format(\"DD/MM\")}`}\n]\n\nexport const activityDurations = [{value: 1, label: \"1 semaine\"}]\n\nexport const weekDaysShort = {\n Monday: 'L',\n Tuesday: 'M',\n Wednesday: 'M',\n Thursday: 'J',\n Friday: 'V',\n Saturday: 'S',\n Sunday: 'D'\n}\n\nexport const weekDayNums = {\n Monday: 0,\n Tuesday: 1,\n Wednesday: 2,\n Thursday: 3,\n Friday: 4,\n Saturday: 5,\n Sunday: 6\n}\n\nexport const activityTypes = {\n card: \"Fiche\",\n written_exercise: \"Exercice écrit\",\n revision: \"Révision\",\n oral_exercise: \"Exercice oral\",\n external_resource: \"Ressource externe\"\n}\n\nexport const activityGoals = {\n external_resource: \"Comprendre\",\n card: \"Apprendre\",\n exercise: \"S'exercer\",\n revision: \"Réviser\",\n}\n\nexport const schoolSubjectCategories = {\n \"scientific\": \"Scientifiques\",\n \"litterary/economic\": \"Littéraires / éco\",\n \"language\": \"Langues\",\n}\n\nexport const activityAssessmentResponses = [\n \"Insatisfaisant\",\n \"Moyen\",\n \"Satisfaisant\"\n]\n","export const authConstants = {\n\n LOGOUT_401: 'LOGOUT_401',\n NOT_LOGGED_IN_REDIRECT: 'NOT_LOGGED_IN_REDIRECT',\n NOT_LOGGED_IN_REDIRECT_REMOVE: 'NOT_LOGGED_IN_REDIRECT_REMOVE',\n}\n\n","import axios from \"axios\"\n\n\nfunction postChallengeAsStudent(routeParams, formData) {\n return axios.post(`api/challenges`, formData)\n}\n\nfunction abandonChallenge({id}) {\n return axios.post(`/api/challenges/${id}/abandon`)\n}\n\nfunction getChallengeHistory({}, {}, {page}) {\n return axios.get(`api/challenge-history`, {\n params: {\n page\n }\n })\n}\nfunction postChallengeAsTutor({studentId}, formData) {\n return axios.post(`api/students/${studentId}/challenges`, formData)\n}\n\nfunction getStudentChallengeHistory({id}, {}, {page}) {\n return axios.get(`api/students/${id}/challenge-history`, {\n params: {\n page\n }\n })\n}\n\nfunction abandonChallengeAsTutor({studentId, challengeId}, data) {\n return axios.post(`/api/students/${studentId}/challenges/${challengeId}/abandon`, data)\n}\n\nexport const challengesService = {\n postChallengeAsStudent,\n abandonChallenge,\n getChallengeHistory,\n getStudentChallengeHistory,\n postChallengeAsTutor,\n abandonChallengeAsTutor\n}\n\n","import axios from \"axios\"\n\n\nfunction markAsRead({id}) {\n return axios.post(`/api/achievements/${id}/read`)\n}\n\n\nexport const achievementsService = {\n markAsRead\n}\n\n","import axios from \"axios\"\n\nfunction getSchoolSubjects() {\n return axios.get(`/api/school-subjects`)\n}\n\nfunction chooseSchoolSubject({id}, data) {\n return axios.post(`/api/school-subjects/${id}/prioritize`, data)\n}\n\nfunction removeSchoolSubject({id}) {\n return axios.post(`/api/school-subjects/${id}/remove`)\n}\n\nfunction getSchoolSubjectHistory({}, {}, {page}) {\n return axios.get(`api/school-subject-history`, {\n params: {\n page\n }\n })\n}\n\nfunction getStudentSchoolSubjectHistory({id}, {}, {page}) {\n return axios.get(`api/students/${id}/school-subject-history`, {\n params: {\n page\n }\n })\n}\n\n\nexport const schoolSubjectsService = {\n getSchoolSubjects,\n chooseSchoolSubject,\n removeSchoolSubject,\n getSchoolSubjectHistory,\n getStudentSchoolSubjectHistory\n}\n\n","import axios from \"axios\"\n\nfunction purchase({id}) {\n return axios.post(`api/shop-products/${id}/purchase`)\n}\n\n\n\nexport const shopService = {\n purchase,\n}\n\n","import axios from \"axios\"\n\nfunction subscribeToTrial({}, data) {\n return axios.post(`/api/v1/user/subscribe-trial`, data)\n}\n\nfunction getLiveRoomsAvailableForTrial({}, {}, params) {\n return axios.get(`/api/v2/live-rooms/available-for-trial`, {params})\n}\n\nfunction subscribeToTrialV2({}, data) {\n return axios.post(`/api/v2/user/subscribe-trial`, data)\n}\n\nfunction subscribeToSpecialV2({}, data) {\n return axios.post(`/api/v2/user/subscribe-special`, data)\n}\n\nfunction getSubscribePricing({}, {}, params) {\n return axios.get(`/api/v2/subscribe/pricing`, {params})\n}\n\nfunction getSubscribeRedirectUrl({}, {}, params) {\n return axios.get(`/api/v2/subscribe/redirect`, {params})\n}\n\nfunction submitTrialSlots({}, data) {\n return axios.post(`/api/v1/user/submit-trial-slots`, data)\n}\n\nfunction updatePrioritizedSchoolSubjects({}, data) {\n return axios.put(`/api/v2/subscribe/prioritized-school-subjects`, data)\n}\n\nfunction updateAvailabilitySlots({}, data) {\n return axios.put(`/api/v2/subscribe/availability-slots`, data)\n}\n\nfunction checkPromoCode({}, data) {\n return axios.post(`/api/user/check-promo-code`, data)\n}\n\nfunction suspendSubscription({}, data) {\n return axios.post(`/api/v1/subscription/pause-resume-choice`, data)\n}\n\nfunction getPauseResumeChoice({}, {}, params) {\n return axios.get(`/api/v1/subscription/pause-resume-choice`, {params})\n}\n\nfunction callMeBack({}, data) {\n return axios.post(`/api/v2/trial-call-me-back`, data)\n}\n\nexport const subscriptionService = {\n subscribeToTrial,\n subscribeToTrialV2,\n subscribeToSpecialV2,\n submitTrialSlots,\n checkPromoCode,\n suspendSubscription,\n getPauseResumeChoice,\n getLiveRoomsAvailableForTrial,\n getSubscribeRedirectUrl,\n getSubscribePricing,\n callMeBack,\n updatePrioritizedSchoolSubjects,\n updateAvailabilitySlots\n}\n\n","export const messengerConstants = {\n\n NEW_MESSAGE: 'NEW_MESSAGE',\n RESET_LIVE_MESSAGES_COUNT: 'RESET_LIVE_MESSAGES_COUNT',\n INCREMENT_TUTOR_MESSENGER_NOT_READ_COUNT: 'INCREMENT_TUTOR_MESSENGER_NOT_READ_COUNT',\n INCREMENT_STUDENT_MESSENGER_NOT_READ_COUNT: 'INCREMENT_STUDENT_MESSENGER_NOT_READ_COUNT',\n IN_CHAT_MESSENGER_NOT_READ_COUNT: \"IN_CHAT_MESSENGER_NOT_READ_COUNT\",\n IN_LIVE_MESSENGER_NOT_READ_COUNT: \"IN_LIVE_MESSENGER_NOT_READ_COUNT\",\n}","import axios from \"axios\";\n\nfunction getMessages({ threadId }) {\n //console.log(`api/messenger/threads/${threadId}/messages`);\n return axios.get(`api/messenger/threads/${threadId}/messages`);\n}\n\nfunction postMessages({ threadId }, value) {\n return axios.post(`api/messenger/threads/${threadId}/messages`, value);\n}\n\nfunction postImage({ threadId }, image) {\n return axios.post(`api/messenger/threads/${threadId}/images`, image);\n}\n\nfunction postAudio({ threadId }, audio) {\n return axios.post(`api/messenger/threads/${threadId}/audio`, audio);\n}\n\nfunction getPageMessages({ threadId, pageId }) {\n return axios.get(`api/messenger/threads/${threadId}/messages/page/${pageId}`);\n}\n\nfunction getMarkRead({ threadId }) {\n return axios.get(`api/messenger/threads/${threadId}/mark-read`);\n}\n\nfunction getMessengerThread({ userId }) {\n return axios.get(`api/v2/users/${userId}/messenger-thread`);\n}\n\nfunction postActivity({}, data) {\n return axios.post(`api/messages/activity`, data);\n}\n\nfunction postActivityStudent({ id }, data) {\n return axios.post(`api/messages/${id}/activity`, data);\n}\n\nfunction getActivityFromChat({ id }) {\n return axios.get(`api/messages/${id}/activity`);\n}\n\nexport const messengerService = {\n getMessages,\n postMessages,\n getPageMessages,\n getMarkRead,\n postImage,\n postAudio,\n getMessengerThread,\n postActivity,\n getActivityFromChat,\n postActivityStudent,\n};\n","import axios from \"axios\"\n\n\nfunction getSkillSets() {\n return axios.get(`/api/v1/user/skill-sets`)\n}\n\nfunction markSkillSetEvolutionAsRead({}, values) {\n return axios.post(`/api/v1/user/skill-sets/read`, values)\n}\n\nfunction getStripeFormUrl({}, {}, params) {\n return axios.get(`/api/v1/user/stripe-form-url`, {params})\n}\n\nfunction getDashboardExpressUrl({}, {}, params) {\n return axios.get(`/api/v1/user/dashboard-express-url`, {params})\n}\n\n\nexport const skillSetsService = {\n getSkillSets,\n markSkillSetEvolutionAsRead,\n getStripeFormUrl,\n getDashboardExpressUrl\n}\n\n","export const liveModeConstants = {\n RESET_LIVE_MODE: 'RESET_LIVE_MODE',\n IS_LIVE_MODE_CHANGE: 'IS_LIVE_MODE_CHANGE',\n IS_TYPING: 'IS_TYPING',\n TYPING_USER: 'TYPING_USER',\n LIVE_PARTICIPANTS: 'LIVE_PARTICIPANTS',\n LIVE_TUTORS: 'LIVE_TUTORS',\n ADD_PARTICIPANT: 'ADD_PARTICIPANT',\n REMOVE_PARTICIPANT: 'REMOVE_PARTICIPANT',\n REMOVE_TUTOR: 'REMOVE_TUTOR',\n CLEAR_MEMBERS: 'CLEAR_MEMBERS',\n IN_CALL_USERS: 'IN_CALL_USERS',\n ADD_IN_CALL_USER: 'ADD_IN_CALL_USER',\n REMOVE_IN_CALL_USERS: 'REMOVE_IN_CALL_USERS',\n PHONE_RINGING: 'PHONE_RINGING',\n RESET_PHONE_RINGING: 'RESET_PHONE_RINGING',\n ADD_PHONE_RINGING: 'ADD_PHONE_RINGING',\n REMOVE_PHONE_RINGING: 'REMOVE_PHONE_RINGING',\n RAISED_HANDS: 'RAISED_HANDS',\n ADD_RAISED_HAND: 'ADD_RAISED_HAND',\n REMOVE_RAISED_HAND: 'REMOVE_RAISED_HAND',\n SET_CALL_PORTAL: \"SET_CALL_PORTAL\",\n SHOW_INCOMING_CALL: \"SHOW_INCOMING_CALL\",\n HIDE_INCOMING_CALL: \"HIDE_INCOMING_CALL\",\n SET_MESSAGES: \"SET_MESSAGES\",\n NEW_LIVE_SESSION_LOG: \"NEW_LIVE_SESSION_LOG\",\n SET_TIMES_SINCE_LAST_CALL: \"SET_TIMES_SINCE_LAST_CALL\",\n PLAY_SOUND: \"PLAY_SOUND\",\n ACTIVITY_FINALIZED: \"ACTIVITY_FINALIZED\",\n SOUND_MODE: 'SOUND_MODE',\n OUT_OF_APP: 'OUT_OF_APP',\n ACTIVITY_CAMERA_ON: 'ACTIVITY_CAMERA_ON',\n VOICE_RECORDING_ACTIVITY: 'VOICE_RECORDING_ACTIVITY',\n SET_ACTIVE_TIME: 'SET_ACTIVE_TIME',\n SET_CALL_KEEP_UUID: 'SET_CALL_KEEP_UUID',\n SET_CALLKEEP_ON: 'SET_CALLKEEP_ON',\n SET_HAS_PHONE_PERMISSION: 'SET_HAS_PHONE_PERMISSION',\n TRIGGER_LK_EVENT: 'TRIGGER_LK_EVENT',\n}\n\nexport const liveKitRoomConstants = {\n SET_LIVEKIT_TOKEN: 'SET_LIVEKIT_TOKEN',\n}","import axios from \"axios\";\n\nfunction updateStatus({id}, data) {\n return axios.post(`api/v1/substitution-proposals/${id}/update-status`, data);\n}\n\nfunction cancelSubstitution({id}) {\n return axios.delete(`api/v1/substitutions/${id}`);\n}\n\nfunction cancelTutorDelay({id}, data) {\n return axios.post(`api/v1/live-sessions/${id}/cancel-tutor-delay`, data);\n}\n\nexport const substitutionProposalsService = {updateStatus, cancelSubstitution, cancelTutorDelay};\n","import axios from \"axios\";\n\nfunction getLiveSessionV2({id}) {\n return axios.get(`api/v2/live-sessions/${id}`);\n}\n\nfunction getCallV2({id}) {\n return axios.get(`api/v2/live-sessions/${id}/call`);\n}\n\nfunction setSoundModeV2({id}, data) {\n return axios.post(`api/v2/live-sessions/${id}/sound-mode`, data);\n}\n\nfunction makeCallV2({id}, value) {\n return axios.post(`api/v2/live-sessions/${id}/call`, value);\n}\n\nfunction joinCallV2({id}) {\n return axios.post(`api/v2/live-sessions/${id}/call/join`);\n}\n\nfunction leaveCallV2({id}) {\n return axios.post(`api/v2/live-sessions/${id}/call/leave`);\n}\n\nfunction setVoiceRecordingActivityV2({id}, data) {\n return axios.post(\n `api/v2/live-sessions/${id}/voice-recording-activity`,\n data\n );\n}\n\nfunction lowerHandsV2({ id }, data) {\n return axios.post(`api/v2/live-sessions/${id}/lower-hands`, data);\n}\n\nfunction raiseHandV2({ id }, data) {\n return axios.post(`api/v2/live-sessions/${id}/raise-hand`, data);\n}\n\nexport const liveServiceV2 = {\n getLiveSessionV2,\n getCallV2,\n setSoundModeV2,\n makeCallV2,\n joinCallV2,\n leaveCallV2,\n setVoiceRecordingActivityV2,\n lowerHandsV2,\n raiseHandV2\n};\n","import { apiConstants } from \"@data/constants/apiConstants\"\nimport { authConstants } from \"@data/constants/authConstants\"\nimport { formDataConstants } from \"@data/constants/formDataConstants\"\nimport { attendanceFlagsService } from \"@data/services/attendanceFlagsService\"\nimport { authService } from \"@data/services/authService\"\nimport { liveService } from \"@data/services/liveService\"\nimport { subscriptionService } from \"@data/services/subscriptionService\"\n\nconst initialState = {\n activity: null,\n answerInput: null,\n holidayOptions: [],\n trialOptions: [],\n diagnostics: [],\n reportFile: null,\n}\n\nexport default function formData(state = initialState, action) {\n switch (action.type) {\n case liveService.getAllMyNextLiveSessionsAsParent.name +\n apiConstants._SUCCESS:\n return {\n ...state,\n user: {\n ...state.user,\n live_sessions: state.user?.live_sessions?.map((session) => {\n const newSession = action.data?.live_sessions?.find(\n (newSession) => newSession.id === session.id\n )\n return newSession ? newSession : session\n }),\n },\n }\n case liveService.reportAbsenceAsParent.name + apiConstants._SUCCESS:\n return {\n ...state,\n user: {\n ...state.user,\n live_sessions: state.user.live_sessions.map((session) => ({\n ...session,\n attendance_flags:\n action.data?.id === session?.id\n ? action.data?.attendance_flags\n : session?.attendance_flags,\n })),\n },\n }\n case attendanceFlagsService.cancelAbsenceAsParent.name +\n apiConstants._SUCCESS:\n return {\n ...state,\n user: {\n ...state.user,\n live_sessions: state.user.live_sessions.map((session) => ({\n ...session,\n attendance_flags: session.attendance_flags.filter(\n (flag) => flag.id !== action?.routeParams?.id\n ),\n })),\n },\n }\n case formDataConstants.SET_ANSWER_INPUT:\n return {\n ...state,\n answerInput: action.data,\n }\n case formDataConstants.SAVE_ACTIVITY:\n return {\n ...state,\n activity: action.data,\n }\n case formDataConstants.SAVE_DIAGNOSTIC:\n const diagnostics = state.diagnostics || []\n\n const diagnosticData = diagnostics?.find(\n (d) => d.live_report_id === action.data.live_report_id\n )\n\n if (!diagnosticData) {\n return {\n ...state,\n diagnostics: [...diagnostics, action.data],\n }\n } else {\n const updatedDiagnostics = diagnostics.map((d) =>\n d.live_report_id === action.data.live_report_id\n ? { ...d, ...action.data }\n : d\n )\n return {\n ...state,\n diagnostics: updatedDiagnostics,\n }\n }\n\n case formDataConstants.CLEAR_DIAGNOSTIC:\n return {\n ...state,\n [action.formId]: remainingEntries,\n }\n case formDataConstants.SAVE_REPORT_FILE:\n return {\n ...state,\n reportFile: action.data,\n }\n\n case formDataConstants.CLEAR_REPORT_FILE:\n return {\n ...state,\n reportFile: null,\n }\n case authConstants.LOGOUT_401:\n case authService.logout.name + apiConstants._SUCCESS:\n case authService.revokeSanctumToken.name + apiConstants._SUCCESS:\n case authService.deleteAccount.name + apiConstants._SUCCESS:\n case formDataConstants.CLEAR_ACTIVITY:\n return {\n ...state,\n activity: null,\n }\n case subscriptionService.getPauseResumeChoice.name +\n apiConstants._SUCCESS:\n return {\n ...state,\n schoolSubjects: action.all_data?.school_subjects,\n nextPaymentDate: action.all_data?.next_payment_date,\n displayName: action.all_data?.display_name,\n remainingDiscounts: action.all_data?.remaining_discounts,\n user: action.all_data?.user, // id, roles, subscription_state, trial_ends_at\n }\n case subscriptionService.updatePrioritizedSchoolSubjects.name +\n apiConstants._SUCCESS:\n case subscriptionService.updateAvailabilitySlots.name +\n apiConstants._SUCCESS:\n return {\n ...state,\n user: action.data,\n }\n case subscriptionService.getSubscribePricing.name +\n apiConstants._SUCCESS:\n return {\n ...state,\n user: action.data?.user,\n pricingTableData: action.data?.pricing_table,\n pricingTableIndividualData:\n action.data?.pricing_table_individual,\n pricingTableV2: action.data?.pricing_table_v2,\n sessionsPerWeek: action.data?.sessions_per_week,\n schoolSubjects: action.data?.school_subjects,\n pricingTableDataNextMode: action.data?.pricing_table_next_mode,\n commitmentEndDate: action.data?.commitment_end_date,\n billingPortalUrl: action.data?.billing_portal_url,\n faq: action.data?.faq,\n subscribedProductPriceId:\n action.data?.subscribed_product_price_id,\n subscribedProductWithNoCommitment:\n action.data?.subscribed_product_with_no_commitment,\n }\n case authService.getAvailableTrialLiveSessions.name +\n apiConstants._SUCCESS:\n return {\n ...state,\n trialOptions: action.data?.options,\n }\n default:\n return state\n }\n}\n","export const formDataConstants = {\n SAVE_ACTIVITY: 'SAVE_ACTIVITY',\n CLEAR_ACTIVITY: 'CLEAR_ACTIVITY',\n SET_ANSWER_INPUT: 'SET_ANSWER_INPUT',\n SAVE_DIAGNOSTIC: 'SAVE_DIAGNOSTIC',\n CLEAR_DIAGNOSTIC: 'CLEAR_DIAGNOSTIC',\n SAVE_REPORT_FILE: 'SAVE_REPORT_FILE',\n CLEAR_REPORT_FILE: 'CLEAR_REPORT_FILE',\n SAVE_FORM_DATA: 'SAVE_FORM_DATA',\n RESET_FORM_DATA: 'RESET_FORM_DATA',\n\n}\n","import {activitiesService} from \"@data/services/activitiesService\"\nimport {apiConstants} from \"@data/constants/apiConstants\"\nimport {authService} from \"@data/services/authService\";\nimport {authConstants} from \"@data/constants/authConstants\";\nimport {SET_ACTIVITIES_REVIEW_FILTER} from \"@data/constants/activitiesConstants\";\nimport {scoringService} from \"@data/services/scoringService\";\n\n// ** Initial State\nconst initialState = {\n object: []\n}\n\nexport function reviewer(state = initialState, action) {\n switch (action.type) {\n\n case authConstants.LOGOUT_401:\n case authService.logout.name + apiConstants._SUCCESS:\n case authService.revokeSanctumToken.name + apiConstants._SUCCESS:\n case authService.deleteAccount.name + apiConstants._SUCCESS:\n return initialState\n\n case activitiesService.getActivities.name + apiConstants._SUCCESS:\n\n // console.log(action?.data)\n\n const updateActivities = () => {\n\n let notFoundActivities = [...action.data]\n\n const result = state.object?.activities?.map(a => {\n const activityFound = action.data?.find(x => x?.id === a?.id)\n if (!!activityFound) {\n notFoundActivities = notFoundActivities?.filter(a => a?.id !== activityFound?.id)\n return activityFound\n } else\n return a\n }) ?? []\n\n return result?.concat(notFoundActivities)\n }\n\n return {\n ...state,\n object: {\n ...state.object,\n activities: updateActivities()\n }\n }\n\n case activitiesService.reviewActivity.name + apiConstants._SUCCESS:\n case activitiesService.reviewLock.name + apiConstants._SUCCESS:\n\n // console.log(action?.data)\n const updateActivityIfFoundInStore = a => {\n return action.data?.id === a?.id ? action.data : a\n }\n\n return {\n ...state,\n object: {\n ...state.object,\n activities: state.object?.activities?.map(updateActivityIfFoundInStore)\n }\n }\n\n case activitiesService.getActivitiesForReview.name + apiConstants._SUCCESS:\n\n let finishedActivities = []\n let challenges = []\n\n // console.log(action.data?.meta?.current_page)\n\n if (action.data?.meta?.current_page === 1) { // refresh\n finishedActivities = action.data?.activities\n challenges = action.data?.challenges\n\n // console.log(\"page 1 reducer\", action.data?.meta)\n } else { // concat\n finishedActivities = state.object?.activities.concat(action.data?.activities)\n challenges = state.object?.challenges.concat(action.data?.challenges)\n\n // console.log(\"page + reducer\", action.data?.meta)\n }\n\n return {\n ...state,\n object: {\n ...state.object,\n activities: finishedActivities,\n challenges: challenges\n }\n }\n\n case SET_ACTIVITIES_REVIEW_FILTER:\n\n return {\n ...state,\n object: {\n ...state.object,\n activitiesFilter: action.filter\n }\n }\n\n\n case scoringService.getStaticScoringData.name + apiConstants._SUCCESS:\n\n return {\n ...state,\n object: {\n ...state.object,\n scoringRules: action.data?.scoring_rules,\n scoringComments: action.data?.scoring_comments,\n }\n }\n\n case scoringService.postScoringComment.name + apiConstants._SUCCESS:\n\n return {\n ...state,\n object: {\n ...state.object,\n scoringComments: [...state.object?.scoringComments, action.data],\n }\n }\n\n case scoringService.postScoringRule.name + apiConstants._SUCCESS:\n\n return {\n ...state,\n object: {\n ...state.object,\n scoringRules: [...state.object?.scoringRules, action.data?.scoring_rule],\n scoringComments: [...state.object?.scoringComments, action.data?.scoring_comment],\n }\n }\n\n default:\n return state\n }\n}\n\nexport default reviewer\n","import axios from \"axios\"\n\nfunction getStaticScoringData() {\n return axios.get(`api/v1/static-data/scoring`)\n}\n\nfunction postScoringRule({}, formData) {\n return axios.post(`api/v1/scoring-rules`, formData)\n}\n\nfunction postScoringComment({}, formData) {\n return axios.post(`api/v1/scoring-comments`, formData)\n}\n\nfunction generateSamAppreciation({}, formData) {\n return axios.post(`api/v1/generate-sam-appreciation`, formData)\n}\n\n\nexport const scoringService = {\n getStaticScoringData,\n postScoringRule,\n postScoringComment,\n generateSamAppreciation\n}\n\n","import { apiConstants } from \"@data/constants/apiConstants\"\nimport { schoolCardReportService } from \"../../../services/schoolCardReportService\"\n\nconst initialState = {\n hash: \"\",\n analysisData: {},\n file: null,\n}\n\nexport default function schoolCardReport(state = initialState, action) {\n switch (action.type) {\n case schoolCardReportService.processFile.name + apiConstants._SUCCESS:\n\n return {\n ...state,\n hash: action.data.hash,\n }\n\n case schoolCardReportService.getAnalysisDataByHash.name +\n apiConstants._SUCCESS:\n return {\n ...state,\n analysisData: action.data,\n }\n default:\n return state\n }\n}\n","import axios from \"axios\"\n\nfunction processFile({}, values) {\n return axios.post(`/api/v1/school-card-report`, values)\n}\n\nfunction getAnalysisDataByHash({ hash }) {\n return axios.get(`/api/v1/school-card-report/analysis/${hash}`)\n}\n\nfunction updateReportEmailByHash({}, { email, hash }) {\n return axios.patch(`/api/v1/school-card-report/email`, { email, hash })\n}\n\nexport const schoolCardReportService = {\n processFile,\n getAnalysisDataByHash,\n updateReportEmailByHash,\n}\n","import {authService} from \"@data/services/authService\"\nimport {apiConstants} from \"@data/constants/apiConstants\"\nimport {authConstants} from \"@data/constants/authConstants\";\n\nconst initialState = {}\n\nexport function session(state = initialState, action) {\n switch (action.type) {\n\n case authConstants.LOGOUT_401:\n case authService.logout.name + apiConstants._SUCCESS:\n case authService.revokeSanctumToken.name + apiConstants._SUCCESS:\n case authService.deleteAccount.name + apiConstants._SUCCESS:\n return {}\n\n case authService.registerV2.name + apiConstants._SUCCESS:\n case authService.registerTrialV2.name + apiConstants._SUCCESS:\n case authService.registerSpecialV2.name + apiConstants._SUCCESS:\n case authService.registerWorkshopV2.name + apiConstants._SUCCESS:\n case authService.registerAndGetSanctumToken.name + apiConstants._SUCCESS:\n case authService.getSanctumToken.name + apiConstants._SUCCESS:\n\n // console.log(action)\n\n return {\n // object: user\n object: {\n token: action.data.token\n }\n }\n\n case authService.login.name + apiConstants._SUCCESS:\n\n // console.log(action)\n\n return {\n // object: user\n object: {\n token: true\n }\n }\n\n case authService.subscribeToNotifications.name + apiConstants._SUCCESS:\n\n // console.log(action)\n\n return {\n object: {\n ...state.object,\n expo_token: action.all_data.expo_token\n }\n }\n\n case authService.unsubscribeFromNotifications.name + apiConstants._SUCCESS:\n\n return {\n object: {\n ...state.object,\n expo_token: null\n }\n }\n\n default:\n return state\n }\n}\n","import {apiConstants} from \"../../../constants/apiConstants\"\nimport {staticDataService} from \"../../../services/staticDataService\";\nimport {schoolSubjectsService} from \"../../../services/schoolSubjectsService\";\n\n// ** Initial State\nconst initialState = {\n challenge_templates: [],\n activity_templates: [],\n school_subjects: [],\n challenge_intensity_levels: [],\n trial_static_data: {},\n}\n\nexport function staticData(state = initialState, action) {\n switch (action.type) {\n\n case staticDataService.getStaticDataTrial.name + apiConstants._SUCCESS:\n return {\n ...state,\n trial_static_data: action.data\n }\n\n case staticDataService.getStaticData.name + apiConstants._SUCCESS:\n return {\n ...state,\n ...action.data\n }\n\n case schoolSubjectsService.getSchoolSubjects.name + apiConstants._SUCCESS:\n return {\n ...state,\n school_subjects: action.data\n }\n\n default:\n return state\n }\n}\n\nexport default staticData\n","import axios from \"axios\"\n\n\nfunction getStaticData() {\n return axios.get(`/api/v1/static-data`)\n\n}\n\nfunction getStaticDataTrial() {\n return axios.get(`/api/v1/static-data/register`)\n\n}\n\n\nexport const staticDataService = {\n\n getStaticData,\n getStaticDataTrial\n}","import {suggestionsConstants} from \"../../../constants/suggestionsConstants\";\nimport moment from \"moment\";\nimport {authConstants} from \"../../../constants/authConstants\";\nimport {authService} from \"../../../services/authService\";\nimport {apiConstants} from \"../../../constants/apiConstants\";\n\nconst initialState = {}\n\nexport default function suggestions(state = initialState, action) {\n switch (action.type) {\n\n case authConstants.LOGOUT_401:\n case authService.logout.name + apiConstants._SUCCESS:\n case authService.revokeSanctumToken.name + apiConstants._SUCCESS:\n case authService.deleteAccount.name + apiConstants._SUCCESS:\n case suggestionsConstants.RESET_SUGGESTIONS:\n return initialState\n\n case suggestionsConstants.HOMEWORK_SUGGESTION:\n return {\n ...state,\n last_homework_suggestion: moment().format(\"YYYY-MM-DD HH:mm:ss\")\n }\n\n case suggestionsConstants.ADDITIONAL_SUGGESTION:\n return {\n ...state,\n last_additional_suggestion: moment().format(\"YYYY-MM-DD HH:mm:ss\")\n }\n\n\n\n default:\n return state\n }\n}\n","export const suggestionsConstants = {\n HOMEWORK_SUGGESTION: 'HOMEWORK_SUGGESTION',\n ADDITIONAL_SUGGESTION: 'ADDITIONAL_SUGGESTION',\n RESET_SUGGESTIONS: 'RESET_SUGGESTIONS',\n}\n","import {apiConstants} from \"@data/constants/apiConstants\"\nimport {tutorsService} from \"@data/services/tutorsService\"\n\n// ** Initial State\nconst initialState = {\n list: [],\n notes: [],\n tutorApplication: [],\n testQuestions: [],\n testAnswers: [],\n tutoringInvoices: [],\n liveOccurrences: []\n}\n\nexport function tutors(state = initialState, action) {\n switch (action.type) {\n\n case tutorsService.submitTestAnswer.name + apiConstants._SUCCESS:\n return {\n ...state,\n testAnswers: state.testAnswers?.map(ta => ta?.id)?.includes(action.data?.id)\n ? state.testAnswers.map(x => x.id === action.data?.id ? action.data : x)\n : state.testAnswers.concat(action.data)\n }\n\n\n case tutorsService.getTestQuestions.name + apiConstants._SUCCESS:\n return {\n ...state,\n testQuestions: action.data?.application_questions,\n testAnswers: action.data?.application_answers\n }\n\n\n case tutorsService.getTestAnswers.name + apiConstants._SUCCESS:\n return {\n ...state,\n tutorApplication: action.data\n }\n case tutorsService.getTutors.name + apiConstants._SUCCESS:\n return {\n ...state,\n list: action.data\n }\n\n case tutorsService.updateNote.name + apiConstants._SUCCESS:\n return {\n ...state,\n notes: state.notes.map(n => n.id === action.data?.id ? action.data : n)\n }\n\n case tutorsService.postNote.name + apiConstants._SUCCESS:\n return {\n ...state,\n notes: [action.data].concat(state.notes),\n }\n case tutorsService.deleteNote.name + apiConstants._SUCCESS:\n return {\n ...state,\n notes: state.notes.filter(n => n?.id !== action.routeParams?.id)\n }\n case tutorsService.getNotes.name + apiConstants._SUCCESS:\n\n let newNotes = []\n\n if (action.data?.meta?.current_page === 1) { // refresh\n newNotes = action.data?.tutor_notes\n\n // console.log(\"page 1 reducer\", action.data?.meta)\n } else { // concat\n newNotes = state?.notes.concat(action.data?.tutor_notes)\n // console.log(\"page + reducer\", action.data?.meta)\n }\n\n return {\n ...state,\n notes: newNotes,\n }\n\n case tutorsService.getTutoringInvoices.name + apiConstants._SUCCESS:\n\n let tutoringInvoices = []\n\n if (action.data?.meta?.current_page === 1) { // refresh\n tutoringInvoices = action.data?.tutoring_invoices\n\n // console.log(\"page 1 reducer\", action.data?.meta)\n } else { // concat\n tutoringInvoices = state?.tutoringInvoices.concat(action.data?.tutoring_invoices)\n // console.log(\"page + reducer\", action.data?.meta)\n }\n\n return {\n ...state,\n tutoringInvoices: tutoringInvoices,\n }\n\n \n // case tutorsService.deleteOccurrence.name + apiConstants._SUCCESS:\n // return {\n // ...state,\n // liveOccurrences: state?.liveOccurrences?.filter(\n // (occurrence) => occurrence?.id !== action?.routeParams?.id\n // ),\n // };\n // case tutorsService.editBilling.name + apiConstants._SUCCESS:\n // return {\n // ...state,\n // liveOccurrences: state.liveOccurrences.map((occurrence) => {\n // if (occurrence?.id === action?.data?.id) {\n // return action?.data;\n // }\n // return occurrence;\n // }),\n // };\n case tutorsService.getTutorLiveOccurrences.name + apiConstants._SUCCESS:\n let liveOccurrences = [];\n if (action.data?.meta?.current_page === 1) {\n liveOccurrences = action.data?.live_occurrences;\n } else {\n liveOccurrences = state.liveOccurrences?.concat(\n action.data?.live_occurrences\n );\n }\n return {\n ...state,\n liveOccurrences,\n };\n\n default:\n return state\n }\n}\n\nexport default tutors\n","import {apiConstants} from \"@data/constants/apiConstants\"\nimport {backOfficeService} from \"@data/services/backOfficeService\"\nimport {authService} from \"@data/services/authService\"\nimport {authConstants} from \"@data/constants/authConstants\";\nimport {tutorsService} from \"@data/services/tutorsService\";\n\n// ** Initial State\nconst initialState = {\n list: [],\n usersList: [],\n usersListFormStep: [],\n}\n\nexport function tutors(state = initialState, action) {\n switch (action.type) {\n\n case authConstants.LOGOUT_401:\n case authService.logout.name + apiConstants._SUCCESS:\n case authService.revokeSanctumToken.name + apiConstants._SUCCESS:\n case authService.deleteAccount.name + apiConstants._SUCCESS:\n return initialState\n\n case backOfficeService.assignTutor.name + apiConstants._SUCCESS:\n case backOfficeService.updateSalary.name + apiConstants._SUCCESS:\n case backOfficeService.updateMaxStudentsPerLive.name + apiConstants._SUCCESS:\n case backOfficeService.assignAdmin.name + apiConstants._SUCCESS:\n case backOfficeService.changePrivileges.name + apiConstants._SUCCESS:\n case backOfficeService.updatePrioritizedSchoolSubjects.name + apiConstants._SUCCESS:\n case backOfficeService.updateChannel.name + apiConstants._SUCCESS:\n case backOfficeService.updateAutonomyLevel.name + apiConstants._SUCCESS:\n case backOfficeService.setTrialConfirmed.name + apiConstants._SUCCESS:\n case backOfficeService.getUserBackoffice.name + apiConstants._SUCCESS:\n case backOfficeService.acceptNewStudents.name + apiConstants._SUCCESS:\n case backOfficeService.updateSlotTutor.name + apiConstants._SUCCESS:\n case backOfficeService.updateUserBackoffice.name + apiConstants._SUCCESS:\n case backOfficeService.updateStudent.name + apiConstants._SUCCESS:\n case backOfficeService.updateTutor.name + apiConstants._SUCCESS:\n case backOfficeService.validateTutor.name + apiConstants._SUCCESS:\n case backOfficeService.postNewTrialLiveSessionChoiceBackoffice.name + apiConstants._SUCCESS:\n case backOfficeService.resetPasswordForUser.name + apiConstants._SUCCESS:\n case tutorsService.acceptTrials.name + apiConstants._SUCCESS:\n return {\n ...state,\n usersList: state.usersList?.length === 0 ? [action.data] : state.usersList?.map((user) => user?.id === action.data?.id ? action.data : user)\n }\n\n case tutorsService.submitApplicationEvaluation.name + apiConstants._SUCCESS:\n return {\n ...state,\n usersList: state.usersList?.map((user) => user?.id === action.data?.id ? action.data : user)\n }\n\n case backOfficeService.assignStudentsToTutor.name + apiConstants._SUCCESS:\n return {\n ...state,\n usersList: state.usersList?.map((user) => {\n const updatedUser = action.data?.find(updated => updated.id === user.id);\n return updatedUser ? updatedUser : user;\n }) || action.data\n }\n\n case backOfficeService.getAllUsers.name + apiConstants._SUCCESS:\n return {\n ...state,\n list: action.data\n }\n\n case backOfficeService.searchUserFormStep.name + apiConstants._SUCCESS:\n let usersListFormStep = []\n //console.log(\"meta\", action.data)\n if (action.data?.meta?.current_page === 1) { // refresh\n usersListFormStep = action.data?.users\n } else { // concat\n usersListFormStep = state.usersListFormStep.concat(action.data?.users)\n }\n return {\n ...state,\n usersListFormStep: usersListFormStep\n }\n\n case backOfficeService.deleteUser.name + apiConstants._SUCCESS:\n return {\n ...state,\n usersList: state.usersList?.filter((user) => user?.id !== action.routeParams?.id)\n }\n\n case backOfficeService.searchUser.name + apiConstants._SUCCESS:\n let usersList = []\n //console.log(\"meta\", action.data)\n if (action.data?.meta?.current_page === 1) { // refresh\n usersList = action.data?.users\n } else { // concat\n usersList = state.usersList.concat(action.data?.users)\n }\n return {\n ...state,\n usersList: usersList\n }\n case backOfficeService.putStudentAccount.name + apiConstants._SUCCESS:\n //console.log(action.data)\n const updateStudentIfFoundInStore = a => {\n return action.data?.id === a?.id ? action.data : a\n }\n return {\n ...state,\n usersList: state.usersList?.map(updateStudentIfFoundInStore)\n }\n case backOfficeService.putTutorAccount.name + apiConstants._SUCCESS:\n const updateTutorIfFoundInStore = a => {\n return action.data?.id === a?.id ? action.data : a\n }\n return {\n ...state,\n usersList: state.usersList?.map(updateTutorIfFoundInStore)\n }\n\n case backOfficeService.createWeeklyReport.name + apiConstants._SUCCESS:\n return {\n ...state,\n report: action.data\n }\n case backOfficeService.sendWeeklyReport.name + apiConstants._SUCCESS:\n case backOfficeService.getAppreciation.name + apiConstants._SUCCESS:\n case backOfficeService.assignTutorAndLiveSlots.name + apiConstants._SUCCESS:\n const updateStudentTutorIfFoundInStore = a => {\n return action.data?.id === a?.id ? {...a, tutor: action.data?.tutor} : a\n }\n return {\n ...state,\n usersList: state.usersList?.map(updateStudentTutorIfFoundInStore)\n }\n case backOfficeService.updateTutorSlots.name + apiConstants._SUCCESS:\n return {\n ...state,\n usersList: state.usersList?.map(user => {\n return user.id === action.data?.id ? action.data : user\n })\n }\n case backOfficeService.newStudent.name + apiConstants._SUCCESS:\n\n return {\n ...state,\n usersList: [...state.usersList, action?.data]\n }\n case backOfficeService.updateStudentSubscription.name + apiConstants._SUCCESS:\n case backOfficeService.newStudentSubscription.name + apiConstants._SUCCESS:\n return {\n ...state,\n usersList: state.usersList?.map((user) => {\n if (user?.id === action?.data?.user?.id) {\n return {...action?.data?.user, current_offer: action?.data?.subscribed_product}\n }\n return user\n })\n }\n case backOfficeService.updateStudentBalance.name + apiConstants._SUCCESS:\n case backOfficeService.cancelStudentSubscription.name + apiConstants._SUCCESS:\n return {\n ...state,\n usersList: state.usersList?.map((user) => {\n if (user?.id === action?.data?.id) {\n return action?.data\n }\n return user\n })\n }\n\n default:\n return state\n }\n}\n\nexport default tutors\n","//import {getMeetingCode, getMeetingUrl} from \"@common/video-call/callUtilities\";\nimport videoCallConstants from \"../../../constants/videoCallConstants\";\n\n// ** Initial State\nconst initialState = {\n userName: '',\n //roomLink: getMeetingUrl(),\n //roomCode: getMeetingCode(),\n hmsLocalPeer: null,\n hmsInstance: null,\n joinConfig: {\n mutedAudio: true,\n mutedVideo: true,\n mirrorCamera: true,\n },\n}\n\nexport function videoCall(state = initialState, action) {\n switch (action.type) {\n case videoCallConstants.SAVE_USER_DATA:\n return {\n ...state,\n ...action.payload,\n };\n case videoCallConstants.CLEAR_HMS_INSTANCE:\n return {\n ...state,\n hmsInstance: null,\n };\n\n case videoCallConstants.RESET_JOIN_CONFIG:\n return {...state, joinConfig: initialState.joinConfig};\n\n case videoCallConstants.CHANGE_JOIN_AUDIO_MUTED:\n return {\n ...state,\n joinConfig: {\n ...state.joinConfig,\n mutedAudio: action.payload.mutedAudio ?? true,\n },\n };\n case videoCallConstants.CHANGE_JOIN_VIDEO_MUTED:\n return {\n ...state,\n joinConfig: {\n ...state.joinConfig,\n mutedVideo: action.payload.mutedVideo ?? true,\n },\n };\n case videoCallConstants.CHANGE_MIRROR_CAMERA:\n return {\n ...state,\n joinConfig: {\n ...state.joinConfig,\n mirrorCamera: action.payload.mirrorCamera ?? true,\n },\n };\n\n default:\n return state\n }\n}\n\nexport default videoCall\n","const SAVE_USER_DATA = 'SAVE_USER_DATA';\n\nconst CLEAR_HMS_INSTANCE = 'CLEAR_HMS_INSTANCE';\n\nconst RESET_JOIN_CONFIG = 'RESET_JOIN_CONFIG';\n\nconst CHANGE_JOIN_AUDIO_MUTED = 'CHANGE_JOIN_AUDIO_MUTED';\n\nconst CHANGE_JOIN_VIDEO_MUTED = 'CHANGE_JOIN_VIDEO_MUTED';\n\nconst CHANGE_MIRROR_CAMERA = 'CHANGE_MIRROR_CAMERA';\n\nconst MUTE_AUDIO = 'MUTE_AUDIO';\n\nconst MUTE_VIDEO = 'MUTE_VIDEO';\n\nexport default {\n SAVE_USER_DATA,\n CLEAR_HMS_INSTANCE,\n RESET_JOIN_CONFIG,\n CHANGE_JOIN_AUDIO_MUTED,\n CHANGE_JOIN_VIDEO_MUTED,\n CHANGE_MIRROR_CAMERA,\n MUTE_AUDIO,\n MUTE_VIDEO,\n};","import {offlineModeConstants} from \"../../../constants/offlineModeConstants\";\n\nconst initialState = {\n isOfflineModeEnabled: false,\n isInternetReachable: true,\n activityStartedWithOfflineMode: false,\n isActivityOfflineModeValid: true,\n timerStepOngoing: false\n}\n\nexport default function offlineMode(state = initialState, action) {\n switch (action.type) {\n case offlineModeConstants.IS_OFFLINE_MODE_CHANGE:\n return {\n ...state,\n isOfflineModeEnabled: action.newState\n }\n case offlineModeConstants.IS_INTERNET_REACHABLE_CHANGE:\n return {\n ...state,\n isInternetReachable: action.newState\n }\n case offlineModeConstants.ACTIVITY_STARTED_WITH_OFFLINE_MODE:\n return {\n ...state,\n activityStartedWithOfflineMode: true\n }\n case offlineModeConstants.ACTIVITY_OFFLINE_MODE_INVALID:\n return {\n ...state,\n isActivityOfflineModeValid: false\n }\n\n case offlineModeConstants.TIMER_STEP_STARTED:\n return {\n ...state,\n timerStepOngoing: true\n }\n\n case offlineModeConstants.OFFLINE_MODE_CLEAR:\n return initialState\n default:\n return state\n }\n}\n","export const offlineModeConstants = {\n IS_OFFLINE_MODE_CHANGE: 'IS_OFFLINE_MODE_CHANGE',\n IS_INTERNET_REACHABLE_CHANGE: 'IS_INTERNET_REACHABLE_CHANGE',\n ACTIVITY_STARTED_WITH_OFFLINE_MODE: 'ACTIVITY_STARTED_WITH_OFFLINE_MODE',\n ACTIVITY_OFFLINE_MODE_INVALID: 'ACTIVITY_OFFLINE_MODE_INVALID',\n OFFLINE_MODE_CLEAR: 'OFFLINE_MODE_CLEAR',\n TIMER_STEP_STARTED: 'TIMER_STEP_STARTED',\n}\n","import {liveModeConstants} from \"../../../constants/liveModeConstants\";\nimport {liveService} from \"../../../services/liveService\";\nimport {apiConstants} from \"../../../constants/apiConstants\";\nimport videoCallConstants from \"@data/constants/videoCallConstants\";\nimport {liveServiceV2} from \"@data/services/liveServiceV2\";\n\nconst initialState = {\n isLiveModeEnabled: false,\n liveSessionId: null,\n isTyping: false,\n liveParticipants: [],\n liveTutors: [],\n typingUser: null,\n inCallUsers: [],\n raisedHands: [],\n phoneRinging: [],\n todayLiveSessionLogs: [],\n timesSinceLastCall: [],\n conferenceToken: null,\n callPortal: false,\n visibleInvite: false,\n sound: null,\n callMode: null,\n //inLiveNotReadMessagesCount: {},\n activityFinalizedCount: null,\n isAudioMuted: false,\n isVideoMuted: false,\n soundModeIds: [],\n outOfAppIds: [],\n activityCameraOnIds: [],\n // soundMode: false,\n voiceActivityRecordingIds: [],\n activeTime: [],\n liveReport: null,\n callKeepUUID: null,\n isCallKeepOn: false,\n hasPhonePermission: true,\n roomVersion: \"\",\n liveSessionsList: [],\n};\n\nexport default function liveMode(state = initialState, action) {\n switch (action.type) {\n case liveService.getLiveSessions.name + apiConstants._SUCCESS:\n return {\n ...state,\n liveSessionsList: action.data\n };\n case liveModeConstants.SET_CALL_KEEP_UUID:\n return {\n ...state,\n callKeepUUID: action.uuid\n };\n case liveModeConstants.SET_CALLKEEP_ON:\n return {\n ...state,\n isCallKeepOn: action.newStatus\n };\n case liveModeConstants.SET_HAS_PHONE_PERMISSION:\n return {\n ...state,\n hasPhonePermission: action.newStatus\n };\n case liveService.getTodayLiveReport.name + apiConstants._SUCCESS:\n return {\n ...state,\n liveReport: action.data\n };\n case liveService.setSoundMode.name + apiConstants._SUCCESS:\n case liveServiceV2.setSoundModeV2.name + apiConstants._SUCCESS:\n return {\n ...state,\n soundModeIds: action.data?.sound_mode_ids,\n // soundMode: !state?.soundMode,\n todayLiveSessionLogs: action.data?.today_live_session_logs\n };\n case liveModeConstants.SOUND_MODE:\n // console.log(\"action.newState\", action.newState, action.userId)\n return {\n ...state,\n soundModeIds: action.newState\n ? state.soundModeIds?.includes(action.userId)\n ? state.soundModeIds\n : [...state.soundModeIds, action.userId]\n : state?.soundModeIds.filter((id) => id !== action.userId)\n };\n case liveModeConstants.OUT_OF_APP:\n // console.log(\"action.newState\", action.newState, action.userId)\n return {\n ...state,\n outOfAppIds: action.newState\n ? state.outOfAppIds?.includes(action.userId)\n ? state.outOfAppIds\n : [...state.outOfAppIds, action.userId]\n : state?.outOfAppIds.filter((id) => id !== action.userId)\n };\n case liveModeConstants.ACTIVITY_CAMERA_ON:\n // console.log(\"action.newState\", action.newState, action.userId)\n return {\n ...state,\n activityCameraOnIds: action.newState\n ? state.activityCameraOnIds?.includes(action.userId)\n ? state.activityCameraOnIds\n : [...state.activityCameraOnIds, action.userId]\n : state?.activityCameraOnIds.filter((id) => id !== action.userId)\n };\n case liveModeConstants.VOICE_RECORDING_ACTIVITY:\n return {\n ...state,\n voiceActivityRecordingIds: action.newState\n ? state.voiceActivityRecordingIds?.includes(action.userId)\n ? state.voiceActivityRecordingIds\n : [...state.voiceActivityRecordingIds, action.userId]\n : state?.voiceActivityRecordingIds.filter((id) => id !== action.userId)\n };\n case videoCallConstants.MUTE_AUDIO:\n return {\n ...state,\n isAudioMuted: action?.muted\n };\n case videoCallConstants.MUTE_VIDEO:\n return {\n ...state,\n isVideoMuted: action?.muted\n };\n case liveModeConstants.RESET_LIVE_MODE:\n return initialState;\n // case liveService.leaveLiveSession.name + apiConstants._SUCCESS:\n // //case liveService.finalizeLiveSession.name + apiConstants._SUCCESS:\n // return {\n // ...state,\n // isLiveModeEnabled: false,\n // }\n case liveServiceV2.getLiveSessionV2.name + apiConstants._SUCCESS:\n return {\n ...state,\n roomVersion: action.data.live_session?.live_room?.version\n }\n case liveService.getLiveSession.name + apiConstants._SUCCESS:\n return {\n ...state,\n conferenceToken: action.data?.conference_token,\n screenshareToken: action.data?.screenshare_token\n };\n case liveServiceV2.leaveCallV2.name + apiConstants._SUCCESS:\n case liveService.joinCall.name + apiConstants._SUCCESS:\n case liveServiceV2.joinCallV2.name + apiConstants._SUCCESS:\n case liveService.getCall.name + apiConstants._SUCCESS:\n case liveServiceV2.getCallV2.name + apiConstants._SUCCESS:\n case liveService.raiseHand.name + apiConstants._SUCCESS:\n case liveService.lowerHands.name + apiConstants._SUCCESS:\n case liveServiceV2.lowerHandsV2.name + apiConstants._SUCCESS:\n case liveService.lowerAllHands.name + apiConstants._SUCCESS:\n return {\n ...state,\n inCallUsers: action.data?.call_participant_ids,\n raisedHands: action.data?.raised_hands_ids,\n visibleInvite: action.data?.has_incoming_call,\n todayLiveSessionLogs: action.data?.today_live_session_logs,\n soundModeIds: action.data?.sound_mode_ids,\n voiceActivityRecordingIds: action.data?.voice_recording_activity_ids\n };\n case liveModeConstants.SET_TIMES_SINCE_LAST_CALL:\n return {\n ...state,\n timesSinceLastCall: action.newState\n };\n case liveModeConstants.SET_ACTIVE_TIME:\n return {\n ...state,\n activeTime: action.newState\n };\n case liveModeConstants.NEW_LIVE_SESSION_LOG:\n return {\n ...state,\n todayLiveSessionLogs: [\n ...(state?.todayLiveSessionLogs ?? []),\n action.newState\n ]\n };\n\n case liveModeConstants.HIDE_INCOMING_CALL:\n return {\n ...state,\n visibleInvite: false\n };\n case liveModeConstants.SHOW_INCOMING_CALL:\n return {\n ...state,\n visibleInvite: true\n };\n case liveModeConstants.IS_LIVE_MODE_CHANGE:\n return {\n ...state,\n isLiveModeEnabled: action.newState,\n liveSessionId: parseInt(action.liveSessionId)\n };\n case liveModeConstants.IS_TYPING:\n return {\n ...state,\n isTyping: action.newState\n };\n case liveModeConstants.TYPING_USER:\n return {\n ...state,\n typingUser: action.newState\n };\n case liveModeConstants.LIVE_PARTICIPANTS:\n return {\n ...state,\n liveParticipants: action.newState\n };\n case liveModeConstants.ADD_PARTICIPANT:\n if (!state.liveParticipants.includes(action.newState))\n return {\n ...state,\n liveParticipants: [...state.liveParticipants, action.newState]\n };\n return state;\n // case liveModeConstants.LIVE_TUTORS:\n // if (!state.liveTutors.map(item => item.id).includes(action.newState.id))\n // return {\n // ...state,\n // liveTutors: [...state.liveTutors, action.newState]\n // }\n // return state\n case liveModeConstants.REMOVE_PARTICIPANT:\n return {\n ...state,\n liveParticipants: state.liveParticipants.filter(\n (p) => p !== action.newState\n )\n };\n // case liveModeConstants.REMOVE_TUTOR:\n // return {\n // ...state,\n // liveTutors: state.liveTutors.filter(t => t.id.toString() !== action.newState?.toString())\n // }\n case liveModeConstants.CLEAR_MEMBERS:\n return {\n ...state,\n liveTutors: [],\n liveParticipants: []\n };\n case liveModeConstants.IN_CALL_USERS:\n return {\n ...state,\n inCallUsers: action.newState\n };\n case liveModeConstants.ADD_IN_CALL_USER:\n return {\n ...state,\n inCallUsers: state.inCallUsers?.includes(action.newState)\n ? state.inCallUsers\n : [...state.inCallUsers, action.newState]\n };\n\n case liveModeConstants.REMOVE_IN_CALL_USERS:\n return {\n ...state,\n inCallUsers: [\n ...state.inCallUsers.filter((t) => t !== action.newState)\n ]\n };\n case liveModeConstants.PHONE_RINGING:\n return {\n ...state,\n phoneRinging: action.newState\n };\n case liveModeConstants.RESET_PHONE_RINGING:\n return {\n ...state,\n phoneRinging: []\n };\n case liveModeConstants.ADD_PHONE_RINGING:\n return {\n ...state,\n phoneRinging: state.phoneRinging?.includes(action.newState)\n ? state.phoneRinging\n : [...state.phoneRinging, action.newState]\n };\n\n case liveModeConstants.REMOVE_PHONE_RINGING:\n return {\n ...state,\n phoneRinging: [\n ...state.phoneRinging.filter((t) => t !== action.newState)\n ]\n };\n case liveModeConstants.RAISED_HANDS:\n return {\n ...state,\n raisedHands: action.newState\n };\n case liveModeConstants.ADD_RAISED_HAND:\n return {\n ...state,\n raisedHands: state.raisedHands?.includes(action.newState)\n ? state.raisedHands\n : [...state.raisedHands, action.newState]\n };\n case liveModeConstants.REMOVE_RAISED_HAND:\n return {\n ...state,\n raisedHands: [\n ...state.raisedHands.filter((t) => t !== action.newState)\n ]\n };\n case liveModeConstants.SET_CALL_PORTAL:\n return {\n ...state,\n callPortal: action.newState,\n callMode: action?.mode\n };\n case liveModeConstants.PLAY_SOUND:\n return {\n ...state,\n sound: action.sound\n };\n default:\n return state;\n }\n}\n","import { cameraConstants } from '@data/constants/cameraConstants'\n\nconst initialState = {\n ratio: null,\n imagePadding: null,\n lastPhoto: null,\n formId: null,\n chatPhoto: null,\n videoRecord: null,\n}\n\nexport default function camera(state = initialState, action) {\n switch (action.type) {\n case cameraConstants.SET_VIDEO_RECORD:\n return {\n ...state,\n videoRecord: action.video,\n }\n case cameraConstants.RECORD_CAMERA_SETTINGS:\n return {\n ...state,\n ratio: action.ratio,\n imagePadding: action.imagePadding,\n }\n\n case cameraConstants.RESET_CAMERA_SETTINGS:\n return {\n ...state,\n ratio: null,\n imagePadding: null,\n }\n case cameraConstants.NEW_PHOTO:\n return {\n ...state,\n formId: action.formId,\n lastPhoto: action.newPhoto,\n }\n case cameraConstants.NEW_PHOTOS:\n return {\n ...state,\n formId: action.formId,\n lastPhotos: action.newPhotos,\n }\n case cameraConstants.PHOTO_CLEAR:\n return {\n ...state,\n formId: null,\n lastPhoto: null,\n }\n case cameraConstants.PHOTOS_CLEAR:\n return {\n ...state,\n formId: null,\n lastPhotos: [],\n }\n default:\n return state\n }\n}\n","export const cameraConstants = {\n RECORD_CAMERA_SETTINGS: 'RECORD_CAMERA_SETTINGS',\n RESET_CAMERA_SETTINGS: 'RESET_CAMERA_SETTINGS',\n NEW_PHOTO: 'NEW_PHOTO',\n NEW_PHOTOS: 'NEW_PHOTOS',\n PHOTO_CLEAR: 'PHOTO_CLEAR',\n PHOTOS_CLEAR: 'PHOTOS_CLEAR',\n NEW_CHAT_PHOTO: 'NEW_CHAT_PHOTO',\n SET_VIDEO_RECORD: 'SET_VIDEO_RECORD',\n}\n","import {apiService} from \"../../../services\"\nimport {apiConstants, VAPOR_FILE_UPLOAD} from \"../../../constants/apiConstants\"\nimport {authConstants} from \"../../../constants/authConstants\";\n\nconst initialState = {\n networkOn: true\n}\n\nexport default function api(state = initialState, action) {\n\n // let i = 0\n\n if (action.type === apiConstants.NETWORK_ON)\n return {\n ...state,\n networkOn: true\n }\n else if (action.type === apiConstants.NETWORK_OFF)\n return {\n ...state,\n networkOn: false\n }\n\n if (action.type === VAPOR_FILE_UPLOAD + apiConstants._IDLE)\n return {\n ...state,\n vaporFileUpload: {}\n }\n else if (action.type === VAPOR_FILE_UPLOAD + apiConstants._REQUEST)\n return {\n ...state,\n vaporFileUpload: {\n request: true,\n file: action.file\n }\n }\n else if (action.type === VAPOR_FILE_UPLOAD + apiConstants._SUCCESS)\n return {\n ...state,\n vaporFileUpload: {\n success: true,\n response: action.response,\n file: action.file,\n formId: action.formId\n }\n }\n else if (action.type === VAPOR_FILE_UPLOAD + apiConstants._FAILURE)\n return {\n ...state,\n vaporFileUpload: {\n error: action.error,\n file: action.file\n }\n }\n\n for (const service of Object.keys(apiService)) {\n for (const request of Object.keys(apiService[service])) {\n\n // console.log(request)\n // i++\n\n switch (action.type) {\n\n case authConstants.LOGOUT_401:\n case request + apiConstants._IDLE:\n return {\n ...state,\n [request]: {}\n }\n\n case request + apiConstants._REQUEST:\n return {\n ...state,\n [request]: {\n request: true,\n routeParams: action.routeParams,\n data: action.data,\n urlParams: action.urlParams\n }\n }\n\n case request + apiConstants._SUCCESS:\n return {\n ...state,\n [request]: {\n success: true,\n routeParams: action.routeParams,\n data: action.data,\n all_data:action.all_data,\n urlParams: action.urlParams\n }\n }\n\n case request + apiConstants._FAILURE:\n return {\n ...state,\n [request]: {error: action.error, routeParams: action.routeParams, urlParams: action.urlParams}\n }\n }\n }\n }\n // console.log(i)\n return state\n}\n","import { activitiesService } from \"./activitiesService\"\nimport { authService } from \"./authService\"\nimport { studentsService } from \"./studentsService\"\nimport { tutorsService } from \"./tutorsService\"\nimport { backOfficeService } from \"./backOfficeService\"\nimport { interviewsService } from \"./interviewsService\"\nimport { staticDataService } from \"./staticDataService\";\nimport { challengesService } from \"./challengesService\";\nimport { achievementsService } from \"./achievementsService\";\nimport { shopService } from \"./shopService\";\nimport { schoolsService } from \"./schoolsService\";\nimport { subscriptionService } from \"./subscriptionService\";\nimport { messengerService } from \"./messengerService\";\nimport { skillSetsService } from \"./skillSetsService\";\nimport { scoringService } from \"./scoringService\";\nimport { liveService } from \"./liveService\";\nimport { roomService } from \"@data/services/roomService\";\nimport { quizzService } from \"@data/services/quizzservice\";\nimport { liveReportService } from \"@data/services/liveReportService\";\nimport { referralService } from \"@data/services/referralService\";\nimport { chaptersService } from \"@data/services/chaptersService\";\nimport { interviewReportService } from \"@data/services/interviewReportService\";\nimport { gradesService } from \"@data/services/gradesService\";\nimport { studyProgramsService } from \"@data/services/studyProgramsService\";\nimport { liveServiceV2} from \"@data/services/liveServiceV2\";\nimport {substitutionProposalsService } from \"./substitutionProposalsService\";\nimport {trialSessionsService} from \"@data/services/trialSessionsService\";\nimport {attendanceFlagsService} from \"@data/services/attendanceFlagsService\";\nimport { schoolCardReportService } from \"./schoolCardReportService\";\n\nexport const apiService = {\n auth: authService,\n activities: activitiesService,\n schools: schoolsService,\n subscriptionService: subscriptionService,\n scoringService: scoringService,\n achievements: achievementsService,\n challenges: challengesService,\n staticData: staticDataService,\n shop: shopService,\n interviews: interviewsService,\n students: studentsService,\n tutors: tutorsService,\n backOffice: backOfficeService,\n messenger: messengerService,\n skill_sets: skillSetsService,\n live: liveService,\n liveV2: liveServiceV2,\n liveReport: liveReportService,\n room: roomService,\n quizz: quizzService,\n referral: referralService,\n chapters: chaptersService,\n interviewReport: interviewReportService,\n grades: gradesService,\n studyPrograms: studyProgramsService,\n substitutionProposals: substitutionProposalsService,\n trialSessions: trialSessionsService,\n attendanceFlags: attendanceFlagsService,\n schoolCardReportService: schoolCardReportService\n\n};\nexport { vaporStore } from \"./vaporService\";\n","import axios from \"axios\"\n\n\n\nfunction quizzQuestions() {\n return axios.get(`api/v1/quizz`)\n}\n\nfunction initQuizzSubmit({}, values) {\n return axios.post(`api/v1/quizz/init`, values)\n}\n\nfunction confirmQuizzSubmit({quizz_submit_id}, values) {\n return axios.post(`/api/v1/quizz/${quizz_submit_id}/confirm`, values)\n}\n\nexport const quizzService = {\n quizzQuestions,\n initQuizzSubmit,\n confirmQuizzSubmit\n}\n","import axios from \"axios\";\n\nexport async function vaporStore(file, options = {}) {\n const response = await axios.post(options.signedStorageUrl ? options.signedStorageUrl : '/vapor/signed-storage-url', {\n 'bucket': options.bucket || '',\n 'content_type': options.contentType || file.type,\n 'expires': options.expires || '',\n 'visibility': options.visibility || '',\n ...options.data\n }, {\n baseURL: options.baseURL || null,\n headers: options.headers || {},\n ...options.options\n });\n\n let headers = response.data.headers;\n\n // if (typeof options.onUploadProgress === 'undefined') {\n // options.onUploadProgress = () => {\n // };\n // }\n\n // const cancelToken = options.cancelToken || ''\n\n // TODO : add upload progress\n // option 1 : keep fetch and add to it progress logic (library ?)\n // option 2 : use XMLHttpRequest https://finnian.io/blog/uploading-files-to-s3-react-native-ruby-on-rails/ and https://gist.github.com/developius/1fa35f2192b886dfce4e7f4eaed8b923#file-axios_gcs_expo_example-ts\n await fetch(response.data.url, {\n method: 'PUT',\n headers: headers,\n body: file\n })\n .catch(error => {\n console.log('Error:', JSON.stringify(error, null, 2))\n return Promise.reject(error)\n })\n\n // delete axios.defaults.headers.common['Authorization']\n //\n // await axios.put(response.data.url, file, {\n // // cancelToken: cancelToken,\n // headers,\n // onUploadProgress: options.onUploadProgress\n // })\n\n // response.data.extension = file._data.name.split('.').pop()\n\n return response.data;\n}","import {notificationConstants} from \"../../../constants/notificationConstants\";\n\nconst initialState = {\n lastIdentifier: null,\n}\n\nexport default function notifications(state = initialState, action) {\n switch (action.type) {\n case notificationConstants.SET_LAST_IDENTIFIER:\n return {\n ...state,\n lastIdentifier: action.lastIdentifier,\n }\n\n case notificationConstants.CLEAR_LAST_IDENTIFIER:\n return {\n ...state,\n lastIdentifier: null,\n }\n default:\n return state\n }\n}\n","export const notificationConstants = {\n SET_LAST_IDENTIFIER: 'SET_LAST_IDENTIFIER',\n CLEAR_LAST_IDENTIFIER: 'CLEAR_LAST_IDENTIFIER'\n}\n","import {activitiesConstants} from \"@data/constants/activitiesConstants\";\n\nconst initialState = {\n activityPaused: false,\n ongoingActivity: false,\n cameraOn: false,\n audioStatus: \"\",\n updatedActivityEventData: null\n}\n\nexport default function activity(state = initialState, action) {\n switch (action.type) {\n case activitiesConstants.UPDATE_ACTIVITY_CHRONO:\n return {\n ...state,\n updatedActivityEventData: action?.data\n }\n case activitiesConstants.AUDIO_STATUS:\n return {\n ...state,\n audioStatus: action?.data\n }\n case activitiesConstants.ONGOING_ACTIVITY:\n return {\n ...state,\n ongoingActivity: action?.data\n }\n case activitiesConstants.PAUSE_ACTIVITY:\n return {\n ...state,\n activityPaused: action?.data\n }\n case activitiesConstants.SET_CAMERA_STATUS:\n return {\n ...state,\n cameraOn: action?.cameraOn\n }\n default:\n return state\n }\n}\n","import {navigationConstants} from \"@data/constants/navigationConstants\";\n\nconst initialState = {\n congrats: [],\n nextScreenParams: {}\n}\n\nexport default function navigation(state = initialState, action) {\n switch (action.type) {\n case navigationConstants.PUT_CONGRATS:\n return {\n ...state,\n congrats: action?.data\n }\n case navigationConstants.PULL_NEXT_CONGRATS:\n let congratsCopy = state?.congrats?.slice()\n congratsCopy.shift()\n\n return {\n ...state,\n congrats: congratsCopy\n }\n case navigationConstants.PUT_NEXT_SCREEN_PARAMS:\n return {\n ...state,\n nextScreenParams: action?.data\n }\n case navigationConstants.PULL_NEXT_SCREEN_PARAMS:\n return {\n ...state,\n nextScreenParams: {}\n }\n\n default:\n return state\n }\n}\n","export const navigationConstants = {\n PUT_CONGRATS: 'PUT_CONGRATS',\n PULL_NEXT_CONGRATS: 'PULL_NEXT_CONGRATS',\n PUT_NEXT_SCREEN_PARAMS: 'PUT_NEXT_SCREEN_PARAMS',\n PULL_NEXT_SCREEN_PARAMS: 'PULL_NEXT_SCREEN_PARAMS'\n}","import {liveServiceV2} from \"@data/services/liveServiceV2\";\nimport {apiConstants} from \"@data/constants/apiConstants\";\nimport {liveService} from \"@data/services/liveService\";\nimport {messengerService} from \"@data/services/messengerService\";\nimport {liveKitRoomConstants, liveModeConstants} from \"@data/constants/liveModeConstants\";\n\nconst initialState = {\n roomData:\n {\n video: false,\n audio: false,\n roomName: null,\n token: null,\n shouldUseCallKeep: true,\n serverUrl: \"wss://masteur-qw3yjura.livekit.cloud/\"\n }\n}\n\nexport default function index(state = initialState, action) {\n switch (action.type) {\n case liveKitRoomConstants.SET_LIVEKIT_TOKEN:\n return {\n ...state,\n roomData: {\n ...state.roomData,\n token: action.token,\n roomName: action.roomName,\n audio: true,\n video: true,\n }\n }\n case liveService.leaveLiveSession.name + apiConstants._SUCCESS:\n case liveModeConstants.RESET_LIVE_MODE:\n return {\n ...state,\n roomData: {\n ...state.roomData,\n token: null,\n roomName: null,\n audio: false,\n video: false,\n }\n }\n case messengerService.getMessengerThread.name + apiConstants._SUCCESS:\n return {\n ...state,\n roomData: {\n ...state.roomData,\n token: action.data.livekit_token,\n roomName: action.data.messenger_thread_id ?? null,\n audio: false,\n video: false,\n messengerThreadId: action.data.messenger_thread_id,\n }\n }\n default:\n return state\n }\n}\n","export { default as persistReducer } from './persistReducer';\nexport { default as persistCombineReducers } from './persistCombineReducers';\nexport { default as persistStore } from './persistStore';\nexport { default as createMigrate } from './createMigrate';\nexport { default as createTransform } from './createTransform';\nexport { default as getStoredState } from './getStoredState';\nexport { default as createPersistoid } from './createPersistoid';\nexport { default as purgeStoredState } from './purgeStoredState';\nexport * from './constants';","function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport { FLUSH, PAUSE, PERSIST, PURGE, REHYDRATE, DEFAULT_VERSION } from './constants';\nimport autoMergeLevel1 from './stateReconciler/autoMergeLevel1';\nimport createPersistoid from './createPersistoid';\nimport defaultGetStoredState from './getStoredState';\nimport purgeStoredState from './purgeStoredState';\nvar DEFAULT_TIMEOUT = 5000;\n/*\n @TODO add validation / handling for:\n - persisting a reducer which has nested _persist\n - handling actions that fire before reydrate is called\n*/\n\nexport default function persistReducer(config, baseReducer) {\n if (process.env.NODE_ENV !== 'production') {\n if (!config) throw new Error('config is required for persistReducer');\n if (!config.key) throw new Error('key is required in persistor config');\n if (!config.storage) throw new Error(\"redux-persist: config.storage is required. Try using one of the provided storage engines `import storage from 'redux-persist/lib/storage'`\");\n }\n\n var version = config.version !== undefined ? config.version : DEFAULT_VERSION;\n var debug = config.debug || false;\n var stateReconciler = config.stateReconciler === undefined ? autoMergeLevel1 : config.stateReconciler;\n var getStoredState = config.getStoredState || defaultGetStoredState;\n var timeout = config.timeout !== undefined ? config.timeout : DEFAULT_TIMEOUT;\n var _persistoid = null;\n var _purge = false;\n var _paused = true;\n\n var conditionalUpdate = function conditionalUpdate(state) {\n // update the persistoid only if we are rehydrated and not paused\n state._persist.rehydrated && _persistoid && !_paused && _persistoid.update(state);\n return state;\n };\n\n return function (state, action) {\n var _ref = state || {},\n _persist = _ref._persist,\n rest = _objectWithoutProperties(_ref, [\"_persist\"]); // $FlowIgnore need to update State type\n\n\n var restState = rest;\n\n if (action.type === PERSIST) {\n var _sealed = false;\n\n var _rehydrate = function _rehydrate(payload, err) {\n // dev warning if we are already sealed\n if (process.env.NODE_ENV !== 'production' && _sealed) console.error(\"redux-persist: rehydrate for \\\"\".concat(config.key, \"\\\" called after timeout.\"), payload, err); // only rehydrate if we are not already sealed\n\n if (!_sealed) {\n action.rehydrate(config.key, payload, err);\n _sealed = true;\n }\n };\n\n timeout && setTimeout(function () {\n !_sealed && _rehydrate(undefined, new Error(\"redux-persist: persist timed out for persist key \\\"\".concat(config.key, \"\\\"\")));\n }, timeout); // @NOTE PERSIST resumes if paused.\n\n _paused = false; // @NOTE only ever create persistoid once, ensure we call it at least once, even if _persist has already been set\n\n if (!_persistoid) _persistoid = createPersistoid(config); // @NOTE PERSIST can be called multiple times, noop after the first\n\n if (_persist) {\n // We still need to call the base reducer because there might be nested\n // uses of persistReducer which need to be aware of the PERSIST action\n return _objectSpread({}, baseReducer(restState, action), {\n _persist: _persist\n });\n }\n\n if (typeof action.rehydrate !== 'function' || typeof action.register !== 'function') throw new Error('redux-persist: either rehydrate or register is not a function on the PERSIST action. This can happen if the action is being replayed. This is an unexplored use case, please open an issue and we will figure out a resolution.');\n action.register(config.key);\n getStoredState(config).then(function (restoredState) {\n var migrate = config.migrate || function (s, v) {\n return Promise.resolve(s);\n };\n\n migrate(restoredState, version).then(function (migratedState) {\n _rehydrate(migratedState);\n }, function (migrateErr) {\n if (process.env.NODE_ENV !== 'production' && migrateErr) console.error('redux-persist: migration error', migrateErr);\n\n _rehydrate(undefined, migrateErr);\n });\n }, function (err) {\n _rehydrate(undefined, err);\n });\n return _objectSpread({}, baseReducer(restState, action), {\n _persist: {\n version: version,\n rehydrated: false\n }\n });\n } else if (action.type === PURGE) {\n _purge = true;\n action.result(purgeStoredState(config));\n return _objectSpread({}, baseReducer(restState, action), {\n _persist: _persist\n });\n } else if (action.type === FLUSH) {\n action.result(_persistoid && _persistoid.flush());\n return _objectSpread({}, baseReducer(restState, action), {\n _persist: _persist\n });\n } else if (action.type === PAUSE) {\n _paused = true;\n } else if (action.type === REHYDRATE) {\n // noop on restState if purging\n if (_purge) return _objectSpread({}, restState, {\n _persist: _objectSpread({}, _persist, {\n rehydrated: true\n }) // @NOTE if key does not match, will continue to default else below\n\n });\n\n if (action.key === config.key) {\n var reducedState = baseReducer(restState, action);\n var inboundState = action.payload; // only reconcile state if stateReconciler and inboundState are both defined\n\n var reconciledRest = stateReconciler !== false && inboundState !== undefined ? stateReconciler(inboundState, state, reducedState, config) : reducedState;\n\n var _newState = _objectSpread({}, reconciledRest, {\n _persist: _objectSpread({}, _persist, {\n rehydrated: true\n })\n });\n\n return conditionalUpdate(_newState);\n }\n } // if we have not already handled PERSIST, straight passthrough\n\n\n if (!_persist) return baseReducer(state, action); // run base reducer:\n // is state modified ? return original : return updated\n\n var newState = baseReducer(restState, action);\n if (newState === restState) return state;\n return conditionalUpdate(_objectSpread({}, newState, {\n _persist: _persist\n }));\n };\n}","export var KEY_PREFIX = 'persist:';\nexport var FLUSH = 'persist/FLUSH';\nexport var REHYDRATE = 'persist/REHYDRATE';\nexport var PAUSE = 'persist/PAUSE';\nexport var PERSIST = 'persist/PERSIST';\nexport var PURGE = 'persist/PURGE';\nexport var REGISTER = 'persist/REGISTER';\nexport var DEFAULT_VERSION = -1;","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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/*\n autoMergeLevel1: \n - merges 1 level of substate\n - skips substate if already modified\n*/\nexport default function autoMergeLevel1(inboundState, originalState, reducedState, _ref) {\n var debug = _ref.debug;\n\n var newState = _objectSpread({}, reducedState); // only rehydrate if inboundState exists and is an object\n\n\n if (inboundState && _typeof(inboundState) === 'object') {\n Object.keys(inboundState).forEach(function (key) {\n // ignore _persist data\n if (key === '_persist') return; // if reducer modifies substate, skip auto rehydration\n\n if (originalState[key] !== reducedState[key]) {\n if (process.env.NODE_ENV !== 'production' && debug) console.log('redux-persist/stateReconciler: sub state for key `%s` modified, skipping.', key);\n return;\n } // otherwise hard set the new value\n\n\n newState[key] = inboundState[key];\n });\n }\n\n if (process.env.NODE_ENV !== 'production' && debug && inboundState && _typeof(inboundState) === 'object') console.log(\"redux-persist/stateReconciler: rehydrated keys '\".concat(Object.keys(inboundState).join(', '), \"'\"));\n return newState;\n}","import { KEY_PREFIX, REHYDRATE } from './constants';\n// @TODO remove once flow < 0.63 support is no longer required.\nexport default function createPersistoid(config) {\n // defaults\n var blacklist = config.blacklist || null;\n var whitelist = config.whitelist || null;\n var transforms = config.transforms || [];\n var throttle = config.throttle || 0;\n var storageKey = \"\".concat(config.keyPrefix !== undefined ? config.keyPrefix : KEY_PREFIX).concat(config.key);\n var storage = config.storage;\n var serialize;\n\n if (config.serialize === false) {\n serialize = function serialize(x) {\n return x;\n };\n } else if (typeof config.serialize === 'function') {\n serialize = config.serialize;\n } else {\n serialize = defaultSerialize;\n }\n\n var writeFailHandler = config.writeFailHandler || null; // initialize stateful values\n\n var lastState = {};\n var stagedState = {};\n var keysToProcess = [];\n var timeIterator = null;\n var writePromise = null;\n\n var update = function update(state) {\n // add any changed keys to the queue\n Object.keys(state).forEach(function (key) {\n if (!passWhitelistBlacklist(key)) return; // is keyspace ignored? noop\n\n if (lastState[key] === state[key]) return; // value unchanged? noop\n\n if (keysToProcess.indexOf(key) !== -1) return; // is key already queued? noop\n\n keysToProcess.push(key); // add key to queue\n }); //if any key is missing in the new state which was present in the lastState,\n //add it for processing too\n\n Object.keys(lastState).forEach(function (key) {\n if (state[key] === undefined && passWhitelistBlacklist(key) && keysToProcess.indexOf(key) === -1 && lastState[key] !== undefined) {\n keysToProcess.push(key);\n }\n }); // start the time iterator if not running (read: throttle)\n\n if (timeIterator === null) {\n timeIterator = setInterval(processNextKey, throttle);\n }\n\n lastState = state;\n };\n\n function processNextKey() {\n if (keysToProcess.length === 0) {\n if (timeIterator) clearInterval(timeIterator);\n timeIterator = null;\n return;\n }\n\n var key = keysToProcess.shift();\n var endState = transforms.reduce(function (subState, transformer) {\n return transformer.in(subState, key, lastState);\n }, lastState[key]);\n\n if (endState !== undefined) {\n try {\n stagedState[key] = serialize(endState);\n } catch (err) {\n console.error('redux-persist/createPersistoid: error serializing state', err);\n }\n } else {\n //if the endState is undefined, no need to persist the existing serialized content\n delete stagedState[key];\n }\n\n if (keysToProcess.length === 0) {\n writeStagedState();\n }\n }\n\n function writeStagedState() {\n // cleanup any removed keys just before write.\n Object.keys(stagedState).forEach(function (key) {\n if (lastState[key] === undefined) {\n delete stagedState[key];\n }\n });\n writePromise = storage.setItem(storageKey, serialize(stagedState)).catch(onWriteFail);\n }\n\n function passWhitelistBlacklist(key) {\n if (whitelist && whitelist.indexOf(key) === -1 && key !== '_persist') return false;\n if (blacklist && blacklist.indexOf(key) !== -1) return false;\n return true;\n }\n\n function onWriteFail(err) {\n // @TODO add fail handlers (typically storage full)\n if (writeFailHandler) writeFailHandler(err);\n\n if (err && process.env.NODE_ENV !== 'production') {\n console.error('Error storing data', err);\n }\n }\n\n var flush = function flush() {\n while (keysToProcess.length !== 0) {\n processNextKey();\n }\n\n return writePromise || Promise.resolve();\n }; // return `persistoid`\n\n\n return {\n update: update,\n flush: flush\n };\n} // @NOTE in the future this may be exposed via config\n\nfunction defaultSerialize(data) {\n return JSON.stringify(data);\n}","import { KEY_PREFIX } from './constants';\nexport default function getStoredState(config) {\n var transforms = config.transforms || [];\n var storageKey = \"\".concat(config.keyPrefix !== undefined ? config.keyPrefix : KEY_PREFIX).concat(config.key);\n var storage = config.storage;\n var debug = config.debug;\n var deserialize;\n\n if (config.deserialize === false) {\n deserialize = function deserialize(x) {\n return x;\n };\n } else if (typeof config.deserialize === 'function') {\n deserialize = config.deserialize;\n } else {\n deserialize = defaultDeserialize;\n }\n\n return storage.getItem(storageKey).then(function (serialized) {\n if (!serialized) return undefined;else {\n try {\n var state = {};\n var rawState = deserialize(serialized);\n Object.keys(rawState).forEach(function (key) {\n state[key] = transforms.reduceRight(function (subState, transformer) {\n return transformer.out(subState, key, rawState);\n }, deserialize(rawState[key]));\n });\n return state;\n } catch (err) {\n if (process.env.NODE_ENV !== 'production' && debug) console.log(\"redux-persist/getStoredState: Error restoring data \".concat(serialized), err);\n throw err;\n }\n }\n });\n}\n\nfunction defaultDeserialize(serial) {\n return JSON.parse(serial);\n}","import { KEY_PREFIX } from './constants';\nexport default function purgeStoredState(config) {\n var storage = config.storage;\n var storageKey = \"\".concat(config.keyPrefix !== undefined ? config.keyPrefix : KEY_PREFIX).concat(config.key);\n return storage.removeItem(storageKey, warnIfRemoveError);\n}\n\nfunction warnIfRemoveError(err) {\n if (err && process.env.NODE_ENV !== 'production') {\n console.error('redux-persist/purgeStoredState: Error purging data stored state', err);\n }\n}","import { combineReducers } from 'redux';\nimport persistReducer from './persistReducer';\nimport autoMergeLevel2 from './stateReconciler/autoMergeLevel2';\n// combineReducers + persistReducer with stateReconciler defaulted to autoMergeLevel2\nexport default function persistCombineReducers(config, reducers) {\n config.stateReconciler = config.stateReconciler === undefined ? autoMergeLevel2 : config.stateReconciler;\n return persistReducer(config, combineReducers(reducers));\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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/*\n autoMergeLevel2: \n - merges 2 level of substate\n - skips substate if already modified\n - this is essentially redux-perist v4 behavior\n*/\nexport default function autoMergeLevel2(inboundState, originalState, reducedState, _ref) {\n var debug = _ref.debug;\n\n var newState = _objectSpread({}, reducedState); // only rehydrate if inboundState exists and is an object\n\n\n if (inboundState && _typeof(inboundState) === 'object') {\n Object.keys(inboundState).forEach(function (key) {\n // ignore _persist data\n if (key === '_persist') return; // if reducer modifies substate, skip auto rehydration\n\n if (originalState[key] !== reducedState[key]) {\n if (process.env.NODE_ENV !== 'production' && debug) console.log('redux-persist/stateReconciler: sub state for key `%s` modified, skipping.', key);\n return;\n }\n\n if (isPlainEnoughObject(reducedState[key])) {\n // if object is plain enough shallow merge the new values (hence \"Level2\")\n newState[key] = _objectSpread({}, newState[key], {}, inboundState[key]);\n return;\n } // otherwise hard set\n\n\n newState[key] = inboundState[key];\n });\n }\n\n if (process.env.NODE_ENV !== 'production' && debug && inboundState && _typeof(inboundState) === 'object') console.log(\"redux-persist/stateReconciler: rehydrated keys '\".concat(Object.keys(inboundState).join(', '), \"'\"));\n return newState;\n}\n\nfunction isPlainEnoughObject(o) {\n return o !== null && !Array.isArray(o) && _typeof(o) === 'object';\n}","function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance\"); }\n\nfunction _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nimport { createStore } from 'redux';\nimport { FLUSH, PAUSE, PERSIST, PURGE, REGISTER, REHYDRATE } from './constants';\nvar initialState = {\n registry: [],\n bootstrapped: false\n};\n\nvar persistorReducer = function persistorReducer() {\n var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;\n var action = arguments.length > 1 ? arguments[1] : undefined;\n\n switch (action.type) {\n case REGISTER:\n return _objectSpread({}, state, {\n registry: [].concat(_toConsumableArray(state.registry), [action.key])\n });\n\n case REHYDRATE:\n var firstIndex = state.registry.indexOf(action.key);\n\n var registry = _toConsumableArray(state.registry);\n\n registry.splice(firstIndex, 1);\n return _objectSpread({}, state, {\n registry: registry,\n bootstrapped: registry.length === 0\n });\n\n default:\n return state;\n }\n};\n\nexport default function persistStore(store, options, cb) {\n // help catch incorrect usage of passing PersistConfig in as PersistorOptions\n if (process.env.NODE_ENV !== 'production') {\n var optionsToTest = options || {};\n var bannedKeys = ['blacklist', 'whitelist', 'transforms', 'storage', 'keyPrefix', 'migrate'];\n bannedKeys.forEach(function (k) {\n if (!!optionsToTest[k]) console.error(\"redux-persist: invalid option passed to persistStore: \\\"\".concat(k, \"\\\". You may be incorrectly passing persistConfig into persistStore, whereas it should be passed into persistReducer.\"));\n });\n }\n\n var boostrappedCb = cb || false;\n\n var _pStore = createStore(persistorReducer, initialState, options && options.enhancer ? options.enhancer : undefined);\n\n var register = function register(key) {\n _pStore.dispatch({\n type: REGISTER,\n key: key\n });\n };\n\n var rehydrate = function rehydrate(key, payload, err) {\n var rehydrateAction = {\n type: REHYDRATE,\n payload: payload,\n err: err,\n key: key // dispatch to `store` to rehydrate and `persistor` to track result\n\n };\n store.dispatch(rehydrateAction);\n\n _pStore.dispatch(rehydrateAction);\n\n if (boostrappedCb && persistor.getState().bootstrapped) {\n boostrappedCb();\n boostrappedCb = false;\n }\n };\n\n var persistor = _objectSpread({}, _pStore, {\n purge: function purge() {\n var results = [];\n store.dispatch({\n type: PURGE,\n result: function result(purgeResult) {\n results.push(purgeResult);\n }\n });\n return Promise.all(results);\n },\n flush: function flush() {\n var results = [];\n store.dispatch({\n type: FLUSH,\n result: function result(flushResult) {\n results.push(flushResult);\n }\n });\n return Promise.all(results);\n },\n pause: function pause() {\n store.dispatch({\n type: PAUSE\n });\n },\n persist: function persist() {\n store.dispatch({\n type: PERSIST,\n register: register,\n rehydrate: rehydrate\n });\n }\n });\n\n if (!(options && options.manualPersist)) {\n persistor.persist();\n }\n\n return persistor;\n}","import { DEFAULT_VERSION } from './constants';\nexport default function createMigrate(migrations, config) {\n var _ref = config || {},\n debug = _ref.debug;\n\n return function (state, currentVersion) {\n if (!state) {\n if (process.env.NODE_ENV !== 'production' && debug) console.log('redux-persist: no inbound state, skipping migration');\n return Promise.resolve(undefined);\n }\n\n var inboundVersion = state._persist && state._persist.version !== undefined ? state._persist.version : DEFAULT_VERSION;\n\n if (inboundVersion === currentVersion) {\n if (process.env.NODE_ENV !== 'production' && debug) console.log('redux-persist: versions match, noop migration');\n return Promise.resolve(state);\n }\n\n if (inboundVersion > currentVersion) {\n if (process.env.NODE_ENV !== 'production') console.error('redux-persist: downgrading version is not supported');\n return Promise.resolve(state);\n }\n\n var migrationKeys = Object.keys(migrations).map(function (ver) {\n return parseInt(ver);\n }).filter(function (key) {\n return currentVersion >= key && key > inboundVersion;\n }).sort(function (a, b) {\n return a - b;\n });\n if (process.env.NODE_ENV !== 'production' && debug) console.log('redux-persist: migrationKeys', migrationKeys);\n\n try {\n var migratedState = migrationKeys.reduce(function (state, versionKey) {\n if (process.env.NODE_ENV !== 'production' && debug) console.log('redux-persist: running migration for versionKey', versionKey);\n return migrations[versionKey](state);\n }, state);\n return Promise.resolve(migratedState);\n } catch (err) {\n return Promise.reject(err);\n }\n };\n}","export default function createTransform( // @NOTE inbound: transform state coming from redux on its way to being serialized and stored\ninbound, // @NOTE outbound: transform state coming from storage, on its way to be rehydrated into redux\noutbound) {\n var config = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var whitelist = config.whitelist || null;\n var blacklist = config.blacklist || null;\n\n function whitelistBlacklistCheck(key) {\n if (whitelist && whitelist.indexOf(key) === -1) return true;\n if (blacklist && blacklist.indexOf(key) !== -1) return true;\n return false;\n }\n\n return {\n in: function _in(state, key, fullState) {\n return !whitelistBlacklistCheck(key) && inbound ? inbound(state, key, fullState) : state;\n },\n out: function out(state, key, fullState) {\n return !whitelistBlacklistCheck(key) && outbound ? outbound(state, key, fullState) : state;\n }\n };\n}","import AsyncStorage from \"./AsyncStorage\";\nexport { useAsyncStorage } from \"./hooks\";\nexport default AsyncStorage;\n//# sourceMappingURL=index.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nimport mergeOptions from \"merge-options\";\n\n// eslint-disable-next-line @typescript-eslint/ban-types\n\n// eslint-disable-next-line @typescript-eslint/ban-types\n\nconst merge = mergeOptions.bind({\n concatArrays: true,\n ignoreUndefined: true\n});\nfunction mergeLocalStorageItem(key, value) {\n const oldValue = window.localStorage.getItem(key);\n if (oldValue) {\n const oldObject = JSON.parse(oldValue);\n const newObject = JSON.parse(value);\n const nextValue = JSON.stringify(merge(oldObject, newObject));\n window.localStorage.setItem(key, nextValue);\n } else {\n window.localStorage.setItem(key, value);\n }\n}\nfunction createPromise(getValue, callback) {\n return new Promise((resolve, reject) => {\n try {\n const value = getValue();\n callback === null || callback === void 0 ? void 0 : callback(null, value);\n resolve(value);\n } catch (err) {\n callback === null || callback === void 0 ? void 0 : callback(err);\n reject(err);\n }\n });\n}\nfunction createPromiseAll(promises, callback, processResult) {\n return Promise.all(promises).then(result => {\n const value = (processResult === null || processResult === void 0 ? void 0 : processResult(result)) ?? null;\n callback === null || callback === void 0 ? void 0 : callback(null, value);\n return Promise.resolve(value);\n }, errors => {\n callback === null || callback === void 0 ? void 0 : callback(errors);\n return Promise.reject(errors);\n });\n}\nconst AsyncStorage = {\n /**\n * Fetches `key` value.\n */\n getItem: (key, callback) => {\n return createPromise(() => window.localStorage.getItem(key), callback);\n },\n /**\n * Sets `value` for `key`.\n */\n setItem: (key, value, callback) => {\n return createPromise(() => window.localStorage.setItem(key, value), callback);\n },\n /**\n * Removes a `key`\n */\n removeItem: (key, callback) => {\n return createPromise(() => window.localStorage.removeItem(key), callback);\n },\n /**\n * Merges existing value with input value, assuming they are stringified JSON.\n */\n mergeItem: (key, value, callback) => {\n return createPromise(() => mergeLocalStorageItem(key, value), callback);\n },\n /**\n * Erases *all* AsyncStorage for the domain.\n */\n clear: callback => {\n return createPromise(() => window.localStorage.clear(), callback);\n },\n /**\n * Gets *all* keys known to the app, for all callers, libraries, etc.\n */\n getAllKeys: callback => {\n return createPromise(() => {\n const numberOfKeys = window.localStorage.length;\n const keys = [];\n for (let i = 0; i < numberOfKeys; i += 1) {\n const key = window.localStorage.key(i) || \"\";\n keys.push(key);\n }\n return keys;\n }, callback);\n },\n /**\n * (stub) Flushes any pending requests using a single batch call to get the data.\n */\n flushGetRequests: () => undefined,\n /**\n * multiGet resolves to an array of key-value pair arrays that matches the\n * input format of multiSet.\n *\n * multiGet(['k1', 'k2']) -> [['k1', 'val1'], ['k2', 'val2']]\n */\n multiGet: (keys, callback) => {\n const promises = keys.map(key => AsyncStorage.getItem(key));\n const processResult = result => result.map((value, i) => [keys[i], value]);\n return createPromiseAll(promises, callback, processResult);\n },\n /**\n * Takes an array of key-value array pairs.\n * multiSet([['k1', 'val1'], ['k2', 'val2']])\n */\n multiSet: (keyValuePairs, callback) => {\n const promises = keyValuePairs.map(item => AsyncStorage.setItem(item[0], item[1]));\n return createPromiseAll(promises, callback);\n },\n /**\n * Delete all the keys in the `keys` array.\n */\n multiRemove: (keys, callback) => {\n const promises = keys.map(key => AsyncStorage.removeItem(key));\n return createPromiseAll(promises, callback);\n },\n /**\n * Takes an array of key-value array pairs and merges them with existing\n * values, assuming they are stringified JSON.\n *\n * multiMerge([['k1', 'val1'], ['k2', 'val2']])\n */\n multiMerge: (keyValuePairs, callback) => {\n const promises = keyValuePairs.map(item => AsyncStorage.mergeItem(item[0], item[1]));\n return createPromiseAll(promises, callback);\n }\n};\nexport default AsyncStorage;\n//# sourceMappingURL=AsyncStorage.js.map","'use strict';\nconst isOptionObject = require('is-plain-obj');\n\nconst {hasOwnProperty} = Object.prototype;\nconst {propertyIsEnumerable} = Object;\nconst defineProperty = (object, name, value) => Object.defineProperty(object, name, {\n\tvalue,\n\twritable: true,\n\tenumerable: true,\n\tconfigurable: true\n});\n\nconst globalThis = this;\nconst defaultMergeOptions = {\n\tconcatArrays: false,\n\tignoreUndefined: false\n};\n\nconst getEnumerableOwnPropertyKeys = value => {\n\tconst keys = [];\n\n\tfor (const key in value) {\n\t\tif (hasOwnProperty.call(value, key)) {\n\t\t\tkeys.push(key);\n\t\t}\n\t}\n\n\t/* istanbul ignore else */\n\tif (Object.getOwnPropertySymbols) {\n\t\tconst symbols = Object.getOwnPropertySymbols(value);\n\n\t\tfor (const symbol of symbols) {\n\t\t\tif (propertyIsEnumerable.call(value, symbol)) {\n\t\t\t\tkeys.push(symbol);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn keys;\n};\n\nfunction clone(value) {\n\tif (Array.isArray(value)) {\n\t\treturn cloneArray(value);\n\t}\n\n\tif (isOptionObject(value)) {\n\t\treturn cloneOptionObject(value);\n\t}\n\n\treturn value;\n}\n\nfunction cloneArray(array) {\n\tconst result = array.slice(0, 0);\n\n\tgetEnumerableOwnPropertyKeys(array).forEach(key => {\n\t\tdefineProperty(result, key, clone(array[key]));\n\t});\n\n\treturn result;\n}\n\nfunction cloneOptionObject(object) {\n\tconst result = Object.getPrototypeOf(object) === null ? Object.create(null) : {};\n\n\tgetEnumerableOwnPropertyKeys(object).forEach(key => {\n\t\tdefineProperty(result, key, clone(object[key]));\n\t});\n\n\treturn result;\n}\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {string[]} keys keys to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n */\nconst mergeKeys = (merged, source, keys, config) => {\n\tkeys.forEach(key => {\n\t\tif (typeof source[key] === 'undefined' && config.ignoreUndefined) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Do not recurse into prototype chain of merged\n\t\tif (key in merged && merged[key] !== Object.getPrototypeOf(merged)) {\n\t\t\tdefineProperty(merged, key, merge(merged[key], source[key], config));\n\t\t} else {\n\t\t\tdefineProperty(merged, key, clone(source[key]));\n\t\t}\n\t});\n\n\treturn merged;\n};\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n *\n * see [Array.prototype.concat ( ...arguments )](http://www.ecma-international.org/ecma-262/6.0/#sec-array.prototype.concat)\n */\nconst concatArrays = (merged, source, config) => {\n\tlet result = merged.slice(0, 0);\n\tlet resultIndex = 0;\n\n\t[merged, source].forEach(array => {\n\t\tconst indices = [];\n\n\t\t// `result.concat(array)` with cloning\n\t\tfor (let k = 0; k < array.length; k++) {\n\t\t\tif (!hasOwnProperty.call(array, k)) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tindices.push(String(k));\n\n\t\t\tif (array === merged) {\n\t\t\t\t// Already cloned\n\t\t\t\tdefineProperty(result, resultIndex++, array[k]);\n\t\t\t} else {\n\t\t\t\tdefineProperty(result, resultIndex++, clone(array[k]));\n\t\t\t}\n\t\t}\n\n\t\t// Merge non-index keys\n\t\tresult = mergeKeys(result, array, getEnumerableOwnPropertyKeys(array).filter(key => !indices.includes(key)), config);\n\t});\n\n\treturn result;\n};\n\n/**\n * @param {*} merged already cloned\n * @param {*} source something to merge\n * @param {Object} config Config Object\n * @returns {*} cloned Object\n */\nfunction merge(merged, source, config) {\n\tif (config.concatArrays && Array.isArray(merged) && Array.isArray(source)) {\n\t\treturn concatArrays(merged, source, config);\n\t}\n\n\tif (!isOptionObject(source) || !isOptionObject(merged)) {\n\t\treturn clone(source);\n\t}\n\n\treturn mergeKeys(merged, source, getEnumerableOwnPropertyKeys(source), config);\n}\n\nmodule.exports = function (...options) {\n\tconst config = merge(clone(defaultMergeOptions), (this !== globalThis && this) || {}, defaultMergeOptions);\n\tlet merged = {_: {}};\n\n\tfor (const option of options) {\n\t\tif (option === undefined) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (!isOptionObject(option)) {\n\t\t\tthrow new TypeError('`' + option + '` is not an Option Object');\n\t\t}\n\n\t\tmerged = merge(merged, {_: option}, config);\n\t}\n\n\treturn merged._;\n};\n","'use strict';\n\nmodule.exports = value => {\n\tif (Object.prototype.toString.call(value) !== '[object Object]') {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value);\n\treturn prototype === null || prototype === Object.prototype;\n};\n","import AsyncStorage from \"./AsyncStorage\";\nexport function useAsyncStorage(key) {\n return {\n getItem: (...args) => AsyncStorage.getItem(key, ...args),\n setItem: (...args) => AsyncStorage.setItem(key, ...args),\n mergeItem: (...args) => AsyncStorage.mergeItem(key, ...args),\n removeItem: (...args) => AsyncStorage.removeItem(key, ...args)\n };\n}\n//# sourceMappingURL=hooks.js.map","\"use strict\";\n\nexports.__esModule = true;\nexports.default = autoMergeLevel2;\n\nfunction _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 ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/*\n autoMergeLevel2: \n - merges 2 level of substate\n - skips substate if already modified\n - this is essentially redux-perist v4 behavior\n*/\nfunction autoMergeLevel2(inboundState, originalState, reducedState, _ref) {\n var debug = _ref.debug;\n\n var newState = _objectSpread({}, reducedState); // only rehydrate if inboundState exists and is an object\n\n\n if (inboundState && _typeof(inboundState) === 'object') {\n Object.keys(inboundState).forEach(function (key) {\n // ignore _persist data\n if (key === '_persist') return; // if reducer modifies substate, skip auto rehydration\n\n if (originalState[key] !== reducedState[key]) {\n if (process.env.NODE_ENV !== 'production' && debug) console.log('redux-persist/stateReconciler: sub state for key `%s` modified, skipping.', key);\n return;\n }\n\n if (isPlainEnoughObject(reducedState[key])) {\n // if object is plain enough shallow merge the new values (hence \"Level2\")\n newState[key] = _objectSpread({}, newState[key], {}, inboundState[key]);\n return;\n } // otherwise hard set\n\n\n newState[key] = inboundState[key];\n });\n }\n\n if (process.env.NODE_ENV !== 'production' && debug && inboundState && _typeof(inboundState) === 'object') console.log(\"redux-persist/stateReconciler: rehydrated keys '\".concat(Object.keys(inboundState).join(', '), \"'\"));\n return newState;\n}\n\nfunction isPlainEnoughObject(o) {\n return o !== null && !Array.isArray(o) && _typeof(o) === 'object';\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.PersistGate = void 0;\n\nvar _react = _interopRequireWildcard(require(\"react\"));\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }\n\nfunction _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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar PersistGate =\n/*#__PURE__*/\nfunction (_PureComponent) {\n _inherits(PersistGate, _PureComponent);\n\n function PersistGate() {\n var _getPrototypeOf2;\n\n var _this;\n\n _classCallCheck(this, PersistGate);\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _possibleConstructorReturn(this, (_getPrototypeOf2 = _getPrototypeOf(PersistGate)).call.apply(_getPrototypeOf2, [this].concat(args)));\n\n _defineProperty(_assertThisInitialized(_this), \"state\", {\n bootstrapped: false\n });\n\n _defineProperty(_assertThisInitialized(_this), \"_unsubscribe\", void 0);\n\n _defineProperty(_assertThisInitialized(_this), \"handlePersistorState\", function () {\n var persistor = _this.props.persistor;\n\n var _persistor$getState = persistor.getState(),\n bootstrapped = _persistor$getState.bootstrapped;\n\n if (bootstrapped) {\n if (_this.props.onBeforeLift) {\n Promise.resolve(_this.props.onBeforeLift()).finally(function () {\n return _this.setState({\n bootstrapped: true\n });\n });\n } else {\n _this.setState({\n bootstrapped: true\n });\n }\n\n _this._unsubscribe && _this._unsubscribe();\n }\n });\n\n return _this;\n }\n\n _createClass(PersistGate, [{\n key: \"componentDidMount\",\n value: function componentDidMount() {\n this._unsubscribe = this.props.persistor.subscribe(this.handlePersistorState);\n this.handlePersistorState();\n }\n }, {\n key: \"componentWillUnmount\",\n value: function componentWillUnmount() {\n this._unsubscribe && this._unsubscribe();\n }\n }, {\n key: \"render\",\n value: function render() {\n if (process.env.NODE_ENV !== 'production') {\n if (typeof this.props.children === 'function' && this.props.loading) console.error('redux-persist: PersistGate expects either a function child or loading prop, but not both. The loading prop will be ignored.');\n }\n\n if (typeof this.props.children === 'function') {\n return this.props.children(this.state.bootstrapped);\n }\n\n return this.state.bootstrapped ? this.props.children : this.props.loading;\n }\n }]);\n\n return PersistGate;\n}(_react.PureComponent);\n\nexports.PersistGate = PersistGate;\n\n_defineProperty(PersistGate, \"defaultProps\", {\n children: null,\n loading: null\n});","import DeepLinking from \"@common/utils/DeepLinking\"\nimport {\n apiIdle,\n apiRequest,\n apiRequestWithPrerequest,\n} from \"@data/redux/actions/api\"\nimport { AbilityContext } from \"@data/utility/Can\"\nimport { createStackNavigator } from \"@react-navigation/stack\"\nimport axios from \"axios\"\nimport * as Linking from \"expo-linking\"\nimport React, { useContext, useEffect, useRef } from \"react\"\nimport { Platform } from \"react-native\"\nimport { connect } from \"react-redux\"\nimport NotFound from \"../../auth/NotFound\"\nimport Unauthorized from \"../../auth/Unauthorized\"\nimport {\n ChampionBottomSheetModal,\n ChampionModalContext,\n} from \"../../student/champions/ChampionBottomSheetModal\"\nimport Header from \"../header/Header\"\nimport { theme } from \"../theme/theme\"\nimport { navigationScreens } from \"./navigationScreens\"\n\nconst Stack = createStackNavigator()\n\nconst RootNavigator = (props) => {\n //** ComponentDidMount\n useEffect(() => {\n if (props.token) {\n axios.defaults.headers.common[\"Authorization\"] =\n \"Bearer \" + props.token\n }\n }, [props.token])\n\n const ability = useContext(AbilityContext)\n\n const championModalRef = useRef()\n\n const unauthorized = (title, name) => {\n return {\n name: name,\n component: Unauthorized,\n options: {\n headerShown: false,\n headerTitle: \"Non autorisé\",\n },\n titles: [{ auth: {} }, { main: {} }, { live: {} }]?.filter(\n (t) => !Object.keys(t)?.includes(title)\n ),\n }\n }\n const renderNavigationScreens = (ns, title) =>\n ns.map((screen) => (\n \n Object.keys(t)?.includes(title)\n )?.[title]?.component\n ? screen.titles?.find((t) =>\n Object.keys(t).includes(title)\n )?.[title]?.component\n : screen?.component\n }\n options={\n screen.titles?.find((t) =>\n Object.keys(t).includes(title)\n )?.[title]?.options\n ? screen.titles?.find((t) =>\n Object.keys(t).includes(title)\n )?.[title]?.options\n : typeof screen.options === \"function\"\n ? screen.options\n : {\n headerTitle: screen.name,\n ...screen.options,\n }\n }\n />\n ))\n const renderNavigator = () => (\n {\n return (\n \n )\n },\n gestureEnabled: false,\n cardStyle: {\n backgroundColor: theme.colors.whiteAlmost,\n flex: 1,\n },\n }}\n >\n {props.token ? (\n /*\n !props?.user?.is_verified ?\n <>\n {/!*** Email validation screens*!/}\n {renderNavigationScreens(navigationScreens.main.filter((screen) => screen?.titles?.includes(\"emailValidation\")), \"emailValidation\")}\n \n : (hasRole(props.user, \"student\") && (\n !props?.user?.onboarding_viewed_at && !ability.can('read', 'premium_icon') && !ability.can('read', 'plus_icon')\n )) ?\n <>\n {/!*** Student onboarding screens*!/}\n {renderNavigationScreens(navigationScreens.main.filter((screen) => screen?.titles?.includes(\"studentOnboarding\")), \"studentOnboarding\")}\n : (hasRole(props.user, \"student\") && !props.user?.champion_intros_viewed_at?.zoe) ?\n <>\n {renderNavigationScreens(navigationScreens.main.filter((screen) => screen?.titles?.includes(\"studentFirstChallenge\")), \"studentFirstChallenge\")}\n :*/\n props.isLiveMode ? (\n <>\n {/*** Live Mode screens*/}\n {renderNavigationScreens(\n navigationScreens.main.filter((screen) =>\n screen?.titles?.find((t) =>\n Object.keys(t)?.includes(\"live\")\n )\n ),\n \"live\"\n )}\n \n ) : (\n <>\n {/*** Main screens*/}\n {/*{renderNavigationScreens(navigationScreens.main)}*/}\n {renderNavigationScreens(\n navigationScreens.main.filter((screen) =>\n screen?.titles?.find((t) =>\n Object.keys(t)?.includes(\"main\")\n )\n ),\n \"main\"\n )}\n \n )\n ) : (\n <>\n {/*** Auth screens*/}\n {renderNavigationScreens(\n navigationScreens.main.filter((screen) =>\n screen?.titles?.find((t) =>\n Object.keys(t)?.includes(\"auth\")\n )\n ),\n \"auth\"\n )}\n \n )}\n \n {/* */}\n \n )\n const prefix = Linking.createURL(\"/\")\n return (\n <>\n {Platform.OS !== \"web\" ? (\n \n {renderNavigator()}\n \n ) : (\n <>\n \n {renderNavigator()}\n \n )}\n\n {Platform.OS !== \"web\" && (\n \n )}\n \n )\n}\n\nconst mapStateToProps = (state) => {\n return {\n networkOn: state.api?.networkOn,\n token: state.data.session?.object?.token,\n url: state.data.session?.initialUrl,\n user: state.data.currentUser?.object,\n isLiveMode: state.liveMode.isLiveModeEnabled,\n }\n}\n\nconst mapDispatchToProps = {\n apiRequest,\n apiRequestWithPrerequest,\n apiIdle,\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps)(RootNavigator)\n","import {useEffect} from 'react';\nimport {apiIdle, apiRequest, apiRequestWithPrerequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\nimport * as Linking from \"expo-linking\";\nimport {IS_WEB, isMobile} from \"@common/utils/mobileUtils\";\nimport {navigationScreens} from \"@common/navigation/navigationScreens\";\nimport {URL} from \"react-native-url-polyfill\";\nimport * as StoreReview from \"expo-store-review\";\nimport Constants from \"expo-constants\";\n\nfunction DeepLinking(props) {\n\n const {prefix} = props\n const handleUrl = async () => {\n let initialUrl\n await Linking.getInitialURL().then((url) => initialUrl = url)\n return \"masteur:///\" + initialUrl?.substring(prefix.length)\n }\n\n const openStore = () => {\n DialogM.show({\n text1: \"L'application n'est pas installée\",\n text2: \"Télécharger l'application ?\",\n buttonText1: 'Télécharger', // buttonColor1: theme.colors.error,\n onPress: () => {\n if (navigator.userAgent.toLowerCase().includes(\"android\")) {\n window.location = props.androidAppUrl ?? Constants.expoConfig.android.playStoreUrl\n } else {\n window.location = props.iosAppUrl ?? Constants.expoConfig.ios.appStoreUrl\n }\n },\n buttonText2: 'Pas maintenant',\n onPressBack: () => {\n }\n })\n }\n\n useEffect(() => {\n if (isMobile() && IS_WEB) {\n let now = new Date().valueOf();\n handleUrl().then((url) => {\n if (new Date().valueOf() - now > 100) return;\n //const deepLink = Object.keys(deepLinks).find((d) => url.includes(d))\n const urlObject = new URL(url)\n const urlPath = urlObject.pathname.slice(1)\n const deepLink = navigationScreens.main?.find((d) => urlPath === d.name) //TODO Warning : to be improved\n if (deepLink && deepLink?.deepLinkConfig?.platform === \"web&mobile\") {\n window.location = url\n window.onfocus = function () {\n DialogM.hide()\n }\n if (deepLink?.deepLinkConfig.downloadBanner) {\n setTimeout(function () {\n openStore()\n }, 2000)\n // setTimeout(openStore, 100);\n } else if (deepLink?.deepLinkConfig.downloadRequired) {\n /* setTimeout(function () {\n window.location = StoreReview.storeUrl()\n }, 100);*/\n }\n }\n })\n }\n\n }, [])\n\n}\n\nconst mapStateToProps = state => {\n return {\n registered: state.api.registerAndGetSanctumToken?.success,\n registering: state.api.registerAndGetSanctumToken?.request,\n error: state.api.registerAndGetSanctumToken?.error,\n\n getSchoolSubjectsRequest: state.api.getSchoolSubjects?.request,\n getSchoolSubjectsSuccess: state.api.getSchoolSubjects?.success,\n getSchoolSubjectsError: state.api.getSchoolSubjects?.error,\n\n schoolSubjects: state.data.staticData?.school_subjects,\n\n androidAppUrl: state.data.staticData?.android_app_url,\n iosAppUrl: state.data.staticData?.ios_app_url,\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiRequestWithPrerequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(DeepLinking)","import {API_URL, apiConstants, VAPOR_FILE_UPLOAD} from \"../../../constants/apiConstants\"\nimport {authService} from \"../../../services/authService\"\nimport {authConstants} from \"../../../constants/authConstants\";\nimport axios from \"axios\";\nimport {vaporStore} from \"../../../services\";\nimport NetInfo from \"@react-native-community/netinfo\";\nimport {store} from \"../../storeConfig/store\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\nimport {notifyBugsnag} from \"@common/utils/initBugsnag\";\n\nexport function setNetworkOn() {\n return {type: apiConstants.NETWORK_ON}\n}\n\nexport function setNetworkOff() {\n return {type: apiConstants.NETWORK_OFF}\n}\n\nexport function apiIdle(serviceFunction, data = {}) {\n return {type: serviceFunction.name + apiConstants._IDLE}\n}\n\n// Action API call\nexport function apiRequest(serviceFunction, routeParams = {}, data = {}, urlParams = {}, onUploadProgress = null) {\n\n // console.log('apiRequest', serviceFunction?.name)\n function request() {\n return {type: serviceFunction.name + apiConstants._REQUEST, routeParams, data, urlParams}\n }\n\n function success(responseData) {\n return {\n type: serviceFunction.name + apiConstants._SUCCESS,\n routeParams,\n data: responseData.data,\n all_data: responseData,\n urlParams\n }\n }\n\n function failure(error) {\n return {type: serviceFunction.name + apiConstants._FAILURE, routeParams, error, urlParams}\n }\n\n const dispatchRequestIfInternet = (dispatch) => {\n\n const token = store.getState()?.data?.session?.object?.token\n if (token) axios.defaults.headers.common['Authorization'] = \"Bearer \" + token;\n\n NetInfo.fetch().then(state => {\n // console.log('API : Connection type', state.type);\n // console.log('API : Is connected?', state.isConnected);\n\n if (state.isConnected) {\n dispatch(request())\n\n serviceFunction(routeParams, data, urlParams, onUploadProgress)\n .then(response => {\n // console.log('success dispatched : ', response)\n dispatch(success(response.data))\n }\n )\n .catch(error => {\n console.error('failure dispatched : ', error)\n\n if (!error?.response) {\n notifyBugsnag(error)\n }\n\n dispatch(failure(error?.response?.data))\n\n if (error?.response && error?.response?.status === 401) {\n dispatch({type: authConstants.LOGOUT_401})\n // return Promise.reject()\n }\n\n })\n } else {\n DialogM.show({\n text1: \"Pas de connexion Internet\",\n text2: '',\n buttonText1: 'Réessayer',\n onPress: () => {\n dispatchRequestIfInternet(dispatch)\n },\n buttonText2: 'Annuler'\n })\n /*alertPolyfill(\"Pas de connexion Internet\", \"\", [\n {\n text: 'Annuler',\n onPress: () => {\n },\n style: 'cancel'\n },\n {\n text: 'Réessayer',\n onPress: () => {\n dispatchRequestIfInternet(dispatch)\n },\n style: 'cancel'\n }\n ])*/\n }\n });\n }\n\n\n return dispatch => {\n // console.log('request dispatched : ', routeParams, data, urlParams)\n dispatchRequestIfInternet(dispatch)\n\n }\n}\n\nexport function vaporFileUploadIdle() {\n return {type: VAPOR_FILE_UPLOAD + apiConstants._IDLE}\n}\n\n// Action API call upload file to vapor s3\nexport function vaporFileUpload(file, options = {}, formId) {\n\n function request() {\n return {type: VAPOR_FILE_UPLOAD + apiConstants._REQUEST, file, formId}\n }\n\n function success(response) {\n return {type: VAPOR_FILE_UPLOAD + apiConstants._SUCCESS, response, file, formId}\n }\n\n function failure(error) {\n return {type: VAPOR_FILE_UPLOAD + apiConstants._FAILURE, error, file, formId}\n }\n\n const dispatchRequestIfInternet = (dispatch) => {\n\n\n NetInfo.fetch().then(state => {\n // console.log('API : Connection type', state.type);\n // console.log('API : Is connected?', state.isConnected);\n\n if (state.isConnected) {\n dispatch(request())\n\n vaporStore(file, {\n ...options,\n baseURL: API_URL\n })\n .then(response => {\n // console.log('success dispatched : ', response)\n dispatch(success(response))\n })\n .catch(error => {\n // console.error('failure dispatched : ', error)\n\n dispatch(failure(error))\n })\n\n } else {\n DialogM.show({\n text1: 'Pas de connexion Internet',\n text2: '',\n buttonText1: 'Réessayer',\n onPress: () => {\n dispatchRequestIfInternet(dispatch)\n },\n buttonText2: 'Annuler'\n // onPressBack: resetSelection\n })\n }\n })\n }\n\n\n return dispatch => {\n // console.log('request dispatched : ', routeParams, data, urlParams)\n // dispatch(request())\n\n dispatchRequestIfInternet(dispatch)\n\n }\n}\n\n// Action API call\nexport function apiRequestWithPrerequest(serviceFunction, routeParams = {}, data = {}, urlParams = {}, onUploadProgress = null) {\n\n function request() {\n return {type: serviceFunction.name + apiConstants._REQUEST, routeParams, data, urlParams}\n }\n\n function success(data) {\n return {type: serviceFunction.name + apiConstants._SUCCESS, data}\n }\n\n function failure(error) {\n return {type: serviceFunction.name + apiConstants._FAILURE, error}\n }\n\n return dispatch => {\n // console.log('request dispatched')\n dispatch(request())\n\n authService.getCsrfToken()\n .then(() => {\n\n serviceFunction(routeParams, data, urlParams, onUploadProgress)\n .then(response => {\n // console.log('success dispatched')\n dispatch(success(response.data.data))\n }\n )\n .catch(error => {\n console.error('failure dispatched : ', error)\n if (!error?.response) {\n notifyBugsnag(error)\n }\n\n dispatch(failure(error?.response?.data))\n })\n\n }).catch(error => {\n console.error('failure dispatched : ', error)\n if (!error?.response) {\n notifyBugsnag(error)\n }\n\n dispatch(failure(error?.response?.data))\n }\n )\n }\n}\n","/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n */\nimport { useState, useEffect, useCallback } from 'react';\nimport { Platform } from 'react-native';\nimport DEFAULT_CONFIGURATION from './internal/defaultConfiguration';\nimport NativeInterface from './internal/nativeInterface';\nimport State from './internal/state';\nimport * as Types from './internal/types'; // Stores the currently used configuration\n\nlet _configuration = DEFAULT_CONFIGURATION; // Stores the singleton reference to the state manager\n\nlet _state = null;\n\nconst createState = () => {\n return new State(_configuration);\n};\n/**\n * Configures the library with the given configuration. Note that calling this will stop all\n * previously added listeners from being called again. It is best to call this right when your\n * application is started to avoid issues. The configuration sets up a global singleton instance.\n *\n * @param configuration The new configuration to set.\n */\n\n\nexport function configure(configuration) {\n _configuration = { ...DEFAULT_CONFIGURATION,\n ...configuration\n };\n\n if (_state) {\n _state.tearDown();\n\n _state = createState();\n }\n\n if (Platform.OS === 'ios') {\n NativeInterface.configure(configuration);\n }\n}\n/**\n * Returns a `Promise` that resolves to a `NetInfoState` object.\n * This function operates on the global singleton instance configured using `configure()`\n *\n * @param [requestedInterface] interface from which to obtain the information\n *\n * @returns A Promise which contains the current connection state.\n */\n\nexport function fetch(requestedInterface) {\n if (!_state) {\n _state = createState();\n }\n\n return _state.latest(requestedInterface);\n}\n/**\n * Force-refreshes the internal state of the global singleton managed by this library.\n *\n * @returns A Promise which contains the updated connection state.\n */\n\nexport function refresh() {\n if (!_state) {\n _state = createState();\n }\n\n return _state._fetchCurrentState();\n}\n/**\n * Subscribe to the global singleton's connection information. The callback is called with a parameter of type\n * [`NetInfoState`](README.md#netinfostate) whenever the connection state changes. Your listener\n * will be called with the latest information soon after you subscribe and then with any\n * subsequent changes afterwards. You should not assume that the listener is called in the same\n * way across devices or platforms.\n *\n * @param listener The listener which is called when the network state changes.\n *\n * @returns A function which can be called to unsubscribe.\n */\n\nexport function addEventListener(listener) {\n if (!_state) {\n _state = createState();\n }\n\n _state.add(listener);\n\n return () => {\n _state && _state.remove(listener);\n };\n}\n/**\n * A React Hook into this library's singleton which updates when the connection state changes.\n *\n * @param {Partial} configuration - Configure the isolated network checker managed by this hook\n *\n * @returns The connection state.\n */\n\nexport function useNetInfo(configuration) {\n if (configuration) {\n configure(configuration);\n }\n\n const [netInfo, setNetInfo] = useState({\n type: Types.NetInfoStateType.unknown,\n isConnected: null,\n isInternetReachable: null,\n details: null\n });\n useEffect(() => {\n return addEventListener(setNetInfo);\n }, []);\n return netInfo;\n}\n/**\n * A React Hook which manages an isolated instance of the network info manager.\n * This is not a hook into a singleton shared state. NetInfo.configure, NetInfo.addEventListener,\n * NetInfo.fetch, NetInfo.refresh are performed on a global singleton and have no affect on this hook.\n * @param {boolean} isPaused - Pause the internal network checks.\n * @param {Partial} configuration - Configure the isolated network checker managed by this hook\n *\n * @returns the netInfo state and a refresh function\n */\n\nexport function useNetInfoInstance(isPaused = false, configuration) {\n const [networkInfoManager, setNetworkInfoManager] = useState();\n const [netInfo, setNetInfo] = useState({\n type: Types.NetInfoStateType.unknown,\n isConnected: null,\n isInternetReachable: null,\n details: null\n });\n useEffect(() => {\n if (isPaused) {\n return;\n }\n\n const config = { ...DEFAULT_CONFIGURATION,\n ...configuration\n };\n const state = new State(config);\n setNetworkInfoManager(state);\n state.add(setNetInfo);\n return state.tearDown;\n }, [isPaused, configuration]);\n const refresh = useCallback(() => {\n networkInfoManager && networkInfoManager._fetchCurrentState();\n }, [networkInfoManager]);\n return {\n netInfo,\n refresh\n };\n}\nexport * from './internal/types';\nexport default {\n configure,\n fetch,\n refresh,\n addEventListener,\n useNetInfo,\n useNetInfoInstance\n};\n//# sourceMappingURL=index.js.map","const DEFAULT_CONFIGURATION = {\n reachabilityUrl: '/',\n reachabilityMethod: \"HEAD\",\n reachabilityHeaders: {},\n reachabilityTest: response => Promise.resolve(response.status === 200),\n reachabilityShortTimeout: 5 * 1000,\n // 5s\n reachabilityLongTimeout: 60 * 1000,\n // 60s\n reachabilityRequestTimeout: 15 * 1000,\n // 15s\n reachabilityShouldRun: () => true,\n shouldFetchWiFiSSID: true,\n useNativeReachability: true\n};\nexport default DEFAULT_CONFIGURATION;\n//# sourceMappingURL=defaultConfiguration.web.js.map","/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n */\nimport { NativeEventEmitter } from 'react-native';\nimport RNCNetInfo from './nativeModule';\nimport { DEVICE_CONNECTIVITY_EVENT } from './privateTypes';\nconst nativeEventEmitter = new NativeEventEmitter(); // Listen to connectivity events\n\nRNCNetInfo.addListener(DEVICE_CONNECTIVITY_EVENT, event => {\n nativeEventEmitter.emit(DEVICE_CONNECTIVITY_EVENT, event);\n});\nexport default { ...RNCNetInfo,\n eventEmitter: nativeEventEmitter\n};\n//# sourceMappingURL=nativeInterface.web.js.map","/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n */\nimport { DEVICE_CONNECTIVITY_EVENT } from './privateTypes';\nimport { NetInfoCellularGeneration, NetInfoStateType } from './types'; // See https://wicg.github.io/netinfo/#dom-connectiontype\n\n// Use a constant test of this form because in SSR on next.js, optional chaining is not sufficient,\n// but this test correctly detects that window is not available and allows for conditionals before access\nconst isWindowPresent = typeof window !== 'undefined'; // Check if window exists and if the browser supports the connection API\n\nconst connection = isWindowPresent && !window.hasOwnProperty('tizen') && !window.hasOwnProperty('webOS') ? window.navigator.connection || window.navigator.mozConnection || window.navigator.webkitConnection : undefined; // Map browser types to native types\n\nconst typeMapping = {\n bluetooth: NetInfoStateType.bluetooth,\n cellular: NetInfoStateType.cellular,\n ethernet: NetInfoStateType.ethernet,\n none: NetInfoStateType.none,\n other: NetInfoStateType.other,\n unknown: NetInfoStateType.unknown,\n wifi: NetInfoStateType.wifi,\n wimax: NetInfoStateType.wimax,\n mixed: NetInfoStateType.other\n};\nconst effectiveTypeMapping = {\n '2g': NetInfoCellularGeneration['2g'],\n '3g': NetInfoCellularGeneration['3g'],\n '4g': NetInfoCellularGeneration['4g'],\n 'slow-2g': NetInfoCellularGeneration['2g']\n}; // Determine current state of connection\n\nconst getCurrentState = _requestedInterface => {\n const isConnected = isWindowPresent ? navigator.onLine : false;\n const baseState = {\n isInternetReachable: null\n }; // If we don't have a connection object, we return minimal information\n\n if (!connection) {\n if (isConnected) {\n const state = { ...baseState,\n isConnected: true,\n type: NetInfoStateType.other,\n details: {\n isConnectionExpensive: false\n }\n };\n return state;\n }\n\n const state = { ...baseState,\n isConnected: false,\n isInternetReachable: false,\n type: NetInfoStateType.none,\n details: null\n };\n return state;\n } // Otherwise try to return detailed information\n\n\n const isConnectionExpensive = connection.saveData;\n const type = connection.type ? typeMapping[connection.type] : isConnected ? NetInfoStateType.other : NetInfoStateType.unknown;\n\n if (type === NetInfoStateType.bluetooth) {\n const state = { ...baseState,\n isConnected: true,\n type,\n details: {\n isConnectionExpensive\n }\n };\n return state;\n } else if (type === NetInfoStateType.cellular) {\n const state = { ...baseState,\n isConnected: true,\n type,\n details: {\n isConnectionExpensive,\n cellularGeneration: effectiveTypeMapping[connection.effectiveType] || null,\n carrier: null\n }\n };\n return state;\n } else if (type === NetInfoStateType.ethernet) {\n const state = { ...baseState,\n isConnected: true,\n type,\n details: {\n isConnectionExpensive,\n ipAddress: null,\n subnet: null\n }\n };\n return state;\n } else if (type === NetInfoStateType.wifi) {\n const state = { ...baseState,\n isConnected: true,\n type,\n details: {\n isConnectionExpensive,\n ssid: null,\n bssid: null,\n strength: null,\n ipAddress: null,\n subnet: null,\n frequency: null,\n linkSpeed: null,\n rxLinkSpeed: null,\n txLinkSpeed: null\n }\n };\n return state;\n } else if (type === NetInfoStateType.wimax) {\n const state = { ...baseState,\n isConnected: true,\n type,\n details: {\n isConnectionExpensive\n }\n };\n return state;\n } else if (type === NetInfoStateType.none) {\n const state = { ...baseState,\n isConnected: false,\n isInternetReachable: false,\n type,\n details: null\n };\n return state;\n } else if (type === NetInfoStateType.unknown) {\n const state = { ...baseState,\n isConnected,\n isInternetReachable: null,\n type,\n details: null\n };\n return state;\n }\n\n const state = { ...baseState,\n isConnected: true,\n type: NetInfoStateType.other,\n details: {\n isConnectionExpensive\n }\n };\n return state;\n};\n\nconst handlers = [];\nconst nativeHandlers = [];\nconst RNCNetInfo = {\n addListener(type, handler) {\n switch (type) {\n case DEVICE_CONNECTIVITY_EVENT:\n {\n const nativeHandler = () => {\n handler(getCurrentState());\n };\n\n if (connection) {\n connection.addEventListener('change', nativeHandler);\n } else {\n if (isWindowPresent) {\n window.addEventListener('online', nativeHandler, false);\n window.addEventListener('offline', nativeHandler, false);\n }\n } // Remember handlers\n\n\n handlers.push(handler);\n nativeHandlers.push(nativeHandler);\n break;\n }\n }\n },\n\n removeListeners(type, handler) {\n switch (type) {\n case DEVICE_CONNECTIVITY_EVENT:\n {\n // Get native handler\n const index = handlers.indexOf(handler);\n const nativeHandler = nativeHandlers[index];\n\n if (connection) {\n connection.removeEventListener('change', nativeHandler);\n } else {\n if (isWindowPresent) {\n window.removeEventListener('online', nativeHandler);\n window.removeEventListener('offline', nativeHandler);\n }\n } // Remove handlers\n\n\n handlers.splice(index, 1);\n nativeHandlers.splice(index, 1);\n break;\n }\n }\n },\n\n async getCurrentState(requestedInterface) {\n return getCurrentState(requestedInterface);\n },\n\n configure() {\n return;\n }\n\n};\nexport default RNCNetInfo;\n//# sourceMappingURL=nativeModule.web.js.map","/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n */\nexport const DEVICE_CONNECTIVITY_EVENT = 'netInfo.networkStatusDidChange'; // Certain properties are optional when sent by the native module and are handled by the JS code\n//# sourceMappingURL=privateTypes.js.map","/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n */\nexport let NetInfoStateType;\n\n(function (NetInfoStateType) {\n NetInfoStateType[\"unknown\"] = \"unknown\";\n NetInfoStateType[\"none\"] = \"none\";\n NetInfoStateType[\"cellular\"] = \"cellular\";\n NetInfoStateType[\"wifi\"] = \"wifi\";\n NetInfoStateType[\"bluetooth\"] = \"bluetooth\";\n NetInfoStateType[\"ethernet\"] = \"ethernet\";\n NetInfoStateType[\"wimax\"] = \"wimax\";\n NetInfoStateType[\"vpn\"] = \"vpn\";\n NetInfoStateType[\"other\"] = \"other\";\n})(NetInfoStateType || (NetInfoStateType = {}));\n\nexport let NetInfoCellularGeneration;\n\n(function (NetInfoCellularGeneration) {\n NetInfoCellularGeneration[\"2g\"] = \"2g\";\n NetInfoCellularGeneration[\"3g\"] = \"3g\";\n NetInfoCellularGeneration[\"4g\"] = \"4g\";\n NetInfoCellularGeneration[\"5g\"] = \"5g\";\n})(NetInfoCellularGeneration || (NetInfoCellularGeneration = {}));\n//# sourceMappingURL=types.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n */\nimport NativeInterface from './nativeInterface';\nimport InternetReachability from './internetReachability';\nimport * as PrivateTypes from './privateTypes';\nexport default class State {\n constructor(configuration) {\n _defineProperty(this, \"_nativeEventSubscription\", null);\n\n _defineProperty(this, \"_subscriptions\", new Set());\n\n _defineProperty(this, \"_latestState\", null);\n\n _defineProperty(this, \"_internetReachability\", void 0);\n\n _defineProperty(this, \"_handleNativeStateUpdate\", state => {\n // Update the internet reachability module\n this._internetReachability.update(state); // Convert the state from native to JS shape\n\n\n const convertedState = this._convertState(state); // Update the listeners\n\n\n this._latestState = convertedState;\n\n this._subscriptions.forEach(handler => handler(convertedState));\n });\n\n _defineProperty(this, \"_handleInternetReachabilityUpdate\", isInternetReachable => {\n if (!this._latestState) {\n return;\n }\n\n const nextState = { ...this._latestState,\n isInternetReachable\n };\n this._latestState = nextState;\n\n this._subscriptions.forEach(handler => handler(nextState));\n });\n\n _defineProperty(this, \"_fetchCurrentState\", async requestedInterface => {\n const state = await NativeInterface.getCurrentState(requestedInterface); // Update the internet reachability module\n\n this._internetReachability.update(state); // Convert and store the new state\n\n\n const convertedState = this._convertState(state);\n\n if (!requestedInterface) {\n this._latestState = convertedState;\n\n this._subscriptions.forEach(handler => handler(convertedState));\n }\n\n return convertedState;\n });\n\n _defineProperty(this, \"_convertState\", input => {\n if (typeof input.isInternetReachable === 'boolean') {\n return input;\n } else {\n return { ...input,\n isInternetReachable: this._internetReachability.currentState()\n };\n }\n });\n\n _defineProperty(this, \"latest\", requestedInterface => {\n if (requestedInterface) {\n return this._fetchCurrentState(requestedInterface);\n } else if (this._latestState) {\n return Promise.resolve(this._latestState);\n } else {\n return this._fetchCurrentState();\n }\n });\n\n _defineProperty(this, \"add\", handler => {\n // Add the subscription handler to our set\n this._subscriptions.add(handler); // Send it the latest data we have\n\n\n if (this._latestState) {\n handler(this._latestState);\n } else {\n this.latest().then(handler);\n }\n });\n\n _defineProperty(this, \"remove\", handler => {\n this._subscriptions.delete(handler);\n });\n\n _defineProperty(this, \"tearDown\", () => {\n if (this._internetReachability) {\n this._internetReachability.tearDown();\n }\n\n if (this._nativeEventSubscription) {\n this._nativeEventSubscription.remove();\n }\n\n this._subscriptions.clear();\n });\n\n // Add the listener to the internet connectivity events\n this._internetReachability = new InternetReachability(configuration, this._handleInternetReachabilityUpdate); // Add the subscription to the native events\n\n this._nativeEventSubscription = NativeInterface.eventEmitter.addListener(PrivateTypes.DEVICE_CONNECTIVITY_EVENT, this._handleNativeStateUpdate); // Fetch the current state from the native module\n\n this._fetchCurrentState();\n }\n\n}\n//# sourceMappingURL=state.js.map","function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/**\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n */\nexport default class InternetReachability {\n constructor(configuration, listener) {\n _defineProperty(this, \"_configuration\", void 0);\n\n _defineProperty(this, \"_listener\", void 0);\n\n _defineProperty(this, \"_isInternetReachable\", undefined);\n\n _defineProperty(this, \"_currentInternetReachabilityCheckHandler\", null);\n\n _defineProperty(this, \"_currentTimeoutHandle\", null);\n\n _defineProperty(this, \"_setIsInternetReachable\", isInternetReachable => {\n if (this._isInternetReachable === isInternetReachable) {\n return;\n }\n\n this._isInternetReachable = isInternetReachable;\n\n this._listener(this._isInternetReachable);\n });\n\n _defineProperty(this, \"_setExpectsConnection\", expectsConnection => {\n // Cancel any pending check\n if (this._currentInternetReachabilityCheckHandler !== null) {\n this._currentInternetReachabilityCheckHandler.cancel();\n\n this._currentInternetReachabilityCheckHandler = null;\n } // Cancel any pending timeout\n\n\n if (this._currentTimeoutHandle !== null) {\n clearTimeout(this._currentTimeoutHandle);\n this._currentTimeoutHandle = null;\n }\n\n if (expectsConnection && this._configuration.reachabilityShouldRun()) {\n // If we expect a connection, start the process for finding if we have one\n // Set the state to \"null\" if it was previously false\n if (!this._isInternetReachable) {\n this._setIsInternetReachable(null);\n } // Start a network request to check for internet\n\n\n this._currentInternetReachabilityCheckHandler = this._checkInternetReachability();\n } else {\n // If we don't expect a connection or don't run reachability check, just change the state to \"false\"\n this._setIsInternetReachable(false);\n }\n });\n\n _defineProperty(this, \"_checkInternetReachability\", () => {\n const controller = new AbortController();\n const responsePromise = fetch(this._configuration.reachabilityUrl, {\n headers: this._configuration.reachabilityHeaders,\n method: this._configuration.reachabilityMethod,\n cache: 'no-cache',\n signal: controller.signal\n }); // Create promise that will reject after the request timeout has been reached\n\n let timeoutHandle;\n const timeoutPromise = new Promise((_, reject) => {\n timeoutHandle = setTimeout(() => reject('timedout'), this._configuration.reachabilityRequestTimeout);\n }); // Create promise that makes it possible to cancel a pending request through a reject\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n\n let cancel = () => {};\n\n const cancelPromise = new Promise((_, reject) => {\n cancel = () => reject('canceled');\n });\n const promise = Promise.race([responsePromise, timeoutPromise, cancelPromise]).then(response => {\n return this._configuration.reachabilityTest(response);\n }).then(result => {\n this._setIsInternetReachable(result);\n\n const nextTimeoutInterval = this._isInternetReachable ? this._configuration.reachabilityLongTimeout : this._configuration.reachabilityShortTimeout;\n this._currentTimeoutHandle = setTimeout(this._checkInternetReachability, nextTimeoutInterval);\n }).catch(error => {\n if ('canceled' === error) {\n controller.abort();\n } else {\n if ('timedout' === error) {\n controller.abort();\n }\n\n this._setIsInternetReachable(false);\n\n this._currentTimeoutHandle = setTimeout(this._checkInternetReachability, this._configuration.reachabilityShortTimeout);\n }\n }) // Clear request timeout and propagate any errors\n .then(() => {\n clearTimeout(timeoutHandle);\n }, error => {\n clearTimeout(timeoutHandle);\n throw error;\n });\n return {\n promise,\n cancel\n };\n });\n\n _defineProperty(this, \"update\", state => {\n if (typeof state.isInternetReachable === 'boolean' && this._configuration.useNativeReachability) {\n this._setIsInternetReachable(state.isInternetReachable);\n } else {\n this._setExpectsConnection(state.isConnected);\n }\n });\n\n _defineProperty(this, \"currentState\", () => {\n return this._isInternetReachable;\n });\n\n _defineProperty(this, \"tearDown\", () => {\n // Cancel any pending check\n if (this._currentInternetReachabilityCheckHandler !== null) {\n this._currentInternetReachabilityCheckHandler.cancel();\n\n this._currentInternetReachabilityCheckHandler = null;\n } // Cancel any pending timeout\n\n\n if (this._currentTimeoutHandle !== null) {\n clearTimeout(this._currentTimeoutHandle);\n this._currentTimeoutHandle = null;\n }\n });\n\n this._configuration = configuration;\n this._listener = listener;\n }\n\n}\n//# sourceMappingURL=internetReachability.js.map","import { Button, Dialog, IconButton, Portal, Text } from \"react-native-paper\"\nimport React, {forwardRef, useCallback, useContext, useImperativeHandle, useRef} from \"react\";\nimport {useDialog} from \"@common/components/alert/dialog/useDialog\";\nimport {theme} from \"@common/theme/theme\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport {ChampionImageM} from \"../../../../student/champions/ChampionImageM\";\nimport * as amplitude from '@amplitude/analytics-react-native';\nimport slugify from \"slugify\";\n\n\nlet currentRef = null\nexport const DialogComponent = forwardRef((props, ref) => {\n const {config, ...defaultOptions} = props;\n const {show, hide, isVisible, options, data} = useDialog({\n defaultOptions\n })\n\n const dimensions = useContext(DimensionsContext)\n\n useImperativeHandle(\n ref,\n useCallback(\n () => ({\n show,\n hide\n }),\n [hide, show]\n )\n );\n\n const championCenteredStyle = {\n alignItems: data?.champion ? \"center\" : null,\n textAlign: data?.champion ? \"center\" : null\n }\n return (\n\n \n\n {\n\n hide()\n\n }}\n dismissable={false}\n // theme={{\n // colors: {\n // backdrop: theme.colors.blackTransparent2\n // }\n // }}\n style={{\n maxWidth: dimensions?.width,\n alignSelf: 'center',\n // position: 'fixed',\n backgroundColor: theme.colors.white,\n borderRadius: 20,\n elevation: 10,\n zIndex: 10,\n paddingTop: 10,\n }}>\n\n {data?.champion && \n \n }\n {data.text1}\n \n \n {data?.component ? data?.component :\n {data.text2}}\n \n \n \n {!data.hideButton1 && {\n amplitude.track(\"dialog.button.clicked.\" + slugify(data.text1?.substring(0, 15)) + \".\" + slugify((data.buttonText1 ?? \"OK\")?.substring(0, 15)))\n options.onPress()\n hide()\n }}>\n {data.buttonText1 ?? \"OK\"}\n }\n {data?.buttonText3 && {\n amplitude.track(\"dialog.button.clicked.\" + slugify(data.text1?.substring(0, 15)) + \".\" + slugify(data.buttonText3?.substring(0, 15)))\n options.onPress3()\n hide()\n }}>\n {data?.buttonText3}\n }\n {!data?.exitButton && data.buttonText2 && {\n amplitude.track(\"dialog.button.clicked.\" + slugify(data.text1?.substring(0, 15)) + \".\" + slugify(data.buttonText2?.substring(0, 15)))\n options.onPressBack()\n hide()\n }}>\n {data.buttonText2}\n }\n \n {data?.exitButton && \n {\n amplitude.track(\"dialog.button.clicked.times\")\n options.onPressBack()\n hide()\n }}\n />\n }\n \n\n \n\n\n );\n\n})\n\nexport function DialogM(props) {\n const dialogRef = useRef(null);\n\n const setRef = useCallback((ref) => {\n if (ref) {\n dialogRef.current = ref;\n currentRef = ref;\n }\n }, []);\n\n return (\n \n );\n}\n\nDialogM.show = (params) => {\n currentRef?.show(params);\n};\n\nDialogM.hide = (params) => {\n\n currentRef?.hide(params);\n};","import {useCallback, useState} from 'react'\nimport {DEFAULT_DATA, DEFAULT_OPTIONS, mergeIfDefined} from \"@common/components/alert/snackbar/useSnackBar\";\n\n\nexport function useDialog({defaultOptions}) {\n const [isVisible, setIsVisible] = useState(false);\n const [data, setData] = useState(DEFAULT_DATA);\n\n const initialOptions = mergeIfDefined(\n DEFAULT_OPTIONS,\n defaultOptions)\n\n const [options, setOptions] = useState(initialOptions);\n\n const hide = useCallback(() => {\n setIsVisible(false);\n options.onHide();\n }, [options]);\n\n const show = useCallback(\n (params) => {\n const {\n component = DEFAULT_DATA?.component,\n champion = DEFAULT_DATA.champion,\n variant = DEFAULT_DATA.variant,\n text1 = DEFAULT_DATA.text1,\n text2 = DEFAULT_DATA.text2,\n buttonText1 = DEFAULT_DATA.buttonText1,\n buttonText2 = DEFAULT_DATA.buttonText2,\n buttonText3 = DEFAULT_DATA.buttonText3,\n buttonDisabled1 = DEFAULT_DATA.buttonDisabled1,\n buttonColor1 = DEFAULT_DATA.buttonColor1,\n buttonColor2 = DEFAULT_DATA.buttonColor2,\n buttonColor3 = DEFAULT_DATA.buttonColor3,\n duration = DEFAULT_DATA.duration,\n exitButton = DEFAULT_DATA.exitButton,\n onShow = initialOptions.onShow,\n onHide = initialOptions.onHide,\n onPress = initialOptions.onPress,\n onPressBack = initialOptions.onPressBack,\n onPress3 = initialOptions.onPress3,\n hideButton1 = DEFAULT_DATA.hideButton1,\n props = initialOptions.props\n } = params;\n setData({\n component,\n champion,\n variant,\n text1,\n text2,\n buttonText1,\n buttonText2,\n buttonText3,\n buttonDisabled1,\n buttonColor1,\n buttonColor2,\n buttonColor3,\n duration,\n hideButton1,\n exitButton\n });\n setOptions(\n mergeIfDefined(initialOptions, {\n duration,\n onShow,\n onHide,\n onPress,\n onPressBack,\n onPress3,\n props\n })\n );\n setIsVisible(true);\n onShow();\n },\n [initialOptions]\n );\n\n\n return {\n isVisible,\n data,\n options,\n show,\n hide\n };\n}","import {useCallback, useState} from 'react'\n\nexport const DEFAULT_DATA = {\n component: undefined,\n champion: undefined,\n variant: undefined,\n text1: undefined,\n text2: undefined,\n buttonText1: \"Ok\",\n buttonText2: undefined,\n buttonText3: undefined,\n buttonDisabled1: false,\n duration: undefined,\n buttonColor1: undefined,\n buttonColor2: undefined,\n buttonColor3: undefined,\n hideButton1: false,\n exitButton: false\n};\n\nexport const DEFAULT_OPTIONS = {\n onShow: () => {\n },\n onHide: () => {\n },\n onPress: () => {\n },\n onPressBack: () => {\n },\n onPress3: () => {\n },\n props: {}\n};\n\nexport function mergeIfDefined(\n obj1,\n obj2\n) {\n const newObj = {\n ...obj1\n };\n Object.entries(obj2).forEach(([key, value]) => {\n if (value !== null && value !== undefined) {\n newObj[key] = value;\n }\n });\n return newObj;\n}\n\nexport function useSnackBar({defaultOptions}) {\n const [isVisible, setIsVisible] = useState(false);\n const [data, setData] = useState(DEFAULT_DATA);\n\n const initialOptions = mergeIfDefined(\n DEFAULT_OPTIONS,\n defaultOptions)\n\n const [options, setOptions] = useState(initialOptions);\n\n const hide = useCallback(() => {\n setIsVisible(false);\n options.onHide();\n }, [options]);\n\n const show = useCallback(\n (params) => {\n const {\n text1 = DEFAULT_DATA.text1,\n text2 = DEFAULT_DATA.text2,\n buttonText1 = DEFAULT_DATA.buttonText1,\n buttonText2 = DEFAULT_DATA.buttonText2,\n buttonColor1 = DEFAULT_DATA.buttonColor1,\n buttonColor2 = DEFAULT_DATA.buttonColor2,\n duration = DEFAULT_DATA.duration,\n onShow = initialOptions.onShow,\n onHide = initialOptions.onHide,\n onPress = initialOptions.onPress,\n onPressBack = initialOptions.onPressBack,\n props = initialOptions.props\n } = params;\n setData({\n text1,\n text2,\n buttonText2,\n buttonText1,\n duration,\n buttonColor1,\n buttonColor2,\n });\n setOptions(\n mergeIfDefined(initialOptions, {\n duration,\n onShow,\n onHide,\n onPress,\n onPressBack,\n props\n })\n );\n setIsVisible(true);\n onShow();\n },\n [initialOptions]\n );\n\n\n return {\n isVisible,\n data,\n options,\n show,\n hide\n };\n}","import React from \"react\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport zoe_main from \"../../../assets/champions/zoe_main.png\"\nimport zoe_happy from \"../../../assets/champions/zoe_happy.png\"\nimport zoe_unhappy from \"../../../assets/champions/zoe_unhappy.png\"\nimport abou_main from \"../../../assets/champions/abou_main.png\"\nimport abou_happy from \"../../../assets/champions/abou_happy.png\"\nimport abou_unhappy from \"../../../assets/champions/abou_unhappy.png\"\nimport sam_main from \"../../../assets/champions/sam_main.png\"\nimport sam_happy from \"../../../assets/champions/sam_happy.png\"\nimport sam_unhappy from \"../../../assets/champions/sam_unhappy.png\"\nimport tina_main from \"../../../assets/champions/tina_main.png\"\nimport tina_happy from \"../../../assets/champions/tina_happy.png\"\nimport tina_unhappy from \"../../../assets/champions/tina_unhappy.png\"\nimport {Image, Platform} from \"react-native\";\n\nconst championImages = {\n zoe_main,\n zoe_happy,\n zoe_unhappy,\n abou_main,\n abou_happy,\n abou_unhappy,\n sam_main,\n sam_happy,\n sam_unhappy,\n tina_main,\n tina_happy,\n tina_unhappy\n}\n\nexport const ChampionImageM = (props) => {\n\n const {name = \"zoe\", variant = \"main\", width, eye = false, style, height} = props\n\n const getSource = (name, variant) => {\n return championImages[`${name}_${variant}`]\n }\n\n if (eye)\n return \n else\n return \n}\nexport const samVariantForActivity = (activity) => activity?.score >= 4 ? \"happy\" : activity?.score < 2.5 ? \"unhappy\" : \"main\"\nexport const samVariantForScore = (score) => score >= 4 ? \"happy\" : score < 2.5 ? \"unhappy\" : \"main\"","import React, {useEffect, useState} from \"react\"\nimport lightning from \"../../../../assets/icons/generic/lightning.png\"\nimport gift from \"../../../../assets/icons/generic/gift.png\"\nimport feather from \"../../../../assets/icons/generic/feather.png\"\nimport petal from \"../../../../assets/icons/generic/petal_new.png\"\nimport checked from \"../../../../assets/icons/generic/checked.png\"\nimport remove from \"../../../../assets/icons/generic/remove.png\"\nimport brokenImage from \"../../../../assets/icons/generic/broken-image.png\"\nimport removeGrey from \"../../../../assets/icons/generic/remove-grey.png\"\nimport planningPlus from \"../../../../assets/icons/generic/planning-plus.png\"\nimport premiumPlus from \"../../../../assets/icons/generic/premium-plus.png\"\nimport premiumCoach from \"../../../../assets/icons/generic/premium-coach.png\"\nimport {Image, Platform} from \"react-native\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\n\nexport const PremiumPlus = (props) => {\n return \n}\n\nexport const PremiumCoach = (props) => {\n return \n}\n\nexport const Xp = (props) => {\n return \n}\n\nexport const Gift = (props) => {\n return \n}\nexport const PlanningPlus = (props) => {\n return \n}\n\nexport const Feather = (props) => {\n return \n}\n\nexport const Petal = (props) => {\n return \n}\n\nexport const SkillSetTitle = (props) => {\n\n // console.log(\"props.icon\", props.icon)\n return !!props.icon && \n}\n\nexport const Check = (props) => {\n return \n}\n\nexport const Checked = (props) => {\n return \n}\n\nexport const Remove = (props) => {\n return \n}\n\nexport const RemoveGrey = (props) => {\n return \n}\n\nexport const IconImageM = (props) => {\n\n const {uri, source, width, style, height, resizeMode} = props\n const [size, setSize] = useState({width: width, height: width})\n\n\n useEffect(() => {\n if (Platform.OS !== 'web')\n if (!height && (!!source || !!uri))\n (async () => {\n Image.getSize(source ? Image.resolveAssetSource(source).uri : uri, (width, height) => {\n setSize({width, height})\n })\n })();\n\n return () => setSize({})\n }, [])\n\n\n return \n}","","","","","","","","","","","","import FontAwesome5 from './build/FontAwesome5';\nexport default FontAwesome5;\n","import { createFA5iconSet } from './createIconSetFromFontAwesome5';\nimport glyphMap from './vendor/react-native-vector-icons/glyphmaps/FontAwesome5Free.json';\nimport metadata from './vendor/react-native-vector-icons/glyphmaps/FontAwesome5Free_meta.json';\nconst fontMap = {\n Regular: require('./vendor/react-native-vector-icons/Fonts/FontAwesome5_Regular.ttf'),\n Light: require('./vendor/react-native-vector-icons/Fonts/FontAwesome5_Regular.ttf'),\n Solid: require('./vendor/react-native-vector-icons/Fonts/FontAwesome5_Solid.ttf'),\n Brand: require('./vendor/react-native-vector-icons/Fonts/FontAwesome5_Brands.ttf'),\n};\nexport const FA5Style = {\n regular: 'regular',\n light: 'light',\n solid: 'solid',\n brand: 'brand',\n};\nconst iconSet = createFA5iconSet(glyphMap, metadata, fontMap, false);\nexport default iconSet;\n//# sourceMappingURL=FontAwesome5.js.map","import { Platform } from 'react-native';\nimport createMultiStyleIconSet from './createMultiStyleIconSet';\nexport const FA5Style = {\n regular: 'regular',\n light: 'light',\n solid: 'solid',\n brand: 'brand',\n};\nexport function createFA5iconSet(glyphMap, metadata = {}, fonts, pro = false) {\n const metadataKeys = Object.keys(metadata);\n const fontFamily = `FontAwesome5${pro ? 'Pro' : 'Free'}`;\n function fallbackFamily(glyph) {\n for (let i = 0; i < metadataKeys.length; i += 1) {\n const family = metadataKeys[i];\n if (metadata[family].indexOf(glyph) !== -1) {\n return family === 'brands' ? 'brand' : family;\n }\n }\n return 'regular';\n }\n function glyphValidator(glyph, style) {\n const family = style === 'brand' ? 'brands' : style;\n if (metadataKeys.indexOf(family) === -1)\n return false;\n return metadata[family].indexOf(glyph) !== -1;\n }\n function createFontAwesomeStyle(styleName, fontWeight, family = fontFamily) {\n const fontFile = fonts[styleName];\n return {\n fontFamily: `${family}-${styleName}`,\n fontFile,\n fontStyle: Platform.select({\n ios: {\n fontWeight,\n },\n default: {},\n }),\n glyphMap,\n };\n }\n const brandIcons = createFontAwesomeStyle('Brand', '400');\n const lightIcons = createFontAwesomeStyle('Light', '100');\n const regularIcons = createFontAwesomeStyle('Regular', '400');\n const solidIcons = createFontAwesomeStyle('Solid', '700');\n const Icon = createMultiStyleIconSet({\n brand: brandIcons,\n light: lightIcons,\n regular: regularIcons,\n solid: solidIcons,\n }, {\n defaultStyle: 'regular',\n fallbackFamily,\n glyphValidator,\n });\n return Icon;\n}\n//# sourceMappingURL=createIconSetFromFontAwesome5.js.map","import React, { PureComponent } from 'react';\nimport createIconSet from './createIconSet';\nexport default function createMultiStyleIconSet(styles, optionsInput = {}) {\n const styleNames = Object.keys(styles);\n if (styleNames.length === 0) {\n throw new Error('You need to add at least one style');\n }\n const options = {\n defaultStyle: styleNames[0],\n fallbackFamily: (_unused) => styleNames[0],\n glyphValidator: (_unused, __unused) => true,\n ...optionsInput,\n };\n const iconSets = styleNames.reduce((acc, name) => {\n const style = styles[name];\n acc[name] = createIconSet(style.glyphMap || {}, style.fontFamily || '', style.fontFile || '', style.fontStyle || {});\n return acc;\n }, {});\n function styleFromProps(props) {\n return Object.keys(props).reduce((result, propName) => styleNames.indexOf(propName) !== -1 && props[propName] === true ? propName : result, options.defaultStyle);\n }\n function getIconSetForProps(props) {\n const { name } = props;\n const style = styleFromProps(props);\n if (options.glyphValidator(name, style))\n return iconSets[style];\n const family = options.fallbackFamily(name);\n if (styleNames.indexOf(family) === -1) {\n return options.defaultStyle;\n }\n return iconSets[family];\n }\n function selectIconClass(iconSet, iconClass) {\n return iconClass.length > 0 ? iconSet[iconClass] : iconSet;\n }\n function reduceProps(props) {\n return Object.keys(props).reduce((acc, prop) => {\n if (styleNames.indexOf(prop) === -1) {\n acc[prop] = props[prop];\n }\n return acc;\n }, {});\n }\n function getStyledIconSet(style, name = '') {\n if (styleNames.indexOf(style) === -1) {\n return iconSets[options.defaultStyle];\n }\n return !name\n ? iconSets[styleFromProps({ [style]: true })]\n : getIconSetForProps({ name, [style]: true });\n }\n function getFontFamily(style = options.defaultStyle) {\n return getStyledIconSet(style).getFontFamily();\n }\n function getRawGlyphMap(style = options.defaultStyle) {\n return getStyledIconSet(style).getRawGlyphMap();\n }\n function hasIcon(name, style = options.defaultStyle) {\n return options.glyphValidator(name, style);\n }\n function createStyledIconClass(selectClass = '') {\n class IconClass extends PureComponent {\n static defaultProps = styleNames.reduce((acc, name) => {\n acc[name] = false;\n return acc;\n }, {});\n static font = Object.values(styles).reduce((acc, style) => {\n acc[style.fontFamily] = style.fontFile;\n return acc;\n }, {});\n static Button;\n static StyledIconSet = getStyledIconSet;\n static getFontFamily = getFontFamily;\n static getRawGlyphMap = getRawGlyphMap;\n static hasIcon = hasIcon;\n render() {\n const selectedIconSet = getIconSetForProps(this.props);\n const SelectedIconClass = selectIconClass(selectedIconSet, selectClass);\n const props = reduceProps(this.props);\n return React.createElement(SelectedIconClass, props);\n }\n }\n return IconClass;\n }\n const Icon = createStyledIconClass();\n Icon.Button = createStyledIconClass('Button');\n return Icon;\n}\n//# sourceMappingURL=createMultiStyleIconSet.js.map","{\n \"500px\": 62062,\n \"accessible-icon\": 62312,\n \"accusoft\": 62313,\n \"acquisitions-incorporated\": 63151,\n \"ad\": 63041,\n \"address-book\": 62137,\n \"address-card\": 62139,\n \"adjust\": 61506,\n \"adn\": 61808,\n \"adversal\": 62314,\n \"affiliatetheme\": 62315,\n \"air-freshener\": 62928,\n \"airbnb\": 63540,\n \"algolia\": 62316,\n \"align-center\": 61495,\n \"align-justify\": 61497,\n \"align-left\": 61494,\n \"align-right\": 61496,\n \"alipay\": 63042,\n \"allergies\": 62561,\n \"amazon\": 62064,\n \"amazon-pay\": 62508,\n \"ambulance\": 61689,\n \"american-sign-language-interpreting\": 62115,\n \"amilia\": 62317,\n \"anchor\": 61757,\n \"android\": 61819,\n \"angellist\": 61961,\n \"angle-double-down\": 61699,\n \"angle-double-left\": 61696,\n \"angle-double-right\": 61697,\n \"angle-double-up\": 61698,\n \"angle-down\": 61703,\n \"angle-left\": 61700,\n \"angle-right\": 61701,\n \"angle-up\": 61702,\n \"angry\": 62806,\n \"angrycreative\": 62318,\n \"angular\": 62496,\n \"ankh\": 63044,\n \"app-store\": 62319,\n \"app-store-ios\": 62320,\n \"apper\": 62321,\n \"apple\": 61817,\n \"apple-alt\": 62929,\n \"apple-pay\": 62485,\n \"archive\": 61831,\n \"archway\": 62807,\n \"arrow-alt-circle-down\": 62296,\n \"arrow-alt-circle-left\": 62297,\n \"arrow-alt-circle-right\": 62298,\n \"arrow-alt-circle-up\": 62299,\n \"arrow-circle-down\": 61611,\n \"arrow-circle-left\": 61608,\n \"arrow-circle-right\": 61609,\n \"arrow-circle-up\": 61610,\n \"arrow-down\": 61539,\n \"arrow-left\": 61536,\n \"arrow-right\": 61537,\n \"arrow-up\": 61538,\n \"arrows-alt\": 61618,\n \"arrows-alt-h\": 62263,\n \"arrows-alt-v\": 62264,\n \"artstation\": 63354,\n \"assistive-listening-systems\": 62114,\n \"asterisk\": 61545,\n \"asymmetrik\": 62322,\n \"at\": 61946,\n \"atlas\": 62808,\n \"atlassian\": 63355,\n \"atom\": 62930,\n \"audible\": 62323,\n \"audio-description\": 62110,\n \"autoprefixer\": 62492,\n \"avianex\": 62324,\n \"aviato\": 62497,\n \"award\": 62809,\n \"aws\": 62325,\n \"baby\": 63356,\n \"baby-carriage\": 63357,\n \"backspace\": 62810,\n \"backward\": 61514,\n \"bacon\": 63461,\n \"bacteria\": 57433,\n \"bacterium\": 57434,\n \"bahai\": 63078,\n \"balance-scale\": 62030,\n \"balance-scale-left\": 62741,\n \"balance-scale-right\": 62742,\n \"ban\": 61534,\n \"band-aid\": 62562,\n \"bandcamp\": 62165,\n \"barcode\": 61482,\n \"bars\": 61641,\n \"baseball-ball\": 62515,\n \"basketball-ball\": 62516,\n \"bath\": 62157,\n \"battery-empty\": 62020,\n \"battery-full\": 62016,\n \"battery-half\": 62018,\n \"battery-quarter\": 62019,\n \"battery-three-quarters\": 62017,\n \"battle-net\": 63541,\n \"bed\": 62006,\n \"beer\": 61692,\n \"behance\": 61876,\n \"behance-square\": 61877,\n \"bell\": 61683,\n \"bell-slash\": 61942,\n \"bezier-curve\": 62811,\n \"bible\": 63047,\n \"bicycle\": 61958,\n \"biking\": 63562,\n \"bimobject\": 62328,\n \"binoculars\": 61925,\n \"biohazard\": 63360,\n \"birthday-cake\": 61949,\n \"bitbucket\": 61809,\n \"bitcoin\": 62329,\n \"bity\": 62330,\n \"black-tie\": 62078,\n \"blackberry\": 62331,\n \"blender\": 62743,\n \"blender-phone\": 63158,\n \"blind\": 62109,\n \"blog\": 63361,\n \"blogger\": 62332,\n \"blogger-b\": 62333,\n \"bluetooth\": 62099,\n \"bluetooth-b\": 62100,\n \"bold\": 61490,\n \"bolt\": 61671,\n \"bomb\": 61922,\n \"bone\": 62935,\n \"bong\": 62812,\n \"book\": 61485,\n \"book-dead\": 63159,\n \"book-medical\": 63462,\n \"book-open\": 62744,\n \"book-reader\": 62938,\n \"bookmark\": 61486,\n \"bootstrap\": 63542,\n \"border-all\": 63564,\n \"border-none\": 63568,\n \"border-style\": 63571,\n \"bowling-ball\": 62518,\n \"box\": 62566,\n \"box-open\": 62622,\n \"box-tissue\": 57435,\n \"boxes\": 62568,\n \"braille\": 62113,\n \"brain\": 62940,\n \"bread-slice\": 63468,\n \"briefcase\": 61617,\n \"briefcase-medical\": 62569,\n \"broadcast-tower\": 62745,\n \"broom\": 62746,\n \"brush\": 62813,\n \"btc\": 61786,\n \"buffer\": 63543,\n \"bug\": 61832,\n \"building\": 61869,\n \"bullhorn\": 61601,\n \"bullseye\": 61760,\n \"burn\": 62570,\n \"buromobelexperte\": 62335,\n \"bus\": 61959,\n \"bus-alt\": 62814,\n \"business-time\": 63050,\n \"buy-n-large\": 63654,\n \"buysellads\": 61965,\n \"calculator\": 61932,\n \"calendar\": 61747,\n \"calendar-alt\": 61555,\n \"calendar-check\": 62068,\n \"calendar-day\": 63363,\n \"calendar-minus\": 62066,\n \"calendar-plus\": 62065,\n \"calendar-times\": 62067,\n \"calendar-week\": 63364,\n \"camera\": 61488,\n \"camera-retro\": 61571,\n \"campground\": 63163,\n \"canadian-maple-leaf\": 63365,\n \"candy-cane\": 63366,\n \"cannabis\": 62815,\n \"capsules\": 62571,\n \"car\": 61881,\n \"car-alt\": 62942,\n \"car-battery\": 62943,\n \"car-crash\": 62945,\n \"car-side\": 62948,\n \"caravan\": 63743,\n \"caret-down\": 61655,\n \"caret-left\": 61657,\n \"caret-right\": 61658,\n \"caret-square-down\": 61776,\n \"caret-square-left\": 61841,\n \"caret-square-right\": 61778,\n \"caret-square-up\": 61777,\n \"caret-up\": 61656,\n \"carrot\": 63367,\n \"cart-arrow-down\": 61976,\n \"cart-plus\": 61975,\n \"cash-register\": 63368,\n \"cat\": 63166,\n \"cc-amazon-pay\": 62509,\n \"cc-amex\": 61939,\n \"cc-apple-pay\": 62486,\n \"cc-diners-club\": 62028,\n \"cc-discover\": 61938,\n \"cc-jcb\": 62027,\n \"cc-mastercard\": 61937,\n \"cc-paypal\": 61940,\n \"cc-stripe\": 61941,\n \"cc-visa\": 61936,\n \"centercode\": 62336,\n \"centos\": 63369,\n \"certificate\": 61603,\n \"chair\": 63168,\n \"chalkboard\": 62747,\n \"chalkboard-teacher\": 62748,\n \"charging-station\": 62951,\n \"chart-area\": 61950,\n \"chart-bar\": 61568,\n \"chart-line\": 61953,\n \"chart-pie\": 61952,\n \"check\": 61452,\n \"check-circle\": 61528,\n \"check-double\": 62816,\n \"check-square\": 61770,\n \"cheese\": 63471,\n \"chess\": 62521,\n \"chess-bishop\": 62522,\n \"chess-board\": 62524,\n \"chess-king\": 62527,\n \"chess-knight\": 62529,\n \"chess-pawn\": 62531,\n \"chess-queen\": 62533,\n \"chess-rook\": 62535,\n \"chevron-circle-down\": 61754,\n \"chevron-circle-left\": 61751,\n \"chevron-circle-right\": 61752,\n \"chevron-circle-up\": 61753,\n \"chevron-down\": 61560,\n \"chevron-left\": 61523,\n \"chevron-right\": 61524,\n \"chevron-up\": 61559,\n \"child\": 61870,\n \"chrome\": 62056,\n \"chromecast\": 63544,\n \"church\": 62749,\n \"circle\": 61713,\n \"circle-notch\": 61902,\n \"city\": 63055,\n \"clinic-medical\": 63474,\n \"clipboard\": 62248,\n \"clipboard-check\": 62572,\n \"clipboard-list\": 62573,\n \"clock\": 61463,\n \"clone\": 62029,\n \"closed-captioning\": 61962,\n \"cloud\": 61634,\n \"cloud-download-alt\": 62337,\n \"cloud-meatball\": 63291,\n \"cloud-moon\": 63171,\n \"cloud-moon-rain\": 63292,\n \"cloud-rain\": 63293,\n \"cloud-showers-heavy\": 63296,\n \"cloud-sun\": 63172,\n \"cloud-sun-rain\": 63299,\n \"cloud-upload-alt\": 62338,\n \"cloudflare\": 57469,\n \"cloudscale\": 62339,\n \"cloudsmith\": 62340,\n \"cloudversify\": 62341,\n \"cocktail\": 62817,\n \"code\": 61729,\n \"code-branch\": 61734,\n \"codepen\": 61899,\n \"codiepie\": 62084,\n \"coffee\": 61684,\n \"cog\": 61459,\n \"cogs\": 61573,\n \"coins\": 62750,\n \"columns\": 61659,\n \"comment\": 61557,\n \"comment-alt\": 62074,\n \"comment-dollar\": 63057,\n \"comment-dots\": 62637,\n \"comment-medical\": 63477,\n \"comment-slash\": 62643,\n \"comments\": 61574,\n \"comments-dollar\": 63059,\n \"compact-disc\": 62751,\n \"compass\": 61774,\n \"compress\": 61542,\n \"compress-alt\": 62498,\n \"compress-arrows-alt\": 63372,\n \"concierge-bell\": 62818,\n \"confluence\": 63373,\n \"connectdevelop\": 61966,\n \"contao\": 62061,\n \"cookie\": 62819,\n \"cookie-bite\": 62820,\n \"copy\": 61637,\n \"copyright\": 61945,\n \"cotton-bureau\": 63646,\n \"couch\": 62648,\n \"cpanel\": 62344,\n \"creative-commons\": 62046,\n \"creative-commons-by\": 62695,\n \"creative-commons-nc\": 62696,\n \"creative-commons-nc-eu\": 62697,\n \"creative-commons-nc-jp\": 62698,\n \"creative-commons-nd\": 62699,\n \"creative-commons-pd\": 62700,\n \"creative-commons-pd-alt\": 62701,\n \"creative-commons-remix\": 62702,\n \"creative-commons-sa\": 62703,\n \"creative-commons-sampling\": 62704,\n \"creative-commons-sampling-plus\": 62705,\n \"creative-commons-share\": 62706,\n \"creative-commons-zero\": 62707,\n \"credit-card\": 61597,\n \"critical-role\": 63177,\n \"crop\": 61733,\n \"crop-alt\": 62821,\n \"cross\": 63060,\n \"crosshairs\": 61531,\n \"crow\": 62752,\n \"crown\": 62753,\n \"crutch\": 63479,\n \"css3\": 61756,\n \"css3-alt\": 62347,\n \"cube\": 61874,\n \"cubes\": 61875,\n \"cut\": 61636,\n \"cuttlefish\": 62348,\n \"d-and-d\": 62349,\n \"d-and-d-beyond\": 63178,\n \"dailymotion\": 57426,\n \"dashcube\": 61968,\n \"database\": 61888,\n \"deaf\": 62116,\n \"deezer\": 57463,\n \"delicious\": 61861,\n \"democrat\": 63303,\n \"deploydog\": 62350,\n \"deskpro\": 62351,\n \"desktop\": 61704,\n \"dev\": 63180,\n \"deviantart\": 61885,\n \"dharmachakra\": 63061,\n \"dhl\": 63376,\n \"diagnoses\": 62576,\n \"diaspora\": 63377,\n \"dice\": 62754,\n \"dice-d20\": 63183,\n \"dice-d6\": 63185,\n \"dice-five\": 62755,\n \"dice-four\": 62756,\n \"dice-one\": 62757,\n \"dice-six\": 62758,\n \"dice-three\": 62759,\n \"dice-two\": 62760,\n \"digg\": 61862,\n \"digital-ocean\": 62353,\n \"digital-tachograph\": 62822,\n \"directions\": 62955,\n \"discord\": 62354,\n \"discourse\": 62355,\n \"disease\": 63482,\n \"divide\": 62761,\n \"dizzy\": 62823,\n \"dna\": 62577,\n \"dochub\": 62356,\n \"docker\": 62357,\n \"dog\": 63187,\n \"dollar-sign\": 61781,\n \"dolly\": 62578,\n \"dolly-flatbed\": 62580,\n \"donate\": 62649,\n \"door-closed\": 62762,\n \"door-open\": 62763,\n \"dot-circle\": 61842,\n \"dove\": 62650,\n \"download\": 61465,\n \"draft2digital\": 62358,\n \"drafting-compass\": 62824,\n \"dragon\": 63189,\n \"draw-polygon\": 62958,\n \"dribbble\": 61821,\n \"dribbble-square\": 62359,\n \"dropbox\": 61803,\n \"drum\": 62825,\n \"drum-steelpan\": 62826,\n \"drumstick-bite\": 63191,\n \"drupal\": 61865,\n \"dumbbell\": 62539,\n \"dumpster\": 63379,\n \"dumpster-fire\": 63380,\n \"dungeon\": 63193,\n \"dyalog\": 62361,\n \"earlybirds\": 62362,\n \"ebay\": 62708,\n \"edge\": 62082,\n \"edge-legacy\": 57464,\n \"edit\": 61508,\n \"egg\": 63483,\n \"eject\": 61522,\n \"elementor\": 62512,\n \"ellipsis-h\": 61761,\n \"ellipsis-v\": 61762,\n \"ello\": 62961,\n \"ember\": 62499,\n \"empire\": 61905,\n \"envelope\": 61664,\n \"envelope-open\": 62134,\n \"envelope-open-text\": 63064,\n \"envelope-square\": 61849,\n \"envira\": 62105,\n \"equals\": 62764,\n \"eraser\": 61741,\n \"erlang\": 62365,\n \"ethereum\": 62510,\n \"ethernet\": 63382,\n \"etsy\": 62167,\n \"euro-sign\": 61779,\n \"evernote\": 63545,\n \"exchange-alt\": 62306,\n \"exclamation\": 61738,\n \"exclamation-circle\": 61546,\n \"exclamation-triangle\": 61553,\n \"expand\": 61541,\n \"expand-alt\": 62500,\n \"expand-arrows-alt\": 62238,\n \"expeditedssl\": 62014,\n \"external-link-alt\": 62301,\n \"external-link-square-alt\": 62304,\n \"eye\": 61550,\n \"eye-dropper\": 61947,\n \"eye-slash\": 61552,\n \"facebook\": 61594,\n \"facebook-f\": 62366,\n \"facebook-messenger\": 62367,\n \"facebook-square\": 61570,\n \"fan\": 63587,\n \"fantasy-flight-games\": 63196,\n \"fast-backward\": 61513,\n \"fast-forward\": 61520,\n \"faucet\": 57349,\n \"fax\": 61868,\n \"feather\": 62765,\n \"feather-alt\": 62827,\n \"fedex\": 63383,\n \"fedora\": 63384,\n \"female\": 61826,\n \"fighter-jet\": 61691,\n \"figma\": 63385,\n \"file\": 61787,\n \"file-alt\": 61788,\n \"file-archive\": 61894,\n \"file-audio\": 61895,\n \"file-code\": 61897,\n \"file-contract\": 62828,\n \"file-csv\": 63197,\n \"file-download\": 62829,\n \"file-excel\": 61891,\n \"file-export\": 62830,\n \"file-image\": 61893,\n \"file-import\": 62831,\n \"file-invoice\": 62832,\n \"file-invoice-dollar\": 62833,\n \"file-medical\": 62583,\n \"file-medical-alt\": 62584,\n \"file-pdf\": 61889,\n \"file-powerpoint\": 61892,\n \"file-prescription\": 62834,\n \"file-signature\": 62835,\n \"file-upload\": 62836,\n \"file-video\": 61896,\n \"file-word\": 61890,\n \"fill\": 62837,\n \"fill-drip\": 62838,\n \"film\": 61448,\n \"filter\": 61616,\n \"fingerprint\": 62839,\n \"fire\": 61549,\n \"fire-alt\": 63460,\n \"fire-extinguisher\": 61748,\n \"firefox\": 62057,\n \"firefox-browser\": 57351,\n \"first-aid\": 62585,\n \"first-order\": 62128,\n \"first-order-alt\": 62730,\n \"firstdraft\": 62369,\n \"fish\": 62840,\n \"fist-raised\": 63198,\n \"flag\": 61476,\n \"flag-checkered\": 61726,\n \"flag-usa\": 63309,\n \"flask\": 61635,\n \"flickr\": 61806,\n \"flipboard\": 62541,\n \"flushed\": 62841,\n \"fly\": 62487,\n \"folder\": 61563,\n \"folder-minus\": 63069,\n \"folder-open\": 61564,\n \"folder-plus\": 63070,\n \"font\": 61489,\n \"font-awesome\": 62132,\n \"font-awesome-alt\": 62300,\n \"font-awesome-flag\": 62501,\n \"font-awesome-logo-full\": 62694,\n \"fonticons\": 62080,\n \"fonticons-fi\": 62370,\n \"football-ball\": 62542,\n \"fort-awesome\": 62086,\n \"fort-awesome-alt\": 62371,\n \"forumbee\": 61969,\n \"forward\": 61518,\n \"foursquare\": 61824,\n \"free-code-camp\": 62149,\n \"freebsd\": 62372,\n \"frog\": 62766,\n \"frown\": 61721,\n \"frown-open\": 62842,\n \"fulcrum\": 62731,\n \"funnel-dollar\": 63074,\n \"futbol\": 61923,\n \"galactic-republic\": 62732,\n \"galactic-senate\": 62733,\n \"gamepad\": 61723,\n \"gas-pump\": 62767,\n \"gavel\": 61667,\n \"gem\": 62373,\n \"genderless\": 61997,\n \"get-pocket\": 62053,\n \"gg\": 62048,\n \"gg-circle\": 62049,\n \"ghost\": 63202,\n \"gift\": 61547,\n \"gifts\": 63388,\n \"git\": 61907,\n \"git-alt\": 63553,\n \"git-square\": 61906,\n \"github\": 61595,\n \"github-alt\": 61715,\n \"github-square\": 61586,\n \"gitkraken\": 62374,\n \"gitlab\": 62102,\n \"gitter\": 62502,\n \"glass-cheers\": 63391,\n \"glass-martini\": 61440,\n \"glass-martini-alt\": 62843,\n \"glass-whiskey\": 63392,\n \"glasses\": 62768,\n \"glide\": 62117,\n \"glide-g\": 62118,\n \"globe\": 61612,\n \"globe-africa\": 62844,\n \"globe-americas\": 62845,\n \"globe-asia\": 62846,\n \"globe-europe\": 63394,\n \"gofore\": 62375,\n \"golf-ball\": 62544,\n \"goodreads\": 62376,\n \"goodreads-g\": 62377,\n \"google\": 61856,\n \"google-drive\": 62378,\n \"google-pay\": 57465,\n \"google-play\": 62379,\n \"google-plus\": 62131,\n \"google-plus-g\": 61653,\n \"google-plus-square\": 61652,\n \"google-wallet\": 61934,\n \"gopuram\": 63076,\n \"graduation-cap\": 61853,\n \"gratipay\": 61828,\n \"grav\": 62166,\n \"greater-than\": 62769,\n \"greater-than-equal\": 62770,\n \"grimace\": 62847,\n \"grin\": 62848,\n \"grin-alt\": 62849,\n \"grin-beam\": 62850,\n \"grin-beam-sweat\": 62851,\n \"grin-hearts\": 62852,\n \"grin-squint\": 62853,\n \"grin-squint-tears\": 62854,\n \"grin-stars\": 62855,\n \"grin-tears\": 62856,\n \"grin-tongue\": 62857,\n \"grin-tongue-squint\": 62858,\n \"grin-tongue-wink\": 62859,\n \"grin-wink\": 62860,\n \"grip-horizontal\": 62861,\n \"grip-lines\": 63396,\n \"grip-lines-vertical\": 63397,\n \"grip-vertical\": 62862,\n \"gripfire\": 62380,\n \"grunt\": 62381,\n \"guilded\": 57470,\n \"guitar\": 63398,\n \"gulp\": 62382,\n \"h-square\": 61693,\n \"hacker-news\": 61908,\n \"hacker-news-square\": 62383,\n \"hackerrank\": 62967,\n \"hamburger\": 63493,\n \"hammer\": 63203,\n \"hamsa\": 63077,\n \"hand-holding\": 62653,\n \"hand-holding-heart\": 62654,\n \"hand-holding-medical\": 57436,\n \"hand-holding-usd\": 62656,\n \"hand-holding-water\": 62657,\n \"hand-lizard\": 62040,\n \"hand-middle-finger\": 63494,\n \"hand-paper\": 62038,\n \"hand-peace\": 62043,\n \"hand-point-down\": 61607,\n \"hand-point-left\": 61605,\n \"hand-point-right\": 61604,\n \"hand-point-up\": 61606,\n \"hand-pointer\": 62042,\n \"hand-rock\": 62037,\n \"hand-scissors\": 62039,\n \"hand-sparkles\": 57437,\n \"hand-spock\": 62041,\n \"hands\": 62658,\n \"hands-helping\": 62660,\n \"hands-wash\": 57438,\n \"handshake\": 62133,\n \"handshake-alt-slash\": 57439,\n \"handshake-slash\": 57440,\n \"hanukiah\": 63206,\n \"hard-hat\": 63495,\n \"hashtag\": 62098,\n \"hat-cowboy\": 63680,\n \"hat-cowboy-side\": 63681,\n \"hat-wizard\": 63208,\n \"hdd\": 61600,\n \"head-side-cough\": 57441,\n \"head-side-cough-slash\": 57442,\n \"head-side-mask\": 57443,\n \"head-side-virus\": 57444,\n \"heading\": 61916,\n \"headphones\": 61477,\n \"headphones-alt\": 62863,\n \"headset\": 62864,\n \"heart\": 61444,\n \"heart-broken\": 63401,\n \"heartbeat\": 61982,\n \"helicopter\": 62771,\n \"highlighter\": 62865,\n \"hiking\": 63212,\n \"hippo\": 63213,\n \"hips\": 62546,\n \"hire-a-helper\": 62384,\n \"history\": 61914,\n \"hive\": 57471,\n \"hockey-puck\": 62547,\n \"holly-berry\": 63402,\n \"home\": 61461,\n \"hooli\": 62503,\n \"hornbill\": 62866,\n \"horse\": 63216,\n \"horse-head\": 63403,\n \"hospital\": 61688,\n \"hospital-alt\": 62589,\n \"hospital-symbol\": 62590,\n \"hospital-user\": 63501,\n \"hot-tub\": 62867,\n \"hotdog\": 63503,\n \"hotel\": 62868,\n \"hotjar\": 62385,\n \"hourglass\": 62036,\n \"hourglass-end\": 62035,\n \"hourglass-half\": 62034,\n \"hourglass-start\": 62033,\n \"house-damage\": 63217,\n \"house-user\": 57445,\n \"houzz\": 62076,\n \"hryvnia\": 63218,\n \"html5\": 61755,\n \"hubspot\": 62386,\n \"i-cursor\": 62022,\n \"ice-cream\": 63504,\n \"icicles\": 63405,\n \"icons\": 63597,\n \"id-badge\": 62145,\n \"id-card\": 62146,\n \"id-card-alt\": 62591,\n \"ideal\": 57363,\n \"igloo\": 63406,\n \"image\": 61502,\n \"images\": 62210,\n \"imdb\": 62168,\n \"inbox\": 61468,\n \"indent\": 61500,\n \"industry\": 62069,\n \"infinity\": 62772,\n \"info\": 61737,\n \"info-circle\": 61530,\n \"innosoft\": 57472,\n \"instagram\": 61805,\n \"instagram-square\": 57429,\n \"instalod\": 57473,\n \"intercom\": 63407,\n \"internet-explorer\": 62059,\n \"invision\": 63408,\n \"ioxhost\": 61960,\n \"italic\": 61491,\n \"itch-io\": 63546,\n \"itunes\": 62388,\n \"itunes-note\": 62389,\n \"java\": 62692,\n \"jedi\": 63081,\n \"jedi-order\": 62734,\n \"jenkins\": 62390,\n \"jira\": 63409,\n \"joget\": 62391,\n \"joint\": 62869,\n \"joomla\": 61866,\n \"journal-whills\": 63082,\n \"js\": 62392,\n \"js-square\": 62393,\n \"jsfiddle\": 61900,\n \"kaaba\": 63083,\n \"kaggle\": 62970,\n \"key\": 61572,\n \"keybase\": 62709,\n \"keyboard\": 61724,\n \"keycdn\": 62394,\n \"khanda\": 63085,\n \"kickstarter\": 62395,\n \"kickstarter-k\": 62396,\n \"kiss\": 62870,\n \"kiss-beam\": 62871,\n \"kiss-wink-heart\": 62872,\n \"kiwi-bird\": 62773,\n \"korvue\": 62511,\n \"landmark\": 63087,\n \"language\": 61867,\n \"laptop\": 61705,\n \"laptop-code\": 62972,\n \"laptop-house\": 57446,\n \"laptop-medical\": 63506,\n \"laravel\": 62397,\n \"lastfm\": 61954,\n \"lastfm-square\": 61955,\n \"laugh\": 62873,\n \"laugh-beam\": 62874,\n \"laugh-squint\": 62875,\n \"laugh-wink\": 62876,\n \"layer-group\": 62973,\n \"leaf\": 61548,\n \"leanpub\": 61970,\n \"lemon\": 61588,\n \"less\": 62493,\n \"less-than\": 62774,\n \"less-than-equal\": 62775,\n \"level-down-alt\": 62398,\n \"level-up-alt\": 62399,\n \"life-ring\": 61901,\n \"lightbulb\": 61675,\n \"line\": 62400,\n \"link\": 61633,\n \"linkedin\": 61580,\n \"linkedin-in\": 61665,\n \"linode\": 62136,\n \"linux\": 61820,\n \"lira-sign\": 61845,\n \"list\": 61498,\n \"list-alt\": 61474,\n \"list-ol\": 61643,\n \"list-ul\": 61642,\n \"location-arrow\": 61732,\n \"lock\": 61475,\n \"lock-open\": 62401,\n \"long-arrow-alt-down\": 62217,\n \"long-arrow-alt-left\": 62218,\n \"long-arrow-alt-right\": 62219,\n \"long-arrow-alt-up\": 62220,\n \"low-vision\": 62120,\n \"luggage-cart\": 62877,\n \"lungs\": 62980,\n \"lungs-virus\": 57447,\n \"lyft\": 62403,\n \"magento\": 62404,\n \"magic\": 61648,\n \"magnet\": 61558,\n \"mail-bulk\": 63092,\n \"mailchimp\": 62878,\n \"male\": 61827,\n \"mandalorian\": 62735,\n \"map\": 62073,\n \"map-marked\": 62879,\n \"map-marked-alt\": 62880,\n \"map-marker\": 61505,\n \"map-marker-alt\": 62405,\n \"map-pin\": 62070,\n \"map-signs\": 62071,\n \"markdown\": 62991,\n \"marker\": 62881,\n \"mars\": 61986,\n \"mars-double\": 61991,\n \"mars-stroke\": 61993,\n \"mars-stroke-h\": 61995,\n \"mars-stroke-v\": 61994,\n \"mask\": 63226,\n \"mastodon\": 62710,\n \"maxcdn\": 61750,\n \"mdb\": 63690,\n \"medal\": 62882,\n \"medapps\": 62406,\n \"medium\": 62010,\n \"medium-m\": 62407,\n \"medkit\": 61690,\n \"medrt\": 62408,\n \"meetup\": 62176,\n \"megaport\": 62883,\n \"meh\": 61722,\n \"meh-blank\": 62884,\n \"meh-rolling-eyes\": 62885,\n \"memory\": 62776,\n \"mendeley\": 63411,\n \"menorah\": 63094,\n \"mercury\": 61987,\n \"meteor\": 63315,\n \"microblog\": 57370,\n \"microchip\": 62171,\n \"microphone\": 61744,\n \"microphone-alt\": 62409,\n \"microphone-alt-slash\": 62777,\n \"microphone-slash\": 61745,\n \"microscope\": 62992,\n \"microsoft\": 62410,\n \"minus\": 61544,\n \"minus-circle\": 61526,\n \"minus-square\": 61766,\n \"mitten\": 63413,\n \"mix\": 62411,\n \"mixcloud\": 62089,\n \"mixer\": 57430,\n \"mizuni\": 62412,\n \"mobile\": 61707,\n \"mobile-alt\": 62413,\n \"modx\": 62085,\n \"monero\": 62416,\n \"money-bill\": 61654,\n \"money-bill-alt\": 62417,\n \"money-bill-wave\": 62778,\n \"money-bill-wave-alt\": 62779,\n \"money-check\": 62780,\n \"money-check-alt\": 62781,\n \"monument\": 62886,\n \"moon\": 61830,\n \"mortar-pestle\": 62887,\n \"mosque\": 63096,\n \"motorcycle\": 61980,\n \"mountain\": 63228,\n \"mouse\": 63692,\n \"mouse-pointer\": 62021,\n \"mug-hot\": 63414,\n \"music\": 61441,\n \"napster\": 62418,\n \"neos\": 62994,\n \"network-wired\": 63231,\n \"neuter\": 61996,\n \"newspaper\": 61930,\n \"nimblr\": 62888,\n \"node\": 62489,\n \"node-js\": 62419,\n \"not-equal\": 62782,\n \"notes-medical\": 62593,\n \"npm\": 62420,\n \"ns8\": 62421,\n \"nutritionix\": 62422,\n \"object-group\": 62023,\n \"object-ungroup\": 62024,\n \"octopus-deploy\": 57474,\n \"odnoklassniki\": 62051,\n \"odnoklassniki-square\": 62052,\n \"oil-can\": 62995,\n \"old-republic\": 62736,\n \"om\": 63097,\n \"opencart\": 62013,\n \"openid\": 61851,\n \"opera\": 62058,\n \"optin-monster\": 62012,\n \"orcid\": 63698,\n \"osi\": 62490,\n \"otter\": 63232,\n \"outdent\": 61499,\n \"page4\": 62423,\n \"pagelines\": 61836,\n \"pager\": 63509,\n \"paint-brush\": 61948,\n \"paint-roller\": 62890,\n \"palette\": 62783,\n \"palfed\": 62424,\n \"pallet\": 62594,\n \"paper-plane\": 61912,\n \"paperclip\": 61638,\n \"parachute-box\": 62669,\n \"paragraph\": 61917,\n \"parking\": 62784,\n \"passport\": 62891,\n \"pastafarianism\": 63099,\n \"paste\": 61674,\n \"patreon\": 62425,\n \"pause\": 61516,\n \"pause-circle\": 62091,\n \"paw\": 61872,\n \"paypal\": 61933,\n \"peace\": 63100,\n \"pen\": 62212,\n \"pen-alt\": 62213,\n \"pen-fancy\": 62892,\n \"pen-nib\": 62893,\n \"pen-square\": 61771,\n \"pencil-alt\": 62211,\n \"pencil-ruler\": 62894,\n \"penny-arcade\": 63236,\n \"people-arrows\": 57448,\n \"people-carry\": 62670,\n \"pepper-hot\": 63510,\n \"perbyte\": 57475,\n \"percent\": 62101,\n \"percentage\": 62785,\n \"periscope\": 62426,\n \"person-booth\": 63318,\n \"phabricator\": 62427,\n \"phoenix-framework\": 62428,\n \"phoenix-squadron\": 62737,\n \"phone\": 61589,\n \"phone-alt\": 63609,\n \"phone-slash\": 62429,\n \"phone-square\": 61592,\n \"phone-square-alt\": 63611,\n \"phone-volume\": 62112,\n \"photo-video\": 63612,\n \"php\": 62551,\n \"pied-piper\": 62126,\n \"pied-piper-alt\": 61864,\n \"pied-piper-hat\": 62693,\n \"pied-piper-pp\": 61863,\n \"pied-piper-square\": 57374,\n \"piggy-bank\": 62675,\n \"pills\": 62596,\n \"pinterest\": 61650,\n \"pinterest-p\": 62001,\n \"pinterest-square\": 61651,\n \"pizza-slice\": 63512,\n \"place-of-worship\": 63103,\n \"plane\": 61554,\n \"plane-arrival\": 62895,\n \"plane-departure\": 62896,\n \"plane-slash\": 57449,\n \"play\": 61515,\n \"play-circle\": 61764,\n \"playstation\": 62431,\n \"plug\": 61926,\n \"plus\": 61543,\n \"plus-circle\": 61525,\n \"plus-square\": 61694,\n \"podcast\": 62158,\n \"poll\": 63105,\n \"poll-h\": 63106,\n \"poo\": 62206,\n \"poo-storm\": 63322,\n \"poop\": 63001,\n \"portrait\": 62432,\n \"pound-sign\": 61780,\n \"power-off\": 61457,\n \"pray\": 63107,\n \"praying-hands\": 63108,\n \"prescription\": 62897,\n \"prescription-bottle\": 62597,\n \"prescription-bottle-alt\": 62598,\n \"print\": 61487,\n \"procedures\": 62599,\n \"product-hunt\": 62088,\n \"project-diagram\": 62786,\n \"pump-medical\": 57450,\n \"pump-soap\": 57451,\n \"pushed\": 62433,\n \"puzzle-piece\": 61742,\n \"python\": 62434,\n \"qq\": 61910,\n \"qrcode\": 61481,\n \"question\": 61736,\n \"question-circle\": 61529,\n \"quidditch\": 62552,\n \"quinscape\": 62553,\n \"quora\": 62148,\n \"quote-left\": 61709,\n \"quote-right\": 61710,\n \"quran\": 63111,\n \"r-project\": 62711,\n \"radiation\": 63417,\n \"radiation-alt\": 63418,\n \"rainbow\": 63323,\n \"random\": 61556,\n \"raspberry-pi\": 63419,\n \"ravelry\": 62169,\n \"react\": 62491,\n \"reacteurope\": 63325,\n \"readme\": 62677,\n \"rebel\": 61904,\n \"receipt\": 62787,\n \"record-vinyl\": 63705,\n \"recycle\": 61880,\n \"red-river\": 62435,\n \"reddit\": 61857,\n \"reddit-alien\": 62081,\n \"reddit-square\": 61858,\n \"redhat\": 63420,\n \"redo\": 61470,\n \"redo-alt\": 62201,\n \"registered\": 62045,\n \"remove-format\": 63613,\n \"renren\": 61835,\n \"reply\": 62437,\n \"reply-all\": 61730,\n \"replyd\": 62438,\n \"republican\": 63326,\n \"researchgate\": 62712,\n \"resolving\": 62439,\n \"restroom\": 63421,\n \"retweet\": 61561,\n \"rev\": 62898,\n \"ribbon\": 62678,\n \"ring\": 63243,\n \"road\": 61464,\n \"robot\": 62788,\n \"rocket\": 61749,\n \"rocketchat\": 62440,\n \"rockrms\": 62441,\n \"route\": 62679,\n \"rss\": 61598,\n \"rss-square\": 61763,\n \"ruble-sign\": 61784,\n \"ruler\": 62789,\n \"ruler-combined\": 62790,\n \"ruler-horizontal\": 62791,\n \"ruler-vertical\": 62792,\n \"running\": 63244,\n \"rupee-sign\": 61782,\n \"rust\": 57466,\n \"sad-cry\": 62899,\n \"sad-tear\": 62900,\n \"safari\": 62055,\n \"salesforce\": 63547,\n \"sass\": 62494,\n \"satellite\": 63423,\n \"satellite-dish\": 63424,\n \"save\": 61639,\n \"schlix\": 62442,\n \"school\": 62793,\n \"screwdriver\": 62794,\n \"scribd\": 62090,\n \"scroll\": 63246,\n \"sd-card\": 63426,\n \"search\": 61442,\n \"search-dollar\": 63112,\n \"search-location\": 63113,\n \"search-minus\": 61456,\n \"search-plus\": 61454,\n \"searchengin\": 62443,\n \"seedling\": 62680,\n \"sellcast\": 62170,\n \"sellsy\": 61971,\n \"server\": 62003,\n \"servicestack\": 62444,\n \"shapes\": 63007,\n \"share\": 61540,\n \"share-alt\": 61920,\n \"share-alt-square\": 61921,\n \"share-square\": 61773,\n \"shekel-sign\": 61963,\n \"shield-alt\": 62445,\n \"shield-virus\": 57452,\n \"ship\": 61978,\n \"shipping-fast\": 62603,\n \"shirtsinbulk\": 61972,\n \"shoe-prints\": 62795,\n \"shopify\": 57431,\n \"shopping-bag\": 62096,\n \"shopping-basket\": 62097,\n \"shopping-cart\": 61562,\n \"shopware\": 62901,\n \"shower\": 62156,\n \"shuttle-van\": 62902,\n \"sign\": 62681,\n \"sign-in-alt\": 62198,\n \"sign-language\": 62119,\n \"sign-out-alt\": 62197,\n \"signal\": 61458,\n \"signature\": 62903,\n \"sim-card\": 63428,\n \"simplybuilt\": 61973,\n \"sink\": 57453,\n \"sistrix\": 62446,\n \"sitemap\": 61672,\n \"sith\": 62738,\n \"skating\": 63429,\n \"sketch\": 63430,\n \"skiing\": 63433,\n \"skiing-nordic\": 63434,\n \"skull\": 62796,\n \"skull-crossbones\": 63252,\n \"skyatlas\": 61974,\n \"skype\": 61822,\n \"slack\": 61848,\n \"slack-hash\": 62447,\n \"slash\": 63253,\n \"sleigh\": 63436,\n \"sliders-h\": 61918,\n \"slideshare\": 61927,\n \"smile\": 61720,\n \"smile-beam\": 62904,\n \"smile-wink\": 62682,\n \"smog\": 63327,\n \"smoking\": 62605,\n \"smoking-ban\": 62797,\n \"sms\": 63437,\n \"snapchat\": 62123,\n \"snapchat-ghost\": 62124,\n \"snapchat-square\": 62125,\n \"snowboarding\": 63438,\n \"snowflake\": 62172,\n \"snowman\": 63440,\n \"snowplow\": 63442,\n \"soap\": 57454,\n \"socks\": 63126,\n \"solar-panel\": 62906,\n \"sort\": 61660,\n \"sort-alpha-down\": 61789,\n \"sort-alpha-down-alt\": 63617,\n \"sort-alpha-up\": 61790,\n \"sort-alpha-up-alt\": 63618,\n \"sort-amount-down\": 61792,\n \"sort-amount-down-alt\": 63620,\n \"sort-amount-up\": 61793,\n \"sort-amount-up-alt\": 63621,\n \"sort-down\": 61661,\n \"sort-numeric-down\": 61794,\n \"sort-numeric-down-alt\": 63622,\n \"sort-numeric-up\": 61795,\n \"sort-numeric-up-alt\": 63623,\n \"sort-up\": 61662,\n \"soundcloud\": 61886,\n \"sourcetree\": 63443,\n \"spa\": 62907,\n \"space-shuttle\": 61847,\n \"speakap\": 62451,\n \"speaker-deck\": 63548,\n \"spell-check\": 63633,\n \"spider\": 63255,\n \"spinner\": 61712,\n \"splotch\": 62908,\n \"spotify\": 61884,\n \"spray-can\": 62909,\n \"square\": 61640,\n \"square-full\": 62556,\n \"square-root-alt\": 63128,\n \"squarespace\": 62910,\n \"stack-exchange\": 61837,\n \"stack-overflow\": 61804,\n \"stackpath\": 63554,\n \"stamp\": 62911,\n \"star\": 61445,\n \"star-and-crescent\": 63129,\n \"star-half\": 61577,\n \"star-half-alt\": 62912,\n \"star-of-david\": 63130,\n \"star-of-life\": 63009,\n \"staylinked\": 62453,\n \"steam\": 61878,\n \"steam-square\": 61879,\n \"steam-symbol\": 62454,\n \"step-backward\": 61512,\n \"step-forward\": 61521,\n \"stethoscope\": 61681,\n \"sticker-mule\": 62455,\n \"sticky-note\": 62025,\n \"stop\": 61517,\n \"stop-circle\": 62093,\n \"stopwatch\": 62194,\n \"stopwatch-20\": 57455,\n \"store\": 62798,\n \"store-alt\": 62799,\n \"store-alt-slash\": 57456,\n \"store-slash\": 57457,\n \"strava\": 62504,\n \"stream\": 62800,\n \"street-view\": 61981,\n \"strikethrough\": 61644,\n \"stripe\": 62505,\n \"stripe-s\": 62506,\n \"stroopwafel\": 62801,\n \"studiovinari\": 62456,\n \"stumbleupon\": 61860,\n \"stumbleupon-circle\": 61859,\n \"subscript\": 61740,\n \"subway\": 62009,\n \"suitcase\": 61682,\n \"suitcase-rolling\": 62913,\n \"sun\": 61829,\n \"superpowers\": 62173,\n \"superscript\": 61739,\n \"supple\": 62457,\n \"surprise\": 62914,\n \"suse\": 63446,\n \"swatchbook\": 62915,\n \"swift\": 63713,\n \"swimmer\": 62916,\n \"swimming-pool\": 62917,\n \"symfony\": 63549,\n \"synagogue\": 63131,\n \"sync\": 61473,\n \"sync-alt\": 62193,\n \"syringe\": 62606,\n \"table\": 61646,\n \"table-tennis\": 62557,\n \"tablet\": 61706,\n \"tablet-alt\": 62458,\n \"tablets\": 62608,\n \"tachometer-alt\": 62461,\n \"tag\": 61483,\n \"tags\": 61484,\n \"tape\": 62683,\n \"tasks\": 61614,\n \"taxi\": 61882,\n \"teamspeak\": 62713,\n \"teeth\": 63022,\n \"teeth-open\": 63023,\n \"telegram\": 62150,\n \"telegram-plane\": 62462,\n \"temperature-high\": 63337,\n \"temperature-low\": 63339,\n \"tencent-weibo\": 61909,\n \"tenge\": 63447,\n \"terminal\": 61728,\n \"text-height\": 61492,\n \"text-width\": 61493,\n \"th\": 61450,\n \"th-large\": 61449,\n \"th-list\": 61451,\n \"the-red-yeti\": 63133,\n \"theater-masks\": 63024,\n \"themeco\": 62918,\n \"themeisle\": 62130,\n \"thermometer\": 62609,\n \"thermometer-empty\": 62155,\n \"thermometer-full\": 62151,\n \"thermometer-half\": 62153,\n \"thermometer-quarter\": 62154,\n \"thermometer-three-quarters\": 62152,\n \"think-peaks\": 63281,\n \"thumbs-down\": 61797,\n \"thumbs-up\": 61796,\n \"thumbtack\": 61581,\n \"ticket-alt\": 62463,\n \"tiktok\": 57467,\n \"times\": 61453,\n \"times-circle\": 61527,\n \"tint\": 61507,\n \"tint-slash\": 62919,\n \"tired\": 62920,\n \"toggle-off\": 61956,\n \"toggle-on\": 61957,\n \"toilet\": 63448,\n \"toilet-paper\": 63262,\n \"toilet-paper-slash\": 57458,\n \"toolbox\": 62802,\n \"tools\": 63449,\n \"tooth\": 62921,\n \"torah\": 63136,\n \"torii-gate\": 63137,\n \"tractor\": 63266,\n \"trade-federation\": 62739,\n \"trademark\": 62044,\n \"traffic-light\": 63031,\n \"trailer\": 57409,\n \"train\": 62008,\n \"tram\": 63450,\n \"transgender\": 61988,\n \"transgender-alt\": 61989,\n \"trash\": 61944,\n \"trash-alt\": 62189,\n \"trash-restore\": 63529,\n \"trash-restore-alt\": 63530,\n \"tree\": 61883,\n \"trello\": 61825,\n \"tripadvisor\": 62050,\n \"trophy\": 61585,\n \"truck\": 61649,\n \"truck-loading\": 62686,\n \"truck-monster\": 63035,\n \"truck-moving\": 62687,\n \"truck-pickup\": 63036,\n \"tshirt\": 62803,\n \"tty\": 61924,\n \"tumblr\": 61811,\n \"tumblr-square\": 61812,\n \"tv\": 62060,\n \"twitch\": 61928,\n \"twitter\": 61593,\n \"twitter-square\": 61569,\n \"typo3\": 62507,\n \"uber\": 62466,\n \"ubuntu\": 63455,\n \"uikit\": 62467,\n \"umbraco\": 63720,\n \"umbrella\": 61673,\n \"umbrella-beach\": 62922,\n \"uncharted\": 57476,\n \"underline\": 61645,\n \"undo\": 61666,\n \"undo-alt\": 62186,\n \"uniregistry\": 62468,\n \"unity\": 57417,\n \"universal-access\": 62106,\n \"university\": 61852,\n \"unlink\": 61735,\n \"unlock\": 61596,\n \"unlock-alt\": 61758,\n \"unsplash\": 57468,\n \"untappd\": 62469,\n \"upload\": 61587,\n \"ups\": 63456,\n \"usb\": 62087,\n \"user\": 61447,\n \"user-alt\": 62470,\n \"user-alt-slash\": 62714,\n \"user-astronaut\": 62715,\n \"user-check\": 62716,\n \"user-circle\": 62141,\n \"user-clock\": 62717,\n \"user-cog\": 62718,\n \"user-edit\": 62719,\n \"user-friends\": 62720,\n \"user-graduate\": 62721,\n \"user-injured\": 63272,\n \"user-lock\": 62722,\n \"user-md\": 61680,\n \"user-minus\": 62723,\n \"user-ninja\": 62724,\n \"user-nurse\": 63535,\n \"user-plus\": 62004,\n \"user-secret\": 61979,\n \"user-shield\": 62725,\n \"user-slash\": 62726,\n \"user-tag\": 62727,\n \"user-tie\": 62728,\n \"user-times\": 62005,\n \"users\": 61632,\n \"users-cog\": 62729,\n \"users-slash\": 57459,\n \"usps\": 63457,\n \"ussunnah\": 62471,\n \"utensil-spoon\": 62181,\n \"utensils\": 62183,\n \"vaadin\": 62472,\n \"vector-square\": 62923,\n \"venus\": 61985,\n \"venus-double\": 61990,\n \"venus-mars\": 61992,\n \"vest\": 57477,\n \"vest-patches\": 57478,\n \"viacoin\": 62007,\n \"viadeo\": 62121,\n \"viadeo-square\": 62122,\n \"vial\": 62610,\n \"vials\": 62611,\n \"viber\": 62473,\n \"video\": 61501,\n \"video-slash\": 62690,\n \"vihara\": 63143,\n \"vimeo\": 62474,\n \"vimeo-square\": 61844,\n \"vimeo-v\": 62077,\n \"vine\": 61898,\n \"virus\": 57460,\n \"virus-slash\": 57461,\n \"viruses\": 57462,\n \"vk\": 61833,\n \"vnv\": 62475,\n \"voicemail\": 63639,\n \"volleyball-ball\": 62559,\n \"volume-down\": 61479,\n \"volume-mute\": 63145,\n \"volume-off\": 61478,\n \"volume-up\": 61480,\n \"vote-yea\": 63346,\n \"vr-cardboard\": 63273,\n \"vuejs\": 62495,\n \"walking\": 62804,\n \"wallet\": 62805,\n \"warehouse\": 62612,\n \"watchman-monitoring\": 57479,\n \"water\": 63347,\n \"wave-square\": 63550,\n \"waze\": 63551,\n \"weebly\": 62924,\n \"weibo\": 61834,\n \"weight\": 62614,\n \"weight-hanging\": 62925,\n \"weixin\": 61911,\n \"whatsapp\": 62002,\n \"whatsapp-square\": 62476,\n \"wheelchair\": 61843,\n \"whmcs\": 62477,\n \"wifi\": 61931,\n \"wikipedia-w\": 62054,\n \"wind\": 63278,\n \"window-close\": 62480,\n \"window-maximize\": 62160,\n \"window-minimize\": 62161,\n \"window-restore\": 62162,\n \"windows\": 61818,\n \"wine-bottle\": 63279,\n \"wine-glass\": 62691,\n \"wine-glass-alt\": 62926,\n \"wix\": 62927,\n \"wizards-of-the-coast\": 63280,\n \"wodu\": 57480,\n \"wolf-pack-battalion\": 62740,\n \"won-sign\": 61785,\n \"wordpress\": 61850,\n \"wordpress-simple\": 62481,\n \"wpbeginner\": 62103,\n \"wpexplorer\": 62174,\n \"wpforms\": 62104,\n \"wpressr\": 62436,\n \"wrench\": 61613,\n \"x-ray\": 62615,\n \"xbox\": 62482,\n \"xing\": 61800,\n \"xing-square\": 61801,\n \"y-combinator\": 62011,\n \"yahoo\": 61854,\n \"yammer\": 63552,\n \"yandex\": 62483,\n \"yandex-international\": 62484,\n \"yarn\": 63459,\n \"yelp\": 61929,\n \"yen-sign\": 61783,\n \"yin-yang\": 63149,\n \"yoast\": 62129,\n \"youtube\": 61799,\n \"youtube-square\": 62513,\n \"zhihu\": 63039\n}","{\n \"brands\": [\n \"500px\",\n \"accessible-icon\",\n \"accusoft\",\n \"acquisitions-incorporated\",\n \"adn\",\n \"adversal\",\n \"affiliatetheme\",\n \"airbnb\",\n \"algolia\",\n \"alipay\",\n \"amazon-pay\",\n \"amazon\",\n \"amilia\",\n \"android\",\n \"angellist\",\n \"angrycreative\",\n \"angular\",\n \"app-store-ios\",\n \"app-store\",\n \"apper\",\n \"apple-pay\",\n \"apple\",\n \"artstation\",\n \"asymmetrik\",\n \"atlassian\",\n \"audible\",\n \"autoprefixer\",\n \"avianex\",\n \"aviato\",\n \"aws\",\n \"bandcamp\",\n \"battle-net\",\n \"behance-square\",\n \"behance\",\n \"bimobject\",\n \"bitbucket\",\n \"bitcoin\",\n \"bity\",\n \"black-tie\",\n \"blackberry\",\n \"blogger-b\",\n \"blogger\",\n \"bluetooth-b\",\n \"bluetooth\",\n \"bootstrap\",\n \"btc\",\n \"buffer\",\n \"buromobelexperte\",\n \"buy-n-large\",\n \"buysellads\",\n \"canadian-maple-leaf\",\n \"cc-amazon-pay\",\n \"cc-amex\",\n \"cc-apple-pay\",\n \"cc-diners-club\",\n \"cc-discover\",\n \"cc-jcb\",\n \"cc-mastercard\",\n \"cc-paypal\",\n \"cc-stripe\",\n \"cc-visa\",\n \"centercode\",\n \"centos\",\n \"chrome\",\n \"chromecast\",\n \"cloudflare\",\n \"cloudscale\",\n \"cloudsmith\",\n \"cloudversify\",\n \"codepen\",\n \"codiepie\",\n \"confluence\",\n \"connectdevelop\",\n \"contao\",\n \"cotton-bureau\",\n \"cpanel\",\n \"creative-commons-by\",\n \"creative-commons-nc-eu\",\n \"creative-commons-nc-jp\",\n \"creative-commons-nc\",\n \"creative-commons-nd\",\n \"creative-commons-pd-alt\",\n \"creative-commons-pd\",\n \"creative-commons-remix\",\n \"creative-commons-sa\",\n \"creative-commons-sampling-plus\",\n \"creative-commons-sampling\",\n \"creative-commons-share\",\n \"creative-commons-zero\",\n \"creative-commons\",\n \"critical-role\",\n \"css3-alt\",\n \"css3\",\n \"cuttlefish\",\n \"d-and-d-beyond\",\n \"d-and-d\",\n \"dailymotion\",\n \"dashcube\",\n \"deezer\",\n \"delicious\",\n \"deploydog\",\n \"deskpro\",\n \"dev\",\n \"deviantart\",\n \"dhl\",\n \"diaspora\",\n \"digg\",\n \"digital-ocean\",\n \"discord\",\n \"discourse\",\n \"dochub\",\n \"docker\",\n \"draft2digital\",\n \"dribbble-square\",\n \"dribbble\",\n \"dropbox\",\n \"drupal\",\n \"dyalog\",\n \"earlybirds\",\n \"ebay\",\n \"edge-legacy\",\n \"edge\",\n \"elementor\",\n \"ello\",\n \"ember\",\n \"empire\",\n \"envira\",\n \"erlang\",\n \"ethereum\",\n \"etsy\",\n \"evernote\",\n \"expeditedssl\",\n \"facebook-f\",\n \"facebook-messenger\",\n \"facebook-square\",\n \"facebook\",\n \"fantasy-flight-games\",\n \"fedex\",\n \"fedora\",\n \"figma\",\n \"firefox-browser\",\n \"firefox\",\n \"first-order-alt\",\n \"first-order\",\n \"firstdraft\",\n \"flickr\",\n \"flipboard\",\n \"fly\",\n \"font-awesome-alt\",\n \"font-awesome-flag\",\n \"font-awesome-logo-full\",\n \"font-awesome\",\n \"fonticons-fi\",\n \"fonticons\",\n \"fort-awesome-alt\",\n \"fort-awesome\",\n \"forumbee\",\n \"foursquare\",\n \"free-code-camp\",\n \"freebsd\",\n \"fulcrum\",\n \"galactic-republic\",\n \"galactic-senate\",\n \"get-pocket\",\n \"gg-circle\",\n \"gg\",\n \"git-alt\",\n \"git-square\",\n \"git\",\n \"github-alt\",\n \"github-square\",\n \"github\",\n \"gitkraken\",\n \"gitlab\",\n \"gitter\",\n \"glide-g\",\n \"glide\",\n \"gofore\",\n \"goodreads-g\",\n \"goodreads\",\n \"google-drive\",\n \"google-pay\",\n \"google-play\",\n \"google-plus-g\",\n \"google-plus-square\",\n \"google-plus\",\n \"google-wallet\",\n \"google\",\n \"gratipay\",\n \"grav\",\n \"gripfire\",\n \"grunt\",\n \"guilded\",\n \"gulp\",\n \"hacker-news-square\",\n \"hacker-news\",\n \"hackerrank\",\n \"hips\",\n \"hire-a-helper\",\n \"hive\",\n \"hooli\",\n \"hornbill\",\n \"hotjar\",\n \"houzz\",\n \"html5\",\n \"hubspot\",\n \"ideal\",\n \"imdb\",\n \"innosoft\",\n \"instagram-square\",\n \"instagram\",\n \"instalod\",\n \"intercom\",\n \"internet-explorer\",\n \"invision\",\n \"ioxhost\",\n \"itch-io\",\n \"itunes-note\",\n \"itunes\",\n \"java\",\n \"jedi-order\",\n \"jenkins\",\n \"jira\",\n \"joget\",\n \"joomla\",\n \"js-square\",\n \"js\",\n \"jsfiddle\",\n \"kaggle\",\n \"keybase\",\n \"keycdn\",\n \"kickstarter-k\",\n \"kickstarter\",\n \"korvue\",\n \"laravel\",\n \"lastfm-square\",\n \"lastfm\",\n \"leanpub\",\n \"less\",\n \"line\",\n \"linkedin-in\",\n \"linkedin\",\n \"linode\",\n \"linux\",\n \"lyft\",\n \"magento\",\n \"mailchimp\",\n \"mandalorian\",\n \"markdown\",\n \"mastodon\",\n \"maxcdn\",\n \"mdb\",\n \"medapps\",\n \"medium-m\",\n \"medium\",\n \"medrt\",\n \"meetup\",\n \"megaport\",\n \"mendeley\",\n \"microblog\",\n \"microsoft\",\n \"mix\",\n \"mixcloud\",\n \"mixer\",\n \"mizuni\",\n \"modx\",\n \"monero\",\n \"napster\",\n \"neos\",\n \"nimblr\",\n \"node-js\",\n \"node\",\n \"npm\",\n \"ns8\",\n \"nutritionix\",\n \"octopus-deploy\",\n \"odnoklassniki-square\",\n \"odnoklassniki\",\n \"old-republic\",\n \"opencart\",\n \"openid\",\n \"opera\",\n \"optin-monster\",\n \"orcid\",\n \"osi\",\n \"page4\",\n \"pagelines\",\n \"palfed\",\n \"patreon\",\n \"paypal\",\n \"penny-arcade\",\n \"perbyte\",\n \"periscope\",\n \"phabricator\",\n \"phoenix-framework\",\n \"phoenix-squadron\",\n \"php\",\n \"pied-piper-alt\",\n \"pied-piper-hat\",\n \"pied-piper-pp\",\n \"pied-piper-square\",\n \"pied-piper\",\n \"pinterest-p\",\n \"pinterest-square\",\n \"pinterest\",\n \"playstation\",\n \"product-hunt\",\n \"pushed\",\n \"python\",\n \"qq\",\n \"quinscape\",\n \"quora\",\n \"r-project\",\n \"raspberry-pi\",\n \"ravelry\",\n \"react\",\n \"reacteurope\",\n \"readme\",\n \"rebel\",\n \"red-river\",\n \"reddit-alien\",\n \"reddit-square\",\n \"reddit\",\n \"redhat\",\n \"renren\",\n \"replyd\",\n \"researchgate\",\n \"resolving\",\n \"rev\",\n \"rocketchat\",\n \"rockrms\",\n \"rust\",\n \"safari\",\n \"salesforce\",\n \"sass\",\n \"schlix\",\n \"scribd\",\n \"searchengin\",\n \"sellcast\",\n \"sellsy\",\n \"servicestack\",\n \"shirtsinbulk\",\n \"shopify\",\n \"shopware\",\n \"simplybuilt\",\n \"sistrix\",\n \"sith\",\n \"sketch\",\n \"skyatlas\",\n \"skype\",\n \"slack-hash\",\n \"slack\",\n \"slideshare\",\n \"snapchat-ghost\",\n \"snapchat-square\",\n \"snapchat\",\n \"soundcloud\",\n \"sourcetree\",\n \"speakap\",\n \"speaker-deck\",\n \"spotify\",\n \"squarespace\",\n \"stack-exchange\",\n \"stack-overflow\",\n \"stackpath\",\n \"staylinked\",\n \"steam-square\",\n \"steam-symbol\",\n \"steam\",\n \"sticker-mule\",\n \"strava\",\n \"stripe-s\",\n \"stripe\",\n \"studiovinari\",\n \"stumbleupon-circle\",\n \"stumbleupon\",\n \"superpowers\",\n \"supple\",\n \"suse\",\n \"swift\",\n \"symfony\",\n \"teamspeak\",\n \"telegram-plane\",\n \"telegram\",\n \"tencent-weibo\",\n \"the-red-yeti\",\n \"themeco\",\n \"themeisle\",\n \"think-peaks\",\n \"tiktok\",\n \"trade-federation\",\n \"trello\",\n \"tripadvisor\",\n \"tumblr-square\",\n \"tumblr\",\n \"twitch\",\n \"twitter-square\",\n \"twitter\",\n \"typo3\",\n \"uber\",\n \"ubuntu\",\n \"uikit\",\n \"umbraco\",\n \"uncharted\",\n \"uniregistry\",\n \"unity\",\n \"unsplash\",\n \"untappd\",\n \"ups\",\n \"usb\",\n \"usps\",\n \"ussunnah\",\n \"vaadin\",\n \"viacoin\",\n \"viadeo-square\",\n \"viadeo\",\n \"viber\",\n \"vimeo-square\",\n \"vimeo-v\",\n \"vimeo\",\n \"vine\",\n \"vk\",\n \"vnv\",\n \"vuejs\",\n \"watchman-monitoring\",\n \"waze\",\n \"weebly\",\n \"weibo\",\n \"weixin\",\n \"whatsapp-square\",\n \"whatsapp\",\n \"whmcs\",\n \"wikipedia-w\",\n \"windows\",\n \"wix\",\n \"wizards-of-the-coast\",\n \"wodu\",\n \"wolf-pack-battalion\",\n \"wordpress-simple\",\n \"wordpress\",\n \"wpbeginner\",\n \"wpexplorer\",\n \"wpforms\",\n \"wpressr\",\n \"xbox\",\n \"xing-square\",\n \"xing\",\n \"y-combinator\",\n \"yahoo\",\n \"yammer\",\n \"yandex-international\",\n \"yandex\",\n \"yarn\",\n \"yelp\",\n \"yoast\",\n \"youtube-square\",\n \"youtube\",\n \"zhihu\"\n ],\n \"regular\": [\n \"address-book\",\n \"address-card\",\n \"angry\",\n \"arrow-alt-circle-down\",\n \"arrow-alt-circle-left\",\n \"arrow-alt-circle-right\",\n \"arrow-alt-circle-up\",\n \"bell-slash\",\n \"bell\",\n \"bookmark\",\n \"building\",\n \"calendar-alt\",\n \"calendar-check\",\n \"calendar-minus\",\n \"calendar-plus\",\n \"calendar-times\",\n \"calendar\",\n \"caret-square-down\",\n \"caret-square-left\",\n \"caret-square-right\",\n \"caret-square-up\",\n \"chart-bar\",\n \"check-circle\",\n \"check-square\",\n \"circle\",\n \"clipboard\",\n \"clock\",\n \"clone\",\n \"closed-captioning\",\n \"comment-alt\",\n \"comment-dots\",\n \"comment\",\n \"comments\",\n \"compass\",\n \"copy\",\n \"copyright\",\n \"credit-card\",\n \"dizzy\",\n \"dot-circle\",\n \"edit\",\n \"envelope-open\",\n \"envelope\",\n \"eye-slash\",\n \"eye\",\n \"file-alt\",\n \"file-archive\",\n \"file-audio\",\n \"file-code\",\n \"file-excel\",\n \"file-image\",\n \"file-pdf\",\n \"file-powerpoint\",\n \"file-video\",\n \"file-word\",\n \"file\",\n \"flag\",\n \"flushed\",\n \"folder-open\",\n \"folder\",\n \"font-awesome-logo-full\",\n \"frown-open\",\n \"frown\",\n \"futbol\",\n \"gem\",\n \"grimace\",\n \"grin-alt\",\n \"grin-beam-sweat\",\n \"grin-beam\",\n \"grin-hearts\",\n \"grin-squint-tears\",\n \"grin-squint\",\n \"grin-stars\",\n \"grin-tears\",\n \"grin-tongue-squint\",\n \"grin-tongue-wink\",\n \"grin-tongue\",\n \"grin-wink\",\n \"grin\",\n \"hand-lizard\",\n \"hand-paper\",\n \"hand-peace\",\n \"hand-point-down\",\n \"hand-point-left\",\n \"hand-point-right\",\n \"hand-point-up\",\n \"hand-pointer\",\n \"hand-rock\",\n \"hand-scissors\",\n \"hand-spock\",\n \"handshake\",\n \"hdd\",\n \"heart\",\n \"hospital\",\n \"hourglass\",\n \"id-badge\",\n \"id-card\",\n \"image\",\n \"images\",\n \"keyboard\",\n \"kiss-beam\",\n \"kiss-wink-heart\",\n \"kiss\",\n \"laugh-beam\",\n \"laugh-squint\",\n \"laugh-wink\",\n \"laugh\",\n \"lemon\",\n \"life-ring\",\n \"lightbulb\",\n \"list-alt\",\n \"map\",\n \"meh-blank\",\n \"meh-rolling-eyes\",\n \"meh\",\n \"minus-square\",\n \"money-bill-alt\",\n \"moon\",\n \"newspaper\",\n \"object-group\",\n \"object-ungroup\",\n \"paper-plane\",\n \"pause-circle\",\n \"play-circle\",\n \"plus-square\",\n \"question-circle\",\n \"registered\",\n \"sad-cry\",\n \"sad-tear\",\n \"save\",\n \"share-square\",\n \"smile-beam\",\n \"smile-wink\",\n \"smile\",\n \"snowflake\",\n \"square\",\n \"star-half\",\n \"star\",\n \"sticky-note\",\n \"stop-circle\",\n \"sun\",\n \"surprise\",\n \"thumbs-down\",\n \"thumbs-up\",\n \"times-circle\",\n \"tired\",\n \"trash-alt\",\n \"user-circle\",\n \"user\",\n \"window-close\",\n \"window-maximize\",\n \"window-minimize\",\n \"window-restore\"\n ],\n \"solid\": [\n \"ad\",\n \"address-book\",\n \"address-card\",\n \"adjust\",\n \"air-freshener\",\n \"align-center\",\n \"align-justify\",\n \"align-left\",\n \"align-right\",\n \"allergies\",\n \"ambulance\",\n \"american-sign-language-interpreting\",\n \"anchor\",\n \"angle-double-down\",\n \"angle-double-left\",\n \"angle-double-right\",\n \"angle-double-up\",\n \"angle-down\",\n \"angle-left\",\n \"angle-right\",\n \"angle-up\",\n \"angry\",\n \"ankh\",\n \"apple-alt\",\n \"archive\",\n \"archway\",\n \"arrow-alt-circle-down\",\n \"arrow-alt-circle-left\",\n \"arrow-alt-circle-right\",\n \"arrow-alt-circle-up\",\n \"arrow-circle-down\",\n \"arrow-circle-left\",\n \"arrow-circle-right\",\n \"arrow-circle-up\",\n \"arrow-down\",\n \"arrow-left\",\n \"arrow-right\",\n \"arrow-up\",\n \"arrows-alt-h\",\n \"arrows-alt-v\",\n \"arrows-alt\",\n \"assistive-listening-systems\",\n \"asterisk\",\n \"at\",\n \"atlas\",\n \"atom\",\n \"audio-description\",\n \"award\",\n \"baby-carriage\",\n \"baby\",\n \"backspace\",\n \"backward\",\n \"bacon\",\n \"bacteria\",\n \"bacterium\",\n \"bahai\",\n \"balance-scale-left\",\n \"balance-scale-right\",\n \"balance-scale\",\n \"ban\",\n \"band-aid\",\n \"barcode\",\n \"bars\",\n \"baseball-ball\",\n \"basketball-ball\",\n \"bath\",\n \"battery-empty\",\n \"battery-full\",\n \"battery-half\",\n \"battery-quarter\",\n \"battery-three-quarters\",\n \"bed\",\n \"beer\",\n \"bell-slash\",\n \"bell\",\n \"bezier-curve\",\n \"bible\",\n \"bicycle\",\n \"biking\",\n \"binoculars\",\n \"biohazard\",\n \"birthday-cake\",\n \"blender-phone\",\n \"blender\",\n \"blind\",\n \"blog\",\n \"bold\",\n \"bolt\",\n \"bomb\",\n \"bone\",\n \"bong\",\n \"book-dead\",\n \"book-medical\",\n \"book-open\",\n \"book-reader\",\n \"book\",\n \"bookmark\",\n \"border-all\",\n \"border-none\",\n \"border-style\",\n \"bowling-ball\",\n \"box-open\",\n \"box-tissue\",\n \"box\",\n \"boxes\",\n \"braille\",\n \"brain\",\n \"bread-slice\",\n \"briefcase-medical\",\n \"briefcase\",\n \"broadcast-tower\",\n \"broom\",\n \"brush\",\n \"bug\",\n \"building\",\n \"bullhorn\",\n \"bullseye\",\n \"burn\",\n \"bus-alt\",\n \"bus\",\n \"business-time\",\n \"calculator\",\n \"calendar-alt\",\n \"calendar-check\",\n \"calendar-day\",\n \"calendar-minus\",\n \"calendar-plus\",\n \"calendar-times\",\n \"calendar-week\",\n \"calendar\",\n \"camera-retro\",\n \"camera\",\n \"campground\",\n \"candy-cane\",\n \"cannabis\",\n \"capsules\",\n \"car-alt\",\n \"car-battery\",\n \"car-crash\",\n \"car-side\",\n \"car\",\n \"caravan\",\n \"caret-down\",\n \"caret-left\",\n \"caret-right\",\n \"caret-square-down\",\n \"caret-square-left\",\n \"caret-square-right\",\n \"caret-square-up\",\n \"caret-up\",\n \"carrot\",\n \"cart-arrow-down\",\n \"cart-plus\",\n \"cash-register\",\n \"cat\",\n \"certificate\",\n \"chair\",\n \"chalkboard-teacher\",\n \"chalkboard\",\n \"charging-station\",\n \"chart-area\",\n \"chart-bar\",\n \"chart-line\",\n \"chart-pie\",\n \"check-circle\",\n \"check-double\",\n \"check-square\",\n \"check\",\n \"cheese\",\n \"chess-bishop\",\n \"chess-board\",\n \"chess-king\",\n \"chess-knight\",\n \"chess-pawn\",\n \"chess-queen\",\n \"chess-rook\",\n \"chess\",\n \"chevron-circle-down\",\n \"chevron-circle-left\",\n \"chevron-circle-right\",\n \"chevron-circle-up\",\n \"chevron-down\",\n \"chevron-left\",\n \"chevron-right\",\n \"chevron-up\",\n \"child\",\n \"church\",\n \"circle-notch\",\n \"circle\",\n \"city\",\n \"clinic-medical\",\n \"clipboard-check\",\n \"clipboard-list\",\n \"clipboard\",\n \"clock\",\n \"clone\",\n \"closed-captioning\",\n \"cloud-download-alt\",\n \"cloud-meatball\",\n \"cloud-moon-rain\",\n \"cloud-moon\",\n \"cloud-rain\",\n \"cloud-showers-heavy\",\n \"cloud-sun-rain\",\n \"cloud-sun\",\n \"cloud-upload-alt\",\n \"cloud\",\n \"cocktail\",\n \"code-branch\",\n \"code\",\n \"coffee\",\n \"cog\",\n \"cogs\",\n \"coins\",\n \"columns\",\n \"comment-alt\",\n \"comment-dollar\",\n \"comment-dots\",\n \"comment-medical\",\n \"comment-slash\",\n \"comment\",\n \"comments-dollar\",\n \"comments\",\n \"compact-disc\",\n \"compass\",\n \"compress-alt\",\n \"compress-arrows-alt\",\n \"compress\",\n \"concierge-bell\",\n \"cookie-bite\",\n \"cookie\",\n \"copy\",\n \"copyright\",\n \"couch\",\n \"credit-card\",\n \"crop-alt\",\n \"crop\",\n \"cross\",\n \"crosshairs\",\n \"crow\",\n \"crown\",\n \"crutch\",\n \"cube\",\n \"cubes\",\n \"cut\",\n \"database\",\n \"deaf\",\n \"democrat\",\n \"desktop\",\n \"dharmachakra\",\n \"diagnoses\",\n \"dice-d20\",\n \"dice-d6\",\n \"dice-five\",\n \"dice-four\",\n \"dice-one\",\n \"dice-six\",\n \"dice-three\",\n \"dice-two\",\n \"dice\",\n \"digital-tachograph\",\n \"directions\",\n \"disease\",\n \"divide\",\n \"dizzy\",\n \"dna\",\n \"dog\",\n \"dollar-sign\",\n \"dolly-flatbed\",\n \"dolly\",\n \"donate\",\n \"door-closed\",\n \"door-open\",\n \"dot-circle\",\n \"dove\",\n \"download\",\n \"drafting-compass\",\n \"dragon\",\n \"draw-polygon\",\n \"drum-steelpan\",\n \"drum\",\n \"drumstick-bite\",\n \"dumbbell\",\n \"dumpster-fire\",\n \"dumpster\",\n \"dungeon\",\n \"edit\",\n \"egg\",\n \"eject\",\n \"ellipsis-h\",\n \"ellipsis-v\",\n \"envelope-open-text\",\n \"envelope-open\",\n \"envelope-square\",\n \"envelope\",\n \"equals\",\n \"eraser\",\n \"ethernet\",\n \"euro-sign\",\n \"exchange-alt\",\n \"exclamation-circle\",\n \"exclamation-triangle\",\n \"exclamation\",\n \"expand-alt\",\n \"expand-arrows-alt\",\n \"expand\",\n \"external-link-alt\",\n \"external-link-square-alt\",\n \"eye-dropper\",\n \"eye-slash\",\n \"eye\",\n \"fan\",\n \"fast-backward\",\n \"fast-forward\",\n \"faucet\",\n \"fax\",\n \"feather-alt\",\n \"feather\",\n \"female\",\n \"fighter-jet\",\n \"file-alt\",\n \"file-archive\",\n \"file-audio\",\n \"file-code\",\n \"file-contract\",\n \"file-csv\",\n \"file-download\",\n \"file-excel\",\n \"file-export\",\n \"file-image\",\n \"file-import\",\n \"file-invoice-dollar\",\n \"file-invoice\",\n \"file-medical-alt\",\n \"file-medical\",\n \"file-pdf\",\n \"file-powerpoint\",\n \"file-prescription\",\n \"file-signature\",\n \"file-upload\",\n \"file-video\",\n \"file-word\",\n \"file\",\n \"fill-drip\",\n \"fill\",\n \"film\",\n \"filter\",\n \"fingerprint\",\n \"fire-alt\",\n \"fire-extinguisher\",\n \"fire\",\n \"first-aid\",\n \"fish\",\n \"fist-raised\",\n \"flag-checkered\",\n \"flag-usa\",\n \"flag\",\n \"flask\",\n \"flushed\",\n \"folder-minus\",\n \"folder-open\",\n \"folder-plus\",\n \"folder\",\n \"font-awesome-logo-full\",\n \"font\",\n \"football-ball\",\n \"forward\",\n \"frog\",\n \"frown-open\",\n \"frown\",\n \"funnel-dollar\",\n \"futbol\",\n \"gamepad\",\n \"gas-pump\",\n \"gavel\",\n \"gem\",\n \"genderless\",\n \"ghost\",\n \"gift\",\n \"gifts\",\n \"glass-cheers\",\n \"glass-martini-alt\",\n \"glass-martini\",\n \"glass-whiskey\",\n \"glasses\",\n \"globe-africa\",\n \"globe-americas\",\n \"globe-asia\",\n \"globe-europe\",\n \"globe\",\n \"golf-ball\",\n \"gopuram\",\n \"graduation-cap\",\n \"greater-than-equal\",\n \"greater-than\",\n \"grimace\",\n \"grin-alt\",\n \"grin-beam-sweat\",\n \"grin-beam\",\n \"grin-hearts\",\n \"grin-squint-tears\",\n \"grin-squint\",\n \"grin-stars\",\n \"grin-tears\",\n \"grin-tongue-squint\",\n \"grin-tongue-wink\",\n \"grin-tongue\",\n \"grin-wink\",\n \"grin\",\n \"grip-horizontal\",\n \"grip-lines-vertical\",\n \"grip-lines\",\n \"grip-vertical\",\n \"guitar\",\n \"h-square\",\n \"hamburger\",\n \"hammer\",\n \"hamsa\",\n \"hand-holding-heart\",\n \"hand-holding-medical\",\n \"hand-holding-usd\",\n \"hand-holding-water\",\n \"hand-holding\",\n \"hand-lizard\",\n \"hand-middle-finger\",\n \"hand-paper\",\n \"hand-peace\",\n \"hand-point-down\",\n \"hand-point-left\",\n \"hand-point-right\",\n \"hand-point-up\",\n \"hand-pointer\",\n \"hand-rock\",\n \"hand-scissors\",\n \"hand-sparkles\",\n \"hand-spock\",\n \"hands-helping\",\n \"hands-wash\",\n \"hands\",\n \"handshake-alt-slash\",\n \"handshake-slash\",\n \"handshake\",\n \"hanukiah\",\n \"hard-hat\",\n \"hashtag\",\n \"hat-cowboy-side\",\n \"hat-cowboy\",\n \"hat-wizard\",\n \"hdd\",\n \"head-side-cough-slash\",\n \"head-side-cough\",\n \"head-side-mask\",\n \"head-side-virus\",\n \"heading\",\n \"headphones-alt\",\n \"headphones\",\n \"headset\",\n \"heart-broken\",\n \"heart\",\n \"heartbeat\",\n \"helicopter\",\n \"highlighter\",\n \"hiking\",\n \"hippo\",\n \"history\",\n \"hockey-puck\",\n \"holly-berry\",\n \"home\",\n \"horse-head\",\n \"horse\",\n \"hospital-alt\",\n \"hospital-symbol\",\n \"hospital-user\",\n \"hospital\",\n \"hot-tub\",\n \"hotdog\",\n \"hotel\",\n \"hourglass-end\",\n \"hourglass-half\",\n \"hourglass-start\",\n \"hourglass\",\n \"house-damage\",\n \"house-user\",\n \"hryvnia\",\n \"i-cursor\",\n \"ice-cream\",\n \"icicles\",\n \"icons\",\n \"id-badge\",\n \"id-card-alt\",\n \"id-card\",\n \"igloo\",\n \"image\",\n \"images\",\n \"inbox\",\n \"indent\",\n \"industry\",\n \"infinity\",\n \"info-circle\",\n \"info\",\n \"italic\",\n \"jedi\",\n \"joint\",\n \"journal-whills\",\n \"kaaba\",\n \"key\",\n \"keyboard\",\n \"khanda\",\n \"kiss-beam\",\n \"kiss-wink-heart\",\n \"kiss\",\n \"kiwi-bird\",\n \"landmark\",\n \"language\",\n \"laptop-code\",\n \"laptop-house\",\n \"laptop-medical\",\n \"laptop\",\n \"laugh-beam\",\n \"laugh-squint\",\n \"laugh-wink\",\n \"laugh\",\n \"layer-group\",\n \"leaf\",\n \"lemon\",\n \"less-than-equal\",\n \"less-than\",\n \"level-down-alt\",\n \"level-up-alt\",\n \"life-ring\",\n \"lightbulb\",\n \"link\",\n \"lira-sign\",\n \"list-alt\",\n \"list-ol\",\n \"list-ul\",\n \"list\",\n \"location-arrow\",\n \"lock-open\",\n \"lock\",\n \"long-arrow-alt-down\",\n \"long-arrow-alt-left\",\n \"long-arrow-alt-right\",\n \"long-arrow-alt-up\",\n \"low-vision\",\n \"luggage-cart\",\n \"lungs-virus\",\n \"lungs\",\n \"magic\",\n \"magnet\",\n \"mail-bulk\",\n \"male\",\n \"map-marked-alt\",\n \"map-marked\",\n \"map-marker-alt\",\n \"map-marker\",\n \"map-pin\",\n \"map-signs\",\n \"map\",\n \"marker\",\n \"mars-double\",\n \"mars-stroke-h\",\n \"mars-stroke-v\",\n \"mars-stroke\",\n \"mars\",\n \"mask\",\n \"medal\",\n \"medkit\",\n \"meh-blank\",\n \"meh-rolling-eyes\",\n \"meh\",\n \"memory\",\n \"menorah\",\n \"mercury\",\n \"meteor\",\n \"microchip\",\n \"microphone-alt-slash\",\n \"microphone-alt\",\n \"microphone-slash\",\n \"microphone\",\n \"microscope\",\n \"minus-circle\",\n \"minus-square\",\n \"minus\",\n \"mitten\",\n \"mobile-alt\",\n \"mobile\",\n \"money-bill-alt\",\n \"money-bill-wave-alt\",\n \"money-bill-wave\",\n \"money-bill\",\n \"money-check-alt\",\n \"money-check\",\n \"monument\",\n \"moon\",\n \"mortar-pestle\",\n \"mosque\",\n \"motorcycle\",\n \"mountain\",\n \"mouse-pointer\",\n \"mouse\",\n \"mug-hot\",\n \"music\",\n \"network-wired\",\n \"neuter\",\n \"newspaper\",\n \"not-equal\",\n \"notes-medical\",\n \"object-group\",\n \"object-ungroup\",\n \"oil-can\",\n \"om\",\n \"otter\",\n \"outdent\",\n \"pager\",\n \"paint-brush\",\n \"paint-roller\",\n \"palette\",\n \"pallet\",\n \"paper-plane\",\n \"paperclip\",\n \"parachute-box\",\n \"paragraph\",\n \"parking\",\n \"passport\",\n \"pastafarianism\",\n \"paste\",\n \"pause-circle\",\n \"pause\",\n \"paw\",\n \"peace\",\n \"pen-alt\",\n \"pen-fancy\",\n \"pen-nib\",\n \"pen-square\",\n \"pen\",\n \"pencil-alt\",\n \"pencil-ruler\",\n \"people-arrows\",\n \"people-carry\",\n \"pepper-hot\",\n \"percent\",\n \"percentage\",\n \"person-booth\",\n \"phone-alt\",\n \"phone-slash\",\n \"phone-square-alt\",\n \"phone-square\",\n \"phone-volume\",\n \"phone\",\n \"photo-video\",\n \"piggy-bank\",\n \"pills\",\n \"pizza-slice\",\n \"place-of-worship\",\n \"plane-arrival\",\n \"plane-departure\",\n \"plane-slash\",\n \"plane\",\n \"play-circle\",\n \"play\",\n \"plug\",\n \"plus-circle\",\n \"plus-square\",\n \"plus\",\n \"podcast\",\n \"poll-h\",\n \"poll\",\n \"poo-storm\",\n \"poo\",\n \"poop\",\n \"portrait\",\n \"pound-sign\",\n \"power-off\",\n \"pray\",\n \"praying-hands\",\n \"prescription-bottle-alt\",\n \"prescription-bottle\",\n \"prescription\",\n \"print\",\n \"procedures\",\n \"project-diagram\",\n \"pump-medical\",\n \"pump-soap\",\n \"puzzle-piece\",\n \"qrcode\",\n \"question-circle\",\n \"question\",\n \"quidditch\",\n \"quote-left\",\n \"quote-right\",\n \"quran\",\n \"radiation-alt\",\n \"radiation\",\n \"rainbow\",\n \"random\",\n \"receipt\",\n \"record-vinyl\",\n \"recycle\",\n \"redo-alt\",\n \"redo\",\n \"registered\",\n \"remove-format\",\n \"reply-all\",\n \"reply\",\n \"republican\",\n \"restroom\",\n \"retweet\",\n \"ribbon\",\n \"ring\",\n \"road\",\n \"robot\",\n \"rocket\",\n \"route\",\n \"rss-square\",\n \"rss\",\n \"ruble-sign\",\n \"ruler-combined\",\n \"ruler-horizontal\",\n \"ruler-vertical\",\n \"ruler\",\n \"running\",\n \"rupee-sign\",\n \"sad-cry\",\n \"sad-tear\",\n \"satellite-dish\",\n \"satellite\",\n \"save\",\n \"school\",\n \"screwdriver\",\n \"scroll\",\n \"sd-card\",\n \"search-dollar\",\n \"search-location\",\n \"search-minus\",\n \"search-plus\",\n \"search\",\n \"seedling\",\n \"server\",\n \"shapes\",\n \"share-alt-square\",\n \"share-alt\",\n \"share-square\",\n \"share\",\n \"shekel-sign\",\n \"shield-alt\",\n \"shield-virus\",\n \"ship\",\n \"shipping-fast\",\n \"shoe-prints\",\n \"shopping-bag\",\n \"shopping-basket\",\n \"shopping-cart\",\n \"shower\",\n \"shuttle-van\",\n \"sign-in-alt\",\n \"sign-language\",\n \"sign-out-alt\",\n \"sign\",\n \"signal\",\n \"signature\",\n \"sim-card\",\n \"sink\",\n \"sitemap\",\n \"skating\",\n \"skiing-nordic\",\n \"skiing\",\n \"skull-crossbones\",\n \"skull\",\n \"slash\",\n \"sleigh\",\n \"sliders-h\",\n \"smile-beam\",\n \"smile-wink\",\n \"smile\",\n \"smog\",\n \"smoking-ban\",\n \"smoking\",\n \"sms\",\n \"snowboarding\",\n \"snowflake\",\n \"snowman\",\n \"snowplow\",\n \"soap\",\n \"socks\",\n \"solar-panel\",\n \"sort-alpha-down-alt\",\n \"sort-alpha-down\",\n \"sort-alpha-up-alt\",\n \"sort-alpha-up\",\n \"sort-amount-down-alt\",\n \"sort-amount-down\",\n \"sort-amount-up-alt\",\n \"sort-amount-up\",\n \"sort-down\",\n \"sort-numeric-down-alt\",\n \"sort-numeric-down\",\n \"sort-numeric-up-alt\",\n \"sort-numeric-up\",\n \"sort-up\",\n \"sort\",\n \"spa\",\n \"space-shuttle\",\n \"spell-check\",\n \"spider\",\n \"spinner\",\n \"splotch\",\n \"spray-can\",\n \"square-full\",\n \"square-root-alt\",\n \"square\",\n \"stamp\",\n \"star-and-crescent\",\n \"star-half-alt\",\n \"star-half\",\n \"star-of-david\",\n \"star-of-life\",\n \"star\",\n \"step-backward\",\n \"step-forward\",\n \"stethoscope\",\n \"sticky-note\",\n \"stop-circle\",\n \"stop\",\n \"stopwatch-20\",\n \"stopwatch\",\n \"store-alt-slash\",\n \"store-alt\",\n \"store-slash\",\n \"store\",\n \"stream\",\n \"street-view\",\n \"strikethrough\",\n \"stroopwafel\",\n \"subscript\",\n \"subway\",\n \"suitcase-rolling\",\n \"suitcase\",\n \"sun\",\n \"superscript\",\n \"surprise\",\n \"swatchbook\",\n \"swimmer\",\n \"swimming-pool\",\n \"synagogue\",\n \"sync-alt\",\n \"sync\",\n \"syringe\",\n \"table-tennis\",\n \"table\",\n \"tablet-alt\",\n \"tablet\",\n \"tablets\",\n \"tachometer-alt\",\n \"tag\",\n \"tags\",\n \"tape\",\n \"tasks\",\n \"taxi\",\n \"teeth-open\",\n \"teeth\",\n \"temperature-high\",\n \"temperature-low\",\n \"tenge\",\n \"terminal\",\n \"text-height\",\n \"text-width\",\n \"th-large\",\n \"th-list\",\n \"th\",\n \"theater-masks\",\n \"thermometer-empty\",\n \"thermometer-full\",\n \"thermometer-half\",\n \"thermometer-quarter\",\n \"thermometer-three-quarters\",\n \"thermometer\",\n \"thumbs-down\",\n \"thumbs-up\",\n \"thumbtack\",\n \"ticket-alt\",\n \"times-circle\",\n \"times\",\n \"tint-slash\",\n \"tint\",\n \"tired\",\n \"toggle-off\",\n \"toggle-on\",\n \"toilet-paper-slash\",\n \"toilet-paper\",\n \"toilet\",\n \"toolbox\",\n \"tools\",\n \"tooth\",\n \"torah\",\n \"torii-gate\",\n \"tractor\",\n \"trademark\",\n \"traffic-light\",\n \"trailer\",\n \"train\",\n \"tram\",\n \"transgender-alt\",\n \"transgender\",\n \"trash-alt\",\n \"trash-restore-alt\",\n \"trash-restore\",\n \"trash\",\n \"tree\",\n \"trophy\",\n \"truck-loading\",\n \"truck-monster\",\n \"truck-moving\",\n \"truck-pickup\",\n \"truck\",\n \"tshirt\",\n \"tty\",\n \"tv\",\n \"umbrella-beach\",\n \"umbrella\",\n \"underline\",\n \"undo-alt\",\n \"undo\",\n \"universal-access\",\n \"university\",\n \"unlink\",\n \"unlock-alt\",\n \"unlock\",\n \"upload\",\n \"user-alt-slash\",\n \"user-alt\",\n \"user-astronaut\",\n \"user-check\",\n \"user-circle\",\n \"user-clock\",\n \"user-cog\",\n \"user-edit\",\n \"user-friends\",\n \"user-graduate\",\n \"user-injured\",\n \"user-lock\",\n \"user-md\",\n \"user-minus\",\n \"user-ninja\",\n \"user-nurse\",\n \"user-plus\",\n \"user-secret\",\n \"user-shield\",\n \"user-slash\",\n \"user-tag\",\n \"user-tie\",\n \"user-times\",\n \"user\",\n \"users-cog\",\n \"users-slash\",\n \"users\",\n \"utensil-spoon\",\n \"utensils\",\n \"vector-square\",\n \"venus-double\",\n \"venus-mars\",\n \"venus\",\n \"vest-patches\",\n \"vest\",\n \"vial\",\n \"vials\",\n \"video-slash\",\n \"video\",\n \"vihara\",\n \"virus-slash\",\n \"virus\",\n \"viruses\",\n \"voicemail\",\n \"volleyball-ball\",\n \"volume-down\",\n \"volume-mute\",\n \"volume-off\",\n \"volume-up\",\n \"vote-yea\",\n \"vr-cardboard\",\n \"walking\",\n \"wallet\",\n \"warehouse\",\n \"water\",\n \"wave-square\",\n \"weight-hanging\",\n \"weight\",\n \"wheelchair\",\n \"wifi\",\n \"wind\",\n \"window-close\",\n \"window-maximize\",\n \"window-minimize\",\n \"window-restore\",\n \"wine-bottle\",\n \"wine-glass-alt\",\n \"wine-glass\",\n \"won-sign\",\n \"wrench\",\n \"x-ray\",\n \"yen-sign\",\n \"yin-yang\"\n ]\n}\r\n","","","","","","","","","","","","","","","","/* eslint-disable @typescript-eslint/unbound-method */\nimport client from './react-native-client';\nexport { createInstance } from './react-native-client';\nexport const {\n add,\n flush,\n getDeviceId,\n getSessionId,\n getUserId,\n groupIdentify,\n identify,\n init,\n logEvent,\n remove,\n reset,\n revenue,\n setDeviceId,\n setGroup,\n setOptOut,\n setSessionId,\n setUserId,\n track\n} = client;\nexport { Revenue, Identify } from '@amplitude/analytics-core';\n// Hack - react-native apps have trouble with:\n// export * as Types from '@amplitude/analytics-types\nimport * as Types from '@amplitude/analytics-types';\nexport { Types };\n//# sourceMappingURL=index.js.map","function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { AppState } from 'react-native';\nimport { AmplitudeCore, Destination, UUID, returnWrapper, debugWrapper, getClientLogConfig, getClientStates } from '@amplitude/analytics-core';\nimport { CampaignTracker, IdentityEventSender, getAnalyticsConnector, setConnectorDeviceId, setConnectorUserId } from '@amplitude/analytics-client-common';\nimport { Context } from './plugins/context';\nimport { useReactNativeConfig, createCookieStorage } from './config';\nimport { parseOldCookies } from './cookie-migration';\nimport { isNative } from './utils/platform';\nconst START_SESSION_EVENT = 'session_start';\nconst END_SESSION_EVENT = 'session_end';\nexport class AmplitudeReactNative extends AmplitudeCore {\n constructor() {\n super(...arguments);\n _defineProperty(this, \"appState\", 'background');\n _defineProperty(this, \"appStateChangeHandler\", void 0);\n _defineProperty(this, \"explicitSessionId\", void 0);\n _defineProperty(this, \"config\", void 0);\n _defineProperty(this, \"handleAppStateChange\", nextAppState => {\n const currentAppState = this.appState;\n this.appState = nextAppState;\n if (currentAppState !== nextAppState) {\n const timestamp = this.currentTimeMillis();\n if (nextAppState == 'active') {\n this.enterForeground(timestamp);\n } else {\n this.exitForeground(timestamp);\n }\n }\n });\n }\n init() {\n let apiKey = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n let userId = arguments.length > 1 ? arguments[1] : undefined;\n let options = arguments.length > 2 ? arguments[2] : undefined;\n return returnWrapper(this._init({\n ...options,\n userId,\n apiKey\n }));\n }\n async _init(options) {\n var _this$config$loggerPr;\n // Step 0: Block concurrent initialization\n if (this.initializing) {\n return;\n }\n this.initializing = true;\n this.explicitSessionId = options.sessionId;\n\n // Step 1: Read cookies stored by old SDK\n const oldCookies = await parseOldCookies(options.apiKey, options);\n\n // Step 2: Create react native config\n const reactNativeOptions = await useReactNativeConfig(options.apiKey, {\n ...options,\n deviceId: options.deviceId ?? oldCookies.deviceId,\n sessionId: oldCookies.sessionId,\n optOut: options.optOut ?? oldCookies.optOut,\n lastEventTime: oldCookies.lastEventTime,\n userId: options.userId ?? oldCookies.userId\n });\n await super._init(reactNativeOptions);\n\n // Set up the analytics connector to integrate with the experiment SDK.\n // Send events from the experiment SDK and forward identifies to the\n // identity store.\n const connector = getAnalyticsConnector();\n connector.identityStore.setIdentity({\n userId: this.config.userId,\n deviceId: this.config.deviceId\n });\n\n // Step 3: Install plugins\n // Do not track any events before this\n await this.add(new Destination()).promise;\n await this.add(new Context()).promise;\n await this.add(new IdentityEventSender()).promise;\n\n // Step 4: Manage session\n this.appState = AppState.currentState;\n const isNewSession = this.startNewSessionIfNeeded(this.currentTimeMillis());\n (_this$config$loggerPr = this.config.loggerProvider) === null || _this$config$loggerPr === void 0 ? void 0 : _this$config$loggerPr.log(`Init: startNewSessionIfNeeded = ${isNewSession ? 'yes' : 'no'}, sessionId = ${this.getSessionId() ?? 'undefined'}`);\n this.appStateChangeHandler = AppState.addEventListener('change', this.handleAppStateChange);\n this.initializing = false;\n\n // Step 5: Track attributions\n await this.runAttributionStrategy(options.attribution, isNewSession);\n\n // Step 6: Run queued functions\n await this.runQueuedFunctions('dispatchQ');\n\n // Step 7: Add the event receiver after running remaining queued functions.\n connector.eventBridge.setEventReceiver(event => {\n void this.track(event.eventType, event.eventProperties);\n });\n }\n shutdown() {\n var _this$appStateChangeH;\n (_this$appStateChangeH = this.appStateChangeHandler) === null || _this$appStateChangeH === void 0 ? void 0 : _this$appStateChangeH.remove();\n }\n async runAttributionStrategy(attributionConfig) {\n var _this = this;\n let isNewSession = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n if (isNative()) {\n return;\n }\n const track = function () {\n return _this.track(...arguments).promise;\n };\n const onNewCampaign = this.setSessionId.bind(this, this.currentTimeMillis());\n const storage = await createCookieStorage(this.config);\n const campaignTracker = new CampaignTracker(this.config.apiKey, {\n ...attributionConfig,\n storage,\n track,\n onNewCampaign\n });\n await campaignTracker.send(isNewSession);\n }\n getUserId() {\n var _this$config;\n return (_this$config = this.config) === null || _this$config === void 0 ? void 0 : _this$config.userId;\n }\n setUserId(userId) {\n if (!this.config) {\n this.q.push(this.setUserId.bind(this, userId));\n return;\n }\n this.config.userId = userId;\n setConnectorUserId(userId);\n }\n getDeviceId() {\n var _this$config2;\n return (_this$config2 = this.config) === null || _this$config2 === void 0 ? void 0 : _this$config2.deviceId;\n }\n setDeviceId(deviceId) {\n if (!this.config) {\n this.q.push(this.setDeviceId.bind(this, deviceId));\n return;\n }\n this.config.deviceId = deviceId;\n setConnectorDeviceId(deviceId);\n }\n identify(identify, eventOptions) {\n if (eventOptions !== null && eventOptions !== void 0 && eventOptions.user_id) {\n this.setUserId(eventOptions.user_id);\n }\n if (eventOptions !== null && eventOptions !== void 0 && eventOptions.device_id) {\n this.setDeviceId(eventOptions.device_id);\n }\n return super.identify(identify, eventOptions);\n }\n reset() {\n this.setUserId(undefined);\n this.setDeviceId(UUID());\n }\n getSessionId() {\n var _this$config3;\n return (_this$config3 = this.config) === null || _this$config3 === void 0 ? void 0 : _this$config3.sessionId;\n }\n setSessionId(sessionId) {\n if (!this.config) {\n this.q.push(this.setSessionId.bind(this, sessionId));\n return;\n }\n this.explicitSessionId = sessionId;\n void this.setSessionIdInternal(sessionId, this.currentTimeMillis());\n }\n extendSession() {\n if (!this.config) {\n this.q.push(this.extendSession.bind(this));\n return;\n }\n this.config.lastEventTime = this.currentTimeMillis();\n }\n setSessionIdInternal(sessionId, eventTime) {\n const previousSessionId = this.config.sessionId;\n if (previousSessionId === sessionId) {\n return;\n }\n this.config.sessionId = sessionId;\n if (this.config.trackingSessionEvents) {\n var _this$config$loggerPr2, _this$config$loggerPr3;\n (_this$config$loggerPr2 = this.config.loggerProvider) === null || _this$config$loggerPr2 === void 0 ? void 0 : _this$config$loggerPr2.log(`SESSION_END event: previousSessionId = ${previousSessionId ?? 'undefined'}`);\n if (previousSessionId !== undefined) {\n const sessionEndEvent = {\n event_type: END_SESSION_EVENT,\n time: this.config.lastEventTime !== undefined ? this.config.lastEventTime + 1 : sessionId,\n // increment lastEventTime to sort events properly in UI - session_end should be the last event in a session\n session_id: previousSessionId\n };\n void this.track(sessionEndEvent);\n }\n (_this$config$loggerPr3 = this.config.loggerProvider) === null || _this$config$loggerPr3 === void 0 ? void 0 : _this$config$loggerPr3.log(`SESSION_START event: sessionId = ${sessionId}`);\n const sessionStartEvent = {\n event_type: START_SESSION_EVENT,\n time: eventTime,\n session_id: sessionId\n };\n void this.track(sessionStartEvent);\n }\n this.config.lastEventTime = eventTime;\n }\n async process(event) {\n if (!this.config.optOut) {\n const eventTime = event.time ?? this.currentTimeMillis();\n if (event.time === undefined) {\n event = {\n ...event,\n time: eventTime\n };\n }\n const isSessionEvent = event.event_type === START_SESSION_EVENT || event.event_type === END_SESSION_EVENT;\n const isCustomEventSessionId = !isSessionEvent && event.session_id != undefined && event.session_id !== this.getSessionId();\n if (!isCustomEventSessionId) {\n if (!isSessionEvent) {\n if (this.appState !== 'active') {\n this.startNewSessionIfNeeded(eventTime);\n }\n }\n this.config.lastEventTime = eventTime;\n }\n if (event.session_id == undefined) {\n event.session_id = this.getSessionId();\n }\n if (event.event_id === undefined) {\n const eventId = (this.config.lastEventId ?? 0) + 1;\n event = {\n ...event,\n event_id: eventId\n };\n this.config.lastEventId = eventId;\n }\n }\n return super.process(event);\n }\n currentTimeMillis() {\n return Date.now();\n }\n startNewSessionIfNeeded(timestamp) {\n const sessionId = this.explicitSessionId ?? timestamp;\n const shouldStartNewSession = this.shouldStartNewSession(timestamp);\n if (shouldStartNewSession) {\n this.setSessionIdInternal(sessionId, timestamp);\n } else {\n this.config.lastEventTime = timestamp;\n }\n return shouldStartNewSession;\n }\n shouldStartNewSession(timestamp) {\n const sessionId = this.explicitSessionId ?? timestamp;\n return !this.inSession() || this.explicitSessionId !== this.config.sessionId && (this.explicitSessionId !== undefined || !this.isWithinMinTimeBetweenSessions(sessionId));\n }\n isWithinMinTimeBetweenSessions(timestamp) {\n return timestamp - (this.config.lastEventTime ?? 0) < this.config.sessionTimeout;\n }\n inSession() {\n return this.config.sessionId != undefined;\n }\n enterForeground(timestamp) {\n var _this$config$loggerPr4;\n (_this$config$loggerPr4 = this.config.loggerProvider) === null || _this$config$loggerPr4 === void 0 ? void 0 : _this$config$loggerPr4.log('App Activated');\n return this.startNewSessionIfNeeded(timestamp);\n }\n exitForeground(timestamp) {\n this.config.lastEventTime = timestamp;\n }\n}\nexport const createInstance = () => {\n const client = new AmplitudeReactNative();\n return {\n init: debugWrapper(client.init.bind(client), 'init', getClientLogConfig(client), getClientStates(client, ['config'])),\n add: debugWrapper(client.add.bind(client), 'add', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.plugins'])),\n remove: debugWrapper(client.remove.bind(client), 'remove', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.plugins'])),\n track: debugWrapper(client.track.bind(client), 'track', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.queue.length'])),\n logEvent: debugWrapper(client.logEvent.bind(client), 'logEvent', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.queue.length'])),\n identify: debugWrapper(client.identify.bind(client), 'identify', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.queue.length'])),\n groupIdentify: debugWrapper(client.groupIdentify.bind(client), 'groupIdentify', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.queue.length'])),\n setGroup: debugWrapper(client.setGroup.bind(client), 'setGroup', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.queue.length'])),\n revenue: debugWrapper(client.revenue.bind(client), 'revenue', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.queue.length'])),\n flush: debugWrapper(client.flush.bind(client), 'flush', getClientLogConfig(client), getClientStates(client, ['config.apiKey', 'timeline.queue.length'])),\n getUserId: debugWrapper(client.getUserId.bind(client), 'getUserId', getClientLogConfig(client), getClientStates(client, ['config', 'config.userId'])),\n setUserId: debugWrapper(client.setUserId.bind(client), 'setUserId', getClientLogConfig(client), getClientStates(client, ['config', 'config.userId'])),\n getDeviceId: debugWrapper(client.getDeviceId.bind(client), 'getDeviceId', getClientLogConfig(client), getClientStates(client, ['config', 'config.deviceId'])),\n setDeviceId: debugWrapper(client.setDeviceId.bind(client), 'setDeviceId', getClientLogConfig(client), getClientStates(client, ['config', 'config.deviceId'])),\n reset: debugWrapper(client.reset.bind(client), 'reset', getClientLogConfig(client), getClientStates(client, ['config', 'config.userId', 'config.deviceId'])),\n getSessionId: debugWrapper(client.getSessionId.bind(client), 'getSessionId', getClientLogConfig(client), getClientStates(client, ['config'])),\n setSessionId: debugWrapper(client.setSessionId.bind(client), 'setSessionId', getClientLogConfig(client), getClientStates(client, ['config'])),\n extendSession: debugWrapper(client.extendSession.bind(client), 'extendSession', getClientLogConfig(client), getClientStates(client, ['config'])),\n setOptOut: debugWrapper(client.setOptOut.bind(client), 'setOptOut', getClientLogConfig(client), getClientStates(client, ['config']))\n };\n};\nexport default createInstance();\n//# sourceMappingURL=react-native-client.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport invariant from 'fbjs/lib/invariant';\nimport EventEmitter from '../../vendor/react-native/vendor/emitter/EventEmitter';\nimport canUseDOM from '../../modules/canUseDom';\n\n// Android 4.4 browser\nvar isPrefixed = canUseDOM && !document.hasOwnProperty('hidden') && document.hasOwnProperty('webkitHidden');\nvar EVENT_TYPES = ['change', 'memoryWarning'];\nvar VISIBILITY_CHANGE_EVENT = isPrefixed ? 'webkitvisibilitychange' : 'visibilitychange';\nvar VISIBILITY_STATE_PROPERTY = isPrefixed ? 'webkitVisibilityState' : 'visibilityState';\nvar AppStates = {\n BACKGROUND: 'background',\n ACTIVE: 'active'\n};\nvar changeEmitter = null;\nexport default class AppState {\n static get currentState() {\n if (!AppState.isAvailable) {\n return AppStates.ACTIVE;\n }\n switch (document[VISIBILITY_STATE_PROPERTY]) {\n case 'hidden':\n case 'prerender':\n case 'unloaded':\n return AppStates.BACKGROUND;\n default:\n return AppStates.ACTIVE;\n }\n }\n static addEventListener(type, handler) {\n if (AppState.isAvailable) {\n invariant(EVENT_TYPES.indexOf(type) !== -1, 'Trying to subscribe to unknown event: \"%s\"', type);\n if (type === 'change') {\n if (!changeEmitter) {\n changeEmitter = new EventEmitter();\n document.addEventListener(VISIBILITY_CHANGE_EVENT, () => {\n if (changeEmitter) {\n changeEmitter.emit('change', AppState.currentState);\n }\n }, false);\n }\n return changeEmitter.addListener(type, handler);\n }\n }\n }\n}\nAppState.isAvailable = canUseDOM && document[VISIBILITY_STATE_PROPERTY];","export { AmplitudeCore } from './core-client';\nexport { Identify } from './identify';\nexport { Revenue } from './revenue';\nexport { Destination } from './plugins/destination';\nexport { Config } from './config';\nexport { Logger } from './logger';\nexport { AMPLITUDE_PREFIX, STORAGE_PREFIX } from './constants';\nexport { returnWrapper } from './utils/return-wrapper';\nexport { debugWrapper, getClientLogConfig, getClientStates } from './utils/debug';\nexport { UUID } from './utils/uuid';\nexport { MemoryStorage } from './storage/memory';\nexport { BaseTransport } from './transports/base';\nexport { createIdentifyEvent } from './utils/event-builder';\n//# sourceMappingURL=index.js.map","import { __awaiter, __generator, __values } from \"tslib\";\nimport { createGroupIdentifyEvent, createIdentifyEvent, createTrackEvent, createRevenueEvent, createGroupEvent, } from './utils/event-builder';\nimport { Timeline } from './timeline';\nimport { buildResult } from './utils/result-builder';\nimport { CLIENT_NOT_INITIALIZED, OPT_OUT_MESSAGE } from './messages';\nimport { returnWrapper } from './utils/return-wrapper';\nvar AmplitudeCore = /** @class */ (function () {\n function AmplitudeCore(name) {\n if (name === void 0) { name = '$default'; }\n this.initializing = false;\n this.q = [];\n this.dispatchQ = [];\n this.logEvent = this.track.bind(this);\n this.timeline = new Timeline(this);\n this.name = name;\n }\n AmplitudeCore.prototype._init = function (config) {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n this.config = config;\n this.timeline.reset(this);\n return [4 /*yield*/, this.runQueuedFunctions('q')];\n case 1:\n _a.sent();\n return [2 /*return*/];\n }\n });\n });\n };\n AmplitudeCore.prototype.runQueuedFunctions = function (queueName) {\n return __awaiter(this, void 0, void 0, function () {\n var queuedFunctions, queuedFunctions_1, queuedFunctions_1_1, queuedFunction, e_1_1;\n var e_1, _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n queuedFunctions = this[queueName];\n this[queueName] = [];\n _b.label = 1;\n case 1:\n _b.trys.push([1, 6, 7, 8]);\n queuedFunctions_1 = __values(queuedFunctions), queuedFunctions_1_1 = queuedFunctions_1.next();\n _b.label = 2;\n case 2:\n if (!!queuedFunctions_1_1.done) return [3 /*break*/, 5];\n queuedFunction = queuedFunctions_1_1.value;\n return [4 /*yield*/, queuedFunction()];\n case 3:\n _b.sent();\n _b.label = 4;\n case 4:\n queuedFunctions_1_1 = queuedFunctions_1.next();\n return [3 /*break*/, 2];\n case 5: return [3 /*break*/, 8];\n case 6:\n e_1_1 = _b.sent();\n e_1 = { error: e_1_1 };\n return [3 /*break*/, 8];\n case 7:\n try {\n if (queuedFunctions_1_1 && !queuedFunctions_1_1.done && (_a = queuedFunctions_1.return)) _a.call(queuedFunctions_1);\n }\n finally { if (e_1) throw e_1.error; }\n return [7 /*endfinally*/];\n case 8: return [2 /*return*/];\n }\n });\n });\n };\n AmplitudeCore.prototype.track = function (eventInput, eventProperties, eventOptions) {\n var event = createTrackEvent(eventInput, eventProperties, eventOptions);\n return returnWrapper(this.dispatch(event));\n };\n AmplitudeCore.prototype.identify = function (identify, eventOptions) {\n var event = createIdentifyEvent(identify, eventOptions);\n return returnWrapper(this.dispatch(event));\n };\n AmplitudeCore.prototype.groupIdentify = function (groupType, groupName, identify, eventOptions) {\n var event = createGroupIdentifyEvent(groupType, groupName, identify, eventOptions);\n return returnWrapper(this.dispatch(event));\n };\n AmplitudeCore.prototype.setGroup = function (groupType, groupName, eventOptions) {\n var event = createGroupEvent(groupType, groupName, eventOptions);\n return returnWrapper(this.dispatch(event));\n };\n AmplitudeCore.prototype.revenue = function (revenue, eventOptions) {\n var event = createRevenueEvent(revenue, eventOptions);\n return returnWrapper(this.dispatch(event));\n };\n AmplitudeCore.prototype.add = function (plugin) {\n if (!this.config) {\n this.q.push(this.add.bind(this, plugin));\n return returnWrapper();\n }\n return returnWrapper(this.timeline.register(plugin, this.config));\n };\n AmplitudeCore.prototype.remove = function (pluginName) {\n if (!this.config) {\n this.q.push(this.remove.bind(this, pluginName));\n return returnWrapper();\n }\n return returnWrapper(this.timeline.deregister(pluginName));\n };\n AmplitudeCore.prototype.dispatchWithCallback = function (event, callback) {\n if (!this.config) {\n return callback(buildResult(event, 0, CLIENT_NOT_INITIALIZED));\n }\n void this.process(event).then(callback);\n };\n AmplitudeCore.prototype.dispatch = function (event) {\n return __awaiter(this, void 0, void 0, function () {\n var _this = this;\n return __generator(this, function (_a) {\n if (!this.config) {\n return [2 /*return*/, new Promise(function (resolve) {\n _this.dispatchQ.push(_this.dispatchWithCallback.bind(_this, event, resolve));\n })];\n }\n return [2 /*return*/, this.process(event)];\n });\n });\n };\n AmplitudeCore.prototype.process = function (event) {\n return __awaiter(this, void 0, void 0, function () {\n var result, e_2, message, result;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n _a.trys.push([0, 2, , 3]);\n // skip event processing if opt out\n if (this.config.optOut) {\n return [2 /*return*/, buildResult(event, 0, OPT_OUT_MESSAGE)];\n }\n return [4 /*yield*/, this.timeline.push(event)];\n case 1:\n result = _a.sent();\n result.code === 200\n ? this.config.loggerProvider.log(result.message)\n : this.config.loggerProvider.error(result.message);\n return [2 /*return*/, result];\n case 2:\n e_2 = _a.sent();\n message = String(e_2);\n this.config.loggerProvider.error(message);\n result = buildResult(event, 0, message);\n return [2 /*return*/, result];\n case 3: return [2 /*return*/];\n }\n });\n });\n };\n AmplitudeCore.prototype.setOptOut = function (optOut) {\n if (!this.config) {\n this.q.push(this.setOptOut.bind(this, Boolean(optOut)));\n return;\n }\n this.config.optOut = Boolean(optOut);\n };\n AmplitudeCore.prototype.flush = function () {\n return returnWrapper(this.timeline.flush());\n };\n return AmplitudeCore;\n}());\nexport { AmplitudeCore };\n//# sourceMappingURL=core-client.js.map","/******************************************************************************\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, SuppressedError, Symbol */\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 (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\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 __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\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 (g && (g = 0, op[0] && (_ = 0)), _) 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 var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(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, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, 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\n/** @deprecated */\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\n/** @deprecated */\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 __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\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: false } : 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\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\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 (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, 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, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\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\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\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\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n function next() {\r\n while (env.stack.length) {\r\n var rec = env.stack.pop();\r\n try {\r\n var result = rec.dispose && rec.dispose.call(rec.value);\r\n if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n};\r\n","import { __assign } from \"tslib\";\nimport { SpecialEventType, } from '@amplitude/analytics-types';\nimport { Identify } from '../identify';\nexport var createTrackEvent = function (eventInput, eventProperties, eventOptions) {\n var baseEvent = typeof eventInput === 'string' ? { event_type: eventInput } : eventInput;\n return __assign(__assign(__assign({}, baseEvent), eventOptions), (eventProperties && { event_properties: eventProperties }));\n};\nexport var createIdentifyEvent = function (identify, eventOptions) {\n var identifyEvent = __assign(__assign({}, eventOptions), { event_type: SpecialEventType.IDENTIFY, user_properties: identify.getUserProperties() });\n return identifyEvent;\n};\nexport var createGroupIdentifyEvent = function (groupType, groupName, identify, eventOptions) {\n var _a;\n var groupIdentify = __assign(__assign({}, eventOptions), { event_type: SpecialEventType.GROUP_IDENTIFY, group_properties: identify.getUserProperties(), groups: (_a = {},\n _a[groupType] = groupName,\n _a) });\n return groupIdentify;\n};\nexport var createGroupEvent = function (groupType, groupName, eventOptions) {\n var _a;\n var identify = new Identify();\n identify.set(groupType, groupName);\n var groupEvent = __assign(__assign({}, eventOptions), { event_type: SpecialEventType.IDENTIFY, user_properties: identify.getUserProperties(), groups: (_a = {},\n _a[groupType] = groupName,\n _a) });\n return groupEvent;\n};\nexport var createRevenueEvent = function (revenue, eventOptions) {\n return __assign(__assign({}, eventOptions), { event_type: SpecialEventType.REVENUE, event_properties: revenue.getEventProperties() });\n};\n//# sourceMappingURL=event-builder.js.map","export { SpecialEventType, IdentifyOperation, RevenueProperty, } from './event';\nexport { LogLevel } from './logger';\nexport { PluginType } from './plugin';\nexport { ServerZone } from './server-zone';\nexport { Status } from './status';\nexport { TransportType } from './transport';\n//# sourceMappingURL=index.js.map","export var IdentifyOperation;\n(function (IdentifyOperation) {\n // Base Operations to set values\n IdentifyOperation[\"SET\"] = \"$set\";\n IdentifyOperation[\"SET_ONCE\"] = \"$setOnce\";\n // Operations around modifying existing values\n IdentifyOperation[\"ADD\"] = \"$add\";\n IdentifyOperation[\"APPEND\"] = \"$append\";\n IdentifyOperation[\"PREPEND\"] = \"$prepend\";\n IdentifyOperation[\"REMOVE\"] = \"$remove\";\n // Operations around appending values *if* they aren't present\n IdentifyOperation[\"PREINSERT\"] = \"$preInsert\";\n IdentifyOperation[\"POSTINSERT\"] = \"$postInsert\";\n // Operations around removing properties/values\n IdentifyOperation[\"UNSET\"] = \"$unset\";\n IdentifyOperation[\"CLEAR_ALL\"] = \"$clearAll\";\n})(IdentifyOperation || (IdentifyOperation = {}));\nexport var RevenueProperty;\n(function (RevenueProperty) {\n RevenueProperty[\"REVENUE_PRODUCT_ID\"] = \"$productId\";\n RevenueProperty[\"REVENUE_QUANTITY\"] = \"$quantity\";\n RevenueProperty[\"REVENUE_PRICE\"] = \"$price\";\n RevenueProperty[\"REVENUE_TYPE\"] = \"$revenueType\";\n RevenueProperty[\"REVENUE\"] = \"$revenue\";\n})(RevenueProperty || (RevenueProperty = {}));\n/**\n * Strings that have special meaning when used as an event's type\n * and have different specifications.\n */\nexport var SpecialEventType;\n(function (SpecialEventType) {\n SpecialEventType[\"IDENTIFY\"] = \"$identify\";\n SpecialEventType[\"GROUP_IDENTIFY\"] = \"$groupidentify\";\n SpecialEventType[\"REVENUE\"] = \"revenue_amount\";\n})(SpecialEventType || (SpecialEventType = {}));\n//# sourceMappingURL=event.js.map","export var LogLevel;\n(function (LogLevel) {\n LogLevel[LogLevel[\"None\"] = 0] = \"None\";\n LogLevel[LogLevel[\"Error\"] = 1] = \"Error\";\n LogLevel[LogLevel[\"Warn\"] = 2] = \"Warn\";\n LogLevel[LogLevel[\"Verbose\"] = 3] = \"Verbose\";\n LogLevel[LogLevel[\"Debug\"] = 4] = \"Debug\";\n})(LogLevel || (LogLevel = {}));\n//# sourceMappingURL=logger.js.map","export var PluginType;\n(function (PluginType) {\n PluginType[\"BEFORE\"] = \"before\";\n PluginType[\"ENRICHMENT\"] = \"enrichment\";\n PluginType[\"DESTINATION\"] = \"destination\";\n})(PluginType || (PluginType = {}));\n//# sourceMappingURL=plugin.js.map","export var ServerZone;\n(function (ServerZone) {\n ServerZone[\"US\"] = \"US\";\n ServerZone[\"EU\"] = \"EU\";\n})(ServerZone || (ServerZone = {}));\n//# sourceMappingURL=server-zone.js.map","/** The status of an event. */\nexport var Status;\n(function (Status) {\n /** The status could not be determined. */\n Status[\"Unknown\"] = \"unknown\";\n /** The event was skipped due to configuration or callbacks. */\n Status[\"Skipped\"] = \"skipped\";\n /** The event was sent successfully. */\n Status[\"Success\"] = \"success\";\n /** A user or device in the payload is currently rate limited and should try again later. */\n Status[\"RateLimit\"] = \"rate_limit\";\n /** The sent payload was too large to be processed. */\n Status[\"PayloadTooLarge\"] = \"payload_too_large\";\n /** The event could not be processed. */\n Status[\"Invalid\"] = \"invalid\";\n /** A server-side error ocurred during submission. */\n Status[\"Failed\"] = \"failed\";\n /** a server or client side error occuring when a request takes too long and is cancelled */\n Status[\"Timeout\"] = \"Timeout\";\n /** NodeJS runtime environment error.. E.g. disconnected from network */\n Status[\"SystemError\"] = \"SystemError\";\n})(Status || (Status = {}));\n//# sourceMappingURL=status.js.map","export var TransportType;\n(function (TransportType) {\n TransportType[\"XHR\"] = \"xhr\";\n TransportType[\"SendBeacon\"] = \"beacon\";\n TransportType[\"Fetch\"] = \"fetch\";\n})(TransportType || (TransportType = {}));\n//# sourceMappingURL=transport.js.map","import { __assign } from \"tslib\";\nimport { IdentifyOperation, } from '@amplitude/analytics-types';\nimport { UNSET_VALUE } from './constants';\nimport { isValidProperties } from './utils/valid-properties';\nvar Identify = /** @class */ (function () {\n function Identify() {\n this._propertySet = new Set();\n this._properties = {};\n }\n Identify.prototype.getUserProperties = function () {\n return __assign({}, this._properties);\n };\n Identify.prototype.set = function (property, value) {\n this._safeSet(IdentifyOperation.SET, property, value);\n return this;\n };\n Identify.prototype.setOnce = function (property, value) {\n this._safeSet(IdentifyOperation.SET_ONCE, property, value);\n return this;\n };\n Identify.prototype.append = function (property, value) {\n this._safeSet(IdentifyOperation.APPEND, property, value);\n return this;\n };\n Identify.prototype.prepend = function (property, value) {\n this._safeSet(IdentifyOperation.PREPEND, property, value);\n return this;\n };\n Identify.prototype.postInsert = function (property, value) {\n this._safeSet(IdentifyOperation.POSTINSERT, property, value);\n return this;\n };\n Identify.prototype.preInsert = function (property, value) {\n this._safeSet(IdentifyOperation.PREINSERT, property, value);\n return this;\n };\n Identify.prototype.remove = function (property, value) {\n this._safeSet(IdentifyOperation.REMOVE, property, value);\n return this;\n };\n Identify.prototype.add = function (property, value) {\n this._safeSet(IdentifyOperation.ADD, property, value);\n return this;\n };\n Identify.prototype.unset = function (property) {\n this._safeSet(IdentifyOperation.UNSET, property, UNSET_VALUE);\n return this;\n };\n Identify.prototype.clearAll = function () {\n // When clear all happens, all properties are unset. Reset the entire object.\n this._properties = {};\n this._properties[IdentifyOperation.CLEAR_ALL] = UNSET_VALUE;\n return this;\n };\n // Returns whether or not this set actually worked.\n Identify.prototype._safeSet = function (operation, property, value) {\n if (this._validate(operation, property, value)) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n var userPropertyMap = this._properties[operation];\n if (userPropertyMap === undefined) {\n userPropertyMap = {};\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n this._properties[operation] = userPropertyMap;\n }\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n userPropertyMap[property] = value;\n this._propertySet.add(property);\n return true;\n }\n return false;\n };\n Identify.prototype._validate = function (operation, property, value) {\n if (this._properties[IdentifyOperation.CLEAR_ALL] !== undefined) {\n // clear all already set. Skipping operation;\n return false;\n }\n if (this._propertySet.has(property)) {\n // Property already used. Skipping operation\n return false;\n }\n if (operation === IdentifyOperation.ADD) {\n return typeof value === 'number';\n }\n if (operation !== IdentifyOperation.UNSET && operation !== IdentifyOperation.REMOVE) {\n return isValidProperties(property, value);\n }\n return true;\n };\n return Identify;\n}());\nexport { Identify };\n//# sourceMappingURL=identify.js.map","export var UNSET_VALUE = '-';\nexport var AMPLITUDE_PREFIX = 'AMP';\nexport var STORAGE_PREFIX = \"\".concat(AMPLITUDE_PREFIX, \"_unsent\");\nexport var AMPLITUDE_SERVER_URL = 'https://api2.amplitude.com/2/httpapi';\nexport var EU_AMPLITUDE_SERVER_URL = 'https://api.eu.amplitude.com/2/httpapi';\nexport var AMPLITUDE_BATCH_SERVER_URL = 'https://api2.amplitude.com/batch';\nexport var EU_AMPLITUDE_BATCH_SERVER_URL = 'https://api.eu.amplitude.com/batch';\n//# sourceMappingURL=constants.js.map","import { __values } from \"tslib\";\nvar MAX_PROPERTY_KEYS = 1000;\nexport var isValidObject = function (properties) {\n if (Object.keys(properties).length > MAX_PROPERTY_KEYS) {\n return false;\n }\n for (var key in properties) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n var value = properties[key];\n if (!isValidProperties(key, value))\n return false;\n }\n return true;\n};\nexport var isValidProperties = function (property, value) {\n var e_1, _a;\n if (typeof property !== 'string')\n return false;\n if (Array.isArray(value)) {\n var isValid = true;\n try {\n for (var value_1 = __values(value), value_1_1 = value_1.next(); !value_1_1.done; value_1_1 = value_1.next()) {\n var valueElement = value_1_1.value;\n if (Array.isArray(valueElement)) {\n return false;\n }\n else if (typeof valueElement === 'object') {\n isValid = isValid && isValidObject(valueElement);\n }\n else if (!['number', 'string'].includes(typeof valueElement)) {\n return false;\n }\n if (!isValid) {\n return false;\n }\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (value_1_1 && !value_1_1.done && (_a = value_1.return)) _a.call(value_1);\n }\n finally { if (e_1) throw e_1.error; }\n }\n }\n else if (value === null || value === undefined) {\n return false;\n }\n else if (typeof value === 'object') {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n return isValidObject(value);\n }\n else if (!['number', 'string', 'boolean'].includes(typeof value)) {\n return false;\n }\n return true;\n};\n//# sourceMappingURL=valid-properties.js.map","import { __assign, __awaiter, __generator, __read, __values } from \"tslib\";\nimport { PluginType, } from '@amplitude/analytics-types';\nimport { buildResult } from './utils/result-builder';\nvar Timeline = /** @class */ (function () {\n function Timeline(client) {\n this.client = client;\n this.queue = [];\n // Flag to guarantee one schedule apply is running\n this.applying = false;\n // Flag indicates whether timeline is ready to process event\n // Events collected before timeline is ready will stay in the queue to be processed later\n this.plugins = [];\n }\n Timeline.prototype.register = function (plugin, config) {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, plugin.setup(config, this.client)];\n case 1:\n _a.sent();\n this.plugins.push(plugin);\n return [2 /*return*/];\n }\n });\n });\n };\n Timeline.prototype.deregister = function (pluginName) {\n var _a;\n return __awaiter(this, void 0, void 0, function () {\n var index, plugin;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n index = this.plugins.findIndex(function (plugin) { return plugin.name === pluginName; });\n plugin = this.plugins[index];\n this.plugins.splice(index, 1);\n return [4 /*yield*/, ((_a = plugin.teardown) === null || _a === void 0 ? void 0 : _a.call(plugin))];\n case 1:\n _b.sent();\n return [2 /*return*/];\n }\n });\n });\n };\n Timeline.prototype.reset = function (client) {\n this.applying = false;\n var plugins = this.plugins;\n plugins.map(function (plugin) { var _a; return (_a = plugin.teardown) === null || _a === void 0 ? void 0 : _a.call(plugin); });\n this.plugins = [];\n this.client = client;\n };\n Timeline.prototype.push = function (event) {\n var _this = this;\n return new Promise(function (resolve) {\n _this.queue.push([event, resolve]);\n _this.scheduleApply(0);\n });\n };\n Timeline.prototype.scheduleApply = function (timeout) {\n var _this = this;\n if (this.applying)\n return;\n this.applying = true;\n setTimeout(function () {\n void _this.apply(_this.queue.shift()).then(function () {\n _this.applying = false;\n if (_this.queue.length > 0) {\n _this.scheduleApply(0);\n }\n });\n }, timeout);\n };\n Timeline.prototype.apply = function (item) {\n return __awaiter(this, void 0, void 0, function () {\n var _a, event, _b, resolve, before, before_1, before_1_1, plugin, e, e_1_1, enrichment, enrichment_1, enrichment_1_1, plugin, e, e_2_1, destination, executeDestinations;\n var e_1, _c, e_2, _d;\n return __generator(this, function (_e) {\n switch (_e.label) {\n case 0:\n if (!item) {\n return [2 /*return*/];\n }\n _a = __read(item, 1), event = _a[0];\n _b = __read(item, 2), resolve = _b[1];\n before = this.plugins.filter(function (plugin) { return plugin.type === PluginType.BEFORE; });\n _e.label = 1;\n case 1:\n _e.trys.push([1, 6, 7, 8]);\n before_1 = __values(before), before_1_1 = before_1.next();\n _e.label = 2;\n case 2:\n if (!!before_1_1.done) return [3 /*break*/, 5];\n plugin = before_1_1.value;\n return [4 /*yield*/, plugin.execute(__assign({}, event))];\n case 3:\n e = _e.sent();\n if (e === null) {\n resolve({ event: event, code: 0, message: '' });\n return [2 /*return*/];\n }\n else {\n event = e;\n }\n _e.label = 4;\n case 4:\n before_1_1 = before_1.next();\n return [3 /*break*/, 2];\n case 5: return [3 /*break*/, 8];\n case 6:\n e_1_1 = _e.sent();\n e_1 = { error: e_1_1 };\n return [3 /*break*/, 8];\n case 7:\n try {\n if (before_1_1 && !before_1_1.done && (_c = before_1.return)) _c.call(before_1);\n }\n finally { if (e_1) throw e_1.error; }\n return [7 /*endfinally*/];\n case 8:\n enrichment = this.plugins.filter(function (plugin) { return plugin.type === PluginType.ENRICHMENT; });\n _e.label = 9;\n case 9:\n _e.trys.push([9, 14, 15, 16]);\n enrichment_1 = __values(enrichment), enrichment_1_1 = enrichment_1.next();\n _e.label = 10;\n case 10:\n if (!!enrichment_1_1.done) return [3 /*break*/, 13];\n plugin = enrichment_1_1.value;\n return [4 /*yield*/, plugin.execute(__assign({}, event))];\n case 11:\n e = _e.sent();\n if (e === null) {\n resolve({ event: event, code: 0, message: '' });\n return [2 /*return*/];\n }\n else {\n event = e;\n }\n _e.label = 12;\n case 12:\n enrichment_1_1 = enrichment_1.next();\n return [3 /*break*/, 10];\n case 13: return [3 /*break*/, 16];\n case 14:\n e_2_1 = _e.sent();\n e_2 = { error: e_2_1 };\n return [3 /*break*/, 16];\n case 15:\n try {\n if (enrichment_1_1 && !enrichment_1_1.done && (_d = enrichment_1.return)) _d.call(enrichment_1);\n }\n finally { if (e_2) throw e_2.error; }\n return [7 /*endfinally*/];\n case 16:\n destination = this.plugins.filter(function (plugin) { return plugin.type === PluginType.DESTINATION; });\n executeDestinations = destination.map(function (plugin) {\n var eventClone = __assign({}, event);\n return plugin.execute(eventClone).catch(function (e) { return buildResult(eventClone, 0, String(e)); });\n });\n void Promise.all(executeDestinations).then(function (_a) {\n var _b = __read(_a, 1), result = _b[0];\n resolve(result);\n });\n return [2 /*return*/];\n }\n });\n });\n };\n Timeline.prototype.flush = function () {\n return __awaiter(this, void 0, void 0, function () {\n var queue, destination, executeDestinations;\n var _this = this;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n queue = this.queue;\n this.queue = [];\n return [4 /*yield*/, Promise.all(queue.map(function (item) { return _this.apply(item); }))];\n case 1:\n _a.sent();\n destination = this.plugins.filter(function (plugin) { return plugin.type === PluginType.DESTINATION; });\n executeDestinations = destination.map(function (plugin) {\n return plugin.flush && plugin.flush();\n });\n return [4 /*yield*/, Promise.all(executeDestinations)];\n case 2:\n _a.sent();\n return [2 /*return*/];\n }\n });\n });\n };\n return Timeline;\n}());\nexport { Timeline };\n//# sourceMappingURL=timeline.js.map","import { Status } from '@amplitude/analytics-types';\nexport var buildResult = function (event, code, message) {\n if (code === void 0) { code = 0; }\n if (message === void 0) { message = Status.Unknown; }\n return { event: event, code: code, message: message };\n};\n//# sourceMappingURL=result-builder.js.map","export var SUCCESS_MESSAGE = 'Event tracked successfully';\nexport var UNEXPECTED_ERROR_MESSAGE = 'Unexpected error occurred';\nexport var MAX_RETRIES_EXCEEDED_MESSAGE = 'Event rejected due to exceeded retry count';\nexport var OPT_OUT_MESSAGE = 'Event skipped due to optOut config';\nexport var MISSING_API_KEY_MESSAGE = 'Event rejected due to missing API key';\nexport var INVALID_API_KEY = 'Invalid API key';\nexport var CLIENT_NOT_INITIALIZED = 'Client not initialized';\n//# sourceMappingURL=messages.js.map","export var returnWrapper = function (awaitable) { return ({\n promise: awaitable || Promise.resolve(),\n}); };\n//# sourceMappingURL=return-wrapper.js.map","import { __assign } from \"tslib\";\nimport { RevenueProperty, } from '@amplitude/analytics-types';\nimport { isValidObject } from './utils/valid-properties';\nvar Revenue = /** @class */ (function () {\n function Revenue() {\n this.productId = '';\n this.quantity = 1;\n this.price = 0.0;\n }\n Revenue.prototype.setProductId = function (productId) {\n this.productId = productId;\n return this;\n };\n Revenue.prototype.setQuantity = function (quantity) {\n if (quantity > 0) {\n this.quantity = quantity;\n }\n return this;\n };\n Revenue.prototype.setPrice = function (price) {\n this.price = price;\n return this;\n };\n Revenue.prototype.setRevenueType = function (revenueType) {\n this.revenueType = revenueType;\n return this;\n };\n Revenue.prototype.setRevenue = function (revenue) {\n this.revenue = revenue;\n return this;\n };\n Revenue.prototype.setEventProperties = function (properties) {\n if (isValidObject(properties)) {\n this.properties = properties;\n }\n return this;\n };\n Revenue.prototype.getEventProperties = function () {\n var eventProperties = this.properties ? __assign({}, this.properties) : {};\n eventProperties[RevenueProperty.REVENUE_PRODUCT_ID] = this.productId;\n eventProperties[RevenueProperty.REVENUE_QUANTITY] = this.quantity;\n eventProperties[RevenueProperty.REVENUE_PRICE] = this.price;\n eventProperties[RevenueProperty.REVENUE_TYPE] = this.revenueType;\n eventProperties[RevenueProperty.REVENUE] = this.revenue;\n return eventProperties;\n };\n return Revenue;\n}());\nexport { Revenue };\n//# sourceMappingURL=revenue.js.map","import { __awaiter, __generator, __read, __rest, __spreadArray } from \"tslib\";\nimport { PluginType, Status, } from '@amplitude/analytics-types';\nimport { INVALID_API_KEY, MAX_RETRIES_EXCEEDED_MESSAGE, MISSING_API_KEY_MESSAGE, SUCCESS_MESSAGE, UNEXPECTED_ERROR_MESSAGE, } from '../messages';\nimport { STORAGE_PREFIX } from '../constants';\nimport { chunk } from '../utils/chunk';\nimport { buildResult } from '../utils/result-builder';\nimport { createServerConfig } from '../config';\nfunction getErrorMessage(error) {\n if (error instanceof Error)\n return error.message;\n return String(error);\n}\nexport function getResponseBodyString(res) {\n var responseBodyString = '';\n try {\n if ('body' in res) {\n responseBodyString = JSON.stringify(res.body);\n }\n }\n catch (_a) {\n // to avoid crash, but don't care about the error, add comment to avoid empty block lint error\n }\n return responseBodyString;\n}\nvar Destination = /** @class */ (function () {\n function Destination() {\n this.name = 'amplitude';\n this.type = PluginType.DESTINATION;\n this.retryTimeout = 1000;\n this.throttleTimeout = 30000;\n this.storageKey = '';\n this.scheduled = null;\n this.queue = [];\n }\n Destination.prototype.setup = function (config) {\n var _a;\n return __awaiter(this, void 0, void 0, function () {\n var unsent;\n var _this = this;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n this.config = config;\n this.storageKey = \"\".concat(STORAGE_PREFIX, \"_\").concat(this.config.apiKey.substring(0, 10));\n return [4 /*yield*/, ((_a = this.config.storageProvider) === null || _a === void 0 ? void 0 : _a.get(this.storageKey))];\n case 1:\n unsent = _b.sent();\n this.saveEvents(); // sets storage to '[]'\n if (unsent && unsent.length > 0) {\n void Promise.all(unsent.map(function (event) { return _this.execute(event); })).catch();\n }\n return [2 /*return*/, Promise.resolve(undefined)];\n }\n });\n });\n };\n Destination.prototype.execute = function (event) {\n var _this = this;\n return new Promise(function (resolve) {\n var context = {\n event: event,\n attempts: 0,\n callback: function (result) { return resolve(result); },\n timeout: 0,\n };\n void _this.addToQueue(context);\n });\n };\n Destination.prototype.addToQueue = function () {\n var _this = this;\n var list = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n list[_i] = arguments[_i];\n }\n var tryable = list.filter(function (context) {\n if (context.attempts < _this.config.flushMaxRetries) {\n context.attempts += 1;\n return true;\n }\n void _this.fulfillRequest([context], 500, MAX_RETRIES_EXCEEDED_MESSAGE);\n return false;\n });\n tryable.forEach(function (context) {\n _this.queue = _this.queue.concat(context);\n if (context.timeout === 0) {\n _this.schedule(_this.config.flushIntervalMillis);\n return;\n }\n setTimeout(function () {\n context.timeout = 0;\n _this.schedule(0);\n }, context.timeout);\n });\n this.saveEvents();\n };\n Destination.prototype.schedule = function (timeout) {\n var _this = this;\n if (this.scheduled)\n return;\n this.scheduled = setTimeout(function () {\n void _this.flush(true).then(function () {\n if (_this.queue.length > 0) {\n _this.schedule(timeout);\n }\n });\n }, timeout);\n };\n Destination.prototype.flush = function (useRetry) {\n if (useRetry === void 0) { useRetry = false; }\n return __awaiter(this, void 0, void 0, function () {\n var list, later, batches;\n var _this = this;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n list = [];\n later = [];\n this.queue.forEach(function (context) { return (context.timeout === 0 ? list.push(context) : later.push(context)); });\n this.queue = later;\n if (this.scheduled) {\n clearTimeout(this.scheduled);\n this.scheduled = null;\n }\n batches = chunk(list, this.config.flushQueueSize);\n return [4 /*yield*/, Promise.all(batches.map(function (batch) { return _this.send(batch, useRetry); }))];\n case 1:\n _a.sent();\n return [2 /*return*/];\n }\n });\n });\n };\n Destination.prototype.send = function (list, useRetry) {\n if (useRetry === void 0) { useRetry = true; }\n return __awaiter(this, void 0, void 0, function () {\n var payload, serverUrl, res, e_1, errorMessage;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (!this.config.apiKey) {\n return [2 /*return*/, this.fulfillRequest(list, 400, MISSING_API_KEY_MESSAGE)];\n }\n payload = {\n api_key: this.config.apiKey,\n events: list.map(function (context) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n var _a = context.event, extra = _a.extra, eventWithoutExtra = __rest(_a, [\"extra\"]);\n return eventWithoutExtra;\n }),\n options: {\n min_id_length: this.config.minIdLength,\n },\n };\n _a.label = 1;\n case 1:\n _a.trys.push([1, 3, , 4]);\n serverUrl = createServerConfig(this.config.serverUrl, this.config.serverZone, this.config.useBatch).serverUrl;\n return [4 /*yield*/, this.config.transportProvider.send(serverUrl, payload)];\n case 2:\n res = _a.sent();\n if (res === null) {\n this.fulfillRequest(list, 0, UNEXPECTED_ERROR_MESSAGE);\n return [2 /*return*/];\n }\n if (!useRetry) {\n if ('body' in res) {\n this.fulfillRequest(list, res.statusCode, \"\".concat(res.status, \": \").concat(getResponseBodyString(res)));\n }\n else {\n this.fulfillRequest(list, res.statusCode, res.status);\n }\n return [2 /*return*/];\n }\n this.handleResponse(res, list);\n return [3 /*break*/, 4];\n case 3:\n e_1 = _a.sent();\n errorMessage = getErrorMessage(e_1);\n this.config.loggerProvider.error(errorMessage);\n this.fulfillRequest(list, 0, errorMessage);\n return [3 /*break*/, 4];\n case 4: return [2 /*return*/];\n }\n });\n });\n };\n Destination.prototype.handleResponse = function (res, list) {\n var status = res.status;\n switch (status) {\n case Status.Success: {\n this.handleSuccessResponse(res, list);\n break;\n }\n case Status.Invalid: {\n this.handleInvalidResponse(res, list);\n break;\n }\n case Status.PayloadTooLarge: {\n this.handlePayloadTooLargeResponse(res, list);\n break;\n }\n case Status.RateLimit: {\n this.handleRateLimitResponse(res, list);\n break;\n }\n default: {\n // log intermediate event status before retry\n this.config.loggerProvider.warn(\"{code: 0, error: \\\"Status '\".concat(status, \"' provided for \").concat(list.length, \" events\\\"}\"));\n this.handleOtherResponse(list);\n break;\n }\n }\n };\n Destination.prototype.handleSuccessResponse = function (res, list) {\n this.fulfillRequest(list, res.statusCode, SUCCESS_MESSAGE);\n };\n Destination.prototype.handleInvalidResponse = function (res, list) {\n var _this = this;\n if (res.body.missingField || res.body.error.startsWith(INVALID_API_KEY)) {\n this.fulfillRequest(list, res.statusCode, res.body.error);\n return;\n }\n var dropIndex = __spreadArray(__spreadArray(__spreadArray(__spreadArray([], __read(Object.values(res.body.eventsWithInvalidFields)), false), __read(Object.values(res.body.eventsWithMissingFields)), false), __read(Object.values(res.body.eventsWithInvalidIdLengths)), false), __read(res.body.silencedEvents), false).flat();\n var dropIndexSet = new Set(dropIndex);\n var retry = list.filter(function (context, index) {\n if (dropIndexSet.has(index)) {\n _this.fulfillRequest([context], res.statusCode, res.body.error);\n return;\n }\n return true;\n });\n if (retry.length > 0) {\n // log intermediate event status before retry\n this.config.loggerProvider.warn(getResponseBodyString(res));\n }\n this.addToQueue.apply(this, __spreadArray([], __read(retry), false));\n };\n Destination.prototype.handlePayloadTooLargeResponse = function (res, list) {\n if (list.length === 1) {\n this.fulfillRequest(list, res.statusCode, res.body.error);\n return;\n }\n // log intermediate event status before retry\n this.config.loggerProvider.warn(getResponseBodyString(res));\n this.config.flushQueueSize /= 2;\n this.addToQueue.apply(this, __spreadArray([], __read(list), false));\n };\n Destination.prototype.handleRateLimitResponse = function (res, list) {\n var _this = this;\n var dropUserIds = Object.keys(res.body.exceededDailyQuotaUsers);\n var dropDeviceIds = Object.keys(res.body.exceededDailyQuotaDevices);\n var throttledIndex = res.body.throttledEvents;\n var dropUserIdsSet = new Set(dropUserIds);\n var dropDeviceIdsSet = new Set(dropDeviceIds);\n var throttledIndexSet = new Set(throttledIndex);\n var retry = list.filter(function (context, index) {\n if ((context.event.user_id && dropUserIdsSet.has(context.event.user_id)) ||\n (context.event.device_id && dropDeviceIdsSet.has(context.event.device_id))) {\n _this.fulfillRequest([context], res.statusCode, res.body.error);\n return;\n }\n if (throttledIndexSet.has(index)) {\n context.timeout = _this.throttleTimeout;\n }\n return true;\n });\n if (retry.length > 0) {\n // log intermediate event status before retry\n this.config.loggerProvider.warn(getResponseBodyString(res));\n }\n this.addToQueue.apply(this, __spreadArray([], __read(retry), false));\n };\n Destination.prototype.handleOtherResponse = function (list) {\n var _this = this;\n this.addToQueue.apply(this, __spreadArray([], __read(list.map(function (context) {\n context.timeout = context.attempts * _this.retryTimeout;\n return context;\n })), false));\n };\n Destination.prototype.fulfillRequest = function (list, code, message) {\n this.saveEvents();\n list.forEach(function (context) { return context.callback(buildResult(context.event, code, message)); });\n };\n /**\n * Saves events to storage\n * This is called on\n * 1) new events are added to queue; or\n * 2) response comes back for a request\n */\n Destination.prototype.saveEvents = function () {\n if (!this.config.storageProvider) {\n return;\n }\n var events = Array.from(this.queue.map(function (context) { return context.event; }));\n void this.config.storageProvider.set(this.storageKey, events);\n };\n return Destination;\n}());\nexport { Destination };\n//# sourceMappingURL=destination.js.map","// Creates an array of elements split into groups the length of size.\n// If array can't be split evenly, the final chunk will be the remaining elements.\n// Works similary as https://lodash.com/docs/4.17.15#chunk\nexport var chunk = function (arr, size) {\n var chunkSize = Math.max(size, 1);\n return arr.reduce(function (chunks, element, index) {\n var chunkIndex = Math.floor(index / chunkSize);\n if (!chunks[chunkIndex]) {\n chunks[chunkIndex] = [];\n }\n chunks[chunkIndex].push(element);\n return chunks;\n }, []);\n};\n//# sourceMappingURL=chunk.js.map","import { LogLevel, ServerZone, } from '@amplitude/analytics-types';\nimport { AMPLITUDE_SERVER_URL, AMPLITUDE_BATCH_SERVER_URL, EU_AMPLITUDE_SERVER_URL, EU_AMPLITUDE_BATCH_SERVER_URL, } from './constants';\nimport { Logger } from './logger';\nexport var getDefaultConfig = function () { return ({\n flushMaxRetries: 12,\n flushQueueSize: 200,\n flushIntervalMillis: 10000,\n instanceName: '$default_instance',\n logLevel: LogLevel.Warn,\n loggerProvider: new Logger(),\n optOut: false,\n serverUrl: AMPLITUDE_SERVER_URL,\n serverZone: ServerZone.US,\n useBatch: false,\n}); };\nvar Config = /** @class */ (function () {\n function Config(options) {\n var _a, _b, _c, _d;\n this._optOut = false;\n var defaultConfig = getDefaultConfig();\n this.apiKey = options.apiKey;\n this.flushIntervalMillis = (_a = options.flushIntervalMillis) !== null && _a !== void 0 ? _a : defaultConfig.flushIntervalMillis;\n this.flushMaxRetries = options.flushMaxRetries || defaultConfig.flushMaxRetries;\n this.flushQueueSize = options.flushQueueSize || defaultConfig.flushQueueSize;\n this.instanceName = options.instanceName || defaultConfig.instanceName;\n this.loggerProvider = options.loggerProvider || defaultConfig.loggerProvider;\n this.logLevel = (_b = options.logLevel) !== null && _b !== void 0 ? _b : defaultConfig.logLevel;\n this.minIdLength = options.minIdLength;\n this.plan = options.plan;\n this.ingestionMetadata = options.ingestionMetadata;\n this.optOut = (_c = options.optOut) !== null && _c !== void 0 ? _c : defaultConfig.optOut;\n this.serverUrl = options.serverUrl;\n this.serverZone = options.serverZone || defaultConfig.serverZone;\n this.storageProvider = options.storageProvider;\n this.transportProvider = options.transportProvider;\n this.useBatch = (_d = options.useBatch) !== null && _d !== void 0 ? _d : defaultConfig.useBatch;\n this.loggerProvider.enable(this.logLevel);\n var serverConfig = createServerConfig(options.serverUrl, options.serverZone, options.useBatch);\n this.serverZone = serverConfig.serverZone;\n this.serverUrl = serverConfig.serverUrl;\n }\n Object.defineProperty(Config.prototype, \"optOut\", {\n get: function () {\n return this._optOut;\n },\n set: function (optOut) {\n this._optOut = optOut;\n },\n enumerable: false,\n configurable: true\n });\n return Config;\n}());\nexport { Config };\nexport var getServerUrl = function (serverZone, useBatch) {\n if (serverZone === ServerZone.EU) {\n return useBatch ? EU_AMPLITUDE_BATCH_SERVER_URL : EU_AMPLITUDE_SERVER_URL;\n }\n return useBatch ? AMPLITUDE_BATCH_SERVER_URL : AMPLITUDE_SERVER_URL;\n};\nexport var createServerConfig = function (serverUrl, serverZone, useBatch) {\n if (serverUrl === void 0) { serverUrl = ''; }\n if (serverZone === void 0) { serverZone = getDefaultConfig().serverZone; }\n if (useBatch === void 0) { useBatch = getDefaultConfig().useBatch; }\n if (serverUrl) {\n return { serverUrl: serverUrl, serverZone: undefined };\n }\n var _serverZone = ['US', 'EU'].includes(serverZone) ? serverZone : getDefaultConfig().serverZone;\n return {\n serverZone: _serverZone,\n serverUrl: getServerUrl(_serverZone, useBatch),\n };\n};\n//# sourceMappingURL=config.js.map","import { LogLevel } from '@amplitude/analytics-types';\nvar PREFIX = 'Amplitude Logger ';\nvar Logger = /** @class */ (function () {\n function Logger() {\n this.logLevel = LogLevel.None;\n }\n Logger.prototype.disable = function () {\n this.logLevel = LogLevel.None;\n };\n Logger.prototype.enable = function (logLevel) {\n if (logLevel === void 0) { logLevel = LogLevel.Warn; }\n this.logLevel = logLevel;\n };\n Logger.prototype.log = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n if (this.logLevel < LogLevel.Verbose) {\n return;\n }\n console.log(\"\".concat(PREFIX, \"[Log]: \").concat(args.join(' ')));\n };\n Logger.prototype.warn = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n if (this.logLevel < LogLevel.Warn) {\n return;\n }\n console.warn(\"\".concat(PREFIX, \"[Warn]: \").concat(args.join(' ')));\n };\n Logger.prototype.error = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n if (this.logLevel < LogLevel.Error) {\n return;\n }\n console.error(\"\".concat(PREFIX, \"[Error]: \").concat(args.join(' ')));\n };\n Logger.prototype.debug = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n if (this.logLevel < LogLevel.Debug) {\n return;\n }\n // console.debug output is hidden by default in chrome\n console.log(\"\".concat(PREFIX, \"[Debug]: \").concat(args.join(' ')));\n };\n return Logger;\n}());\nexport { Logger };\n//# sourceMappingURL=logger.js.map","import { __assign, __values } from \"tslib\";\n/* eslint-disable @typescript-eslint/no-unsafe-assignment */\n/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable @typescript-eslint/no-unsafe-call */\n/* eslint-disable @typescript-eslint/no-non-null-assertion */\nimport { LogLevel } from '@amplitude/analytics-types';\nexport var getStacktrace = function (ignoreDepth) {\n if (ignoreDepth === void 0) { ignoreDepth = 0; }\n var trace = new Error().stack || '';\n return trace\n .split('\\n')\n .slice(2 + ignoreDepth)\n .map(function (text) { return text.trim(); });\n};\n// This hook makes sure we always get the latest logger and logLevel.\nexport var getClientLogConfig = function (client) { return function () {\n var _a = __assign({}, client.config), logger = _a.loggerProvider, logLevel = _a.logLevel;\n return {\n logger: logger,\n logLevel: logLevel,\n };\n}; };\n// This is a convenient function to get the attribute from object with string path, similar to lodash '#get'.\nexport var getValueByStringPath = function (obj, path) {\n var e_1, _a;\n path = path.replace(/\\[(\\w+)\\]/g, '.$1'); // convert indexes to properties\n path = path.replace(/^\\./, ''); // strip a leading dot\n try {\n for (var _b = __values(path.split('.')), _c = _b.next(); !_c.done; _c = _b.next()) {\n var attr = _c.value;\n if (attr in obj) {\n obj = obj[attr];\n }\n else {\n return;\n }\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\n }\n finally { if (e_1) throw e_1.error; }\n }\n return obj;\n};\nexport var getClientStates = function (client, paths) { return function () {\n var e_2, _a;\n var res = {};\n try {\n for (var paths_1 = __values(paths), paths_1_1 = paths_1.next(); !paths_1_1.done; paths_1_1 = paths_1.next()) {\n var path = paths_1_1.value;\n res[path] = getValueByStringPath(client, path);\n }\n }\n catch (e_2_1) { e_2 = { error: e_2_1 }; }\n finally {\n try {\n if (paths_1_1 && !paths_1_1.done && (_a = paths_1.return)) _a.call(paths_1);\n }\n finally { if (e_2) throw e_2.error; }\n }\n return res;\n}; };\nexport var debugWrapper = function (fn, fnName, getLogConfig, getStates, fnContext) {\n if (fnContext === void 0) { fnContext = null; }\n return function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var _a = getLogConfig(), logger = _a.logger, logLevel = _a.logLevel;\n // return early if possible to reduce overhead\n if ((logLevel && logLevel < LogLevel.Debug) || !logLevel || !logger) {\n return fn.apply(fnContext, args);\n }\n var debugContext = {\n type: 'invoke public method',\n name: fnName,\n args: args,\n stacktrace: getStacktrace(1),\n time: {\n start: new Date().toISOString(),\n },\n states: {},\n };\n if (getStates && debugContext.states) {\n debugContext.states.before = getStates();\n }\n var result = fn.apply(fnContext, args);\n if (result && result.promise) {\n // if result is a promise, add the callback\n result.promise.then(function () {\n if (getStates && debugContext.states) {\n debugContext.states.after = getStates();\n }\n if (debugContext.time) {\n debugContext.time.end = new Date().toISOString();\n }\n logger.debug(JSON.stringify(debugContext, null, 2));\n });\n }\n else {\n if (getStates && debugContext.states) {\n debugContext.states.after = getStates();\n }\n if (debugContext.time) {\n debugContext.time.end = new Date().toISOString();\n }\n logger.debug(JSON.stringify(debugContext, null, 2));\n }\n return result;\n };\n};\n//# sourceMappingURL=debug.js.map","/**\n * Source: [jed's gist]{@link https://gist.github.com/982883}.\n * Returns a random v4 UUID of the form xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx,\n * where each x is replaced with a random hexadecimal digit from 0 to f, and\n * y is replaced with a random hexadecimal digit from 8 to b.\n * Used to generate UUIDs for deviceIds.\n * @private\n */\nexport var UUID = function (a) {\n return a // if the placeholder was passed, return\n ? // a random number from 0 to 15\n (a ^ // unless b is 8,\n ((Math.random() * // in which case\n 16) >> // a random number from\n (a / 4))) // 8 to 11\n .toString(16) // in hexadecimal\n : // or otherwise a concatenated string:\n (String(1e7) + // 10000000 +\n String(-1e3) + // -1000 +\n String(-4e3) + // -4000 +\n String(-8e3) + // -80000000 +\n String(-1e11)) // -100000000000,\n .replace(\n // replacing\n /[018]/g, // zeroes, ones, and eights with\n UUID);\n};\n//# sourceMappingURL=uuid.js.map","import { __awaiter, __generator } from \"tslib\";\nvar MemoryStorage = /** @class */ (function () {\n function MemoryStorage() {\n this.memoryStorage = new Map();\n }\n MemoryStorage.prototype.isEnabled = function () {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n return [2 /*return*/, true];\n });\n });\n };\n MemoryStorage.prototype.get = function (key) {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n return [2 /*return*/, this.memoryStorage.get(key)];\n });\n });\n };\n MemoryStorage.prototype.getRaw = function (key) {\n return __awaiter(this, void 0, void 0, function () {\n var value;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, this.get(key)];\n case 1:\n value = _a.sent();\n return [2 /*return*/, value ? JSON.stringify(value) : undefined];\n }\n });\n });\n };\n MemoryStorage.prototype.set = function (key, value) {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n this.memoryStorage.set(key, value);\n return [2 /*return*/];\n });\n });\n };\n MemoryStorage.prototype.remove = function (key) {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n this.memoryStorage.delete(key);\n return [2 /*return*/];\n });\n });\n };\n MemoryStorage.prototype.reset = function () {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n this.memoryStorage.clear();\n return [2 /*return*/];\n });\n });\n };\n return MemoryStorage;\n}());\nexport { MemoryStorage };\n//# sourceMappingURL=memory.js.map","/* eslint-disable @typescript-eslint/no-unsafe-argument */\n/* eslint-disable @typescript-eslint/no-unsafe-assignment */\n/* eslint-disable @typescript-eslint/no-unsafe-call */\nimport { Status } from '@amplitude/analytics-types';\nvar BaseTransport = /** @class */ (function () {\n function BaseTransport() {\n }\n BaseTransport.prototype.send = function (_serverUrl, _payload) {\n return Promise.resolve(null);\n };\n BaseTransport.prototype.buildResponse = function (responseJSON) {\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x;\n if (typeof responseJSON !== 'object') {\n return null;\n }\n var statusCode = responseJSON.code || 0;\n var status = this.buildStatus(statusCode);\n switch (status) {\n case Status.Success:\n return {\n status: status,\n statusCode: statusCode,\n body: {\n eventsIngested: (_a = responseJSON.events_ingested) !== null && _a !== void 0 ? _a : 0,\n payloadSizeBytes: (_b = responseJSON.payload_size_bytes) !== null && _b !== void 0 ? _b : 0,\n serverUploadTime: (_c = responseJSON.server_upload_time) !== null && _c !== void 0 ? _c : 0,\n },\n };\n case Status.Invalid:\n return {\n status: status,\n statusCode: statusCode,\n body: {\n error: (_d = responseJSON.error) !== null && _d !== void 0 ? _d : '',\n missingField: (_e = responseJSON.missing_field) !== null && _e !== void 0 ? _e : '',\n eventsWithInvalidFields: (_f = responseJSON.events_with_invalid_fields) !== null && _f !== void 0 ? _f : {},\n eventsWithMissingFields: (_g = responseJSON.events_with_missing_fields) !== null && _g !== void 0 ? _g : {},\n eventsWithInvalidIdLengths: (_h = responseJSON.events_with_invalid_id_lengths) !== null && _h !== void 0 ? _h : {},\n epsThreshold: (_j = responseJSON.eps_threshold) !== null && _j !== void 0 ? _j : 0,\n exceededDailyQuotaDevices: (_k = responseJSON.exceeded_daily_quota_devices) !== null && _k !== void 0 ? _k : {},\n silencedDevices: (_l = responseJSON.silenced_devices) !== null && _l !== void 0 ? _l : [],\n silencedEvents: (_m = responseJSON.silenced_events) !== null && _m !== void 0 ? _m : [],\n throttledDevices: (_o = responseJSON.throttled_devices) !== null && _o !== void 0 ? _o : {},\n throttledEvents: (_p = responseJSON.throttled_events) !== null && _p !== void 0 ? _p : [],\n },\n };\n case Status.PayloadTooLarge:\n return {\n status: status,\n statusCode: statusCode,\n body: {\n error: (_q = responseJSON.error) !== null && _q !== void 0 ? _q : '',\n },\n };\n case Status.RateLimit:\n return {\n status: status,\n statusCode: statusCode,\n body: {\n error: (_r = responseJSON.error) !== null && _r !== void 0 ? _r : '',\n epsThreshold: (_s = responseJSON.eps_threshold) !== null && _s !== void 0 ? _s : 0,\n throttledDevices: (_t = responseJSON.throttled_devices) !== null && _t !== void 0 ? _t : {},\n throttledUsers: (_u = responseJSON.throttled_users) !== null && _u !== void 0 ? _u : {},\n exceededDailyQuotaDevices: (_v = responseJSON.exceeded_daily_quota_devices) !== null && _v !== void 0 ? _v : {},\n exceededDailyQuotaUsers: (_w = responseJSON.exceeded_daily_quota_users) !== null && _w !== void 0 ? _w : {},\n throttledEvents: (_x = responseJSON.throttled_events) !== null && _x !== void 0 ? _x : [],\n },\n };\n case Status.Timeout:\n default:\n return {\n status: status,\n statusCode: statusCode,\n };\n }\n };\n BaseTransport.prototype.buildStatus = function (code) {\n if (code >= 200 && code < 300) {\n return Status.Success;\n }\n if (code === 429) {\n return Status.RateLimit;\n }\n if (code === 413) {\n return Status.PayloadTooLarge;\n }\n if (code === 408) {\n return Status.Timeout;\n }\n if (code >= 400 && code < 500) {\n return Status.Invalid;\n }\n if (code >= 500) {\n return Status.Failed;\n }\n return Status.Unknown;\n };\n return BaseTransport;\n}());\nexport { BaseTransport };\n//# sourceMappingURL=base.js.map","export { getAnalyticsConnector, setConnectorDeviceId, setConnectorOptOut, setConnectorUserId, } from './analytics-connector';\nexport { CampaignParser } from './attribution/campaign-parser';\nexport { CampaignTracker } from './attribution/campaign-tracker';\nexport { BASE_CAMPAIGN } from './attribution/constants';\nexport { getCookieName, getOldCookieName } from './cookie-name';\nexport { getPageViewTrackingConfig, isFileDownloadTrackingEnabled, isFormInteractionTrackingEnabled, isPageViewTrackingEnabled, isSessionTrackingEnabled, } from './default-tracking';\nexport { getGlobalScope } from './global-scope';\nexport { getLanguage } from './language';\nexport { IdentityEventSender } from './plugins/identity';\nexport { getQueryParams } from './query-params';\nexport { CookieStorage } from './storage/cookie';\nexport { FetchTransport } from './transports/fetch';\n//# sourceMappingURL=index.js.map","import { AnalyticsConnector } from '@amplitude/analytics-connector';\nexport var getAnalyticsConnector = function (instanceName) {\n if (instanceName === void 0) { instanceName = '$default_instance'; }\n return AnalyticsConnector.getInstance(instanceName);\n};\nexport var setConnectorUserId = function (userId, instanceName) {\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n getAnalyticsConnector(instanceName).identityStore.editIdentity().setUserId(userId).commit();\n};\nexport var setConnectorDeviceId = function (deviceId, instanceName) {\n getAnalyticsConnector(instanceName).identityStore.editIdentity().setDeviceId(deviceId).commit();\n};\nexport var setConnectorOptOut = function (optOut, instanceName) {\n getAnalyticsConnector(instanceName).identityStore.editIdentity().setOptOut(optOut).commit();\n};\n//# sourceMappingURL=analytics-connector.js.map","var ApplicationContextProviderImpl = /** @class */ (function () {\n function ApplicationContextProviderImpl() {\n }\n ApplicationContextProviderImpl.prototype.getApplicationContext = function () {\n return {\n versionName: this.versionName,\n language: getLanguage(),\n platform: 'Web',\n os: undefined,\n deviceModel: undefined,\n };\n };\n return ApplicationContextProviderImpl;\n}());\nvar getLanguage = function () {\n return ((typeof navigator !== 'undefined' &&\n ((navigator.languages && navigator.languages[0]) ||\n navigator.language)) ||\n '');\n};\n\nvar EventBridgeImpl = /** @class */ (function () {\n function EventBridgeImpl() {\n this.queue = [];\n }\n EventBridgeImpl.prototype.logEvent = function (event) {\n if (!this.receiver) {\n if (this.queue.length < 512) {\n this.queue.push(event);\n }\n }\n else {\n this.receiver(event);\n }\n };\n EventBridgeImpl.prototype.setEventReceiver = function (receiver) {\n this.receiver = receiver;\n if (this.queue.length > 0) {\n this.queue.forEach(function (event) {\n receiver(event);\n });\n this.queue = [];\n }\n };\n return EventBridgeImpl;\n}());\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***************************************************************************** */\nvar __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\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nvar isEqual = function (obj1, obj2) {\n var primitive = ['string', 'number', 'boolean', 'undefined'];\n var typeA = typeof obj1;\n var typeB = typeof obj2;\n if (typeA !== typeB) {\n return false;\n }\n for (var _i = 0, primitive_1 = primitive; _i < primitive_1.length; _i++) {\n var p = primitive_1[_i];\n if (p === typeA) {\n return obj1 === obj2;\n }\n }\n // check null\n if (obj1 == null && obj2 == null) {\n return true;\n }\n else if (obj1 == null || obj2 == null) {\n return false;\n }\n // if got here - objects\n if (obj1.length !== obj2.length) {\n return false;\n }\n //check if arrays\n var isArrayA = Array.isArray(obj1);\n var isArrayB = Array.isArray(obj2);\n if (isArrayA !== isArrayB) {\n return false;\n }\n if (isArrayA && isArrayB) {\n //arrays\n for (var i = 0; i < obj1.length; i++) {\n if (!isEqual(obj1[i], obj2[i])) {\n return false;\n }\n }\n }\n else {\n //objects\n var sorted1 = Object.keys(obj1).sort();\n var sorted2 = Object.keys(obj2).sort();\n if (!isEqual(sorted1, sorted2)) {\n return false;\n }\n //compare object values\n var result_1 = true;\n Object.keys(obj1).forEach(function (key) {\n if (!isEqual(obj1[key], obj2[key])) {\n result_1 = false;\n }\n });\n return result_1;\n }\n return true;\n};\n\nvar ID_OP_SET = '$set';\nvar ID_OP_UNSET = '$unset';\nvar ID_OP_CLEAR_ALL = '$clearAll';\n// Polyfill for Object.entries\nif (!Object.entries) {\n Object.entries = function (obj) {\n var ownProps = Object.keys(obj);\n var i = ownProps.length;\n var resArray = new Array(i);\n while (i--) {\n resArray[i] = [ownProps[i], obj[ownProps[i]]];\n }\n return resArray;\n };\n}\nvar IdentityStoreImpl = /** @class */ (function () {\n function IdentityStoreImpl() {\n this.identity = { userProperties: {} };\n this.listeners = new Set();\n }\n IdentityStoreImpl.prototype.editIdentity = function () {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n var self = this;\n var actingUserProperties = __assign({}, this.identity.userProperties);\n var actingIdentity = __assign(__assign({}, this.identity), { userProperties: actingUserProperties });\n return {\n setUserId: function (userId) {\n actingIdentity.userId = userId;\n return this;\n },\n setDeviceId: function (deviceId) {\n actingIdentity.deviceId = deviceId;\n return this;\n },\n setUserProperties: function (userProperties) {\n actingIdentity.userProperties = userProperties;\n return this;\n },\n setOptOut: function (optOut) {\n actingIdentity.optOut = optOut;\n return this;\n },\n updateUserProperties: function (actions) {\n var actingProperties = actingIdentity.userProperties || {};\n for (var _i = 0, _a = Object.entries(actions); _i < _a.length; _i++) {\n var _b = _a[_i], action = _b[0], properties = _b[1];\n switch (action) {\n case ID_OP_SET:\n for (var _c = 0, _d = Object.entries(properties); _c < _d.length; _c++) {\n var _e = _d[_c], key = _e[0], value = _e[1];\n actingProperties[key] = value;\n }\n break;\n case ID_OP_UNSET:\n for (var _f = 0, _g = Object.keys(properties); _f < _g.length; _f++) {\n var key = _g[_f];\n delete actingProperties[key];\n }\n break;\n case ID_OP_CLEAR_ALL:\n actingProperties = {};\n break;\n }\n }\n actingIdentity.userProperties = actingProperties;\n return this;\n },\n commit: function () {\n self.setIdentity(actingIdentity);\n return this;\n },\n };\n };\n IdentityStoreImpl.prototype.getIdentity = function () {\n return __assign({}, this.identity);\n };\n IdentityStoreImpl.prototype.setIdentity = function (identity) {\n var originalIdentity = __assign({}, this.identity);\n this.identity = __assign({}, identity);\n if (!isEqual(originalIdentity, this.identity)) {\n this.listeners.forEach(function (listener) {\n listener(identity);\n });\n }\n };\n IdentityStoreImpl.prototype.addIdentityListener = function (listener) {\n this.listeners.add(listener);\n };\n IdentityStoreImpl.prototype.removeIdentityListener = function (listener) {\n this.listeners.delete(listener);\n };\n return IdentityStoreImpl;\n}());\n\nvar safeGlobal = typeof globalThis !== 'undefined'\n ? globalThis\n : typeof global !== 'undefined'\n ? global\n : self;\n\nvar AnalyticsConnector = /** @class */ (function () {\n function AnalyticsConnector() {\n this.identityStore = new IdentityStoreImpl();\n this.eventBridge = new EventBridgeImpl();\n this.applicationContextProvider = new ApplicationContextProviderImpl();\n }\n AnalyticsConnector.getInstance = function (instanceName) {\n if (!safeGlobal['analyticsConnectorInstances']) {\n safeGlobal['analyticsConnectorInstances'] = {};\n }\n if (!safeGlobal['analyticsConnectorInstances'][instanceName]) {\n safeGlobal['analyticsConnectorInstances'][instanceName] =\n new AnalyticsConnector();\n }\n return safeGlobal['analyticsConnectorInstances'][instanceName];\n };\n return AnalyticsConnector;\n}());\n\nexport { AnalyticsConnector };\n","import { __assign, __awaiter, __generator } from \"tslib\";\nimport { getQueryParams } from '../query-params';\nimport { UTM_CAMPAIGN, UTM_CONTENT, UTM_MEDIUM, UTM_SOURCE, UTM_TERM, GCLID, FBCLID, BASE_CAMPAIGN, DCLID, MSCLKID, RDT_CID, TWCLID, TTCLID, KO_CLICK_ID, LI_FAT_ID, GBRAID, WBRAID, UTM_ID, } from './constants';\nvar CampaignParser = /** @class */ (function () {\n function CampaignParser() {\n }\n CampaignParser.prototype.parse = function () {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n return [2 /*return*/, __assign(__assign(__assign(__assign({}, BASE_CAMPAIGN), this.getUtmParam()), this.getReferrer()), this.getClickIds())];\n });\n });\n };\n CampaignParser.prototype.getUtmParam = function () {\n var params = getQueryParams();\n var utmCampaign = params[UTM_CAMPAIGN];\n var utmContent = params[UTM_CONTENT];\n var utmId = params[UTM_ID];\n var utmMedium = params[UTM_MEDIUM];\n var utmSource = params[UTM_SOURCE];\n var utmTerm = params[UTM_TERM];\n return {\n utm_campaign: utmCampaign,\n utm_content: utmContent,\n utm_id: utmId,\n utm_medium: utmMedium,\n utm_source: utmSource,\n utm_term: utmTerm,\n };\n };\n CampaignParser.prototype.getReferrer = function () {\n var _a, _b;\n var data = {\n referrer: undefined,\n referring_domain: undefined,\n };\n try {\n data.referrer = document.referrer || undefined;\n data.referring_domain = (_b = (_a = data.referrer) === null || _a === void 0 ? void 0 : _a.split('/')[2]) !== null && _b !== void 0 ? _b : undefined;\n }\n catch (_c) {\n // nothing to track\n }\n return data;\n };\n CampaignParser.prototype.getClickIds = function () {\n var _a;\n var params = getQueryParams();\n return _a = {},\n _a[DCLID] = params[DCLID],\n _a[FBCLID] = params[FBCLID],\n _a[GBRAID] = params[GBRAID],\n _a[GCLID] = params[GCLID],\n _a[KO_CLICK_ID] = params[KO_CLICK_ID],\n _a[LI_FAT_ID] = params[LI_FAT_ID],\n _a[MSCLKID] = params[MSCLKID],\n _a[RDT_CID] = params[RDT_CID],\n _a[TTCLID] = params[TTCLID],\n _a[TWCLID] = params[TWCLID],\n _a[WBRAID] = params[WBRAID],\n _a;\n };\n return CampaignParser;\n}());\nexport { CampaignParser };\n//# sourceMappingURL=campaign-parser.js.map","import { getGlobalScope } from './global-scope';\nexport var getQueryParams = function () {\n var _a;\n var globalScope = getGlobalScope();\n /* istanbul ignore if */\n if (!((_a = globalScope === null || globalScope === void 0 ? void 0 : globalScope.location) === null || _a === void 0 ? void 0 : _a.search)) {\n return {};\n }\n var pairs = globalScope.location.search.substring(1).split('&').filter(Boolean);\n var params = pairs.reduce(function (acc, curr) {\n var query = curr.split('=', 2);\n var key = tryDecodeURIComponent(query[0]);\n var value = tryDecodeURIComponent(query[1]);\n if (!value) {\n return acc;\n }\n acc[key] = value;\n return acc;\n }, {});\n return params;\n};\nexport var tryDecodeURIComponent = function (value) {\n if (value === void 0) { value = ''; }\n try {\n return decodeURIComponent(value);\n }\n catch (_a) {\n return '';\n }\n};\n//# sourceMappingURL=query-params.js.map","/* eslint-disable no-restricted-globals */\n/* Only file allowed to access to globalThis, window, self */\nexport var getGlobalScope = function () {\n if (typeof globalThis !== 'undefined') {\n return globalThis;\n }\n if (typeof window !== 'undefined') {\n return window;\n }\n if (typeof self !== 'undefined') {\n return self;\n }\n if (typeof global !== 'undefined') {\n return global;\n }\n return undefined;\n};\n//# sourceMappingURL=global-scope.js.map","export var UTM_CAMPAIGN = 'utm_campaign';\nexport var UTM_CONTENT = 'utm_content';\nexport var UTM_ID = 'utm_id';\nexport var UTM_MEDIUM = 'utm_medium';\nexport var UTM_SOURCE = 'utm_source';\nexport var UTM_TERM = 'utm_term';\nexport var DCLID = 'dclid';\nexport var FBCLID = 'fbclid';\nexport var GBRAID = 'gbraid';\nexport var GCLID = 'gclid';\nexport var KO_CLICK_ID = 'ko_click_id';\nexport var LI_FAT_ID = 'li_fat_id';\nexport var MSCLKID = 'msclkid';\nexport var RDT_CID = 'rtd_cid';\nexport var TTCLID = 'ttclid';\nexport var TWCLID = 'twclid';\nexport var WBRAID = 'wbraid';\nexport var EMPTY_VALUE = 'EMPTY';\nexport var BASE_CAMPAIGN = {\n utm_campaign: undefined,\n utm_content: undefined,\n utm_id: undefined,\n utm_medium: undefined,\n utm_source: undefined,\n utm_term: undefined,\n referrer: undefined,\n referring_domain: undefined,\n dclid: undefined,\n gbraid: undefined,\n gclid: undefined,\n fbclid: undefined,\n ko_click_id: undefined,\n li_fat_id: undefined,\n msclkid: undefined,\n rtd_cid: undefined,\n ttclid: undefined,\n twclid: undefined,\n wbraid: undefined,\n};\nexport var MKTG = 'MKTG';\n//# sourceMappingURL=constants.js.map","import { __assign, __awaiter, __generator, __read, __rest } from \"tslib\";\nimport { createIdentifyEvent, Identify } from '@amplitude/analytics-core';\nimport { getCookieName as getStorageKey } from '../cookie-name';\nimport { CampaignParser } from './campaign-parser';\nimport { BASE_CAMPAIGN, EMPTY_VALUE, MKTG } from './constants';\n/**\n * @deprecated\n * Campaign tracker has mixed logic from built-in and plugin web attribution\n * features. Do not add more features here. The plan moving foward is to consolidate logic\n * in @amplitude/plugin-web-attribution-browser with backward compatibility.\n */\nvar CampaignTracker = /** @class */ (function () {\n function CampaignTracker(apiKey, options) {\n var _a, _b;\n this.storage = options.storage;\n this.storageKey = getStorageKey(apiKey, MKTG);\n this.parser = new CampaignParser();\n this.track = options.track;\n this.onNewCampaign = options.onNewCampaign;\n this.disabled = Boolean(options.disabled);\n this.trackNewCampaigns = Boolean(options.trackNewCampaigns);\n this.trackPageViews = Boolean(options.trackPageViews);\n this.excludeReferrers = (_a = options.excludeReferrers) !== null && _a !== void 0 ? _a : [];\n if (typeof location !== 'undefined') {\n this.excludeReferrers.unshift(location.hostname);\n }\n this.initialEmptyValue = (_b = options.initialEmptyValue) !== null && _b !== void 0 ? _b : EMPTY_VALUE;\n }\n CampaignTracker.prototype.isNewCampaign = function (current, previous, ignoreSubdomainInReferrer) {\n if (ignoreSubdomainInReferrer === void 0) { ignoreSubdomainInReferrer = false; }\n var referrer = current.referrer, referring_domain = current.referring_domain, currentCampaign = __rest(current, [\"referrer\", \"referring_domain\"]);\n var _a = previous || {}, _previous_referrer = _a.referrer, prevReferringDomain = _a.referring_domain, previousCampaign = __rest(_a, [\"referrer\", \"referring_domain\"]);\n if (current.referring_domain && this.excludeReferrers.includes(current.referring_domain)) {\n return false;\n }\n var hasNewCampaign = JSON.stringify(currentCampaign) !== JSON.stringify(previousCampaign);\n var hasNewDomain = ignoreSubdomainInReferrer\n ? domainWithoutSubdomain(referring_domain || '') !== domainWithoutSubdomain(prevReferringDomain || '')\n : referring_domain !== prevReferringDomain;\n return !previous || hasNewCampaign || hasNewDomain;\n };\n CampaignTracker.prototype.saveCampaignToStorage = function (campaign) {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, this.storage.set(this.storageKey, campaign)];\n case 1:\n _a.sent();\n return [2 /*return*/];\n }\n });\n });\n };\n CampaignTracker.prototype.getCampaignFromStorage = function () {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, this.storage.get(this.storageKey)];\n case 1: return [2 /*return*/, _a.sent()];\n }\n });\n });\n };\n CampaignTracker.prototype.createCampaignEvent = function (campaign) {\n var _this = this;\n var campaignParameters = __assign(__assign({}, BASE_CAMPAIGN), campaign);\n var identifyEvent = Object.entries(campaignParameters).reduce(function (identify, _a) {\n var _b = __read(_a, 2), key = _b[0], value = _b[1];\n identify.setOnce(\"initial_\".concat(key), value || _this.initialEmptyValue);\n if (value) {\n return identify.set(key, value);\n }\n return identify.unset(key);\n }, new Identify());\n var pageViewEvent = {\n event_type: 'Page View',\n event_properties: {\n page_title: /* istanbul ignore next */ (typeof document !== 'undefined' && document.title) || '',\n page_location: /* istanbul ignore next */ (typeof location !== 'undefined' && location.href) || '',\n page_path: /* istanbul ignore next */ (typeof location !== 'undefined' && location.pathname) || '',\n },\n };\n return __assign(__assign({}, createIdentifyEvent(identifyEvent)), (this.trackPageViews && pageViewEvent));\n };\n CampaignTracker.prototype.send = function (isNewSession) {\n return __awaiter(this, void 0, void 0, function () {\n var currentCampaign, previousCampaign;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n if (this.disabled) {\n return [2 /*return*/];\n }\n return [4 /*yield*/, this.parser.parse()];\n case 1:\n currentCampaign = _a.sent();\n return [4 /*yield*/, this.getCampaignFromStorage()];\n case 2:\n previousCampaign = _a.sent();\n if (!isNewSession) {\n if (!this.trackNewCampaigns || !this.isNewCampaign(currentCampaign, previousCampaign)) {\n return [2 /*return*/];\n }\n this.onNewCampaign(currentCampaign);\n }\n return [4 /*yield*/, this.track(this.createCampaignEvent(currentCampaign))];\n case 3:\n _a.sent();\n return [4 /*yield*/, this.saveCampaignToStorage(currentCampaign)];\n case 4:\n _a.sent();\n return [2 /*return*/];\n }\n });\n });\n };\n return CampaignTracker;\n}());\nexport { CampaignTracker };\nvar domainWithoutSubdomain = function (domain) {\n var parts = domain.split('.');\n if (parts.length <= 2) {\n return domain;\n }\n return parts.slice(parts.length - 2, parts.length).join('.');\n};\n//# sourceMappingURL=campaign-tracker.js.map","import { AMPLITUDE_PREFIX } from '@amplitude/analytics-core';\nexport var getCookieName = function (apiKey, postKey, limit) {\n if (postKey === void 0) { postKey = ''; }\n if (limit === void 0) { limit = 10; }\n return [AMPLITUDE_PREFIX, postKey, apiKey.substring(0, limit)].filter(Boolean).join('_');\n};\nexport var getOldCookieName = function (apiKey) {\n return \"\".concat(AMPLITUDE_PREFIX.toLowerCase(), \"_\").concat(apiKey.substring(0, 6));\n};\n//# sourceMappingURL=cookie-name.js.map","export var isFileDownloadTrackingEnabled = function (defaultTracking) {\n if (typeof defaultTracking === 'boolean') {\n return defaultTracking;\n }\n if (defaultTracking === null || defaultTracking === void 0 ? void 0 : defaultTracking.fileDownloads) {\n return true;\n }\n return false;\n};\nexport var isFormInteractionTrackingEnabled = function (defaultTracking) {\n if (typeof defaultTracking === 'boolean') {\n return defaultTracking;\n }\n if (defaultTracking === null || defaultTracking === void 0 ? void 0 : defaultTracking.formInteractions) {\n return true;\n }\n return false;\n};\nexport var isPageViewTrackingEnabled = function (defaultTracking) {\n if (typeof defaultTracking === 'boolean') {\n return defaultTracking;\n }\n if ((defaultTracking === null || defaultTracking === void 0 ? void 0 : defaultTracking.pageViews) === true ||\n ((defaultTracking === null || defaultTracking === void 0 ? void 0 : defaultTracking.pageViews) && typeof defaultTracking.pageViews === 'object')) {\n return true;\n }\n return false;\n};\nexport var isSessionTrackingEnabled = function (defaultTracking) {\n if (typeof defaultTracking === 'boolean') {\n return defaultTracking;\n }\n if (defaultTracking === null || defaultTracking === void 0 ? void 0 : defaultTracking.sessions) {\n return true;\n }\n return false;\n};\n/**\n * Returns page view tracking config\n *\n * if config.attribution.trackPageViews and config.defaultTracking.pageViews are both TRUE\n * then always track page views\n *\n * if config.attribution.trackPageViews is TRUE and config.defaultTracking.pageViews is FALSE\n * then only track page views on attribution\n *\n * if config.attribution.trackPageViews is FALSE and config.defaultTracking.pageViews is TRUE\n * then always track page views\n *\n * if config.attribution.trackPageViews and config.defaultTracking.pageViews are both FALSE\n * then never track page views\n */\nexport var getPageViewTrackingConfig = function (config) {\n var _a;\n var trackOn = ((_a = config.attribution) === null || _a === void 0 ? void 0 : _a.trackPageViews) ? 'attribution' : function () { return false; };\n var trackHistoryChanges = undefined;\n var eventType = 'Page View';\n var isDefaultPageViewTrackingEnabled = isPageViewTrackingEnabled(config.defaultTracking);\n if (isDefaultPageViewTrackingEnabled) {\n trackOn = undefined;\n eventType = undefined;\n if (config.defaultTracking &&\n typeof config.defaultTracking === 'object' &&\n config.defaultTracking.pageViews &&\n typeof config.defaultTracking.pageViews === 'object') {\n if ('trackOn' in config.defaultTracking.pageViews) {\n trackOn = config.defaultTracking.pageViews.trackOn;\n }\n if ('trackHistoryChanges' in config.defaultTracking.pageViews) {\n trackHistoryChanges = config.defaultTracking.pageViews.trackHistoryChanges;\n }\n if ('eventType' in config.defaultTracking.pageViews && config.defaultTracking.pageViews.eventType) {\n eventType = config.defaultTracking.pageViews.eventType;\n }\n }\n }\n return {\n trackOn: trackOn,\n trackHistoryChanges: trackHistoryChanges,\n eventType: eventType,\n };\n};\n//# sourceMappingURL=default-tracking.js.map","export var getLanguage = function () {\n var _a, _b, _c, _d;\n if (typeof navigator === 'undefined')\n return '';\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n var userLanguage = navigator.userLanguage;\n return (_d = (_c = (_b = (_a = navigator.languages) === null || _a === void 0 ? void 0 : _a[0]) !== null && _b !== void 0 ? _b : navigator.language) !== null && _c !== void 0 ? _c : userLanguage) !== null && _d !== void 0 ? _d : '';\n};\n//# sourceMappingURL=language.js.map","import { __awaiter, __generator } from \"tslib\";\nimport { PluginType } from '@amplitude/analytics-types';\nimport { getAnalyticsConnector } from '../analytics-connector';\nvar IdentityEventSender = /** @class */ (function () {\n function IdentityEventSender() {\n this.name = 'identity';\n this.type = PluginType.BEFORE;\n this.identityStore = getAnalyticsConnector().identityStore;\n }\n IdentityEventSender.prototype.execute = function (context) {\n return __awaiter(this, void 0, void 0, function () {\n var userProperties;\n return __generator(this, function (_a) {\n userProperties = context.user_properties;\n if (userProperties) {\n this.identityStore.editIdentity().updateUserProperties(userProperties).commit();\n }\n return [2 /*return*/, context];\n });\n });\n };\n IdentityEventSender.prototype.setup = function (config) {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n if (config.instanceName) {\n this.identityStore = getAnalyticsConnector(config.instanceName).identityStore;\n }\n return [2 /*return*/];\n });\n });\n };\n return IdentityEventSender;\n}());\nexport { IdentityEventSender };\n//# sourceMappingURL=identity.js.map","import { __assign, __awaiter, __generator } from \"tslib\";\nimport { getGlobalScope } from '../global-scope';\nvar CookieStorage = /** @class */ (function () {\n function CookieStorage(options) {\n this.options = __assign({}, options);\n }\n CookieStorage.prototype.isEnabled = function () {\n return __awaiter(this, void 0, void 0, function () {\n var testStrorage, testKey, value, _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n /* istanbul ignore if */\n if (!getGlobalScope()) {\n return [2 /*return*/, false];\n }\n CookieStorage.testValue = String(Date.now());\n testStrorage = new CookieStorage(this.options);\n testKey = 'AMP_TEST';\n _b.label = 1;\n case 1:\n _b.trys.push([1, 4, 5, 7]);\n return [4 /*yield*/, testStrorage.set(testKey, CookieStorage.testValue)];\n case 2:\n _b.sent();\n return [4 /*yield*/, testStrorage.get(testKey)];\n case 3:\n value = _b.sent();\n return [2 /*return*/, value === CookieStorage.testValue];\n case 4:\n _a = _b.sent();\n /* istanbul ignore next */\n return [2 /*return*/, false];\n case 5: return [4 /*yield*/, testStrorage.remove(testKey)];\n case 6:\n _b.sent();\n return [7 /*endfinally*/];\n case 7: return [2 /*return*/];\n }\n });\n });\n };\n CookieStorage.prototype.get = function (key) {\n return __awaiter(this, void 0, void 0, function () {\n var value;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, this.getRaw(key)];\n case 1:\n value = _a.sent();\n if (!value) {\n return [2 /*return*/, undefined];\n }\n try {\n try {\n value = decodeURIComponent(atob(value));\n }\n catch (_b) {\n // value not encoded\n }\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return [2 /*return*/, JSON.parse(value)];\n }\n catch (_c) {\n /* istanbul ignore next */\n return [2 /*return*/, undefined];\n }\n return [2 /*return*/];\n }\n });\n });\n };\n CookieStorage.prototype.getRaw = function (key) {\n var _a;\n return __awaiter(this, void 0, void 0, function () {\n var globalScope, cookie, match;\n return __generator(this, function (_b) {\n globalScope = getGlobalScope();\n cookie = (_a = globalScope === null || globalScope === void 0 ? void 0 : globalScope.document.cookie.split('; ')) !== null && _a !== void 0 ? _a : [];\n match = cookie.find(function (c) { return c.indexOf(key + '=') === 0; });\n if (!match) {\n return [2 /*return*/, undefined];\n }\n return [2 /*return*/, match.substring(key.length + 1)];\n });\n });\n };\n CookieStorage.prototype.set = function (key, value) {\n var _a;\n return __awaiter(this, void 0, void 0, function () {\n var expirationDays, expires, expireDate, date, str, globalScope;\n return __generator(this, function (_b) {\n try {\n expirationDays = (_a = this.options.expirationDays) !== null && _a !== void 0 ? _a : 0;\n expires = value !== null ? expirationDays : -1;\n expireDate = undefined;\n if (expires) {\n date = new Date();\n date.setTime(date.getTime() + expires * 24 * 60 * 60 * 1000);\n expireDate = date;\n }\n str = \"\".concat(key, \"=\").concat(btoa(encodeURIComponent(JSON.stringify(value))));\n if (expireDate) {\n str += \"; expires=\".concat(expireDate.toUTCString());\n }\n str += '; path=/';\n if (this.options.domain) {\n str += \"; domain=\".concat(this.options.domain);\n }\n if (this.options.secure) {\n str += '; Secure';\n }\n if (this.options.sameSite) {\n str += \"; SameSite=\".concat(this.options.sameSite);\n }\n globalScope = getGlobalScope();\n if (globalScope) {\n globalScope.document.cookie = str;\n }\n }\n catch (_c) {\n //\n }\n return [2 /*return*/];\n });\n });\n };\n CookieStorage.prototype.remove = function (key) {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, this.set(key, null)];\n case 1:\n _a.sent();\n return [2 /*return*/];\n }\n });\n });\n };\n CookieStorage.prototype.reset = function () {\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n return [2 /*return*/];\n });\n });\n };\n return CookieStorage;\n}());\nexport { CookieStorage };\n//# sourceMappingURL=cookie.js.map","import { __awaiter, __extends, __generator } from \"tslib\";\nimport { BaseTransport } from '@amplitude/analytics-core';\nvar FetchTransport = /** @class */ (function (_super) {\n __extends(FetchTransport, _super);\n function FetchTransport() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n FetchTransport.prototype.send = function (serverUrl, payload) {\n return __awaiter(this, void 0, void 0, function () {\n var options, response, responsePayload;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n /* istanbul ignore if */\n if (typeof fetch === 'undefined') {\n throw new Error('FetchTransport is not supported');\n }\n options = {\n headers: {\n 'Content-Type': 'application/json',\n Accept: '*/*',\n },\n body: JSON.stringify(payload),\n method: 'POST',\n };\n return [4 /*yield*/, fetch(serverUrl, options)];\n case 1:\n response = _a.sent();\n return [4 /*yield*/, response.json()];\n case 2:\n responsePayload = _a.sent();\n return [2 /*return*/, this.buildResponse(responsePayload)];\n }\n });\n });\n };\n return FetchTransport;\n}(BaseTransport));\nexport { FetchTransport };\n//# sourceMappingURL=fetch.js.map","function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { PluginType } from '@amplitude/analytics-types';\nimport UAParser from '@amplitude/ua-parser-js';\nimport { UUID } from '@amplitude/analytics-core';\nimport { getLanguage } from '@amplitude/analytics-client-common';\nimport { VERSION } from '../version';\nimport { NativeModules } from 'react-native';\nconst BROWSER_PLATFORM = 'Web';\nconst IP_ADDRESS = '$remote';\nexport class Context {\n // this.config is defined in setup() which will always be called first\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n\n constructor() {\n _defineProperty(this, \"name\", 'context');\n _defineProperty(this, \"type\", PluginType.BEFORE);\n _defineProperty(this, \"config\", void 0);\n _defineProperty(this, \"uaResult\", void 0);\n _defineProperty(this, \"nativeModule\", NativeModules.AmplitudeReactNative);\n _defineProperty(this, \"library\", `amplitude-react-native-ts/${VERSION}`);\n let agent;\n /* istanbul ignore else */\n if (typeof navigator !== 'undefined') {\n agent = navigator.userAgent;\n }\n this.uaResult = new UAParser(agent).getResult();\n }\n setup(config) {\n this.config = config;\n return Promise.resolve(undefined);\n }\n async execute(context) {\n var _this$nativeModule;\n const time = new Date().getTime();\n const nativeContext = await ((_this$nativeModule = this.nativeModule) === null || _this$nativeModule === void 0 ? void 0 : _this$nativeModule.getApplicationContext(this.config.trackingOptions));\n const appVersion = this.config.appVersion || (nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.version);\n const platform = (nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.platform) || BROWSER_PLATFORM;\n const osName = (nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.osName) || this.uaResult.browser.name;\n const osVersion = (nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.osVersion) || this.uaResult.browser.version;\n const deviceVendor = (nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.deviceManufacturer) || this.uaResult.device.vendor;\n const deviceModel = (nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.deviceModel) || this.uaResult.device.model || this.uaResult.os.name;\n const language = (nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.language) || getLanguage();\n const country = nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.country;\n const carrier = nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.carrier;\n const adid = nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.adid;\n const appSetId = nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.appSetId;\n const idfv = nativeContext === null || nativeContext === void 0 ? void 0 : nativeContext.idfv;\n const event = {\n user_id: this.config.userId,\n device_id: this.config.deviceId,\n session_id: this.config.sessionId,\n time,\n ...(appVersion && {\n app_version: appVersion\n }),\n ...(this.config.trackingOptions.platform && {\n platform: platform\n }),\n ...(this.config.trackingOptions.osName && {\n os_name: osName\n }),\n ...(this.config.trackingOptions.osVersion && {\n os_version: osVersion\n }),\n ...(this.config.trackingOptions.deviceManufacturer && {\n device_manufacturer: deviceVendor\n }),\n ...(this.config.trackingOptions.deviceModel && {\n device_model: deviceModel\n }),\n ...(this.config.trackingOptions.language && {\n language: language\n }),\n ...(this.config.trackingOptions.country && {\n country: country\n }),\n ...(this.config.trackingOptions.carrier && {\n carrier: carrier\n }),\n ...(this.config.trackingOptions.ipAddress && {\n ip: IP_ADDRESS\n }),\n ...(this.config.trackingOptions.adid && {\n adid: adid\n }),\n ...(this.config.trackingOptions.appSetId && {\n android_app_set_id: appSetId\n }),\n ...(this.config.trackingOptions.idfv && {\n idfv: idfv\n }),\n insert_id: UUID(),\n partner_id: this.config.partnerId,\n plan: this.config.plan,\n ...(this.config.ingestionMetadata && {\n ingestion_metadata: {\n source_name: this.config.ingestionMetadata.sourceName,\n source_version: this.config.ingestionMetadata.sourceVersion\n }\n }),\n ...context,\n library: this.library\n };\n return event;\n }\n}\n//# sourceMappingURL=context.js.map","/////////////////////////////////////////////////////////////////////////////////\n/* UAParser.js v0.7.33\n Copyright © 2012-2021 Faisal Salman \n MIT License */ /*\n Detect Browser, Engine, OS, CPU, and Device type/model from User-Agent data.\n Supports browser & node.js environment.\n Demo : https://faisalman.github.io/ua-parser-js\n Source : https://github.com/faisalman/ua-parser-js */\n/////////////////////////////////////////////////////////////////////////////////\n\n(function (window, undefined) {\n \"use strict\";\n\n //////////////\n // Constants\n /////////////\n\n var LIBVERSION = \"0.7.33\",\n EMPTY = \"\",\n UNKNOWN = \"?\",\n FUNC_TYPE = \"function\",\n UNDEF_TYPE = \"undefined\",\n OBJ_TYPE = \"object\",\n STR_TYPE = \"string\",\n MAJOR = \"major\",\n MODEL = \"model\",\n NAME = \"name\",\n TYPE = \"type\",\n VENDOR = \"vendor\",\n VERSION = \"version\",\n ARCHITECTURE = \"architecture\",\n CONSOLE = \"console\",\n MOBILE = \"mobile\",\n TABLET = \"tablet\",\n SMARTTV = \"smarttv\",\n WEARABLE = \"wearable\",\n EMBEDDED = \"embedded\",\n UA_MAX_LENGTH = 350;\n\n var AMAZON = \"Amazon\",\n APPLE = \"Apple\",\n ASUS = \"ASUS\",\n BLACKBERRY = \"BlackBerry\",\n BROWSER = \"Browser\",\n CHROME = \"Chrome\",\n EDGE = \"Edge\",\n FIREFOX = \"Firefox\",\n GOOGLE = \"Google\",\n HUAWEI = \"Huawei\",\n LG = \"LG\",\n MICROSOFT = \"Microsoft\",\n MOTOROLA = \"Motorola\",\n OPERA = \"Opera\",\n SAMSUNG = \"Samsung\",\n SHARP = \"Sharp\",\n SONY = \"Sony\",\n XIAOMI = \"Xiaomi\",\n ZEBRA = \"Zebra\",\n FACEBOOK = \"Facebook\";\n\n ///////////\n // Helper\n //////////\n\n var extend = function (regexes, extensions) {\n var mergedRegexes = {};\n for (var i in regexes) {\n if (extensions[i] && extensions[i].length % 2 === 0) {\n mergedRegexes[i] = extensions[i].concat(regexes[i]);\n } else {\n mergedRegexes[i] = regexes[i];\n }\n }\n return mergedRegexes;\n },\n enumerize = function (arr) {\n var enums = {};\n for (var i = 0; i < arr.length; i++) {\n enums[arr[i].toUpperCase()] = arr[i];\n }\n return enums;\n },\n has = function (str1, str2) {\n return typeof str1 === STR_TYPE ? lowerize(str2).indexOf(lowerize(str1)) !== -1 : false;\n },\n lowerize = function (str) {\n return str.toLowerCase();\n },\n majorize = function (version) {\n return typeof version === STR_TYPE ? version.replace(/[^\\d\\.]/g, EMPTY).split(\".\")[0] : undefined;\n },\n trim = function (str, len) {\n if (typeof str === STR_TYPE) {\n str = str.replace(/^\\s\\s*/, EMPTY);\n return typeof len === UNDEF_TYPE ? str : str.substring(0, UA_MAX_LENGTH);\n }\n };\n\n ///////////////\n // Map helper\n //////////////\n\n var rgxMapper = function (ua, arrays) {\n var i = 0,\n j,\n k,\n p,\n q,\n matches,\n match;\n\n // loop through all regexes maps\n while (i < arrays.length && !matches) {\n var regex = arrays[i], // even sequence (0,2,4,..)\n props = arrays[i + 1]; // odd sequence (1,3,5,..)\n j = k = 0;\n\n // try matching uastring with regexes\n while (j < regex.length && !matches) {\n matches = regex[j++].exec(ua);\n\n if (!!matches) {\n for (p = 0; p < props.length; p++) {\n match = matches[++k];\n q = props[p];\n // check if given property is actually array\n if (typeof q === OBJ_TYPE && q.length > 0) {\n if (q.length === 2) {\n if (typeof q[1] == FUNC_TYPE) {\n // assign modified match\n this[q[0]] = q[1].call(this, match);\n } else {\n // assign given value, ignore regex match\n this[q[0]] = q[1];\n }\n } else if (q.length === 3) {\n // check whether function or regex\n if (typeof q[1] === FUNC_TYPE && !(q[1].exec && q[1].test)) {\n // call function (usually string mapper)\n this[q[0]] = match ? q[1].call(this, match, q[2]) : undefined;\n } else {\n // sanitize match using given regex\n this[q[0]] = match ? match.replace(q[1], q[2]) : undefined;\n }\n } else if (q.length === 4) {\n this[q[0]] = match ? q[3].call(this, match.replace(q[1], q[2])) : undefined;\n }\n } else {\n this[q] = match ? match : undefined;\n }\n }\n }\n }\n i += 2;\n }\n },\n strMapper = function (str, map) {\n for (var i in map) {\n // check if current value is array\n if (typeof map[i] === OBJ_TYPE && map[i].length > 0) {\n for (var j = 0; j < map[i].length; j++) {\n if (has(map[i][j], str)) {\n return i === UNKNOWN ? undefined : i;\n }\n }\n } else if (has(map[i], str)) {\n return i === UNKNOWN ? undefined : i;\n }\n }\n return str;\n };\n\n ///////////////\n // String map\n //////////////\n\n // Safari < 3.0\n var oldSafariMap = {\n \"1.0\": \"/8\",\n 1.2: \"/1\",\n 1.3: \"/3\",\n \"2.0\": \"/412\",\n \"2.0.2\": \"/416\",\n \"2.0.3\": \"/417\",\n \"2.0.4\": \"/419\",\n \"?\": \"/\"\n },\n windowsVersionMap = {\n ME: \"4.90\",\n \"NT 3.11\": \"NT3.51\",\n \"NT 4.0\": \"NT4.0\",\n 2000: \"NT 5.0\",\n XP: [\"NT 5.1\", \"NT 5.2\"],\n Vista: \"NT 6.0\",\n 7: \"NT 6.1\",\n 8: \"NT 6.2\",\n 8.1: \"NT 6.3\",\n 10: [\"NT 6.4\", \"NT 10.0\"],\n RT: \"ARM\"\n };\n\n //////////////\n // Regex map\n /////////////\n\n var regexes = {\n browser: [\n [\n /\\b(?:crmo|crios)\\/([\\w\\.]+)/i // Chrome for Android/iOS\n ],\n [VERSION, [NAME, \"Chrome\"]],\n [\n /edg(?:e|ios|a)?\\/([\\w\\.]+)/i // Microsoft Edge\n ],\n [VERSION, [NAME, \"Edge\"]],\n [\n // Presto based\n /(opera mini)\\/([-\\w\\.]+)/i, // Opera Mini\n /(opera [mobiletab]{3,6})\\b.+version\\/([-\\w\\.]+)/i, // Opera Mobi/Tablet\n /(opera)(?:.+version\\/|[\\/ ]+)([\\w\\.]+)/i // Opera\n ],\n [NAME, VERSION],\n [\n /opios[\\/ ]+([\\w\\.]+)/i // Opera mini on iphone >= 8.0\n ],\n [VERSION, [NAME, OPERA + \" Mini\"]],\n [\n /\\bopr\\/([\\w\\.]+)/i // Opera Webkit\n ],\n [VERSION, [NAME, OPERA]],\n [\n // Mixed\n /(kindle)\\/([\\w\\.]+)/i, // Kindle\n /(lunascape|maxthon|netfront|jasmine|blazer)[\\/ ]?([\\w\\.]*)/i, // Lunascape/Maxthon/Netfront/Jasmine/Blazer\n // Trident based\n /(avant |iemobile|slim)(?:browser)?[\\/ ]?([\\w\\.]*)/i, // Avant/IEMobile/SlimBrowser\n /(ba?idubrowser)[\\/ ]?([\\w\\.]+)/i, // Baidu Browser\n /(?:ms|\\()(ie) ([\\w\\.]+)/i, // Internet Explorer\n\n // Webkit/KHTML based // Flock/RockMelt/Midori/Epiphany/Silk/Skyfire/Bolt/Iron/Iridium/PhantomJS/Bowser/QupZilla/Falkon\n /(flock|rockmelt|midori|epiphany|silk|skyfire|ovibrowser|bolt|iron|vivaldi|iridium|phantomjs|bowser|quark|qupzilla|falkon|rekonq|puffin|brave|whale|qqbrowserlite|qq|duckduckgo)\\/([-\\w\\.]+)/i,\n // Rekonq/Puffin/Brave/Whale/QQBrowserLite/QQ, aka ShouQ\n /(weibo)__([\\d\\.]+)/i // Weibo\n ],\n [NAME, VERSION],\n [\n /(?:\\buc? ?browser|(?:juc.+)ucweb)[\\/ ]?([\\w\\.]+)/i // UCBrowser\n ],\n [VERSION, [NAME, \"UC\" + BROWSER]],\n [\n /microm.+\\bqbcore\\/([\\w\\.]+)/i, // WeChat Desktop for Windows Built-in Browser\n /\\bqbcore\\/([\\w\\.]+).+microm/i\n ],\n [VERSION, [NAME, \"WeChat(Win) Desktop\"]],\n [\n /micromessenger\\/([\\w\\.]+)/i // WeChat\n ],\n [VERSION, [NAME, \"WeChat\"]],\n [\n /konqueror\\/([\\w\\.]+)/i // Konqueror\n ],\n [VERSION, [NAME, \"Konqueror\"]],\n [\n /trident.+rv[: ]([\\w\\.]{1,9})\\b.+like gecko/i // IE11\n ],\n [VERSION, [NAME, \"IE\"]],\n [\n /yabrowser\\/([\\w\\.]+)/i // Yandex\n ],\n [VERSION, [NAME, \"Yandex\"]],\n [\n /(avast|avg)\\/([\\w\\.]+)/i // Avast/AVG Secure Browser\n ],\n [[NAME, /(.+)/, \"$1 Secure \" + BROWSER], VERSION],\n [\n /\\bfocus\\/([\\w\\.]+)/i // Firefox Focus\n ],\n [VERSION, [NAME, FIREFOX + \" Focus\"]],\n [\n /\\bopt\\/([\\w\\.]+)/i // Opera Touch\n ],\n [VERSION, [NAME, OPERA + \" Touch\"]],\n [\n /coc_coc\\w+\\/([\\w\\.]+)/i // Coc Coc Browser\n ],\n [VERSION, [NAME, \"Coc Coc\"]],\n [\n /dolfin\\/([\\w\\.]+)/i // Dolphin\n ],\n [VERSION, [NAME, \"Dolphin\"]],\n [\n /coast\\/([\\w\\.]+)/i // Opera Coast\n ],\n [VERSION, [NAME, OPERA + \" Coast\"]],\n [\n /miuibrowser\\/([\\w\\.]+)/i // MIUI Browser\n ],\n [VERSION, [NAME, \"MIUI \" + BROWSER]],\n [\n /fxios\\/([-\\w\\.]+)/i // Firefox for iOS\n ],\n [VERSION, [NAME, FIREFOX]],\n [\n /\\bqihu|(qi?ho?o?|360)browser/i // 360\n ],\n [[NAME, \"360 \" + BROWSER]],\n [/(oculus|samsung|sailfish|huawei)browser\\/([\\w\\.]+)/i],\n [[NAME, /(.+)/, \"$1 \" + BROWSER], VERSION],\n [\n // Oculus/Samsung/Sailfish/Huawei Browser\n /(comodo_dragon)\\/([\\w\\.]+)/i // Comodo Dragon\n ],\n [[NAME, /_/g, \" \"], VERSION],\n [\n /(electron)\\/([\\w\\.]+) safari/i, // Electron-based App\n /(tesla)(?: qtcarbrowser|\\/(20\\d\\d\\.[-\\w\\.]+))/i, // Tesla\n /m?(qqbrowser|baiduboxapp|2345Explorer)[\\/ ]?([\\w\\.]+)/i // QQBrowser/Baidu App/2345 Browser\n ],\n [NAME, VERSION],\n [\n /(metasr)[\\/ ]?([\\w\\.]+)/i, // SouGouBrowser\n /(lbbrowser)/i, // LieBao Browser\n /\\[(linkedin)app\\]/i // LinkedIn App for iOS & Android\n ],\n [NAME],\n [\n // WebView\n /((?:fban\\/fbios|fb_iab\\/fb4a)(?!.+fbav)|;fbav\\/([\\w\\.]+);)/i // Facebook App for iOS & Android\n ],\n [[NAME, FACEBOOK], VERSION],\n [\n /safari (line)\\/([\\w\\.]+)/i, // Line App for iOS\n /\\b(line)\\/([\\w\\.]+)\\/iab/i, // Line App for Android\n /(chromium|instagram)[\\/ ]([-\\w\\.]+)/i // Chromium/Instagram\n ],\n [NAME, VERSION],\n [\n /\\bgsa\\/([\\w\\.]+) .*safari\\//i // Google Search Appliance on iOS\n ],\n [VERSION, [NAME, \"GSA\"]],\n [\n /headlesschrome(?:\\/([\\w\\.]+)| )/i // Chrome Headless\n ],\n [VERSION, [NAME, CHROME + \" Headless\"]],\n [\n / wv\\).+(chrome)\\/([\\w\\.]+)/i // Chrome WebView\n ],\n [[NAME, CHROME + \" WebView\"], VERSION],\n [\n /droid.+ version\\/([\\w\\.]+)\\b.+(?:mobile safari|safari)/i // Android Browser\n ],\n [VERSION, [NAME, \"Android \" + BROWSER]],\n [\n /(chrome|omniweb|arora|[tizenoka]{5} ?browser)\\/v?([\\w\\.]+)/i // Chrome/OmniWeb/Arora/Tizen/Nokia\n ],\n [NAME, VERSION],\n [\n /version\\/([\\w\\.\\,]+) .*mobile\\/\\w+ (safari)/i // Mobile Safari\n ],\n [VERSION, [NAME, \"Mobile Safari\"]],\n [\n /version\\/([\\w(\\.|\\,)]+) .*(mobile ?safari|safari)/i // Safari & Safari Mobile\n ],\n [VERSION, NAME],\n [\n /webkit.+?(mobile ?safari|safari)(\\/[\\w\\.]+)/i // Safari < 3.0\n ],\n [NAME, [VERSION, strMapper, oldSafariMap]],\n [/(webkit|khtml)\\/([\\w\\.]+)/i],\n [NAME, VERSION],\n [\n // Gecko based\n /(navigator|netscape\\d?)\\/([-\\w\\.]+)/i // Netscape\n ],\n [[NAME, \"Netscape\"], VERSION],\n [\n /mobile vr; rv:([\\w\\.]+)\\).+firefox/i // Firefox Reality\n ],\n [VERSION, [NAME, FIREFOX + \" Reality\"]],\n [\n /ekiohf.+(flow)\\/([\\w\\.]+)/i, // Flow\n /(swiftfox)/i, // Swiftfox\n /(icedragon|iceweasel|camino|chimera|fennec|maemo browser|minimo|conkeror|klar)[\\/ ]?([\\w\\.\\+]+)/i,\n // IceDragon/Iceweasel/Camino/Chimera/Fennec/Maemo/Minimo/Conkeror/Klar\n /(seamonkey|k-meleon|icecat|iceape|firebird|phoenix|palemoon|basilisk|waterfox)\\/([-\\w\\.]+)$/i,\n // Firefox/SeaMonkey/K-Meleon/IceCat/IceApe/Firebird/Phoenix\n /(firefox)\\/([\\w\\.]+)/i, // Other Firefox-based\n /(mozilla)\\/([\\w\\.]+) .+rv\\:.+gecko\\/\\d+/i, // Mozilla\n\n // Other\n /(polaris|lynx|dillo|icab|doris|amaya|w3m|netsurf|sleipnir|obigo|mosaic|(?:go|ice|up)[\\. ]?browser)[-\\/ ]?v?([\\w\\.]+)/i,\n // Polaris/Lynx/Dillo/iCab/Doris/Amaya/w3m/NetSurf/Sleipnir/Obigo/Mosaic/Go/ICE/UP.Browser\n /(links) \\(([\\w\\.]+)/i // Links\n ],\n [NAME, VERSION],\n [\n /(cobalt)\\/([\\w\\.]+)/i // Cobalt\n ],\n [NAME, [VERSION, /master.|lts./, \"\"]]\n ],\n\n cpu: [\n [\n /(?:(amd|x(?:(?:86|64)[-_])?|wow|win)64)[;\\)]/i // AMD64 (x64)\n ],\n [[ARCHITECTURE, \"amd64\"]],\n [\n /(ia32(?=;))/i // IA32 (quicktime)\n ],\n [[ARCHITECTURE, lowerize]],\n [\n /((?:i[346]|x)86)[;\\)]/i // IA32 (x86)\n ],\n [[ARCHITECTURE, \"ia32\"]],\n [\n /\\b(aarch64|arm(v?8e?l?|_?64))\\b/i // ARM64\n ],\n [[ARCHITECTURE, \"arm64\"]],\n [\n /\\b(arm(?:v[67])?ht?n?[fl]p?)\\b/i // ARMHF\n ],\n [[ARCHITECTURE, \"armhf\"]],\n [\n // PocketPC mistakenly identified as PowerPC\n /windows (ce|mobile); ppc;/i\n ],\n [[ARCHITECTURE, \"arm\"]],\n [\n /((?:ppc|powerpc)(?:64)?)(?: mac|;|\\))/i // PowerPC\n ],\n [[ARCHITECTURE, /ower/, EMPTY, lowerize]],\n [\n /(sun4\\w)[;\\)]/i // SPARC\n ],\n [[ARCHITECTURE, \"sparc\"]],\n [\n /((?:avr32|ia64(?=;))|68k(?=\\))|\\barm(?=v(?:[1-7]|[5-7]1)l?|;|eabi)|(?=atmel )avr|(?:irix|mips|sparc)(?:64)?\\b|pa-risc)/i\n // IA64, 68K, ARM/64, AVR/32, IRIX/64, MIPS/64, SPARC/64, PA-RISC\n ],\n [[ARCHITECTURE, lowerize]]\n ],\n\n device: [\n [\n //////////////////////////\n // MOBILES & TABLETS\n // Ordered by popularity\n /////////////////////////\n\n // Samsung\n /\\b(sch-i[89]0\\d|shw-m380s|sm-[ptx]\\w{2,4}|gt-[pn]\\d{2,4}|sgh-t8[56]9|nexus 10)/i\n ],\n [MODEL, [VENDOR, SAMSUNG], [TYPE, TABLET]],\n [\n /\\b((?:s[cgp]h|gt|sm)-\\w+|galaxy nexus)/i,\n /samsung[- ]([-\\w]+)/i,\n /sec-(sgh\\w+)/i\n ],\n [MODEL, [VENDOR, SAMSUNG], [TYPE, MOBILE]],\n [\n // Apple\n /((ipod|iphone)\\d+,\\d+)/i // iPod/iPhone model\n ],\n [MODEL, [VENDOR, APPLE], [TYPE, MOBILE]],\n [\n /(ipad\\d+,\\d+)/i // iPad model\n ],\n [MODEL, [VENDOR, APPLE], [TYPE, TABLET]],\n [\n /\\((ip(?:hone|od)[\\w ]*);/i // iPod/iPhone\n ],\n [MODEL, [VENDOR, APPLE], [TYPE, MOBILE]],\n [\n /\\((ipad);[-\\w\\),; ]+apple/i, // iPad\n /applecoremedia\\/[\\w\\.]+ \\((ipad)/i,\n /\\b(ipad)\\d\\d?,\\d\\d?[;\\]].+ios/i\n ],\n [MODEL, [VENDOR, APPLE], [TYPE, TABLET]],\n [/(macintosh);/i],\n [MODEL, [VENDOR, APPLE]],\n [\n // Huawei\n /\\b((?:ag[rs][23]?|bah2?|sht?|btv)-a?[lw]\\d{2})\\b(?!.+d\\/s)/i\n ],\n [MODEL, [VENDOR, HUAWEI], [TYPE, TABLET]],\n [\n /(?:huawei|honor)([-\\w ]+)[;\\)]/i,\n /\\b(nexus 6p|\\w{2,4}e?-[atu]?[ln][\\dx][012359c][adn]?)\\b(?!.+d\\/s)/i\n ],\n [MODEL, [VENDOR, HUAWEI], [TYPE, MOBILE]],\n [\n // Xiaomi\n /\\b(poco[\\w ]+)(?: bui|\\))/i, // Xiaomi POCO\n /\\b; (\\w+) build\\/hm\\1/i, // Xiaomi Hongmi 'numeric' models\n /\\b(hm[-_ ]?note?[_ ]?(?:\\d\\w)?) bui/i, // Xiaomi Hongmi\n /\\b(redmi[\\-_ ]?(?:note|k)?[\\w_ ]+)(?: bui|\\))/i, // Xiaomi Redmi\n /\\b(mi[-_ ]?(?:a\\d|one|one[_ ]plus|note lte|max|cc)?[_ ]?(?:\\d?\\w?)[_ ]?(?:plus|se|lite)?)(?: bui|\\))/i // Xiaomi Mi\n ],\n [\n [MODEL, /_/g, \" \"],\n [VENDOR, XIAOMI],\n [TYPE, MOBILE]\n ],\n [\n /\\b(mi[-_ ]?(?:pad)(?:[\\w_ ]+))(?: bui|\\))/i // Mi Pad tablets\n ],\n [\n [MODEL, /_/g, \" \"],\n [VENDOR, XIAOMI],\n [TYPE, TABLET]\n ],\n [\n // OPPO\n /; (\\w+) bui.+ oppo/i,\n /\\b(cph[12]\\d{3}|p(?:af|c[al]|d\\w|e[ar])[mt]\\d0|x9007|a101op)\\b/i\n ],\n [MODEL, [VENDOR, \"OPPO\"], [TYPE, MOBILE]],\n [\n // Vivo\n /vivo (\\w+)(?: bui|\\))/i,\n /\\b(v[12]\\d{3}\\w?[at])(?: bui|;)/i\n ],\n [MODEL, [VENDOR, \"Vivo\"], [TYPE, MOBILE]],\n [\n // Realme\n /\\b(rmx[12]\\d{3})(?: bui|;|\\))/i\n ],\n [MODEL, [VENDOR, \"Realme\"], [TYPE, MOBILE]],\n [\n // Motorola\n /\\b(milestone|droid(?:[2-4x]| (?:bionic|x2|pro|razr))?:?( 4g)?)\\b[\\w ]+build\\//i,\n /\\bmot(?:orola)?[- ](\\w*)/i,\n /((?:moto[\\w\\(\\) ]+|xt\\d{3,4}|nexus 6)(?= bui|\\)))/i\n ],\n [MODEL, [VENDOR, MOTOROLA], [TYPE, MOBILE]],\n [/\\b(mz60\\d|xoom[2 ]{0,2}) build\\//i],\n [MODEL, [VENDOR, MOTOROLA], [TYPE, TABLET]],\n [\n // LG\n /((?=lg)?[vl]k\\-?\\d{3}) bui| 3\\.[-\\w; ]{10}lg?-([06cv9]{3,4})/i\n ],\n [MODEL, [VENDOR, LG], [TYPE, TABLET]],\n [\n /(lm(?:-?f100[nv]?|-[\\w\\.]+)(?= bui|\\))|nexus [45])/i,\n /\\blg[-e;\\/ ]+((?!browser|netcast|android tv)\\w+)/i,\n /\\blg-?([\\d\\w]+) bui/i\n ],\n [MODEL, [VENDOR, LG], [TYPE, MOBILE]],\n [\n // Lenovo\n /(ideatab[-\\w ]+)/i,\n /lenovo ?(s[56]000[-\\w]+|tab(?:[\\w ]+)|yt[-\\d\\w]{6}|tb[-\\d\\w]{6})/i\n ],\n [MODEL, [VENDOR, \"Lenovo\"], [TYPE, TABLET]],\n [\n // Nokia\n /(?:maemo|nokia).*(n900|lumia \\d+)/i,\n /nokia[-_ ]?([-\\w\\.]*)/i\n ],\n [\n [MODEL, /_/g, \" \"],\n [VENDOR, \"Nokia\"],\n [TYPE, MOBILE]\n ],\n [\n // Google\n /(pixel c)\\b/i // Google Pixel C\n ],\n [MODEL, [VENDOR, GOOGLE], [TYPE, TABLET]],\n [\n /droid.+; (pixel[\\daxl ]{0,6})(?: bui|\\))/i // Google Pixel\n ],\n [MODEL, [VENDOR, GOOGLE], [TYPE, MOBILE]],\n [\n // Sony\n /droid.+ (a?\\d[0-2]{2}so|[c-g]\\d{4}|so[-gl]\\w+|xq-a\\w[4-7][12])(?= bui|\\).+chrome\\/(?![1-6]{0,1}\\d\\.))/i\n ],\n [MODEL, [VENDOR, SONY], [TYPE, MOBILE]],\n [/sony tablet [ps]/i, /\\b(?:sony)?sgp\\w+(?: bui|\\))/i],\n [\n [MODEL, \"Xperia Tablet\"],\n [VENDOR, SONY],\n [TYPE, TABLET]\n ],\n [\n // OnePlus\n / (kb2005|in20[12]5|be20[12][59])\\b/i,\n /(?:one)?(?:plus)? (a\\d0\\d\\d)(?: b|\\))/i\n ],\n [MODEL, [VENDOR, \"OnePlus\"], [TYPE, MOBILE]],\n [\n // Amazon\n /(alexa)webm/i,\n /(kf[a-z]{2}wi)( bui|\\))/i, // Kindle Fire without Silk\n /(kf[a-z]+)( bui|\\)).+silk\\//i // Kindle Fire HD\n ],\n [MODEL, [VENDOR, AMAZON], [TYPE, TABLET]],\n [\n /((?:sd|kf)[0349hijorstuw]+)( bui|\\)).+silk\\//i // Fire Phone\n ],\n [\n [MODEL, /(.+)/g, \"Fire Phone $1\"],\n [VENDOR, AMAZON],\n [TYPE, MOBILE]\n ],\n [\n // BlackBerry\n /(playbook);[-\\w\\),; ]+(rim)/i // BlackBerry PlayBook\n ],\n [MODEL, VENDOR, [TYPE, TABLET]],\n [\n /\\b((?:bb[a-f]|st[hv])100-\\d)/i,\n /\\(bb10; (\\w+)/i // BlackBerry 10\n ],\n [MODEL, [VENDOR, BLACKBERRY], [TYPE, MOBILE]],\n [\n // Asus\n /(?:\\b|asus_)(transfo[prime ]{4,10} \\w+|eeepc|slider \\w+|nexus 7|padfone|p00[cj])/i\n ],\n [MODEL, [VENDOR, ASUS], [TYPE, TABLET]],\n [/ (z[bes]6[027][012][km][ls]|zenfone \\d\\w?)\\b/i],\n [MODEL, [VENDOR, ASUS], [TYPE, MOBILE]],\n [\n // HTC\n /(nexus 9)/i // HTC Nexus 9\n ],\n [MODEL, [VENDOR, \"HTC\"], [TYPE, TABLET]],\n [\n /(htc)[-;_ ]{1,2}([\\w ]+(?=\\)| bui)|\\w+)/i, // HTC\n\n // ZTE\n /(zte)[- ]([\\w ]+?)(?: bui|\\/|\\))/i,\n /(alcatel|geeksphone|nexian|panasonic|sony(?!-bra))[-_ ]?([-\\w]*)/i // Alcatel/GeeksPhone/Nexian/Panasonic/Sony\n ],\n [VENDOR, [MODEL, /_/g, \" \"], [TYPE, MOBILE]],\n [\n // Acer\n /droid.+; ([ab][1-7]-?[0178a]\\d\\d?)/i\n ],\n [MODEL, [VENDOR, \"Acer\"], [TYPE, TABLET]],\n [\n // Meizu\n /droid.+; (m[1-5] note) bui/i,\n /\\bmz-([-\\w]{2,})/i\n ],\n [MODEL, [VENDOR, \"Meizu\"], [TYPE, MOBILE]],\n [\n // Sharp\n /\\b(sh-?[altvz]?\\d\\d[a-ekm]?)/i\n ],\n [MODEL, [VENDOR, SHARP], [TYPE, MOBILE]],\n [\n // MIXED\n /(blackberry|benq|palm(?=\\-)|sonyericsson|acer|asus|dell|meizu|motorola|polytron)[-_ ]?([-\\w]*)/i,\n // BlackBerry/BenQ/Palm/Sony-Ericsson/Acer/Asus/Dell/Meizu/Motorola/Polytron\n /(hp) ([\\w ]+\\w)/i, // HP iPAQ\n /(asus)-?(\\w+)/i, // Asus\n /(microsoft); (lumia[\\w ]+)/i, // Microsoft Lumia\n /(lenovo)[-_ ]?([-\\w]+)/i, // Lenovo\n /(jolla)/i, // Jolla\n /(oppo) ?([\\w ]+) bui/i // OPPO\n ],\n [VENDOR, MODEL, [TYPE, MOBILE]],\n [\n /(archos) (gamepad2?)/i, // Archos\n /(hp).+(touchpad(?!.+tablet)|tablet)/i, // HP TouchPad\n /(kindle)\\/([\\w\\.]+)/i, // Kindle\n /(nook)[\\w ]+build\\/(\\w+)/i, // Nook\n /(dell) (strea[kpr\\d ]*[\\dko])/i, // Dell Streak\n /(le[- ]+pan)[- ]+(\\w{1,9}) bui/i, // Le Pan Tablets\n /(trinity)[- ]*(t\\d{3}) bui/i, // Trinity Tablets\n /(gigaset)[- ]+(q\\w{1,9}) bui/i, // Gigaset Tablets\n /(vodafone) ([\\w ]+)(?:\\)| bui)/i // Vodafone\n ],\n [VENDOR, MODEL, [TYPE, TABLET]],\n [\n /(surface duo)/i // Surface Duo\n ],\n [MODEL, [VENDOR, MICROSOFT], [TYPE, TABLET]],\n [\n /droid [\\d\\.]+; (fp\\du?)(?: b|\\))/i // Fairphone\n ],\n [MODEL, [VENDOR, \"Fairphone\"], [TYPE, MOBILE]],\n [\n /(u304aa)/i // AT&T\n ],\n [MODEL, [VENDOR, \"AT&T\"], [TYPE, MOBILE]],\n [\n /\\bsie-(\\w*)/i // Siemens\n ],\n [MODEL, [VENDOR, \"Siemens\"], [TYPE, MOBILE]],\n [\n /\\b(rct\\w+) b/i // RCA Tablets\n ],\n [MODEL, [VENDOR, \"RCA\"], [TYPE, TABLET]],\n [\n /\\b(venue[\\d ]{2,7}) b/i // Dell Venue Tablets\n ],\n [MODEL, [VENDOR, \"Dell\"], [TYPE, TABLET]],\n [\n /\\b(q(?:mv|ta)\\w+) b/i // Verizon Tablet\n ],\n [MODEL, [VENDOR, \"Verizon\"], [TYPE, TABLET]],\n [\n /\\b(?:barnes[& ]+noble |bn[rt])([\\w\\+ ]*) b/i // Barnes & Noble Tablet\n ],\n [MODEL, [VENDOR, \"Barnes & Noble\"], [TYPE, TABLET]],\n [/\\b(tm\\d{3}\\w+) b/i],\n [MODEL, [VENDOR, \"NuVision\"], [TYPE, TABLET]],\n [\n /\\b(k88) b/i // ZTE K Series Tablet\n ],\n [MODEL, [VENDOR, \"ZTE\"], [TYPE, TABLET]],\n [\n /\\b(nx\\d{3}j) b/i // ZTE Nubia\n ],\n [MODEL, [VENDOR, \"ZTE\"], [TYPE, MOBILE]],\n [\n /\\b(gen\\d{3}) b.+49h/i // Swiss GEN Mobile\n ],\n [MODEL, [VENDOR, \"Swiss\"], [TYPE, MOBILE]],\n [\n /\\b(zur\\d{3}) b/i // Swiss ZUR Tablet\n ],\n [MODEL, [VENDOR, \"Swiss\"], [TYPE, TABLET]],\n [\n /\\b((zeki)?tb.*\\b) b/i // Zeki Tablets\n ],\n [MODEL, [VENDOR, \"Zeki\"], [TYPE, TABLET]],\n [\n /\\b([yr]\\d{2}) b/i,\n /\\b(dragon[- ]+touch |dt)(\\w{5}) b/i // Dragon Touch Tablet\n ],\n [[VENDOR, \"Dragon Touch\"], MODEL, [TYPE, TABLET]],\n [\n /\\b(ns-?\\w{0,9}) b/i // Insignia Tablets\n ],\n [MODEL, [VENDOR, \"Insignia\"], [TYPE, TABLET]],\n [\n /\\b((nxa|next)-?\\w{0,9}) b/i // NextBook Tablets\n ],\n [MODEL, [VENDOR, \"NextBook\"], [TYPE, TABLET]],\n [\n /\\b(xtreme\\_)?(v(1[045]|2[015]|[3469]0|7[05])) b/i // Voice Xtreme Phones\n ],\n [[VENDOR, \"Voice\"], MODEL, [TYPE, MOBILE]],\n [\n /\\b(lvtel\\-)?(v1[12]) b/i // LvTel Phones\n ],\n [[VENDOR, \"LvTel\"], MODEL, [TYPE, MOBILE]],\n [\n /\\b(ph-1) /i // Essential PH-1\n ],\n [MODEL, [VENDOR, \"Essential\"], [TYPE, MOBILE]],\n [\n /\\b(v(100md|700na|7011|917g).*\\b) b/i // Envizen Tablets\n ],\n [MODEL, [VENDOR, \"Envizen\"], [TYPE, TABLET]],\n [\n /\\b(trio[-\\w\\. ]+) b/i // MachSpeed Tablets\n ],\n [MODEL, [VENDOR, \"MachSpeed\"], [TYPE, TABLET]],\n [\n /\\btu_(1491) b/i // Rotor Tablets\n ],\n [MODEL, [VENDOR, \"Rotor\"], [TYPE, TABLET]],\n [\n /(shield[\\w ]+) b/i // Nvidia Shield Tablets\n ],\n [MODEL, [VENDOR, \"Nvidia\"], [TYPE, TABLET]],\n [\n /(sprint) (\\w+)/i // Sprint Phones\n ],\n [VENDOR, MODEL, [TYPE, MOBILE]],\n [\n /(kin\\.[onetw]{3})/i // Microsoft Kin\n ],\n [\n [MODEL, /\\./g, \" \"],\n [VENDOR, MICROSOFT],\n [TYPE, MOBILE]\n ],\n [\n /droid.+; (cc6666?|et5[16]|mc[239][23]x?|vc8[03]x?)\\)/i // Zebra\n ],\n [MODEL, [VENDOR, ZEBRA], [TYPE, TABLET]],\n [/droid.+; (ec30|ps20|tc[2-8]\\d[kx])\\)/i],\n [MODEL, [VENDOR, ZEBRA], [TYPE, MOBILE]],\n [\n ///////////////////\n // CONSOLES\n ///////////////////\n\n /(ouya)/i, // Ouya\n /(nintendo) ([wids3utch]+)/i // Nintendo\n ],\n [VENDOR, MODEL, [TYPE, CONSOLE]],\n [\n /droid.+; (shield) bui/i // Nvidia\n ],\n [MODEL, [VENDOR, \"Nvidia\"], [TYPE, CONSOLE]],\n [\n /(playstation [345portablevi]+)/i // Playstation\n ],\n [MODEL, [VENDOR, SONY], [TYPE, CONSOLE]],\n [\n /\\b(xbox(?: one)?(?!; xbox))[\\); ]/i // Microsoft Xbox\n ],\n [MODEL, [VENDOR, MICROSOFT], [TYPE, CONSOLE]],\n [\n ///////////////////\n // SMARTTVS\n ///////////////////\n\n /smart-tv.+(samsung)/i // Samsung\n ],\n [VENDOR, [TYPE, SMARTTV]],\n [/hbbtv.+maple;(\\d+)/i],\n [\n [MODEL, /^/, \"SmartTV\"],\n [VENDOR, SAMSUNG],\n [TYPE, SMARTTV]\n ],\n [\n /(nux; netcast.+smarttv|lg (netcast\\.tv-201\\d|android tv))/i // LG SmartTV\n ],\n [\n [VENDOR, LG],\n [TYPE, SMARTTV]\n ],\n [\n /(apple) ?tv/i // Apple TV\n ],\n [VENDOR, [MODEL, APPLE + \" TV\"], [TYPE, SMARTTV]],\n [\n /crkey/i // Google Chromecast\n ],\n [\n [MODEL, CHROME + \"cast\"],\n [VENDOR, GOOGLE],\n [TYPE, SMARTTV]\n ],\n [\n /droid.+aft(\\w)( bui|\\))/i // Fire TV\n ],\n [MODEL, [VENDOR, AMAZON], [TYPE, SMARTTV]],\n [\n /\\(dtv[\\);].+(aquos)/i,\n /(aquos-tv[\\w ]+)\\)/i // Sharp\n ],\n [MODEL, [VENDOR, SHARP], [TYPE, SMARTTV]],\n [\n /(bravia[\\w ]+)( bui|\\))/i // Sony\n ],\n [MODEL, [VENDOR, SONY], [TYPE, SMARTTV]],\n [\n /(mitv-\\w{5}) bui/i // Xiaomi\n ],\n [MODEL, [VENDOR, XIAOMI], [TYPE, SMARTTV]],\n [\n /\\b(roku)[\\dx]*[\\)\\/]((?:dvp-)?[\\d\\.]*)/i, // Roku\n /hbbtv\\/\\d+\\.\\d+\\.\\d+ +\\([\\w ]*; *(\\w[^;]*);([^;]*)/i // HbbTV devices\n ],\n [\n [VENDOR, trim],\n [MODEL, trim],\n [TYPE, SMARTTV]\n ],\n [\n /\\b(android tv|smart[- ]?tv|opera tv|tv; rv:)\\b/i // SmartTV from Unidentified Vendors\n ],\n [[TYPE, SMARTTV]],\n [\n ///////////////////\n // WEARABLES\n ///////////////////\n\n /((pebble))app/i // Pebble\n ],\n [VENDOR, MODEL, [TYPE, WEARABLE]],\n [\n /droid.+; (glass) \\d/i // Google Glass\n ],\n [MODEL, [VENDOR, GOOGLE], [TYPE, WEARABLE]],\n [/droid.+; (wt63?0{2,3})\\)/i],\n [MODEL, [VENDOR, ZEBRA], [TYPE, WEARABLE]],\n [\n /(quest( 2)?)/i // Oculus Quest\n ],\n [MODEL, [VENDOR, FACEBOOK], [TYPE, WEARABLE]],\n [\n ///////////////////\n // EMBEDDED\n ///////////////////\n\n /(tesla)(?: qtcarbrowser|\\/[-\\w\\.]+)/i // Tesla\n ],\n [VENDOR, [TYPE, EMBEDDED]],\n [\n ////////////////////\n // MIXED (GENERIC)\n ///////////////////\n\n /droid .+?; ([^;]+?)(?: bui|\\) applew).+? mobile safari/i // Android Phones from Unidentified Vendors\n ],\n [MODEL, [TYPE, MOBILE]],\n [\n /droid .+?; ([^;]+?)(?: bui|\\) applew).+?(?! mobile) safari/i // Android Tablets from Unidentified Vendors\n ],\n [MODEL, [TYPE, TABLET]],\n [\n /\\b((tablet|tab)[;\\/]|focus\\/\\d(?!.+mobile))/i // Unidentifiable Tablet\n ],\n [[TYPE, TABLET]],\n [\n /(phone|mobile(?:[;\\/]| [ \\w\\/\\.]*safari)|pda(?=.+windows ce))/i // Unidentifiable Mobile\n ],\n [[TYPE, MOBILE]],\n [\n /(android[-\\w\\. ]{0,9});.+buil/i // Generic Android Device\n ],\n [MODEL, [VENDOR, \"Generic\"]]\n ],\n\n engine: [\n [\n /windows.+ edge\\/([\\w\\.]+)/i // EdgeHTML\n ],\n [VERSION, [NAME, EDGE + \"HTML\"]],\n [\n /webkit\\/537\\.36.+chrome\\/(?!27)([\\w\\.]+)/i // Blink\n ],\n [VERSION, [NAME, \"Blink\"]],\n [\n /(presto)\\/([\\w\\.]+)/i, // Presto\n /(webkit|trident|netfront|netsurf|amaya|lynx|w3m|goanna)\\/([\\w\\.]+)/i, // WebKit/Trident/NetFront/NetSurf/Amaya/Lynx/w3m/Goanna\n /ekioh(flow)\\/([\\w\\.]+)/i, // Flow\n /(khtml|tasman|links)[\\/ ]\\(?([\\w\\.]+)/i, // KHTML/Tasman/Links\n /(icab)[\\/ ]([23]\\.[\\d\\.]+)/i // iCab\n ],\n [NAME, VERSION],\n [\n /rv\\:([\\w\\.]{1,9})\\b.+(gecko)/i // Gecko\n ],\n [VERSION, NAME]\n ],\n\n os: [\n [\n // Windows\n /microsoft (windows) (vista|xp)/i // Windows (iTunes)\n ],\n [NAME, VERSION],\n [\n /(windows) nt 6\\.2; (arm)/i, // Windows RT\n /(windows (?:phone(?: os)?|mobile))[\\/ ]?([\\d\\.\\w ]*)/i, // Windows Phone\n /(windows)[\\/ ]?([ntce\\d\\. ]+\\w)(?!.+xbox)/i\n ],\n [NAME, [VERSION, strMapper, windowsVersionMap]],\n [/(win(?=3|9|n)|win 9x )([nt\\d\\.]+)/i],\n [\n [NAME, \"Windows\"],\n [VERSION, strMapper, windowsVersionMap]\n ],\n [\n // iOS/macOS\n /ip[honead]{2,4}\\b(?:.*os ([\\w]+) like mac|; opera)/i, // iOS\n /cfnetwork\\/.+darwin/i\n ],\n [\n [VERSION, /_/g, \".\"],\n [NAME, \"iOS\"]\n ],\n [\n /(mac os x) ?([\\w\\. ]*)/i,\n /(macintosh|mac_powerpc\\b)(?!.+haiku)/i // Mac OS\n ],\n [\n [NAME, \"Mac OS\"],\n [VERSION, /_/g, \".\"]\n ],\n [\n // Mobile OSes\n /droid ([\\w\\.]+)\\b.+(android[- ]x86|harmonyos)/i // Android-x86/HarmonyOS\n ],\n [VERSION, NAME],\n [\n // Android/WebOS/QNX/Bada/RIM/Maemo/MeeGo/Sailfish OS\n /(android|webos|qnx|bada|rim tablet os|maemo|meego|sailfish)[-\\/ ]?([\\w\\.]*)/i,\n /(blackberry)\\w*\\/([\\w\\.]*)/i, // Blackberry\n /(tizen|kaios)[\\/ ]([\\w\\.]+)/i, // Tizen/KaiOS\n /\\((series40);/i // Series 40\n ],\n [NAME, VERSION],\n [\n /\\(bb(10);/i // BlackBerry 10\n ],\n [VERSION, [NAME, BLACKBERRY]],\n [\n /(?:symbian ?os|symbos|s60(?=;)|series60)[-\\/ ]?([\\w\\.]*)/i // Symbian\n ],\n [VERSION, [NAME, \"Symbian\"]],\n [\n /mozilla\\/[\\d\\.]+ \\((?:mobile|tablet|tv|mobile; [\\w ]+); rv:.+ gecko\\/([\\w\\.]+)/i // Firefox OS\n ],\n [VERSION, [NAME, FIREFOX + \" OS\"]],\n [\n /web0s;.+rt(tv)/i,\n /\\b(?:hp)?wos(?:browser)?\\/([\\w\\.]+)/i // WebOS\n ],\n [VERSION, [NAME, \"webOS\"]],\n [\n // Google Chromecast\n /crkey\\/([\\d\\.]+)/i // Google Chromecast\n ],\n [VERSION, [NAME, CHROME + \"cast\"]],\n [\n /(cros) [\\w]+ ([\\w\\.]+\\w)/i // Chromium OS\n ],\n [[NAME, \"Chromium OS\"], VERSION],\n [\n // Console\n /(nintendo|playstation) ([wids345portablevuch]+)/i, // Nintendo/Playstation\n /(xbox); +xbox ([^\\);]+)/i, // Microsoft Xbox (360, One, X, S, Series X, Series S)\n\n // Other\n /\\b(joli|palm)\\b ?(?:os)?\\/?([\\w\\.]*)/i, // Joli/Palm\n /(mint)[\\/\\(\\) ]?(\\w*)/i, // Mint\n /(mageia|vectorlinux)[; ]/i, // Mageia/VectorLinux\n /([kxln]?ubuntu|debian|suse|opensuse|gentoo|arch(?= linux)|slackware|fedora|mandriva|centos|pclinuxos|red ?hat|zenwalk|linpus|raspbian|plan 9|minix|risc os|contiki|deepin|manjaro|elementary os|sabayon|linspire)(?: gnu\\/linux)?(?: enterprise)?(?:[- ]linux)?(?:-gnu)?[-\\/ ]?(?!chrom|package)([-\\w\\.]*)/i,\n // Ubuntu/Debian/SUSE/Gentoo/Arch/Slackware/Fedora/Mandriva/CentOS/PCLinuxOS/RedHat/Zenwalk/Linpus/Raspbian/Plan9/Minix/RISCOS/Contiki/Deepin/Manjaro/elementary/Sabayon/Linspire\n /(hurd|linux) ?([\\w\\.]*)/i, // Hurd/Linux\n /(gnu) ?([\\w\\.]*)/i, // GNU\n /\\b([-frentopcghs]{0,5}bsd|dragonfly)[\\/ ]?(?!amd|[ix346]{1,2}86)([\\w\\.]*)/i, // FreeBSD/NetBSD/OpenBSD/PC-BSD/GhostBSD/DragonFly\n /(haiku) (\\w+)/i // Haiku\n ],\n [NAME, VERSION],\n [\n /(sunos) ?([\\w\\.\\d]*)/i // Solaris\n ],\n [[NAME, \"Solaris\"], VERSION],\n [\n /((?:open)?solaris)[-\\/ ]?([\\w\\.]*)/i, // Solaris\n /(aix) ((\\d)(?=\\.|\\)| )[\\w\\.])*/i, // AIX\n /\\b(beos|os\\/2|amigaos|morphos|openvms|fuchsia|hp-ux)/i, // BeOS/OS2/AmigaOS/MorphOS/OpenVMS/Fuchsia/HP-UX\n /(unix) ?([\\w\\.]*)/i // UNIX\n ],\n [NAME, VERSION]\n ]\n };\n\n /////////////////\n // Constructor\n ////////////////\n\n var UAParser = function (ua, extensions) {\n if (typeof ua === OBJ_TYPE) {\n extensions = ua;\n ua = undefined;\n }\n\n if (!(this instanceof UAParser)) {\n return new UAParser(ua, extensions).getResult();\n }\n\n var _ua =\n ua ||\n (typeof window !== UNDEF_TYPE &&\n window.navigator &&\n window.navigator.userAgent ? window.navigator.userAgent : EMPTY);\n var _rgxmap = extensions ? extend(regexes, extensions) : regexes;\n\n this.getBrowser = function () {\n var _browser = {};\n _browser[NAME] = undefined;\n _browser[VERSION] = undefined;\n rgxMapper.call(_browser, _ua, _rgxmap.browser);\n _browser.major = majorize(_browser.version);\n return _browser;\n };\n this.getCPU = function () {\n var _cpu = {};\n _cpu[ARCHITECTURE] = undefined;\n rgxMapper.call(_cpu, _ua, _rgxmap.cpu);\n return _cpu;\n };\n this.getDevice = function () {\n var _device = {};\n _device[VENDOR] = undefined;\n _device[MODEL] = undefined;\n _device[TYPE] = undefined;\n rgxMapper.call(_device, _ua, _rgxmap.device);\n return _device;\n };\n this.getEngine = function () {\n var _engine = {};\n _engine[NAME] = undefined;\n _engine[VERSION] = undefined;\n rgxMapper.call(_engine, _ua, _rgxmap.engine);\n return _engine;\n };\n this.getOS = function () {\n var _os = {};\n _os[NAME] = undefined;\n _os[VERSION] = undefined;\n rgxMapper.call(_os, _ua, _rgxmap.os);\n return _os;\n };\n this.getResult = function () {\n return {\n ua: this.getUA(),\n browser: this.getBrowser(),\n engine: this.getEngine(),\n os: this.getOS(),\n device: this.getDevice(),\n cpu: this.getCPU()\n };\n };\n this.getUA = function () {\n return _ua;\n };\n this.setUA = function (ua) {\n _ua =\n typeof ua === STR_TYPE && ua.length > UA_MAX_LENGTH ? trim(ua, UA_MAX_LENGTH) : ua;\n return this;\n };\n this.setUA(_ua);\n return this;\n };\n\n UAParser.VERSION = LIBVERSION;\n UAParser.BROWSER = enumerize([NAME, VERSION, MAJOR]);\n UAParser.CPU = enumerize([ARCHITECTURE]);\n UAParser.DEVICE = enumerize([\n MODEL,\n VENDOR,\n TYPE,\n CONSOLE,\n MOBILE,\n SMARTTV,\n TABLET,\n WEARABLE,\n EMBEDDED\n ]);\n UAParser.ENGINE = UAParser.OS = enumerize([NAME, VERSION]);\n\n ///////////\n // Export\n //////////\n\n // check js environment\n if (typeof exports !== UNDEF_TYPE) {\n // nodejs env\n if (typeof module !== UNDEF_TYPE && module.exports) {\n exports = module.exports = UAParser;\n }\n exports.UAParser = UAParser;\n } else {\n // requirejs env (optional)\n if (typeof define === FUNC_TYPE && define.amd) {\n define(function () {\n return UAParser;\n });\n } else if (typeof window !== UNDEF_TYPE) {\n // browser env\n window.UAParser = UAParser;\n }\n }\n\n // jQuery/Zepto specific (optional)\n // Note:\n // In AMD env the global scope should be kept clean, but jQuery is an exception.\n // jQuery always exports to global scope, unless jQuery.noConflict(true) is used,\n // and we should catch that.\n var $ = typeof window !== UNDEF_TYPE && (window.jQuery || window.Zepto);\n if ($ && !$.ua) {\n var parser = new UAParser();\n $.ua = parser.getResult();\n $.ua.get = function () {\n return parser.getUA();\n };\n $.ua.set = function (ua) {\n parser.setUA(ua);\n var result = parser.getResult();\n for (var prop in result) {\n $.ua[prop] = result[prop];\n }\n };\n }\n})(typeof window === \"object\" ? window : this);\n","export const VERSION = '1.4.4';\n//# sourceMappingURL=version.js.map","function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { Config, MemoryStorage, UUID } from '@amplitude/analytics-core';\nimport { CookieStorage, getCookieName, getQueryParams, FetchTransport } from '@amplitude/analytics-client-common';\nimport { LocalStorage } from './storage/local-storage';\nimport RemnantDataMigration from './migration/remnant-data-migration';\nexport const getDefaultConfig = () => {\n const cookieStorage = new MemoryStorage();\n const trackingOptions = {\n adid: true,\n carrier: true,\n deviceManufacturer: true,\n deviceModel: true,\n ipAddress: true,\n language: true,\n osName: true,\n osVersion: true,\n platform: true,\n appSetId: true,\n idfv: true,\n country: true\n };\n return {\n cookieExpiration: 365,\n cookieSameSite: 'Lax',\n cookieSecure: false,\n cookieStorage,\n cookieUpgrade: true,\n disableCookies: false,\n domain: '',\n sessionTimeout: 5 * 60 * 1000,\n storageProvider: new MemoryStorage(),\n trackingSessionEvents: false,\n trackingOptions,\n transportProvider: new FetchTransport()\n };\n};\nexport class ReactNativeConfig extends Config {\n // NOTE: These protected properties are used to cache values from async storage\n\n constructor(apiKey, options) {\n const defaultConfig = getDefaultConfig();\n super({\n flushIntervalMillis: 1000,\n flushMaxRetries: 5,\n flushQueueSize: 30,\n transportProvider: defaultConfig.transportProvider,\n ...options,\n apiKey\n });\n\n // NOTE: Define `cookieStorage` first to persist user session\n // user session properties expect `cookieStorage` to be defined\n _defineProperty(this, \"appVersion\", void 0);\n _defineProperty(this, \"cookieExpiration\", void 0);\n _defineProperty(this, \"cookieSameSite\", void 0);\n _defineProperty(this, \"cookieSecure\", void 0);\n _defineProperty(this, \"cookieStorage\", void 0);\n _defineProperty(this, \"cookieUpgrade\", void 0);\n _defineProperty(this, \"disableCookies\", void 0);\n _defineProperty(this, \"domain\", void 0);\n _defineProperty(this, \"partnerId\", void 0);\n _defineProperty(this, \"sessionTimeout\", void 0);\n _defineProperty(this, \"trackingSessionEvents\", void 0);\n _defineProperty(this, \"trackingOptions\", void 0);\n _defineProperty(this, \"_deviceId\", void 0);\n _defineProperty(this, \"_lastEventId\", void 0);\n _defineProperty(this, \"_lastEventTime\", void 0);\n _defineProperty(this, \"_optOut\", false);\n _defineProperty(this, \"_sessionId\", void 0);\n _defineProperty(this, \"_userId\", void 0);\n this.cookieStorage = (options === null || options === void 0 ? void 0 : options.cookieStorage) ?? defaultConfig.cookieStorage;\n this.deviceId = options === null || options === void 0 ? void 0 : options.deviceId;\n this.lastEventTime = options === null || options === void 0 ? void 0 : options.lastEventTime;\n this.optOut = Boolean(options === null || options === void 0 ? void 0 : options.optOut);\n this.sessionId = options === null || options === void 0 ? void 0 : options.sessionId;\n this.userId = options === null || options === void 0 ? void 0 : options.userId;\n this.appVersion = options === null || options === void 0 ? void 0 : options.appVersion;\n this.cookieExpiration = (options === null || options === void 0 ? void 0 : options.cookieExpiration) ?? defaultConfig.cookieExpiration;\n this.cookieSameSite = (options === null || options === void 0 ? void 0 : options.cookieSameSite) ?? defaultConfig.cookieSameSite;\n this.cookieSecure = (options === null || options === void 0 ? void 0 : options.cookieSecure) ?? defaultConfig.cookieSecure;\n this.cookieUpgrade = (options === null || options === void 0 ? void 0 : options.cookieUpgrade) ?? defaultConfig.cookieUpgrade;\n this.disableCookies = (options === null || options === void 0 ? void 0 : options.disableCookies) ?? defaultConfig.disableCookies;\n this.domain = (options === null || options === void 0 ? void 0 : options.domain) ?? defaultConfig.domain;\n this.partnerId = options === null || options === void 0 ? void 0 : options.partnerId;\n this.sessionTimeout = (options === null || options === void 0 ? void 0 : options.sessionTimeout) ?? defaultConfig.sessionTimeout;\n this.trackingOptions = (options === null || options === void 0 ? void 0 : options.trackingOptions) ?? defaultConfig.trackingOptions;\n this.trackingSessionEvents = (options === null || options === void 0 ? void 0 : options.trackingSessionEvents) ?? defaultConfig.trackingSessionEvents;\n }\n get deviceId() {\n return this._deviceId;\n }\n set deviceId(deviceId) {\n if (this._deviceId !== deviceId) {\n this._deviceId = deviceId;\n this.updateStorage();\n }\n }\n get userId() {\n return this._userId;\n }\n set userId(userId) {\n if (this._userId !== userId) {\n this._userId = userId;\n this.updateStorage();\n }\n }\n get sessionId() {\n return this._sessionId;\n }\n set sessionId(sessionId) {\n if (this._sessionId !== sessionId) {\n this._sessionId = sessionId;\n this.updateStorage();\n }\n }\n get optOut() {\n return this._optOut;\n }\n set optOut(optOut) {\n if (this._optOut !== optOut) {\n this._optOut = optOut;\n this.updateStorage();\n }\n }\n get lastEventTime() {\n return this._lastEventTime;\n }\n set lastEventTime(lastEventTime) {\n if (this._lastEventTime !== lastEventTime) {\n this._lastEventTime = lastEventTime;\n this.updateStorage();\n }\n }\n get lastEventId() {\n return this._lastEventId;\n }\n set lastEventId(lastEventId) {\n if (this._lastEventId !== lastEventId) {\n this._lastEventId = lastEventId;\n this.updateStorage();\n }\n }\n updateStorage() {\n var _this$cookieStorage;\n const cache = {\n deviceId: this._deviceId,\n userId: this._userId,\n sessionId: this._sessionId,\n optOut: this._optOut,\n lastEventTime: this._lastEventTime,\n lastEventId: this._lastEventId\n };\n void ((_this$cookieStorage = this.cookieStorage) === null || _this$cookieStorage === void 0 ? void 0 : _this$cookieStorage.set(getCookieName(this.apiKey), cache));\n }\n}\nexport const useReactNativeConfig = async (apiKey, options) => {\n var _config$loggerProvide;\n const defaultConfig = getDefaultConfig();\n\n // create cookie storage\n const domain = options !== null && options !== void 0 && options.disableCookies ? '' : (options === null || options === void 0 ? void 0 : options.domain) ?? (await getTopLevelDomain());\n const cookieStorage = await createCookieStorage({\n ...options,\n domain\n });\n const previousCookies = await cookieStorage.get(getCookieName(apiKey));\n const queryParams = getQueryParams();\n\n // reconcile user session\n let deviceId = (options === null || options === void 0 ? void 0 : options.deviceId) ?? queryParams.deviceId ?? (previousCookies === null || previousCookies === void 0 ? void 0 : previousCookies.deviceId);\n let lastEventTime = (options === null || options === void 0 ? void 0 : options.lastEventTime) ?? (previousCookies === null || previousCookies === void 0 ? void 0 : previousCookies.lastEventTime);\n const optOut = (options === null || options === void 0 ? void 0 : options.optOut) ?? Boolean(previousCookies === null || previousCookies === void 0 ? void 0 : previousCookies.optOut);\n let sessionId = (options === null || options === void 0 ? void 0 : options.sessionId) ?? (previousCookies === null || previousCookies === void 0 ? void 0 : previousCookies.sessionId);\n let userId = (options === null || options === void 0 ? void 0 : options.userId) ?? (previousCookies === null || previousCookies === void 0 ? void 0 : previousCookies.userId);\n let lastEventId = previousCookies === null || previousCookies === void 0 ? void 0 : previousCookies.lastEventId;\n const storageProvider = (options === null || options === void 0 ? void 0 : options.storageProvider) ?? (await createEventsStorage(options));\n if ((options === null || options === void 0 ? void 0 : options.migrateLegacyData) !== false) {\n const legacySessionData = await new RemnantDataMigration(apiKey, options === null || options === void 0 ? void 0 : options.instanceName, storageProvider, (previousCookies === null || previousCookies === void 0 ? void 0 : previousCookies.lastEventTime) === undefined, options === null || options === void 0 ? void 0 : options.loggerProvider).execute();\n deviceId = deviceId ?? legacySessionData.deviceId;\n userId = userId ?? legacySessionData.userId;\n sessionId = sessionId ?? legacySessionData.sessionId;\n lastEventTime = lastEventTime ?? legacySessionData.lastEventTime;\n lastEventId = lastEventId ?? legacySessionData.lastEventId;\n }\n const config = new ReactNativeConfig(apiKey, {\n ...options,\n cookieStorage,\n deviceId: deviceId ?? UUID(),\n domain,\n lastEventTime,\n optOut,\n sessionId,\n storageProvider,\n trackingOptions: {\n ...defaultConfig.trackingOptions,\n ...(options === null || options === void 0 ? void 0 : options.trackingOptions)\n },\n transportProvider: (options === null || options === void 0 ? void 0 : options.transportProvider) ?? new FetchTransport(),\n userId\n });\n config.lastEventId = lastEventId;\n (_config$loggerProvide = config.loggerProvider) === null || _config$loggerProvide === void 0 ? void 0 : _config$loggerProvide.log(`Init: storage=${cookieStorage.constructor.name} restoredSessionId = ${(previousCookies === null || previousCookies === void 0 ? void 0 : previousCookies.sessionId) ?? 'undefined'}, optionsSessionId = ${(options === null || options === void 0 ? void 0 : options.sessionId) ?? 'undefined'}`);\n return config;\n};\nexport const createCookieStorage = async function (overrides) {\n let baseConfig = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : getDefaultConfig();\n const options = {\n ...baseConfig,\n ...overrides\n };\n const cookieStorage = overrides === null || overrides === void 0 ? void 0 : overrides.cookieStorage;\n if (!cookieStorage || !(await cookieStorage.isEnabled())) {\n return createFlexibleStorage(options);\n }\n return cookieStorage;\n};\nconst createFlexibleStorage = async options => {\n let storage = new CookieStorage({\n domain: options.domain,\n expirationDays: options.cookieExpiration,\n sameSite: options.cookieSameSite,\n secure: options.cookieSecure\n });\n if (options.disableCookies || !(await storage.isEnabled())) {\n storage = new LocalStorage();\n if (!(await storage.isEnabled())) {\n storage = new MemoryStorage();\n }\n }\n return storage;\n};\nexport const createEventsStorage = async overrides => {\n const hasStorageProviderProperty = overrides && Object.prototype.hasOwnProperty.call(overrides, 'storageProvider');\n // If storageProperty is explicitly undefined like `{ storageProperty: undefined }`\n // then storageProvider is undefined\n // If storageProvider is implicitly undefined like `{ }`\n // then storageProvider is LocalStorage\n // Otherwise storageProvider is overriden\n if (!hasStorageProviderProperty || overrides.storageProvider) {\n for (const storage of [overrides === null || overrides === void 0 ? void 0 : overrides.storageProvider, new LocalStorage()]) {\n if (storage && (await storage.isEnabled())) {\n return storage;\n }\n }\n }\n return undefined;\n};\nexport const getTopLevelDomain = async url => {\n if (!(await new CookieStorage().isEnabled()) || !url && typeof location === 'undefined') {\n return '';\n }\n const host = url ?? location.hostname;\n const parts = host.split('.');\n const levels = [];\n const storageKey = 'AMP_TLDTEST';\n for (let i = parts.length - 2; i >= 0; --i) {\n levels.push(parts.slice(i).join('.'));\n }\n for (let i = 0; i < levels.length; i++) {\n const domain = levels[i];\n const options = {\n domain: '.' + domain\n };\n const storage = new CookieStorage(options);\n await storage.set(storageKey, 1);\n const value = await storage.get(storageKey);\n if (value) {\n await storage.remove(storageKey);\n return '.' + domain;\n }\n }\n return '';\n};\n//# sourceMappingURL=config.js.map","import { getGlobalScope } from '@amplitude/analytics-client-common';\nimport AsyncStorage from '@react-native-async-storage/async-storage';\nexport class LocalStorage {\n async isEnabled() {\n /* istanbul ignore if */\n if (!getGlobalScope()) {\n return false;\n }\n const random = String(Date.now());\n const testStorage = new LocalStorage();\n const testKey = 'AMP_TEST';\n try {\n await testStorage.set(testKey, random);\n const value = await testStorage.get(testKey);\n return value === random;\n } catch {\n /* istanbul ignore next */\n return false;\n } finally {\n await testStorage.remove(testKey);\n }\n }\n async get(key) {\n try {\n const value = await this.getRaw(key);\n if (!value) {\n return undefined;\n }\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return JSON.parse(value);\n } catch {\n /* istanbul ignore next */\n return undefined;\n }\n }\n async getRaw(key) {\n return (await AsyncStorage.getItem(key)) || undefined;\n }\n async set(key, value) {\n try {\n await AsyncStorage.setItem(key, JSON.stringify(value));\n } catch {\n //\n }\n }\n async remove(key) {\n try {\n await AsyncStorage.removeItem(key);\n } catch {\n //\n }\n }\n async reset() {\n try {\n await AsyncStorage.clear();\n } catch {\n //\n }\n }\n}\n//# sourceMappingURL=local-storage.js.map","import AsyncStorage from './AsyncStorage';\nexport { useAsyncStorage } from './hooks';\nexport default AsyncStorage;\n//# sourceMappingURL=index.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n// @ts-ignore Cannot find module 'merge-options' or its corresponding type declarations\nimport mergeOptions from 'merge-options';\nconst merge = mergeOptions.bind({\n concatArrays: true,\n ignoreUndefined: true\n});\nfunction mergeLocalStorageItem(key, value) {\n const oldValue = window.localStorage.getItem(key);\n if (oldValue) {\n const oldObject = JSON.parse(oldValue);\n const newObject = JSON.parse(value);\n const nextValue = JSON.stringify(merge(oldObject, newObject));\n window.localStorage.setItem(key, nextValue);\n } else {\n window.localStorage.setItem(key, value);\n }\n}\nfunction createPromise(getValue, callback) {\n return new Promise((resolve, reject) => {\n try {\n const value = getValue();\n callback === null || callback === void 0 ? void 0 : callback(null, value);\n resolve(value);\n } catch (err) {\n callback === null || callback === void 0 ? void 0 : callback(err);\n reject(err);\n }\n });\n}\nfunction createPromiseAll(promises, callback, processResult) {\n return Promise.all(promises).then(result => {\n const value = (processResult === null || processResult === void 0 ? void 0 : processResult(result)) ?? null;\n callback === null || callback === void 0 ? void 0 : callback(null, value);\n return Promise.resolve(value);\n }, errors => {\n callback === null || callback === void 0 ? void 0 : callback(errors);\n return Promise.reject(errors);\n });\n}\nconst AsyncStorage = {\n /**\n * Fetches `key` value.\n */\n getItem: (key, callback) => {\n return createPromise(() => window.localStorage.getItem(key), callback);\n },\n /**\n * Sets `value` for `key`.\n */\n setItem: (key, value, callback) => {\n return createPromise(() => window.localStorage.setItem(key, value), callback);\n },\n /**\n * Removes a `key`\n */\n removeItem: (key, callback) => {\n return createPromise(() => window.localStorage.removeItem(key), callback);\n },\n /**\n * Merges existing value with input value, assuming they are stringified JSON.\n */\n mergeItem: (key, value, callback) => {\n return createPromise(() => mergeLocalStorageItem(key, value), callback);\n },\n /**\n * Erases *all* AsyncStorage for the domain.\n */\n clear: callback => {\n return createPromise(() => window.localStorage.clear(), callback);\n },\n /**\n * Gets *all* keys known to the app, for all callers, libraries, etc.\n */\n getAllKeys: callback => {\n return createPromise(() => {\n const numberOfKeys = window.localStorage.length;\n const keys = [];\n for (let i = 0; i < numberOfKeys; i += 1) {\n const key = window.localStorage.key(i) || '';\n keys.push(key);\n }\n return keys;\n }, callback);\n },\n /**\n * (stub) Flushes any pending requests using a single batch call to get the data.\n */\n flushGetRequests: () => undefined,\n /**\n * multiGet resolves to an array of key-value pair arrays that matches the\n * input format of multiSet.\n *\n * multiGet(['k1', 'k2']) -> [['k1', 'val1'], ['k2', 'val2']]\n */\n multiGet: (keys, callback) => {\n const promises = keys.map(key => AsyncStorage.getItem(key));\n const processResult = result => result.map((value, i) => [keys[i], value]);\n return createPromiseAll(promises, callback, processResult);\n },\n /**\n * Takes an array of key-value array pairs.\n * multiSet([['k1', 'val1'], ['k2', 'val2']])\n */\n multiSet: (keyValuePairs, callback) => {\n const promises = keyValuePairs.map(item => AsyncStorage.setItem(item[0], item[1]));\n return createPromiseAll(promises, callback);\n },\n /**\n * Delete all the keys in the `keys` array.\n */\n multiRemove: (keys, callback) => {\n const promises = keys.map(key => AsyncStorage.removeItem(key));\n return createPromiseAll(promises, callback);\n },\n /**\n * Takes an array of key-value array pairs and merges them with existing\n * values, assuming they are stringified JSON.\n *\n * multiMerge([['k1', 'val1'], ['k2', 'val2']])\n */\n multiMerge: (keyValuePairs, callback) => {\n const promises = keyValuePairs.map(item => AsyncStorage.mergeItem(item[0], item[1]));\n return createPromiseAll(promises, callback);\n }\n};\nexport default AsyncStorage;\n//# sourceMappingURL=AsyncStorage.js.map","import AsyncStorage from './AsyncStorage';\nexport function useAsyncStorage(key) {\n return {\n getItem: function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return AsyncStorage.getItem(key, ...args);\n },\n setItem: function () {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n return AsyncStorage.setItem(key, ...args);\n },\n mergeItem: function () {\n for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n args[_key3] = arguments[_key3];\n }\n return AsyncStorage.mergeItem(key, ...args);\n },\n removeItem: function () {\n for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n args[_key4] = arguments[_key4];\n }\n return AsyncStorage.removeItem(key, ...args);\n }\n };\n}\n//# sourceMappingURL=hooks.js.map","function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { NativeModules } from 'react-native';\nimport { STORAGE_PREFIX } from '@amplitude/analytics-core';\nexport default class RemnantDataMigration {\n constructor(apiKey, instanceName, storage, firstRunSinceUpgrade, logger) {\n this.apiKey = apiKey;\n this.instanceName = instanceName;\n this.storage = storage;\n this.firstRunSinceUpgrade = firstRunSinceUpgrade;\n this.logger = logger;\n _defineProperty(this, \"eventsStorageKey\", void 0);\n _defineProperty(this, \"nativeModule\", void 0);\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n this.eventsStorageKey = `${STORAGE_PREFIX}_${this.apiKey.substring(0, 10)}`;\n this.nativeModule = NativeModules.AmplitudeReactNative;\n }\n async execute() {\n if (!this.nativeModule) {\n return {};\n }\n if (this.firstRunSinceUpgrade) {\n await this.moveIdentifies();\n await this.moveInterceptedIdentifies();\n }\n await this.moveEvents();\n const sessionData = await this.callNativeFunction(() => this.nativeModule.getLegacySessionData(this.instanceName));\n return sessionData ?? {};\n }\n async moveEvents() {\n await this.moveLegacyEvents('event');\n }\n async moveIdentifies() {\n await this.moveLegacyEvents('identify');\n }\n async moveInterceptedIdentifies() {\n await this.moveLegacyEvents('interceptedIdentify');\n }\n async callNativeFunction(action) {\n try {\n return await action();\n } catch (e) {\n var _this$logger;\n (_this$logger = this.logger) === null || _this$logger === void 0 ? void 0 : _this$logger.error(`can't call native function: ${String(e)}`);\n return undefined;\n }\n }\n callNativeAction(action) {\n try {\n action();\n } catch (e) {\n var _this$logger2;\n (_this$logger2 = this.logger) === null || _this$logger2 === void 0 ? void 0 : _this$logger2.error(`can't call native function: ${String(e)}`);\n }\n }\n async moveLegacyEvents(eventKind) {\n const legacyJsonEvents = await this.callNativeFunction(() => this.nativeModule.getLegacyEvents(this.instanceName, eventKind));\n if (!this.storage || !legacyJsonEvents || legacyJsonEvents.length === 0) {\n return;\n }\n const events = (await this.storage.get(this.eventsStorageKey)) ?? [];\n const eventIds = [];\n legacyJsonEvents.forEach(jsonEvent => {\n const event = this.convertLegacyEvent(jsonEvent);\n if (event) {\n events.push(event);\n if (event.event_id !== undefined) {\n eventIds.push(event.event_id);\n }\n }\n });\n await this.storage.set(this.eventsStorageKey, events);\n eventIds.forEach(eventId => this.callNativeAction(() => this.nativeModule.removeLegacyEvent(this.instanceName, eventKind, eventId)));\n }\n\n /* eslint-disable @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access */\n convertLegacyEvent(legacyJsonEvent) {\n try {\n const event = JSON.parse(legacyJsonEvent);\n const {\n library,\n timestamp,\n uuid,\n api_properties\n } = event;\n if (library !== undefined) {\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n event.library = `${library.name}/${library.version}`;\n }\n if (timestamp !== undefined) {\n event.time = timestamp;\n }\n if (uuid !== undefined) {\n event.insert_id = uuid;\n }\n if (api_properties) {\n const {\n androidADID,\n android_app_set_id,\n ios_idfa,\n ios_idfv,\n productId,\n quantity,\n price,\n location\n } = api_properties;\n if (androidADID !== undefined) {\n event.adid = androidADID;\n }\n if (android_app_set_id !== undefined) {\n event.android_app_set_id = android_app_set_id;\n }\n if (ios_idfa !== undefined) {\n event.idfa = ios_idfa;\n }\n if (ios_idfv !== undefined) {\n event.idfv = ios_idfv;\n }\n if (productId !== undefined) {\n event.productId = productId;\n }\n if (quantity !== undefined) {\n event.quantity = quantity;\n }\n if (price !== undefined) {\n event.price = price;\n }\n if (location !== undefined) {\n const {\n lat,\n lng\n } = location;\n event.location_lat = lat;\n event.location_lng = lng;\n }\n }\n const {\n $productId: productId,\n $quantity: quantity,\n $price: price,\n $revenueType: revenueType\n } = event;\n if (productId !== undefined) {\n event.productId = productId;\n }\n if (quantity !== undefined) {\n event.quantity = quantity;\n }\n if (price !== undefined) {\n event.price = price;\n }\n if (revenueType !== undefined) {\n event.revenueType = revenueType;\n }\n return event;\n } catch {\n // skip invalid events\n return null;\n }\n }\n // eslint-enable @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\n}\n//# sourceMappingURL=remnant-data-migration.js.map","import { getOldCookieName } from '@amplitude/analytics-client-common';\nimport { createCookieStorage, getDefaultConfig, getTopLevelDomain } from '../config';\nexport const parseOldCookies = async (apiKey, options) => {\n const storage = await createCookieStorage({\n ...options,\n domain: options !== null && options !== void 0 && options.disableCookies ? '' : (options === null || options === void 0 ? void 0 : options.domain) ?? (await getTopLevelDomain())\n });\n const oldCookieName = getOldCookieName(apiKey);\n const cookies = await storage.getRaw(oldCookieName);\n if (!cookies) {\n return {\n optOut: false\n };\n }\n if ((options === null || options === void 0 ? void 0 : options.cookieUpgrade) ?? getDefaultConfig().cookieUpgrade) {\n await storage.remove(oldCookieName);\n }\n const [deviceId, userId, optOut, sessionId, lastEventTime] = cookies.split('.');\n return {\n deviceId,\n userId: decode(userId),\n sessionId: parseTime(sessionId),\n lastEventTime: parseTime(lastEventTime),\n optOut: Boolean(optOut)\n };\n};\nexport const parseTime = num => {\n const integer = parseInt(num, 32);\n if (isNaN(integer)) {\n return undefined;\n }\n return integer;\n};\nexport const decode = value => {\n if (!atob || !escape || !value) {\n return undefined;\n }\n try {\n return decodeURIComponent(escape(atob(value)));\n } catch {\n return undefined;\n }\n};\n//# sourceMappingURL=index.js.map","import { Platform } from 'react-native';\nexport const isWeb = () => {\n return Platform.OS === 'web';\n};\nexport const isNative = () => {\n return !isWeb();\n};\n//# sourceMappingURL=platform.js.map","\n;(function (name, root, factory) {\n if (typeof exports === 'object') {\n module.exports = factory()\n module.exports['default'] = factory()\n }\n /* istanbul ignore next */\n else if (typeof define === 'function' && define.amd) {\n define(factory)\n }\n else {\n root[name] = factory()\n }\n}('slugify', this, function () {\n var charMap = JSON.parse('{\"$\":\"dollar\",\"%\":\"percent\",\"&\":\"and\",\"<\":\"less\",\">\":\"greater\",\"|\":\"or\",\"¢\":\"cent\",\"£\":\"pound\",\"¤\":\"currency\",\"¥\":\"yen\",\"©\":\"(c)\",\"ª\":\"a\",\"®\":\"(r)\",\"º\":\"o\",\"À\":\"A\",\"Á\":\"A\",\"Â\":\"A\",\"Ã\":\"A\",\"Ä\":\"A\",\"Å\":\"A\",\"Æ\":\"AE\",\"Ç\":\"C\",\"È\":\"E\",\"É\":\"E\",\"Ê\":\"E\",\"Ë\":\"E\",\"Ì\":\"I\",\"Í\":\"I\",\"Î\":\"I\",\"Ï\":\"I\",\"Ð\":\"D\",\"Ñ\":\"N\",\"Ò\":\"O\",\"Ó\":\"O\",\"Ô\":\"O\",\"Õ\":\"O\",\"Ö\":\"O\",\"Ø\":\"O\",\"Ù\":\"U\",\"Ú\":\"U\",\"Û\":\"U\",\"Ü\":\"U\",\"Ý\":\"Y\",\"Þ\":\"TH\",\"ß\":\"ss\",\"à\":\"a\",\"á\":\"a\",\"â\":\"a\",\"ã\":\"a\",\"ä\":\"a\",\"å\":\"a\",\"æ\":\"ae\",\"ç\":\"c\",\"è\":\"e\",\"é\":\"e\",\"ê\":\"e\",\"ë\":\"e\",\"ì\":\"i\",\"í\":\"i\",\"î\":\"i\",\"ï\":\"i\",\"ð\":\"d\",\"ñ\":\"n\",\"ò\":\"o\",\"ó\":\"o\",\"ô\":\"o\",\"õ\":\"o\",\"ö\":\"o\",\"ø\":\"o\",\"ù\":\"u\",\"ú\":\"u\",\"û\":\"u\",\"ü\":\"u\",\"ý\":\"y\",\"þ\":\"th\",\"ÿ\":\"y\",\"Ā\":\"A\",\"ā\":\"a\",\"Ă\":\"A\",\"ă\":\"a\",\"Ą\":\"A\",\"ą\":\"a\",\"Ć\":\"C\",\"ć\":\"c\",\"Č\":\"C\",\"č\":\"c\",\"Ď\":\"D\",\"ď\":\"d\",\"Đ\":\"DJ\",\"đ\":\"dj\",\"Ē\":\"E\",\"ē\":\"e\",\"Ė\":\"E\",\"ė\":\"e\",\"Ę\":\"e\",\"ę\":\"e\",\"Ě\":\"E\",\"ě\":\"e\",\"Ğ\":\"G\",\"ğ\":\"g\",\"Ģ\":\"G\",\"ģ\":\"g\",\"Ĩ\":\"I\",\"ĩ\":\"i\",\"Ī\":\"i\",\"ī\":\"i\",\"Į\":\"I\",\"į\":\"i\",\"İ\":\"I\",\"ı\":\"i\",\"Ķ\":\"k\",\"ķ\":\"k\",\"Ļ\":\"L\",\"ļ\":\"l\",\"Ľ\":\"L\",\"ľ\":\"l\",\"Ł\":\"L\",\"ł\":\"l\",\"Ń\":\"N\",\"ń\":\"n\",\"Ņ\":\"N\",\"ņ\":\"n\",\"Ň\":\"N\",\"ň\":\"n\",\"Ō\":\"O\",\"ō\":\"o\",\"Ő\":\"O\",\"ő\":\"o\",\"Œ\":\"OE\",\"œ\":\"oe\",\"Ŕ\":\"R\",\"ŕ\":\"r\",\"Ř\":\"R\",\"ř\":\"r\",\"Ś\":\"S\",\"ś\":\"s\",\"Ş\":\"S\",\"ş\":\"s\",\"Š\":\"S\",\"š\":\"s\",\"Ţ\":\"T\",\"ţ\":\"t\",\"Ť\":\"T\",\"ť\":\"t\",\"Ũ\":\"U\",\"ũ\":\"u\",\"Ū\":\"u\",\"ū\":\"u\",\"Ů\":\"U\",\"ů\":\"u\",\"Ű\":\"U\",\"ű\":\"u\",\"Ų\":\"U\",\"ų\":\"u\",\"Ŵ\":\"W\",\"ŵ\":\"w\",\"Ŷ\":\"Y\",\"ŷ\":\"y\",\"Ÿ\":\"Y\",\"Ź\":\"Z\",\"ź\":\"z\",\"Ż\":\"Z\",\"ż\":\"z\",\"Ž\":\"Z\",\"ž\":\"z\",\"Ə\":\"E\",\"ƒ\":\"f\",\"Ơ\":\"O\",\"ơ\":\"o\",\"Ư\":\"U\",\"ư\":\"u\",\"Lj\":\"LJ\",\"lj\":\"lj\",\"Nj\":\"NJ\",\"nj\":\"nj\",\"Ș\":\"S\",\"ș\":\"s\",\"Ț\":\"T\",\"ț\":\"t\",\"ə\":\"e\",\"˚\":\"o\",\"Ά\":\"A\",\"Έ\":\"E\",\"Ή\":\"H\",\"Ί\":\"I\",\"Ό\":\"O\",\"Ύ\":\"Y\",\"Ώ\":\"W\",\"ΐ\":\"i\",\"Α\":\"A\",\"Β\":\"B\",\"Γ\":\"G\",\"Δ\":\"D\",\"Ε\":\"E\",\"Ζ\":\"Z\",\"Η\":\"H\",\"Θ\":\"8\",\"Ι\":\"I\",\"Κ\":\"K\",\"Λ\":\"L\",\"Μ\":\"M\",\"Ν\":\"N\",\"Ξ\":\"3\",\"Ο\":\"O\",\"Π\":\"P\",\"Ρ\":\"R\",\"Σ\":\"S\",\"Τ\":\"T\",\"Υ\":\"Y\",\"Φ\":\"F\",\"Χ\":\"X\",\"Ψ\":\"PS\",\"Ω\":\"W\",\"Ϊ\":\"I\",\"Ϋ\":\"Y\",\"ά\":\"a\",\"έ\":\"e\",\"ή\":\"h\",\"ί\":\"i\",\"ΰ\":\"y\",\"α\":\"a\",\"β\":\"b\",\"γ\":\"g\",\"δ\":\"d\",\"ε\":\"e\",\"ζ\":\"z\",\"η\":\"h\",\"θ\":\"8\",\"ι\":\"i\",\"κ\":\"k\",\"λ\":\"l\",\"μ\":\"m\",\"ν\":\"n\",\"ξ\":\"3\",\"ο\":\"o\",\"π\":\"p\",\"ρ\":\"r\",\"ς\":\"s\",\"σ\":\"s\",\"τ\":\"t\",\"υ\":\"y\",\"φ\":\"f\",\"χ\":\"x\",\"ψ\":\"ps\",\"ω\":\"w\",\"ϊ\":\"i\",\"ϋ\":\"y\",\"ό\":\"o\",\"ύ\":\"y\",\"ώ\":\"w\",\"Ё\":\"Yo\",\"Ђ\":\"DJ\",\"Є\":\"Ye\",\"І\":\"I\",\"Ї\":\"Yi\",\"Ј\":\"J\",\"Љ\":\"LJ\",\"Њ\":\"NJ\",\"Ћ\":\"C\",\"Џ\":\"DZ\",\"А\":\"A\",\"Б\":\"B\",\"В\":\"V\",\"Г\":\"G\",\"Д\":\"D\",\"Е\":\"E\",\"Ж\":\"Zh\",\"З\":\"Z\",\"И\":\"I\",\"Й\":\"J\",\"К\":\"K\",\"Л\":\"L\",\"М\":\"M\",\"Н\":\"N\",\"О\":\"O\",\"П\":\"P\",\"Р\":\"R\",\"С\":\"S\",\"Т\":\"T\",\"У\":\"U\",\"Ф\":\"F\",\"Х\":\"H\",\"Ц\":\"C\",\"Ч\":\"Ch\",\"Ш\":\"Sh\",\"Щ\":\"Sh\",\"Ъ\":\"U\",\"Ы\":\"Y\",\"Ь\":\"\",\"Э\":\"E\",\"Ю\":\"Yu\",\"Я\":\"Ya\",\"а\":\"a\",\"б\":\"b\",\"в\":\"v\",\"г\":\"g\",\"д\":\"d\",\"е\":\"e\",\"ж\":\"zh\",\"з\":\"z\",\"и\":\"i\",\"й\":\"j\",\"к\":\"k\",\"л\":\"l\",\"м\":\"m\",\"н\":\"n\",\"о\":\"o\",\"п\":\"p\",\"р\":\"r\",\"с\":\"s\",\"т\":\"t\",\"у\":\"u\",\"ф\":\"f\",\"х\":\"h\",\"ц\":\"c\",\"ч\":\"ch\",\"ш\":\"sh\",\"щ\":\"sh\",\"ъ\":\"u\",\"ы\":\"y\",\"ь\":\"\",\"э\":\"e\",\"ю\":\"yu\",\"я\":\"ya\",\"ё\":\"yo\",\"ђ\":\"dj\",\"є\":\"ye\",\"і\":\"i\",\"ї\":\"yi\",\"ј\":\"j\",\"љ\":\"lj\",\"њ\":\"nj\",\"ћ\":\"c\",\"ѝ\":\"u\",\"џ\":\"dz\",\"Ґ\":\"G\",\"ґ\":\"g\",\"Ғ\":\"GH\",\"ғ\":\"gh\",\"Қ\":\"KH\",\"қ\":\"kh\",\"Ң\":\"NG\",\"ң\":\"ng\",\"Ү\":\"UE\",\"ү\":\"ue\",\"Ұ\":\"U\",\"ұ\":\"u\",\"Һ\":\"H\",\"һ\":\"h\",\"Ә\":\"AE\",\"ә\":\"ae\",\"Ө\":\"OE\",\"ө\":\"oe\",\"Ա\":\"A\",\"Բ\":\"B\",\"Գ\":\"G\",\"Դ\":\"D\",\"Ե\":\"E\",\"Զ\":\"Z\",\"Է\":\"E\\'\",\"Ը\":\"Y\\'\",\"Թ\":\"T\\'\",\"Ժ\":\"JH\",\"Ի\":\"I\",\"Լ\":\"L\",\"Խ\":\"X\",\"Ծ\":\"C\\'\",\"Կ\":\"K\",\"Հ\":\"H\",\"Ձ\":\"D\\'\",\"Ղ\":\"GH\",\"Ճ\":\"TW\",\"Մ\":\"M\",\"Յ\":\"Y\",\"Ն\":\"N\",\"Շ\":\"SH\",\"Չ\":\"CH\",\"Պ\":\"P\",\"Ջ\":\"J\",\"Ռ\":\"R\\'\",\"Ս\":\"S\",\"Վ\":\"V\",\"Տ\":\"T\",\"Ր\":\"R\",\"Ց\":\"C\",\"Փ\":\"P\\'\",\"Ք\":\"Q\\'\",\"Օ\":\"O\\'\\'\",\"Ֆ\":\"F\",\"և\":\"EV\",\"ء\":\"a\",\"آ\":\"aa\",\"أ\":\"a\",\"ؤ\":\"u\",\"إ\":\"i\",\"ئ\":\"e\",\"ا\":\"a\",\"ب\":\"b\",\"ة\":\"h\",\"ت\":\"t\",\"ث\":\"th\",\"ج\":\"j\",\"ح\":\"h\",\"خ\":\"kh\",\"د\":\"d\",\"ذ\":\"th\",\"ر\":\"r\",\"ز\":\"z\",\"س\":\"s\",\"ش\":\"sh\",\"ص\":\"s\",\"ض\":\"dh\",\"ط\":\"t\",\"ظ\":\"z\",\"ع\":\"a\",\"غ\":\"gh\",\"ف\":\"f\",\"ق\":\"q\",\"ك\":\"k\",\"ل\":\"l\",\"م\":\"m\",\"ن\":\"n\",\"ه\":\"h\",\"و\":\"w\",\"ى\":\"a\",\"ي\":\"y\",\"ً\":\"an\",\"ٌ\":\"on\",\"ٍ\":\"en\",\"َ\":\"a\",\"ُ\":\"u\",\"ِ\":\"e\",\"ْ\":\"\",\"٠\":\"0\",\"١\":\"1\",\"٢\":\"2\",\"٣\":\"3\",\"٤\":\"4\",\"٥\":\"5\",\"٦\":\"6\",\"٧\":\"7\",\"٨\":\"8\",\"٩\":\"9\",\"پ\":\"p\",\"چ\":\"ch\",\"ژ\":\"zh\",\"ک\":\"k\",\"گ\":\"g\",\"ی\":\"y\",\"۰\":\"0\",\"۱\":\"1\",\"۲\":\"2\",\"۳\":\"3\",\"۴\":\"4\",\"۵\":\"5\",\"۶\":\"6\",\"۷\":\"7\",\"۸\":\"8\",\"۹\":\"9\",\"฿\":\"baht\",\"ა\":\"a\",\"ბ\":\"b\",\"გ\":\"g\",\"დ\":\"d\",\"ე\":\"e\",\"ვ\":\"v\",\"ზ\":\"z\",\"თ\":\"t\",\"ი\":\"i\",\"კ\":\"k\",\"ლ\":\"l\",\"მ\":\"m\",\"ნ\":\"n\",\"ო\":\"o\",\"პ\":\"p\",\"ჟ\":\"zh\",\"რ\":\"r\",\"ს\":\"s\",\"ტ\":\"t\",\"უ\":\"u\",\"ფ\":\"f\",\"ქ\":\"k\",\"ღ\":\"gh\",\"ყ\":\"q\",\"შ\":\"sh\",\"ჩ\":\"ch\",\"ც\":\"ts\",\"ძ\":\"dz\",\"წ\":\"ts\",\"ჭ\":\"ch\",\"ხ\":\"kh\",\"ჯ\":\"j\",\"ჰ\":\"h\",\"Ṣ\":\"S\",\"ṣ\":\"s\",\"Ẁ\":\"W\",\"ẁ\":\"w\",\"Ẃ\":\"W\",\"ẃ\":\"w\",\"Ẅ\":\"W\",\"ẅ\":\"w\",\"ẞ\":\"SS\",\"Ạ\":\"A\",\"ạ\":\"a\",\"Ả\":\"A\",\"ả\":\"a\",\"Ấ\":\"A\",\"ấ\":\"a\",\"Ầ\":\"A\",\"ầ\":\"a\",\"Ẩ\":\"A\",\"ẩ\":\"a\",\"Ẫ\":\"A\",\"ẫ\":\"a\",\"Ậ\":\"A\",\"ậ\":\"a\",\"Ắ\":\"A\",\"ắ\":\"a\",\"Ằ\":\"A\",\"ằ\":\"a\",\"Ẳ\":\"A\",\"ẳ\":\"a\",\"Ẵ\":\"A\",\"ẵ\":\"a\",\"Ặ\":\"A\",\"ặ\":\"a\",\"Ẹ\":\"E\",\"ẹ\":\"e\",\"Ẻ\":\"E\",\"ẻ\":\"e\",\"Ẽ\":\"E\",\"ẽ\":\"e\",\"Ế\":\"E\",\"ế\":\"e\",\"Ề\":\"E\",\"ề\":\"e\",\"Ể\":\"E\",\"ể\":\"e\",\"Ễ\":\"E\",\"ễ\":\"e\",\"Ệ\":\"E\",\"ệ\":\"e\",\"Ỉ\":\"I\",\"ỉ\":\"i\",\"Ị\":\"I\",\"ị\":\"i\",\"Ọ\":\"O\",\"ọ\":\"o\",\"Ỏ\":\"O\",\"ỏ\":\"o\",\"Ố\":\"O\",\"ố\":\"o\",\"Ồ\":\"O\",\"ồ\":\"o\",\"Ổ\":\"O\",\"ổ\":\"o\",\"Ỗ\":\"O\",\"ỗ\":\"o\",\"Ộ\":\"O\",\"ộ\":\"o\",\"Ớ\":\"O\",\"ớ\":\"o\",\"Ờ\":\"O\",\"ờ\":\"o\",\"Ở\":\"O\",\"ở\":\"o\",\"Ỡ\":\"O\",\"ỡ\":\"o\",\"Ợ\":\"O\",\"ợ\":\"o\",\"Ụ\":\"U\",\"ụ\":\"u\",\"Ủ\":\"U\",\"ủ\":\"u\",\"Ứ\":\"U\",\"ứ\":\"u\",\"Ừ\":\"U\",\"ừ\":\"u\",\"Ử\":\"U\",\"ử\":\"u\",\"Ữ\":\"U\",\"ữ\":\"u\",\"Ự\":\"U\",\"ự\":\"u\",\"Ỳ\":\"Y\",\"ỳ\":\"y\",\"Ỵ\":\"Y\",\"ỵ\":\"y\",\"Ỷ\":\"Y\",\"ỷ\":\"y\",\"Ỹ\":\"Y\",\"ỹ\":\"y\",\"–\":\"-\",\"‘\":\"\\'\",\"’\":\"\\'\",\"“\":\"\\\\\\\"\",\"”\":\"\\\\\\\"\",\"„\":\"\\\\\\\"\",\"†\":\"+\",\"•\":\"*\",\"…\":\"...\",\"₠\":\"ecu\",\"₢\":\"cruzeiro\",\"₣\":\"french franc\",\"₤\":\"lira\",\"₥\":\"mill\",\"₦\":\"naira\",\"₧\":\"peseta\",\"₨\":\"rupee\",\"₩\":\"won\",\"₪\":\"new shequel\",\"₫\":\"dong\",\"€\":\"euro\",\"₭\":\"kip\",\"₮\":\"tugrik\",\"₯\":\"drachma\",\"₰\":\"penny\",\"₱\":\"peso\",\"₲\":\"guarani\",\"₳\":\"austral\",\"₴\":\"hryvnia\",\"₵\":\"cedi\",\"₸\":\"kazakhstani tenge\",\"₹\":\"indian rupee\",\"₺\":\"turkish lira\",\"₽\":\"russian ruble\",\"₿\":\"bitcoin\",\"℠\":\"sm\",\"™\":\"tm\",\"∂\":\"d\",\"∆\":\"delta\",\"∑\":\"sum\",\"∞\":\"infinity\",\"♥\":\"love\",\"元\":\"yuan\",\"円\":\"yen\",\"﷼\":\"rial\",\"ﻵ\":\"laa\",\"ﻷ\":\"laa\",\"ﻹ\":\"lai\",\"ﻻ\":\"la\"}')\n var locales = JSON.parse('{\"bg\":{\"Й\":\"Y\",\"Ц\":\"Ts\",\"Щ\":\"Sht\",\"Ъ\":\"A\",\"Ь\":\"Y\",\"й\":\"y\",\"ц\":\"ts\",\"щ\":\"sht\",\"ъ\":\"a\",\"ь\":\"y\"},\"de\":{\"Ä\":\"AE\",\"ä\":\"ae\",\"Ö\":\"OE\",\"ö\":\"oe\",\"Ü\":\"UE\",\"ü\":\"ue\",\"ß\":\"ss\",\"%\":\"prozent\",\"&\":\"und\",\"|\":\"oder\",\"∑\":\"summe\",\"∞\":\"unendlich\",\"♥\":\"liebe\"},\"es\":{\"%\":\"por ciento\",\"&\":\"y\",\"<\":\"menor que\",\">\":\"mayor que\",\"|\":\"o\",\"¢\":\"centavos\",\"£\":\"libras\",\"¤\":\"moneda\",\"₣\":\"francos\",\"∑\":\"suma\",\"∞\":\"infinito\",\"♥\":\"amor\"},\"fr\":{\"%\":\"pourcent\",\"&\":\"et\",\"<\":\"plus petit\",\">\":\"plus grand\",\"|\":\"ou\",\"¢\":\"centime\",\"£\":\"livre\",\"¤\":\"devise\",\"₣\":\"franc\",\"∑\":\"somme\",\"∞\":\"infini\",\"♥\":\"amour\"},\"pt\":{\"%\":\"porcento\",\"&\":\"e\",\"<\":\"menor\",\">\":\"maior\",\"|\":\"ou\",\"¢\":\"centavo\",\"∑\":\"soma\",\"£\":\"libra\",\"∞\":\"infinito\",\"♥\":\"amor\"},\"uk\":{\"И\":\"Y\",\"и\":\"y\",\"Й\":\"Y\",\"й\":\"y\",\"Ц\":\"Ts\",\"ц\":\"ts\",\"Х\":\"Kh\",\"х\":\"kh\",\"Щ\":\"Shch\",\"щ\":\"shch\",\"Г\":\"H\",\"г\":\"h\"},\"vi\":{\"Đ\":\"D\",\"đ\":\"d\"},\"da\":{\"Ø\":\"OE\",\"ø\":\"oe\",\"Å\":\"AA\",\"å\":\"aa\",\"%\":\"procent\",\"&\":\"og\",\"|\":\"eller\",\"$\":\"dollar\",\"<\":\"mindre end\",\">\":\"større end\"},\"nb\":{\"&\":\"og\",\"Å\":\"AA\",\"Æ\":\"AE\",\"Ø\":\"OE\",\"å\":\"aa\",\"æ\":\"ae\",\"ø\":\"oe\"},\"it\":{\"&\":\"e\"},\"nl\":{\"&\":\"en\"},\"sv\":{\"&\":\"och\",\"Å\":\"AA\",\"Ä\":\"AE\",\"Ö\":\"OE\",\"å\":\"aa\",\"ä\":\"ae\",\"ö\":\"oe\"}}')\n\n function replace (string, options) {\n if (typeof string !== 'string') {\n throw new Error('slugify: string argument expected')\n }\n\n options = (typeof options === 'string')\n ? {replacement: options}\n : options || {}\n\n var locale = locales[options.locale] || {}\n\n var replacement = options.replacement === undefined ? '-' : options.replacement\n\n var trim = options.trim === undefined ? true : options.trim\n\n var slug = string.normalize().split('')\n // replace characters based on charMap\n .reduce(function (result, ch) {\n var appendChar = locale[ch];\n if (appendChar === undefined) appendChar = charMap[ch];\n if (appendChar === undefined) appendChar = ch;\n if (appendChar === replacement) appendChar = ' ';\n return result + appendChar\n // remove not allowed characters\n .replace(options.remove || /[^\\w\\s$*_+~.()'\"!\\-:@]+/g, '')\n }, '');\n\n if (options.strict) {\n slug = slug.replace(/[^A-Za-z0-9\\s]/g, '');\n }\n\n if (trim) {\n slug = slug.trim()\n }\n\n // Replace spaces with replacement character, treating multiple consecutive\n // spaces as a single space.\n slug = slug.replace(/\\s+/g, replacement);\n\n if (options.lower) {\n slug = slug.toLowerCase()\n }\n\n return slug\n }\n\n replace.extend = function (customMap) {\n Object.assign(charMap, customMap)\n }\n\n return replace\n}))\n","import React from \"react\"\nimport Constants from \"expo-constants\";\nimport Bugsnag from \"@bugsnag/js\";\nimport BugsnagPluginReact from \"@bugsnag/plugin-react\";\n\nexport const initBugsnag = () => {\n return (!__DEV__) ?\n Bugsnag.start({\n apiKey: Constants.expoConfig.extra.bugsnag.apiKey,\n plugins: [new BugsnagPluginReact()],\n releaseStage: Constants.expoConfig.extra.releaseStage,\n enabledReleaseStages: ['production', 'staging', 'integration'],\n appVersion: Constants.expoConfig.version\n }) : null\n}\nexport const initErrorBoundary = () => {\n return Bugsnag.getPlugin('react').createErrorBoundary(React)\n}\n\nexport const notifyBugsnag = (error) => {\n if ((!__DEV__))\n Bugsnag.notify(error)\n}\n\nexport const setBugsnagUser = (user) => {\n if ((!__DEV__))\n Bugsnag.setUser(user?.id, user?.email, user?.display_name)\n}","module.exports = require('@bugsnag/browser')\n","(function(f){if(typeof exports===\"object\"&&typeof module!==\"undefined\"){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.Bugsnag = f()}})(function(){var define,module,exports;\nvar _$breadcrumbTypes_8 = ['navigation', 'request', 'process', 'log', 'user', 'state', 'error', 'manual'];\n\n// Array#reduce\nvar _$reduce_17 = function (arr, fn, accum) {\n var val = accum;\n\n for (var i = 0, len = arr.length; i < len; i++) {\n val = fn(val, arr[i], i, arr);\n }\n\n return val;\n};\n\n/* removed: var _$reduce_17 = require('./reduce'); */; // Array#filter\n\n\nvar _$filter_12 = function (arr, fn) {\n return _$reduce_17(arr, function (accum, item, i, arr) {\n return !fn(item, i, arr) ? accum : accum.concat(item);\n }, []);\n};\n\n/* removed: var _$reduce_17 = require('./reduce'); */; // Array#includes\n\n\nvar _$includes_13 = function (arr, x) {\n return _$reduce_17(arr, function (accum, item, i, arr) {\n return accum === true || item === x;\n }, false);\n};\n\n// Array#isArray\nvar _$isArray_14 = function (obj) {\n return Object.prototype.toString.call(obj) === '[object Array]';\n};\n\n/* eslint-disable-next-line no-prototype-builtins */\nvar _hasDontEnumBug = !{\n toString: null\n}.propertyIsEnumerable('toString');\n\nvar _dontEnums = ['toString', 'toLocaleString', 'valueOf', 'hasOwnProperty', 'isPrototypeOf', 'propertyIsEnumerable', 'constructor']; // Object#keys\n\nvar _$keys_15 = function (obj) {\n // stripped down version of\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/Keys\n var result = [];\n var prop;\n\n for (prop in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, prop)) result.push(prop);\n }\n\n if (!_hasDontEnumBug) return result;\n\n for (var i = 0, len = _dontEnums.length; i < len; i++) {\n if (Object.prototype.hasOwnProperty.call(obj, _dontEnums[i])) result.push(_dontEnums[i]);\n }\n\n return result;\n};\n\nvar _$intRange_24 = function (min, max) {\n if (min === void 0) {\n min = 1;\n }\n\n if (max === void 0) {\n max = Infinity;\n }\n\n return function (value) {\n return typeof value === 'number' && parseInt('' + value, 10) === value && value >= min && value <= max;\n };\n};\n\n/* removed: var _$filter_12 = require('../es-utils/filter'); */;\n\n/* removed: var _$isArray_14 = require('../es-utils/is-array'); */;\n\nvar _$listOfFunctions_25 = function (value) {\n return typeof value === 'function' || _$isArray_14(value) && _$filter_12(value, function (f) {\n return typeof f === 'function';\n }).length === value.length;\n};\n\nvar _$stringWithLength_26 = function (value) {\n return typeof value === 'string' && !!value.length;\n};\n\nvar _$config_5 = {};\n/* removed: var _$filter_12 = require('./lib/es-utils/filter'); */;\n\n/* removed: var _$reduce_17 = require('./lib/es-utils/reduce'); */;\n\n/* removed: var _$keys_15 = require('./lib/es-utils/keys'); */;\n\n/* removed: var _$isArray_14 = require('./lib/es-utils/is-array'); */;\n\n/* removed: var _$includes_13 = require('./lib/es-utils/includes'); */;\n\n/* removed: var _$intRange_24 = require('./lib/validators/int-range'); */;\n\n/* removed: var _$stringWithLength_26 = require('./lib/validators/string-with-length'); */;\n\n/* removed: var _$listOfFunctions_25 = require('./lib/validators/list-of-functions'); */;\n\n/* removed: var _$breadcrumbTypes_8 = require('./lib/breadcrumb-types'); */;\n\nvar defaultErrorTypes = function () {\n return {\n unhandledExceptions: true,\n unhandledRejections: true\n };\n};\n\n_$config_5.schema = {\n apiKey: {\n defaultValue: function () {\n return null;\n },\n message: 'is required',\n validate: _$stringWithLength_26\n },\n appVersion: {\n defaultValue: function () {\n return undefined;\n },\n message: 'should be a string',\n validate: function (value) {\n return value === undefined || _$stringWithLength_26(value);\n }\n },\n appType: {\n defaultValue: function () {\n return undefined;\n },\n message: 'should be a string',\n validate: function (value) {\n return value === undefined || _$stringWithLength_26(value);\n }\n },\n autoDetectErrors: {\n defaultValue: function () {\n return true;\n },\n message: 'should be true|false',\n validate: function (value) {\n return value === true || value === false;\n }\n },\n enabledErrorTypes: {\n defaultValue: function () {\n return defaultErrorTypes();\n },\n message: 'should be an object containing the flags { unhandledExceptions:true|false, unhandledRejections:true|false }',\n allowPartialObject: true,\n validate: function (value) {\n // ensure we have an object\n if (typeof value !== 'object' || !value) return false;\n var providedKeys = _$keys_15(value);\n var defaultKeys = _$keys_15(defaultErrorTypes()); // ensure it only has a subset of the allowed keys\n\n if (_$filter_12(providedKeys, function (k) {\n return _$includes_13(defaultKeys, k);\n }).length < providedKeys.length) return false; // ensure all of the values are boolean\n\n if (_$filter_12(_$keys_15(value), function (k) {\n return typeof value[k] !== 'boolean';\n }).length > 0) return false;\n return true;\n }\n },\n onError: {\n defaultValue: function () {\n return [];\n },\n message: 'should be a function or array of functions',\n validate: _$listOfFunctions_25\n },\n onSession: {\n defaultValue: function () {\n return [];\n },\n message: 'should be a function or array of functions',\n validate: _$listOfFunctions_25\n },\n onBreadcrumb: {\n defaultValue: function () {\n return [];\n },\n message: 'should be a function or array of functions',\n validate: _$listOfFunctions_25\n },\n endpoints: {\n defaultValue: function () {\n return {\n notify: 'https://notify.bugsnag.com',\n sessions: 'https://sessions.bugsnag.com'\n };\n },\n message: 'should be an object containing endpoint URLs { notify, sessions }',\n validate: function (val) {\n return (// first, ensure it's an object\n val && typeof val === 'object' && // notify and sessions must always be set\n _$stringWithLength_26(val.notify) && _$stringWithLength_26(val.sessions) && // ensure no keys other than notify/session are set on endpoints object\n _$filter_12(_$keys_15(val), function (k) {\n return !_$includes_13(['notify', 'sessions'], k);\n }).length === 0\n );\n }\n },\n autoTrackSessions: {\n defaultValue: function (val) {\n return true;\n },\n message: 'should be true|false',\n validate: function (val) {\n return val === true || val === false;\n }\n },\n enabledReleaseStages: {\n defaultValue: function () {\n return null;\n },\n message: 'should be an array of strings',\n validate: function (value) {\n return value === null || _$isArray_14(value) && _$filter_12(value, function (f) {\n return typeof f === 'string';\n }).length === value.length;\n }\n },\n releaseStage: {\n defaultValue: function () {\n return 'production';\n },\n message: 'should be a string',\n validate: function (value) {\n return typeof value === 'string' && value.length;\n }\n },\n maxBreadcrumbs: {\n defaultValue: function () {\n return 25;\n },\n message: 'should be a number ≤100',\n validate: function (value) {\n return _$intRange_24(0, 100)(value);\n }\n },\n enabledBreadcrumbTypes: {\n defaultValue: function () {\n return _$breadcrumbTypes_8;\n },\n message: \"should be null or a list of available breadcrumb types (\" + _$breadcrumbTypes_8.join(',') + \")\",\n validate: function (value) {\n return value === null || _$isArray_14(value) && _$reduce_17(value, function (accum, maybeType) {\n if (accum === false) return accum;\n return _$includes_13(_$breadcrumbTypes_8, maybeType);\n }, true);\n }\n },\n context: {\n defaultValue: function () {\n return undefined;\n },\n message: 'should be a string',\n validate: function (value) {\n return value === undefined || typeof value === 'string';\n }\n },\n user: {\n defaultValue: function () {\n return {};\n },\n message: 'should be an object with { id, email, name } properties',\n validate: function (value) {\n return value === null || value && _$reduce_17(_$keys_15(value), function (accum, key) {\n return accum && _$includes_13(['id', 'email', 'name'], key);\n }, true);\n }\n },\n metadata: {\n defaultValue: function () {\n return {};\n },\n message: 'should be an object',\n validate: function (value) {\n return typeof value === 'object' && value !== null;\n }\n },\n logger: {\n defaultValue: function () {\n return undefined;\n },\n message: 'should be null or an object with methods { debug, info, warn, error }',\n validate: function (value) {\n return !value || value && _$reduce_17(['debug', 'info', 'warn', 'error'], function (accum, method) {\n return accum && typeof value[method] === 'function';\n }, true);\n }\n },\n redactedKeys: {\n defaultValue: function () {\n return ['password'];\n },\n message: 'should be an array of strings|regexes',\n validate: function (value) {\n return _$isArray_14(value) && value.length === _$filter_12(value, function (s) {\n return typeof s === 'string' || s && typeof s.test === 'function';\n }).length;\n }\n },\n plugins: {\n defaultValue: function () {\n return [];\n },\n message: 'should be an array of plugin objects',\n validate: function (value) {\n return _$isArray_14(value) && value.length === _$filter_12(value, function (p) {\n return p && typeof p === 'object' && typeof p.load === 'function';\n }).length;\n }\n },\n featureFlags: {\n defaultValue: function () {\n return [];\n },\n message: 'should be an array of objects that have a \"name\" property',\n validate: function (value) {\n return _$isArray_14(value) && value.length === _$filter_12(value, function (feature) {\n return feature && typeof feature === 'object' && typeof feature.name === 'string';\n }).length;\n }\n }\n};\n\n// extends helper from babel\n// https://github.com/babel/babel/blob/916429b516e6466fd06588ee820e40e025d7f3a3/packages/babel-helpers/src/helpers.js#L377-L393\nvar _$assign_11 = function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n};\n\n/* removed: var _$reduce_17 = require('./reduce'); */; // Array#map\n\n\nvar _$map_16 = function (arr, fn) {\n return _$reduce_17(arr, function (accum, item, i, arr) {\n return accum.concat(fn(item, i, arr));\n }, []);\n};\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nvar schema = _$config_5.schema;\n\n/* removed: var _$map_16 = require('@bugsnag/core/lib/es-utils/map'); */;\n\n/* removed: var _$assign_11 = require('@bugsnag/core/lib/es-utils/assign'); */;\n\nvar _$config_1 = {\n releaseStage: _$assign_11({}, schema.releaseStage, {\n defaultValue: function () {\n if (/^localhost(:\\d+)?$/.test(window.location.host)) return 'development';\n return 'production';\n }\n }),\n appType: _extends({}, schema.appType, {\n defaultValue: function () {\n return 'browser';\n }\n }),\n logger: _$assign_11({}, schema.logger, {\n defaultValue: function () {\n return (// set logger based on browser capability\n typeof console !== 'undefined' && typeof console.debug === 'function' ? getPrefixedConsole() : undefined\n );\n }\n })\n};\n\nvar getPrefixedConsole = function () {\n var logger = {};\n var consoleLog = console.log;\n _$map_16(['debug', 'info', 'warn', 'error'], function (method) {\n var consoleMethod = console[method];\n logger[method] = typeof consoleMethod === 'function' ? consoleMethod.bind(console, '[bugsnag]') : consoleLog.bind(console, '[bugsnag]');\n });\n return logger;\n};\n\nvar Breadcrumb = /*#__PURE__*/function () {\n function Breadcrumb(message, metadata, type, timestamp) {\n if (timestamp === void 0) {\n timestamp = new Date();\n }\n\n this.type = type;\n this.message = message;\n this.metadata = metadata;\n this.timestamp = timestamp;\n }\n\n var _proto = Breadcrumb.prototype;\n\n _proto.toJSON = function toJSON() {\n return {\n type: this.type,\n name: this.message,\n timestamp: this.timestamp,\n metaData: this.metadata\n };\n };\n\n return Breadcrumb;\n}();\n\nvar _$Breadcrumb_3 = Breadcrumb;\n\nvar _$stackframe_34 = {};\n(function (root, factory) {\n 'use strict'; // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.\n\n /* istanbul ignore next */\n\n if (typeof define === 'function' && define.amd) {\n define('stackframe', [], factory);\n } else if (typeof _$stackframe_34 === 'object') {\n _$stackframe_34 = factory();\n } else {\n root.StackFrame = factory();\n }\n})(this, function () {\n 'use strict';\n\n function _isNumber(n) {\n return !isNaN(parseFloat(n)) && isFinite(n);\n }\n\n function _capitalize(str) {\n return str.charAt(0).toUpperCase() + str.substring(1);\n }\n\n function _getter(p) {\n return function () {\n return this[p];\n };\n }\n\n var booleanProps = ['isConstructor', 'isEval', 'isNative', 'isToplevel'];\n var numericProps = ['columnNumber', 'lineNumber'];\n var stringProps = ['fileName', 'functionName', 'source'];\n var arrayProps = ['args'];\n var props = booleanProps.concat(numericProps, stringProps, arrayProps);\n\n function StackFrame(obj) {\n if (obj instanceof Object) {\n for (var i = 0; i < props.length; i++) {\n if (obj.hasOwnProperty(props[i]) && obj[props[i]] !== undefined) {\n this['set' + _capitalize(props[i])](obj[props[i]]);\n }\n }\n }\n }\n\n StackFrame.prototype = {\n getArgs: function () {\n return this.args;\n },\n setArgs: function (v) {\n if (Object.prototype.toString.call(v) !== '[object Array]') {\n throw new TypeError('Args must be an Array');\n }\n\n this.args = v;\n },\n getEvalOrigin: function () {\n return this.evalOrigin;\n },\n setEvalOrigin: function (v) {\n if (v instanceof StackFrame) {\n this.evalOrigin = v;\n } else if (v instanceof Object) {\n this.evalOrigin = new StackFrame(v);\n } else {\n throw new TypeError('Eval Origin must be an Object or StackFrame');\n }\n },\n toString: function () {\n var functionName = this.getFunctionName() || '{anonymous}';\n var args = '(' + (this.getArgs() || []).join(',') + ')';\n var fileName = this.getFileName() ? '@' + this.getFileName() : '';\n var lineNumber = _isNumber(this.getLineNumber()) ? ':' + this.getLineNumber() : '';\n var columnNumber = _isNumber(this.getColumnNumber()) ? ':' + this.getColumnNumber() : '';\n return functionName + args + fileName + lineNumber + columnNumber;\n }\n };\n\n for (var i = 0; i < booleanProps.length; i++) {\n StackFrame.prototype['get' + _capitalize(booleanProps[i])] = _getter(booleanProps[i]);\n\n StackFrame.prototype['set' + _capitalize(booleanProps[i])] = function (p) {\n return function (v) {\n this[p] = Boolean(v);\n };\n }(booleanProps[i]);\n }\n\n for (var j = 0; j < numericProps.length; j++) {\n StackFrame.prototype['get' + _capitalize(numericProps[j])] = _getter(numericProps[j]);\n\n StackFrame.prototype['set' + _capitalize(numericProps[j])] = function (p) {\n return function (v) {\n if (!_isNumber(v)) {\n throw new TypeError(p + ' must be a Number');\n }\n\n this[p] = Number(v);\n };\n }(numericProps[j]);\n }\n\n for (var k = 0; k < stringProps.length; k++) {\n StackFrame.prototype['get' + _capitalize(stringProps[k])] = _getter(stringProps[k]);\n\n StackFrame.prototype['set' + _capitalize(stringProps[k])] = function (p) {\n return function (v) {\n this[p] = String(v);\n };\n }(stringProps[k]);\n }\n\n return StackFrame;\n});\n\nvar _$errorStackParser_31 = {};\n(function (root, factory) {\n 'use strict'; // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.\n\n /* istanbul ignore next */\n\n if (typeof define === 'function' && define.amd) {\n define('error-stack-parser', ['stackframe'], factory);\n } else if (typeof _$errorStackParser_31 === 'object') {\n _$errorStackParser_31 = factory(_$stackframe_34);\n } else {\n root.ErrorStackParser = factory(root.StackFrame);\n }\n})(this, function ErrorStackParser(StackFrame) {\n 'use strict';\n\n var FIREFOX_SAFARI_STACK_REGEXP = /(^|@)\\S+\\:\\d+/;\n var CHROME_IE_STACK_REGEXP = /^\\s*at .*(\\S+\\:\\d+|\\(native\\))/m;\n var SAFARI_NATIVE_CODE_REGEXP = /^(eval@)?(\\[native code\\])?$/;\n return {\n /**\n * Given an Error object, extract the most information from it.\n *\n * @param {Error} error object\n * @return {Array} of StackFrames\n */\n parse: function ErrorStackParser$$parse(error) {\n if (typeof error.stacktrace !== 'undefined' || typeof error['opera#sourceloc'] !== 'undefined') {\n return this.parseOpera(error);\n } else if (error.stack && error.stack.match(CHROME_IE_STACK_REGEXP)) {\n return this.parseV8OrIE(error);\n } else if (error.stack) {\n return this.parseFFOrSafari(error);\n } else {\n throw new Error('Cannot parse given Error object');\n }\n },\n // Separate line and column numbers from a string of the form: (URI:Line:Column)\n extractLocation: function ErrorStackParser$$extractLocation(urlLike) {\n // Fail-fast but return locations like \"(native)\"\n if (urlLike.indexOf(':') === -1) {\n return [urlLike];\n }\n\n var regExp = /(.+?)(?:\\:(\\d+))?(?:\\:(\\d+))?$/;\n var parts = regExp.exec(urlLike.replace(/[\\(\\)]/g, ''));\n return [parts[1], parts[2] || undefined, parts[3] || undefined];\n },\n parseV8OrIE: function ErrorStackParser$$parseV8OrIE(error) {\n var filtered = error.stack.split('\\n').filter(function (line) {\n return !!line.match(CHROME_IE_STACK_REGEXP);\n }, this);\n return filtered.map(function (line) {\n if (line.indexOf('(eval ') > -1) {\n // Throw away eval information until we implement stacktrace.js/stackframe#8\n line = line.replace(/eval code/g, 'eval').replace(/(\\(eval at [^\\()]*)|(\\)\\,.*$)/g, '');\n }\n\n var sanitizedLine = line.replace(/^\\s+/, '').replace(/\\(eval code/g, '('); // capture and preseve the parenthesized location \"(/foo/my bar.js:12:87)\" in\n // case it has spaces in it, as the string is split on \\s+ later on\n\n var location = sanitizedLine.match(/ (\\((.+):(\\d+):(\\d+)\\)$)/); // remove the parenthesized location from the line, if it was matched\n\n sanitizedLine = location ? sanitizedLine.replace(location[0], '') : sanitizedLine;\n var tokens = sanitizedLine.split(/\\s+/).slice(1); // if a location was matched, pass it to extractLocation() otherwise pop the last token\n\n var locationParts = this.extractLocation(location ? location[1] : tokens.pop());\n var functionName = tokens.join(' ') || undefined;\n var fileName = ['eval', ''].indexOf(locationParts[0]) > -1 ? undefined : locationParts[0];\n return new StackFrame({\n functionName: functionName,\n fileName: fileName,\n lineNumber: locationParts[1],\n columnNumber: locationParts[2],\n source: line\n });\n }, this);\n },\n parseFFOrSafari: function ErrorStackParser$$parseFFOrSafari(error) {\n var filtered = error.stack.split('\\n').filter(function (line) {\n return !line.match(SAFARI_NATIVE_CODE_REGEXP);\n }, this);\n return filtered.map(function (line) {\n // Throw away eval information until we implement stacktrace.js/stackframe#8\n if (line.indexOf(' > eval') > -1) {\n line = line.replace(/ line (\\d+)(?: > eval line \\d+)* > eval\\:\\d+\\:\\d+/g, ':$1');\n }\n\n if (line.indexOf('@') === -1 && line.indexOf(':') === -1) {\n // Safari eval frames only have function names and nothing else\n return new StackFrame({\n functionName: line\n });\n } else {\n var functionNameRegex = /((.*\".+\"[^@]*)?[^@]*)(?:@)/;\n var matches = line.match(functionNameRegex);\n var functionName = matches && matches[1] ? matches[1] : undefined;\n var locationParts = this.extractLocation(line.replace(functionNameRegex, ''));\n return new StackFrame({\n functionName: functionName,\n fileName: locationParts[0],\n lineNumber: locationParts[1],\n columnNumber: locationParts[2],\n source: line\n });\n }\n }, this);\n },\n parseOpera: function ErrorStackParser$$parseOpera(e) {\n if (!e.stacktrace || e.message.indexOf('\\n') > -1 && e.message.split('\\n').length > e.stacktrace.split('\\n').length) {\n return this.parseOpera9(e);\n } else if (!e.stack) {\n return this.parseOpera10(e);\n } else {\n return this.parseOpera11(e);\n }\n },\n parseOpera9: function ErrorStackParser$$parseOpera9(e) {\n var lineRE = /Line (\\d+).*script (?:in )?(\\S+)/i;\n var lines = e.message.split('\\n');\n var result = [];\n\n for (var i = 2, len = lines.length; i < len; i += 2) {\n var match = lineRE.exec(lines[i]);\n\n if (match) {\n result.push(new StackFrame({\n fileName: match[2],\n lineNumber: match[1],\n source: lines[i]\n }));\n }\n }\n\n return result;\n },\n parseOpera10: function ErrorStackParser$$parseOpera10(e) {\n var lineRE = /Line (\\d+).*script (?:in )?(\\S+)(?:: In function (\\S+))?$/i;\n var lines = e.stacktrace.split('\\n');\n var result = [];\n\n for (var i = 0, len = lines.length; i < len; i += 2) {\n var match = lineRE.exec(lines[i]);\n\n if (match) {\n result.push(new StackFrame({\n functionName: match[3] || undefined,\n fileName: match[2],\n lineNumber: match[1],\n source: lines[i]\n }));\n }\n }\n\n return result;\n },\n // Opera 10.65+ Error.stack very similar to FF/Safari\n parseOpera11: function ErrorStackParser$$parseOpera11(error) {\n var filtered = error.stack.split('\\n').filter(function (line) {\n return !!line.match(FIREFOX_SAFARI_STACK_REGEXP) && !line.match(/^Error created at/);\n }, this);\n return filtered.map(function (line) {\n var tokens = line.split('@');\n var locationParts = this.extractLocation(tokens.pop());\n var functionCall = tokens.shift() || '';\n var functionName = functionCall.replace(//, '$2').replace(/\\([^\\)]*\\)/g, '') || undefined;\n var argsRaw;\n\n if (functionCall.match(/\\(([^\\)]*)\\)/)) {\n argsRaw = functionCall.replace(/^[^\\(]+\\(([^\\)]*)\\)$/, '$1');\n }\n\n var args = argsRaw === undefined || argsRaw === '[arguments not available]' ? undefined : argsRaw.split(',');\n return new StackFrame({\n functionName: functionName,\n args: args,\n fileName: locationParts[0],\n lineNumber: locationParts[1],\n columnNumber: locationParts[2],\n source: line\n });\n }, this);\n }\n };\n});\n\nvar _$errorStackParser_10 = _$errorStackParser_31;\n\nvar _$safeJsonStringify_30 = function (data, replacer, space, opts) {\n var redactedKeys = opts && opts.redactedKeys ? opts.redactedKeys : [];\n var redactedPaths = opts && opts.redactedPaths ? opts.redactedPaths : [];\n return JSON.stringify(prepareObjForSerialization(data, redactedKeys, redactedPaths), replacer, space);\n};\n\nvar MAX_DEPTH = 20;\nvar MAX_EDGES = 25000;\nvar MIN_PRESERVED_DEPTH = 8;\nvar REPLACEMENT_NODE = '...';\n\nfunction isError(o) {\n return o instanceof Error || /^\\[object (Error|(Dom)?Exception)\\]$/.test(Object.prototype.toString.call(o));\n}\n\nfunction throwsMessage(err) {\n return '[Throws: ' + (err ? err.message : '?') + ']';\n}\n\nfunction find(haystack, needle) {\n for (var i = 0, len = haystack.length; i < len; i++) {\n if (haystack[i] === needle) return true;\n }\n\n return false;\n} // returns true if the string `path` starts with any of the provided `paths`\n\n\nfunction isDescendent(paths, path) {\n for (var i = 0, len = paths.length; i < len; i++) {\n if (path.indexOf(paths[i]) === 0) return true;\n }\n\n return false;\n}\n\nfunction shouldRedact(patterns, key) {\n for (var i = 0, len = patterns.length; i < len; i++) {\n if (typeof patterns[i] === 'string' && patterns[i].toLowerCase() === key.toLowerCase()) return true;\n if (patterns[i] && typeof patterns[i].test === 'function' && patterns[i].test(key)) return true;\n }\n\n return false;\n}\n\nfunction __isArray_30(obj) {\n return Object.prototype.toString.call(obj) === '[object Array]';\n}\n\nfunction safelyGetProp(obj, prop) {\n try {\n return obj[prop];\n } catch (err) {\n return throwsMessage(err);\n }\n}\n\nfunction prepareObjForSerialization(obj, redactedKeys, redactedPaths) {\n var seen = []; // store references to objects we have seen before\n\n var edges = 0;\n\n function visit(obj, path) {\n function edgesExceeded() {\n return path.length > MIN_PRESERVED_DEPTH && edges > MAX_EDGES;\n }\n\n edges++;\n if (path.length > MAX_DEPTH) return REPLACEMENT_NODE;\n if (edgesExceeded()) return REPLACEMENT_NODE;\n if (obj === null || typeof obj !== 'object') return obj;\n if (find(seen, obj)) return '[Circular]';\n seen.push(obj);\n\n if (typeof obj.toJSON === 'function') {\n try {\n // we're not going to count this as an edge because it\n // replaces the value of the currently visited object\n edges--;\n var fResult = visit(obj.toJSON(), path);\n seen.pop();\n return fResult;\n } catch (err) {\n return throwsMessage(err);\n }\n }\n\n var er = isError(obj);\n\n if (er) {\n edges--;\n var eResult = visit({\n name: obj.name,\n message: obj.message\n }, path);\n seen.pop();\n return eResult;\n }\n\n if (__isArray_30(obj)) {\n var aResult = [];\n\n for (var i = 0, len = obj.length; i < len; i++) {\n if (edgesExceeded()) {\n aResult.push(REPLACEMENT_NODE);\n break;\n }\n\n aResult.push(visit(obj[i], path.concat('[]')));\n }\n\n seen.pop();\n return aResult;\n }\n\n var result = {};\n\n try {\n for (var prop in obj) {\n if (!Object.prototype.hasOwnProperty.call(obj, prop)) continue;\n\n if (isDescendent(redactedPaths, path.join('.')) && shouldRedact(redactedKeys, prop)) {\n result[prop] = '[REDACTED]';\n continue;\n }\n\n if (edgesExceeded()) {\n result[prop] = REPLACEMENT_NODE;\n break;\n }\n\n result[prop] = visit(safelyGetProp(obj, prop), path.concat(prop));\n }\n } catch (e) {}\n\n seen.pop();\n return result;\n }\n\n return visit(obj, []);\n}\n\n/* removed: var _$map_16 = require('./es-utils/map'); */;\n\n/* removed: var _$filter_12 = require('./es-utils/filter'); */;\n\n/* removed: var _$isArray_14 = require('./es-utils/is-array'); */;\n\n/* removed: var _$safeJsonStringify_30 = require('@bugsnag/safe-json-stringify'); */;\n\nfunction add(existingFeatures, existingFeatureKeys, name, variant) {\n if (typeof name !== 'string') {\n return;\n }\n\n if (variant === undefined) {\n variant = null;\n } else if (variant !== null && typeof variant !== 'string') {\n variant = _$safeJsonStringify_30(variant);\n }\n\n var existingIndex = existingFeatureKeys[name];\n\n if (typeof existingIndex === 'number') {\n existingFeatures[existingIndex] = {\n name: name,\n variant: variant\n };\n return;\n }\n\n existingFeatures.push({\n name: name,\n variant: variant\n });\n existingFeatureKeys[name] = existingFeatures.length - 1;\n}\n\nfunction merge(existingFeatures, newFeatures, existingFeatureKeys) {\n if (!_$isArray_14(newFeatures)) {\n return;\n }\n\n for (var i = 0; i < newFeatures.length; ++i) {\n var feature = newFeatures[i];\n\n if (feature === null || typeof feature !== 'object') {\n continue;\n } // 'add' will handle if 'name' doesn't exist & 'variant' is optional\n\n\n add(existingFeatures, existingFeatureKeys, feature.name, feature.variant);\n }\n\n return existingFeatures;\n} // convert feature flags from a map of 'name -> variant' into the format required\n// by the Bugsnag Event API:\n// [{ featureFlag: 'name', variant: 'variant' }, { featureFlag: 'name 2' }]\n\n\nfunction toEventApi(featureFlags) {\n return _$map_16(_$filter_12(featureFlags, Boolean), function (_ref) {\n var name = _ref.name,\n variant = _ref.variant;\n var flag = {\n featureFlag: name\n }; // don't add a 'variant' property unless there's actually a value\n\n if (typeof variant === 'string') {\n flag.variant = variant;\n }\n\n return flag;\n });\n}\n\nfunction clear(features, featuresIndex, name) {\n var existingIndex = featuresIndex[name];\n\n if (typeof existingIndex === 'number') {\n features[existingIndex] = null;\n delete featuresIndex[name];\n }\n}\n\nvar _$featureFlagDelegate_18 = {\n add: add,\n clear: clear,\n merge: merge,\n toEventApi: toEventApi\n};\n\n// Given `err` which may be an error, does it have a stack property which is a string?\nvar _$hasStack_19 = function (err) {\n return !!err && (!!err.stack || !!err.stacktrace || !!err['opera#sourceloc']) && typeof (err.stack || err.stacktrace || err['opera#sourceloc']) === 'string' && err.stack !== err.name + \": \" + err.message;\n};\n\n/**\n * Expose `isError`.\n */\nvar _$isError_32 = __isError_32;\n/**\n * Test whether `value` is error object.\n *\n * @param {*} value\n * @returns {boolean}\n */\n\nfunction __isError_32(value) {\n switch (Object.prototype.toString.call(value)) {\n case '[object Error]':\n return true;\n\n case '[object Exception]':\n return true;\n\n case '[object DOMException]':\n return true;\n\n default:\n return value instanceof Error;\n }\n}\n\nvar _$iserror_20 = _$isError_32;\n\n/* removed: var _$assign_11 = require('./es-utils/assign'); */;\n\nvar __add_22 = function (state, section, keyOrObj, maybeVal) {\n var _updates;\n\n if (!section) return;\n var updates; // addMetadata(\"section\", null) -> clears section\n\n if (keyOrObj === null) return __clear_22(state, section); // normalise the two supported input types into object form\n\n if (typeof keyOrObj === 'object') updates = keyOrObj;\n if (typeof keyOrObj === 'string') updates = (_updates = {}, _updates[keyOrObj] = maybeVal, _updates); // exit if we don't have an updates object at this point\n\n if (!updates) return; // ensure a section with this name exists\n\n if (!state[section]) state[section] = {}; // merge the updates with the existing section\n\n state[section] = _$assign_11({}, state[section], updates);\n};\n\nvar get = function (state, section, key) {\n if (typeof section !== 'string') return undefined;\n\n if (!key) {\n return state[section];\n }\n\n if (state[section]) {\n return state[section][key];\n }\n\n return undefined;\n};\n\nvar __clear_22 = function (state, section, key) {\n if (typeof section !== 'string') return; // clear an entire section\n\n if (!key) {\n delete state[section];\n return;\n } // clear a single value from a section\n\n\n if (state[section]) {\n delete state[section][key];\n }\n};\n\nvar _$metadataDelegate_22 = {\n add: __add_22,\n get: get,\n clear: __clear_22\n};\n\nvar _$stackGenerator_33 = {};\n(function (root, factory) {\n 'use strict'; // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, Rhino, and browsers.\n\n /* istanbul ignore next */\n\n if (typeof define === 'function' && define.amd) {\n define('stack-generator', ['stackframe'], factory);\n } else if (typeof _$stackGenerator_33 === 'object') {\n _$stackGenerator_33 = factory(_$stackframe_34);\n } else {\n root.StackGenerator = factory(root.StackFrame);\n }\n})(this, function (StackFrame) {\n return {\n backtrace: function StackGenerator$$backtrace(opts) {\n var stack = [];\n var maxStackSize = 10;\n\n if (typeof opts === 'object' && typeof opts.maxStackSize === 'number') {\n maxStackSize = opts.maxStackSize;\n }\n\n var curr = arguments.callee;\n\n while (curr && stack.length < maxStackSize && curr['arguments']) {\n // Allow V8 optimizations\n var args = new Array(curr['arguments'].length);\n\n for (var i = 0; i < args.length; ++i) {\n args[i] = curr['arguments'][i];\n }\n\n if (/function(?:\\s+([\\w$]+))+\\s*\\(/.test(curr.toString())) {\n stack.push(new StackFrame({\n functionName: RegExp.$1 || undefined,\n args: args\n }));\n } else {\n stack.push(new StackFrame({\n args: args\n }));\n }\n\n try {\n curr = curr.caller;\n } catch (e) {\n break;\n }\n }\n\n return stack;\n }\n };\n});\n\n/* removed: var _$errorStackParser_10 = require('./lib/error-stack-parser'); */;\n\n/* removed: var _$stackGenerator_33 = require('stack-generator'); */;\n\n/* removed: var _$hasStack_19 = require('./lib/has-stack'); */;\n\n/* removed: var _$map_16 = require('./lib/es-utils/map'); */;\n\n/* removed: var _$reduce_17 = require('./lib/es-utils/reduce'); */;\n\n/* removed: var _$filter_12 = require('./lib/es-utils/filter'); */;\n\n/* removed: var _$assign_11 = require('./lib/es-utils/assign'); */;\n\n/* removed: var _$metadataDelegate_22 = require('./lib/metadata-delegate'); */;\n\n/* removed: var _$featureFlagDelegate_18 = require('./lib/feature-flag-delegate'); */;\n\n/* removed: var _$iserror_20 = require('./lib/iserror'); */;\n\nvar Event = /*#__PURE__*/function () {\n function Event(errorClass, errorMessage, stacktrace, handledState, originalError) {\n if (stacktrace === void 0) {\n stacktrace = [];\n }\n\n if (handledState === void 0) {\n handledState = defaultHandledState();\n }\n\n this.apiKey = undefined;\n this.context = undefined;\n this.groupingHash = undefined;\n this.originalError = originalError;\n this._handledState = handledState;\n this.severity = this._handledState.severity;\n this.unhandled = this._handledState.unhandled;\n this.app = {};\n this.device = {};\n this.request = {};\n this.breadcrumbs = [];\n this.threads = [];\n this._metadata = {};\n this._features = [];\n this._featuresIndex = {};\n this._user = {};\n this._session = undefined;\n this.errors = [createBugsnagError(errorClass, errorMessage, Event.__type, stacktrace)]; // Flags.\n // Note these are not initialised unless they are used\n // to save unnecessary bytes in the browser bundle\n\n /* this.attemptImmediateDelivery, default: true */\n }\n\n var _proto = Event.prototype;\n\n _proto.addMetadata = function addMetadata(section, keyOrObj, maybeVal) {\n return _$metadataDelegate_22.add(this._metadata, section, keyOrObj, maybeVal);\n };\n\n _proto.getMetadata = function getMetadata(section, key) {\n return _$metadataDelegate_22.get(this._metadata, section, key);\n };\n\n _proto.clearMetadata = function clearMetadata(section, key) {\n return _$metadataDelegate_22.clear(this._metadata, section, key);\n };\n\n _proto.addFeatureFlag = function addFeatureFlag(name, variant) {\n if (variant === void 0) {\n variant = null;\n }\n\n _$featureFlagDelegate_18.add(this._features, this._featuresIndex, name, variant);\n };\n\n _proto.addFeatureFlags = function addFeatureFlags(featureFlags) {\n _$featureFlagDelegate_18.merge(this._features, featureFlags, this._featuresIndex);\n };\n\n _proto.getFeatureFlags = function getFeatureFlags() {\n return _$featureFlagDelegate_18.toEventApi(this._features);\n };\n\n _proto.clearFeatureFlag = function clearFeatureFlag(name) {\n _$featureFlagDelegate_18.clear(this._features, this._featuresIndex, name);\n };\n\n _proto.clearFeatureFlags = function clearFeatureFlags() {\n this._features = [];\n this._featuresIndex = {};\n };\n\n _proto.getUser = function getUser() {\n return this._user;\n };\n\n _proto.setUser = function setUser(id, email, name) {\n this._user = {\n id: id,\n email: email,\n name: name\n };\n };\n\n _proto.toJSON = function toJSON() {\n return {\n payloadVersion: '4',\n exceptions: _$map_16(this.errors, function (er) {\n return _$assign_11({}, er, {\n message: er.errorMessage\n });\n }),\n severity: this.severity,\n unhandled: this._handledState.unhandled,\n severityReason: this._handledState.severityReason,\n app: this.app,\n device: this.device,\n request: this.request,\n breadcrumbs: this.breadcrumbs,\n context: this.context,\n groupingHash: this.groupingHash,\n metaData: this._metadata,\n user: this._user,\n session: this._session,\n featureFlags: this.getFeatureFlags()\n };\n };\n\n return Event;\n}(); // takes a stacktrace.js style stackframe (https://github.com/stacktracejs/stackframe)\n// and returns a Bugsnag compatible stackframe (https://docs.bugsnag.com/api/error-reporting/#json-payload)\n\n\nvar formatStackframe = function (frame) {\n var f = {\n file: frame.fileName,\n method: normaliseFunctionName(frame.functionName),\n lineNumber: frame.lineNumber,\n columnNumber: frame.columnNumber,\n code: undefined,\n inProject: undefined\n }; // Some instances result in no file:\n // - calling notify() from chrome's terminal results in no file/method.\n // - non-error exception thrown from global code in FF\n // This adds one.\n\n if (f.lineNumber > -1 && !f.file && !f.method) {\n f.file = 'global code';\n }\n\n return f;\n};\n\nvar normaliseFunctionName = function (name) {\n return /^global code$/i.test(name) ? 'global code' : name;\n};\n\nvar defaultHandledState = function () {\n return {\n unhandled: false,\n severity: 'warning',\n severityReason: {\n type: 'handledException'\n }\n };\n};\n\nvar ensureString = function (str) {\n return typeof str === 'string' ? str : '';\n};\n\nfunction createBugsnagError(errorClass, errorMessage, type, stacktrace) {\n return {\n errorClass: ensureString(errorClass),\n errorMessage: ensureString(errorMessage),\n type: type,\n stacktrace: _$reduce_17(stacktrace, function (accum, frame) {\n var f = formatStackframe(frame); // don't include a stackframe if none of its properties are defined\n\n try {\n if (JSON.stringify(f) === '{}') return accum;\n return accum.concat(f);\n } catch (e) {\n return accum;\n }\n }, [])\n };\n}\n\nfunction getCauseStack(error) {\n if (error.cause) {\n return [error].concat(getCauseStack(error.cause));\n } else {\n return [error];\n }\n} // Helpers\n\n\nEvent.getStacktrace = function (error, errorFramesToSkip, backtraceFramesToSkip) {\n if (_$hasStack_19(error)) return _$errorStackParser_10.parse(error).slice(errorFramesToSkip); // error wasn't provided or didn't have a stacktrace so try to walk the callstack\n\n try {\n return _$filter_12(_$stackGenerator_33.backtrace(), function (frame) {\n return (frame.functionName || '').indexOf('StackGenerator$$') === -1;\n }).slice(1 + backtraceFramesToSkip);\n } catch (e) {\n return [];\n }\n};\n\nEvent.create = function (maybeError, tolerateNonErrors, handledState, component, errorFramesToSkip, logger) {\n if (errorFramesToSkip === void 0) {\n errorFramesToSkip = 0;\n }\n\n var _normaliseError = normaliseError(maybeError, tolerateNonErrors, component, logger),\n error = _normaliseError[0],\n internalFrames = _normaliseError[1];\n\n var event;\n\n try {\n var stacktrace = Event.getStacktrace(error, // if an error was created/throw in the normaliseError() function, we need to\n // tell the getStacktrace() function to skip the number of frames we know will\n // be from our own functions. This is added to the number of frames deep we\n // were told about\n internalFrames > 0 ? 1 + internalFrames + errorFramesToSkip : 0, // if there's no stacktrace, the callstack may be walked to generated one.\n // this is how many frames should be removed because they come from our library\n 1 + errorFramesToSkip);\n event = new Event(error.name, error.message, stacktrace, handledState, maybeError);\n } catch (e) {\n event = new Event(error.name, error.message, [], handledState, maybeError);\n }\n\n if (error.name === 'InvalidError') {\n event.addMetadata(\"\" + component, 'non-error parameter', makeSerialisable(maybeError));\n }\n\n if (error.cause) {\n var _event$errors;\n\n var causes = getCauseStack(error).slice(1);\n var normalisedCauses = _$map_16(causes, function (cause) {\n // Only get stacktrace for error causes that are a valid JS Error and already have a stack\n var stacktrace = _$iserror_20(cause) && _$hasStack_19(cause) ? _$errorStackParser_10.parse(cause) : [];\n\n var _normaliseError2 = normaliseError(cause, true, 'error cause'),\n error = _normaliseError2[0];\n\n if (error.name === 'InvalidError') event.addMetadata('error cause', makeSerialisable(cause));\n return createBugsnagError(error.name, error.message, Event.__type, stacktrace);\n });\n\n (_event$errors = event.errors).push.apply(_event$errors, normalisedCauses);\n }\n\n return event;\n};\n\nvar makeSerialisable = function (err) {\n if (err === null) return 'null';\n if (err === undefined) return 'undefined';\n return err;\n};\n\nvar normaliseError = function (maybeError, tolerateNonErrors, component, logger) {\n var error;\n var internalFrames = 0;\n\n var createAndLogInputError = function (reason) {\n var verb = component === 'error cause' ? 'was' : 'received';\n if (logger) logger.warn(component + \" \" + verb + \" a non-error: \\\"\" + reason + \"\\\"\");\n var err = new Error(component + \" \" + verb + \" a non-error. See \\\"\" + component + \"\\\" tab for more detail.\");\n err.name = 'InvalidError';\n return err;\n }; // In some cases:\n //\n // - the promise rejection handler (both in the browser and node)\n // - the node uncaughtException handler\n //\n // We are really limited in what we can do to get a stacktrace. So we use the\n // tolerateNonErrors option to ensure that the resulting error communicates as\n // such.\n\n\n if (!tolerateNonErrors) {\n if (_$iserror_20(maybeError)) {\n error = maybeError;\n } else {\n error = createAndLogInputError(typeof maybeError);\n internalFrames += 2;\n }\n } else {\n switch (typeof maybeError) {\n case 'string':\n case 'number':\n case 'boolean':\n error = new Error(String(maybeError));\n internalFrames += 1;\n break;\n\n case 'function':\n error = createAndLogInputError('function');\n internalFrames += 2;\n break;\n\n case 'object':\n if (maybeError !== null && _$iserror_20(maybeError)) {\n error = maybeError;\n } else if (maybeError !== null && hasNecessaryFields(maybeError)) {\n error = new Error(maybeError.message || maybeError.errorMessage);\n error.name = maybeError.name || maybeError.errorClass;\n internalFrames += 1;\n } else {\n error = createAndLogInputError(maybeError === null ? 'null' : 'unsupported object');\n internalFrames += 2;\n }\n\n break;\n\n default:\n error = createAndLogInputError('nothing');\n internalFrames += 2;\n }\n }\n\n if (!_$hasStack_19(error)) {\n // in IE10/11 a new Error() doesn't have a stacktrace until you throw it, so try that here\n try {\n throw error;\n } catch (e) {\n if (_$hasStack_19(e)) {\n error = e; // if the error only got a stacktrace after we threw it here, we know it\n // will only have one extra internal frame from this function, regardless\n // of whether it went through createAndLogInputError() or not\n\n internalFrames = 1;\n }\n }\n }\n\n return [error, internalFrames];\n}; // default value for stacktrace.type\n\n\nEvent.__type = 'browserjs';\n\nvar hasNecessaryFields = function (error) {\n return (typeof error.name === 'string' || typeof error.errorClass === 'string') && (typeof error.message === 'string' || typeof error.errorMessage === 'string');\n};\n\nvar _$Event_6 = Event;\n\n// This is a heavily modified/simplified version of\n// https://github.com/othiym23/async-some\n// with the logic flipped so that it is akin to the\n// synchronous \"every\" method instead of \"some\".\n// run the asynchronous test function (fn) over each item in the array (arr)\n// in series until:\n// - fn(item, cb) => calls cb(null, false)\n// - or the end of the array is reached\n// the callback (cb) will be passed (null, false) if any of the items in arr\n// caused fn to call back with false, otherwise it will be passed (null, true)\nvar _$asyncEvery_7 = function (arr, fn, cb) {\n var index = 0;\n\n var next = function () {\n if (index >= arr.length) return cb(null, true);\n fn(arr[index], function (err, result) {\n if (err) return cb(err);\n if (result === false) return cb(null, false);\n index++;\n next();\n });\n };\n\n next();\n};\n\n/* removed: var _$asyncEvery_7 = require('./async-every'); */;\n\nvar _$callbackRunner_9 = function (callbacks, event, onCallbackError, cb) {\n // This function is how we support different kinds of callback:\n // - synchronous - return value\n // - node-style async with callback - cb(err, value)\n // - promise/thenable - resolve(value)\n // It normalises each of these into the lowest common denominator – a node-style callback\n var runMaybeAsyncCallback = function (fn, cb) {\n if (typeof fn !== 'function') return cb(null);\n\n try {\n // if function appears sync…\n if (fn.length !== 2) {\n var ret = fn(event); // check if it returned a \"thenable\" (promise)\n\n if (ret && typeof ret.then === 'function') {\n return ret.then( // resolve\n function (val) {\n return setTimeout(function () {\n return cb(null, val);\n });\n }, // reject\n function (err) {\n setTimeout(function () {\n onCallbackError(err);\n return cb(null, true);\n });\n });\n }\n\n return cb(null, ret);\n } // if function is async…\n\n\n fn(event, function (err, result) {\n if (err) {\n onCallbackError(err);\n return cb(null);\n }\n\n cb(null, result);\n });\n } catch (e) {\n onCallbackError(e);\n cb(null);\n }\n };\n\n _$asyncEvery_7(callbacks, runMaybeAsyncCallback, cb);\n};\n\nvar _$syncCallbackRunner_23 = function (callbacks, callbackArg, callbackType, logger) {\n var ignore = false;\n var cbs = callbacks.slice();\n\n while (!ignore) {\n if (!cbs.length) break;\n\n try {\n ignore = cbs.pop()(callbackArg) === false;\n } catch (e) {\n logger.error(\"Error occurred in \" + callbackType + \" callback, continuing anyway\\u2026\");\n logger.error(e);\n }\n }\n\n return ignore;\n};\n\nvar _$pad_29 = function pad(num, size) {\n var s = '000000000' + num;\n return s.substr(s.length - size);\n};\n\n/* removed: var _$pad_29 = require('./pad.js'); */;\n\nvar env = typeof window === 'object' ? window : self;\nvar globalCount = 0;\n\nfor (var prop in env) {\n if (Object.hasOwnProperty.call(env, prop)) globalCount++;\n}\n\nvar mimeTypesLength = navigator.mimeTypes ? navigator.mimeTypes.length : 0;\nvar clientId = _$pad_29((mimeTypesLength + navigator.userAgent.length).toString(36) + globalCount.toString(36), 4);\n\nvar _$fingerprint_28 = function fingerprint() {\n return clientId;\n};\n\n/**\n * cuid.js\n * Collision-resistant UID generator for browsers and node.\n * Sequential for fast db lookups and recency sorting.\n * Safe for element IDs and server-side lookups.\n *\n * Extracted from CLCTR\n *\n * Copyright (c) Eric Elliott 2012\n * MIT License\n */\n/* removed: var _$fingerprint_28 = require('./lib/fingerprint.js'); */;\n\n/* removed: var _$pad_29 = require('./lib/pad.js'); */;\n\nvar c = 0,\n blockSize = 4,\n base = 36,\n discreteValues = Math.pow(base, blockSize);\n\nfunction randomBlock() {\n return _$pad_29((Math.random() * discreteValues << 0).toString(base), blockSize);\n}\n\nfunction safeCounter() {\n c = c < discreteValues ? c : 0;\n c++; // this is not subliminal\n\n return c - 1;\n}\n\nfunction cuid() {\n // Starting with a lowercase letter makes\n // it HTML element ID friendly.\n var letter = 'c',\n // hard-coded allows for sequential access\n // timestamp\n // warning: this exposes the exact date and time\n // that the uid was created.\n timestamp = new Date().getTime().toString(base),\n // Prevent same-machine collisions.\n counter = _$pad_29(safeCounter().toString(base), blockSize),\n // A few chars to generate distinct ids for different\n // clients (so different computers are far less\n // likely to generate the same id)\n print = _$fingerprint_28(),\n // Grab some more chars from Math.random()\n random = randomBlock() + randomBlock();\n return letter + timestamp + counter + print + random;\n}\n\ncuid.fingerprint = _$fingerprint_28;\nvar _$cuid_27 = cuid;\n\n/* removed: var _$cuid_27 = require('@bugsnag/cuid'); */;\n\nvar Session = /*#__PURE__*/function () {\n function Session() {\n this.id = _$cuid_27();\n this.startedAt = new Date();\n this._handled = 0;\n this._unhandled = 0;\n this._user = {};\n this.app = {};\n this.device = {};\n }\n\n var _proto = Session.prototype;\n\n _proto.getUser = function getUser() {\n return this._user;\n };\n\n _proto.setUser = function setUser(id, email, name) {\n this._user = {\n id: id,\n email: email,\n name: name\n };\n };\n\n _proto.toJSON = function toJSON() {\n return {\n id: this.id,\n startedAt: this.startedAt,\n events: {\n handled: this._handled,\n unhandled: this._unhandled\n }\n };\n };\n\n _proto._track = function _track(event) {\n this[event._handledState.unhandled ? '_unhandled' : '_handled'] += 1;\n };\n\n return Session;\n}();\n\nvar _$Session_35 = Session;\n\n/* removed: var _$config_5 = require('./config'); */;\n\n/* removed: var _$Event_6 = require('./event'); */;\n\n/* removed: var _$Breadcrumb_3 = require('./breadcrumb'); */;\n\n/* removed: var _$Session_35 = require('./session'); */;\n\n/* removed: var _$map_16 = require('./lib/es-utils/map'); */;\n\n/* removed: var _$includes_13 = require('./lib/es-utils/includes'); */;\n\n/* removed: var _$filter_12 = require('./lib/es-utils/filter'); */;\n\n/* removed: var _$reduce_17 = require('./lib/es-utils/reduce'); */;\n\n/* removed: var _$keys_15 = require('./lib/es-utils/keys'); */;\n\n/* removed: var _$assign_11 = require('./lib/es-utils/assign'); */;\n\n/* removed: var _$callbackRunner_9 = require('./lib/callback-runner'); */;\n\n/* removed: var _$metadataDelegate_22 = require('./lib/metadata-delegate'); */;\n\n/* removed: var _$syncCallbackRunner_23 = require('./lib/sync-callback-runner'); */;\n\n/* removed: var _$breadcrumbTypes_8 = require('./lib/breadcrumb-types'); */;\n\nvar __add_4 = _$featureFlagDelegate_18.add,\n __clear_4 = _$featureFlagDelegate_18.clear,\n __merge_4 = _$featureFlagDelegate_18.merge;\n\nvar noop = function () {};\n\nvar Client = /*#__PURE__*/function () {\n function Client(configuration, schema, internalPlugins, notifier) {\n var _this = this;\n\n if (schema === void 0) {\n schema = _$config_5.schema;\n }\n\n if (internalPlugins === void 0) {\n internalPlugins = [];\n }\n\n // notifier id\n this._notifier = notifier; // intialise opts and config\n\n this._config = {};\n this._schema = schema; // i/o\n\n this._delivery = {\n sendSession: noop,\n sendEvent: noop\n };\n this._logger = {\n debug: noop,\n info: noop,\n warn: noop,\n error: noop\n }; // plugins\n\n this._plugins = {}; // state\n\n this._breadcrumbs = [];\n this._session = null;\n this._metadata = {};\n this._featuresIndex = {};\n this._features = [];\n this._context = undefined;\n this._user = {}; // callbacks:\n // e: onError\n // s: onSession\n // sp: onSessionPayload\n // b: onBreadcrumb\n // (note these names are minified by hand because object\n // properties are not safe to minify automatically)\n\n this._cbs = {\n e: [],\n s: [],\n sp: [],\n b: []\n }; // expose internal constructors\n\n this.Client = Client;\n this.Event = _$Event_6;\n this.Breadcrumb = _$Breadcrumb_3;\n this.Session = _$Session_35;\n this._config = this._configure(configuration, internalPlugins);\n _$map_16(internalPlugins.concat(this._config.plugins), function (pl) {\n if (pl) _this._loadPlugin(pl);\n }); // when notify() is called we need to know how many frames are from our own source\n // this inital value is 1 not 0 because we wrap notify() to ensure it is always\n // bound to have the client as its `this` value – see below.\n\n this._depth = 1;\n var self = this;\n var notify = this.notify;\n\n this.notify = function () {\n return notify.apply(self, arguments);\n };\n }\n\n var _proto = Client.prototype;\n\n _proto.addMetadata = function addMetadata(section, keyOrObj, maybeVal) {\n return _$metadataDelegate_22.add(this._metadata, section, keyOrObj, maybeVal);\n };\n\n _proto.getMetadata = function getMetadata(section, key) {\n return _$metadataDelegate_22.get(this._metadata, section, key);\n };\n\n _proto.clearMetadata = function clearMetadata(section, key) {\n return _$metadataDelegate_22.clear(this._metadata, section, key);\n };\n\n _proto.addFeatureFlag = function addFeatureFlag(name, variant) {\n if (variant === void 0) {\n variant = null;\n }\n\n __add_4(this._features, this._featuresIndex, name, variant);\n };\n\n _proto.addFeatureFlags = function addFeatureFlags(featureFlags) {\n __merge_4(this._features, featureFlags, this._featuresIndex);\n };\n\n _proto.clearFeatureFlag = function clearFeatureFlag(name) {\n __clear_4(this._features, this._featuresIndex, name);\n };\n\n _proto.clearFeatureFlags = function clearFeatureFlags() {\n this._features = [];\n this._featuresIndex = {};\n };\n\n _proto.getContext = function getContext() {\n return this._context;\n };\n\n _proto.setContext = function setContext(c) {\n this._context = c;\n };\n\n _proto._configure = function _configure(opts, internalPlugins) {\n var schema = _$reduce_17(internalPlugins, function (schema, plugin) {\n if (plugin && plugin.configSchema) return _$assign_11({}, schema, plugin.configSchema);\n return schema;\n }, this._schema); // accumulate configuration and error messages\n\n var _reduce = _$reduce_17(_$keys_15(schema), function (accum, key) {\n var defaultValue = schema[key].defaultValue(opts[key]);\n\n if (opts[key] !== undefined) {\n var valid = schema[key].validate(opts[key]);\n\n if (!valid) {\n accum.errors[key] = schema[key].message;\n accum.config[key] = defaultValue;\n } else {\n if (schema[key].allowPartialObject) {\n accum.config[key] = _$assign_11(defaultValue, opts[key]);\n } else {\n accum.config[key] = opts[key];\n }\n }\n } else {\n accum.config[key] = defaultValue;\n }\n\n return accum;\n }, {\n errors: {},\n config: {}\n }),\n errors = _reduce.errors,\n config = _reduce.config;\n\n if (schema.apiKey) {\n // missing api key is the only fatal error\n if (!config.apiKey) throw new Error('No Bugsnag API Key set'); // warn about an apikey that is not of the expected format\n\n if (!/^[0-9a-f]{32}$/i.test(config.apiKey)) errors.apiKey = 'should be a string of 32 hexadecimal characters';\n } // update and elevate some options\n\n\n this._metadata = _$assign_11({}, config.metadata);\n __merge_4(this._features, config.featureFlags, this._featuresIndex);\n this._user = _$assign_11({}, config.user);\n this._context = config.context;\n if (config.logger) this._logger = config.logger; // add callbacks\n\n if (config.onError) this._cbs.e = this._cbs.e.concat(config.onError);\n if (config.onBreadcrumb) this._cbs.b = this._cbs.b.concat(config.onBreadcrumb);\n if (config.onSession) this._cbs.s = this._cbs.s.concat(config.onSession); // finally warn about any invalid config where we fell back to the default\n\n if (_$keys_15(errors).length) {\n this._logger.warn(generateConfigErrorMessage(errors, opts));\n }\n\n return config;\n };\n\n _proto.getUser = function getUser() {\n return this._user;\n };\n\n _proto.setUser = function setUser(id, email, name) {\n this._user = {\n id: id,\n email: email,\n name: name\n };\n };\n\n _proto._loadPlugin = function _loadPlugin(plugin) {\n var result = plugin.load(this); // JS objects are not the safest way to store arbitrarily keyed values,\n // so bookend the key with some characters that prevent tampering with\n // stuff like __proto__ etc. (only store the result if the plugin had a\n // name)\n\n if (plugin.name) this._plugins[\"~\" + plugin.name + \"~\"] = result;\n return this;\n };\n\n _proto.getPlugin = function getPlugin(name) {\n return this._plugins[\"~\" + name + \"~\"];\n };\n\n _proto._setDelivery = function _setDelivery(d) {\n this._delivery = d(this);\n };\n\n _proto.startSession = function startSession() {\n var session = new _$Session_35();\n session.app.releaseStage = this._config.releaseStage;\n session.app.version = this._config.appVersion;\n session.app.type = this._config.appType;\n session._user = _$assign_11({}, this._user); // run onSession callbacks\n\n var ignore = _$syncCallbackRunner_23(this._cbs.s, session, 'onSession', this._logger);\n\n if (ignore) {\n this._logger.debug('Session not started due to onSession callback');\n\n return this;\n }\n\n return this._sessionDelegate.startSession(this, session);\n };\n\n _proto.addOnError = function addOnError(fn, front) {\n if (front === void 0) {\n front = false;\n }\n\n this._cbs.e[front ? 'unshift' : 'push'](fn);\n };\n\n _proto.removeOnError = function removeOnError(fn) {\n this._cbs.e = _$filter_12(this._cbs.e, function (f) {\n return f !== fn;\n });\n };\n\n _proto._addOnSessionPayload = function _addOnSessionPayload(fn) {\n this._cbs.sp.push(fn);\n };\n\n _proto.addOnSession = function addOnSession(fn) {\n this._cbs.s.push(fn);\n };\n\n _proto.removeOnSession = function removeOnSession(fn) {\n this._cbs.s = _$filter_12(this._cbs.s, function (f) {\n return f !== fn;\n });\n };\n\n _proto.addOnBreadcrumb = function addOnBreadcrumb(fn, front) {\n if (front === void 0) {\n front = false;\n }\n\n this._cbs.b[front ? 'unshift' : 'push'](fn);\n };\n\n _proto.removeOnBreadcrumb = function removeOnBreadcrumb(fn) {\n this._cbs.b = _$filter_12(this._cbs.b, function (f) {\n return f !== fn;\n });\n };\n\n _proto.pauseSession = function pauseSession() {\n return this._sessionDelegate.pauseSession(this);\n };\n\n _proto.resumeSession = function resumeSession() {\n return this._sessionDelegate.resumeSession(this);\n };\n\n _proto.leaveBreadcrumb = function leaveBreadcrumb(message, metadata, type) {\n // coerce bad values so that the defaults get set\n message = typeof message === 'string' ? message : '';\n type = typeof type === 'string' && _$includes_13(_$breadcrumbTypes_8, type) ? type : 'manual';\n metadata = typeof metadata === 'object' && metadata !== null ? metadata : {}; // if no message, discard\n\n if (!message) return;\n var crumb = new _$Breadcrumb_3(message, metadata, type); // run onBreadcrumb callbacks\n\n var ignore = _$syncCallbackRunner_23(this._cbs.b, crumb, 'onBreadcrumb', this._logger);\n\n if (ignore) {\n this._logger.debug('Breadcrumb not attached due to onBreadcrumb callback');\n\n return;\n } // push the valid crumb onto the queue and maintain the length\n\n\n this._breadcrumbs.push(crumb);\n\n if (this._breadcrumbs.length > this._config.maxBreadcrumbs) {\n this._breadcrumbs = this._breadcrumbs.slice(this._breadcrumbs.length - this._config.maxBreadcrumbs);\n }\n };\n\n _proto._isBreadcrumbTypeEnabled = function _isBreadcrumbTypeEnabled(type) {\n var types = this._config.enabledBreadcrumbTypes;\n return types === null || _$includes_13(types, type);\n };\n\n _proto.notify = function notify(maybeError, onError, postReportCallback) {\n if (postReportCallback === void 0) {\n postReportCallback = noop;\n }\n\n var event = _$Event_6.create(maybeError, true, undefined, 'notify()', this._depth + 1, this._logger);\n\n this._notify(event, onError, postReportCallback);\n };\n\n _proto._notify = function _notify(event, onError, postReportCallback) {\n var _this2 = this;\n\n if (postReportCallback === void 0) {\n postReportCallback = noop;\n }\n\n event.app = _$assign_11({}, event.app, {\n releaseStage: this._config.releaseStage,\n version: this._config.appVersion,\n type: this._config.appType\n });\n event.context = event.context || this._context;\n event._metadata = _$assign_11({}, event._metadata, this._metadata);\n event._user = _$assign_11({}, event._user, this._user);\n event.breadcrumbs = this._breadcrumbs.slice();\n __merge_4(event._features, this._features, event._featuresIndex); // exit early if events should not be sent on the current releaseStage\n\n if (this._config.enabledReleaseStages !== null && !_$includes_13(this._config.enabledReleaseStages, this._config.releaseStage)) {\n this._logger.warn('Event not sent due to releaseStage/enabledReleaseStages configuration');\n\n return postReportCallback(null, event);\n }\n\n var originalSeverity = event.severity;\n\n var onCallbackError = function (err) {\n // errors in callbacks are tolerated but we want to log them out\n _this2._logger.error('Error occurred in onError callback, continuing anyway…');\n\n _this2._logger.error(err);\n };\n\n var callbacks = [].concat(this._cbs.e).concat(onError);\n _$callbackRunner_9(callbacks, event, onCallbackError, function (err, shouldSend) {\n if (err) onCallbackError(err);\n\n if (!shouldSend) {\n _this2._logger.debug('Event not sent due to onError callback');\n\n return postReportCallback(null, event);\n }\n\n if (_this2._isBreadcrumbTypeEnabled('error')) {\n // only leave a crumb for the error if actually got sent\n Client.prototype.leaveBreadcrumb.call(_this2, event.errors[0].errorClass, {\n errorClass: event.errors[0].errorClass,\n errorMessage: event.errors[0].errorMessage,\n severity: event.severity\n }, 'error');\n }\n\n if (originalSeverity !== event.severity) {\n event._handledState.severityReason = {\n type: 'userCallbackSetSeverity'\n };\n }\n\n if (event.unhandled !== event._handledState.unhandled) {\n event._handledState.severityReason.unhandledOverridden = true;\n event._handledState.unhandled = event.unhandled;\n }\n\n if (_this2._session) {\n _this2._session._track(event);\n\n event._session = _this2._session;\n }\n\n _this2._delivery.sendEvent({\n apiKey: event.apiKey || _this2._config.apiKey,\n notifier: _this2._notifier,\n events: [event]\n }, function (err) {\n return postReportCallback(err, event);\n });\n });\n };\n\n return Client;\n}();\n\nvar generateConfigErrorMessage = function (errors, rawInput) {\n var er = new Error(\"Invalid configuration\\n\" + _$map_16(_$keys_15(errors), function (key) {\n return \" - \" + key + \" \" + errors[key] + \", got \" + stringify(rawInput[key]);\n }).join('\\n\\n'));\n return er;\n};\n\nvar stringify = function (val) {\n switch (typeof val) {\n case 'string':\n case 'number':\n case 'object':\n return JSON.stringify(val);\n\n default:\n return String(val);\n }\n};\n\nvar _$Client_4 = Client;\n\nvar _$jsonPayload_21 = {};\n/* removed: var _$safeJsonStringify_30 = require('@bugsnag/safe-json-stringify'); */;\n\nvar EVENT_REDACTION_PATHS = ['events.[].metaData', 'events.[].breadcrumbs.[].metaData', 'events.[].request'];\n\n_$jsonPayload_21.event = function (event, redactedKeys) {\n var payload = _$safeJsonStringify_30(event, null, null, {\n redactedPaths: EVENT_REDACTION_PATHS,\n redactedKeys: redactedKeys\n });\n\n if (payload.length > 10e5) {\n event.events[0]._metadata = {\n notifier: \"WARNING!\\nSerialized payload was \" + payload.length / 10e5 + \"MB (limit = 1MB)\\nmetadata was removed\"\n };\n payload = _$safeJsonStringify_30(event, null, null, {\n redactedPaths: EVENT_REDACTION_PATHS,\n redactedKeys: redactedKeys\n });\n }\n\n return payload;\n};\n\n_$jsonPayload_21.session = function (session, redactedKeys) {\n var payload = _$safeJsonStringify_30(session, null, null);\n return payload;\n};\n\nvar _$delivery_36 = {};\n/* removed: var _$jsonPayload_21 = require('@bugsnag/core/lib/json-payload'); */;\n\n_$delivery_36 = function (client, win) {\n if (win === void 0) {\n win = window;\n }\n\n return {\n sendEvent: function (event, cb) {\n if (cb === void 0) {\n cb = function () {};\n }\n\n var url = getApiUrl(client._config, 'notify', '4', win);\n var body = _$jsonPayload_21.event(event, client._config.redactedKeys);\n var req = new win.XDomainRequest();\n\n req.onload = function () {\n cb(null);\n };\n\n req.onerror = function () {\n var err = new Error('Event failed to send');\n\n client._logger.error('Event failed to send…', err);\n\n if (body.length > 10e5) {\n client._logger.warn(\"Event oversized (\" + (body.length / 10e5).toFixed(2) + \" MB)\");\n }\n\n cb(err);\n };\n\n req.open('POST', url);\n setTimeout(function () {\n try {\n req.send(body);\n } catch (e) {\n client._logger.error(e);\n\n cb(e);\n }\n }, 0);\n },\n sendSession: function (session, cb) {\n if (cb === void 0) {\n cb = function () {};\n }\n\n var url = getApiUrl(client._config, 'sessions', '1', win);\n var req = new win.XDomainRequest();\n\n req.onload = function () {\n cb(null);\n };\n\n req.open('POST', url);\n setTimeout(function () {\n try {\n req.send(_$jsonPayload_21.session(session, client._config.redactedKeys));\n } catch (e) {\n client._logger.error(e);\n\n cb(e);\n }\n }, 0);\n }\n };\n};\n\nvar getApiUrl = function (config, endpoint, version, win) {\n // IE8 doesn't support Date.prototype.toISOstring(), but it does convert a date\n // to an ISO string when you use JSON stringify. Simply parsing the result of\n // JSON.stringify is smaller than using a toISOstring() polyfill.\n var isoDate = JSON.parse(JSON.stringify(new Date()));\n var url = matchPageProtocol(config.endpoints[endpoint], win.location.protocol);\n return url + \"?apiKey=\" + encodeURIComponent(config.apiKey) + \"&payloadVersion=\" + version + \"&sentAt=\" + encodeURIComponent(isoDate);\n};\n\nvar matchPageProtocol = _$delivery_36._matchPageProtocol = function (endpoint, pageProtocol) {\n return pageProtocol === 'http:' ? endpoint.replace(/^https:/, 'http:') : endpoint;\n};\n\n/* removed: var _$jsonPayload_21 = require('@bugsnag/core/lib/json-payload'); */;\n\nvar _$delivery_37 = function (client, win) {\n if (win === void 0) {\n win = window;\n }\n\n return {\n sendEvent: function (event, cb) {\n if (cb === void 0) {\n cb = function () {};\n }\n\n try {\n var url = client._config.endpoints.notify;\n var req = new win.XMLHttpRequest();\n var body = _$jsonPayload_21.event(event, client._config.redactedKeys);\n\n req.onreadystatechange = function () {\n if (req.readyState === win.XMLHttpRequest.DONE) {\n var status = req.status;\n\n if (status === 0 || status >= 400) {\n var err = new Error(\"Request failed with status \" + status);\n\n client._logger.error('Event failed to send…', err);\n\n if (body.length > 10e5) {\n client._logger.warn(\"Event oversized (\" + (body.length / 10e5).toFixed(2) + \" MB)\");\n }\n\n cb(err);\n } else {\n cb(null);\n }\n }\n };\n\n req.open('POST', url);\n req.setRequestHeader('Content-Type', 'application/json');\n req.setRequestHeader('Bugsnag-Api-Key', event.apiKey || client._config.apiKey);\n req.setRequestHeader('Bugsnag-Payload-Version', '4');\n req.setRequestHeader('Bugsnag-Sent-At', new Date().toISOString());\n req.send(body);\n } catch (e) {\n client._logger.error(e);\n }\n },\n sendSession: function (session, cb) {\n if (cb === void 0) {\n cb = function () {};\n }\n\n try {\n var url = client._config.endpoints.sessions;\n var req = new win.XMLHttpRequest();\n\n req.onreadystatechange = function () {\n if (req.readyState === win.XMLHttpRequest.DONE) {\n var status = req.status;\n\n if (status === 0 || status >= 400) {\n var err = new Error(\"Request failed with status \" + status);\n\n client._logger.error('Session failed to send…', err);\n\n cb(err);\n } else {\n cb(null);\n }\n }\n };\n\n req.open('POST', url);\n req.setRequestHeader('Content-Type', 'application/json');\n req.setRequestHeader('Bugsnag-Api-Key', client._config.apiKey);\n req.setRequestHeader('Bugsnag-Payload-Version', '1');\n req.setRequestHeader('Bugsnag-Sent-At', new Date().toISOString());\n req.send(_$jsonPayload_21.session(session, client._config.redactedKeys));\n } catch (e) {\n client._logger.error(e);\n }\n }\n };\n};\n\nvar appStart = new Date();\n\nvar reset = function () {\n appStart = new Date();\n};\n\nvar _$app_38 = {\n name: 'appDuration',\n load: function (client) {\n client.addOnError(function (event) {\n var now = new Date();\n event.app.duration = now - appStart;\n }, true);\n return {\n reset: reset\n };\n }\n};\n\n/*\n * Sets the default context to be the current URL\n */\nvar _$context_39 = function (win) {\n if (win === void 0) {\n win = window;\n }\n\n return {\n load: function (client) {\n client.addOnError(function (event) {\n if (event.context !== undefined) return;\n event.context = win.location.pathname;\n }, true);\n }\n };\n};\n\nvar _$pad_43 = function pad(num, size) {\n var s = '000000000' + num;\n return s.substr(s.length - size);\n};\n\n/* removed: var _$pad_43 = require('./pad.js'); */;\n\nvar __env_42 = typeof window === 'object' ? window : self;\nvar __globalCount_42 = 0;\n\nfor (var __prop_42 in __env_42) {\n if (Object.hasOwnProperty.call(__env_42, __prop_42)) __globalCount_42++;\n}\n\nvar __mimeTypesLength_42 = navigator.mimeTypes ? navigator.mimeTypes.length : 0;\nvar __clientId_42 = _$pad_43((__mimeTypesLength_42 + navigator.userAgent.length).toString(36) + __globalCount_42.toString(36), 4);\n\nvar _$fingerprint_42 = function fingerprint() {\n return __clientId_42;\n};\n\n/**\n * cuid.js\n * Collision-resistant UID generator for browsers and node.\n * Sequential for fast db lookups and recency sorting.\n * Safe for element IDs and server-side lookups.\n *\n * Extracted from CLCTR\n *\n * Copyright (c) Eric Elliott 2012\n * MIT License\n */\n/* removed: var _$fingerprint_42 = require('./lib/fingerprint.js'); */;\n\n/* removed: var _$pad_43 = require('./lib/pad.js'); */;\n\nvar __c_41 = 0,\n __blockSize_41 = 4,\n __base_41 = 36,\n __discreteValues_41 = Math.pow(__base_41, __blockSize_41);\n\nfunction __randomBlock_41() {\n return _$pad_43((Math.random() * __discreteValues_41 << 0).toString(__base_41), __blockSize_41);\n}\n\nfunction __safeCounter_41() {\n __c_41 = __c_41 < __discreteValues_41 ? __c_41 : 0;\n __c_41++; // this is not subliminal\n\n return __c_41 - 1;\n}\n\nfunction __cuid_41() {\n // Starting with a lowercase letter makes\n // it HTML element ID friendly.\n var letter = 'c',\n // hard-coded allows for sequential access\n // timestamp\n // warning: this exposes the exact date and time\n // that the uid was created.\n timestamp = new Date().getTime().toString(__base_41),\n // Prevent same-machine collisions.\n counter = _$pad_43(__safeCounter_41().toString(__base_41), __blockSize_41),\n // A few chars to generate distinct ids for different\n // clients (so different computers are far less\n // likely to generate the same id)\n print = _$fingerprint_42(),\n // Grab some more chars from Math.random()\n random = __randomBlock_41() + __randomBlock_41();\n return letter + timestamp + counter + print + random;\n}\n\n__cuid_41.fingerprint = _$fingerprint_42;\nvar _$cuid_41 = __cuid_41;\n\n/* removed: var _$assign_11 = require('@bugsnag/core/lib/es-utils/assign'); */;\n\nvar BUGSNAG_ANONYMOUS_ID_KEY = 'bugsnag-anonymous-id';\n\nvar getDeviceId = function (win) {\n try {\n var storage = win.localStorage;\n var id = storage.getItem(BUGSNAG_ANONYMOUS_ID_KEY); // If we get an ID, make sure it looks like a valid cuid. The length can\n // fluctuate slightly, so some leeway is built in\n\n if (id && /^c[a-z0-9]{20,32}$/.test(id)) {\n return id;\n }\n\n /* removed: var _$cuid_41 = require('@bugsnag/cuid'); */;\n\n id = _$cuid_41();\n storage.setItem(BUGSNAG_ANONYMOUS_ID_KEY, id);\n return id;\n } catch (err) {// If localStorage is not available (e.g. because it's disabled) then give up\n }\n};\n/*\n * Automatically detects browser device details\n */\n\n\nvar _$device_40 = function (nav, win) {\n if (nav === void 0) {\n nav = navigator;\n }\n\n if (win === void 0) {\n win = window;\n }\n\n return {\n load: function (client) {\n var device = {\n locale: nav.browserLanguage || nav.systemLanguage || nav.userLanguage || nav.language,\n userAgent: nav.userAgent\n };\n\n if (win && win.screen && win.screen.orientation && win.screen.orientation.type) {\n device.orientation = win.screen.orientation.type;\n } else if (win && win.document) {\n device.orientation = win.document.documentElement.clientWidth > win.document.documentElement.clientHeight ? 'landscape' : 'portrait';\n }\n\n if (client._config.generateAnonymousId) {\n device.id = getDeviceId(win);\n }\n\n client.addOnSession(function (session) {\n session.device = _$assign_11({}, session.device, device); // only set device id if collectUserIp is false\n\n if (!client._config.collectUserIp) setDefaultUserId(session);\n }); // add time just as the event is sent\n\n client.addOnError(function (event) {\n event.device = _$assign_11({}, event.device, device, {\n time: new Date()\n });\n if (!client._config.collectUserIp) setDefaultUserId(event);\n }, true);\n },\n configSchema: {\n generateAnonymousId: {\n validate: function (value) {\n return value === true || value === false;\n },\n defaultValue: function () {\n return true;\n },\n message: 'should be true|false'\n }\n }\n };\n};\n\nvar setDefaultUserId = function (eventOrSession) {\n // device id is also used to populate the user id field, if it's not already set\n var user = eventOrSession.getUser();\n\n if (!user || !user.id) {\n eventOrSession.setUser(eventOrSession.device.id);\n }\n};\n\n/* removed: var _$assign_11 = require('@bugsnag/core/lib/es-utils/assign'); */;\n/*\n * Sets the event request: { url } to be the current href\n */\n\n\nvar _$request_44 = function (win) {\n if (win === void 0) {\n win = window;\n }\n\n return {\n load: function (client) {\n client.addOnError(function (event) {\n if (event.request && event.request.url) return;\n event.request = _$assign_11({}, event.request, {\n url: win.location.href\n });\n }, true);\n }\n };\n};\n\n/* removed: var _$includes_13 = require('@bugsnag/core/lib/es-utils/includes'); */;\n\nvar _$session_45 = {\n load: function (client) {\n client._sessionDelegate = sessionDelegate;\n }\n};\nvar sessionDelegate = {\n startSession: function (client, session) {\n var sessionClient = client;\n sessionClient._session = session;\n sessionClient._pausedSession = null; // exit early if the current releaseStage is not enabled\n\n if (sessionClient._config.enabledReleaseStages !== null && !_$includes_13(sessionClient._config.enabledReleaseStages, sessionClient._config.releaseStage)) {\n sessionClient._logger.warn('Session not sent due to releaseStage/enabledReleaseStages configuration');\n\n return sessionClient;\n }\n\n sessionClient._delivery.sendSession({\n notifier: sessionClient._notifier,\n device: session.device,\n app: session.app,\n sessions: [{\n id: session.id,\n startedAt: session.startedAt,\n user: session._user\n }]\n });\n\n return sessionClient;\n },\n resumeSession: function (client) {\n // Do nothing if there's already an active session\n if (client._session) {\n return client;\n } // If we have a paused session then make it the active session\n\n\n if (client._pausedSession) {\n client._session = client._pausedSession;\n client._pausedSession = null;\n return client;\n } // Otherwise start a new session\n\n\n return client.startSession();\n },\n pauseSession: function (client) {\n client._pausedSession = client._session;\n client._session = null;\n }\n};\n\n/* removed: var _$assign_11 = require('@bugsnag/core/lib/es-utils/assign'); */;\n/*\n * Prevent collection of user IPs\n */\n\n\nvar _$clientIp_46 = {\n load: function (client) {\n if (client._config.collectUserIp) return;\n client.addOnError(function (event) {\n // If user.id is explicitly undefined, it will be missing from the payload. It needs\n // removing so that the following line replaces it\n if (event._user && typeof event._user.id === 'undefined') delete event._user.id;\n event._user = _$assign_11({\n id: '[REDACTED]'\n }, event._user);\n event.request = _$assign_11({\n clientIp: '[REDACTED]'\n }, event.request);\n });\n },\n configSchema: {\n collectUserIp: {\n defaultValue: function () {\n return true;\n },\n message: 'should be true|false',\n validate: function (value) {\n return value === true || value === false;\n }\n }\n }\n};\n\nvar _$consoleBreadcrumbs_47 = {};\n/* removed: var _$map_16 = require('@bugsnag/core/lib/es-utils/map'); */;\n\n/* removed: var _$reduce_17 = require('@bugsnag/core/lib/es-utils/reduce'); */;\n\n/* removed: var _$filter_12 = require('@bugsnag/core/lib/es-utils/filter'); */;\n/*\n * Leaves breadcrumbs when console log methods are called\n */\n\n\n_$consoleBreadcrumbs_47.load = function (client) {\n var isDev = /^(local-)?dev(elopment)?$/.test(client._config.releaseStage);\n if (isDev || !client._isBreadcrumbTypeEnabled('log')) return;\n _$map_16(CONSOLE_LOG_METHODS, function (method) {\n var original = console[method];\n\n console[method] = function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n client.leaveBreadcrumb('Console output', _$reduce_17(args, function (accum, arg, i) {\n // do the best/simplest stringification of each argument\n var stringified = '[Unknown value]'; // this may fail if the input is:\n // - an object whose [[Prototype]] is null (no toString)\n // - an object with a broken toString or @@toPrimitive implementation\n\n try {\n stringified = String(arg);\n } catch (e) {} // if it stringifies to [object Object] attempt to JSON stringify\n\n\n if (stringified === '[object Object]') {\n // catch stringify errors and fallback to [object Object]\n try {\n stringified = JSON.stringify(arg);\n } catch (e) {}\n }\n\n accum[\"[\" + i + \"]\"] = stringified;\n return accum;\n }, {\n severity: method.indexOf('group') === 0 ? 'log' : method\n }), 'log');\n original.apply(console, args);\n };\n\n console[method]._restore = function () {\n console[method] = original;\n };\n });\n};\n\nif (\"production\" !== 'production') {\n _$consoleBreadcrumbs_47.destroy = function () {\n return CONSOLE_LOG_METHODS.forEach(function (method) {\n if (typeof console[method]._restore === 'function') console[method]._restore();\n });\n };\n}\n\nvar CONSOLE_LOG_METHODS = _$filter_12(['log', 'debug', 'info', 'warn', 'error'], function (method) {\n return typeof console !== 'undefined' && typeof console[method] === 'function';\n});\n\n/* removed: var _$map_16 = require('@bugsnag/core/lib/es-utils/map'); */;\n\n/* removed: var _$reduce_17 = require('@bugsnag/core/lib/es-utils/reduce'); */;\n\n/* removed: var _$filter_12 = require('@bugsnag/core/lib/es-utils/filter'); */;\n\nvar MAX_LINE_LENGTH = 200;\nvar MAX_SCRIPT_LENGTH = 500000;\n\nvar _$inlineScriptContent_48 = function (doc, win) {\n if (doc === void 0) {\n doc = document;\n }\n\n if (win === void 0) {\n win = window;\n }\n\n return {\n load: function (client) {\n if (!client._config.trackInlineScripts) return;\n var originalLocation = win.location.href;\n var html = ''; // in IE8-10 the 'interactive' state can fire too soon (before scripts have finished executing), so in those\n // we wait for the 'complete' state before assuming that synchronous scripts are no longer executing\n\n var isOldIe = !!doc.attachEvent;\n var DOMContentLoaded = isOldIe ? doc.readyState === 'complete' : doc.readyState !== 'loading';\n\n var getHtml = function () {\n return doc.documentElement.outerHTML;\n }; // get whatever HTML exists at this point in time\n\n\n html = getHtml();\n var prev = doc.onreadystatechange; // then update it when the DOM content has loaded\n\n doc.onreadystatechange = function () {\n // IE8 compatible alternative to document#DOMContentLoaded\n if (doc.readyState === 'interactive') {\n html = getHtml();\n DOMContentLoaded = true;\n }\n\n try {\n prev.apply(this, arguments);\n } catch (e) {}\n };\n\n var _lastScript = null;\n\n var updateLastScript = function (script) {\n _lastScript = script;\n };\n\n var getCurrentScript = function () {\n var script = doc.currentScript || _lastScript;\n\n if (!script && !DOMContentLoaded) {\n var scripts = doc.scripts || doc.getElementsByTagName('script');\n script = scripts[scripts.length - 1];\n }\n\n return script;\n };\n\n var addSurroundingCode = function (lineNumber) {\n // get whatever html has rendered at this point\n if (!DOMContentLoaded || !html) html = getHtml(); // simulate the raw html\n\n var htmlLines = [''].concat(html.split('\\n'));\n var zeroBasedLine = lineNumber - 1;\n var start = Math.max(zeroBasedLine - 3, 0);\n var end = Math.min(zeroBasedLine + 3, htmlLines.length);\n return _$reduce_17(htmlLines.slice(start, end), function (accum, line, i) {\n accum[start + 1 + i] = line.length <= MAX_LINE_LENGTH ? line : line.substr(0, MAX_LINE_LENGTH);\n return accum;\n }, {});\n };\n\n client.addOnError(function (event) {\n // remove any of our own frames that may be part the stack this\n // happens before the inline script check as it happens for all errors\n event.errors[0].stacktrace = _$filter_12(event.errors[0].stacktrace, function (f) {\n return !/__trace__$/.test(f.method);\n });\n var frame = event.errors[0].stacktrace[0]; // remove hash and query string from url\n\n var cleanUrl = function (url) {\n return url.replace(/#.*$/, '').replace(/\\?.*$/, '');\n }; // if frame.file exists and is not the original location of the page, this can't be an inline script\n\n\n if (frame && frame.file && cleanUrl(frame.file) !== cleanUrl(originalLocation)) return; // grab the last script known to have run\n\n var currentScript = getCurrentScript();\n\n if (currentScript) {\n var content = currentScript.innerHTML;\n event.addMetadata('script', 'content', content.length <= MAX_SCRIPT_LENGTH ? content : content.substr(0, MAX_SCRIPT_LENGTH)); // only attempt to grab some surrounding code if we have a line number\n\n if (frame && frame.lineNumber) {\n frame.code = addSurroundingCode(frame.lineNumber);\n }\n }\n }, true); // Proxy all the timer functions whose callback is their 0th argument.\n // Keep a reference to the original setTimeout because we need it later\n\n var _map = _$map_16(['setTimeout', 'setInterval', 'setImmediate', 'requestAnimationFrame'], function (fn) {\n return __proxy(win, fn, function (original) {\n return __traceOriginalScript(original, function (args) {\n return {\n get: function () {\n return args[0];\n },\n replace: function (fn) {\n args[0] = fn;\n }\n };\n });\n });\n }),\n _setTimeout = _map[0]; // Proxy all the host objects whose prototypes have an addEventListener function\n\n\n _$map_16(['EventTarget', 'Window', 'Node', 'ApplicationCache', 'AudioTrackList', 'ChannelMergerNode', 'CryptoOperation', 'EventSource', 'FileReader', 'HTMLUnknownElement', 'IDBDatabase', 'IDBRequest', 'IDBTransaction', 'KeyOperation', 'MediaController', 'MessagePort', 'ModalWindow', 'Notification', 'SVGElementInstance', 'Screen', 'TextTrack', 'TextTrackCue', 'TextTrackList', 'WebSocket', 'WebSocketWorker', 'Worker', 'XMLHttpRequest', 'XMLHttpRequestEventTarget', 'XMLHttpRequestUpload'], function (o) {\n if (!win[o] || !win[o].prototype || !Object.prototype.hasOwnProperty.call(win[o].prototype, 'addEventListener')) return;\n\n __proxy(win[o].prototype, 'addEventListener', function (original) {\n return __traceOriginalScript(original, eventTargetCallbackAccessor);\n });\n\n __proxy(win[o].prototype, 'removeEventListener', function (original) {\n return __traceOriginalScript(original, eventTargetCallbackAccessor, true);\n });\n });\n\n function __traceOriginalScript(fn, callbackAccessor, alsoCallOriginal) {\n if (alsoCallOriginal === void 0) {\n alsoCallOriginal = false;\n }\n\n return function () {\n // this is required for removeEventListener to remove anything added with\n // addEventListener before the functions started being wrapped by Bugsnag\n var args = [].slice.call(arguments);\n\n try {\n var cba = callbackAccessor(args);\n var cb = cba.get();\n if (alsoCallOriginal) fn.apply(this, args);\n if (typeof cb !== 'function') return fn.apply(this, args);\n\n if (cb.__trace__) {\n cba.replace(cb.__trace__);\n } else {\n var script = getCurrentScript(); // this function mustn't be annonymous due to a bug in the stack\n // generation logic, meaning it gets tripped up\n // see: https://github.com/stacktracejs/stack-generator/issues/6\n\n cb.__trace__ = function __trace__() {\n // set the script that called this function\n updateLastScript(script); // immediately unset the currentScript synchronously below, however\n // if this cb throws an error the line after will not get run so schedule\n // an almost-immediate aysnc update too\n\n _setTimeout(function () {\n updateLastScript(null);\n }, 0);\n\n var ret = cb.apply(this, arguments);\n updateLastScript(null);\n return ret;\n };\n\n cb.__trace__.__trace__ = cb.__trace__;\n cba.replace(cb.__trace__);\n }\n } catch (e) {// swallow these errors on Selenium:\n // Permission denied to access property '__trace__'\n // WebDriverException: Message: Permission denied to access property \"handleEvent\"\n } // IE8 doesn't let you call .apply() on setTimeout/setInterval\n\n\n if (fn.apply) return fn.apply(this, args);\n\n switch (args.length) {\n case 1:\n return fn(args[0]);\n\n case 2:\n return fn(args[0], args[1]);\n\n default:\n return fn();\n }\n };\n }\n },\n configSchema: {\n trackInlineScripts: {\n validate: function (value) {\n return value === true || value === false;\n },\n defaultValue: function () {\n return true;\n },\n message: 'should be true|false'\n }\n }\n };\n};\n\nfunction __proxy(host, name, replacer) {\n var original = host[name];\n if (!original) return original;\n var replacement = replacer(original);\n host[name] = replacement;\n return original;\n}\n\nfunction eventTargetCallbackAccessor(args) {\n var isEventHandlerObj = !!args[1] && typeof args[1].handleEvent === 'function';\n return {\n get: function () {\n return isEventHandlerObj ? args[1].handleEvent : args[1];\n },\n replace: function (fn) {\n if (isEventHandlerObj) {\n args[1].handleEvent = fn;\n } else {\n args[1] = fn;\n }\n }\n };\n}\n\n/*\n * Leaves breadcrumbs when the user interacts with the DOM\n */\nvar _$interactionBreadcrumbs_49 = function (win) {\n if (win === void 0) {\n win = window;\n }\n\n return {\n load: function (client) {\n if (!('addEventListener' in win)) return;\n if (!client._isBreadcrumbTypeEnabled('user')) return;\n win.addEventListener('click', function (event) {\n var targetText, targetSelector;\n\n try {\n targetText = getNodeText(event.target);\n targetSelector = getNodeSelector(event.target, win);\n } catch (e) {\n targetText = '[hidden]';\n targetSelector = '[hidden]';\n\n client._logger.error('Cross domain error when tracking click event. See docs: https://tinyurl.com/yy3rn63z');\n }\n\n client.leaveBreadcrumb('UI click', {\n targetText: targetText,\n targetSelector: targetSelector\n }, 'user');\n }, true);\n }\n };\n};\n\nvar trimStart = /^\\s+/;\nvar trimEnd = /(^|[^\\s])\\s+$/;\n\nfunction getNodeText(el) {\n var text = el.textContent || el.innerText || '';\n\n if (!text && (el.type === 'submit' || el.type === 'button')) {\n text = el.value;\n }\n\n text = text.replace(trimStart, '').replace(trimEnd, '$1');\n\n if (text.length > 140) {\n return text.slice(0, 135) + '(...)';\n }\n\n return text;\n} // Create a label from tagname, id and css class of the element\n\n\nfunction getNodeSelector(el, win) {\n var parts = [el.tagName];\n if (el.id) parts.push('#' + el.id);\n if (el.className && el.className.length) parts.push(\".\" + el.className.split(' ').join('.')); // Can't get much more advanced with the current browser\n\n if (!win.document.querySelectorAll || !Array.prototype.indexOf) return parts.join('');\n\n try {\n if (win.document.querySelectorAll(parts.join('')).length === 1) return parts.join('');\n } catch (e) {\n // Sometimes the query selector can be invalid just return it as-is\n return parts.join('');\n } // try to get a more specific selector if this one matches more than one element\n\n\n if (el.parentNode.childNodes.length > 1) {\n var index = Array.prototype.indexOf.call(el.parentNode.childNodes, el) + 1;\n parts.push(\":nth-child(\" + index + \")\");\n }\n\n if (win.document.querySelectorAll(parts.join('')).length === 1) return parts.join(''); // try prepending the parent node selector\n\n if (el.parentNode) return getNodeSelector(el.parentNode, win) + \" > \" + parts.join('');\n return parts.join('');\n}\n\nvar _$navigationBreadcrumbs_50 = {};\n/*\n* Leaves breadcrumbs when navigation methods are called or events are emitted\n*/\n_$navigationBreadcrumbs_50 = function (win) {\n if (win === void 0) {\n win = window;\n }\n\n var plugin = {\n load: function (client) {\n if (!('addEventListener' in win)) return;\n if (!client._isBreadcrumbTypeEnabled('navigation')) return; // returns a function that will drop a breadcrumb with a given name\n\n var drop = function (name) {\n return function () {\n return client.leaveBreadcrumb(name, {}, 'navigation');\n };\n }; // simple drops – just names, no meta\n\n\n win.addEventListener('pagehide', drop('Page hidden'), true);\n win.addEventListener('pageshow', drop('Page shown'), true);\n win.addEventListener('load', drop('Page loaded'), true);\n win.document.addEventListener('DOMContentLoaded', drop('DOMContentLoaded'), true); // some browsers like to emit popstate when the page loads, so only add the popstate listener after that\n\n win.addEventListener('load', function () {\n return win.addEventListener('popstate', drop('Navigated back'), true);\n }); // hashchange has some metadata that we care about\n\n win.addEventListener('hashchange', function (event) {\n var metadata = event.oldURL ? {\n from: relativeLocation(event.oldURL, win),\n to: relativeLocation(event.newURL, win),\n state: getCurrentState(win)\n } : {\n to: relativeLocation(win.location.href, win)\n };\n client.leaveBreadcrumb('Hash changed', metadata, 'navigation');\n }, true); // the only way to know about replaceState/pushState is to wrap them… >_<\n\n if (win.history.replaceState) wrapHistoryFn(client, win.history, 'replaceState', win);\n if (win.history.pushState) wrapHistoryFn(client, win.history, 'pushState', win);\n }\n };\n\n if (\"production\" !== 'production') {\n plugin.destroy = function (win) {\n if (win === void 0) {\n win = window;\n }\n\n win.history.replaceState._restore();\n\n win.history.pushState._restore();\n };\n }\n\n return plugin;\n};\n\nif (\"production\" !== 'production') {\n _$navigationBreadcrumbs_50.destroy = function (win) {\n if (win === void 0) {\n win = window;\n }\n\n win.history.replaceState._restore();\n\n win.history.pushState._restore();\n };\n} // takes a full url like http://foo.com:1234/pages/01.html?yes=no#section-2 and returns\n// just the path and hash parts, e.g. /pages/01.html?yes=no#section-2\n\n\nvar relativeLocation = function (url, win) {\n var a = win.document.createElement('A');\n a.href = url;\n return \"\" + a.pathname + a.search + a.hash;\n};\n\nvar stateChangeToMetadata = function (win, state, title, url) {\n var currentPath = relativeLocation(win.location.href, win);\n return {\n title: title,\n state: state,\n prevState: getCurrentState(win),\n to: url || currentPath,\n from: currentPath\n };\n};\n\nvar wrapHistoryFn = function (client, target, fn, win) {\n var orig = target[fn];\n\n target[fn] = function (state, title, url) {\n client.leaveBreadcrumb(\"History \" + fn, stateChangeToMetadata(win, state, title, url), 'navigation'); // if throttle plugin is in use, reset the event sent count\n\n if (typeof client.resetEventCount === 'function') client.resetEventCount(); // if the client is operating in auto session-mode, a new route should trigger a new session\n\n if (client._config.autoTrackSessions) client.startSession(); // Internet Explorer will convert `undefined` to a string when passed, causing an unintended redirect\n // to '/undefined'. therefore we only pass the url if it's not undefined.\n\n orig.apply(target, [state, title].concat(url !== undefined ? url : []));\n };\n\n if (\"production\" !== 'production') {\n target[fn]._restore = function () {\n target[fn] = orig;\n };\n }\n};\n\nvar getCurrentState = function (win) {\n try {\n return win.history.state;\n } catch (e) {}\n};\n\nvar BREADCRUMB_TYPE = 'request';\n\n/* removed: var _$includes_13 = require('@bugsnag/core/lib/es-utils/includes'); */;\n/*\n * Leaves breadcrumbs when network requests occur\n */\n\n\nvar _$networkBreadcrumbs_51 = function (_ignoredUrls, win) {\n if (_ignoredUrls === void 0) {\n _ignoredUrls = [];\n }\n\n if (win === void 0) {\n win = window;\n }\n\n var restoreFunctions = [];\n var plugin = {\n load: function (client) {\n if (!client._isBreadcrumbTypeEnabled('request')) return;\n var ignoredUrls = [client._config.endpoints.notify, client._config.endpoints.sessions].concat(_ignoredUrls);\n monkeyPatchXMLHttpRequest();\n monkeyPatchFetch(); // XMLHttpRequest monkey patch\n\n function monkeyPatchXMLHttpRequest() {\n if (!('addEventListener' in win.XMLHttpRequest.prototype)) return;\n var nativeOpen = win.XMLHttpRequest.prototype.open; // override native open()\n\n win.XMLHttpRequest.prototype.open = function open(method, url) {\n var _this = this;\n\n var requestSetupKey = false;\n\n var error = function () {\n return handleXHRError(method, url);\n };\n\n var load = function () {\n return handleXHRLoad(method, url, _this.status);\n }; // if we have already setup listeners, it means open() was called twice, we need to remove\n // the listeners and recreate them\n\n\n if (requestSetupKey) {\n this.removeEventListener('load', load);\n this.removeEventListener('error', error);\n } // attach load event listener\n\n\n this.addEventListener('load', load); // attach error event listener\n\n this.addEventListener('error', error);\n requestSetupKey = true;\n nativeOpen.apply(this, arguments);\n };\n\n if (\"production\" !== 'production') {\n restoreFunctions.push(function () {\n win.XMLHttpRequest.prototype.open = nativeOpen;\n });\n }\n }\n\n function handleXHRLoad(method, url, status) {\n if (url === undefined) {\n client._logger.warn('The request URL is no longer present on this XMLHttpRequest. A breadcrumb cannot be left for this request.');\n\n return;\n } // an XMLHttpRequest's URL can be an object as long as its 'toString'\n // returns a URL, e.g. a HTMLAnchorElement\n\n\n if (typeof url === 'string' && _$includes_13(ignoredUrls, url.replace(/\\?.*$/, ''))) {\n // don't leave a network breadcrumb from bugsnag notify calls\n return;\n }\n\n var metadata = {\n status: status,\n request: method + \" \" + url\n };\n\n if (status >= 400) {\n // contacted server but got an error response\n client.leaveBreadcrumb('XMLHttpRequest failed', metadata, BREADCRUMB_TYPE);\n } else {\n client.leaveBreadcrumb('XMLHttpRequest succeeded', metadata, BREADCRUMB_TYPE);\n }\n }\n\n function handleXHRError(method, url) {\n if (url === undefined) {\n client._logger.warn('The request URL is no longer present on this XMLHttpRequest. A breadcrumb cannot be left for this request.');\n\n return;\n }\n\n if (typeof url === 'string' && _$includes_13(ignoredUrls, url.replace(/\\?.*$/, ''))) {\n // don't leave a network breadcrumb from bugsnag notify calls\n return;\n } // failed to contact server\n\n\n client.leaveBreadcrumb('XMLHttpRequest error', {\n request: method + \" \" + url\n }, BREADCRUMB_TYPE);\n } // window.fetch monkey patch\n\n\n function monkeyPatchFetch() {\n // only patch it if it exists and if it is not a polyfill (patching a polyfilled\n // fetch() results in duplicate breadcrumbs for the same request because the\n // implementation uses XMLHttpRequest which is also patched)\n if (!('fetch' in win) || win.fetch.polyfill) return;\n var oldFetch = win.fetch;\n\n win.fetch = function fetch() {\n var _arguments = arguments;\n var urlOrRequest = arguments[0];\n var options = arguments[1];\n var method;\n var url = null;\n\n if (urlOrRequest && typeof urlOrRequest === 'object') {\n url = urlOrRequest.url;\n\n if (options && 'method' in options) {\n method = options.method;\n } else if (urlOrRequest && 'method' in urlOrRequest) {\n method = urlOrRequest.method;\n }\n } else {\n url = urlOrRequest;\n\n if (options && 'method' in options) {\n method = options.method;\n }\n }\n\n if (method === undefined) {\n method = 'GET';\n }\n\n return new Promise(function (resolve, reject) {\n // pass through to native fetch\n oldFetch.apply(void 0, _arguments).then(function (response) {\n handleFetchSuccess(response, method, url);\n resolve(response);\n })[\"catch\"](function (error) {\n handleFetchError(method, url);\n reject(error);\n });\n });\n };\n\n if (\"production\" !== 'production') {\n restoreFunctions.push(function () {\n win.fetch = oldFetch;\n });\n }\n }\n\n var handleFetchSuccess = function (response, method, url) {\n var metadata = {\n status: response.status,\n request: method + \" \" + url\n };\n\n if (response.status >= 400) {\n // when the request comes back with a 4xx or 5xx status it does not reject the fetch promise,\n client.leaveBreadcrumb('fetch() failed', metadata, BREADCRUMB_TYPE);\n } else {\n client.leaveBreadcrumb('fetch() succeeded', metadata, BREADCRUMB_TYPE);\n }\n };\n\n var handleFetchError = function (method, url) {\n client.leaveBreadcrumb('fetch() error', {\n request: method + \" \" + url\n }, BREADCRUMB_TYPE);\n };\n }\n };\n\n if (\"production\" !== 'production') {\n plugin.destroy = function () {\n restoreFunctions.forEach(function (fn) {\n return fn();\n });\n restoreFunctions = [];\n };\n }\n\n return plugin;\n};\n\n/* removed: var _$intRange_24 = require('@bugsnag/core/lib/validators/int-range'); */;\n/*\n * Throttles and dedupes events\n */\n\n\nvar _$throttle_52 = {\n load: function (client) {\n // track sent events for each init of the plugin\n var n = 0; // add onError hook\n\n client.addOnError(function (event) {\n // have max events been sent already?\n if (n >= client._config.maxEvents) {\n client._logger.warn(\"Cancelling event send due to maxEvents per session limit of \" + client._config.maxEvents + \" being reached\");\n\n return false;\n }\n\n n++;\n });\n\n client.resetEventCount = function () {\n n = 0;\n };\n },\n configSchema: {\n maxEvents: {\n defaultValue: function () {\n return 10;\n },\n message: 'should be a positive integer ≤100',\n validate: function (val) {\n return _$intRange_24(1, 100)(val);\n }\n }\n }\n};\n\nvar _$stripQueryString_53 = {};\n/*\n * Remove query strings (and fragments) from stacktraces\n */\n/* removed: var _$map_16 = require('@bugsnag/core/lib/es-utils/map'); */;\n\n/* removed: var _$reduce_17 = require('@bugsnag/core/lib/es-utils/reduce'); */;\n\n_$stripQueryString_53 = {\n load: function (client) {\n client.addOnError(function (event) {\n var allFrames = _$reduce_17(event.errors, function (accum, er) {\n return accum.concat(er.stacktrace);\n }, []);\n _$map_16(allFrames, function (frame) {\n frame.file = strip(frame.file);\n });\n });\n }\n};\n\nvar strip = _$stripQueryString_53._strip = function (str) {\n return typeof str === 'string' ? str.replace(/\\?.*$/, '').replace(/#.*$/, '') : str;\n};\n\n/*\n * Automatically notifies Bugsnag when window.onerror is called\n */\nvar _$onerror_54 = function (win, component) {\n if (win === void 0) {\n win = window;\n }\n\n if (component === void 0) {\n component = 'window onerror';\n }\n\n return {\n load: function (client) {\n if (!client._config.autoDetectErrors) return;\n if (!client._config.enabledErrorTypes.unhandledExceptions) return;\n\n function onerror(messageOrEvent, url, lineNo, charNo, error) {\n // Ignore errors with no info due to CORS settings\n if (lineNo === 0 && /Script error\\.?/.test(messageOrEvent)) {\n client._logger.warn('Ignoring cross-domain or eval script error. See docs: https://tinyurl.com/yy3rn63z');\n } else {\n // any error sent to window.onerror is unhandled and has severity=error\n var handledState = {\n severity: 'error',\n unhandled: true,\n severityReason: {\n type: 'unhandledException'\n }\n };\n var event; // window.onerror can be called in a number of ways. This big if-else is how we\n // figure out which arguments were supplied, and what kind of values it received.\n\n if (error) {\n // if the last parameter (error) was supplied, this is a modern browser's\n // way of saying \"this value was thrown and not caught\"\n event = client.Event.create(error, true, handledState, component, 1);\n decorateStack(event.errors[0].stacktrace, url, lineNo, charNo);\n } else if ( // This complex case detects \"error\" events that are typically synthesised\n // by jquery's trigger method (although can be created in other ways). In\n // order to detect this:\n // - the first argument (message) must exist and be an object (most likely it's a jQuery event)\n // - the second argument (url) must either not exist or be something other than a string (if it\n // exists and is not a string, it'll be the extraParameters argument from jQuery's trigger()\n // function)\n // - the third, fourth and fifth arguments must not exist (lineNo, charNo and error)\n typeof messageOrEvent === 'object' && messageOrEvent !== null && (!url || typeof url !== 'string') && !lineNo && !charNo && !error) {\n // The jQuery event may have a \"type\" property, if so use it as part of the error message\n var name = messageOrEvent.type ? \"Event: \" + messageOrEvent.type : 'Error'; // attempt to find a message from one of the conventional properties, but\n // default to empty string (the event will fill it with a placeholder)\n\n var message = messageOrEvent.message || messageOrEvent.detail || '';\n event = client.Event.create({\n name: name,\n message: message\n }, true, handledState, component, 1); // provide the original thing onerror received – not our error-like object we passed to _notify\n\n event.originalError = messageOrEvent; // include the raw input as metadata – it might contain more info than we extracted\n\n event.addMetadata(component, {\n event: messageOrEvent,\n extraParameters: url\n });\n } else {\n // Lastly, if there was no \"error\" parameter this event was probably from an old\n // browser that doesn't support that. Instead we need to generate a stacktrace.\n event = client.Event.create(messageOrEvent, true, handledState, component, 1);\n decorateStack(event.errors[0].stacktrace, url, lineNo, charNo);\n }\n\n client._notify(event);\n }\n\n if (typeof prevOnError === 'function') prevOnError.apply(this, arguments);\n }\n\n var prevOnError = win.onerror;\n win.onerror = onerror;\n }\n };\n}; // Sometimes the stacktrace has less information than was passed to window.onerror.\n// This function will augment the first stackframe with any useful info that was\n// received as arguments to the onerror callback.\n\n\nvar decorateStack = function (stack, url, lineNo, charNo) {\n if (!stack[0]) stack.push({});\n var culprit = stack[0];\n if (!culprit.file && typeof url === 'string') culprit.file = url;\n if (!culprit.lineNumber && isActualNumber(lineNo)) culprit.lineNumber = lineNo;\n\n if (!culprit.columnNumber) {\n if (isActualNumber(charNo)) {\n culprit.columnNumber = charNo;\n } else if (window.event && isActualNumber(window.event.errorCharacter)) {\n culprit.columnNumber = window.event.errorCharacter;\n }\n }\n};\n\nvar isActualNumber = function (n) {\n return typeof n === 'number' && String.call(n) !== 'NaN';\n};\n\n/* removed: var _$map_16 = require('@bugsnag/core/lib/es-utils/map'); */;\n\n/* removed: var _$iserror_20 = require('@bugsnag/core/lib/iserror'); */;\n\nvar _listener;\n/*\n * Automatically notifies Bugsnag when window.onunhandledrejection is called\n */\n\n\nvar _$unhandledRejection_55 = function (win) {\n if (win === void 0) {\n win = window;\n }\n\n var plugin = {\n load: function (client) {\n if (!client._config.autoDetectErrors || !client._config.enabledErrorTypes.unhandledRejections) return;\n\n var listener = function (evt) {\n var error = evt.reason;\n var isBluebird = false; // accessing properties on evt.detail can throw errors (see #394)\n\n try {\n if (evt.detail && evt.detail.reason) {\n error = evt.detail.reason;\n isBluebird = true;\n }\n } catch (e) {}\n\n var event = client.Event.create(error, false, {\n severity: 'error',\n unhandled: true,\n severityReason: {\n type: 'unhandledPromiseRejection'\n }\n }, 'unhandledrejection handler', 1, client._logger);\n\n if (isBluebird) {\n _$map_16(event.errors[0].stacktrace, fixBluebirdStacktrace(error));\n }\n\n client._notify(event, function (event) {\n if (_$iserror_20(event.originalError) && !event.originalError.stack) {\n var _event$addMetadata;\n\n event.addMetadata('unhandledRejection handler', (_event$addMetadata = {}, _event$addMetadata[Object.prototype.toString.call(event.originalError)] = {\n name: event.originalError.name,\n message: event.originalError.message,\n code: event.originalError.code\n }, _event$addMetadata));\n }\n });\n };\n\n if ('addEventListener' in win) {\n win.addEventListener('unhandledrejection', listener);\n } else {\n win.onunhandledrejection = function (reason, promise) {\n listener({\n detail: {\n reason: reason,\n promise: promise\n }\n });\n };\n }\n\n _listener = listener;\n }\n };\n\n if (\"production\" !== 'production') {\n plugin.destroy = function (win) {\n if (win === void 0) {\n win = window;\n }\n\n if (_listener) {\n if ('addEventListener' in win) {\n win.removeEventListener('unhandledrejection', _listener);\n } else {\n win.onunhandledrejection = null;\n }\n }\n\n _listener = null;\n };\n }\n\n return plugin;\n}; // The stack parser on bluebird stacks in FF get a suprious first frame:\n//\n// Error: derp\n// b@http://localhost:5000/bluebird.html:22:24\n// a@http://localhost:5000/bluebird.html:18:9\n// @http://localhost:5000/bluebird.html:14:9\n//\n// results in\n// […]\n// 0: Object { file: \"Error: derp\", method: undefined, lineNumber: undefined, … }\n// 1: Object { file: \"http://localhost:5000/bluebird.html\", method: \"b\", lineNumber: 22, … }\n// 2: Object { file: \"http://localhost:5000/bluebird.html\", method: \"a\", lineNumber: 18, … }\n// 3: Object { file: \"http://localhost:5000/bluebird.html\", lineNumber: 14, columnNumber: 9, … }\n//\n// so the following reduce/accumulator function removes such frames\n//\n// Bluebird pads method names with spaces so trim that too…\n// https://github.com/petkaantonov/bluebird/blob/b7f21399816d02f979fe434585334ce901dcaf44/src/debuggability.js#L568-L571\n\n\nvar fixBluebirdStacktrace = function (error) {\n return function (frame) {\n if (frame.file === error.toString()) return;\n\n if (frame.method) {\n frame.method = frame.method.replace(/^\\s+/, '');\n }\n };\n};\n\nvar _$notifier_2 = {};\nvar name = 'Bugsnag JavaScript';\nvar version = '7.20.2';\nvar url = 'https://github.com/bugsnag/bugsnag-js';\n\n/* removed: var _$Client_4 = require('@bugsnag/core/client'); */;\n\n/* removed: var _$Event_6 = require('@bugsnag/core/event'); */;\n\n/* removed: var _$Session_35 = require('@bugsnag/core/session'); */;\n\n/* removed: var _$Breadcrumb_3 = require('@bugsnag/core/breadcrumb'); */;\n\n/* removed: var _$map_16 = require('@bugsnag/core/lib/es-utils/map'); */;\n\n/* removed: var _$keys_15 = require('@bugsnag/core/lib/es-utils/keys'); */;\n\n/* removed: var _$assign_11 = require('@bugsnag/core/lib/es-utils/assign'); */; // extend the base config schema with some browser-specific options\n\n\nvar __schema_2 = _$assign_11({}, _$config_5.schema, _$config_1);\n\n/* removed: var _$onerror_54 = require('@bugsnag/plugin-window-onerror'); */;\n\n/* removed: var _$unhandledRejection_55 = require('@bugsnag/plugin-window-unhandled-rejection'); */;\n\n/* removed: var _$app_38 = require('@bugsnag/plugin-app-duration'); */;\n\n/* removed: var _$device_40 = require('@bugsnag/plugin-browser-device'); */;\n\n/* removed: var _$context_39 = require('@bugsnag/plugin-browser-context'); */;\n\n/* removed: var _$request_44 = require('@bugsnag/plugin-browser-request'); */;\n\n/* removed: var _$throttle_52 = require('@bugsnag/plugin-simple-throttle'); */;\n\n/* removed: var _$consoleBreadcrumbs_47 = require('@bugsnag/plugin-console-breadcrumbs'); */;\n\n/* removed: var _$networkBreadcrumbs_51 = require('@bugsnag/plugin-network-breadcrumbs'); */;\n\n/* removed: var _$navigationBreadcrumbs_50 = require('@bugsnag/plugin-navigation-breadcrumbs'); */;\n\n/* removed: var _$interactionBreadcrumbs_49 = require('@bugsnag/plugin-interaction-breadcrumbs'); */;\n\n/* removed: var _$inlineScriptContent_48 = require('@bugsnag/plugin-inline-script-content'); */;\n\n/* removed: var _$session_45 = require('@bugsnag/plugin-browser-session'); */;\n\n/* removed: var _$clientIp_46 = require('@bugsnag/plugin-client-ip'); */;\n\n/* removed: var _$stripQueryString_53 = require('@bugsnag/plugin-strip-query-string'); */; // delivery mechanisms\n\n\n/* removed: var _$delivery_36 = require('@bugsnag/delivery-x-domain-request'); */;\n\n/* removed: var _$delivery_37 = require('@bugsnag/delivery-xml-http-request'); */;\n\nvar Bugsnag = {\n _client: null,\n createClient: function (opts) {\n // handle very simple use case where user supplies just the api key as a string\n if (typeof opts === 'string') opts = {\n apiKey: opts\n };\n if (!opts) opts = {};\n var internalPlugins = [// add browser-specific plugins\n _$app_38, _$device_40(), _$context_39(), _$request_44(), _$throttle_52, _$session_45, _$clientIp_46, _$stripQueryString_53, _$onerror_54(), _$unhandledRejection_55(), _$navigationBreadcrumbs_50(), _$interactionBreadcrumbs_49(), _$networkBreadcrumbs_51(), _$consoleBreadcrumbs_47, // this one added last to avoid wrapping functionality before bugsnag uses it\n _$inlineScriptContent_48()]; // configure a client with user supplied options\n\n var bugsnag = new _$Client_4(opts, __schema_2, internalPlugins, {\n name: name,\n version: version,\n url: url\n }); // set delivery based on browser capability (IE 8+9 have an XDomainRequest object)\n\n bugsnag._setDelivery(window.XDomainRequest ? _$delivery_36 : _$delivery_37);\n\n bugsnag._logger.debug('Loaded!');\n\n bugsnag.leaveBreadcrumb('Bugsnag loaded', {}, 'state');\n return bugsnag._config.autoTrackSessions ? bugsnag.startSession() : bugsnag;\n },\n start: function (opts) {\n if (Bugsnag._client) {\n Bugsnag._client._logger.warn('Bugsnag.start() was called more than once. Ignoring.');\n\n return Bugsnag._client;\n }\n\n Bugsnag._client = Bugsnag.createClient(opts);\n return Bugsnag._client;\n },\n isStarted: function () {\n return Bugsnag._client != null;\n }\n};\n_$map_16(['resetEventCount'].concat(_$keys_15(_$Client_4.prototype)), function (m) {\n if (/^_/.test(m)) return;\n\n Bugsnag[m] = function () {\n if (!Bugsnag._client) return console.log(\"Bugsnag.\" + m + \"() was called before Bugsnag.start()\");\n Bugsnag._client._depth += 1;\n\n var ret = Bugsnag._client[m].apply(Bugsnag._client, arguments);\n\n Bugsnag._client._depth -= 1;\n return ret;\n };\n});\n_$notifier_2 = Bugsnag;\n_$notifier_2.Client = _$Client_4;\n_$notifier_2.Event = _$Event_6;\n_$notifier_2.Session = _$Session_35;\n_$notifier_2.Breadcrumb = _$Breadcrumb_3; // Export a \"default\" property for compatibility with ESM imports\n\n_$notifier_2[\"default\"] = Bugsnag;\n\nreturn _$notifier_2;\n\n});\n//# sourceMappingURL=bugsnag.js.map\n","(function(f){if(typeof exports===\"object\"&&typeof module!==\"undefined\"){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.BugsnagPluginReact = f()}})(function(){var define,module,exports;\nvar _$src_1 = {};\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n_$src_1 = /*#__PURE__*/function () {\n function BugsnagPluginReact() {\n // Fetch React from the window object, if it exists\n var globalReact = typeof window !== 'undefined' && window.React;\n this.name = 'react';\n this.lazy = arguments.length === 0 && !globalReact;\n\n if (!this.lazy) {\n this.React = (arguments.length <= 0 ? undefined : arguments[0]) || globalReact;\n if (!this.React) throw new Error('@bugsnag/plugin-react reference to `React` was undefined');\n }\n }\n\n var _proto = BugsnagPluginReact.prototype;\n\n _proto.load = function load(client) {\n if (!this.lazy) {\n var ErrorBoundary = createClass(this.React, client);\n\n ErrorBoundary.createErrorBoundary = function () {\n return ErrorBoundary;\n };\n\n return ErrorBoundary;\n }\n\n var BugsnagPluginReactLazyInitializer = function () {\n throw new Error(\"@bugsnag/plugin-react was used incorrectly. Valid usage is as follows:\\nPass React to the plugin constructor\\n\\n `Bugsnag.start({ plugins: [new BugsnagPluginReact(React)] })`\\nand then call `const ErrorBoundary = Bugsnag.getPlugin('react').createErrorBoundary()`\\n\\nOr if React is not available until after Bugsnag has started,\\nconstruct the plugin with no arguments\\n `Bugsnag.start({ plugins: [new BugsnagPluginReact()] })`,\\nthen pass in React when available to construct your error boundary\\n `const ErrorBoundary = Bugsnag.getPlugin('react').createErrorBoundary(React)`\");\n };\n\n BugsnagPluginReactLazyInitializer.createErrorBoundary = function (React) {\n if (!React) throw new Error('@bugsnag/plugin-react reference to `React` was undefined');\n return createClass(React, client);\n };\n\n return BugsnagPluginReactLazyInitializer;\n };\n\n return BugsnagPluginReact;\n}();\n\nvar formatComponentStack = function (str) {\n var lines = str.split(/\\s*\\n\\s*/g);\n var ret = '';\n\n for (var line = 0, len = lines.length; line < len; line++) {\n if (lines[line].length) ret += \"\" + (ret.length ? '\\n' : '') + lines[line];\n }\n\n return ret;\n};\n\nvar createClass = function (React, client) {\n return /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(ErrorBoundary, _React$Component);\n\n function ErrorBoundary(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this;\n _this.state = {\n error: null,\n info: null\n };\n _this.handleClearError = _this.handleClearError.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n var _proto2 = ErrorBoundary.prototype;\n\n _proto2.handleClearError = function handleClearError() {\n this.setState({\n error: null,\n info: null\n });\n };\n\n _proto2.componentDidCatch = function componentDidCatch(error, info) {\n var onError = this.props.onError;\n var handledState = {\n severity: 'error',\n unhandled: true,\n severityReason: {\n type: 'unhandledException'\n }\n };\n var event = client.Event.create(error, true, handledState, 1);\n if (info && info.componentStack) info.componentStack = formatComponentStack(info.componentStack);\n event.addMetadata('react', info);\n\n client._notify(event, onError);\n\n this.setState({\n error: error,\n info: info\n });\n };\n\n _proto2.render = function render() {\n var error = this.state.error;\n\n if (error) {\n var FallbackComponent = this.props.FallbackComponent;\n if (FallbackComponent) return React.createElement(FallbackComponent, _extends({}, this.state, {\n clearError: this.handleClearError\n }));\n return null;\n }\n\n return this.props.children;\n };\n\n return ErrorBoundary;\n }(React.Component);\n};\n\n_$src_1.formatComponentStack = formatComponentStack;\n_$src_1[\"default\"] = _$src_1;\n\nreturn _$src_1;\n\n});\n//# sourceMappingURL=bugsnag-react.js.map\n","import { UnavailabilityError } from 'expo-modules-core';\nimport { useEffect, useState } from 'react';\nimport { Platform } from 'react-native';\nimport NativeLinking from './ExpoLinking';\nimport { parse } from './createURL';\nimport { validateURL } from './validateURL';\n// @needsAudit\n/**\n * Add a handler to `Linking` changes by listening to the `url` event type and providing the handler.\n * It is recommended to use the [`useURL()`](#useurl) hook instead.\n * @param type The only valid type is `'url'`.\n * @param handler An [`URLListener`](#urllistener) function that takes an `event` object of the type\n * [`EventType`](#eventype).\n * @return An EmitterSubscription that has the remove method from EventSubscription\n * @see [React Native Docs Linking page](https://reactnative.dev/docs/linking#addeventlistener).\n */\nexport function addEventListener(type, handler) {\n return NativeLinking.addEventListener(type, handler);\n}\n// @needsAudit\n/**\n * Helper method which wraps React Native's `Linking.getInitialURL()` in `Linking.parse()`.\n * Parses the deep link information out of the URL used to open the experience initially.\n * If no link opened the app, all the fields will be `null`.\n * > On the web it parses the current window URL.\n * @return A promise that resolves with `ParsedURL` object.\n */\nexport async function parseInitialURLAsync() {\n const initialUrl = await NativeLinking.getInitialURL();\n if (!initialUrl) {\n return {\n scheme: null,\n hostname: null,\n path: null,\n queryParams: null,\n };\n }\n return parse(initialUrl);\n}\n// @needsAudit\n/**\n * Launch an Android intent with extras.\n * > Use [IntentLauncher](./intent-launcher) instead, `sendIntent` is only included in\n * > `Linking` for API compatibility with React Native's Linking API.\n * @platform android\n */\nexport async function sendIntent(action, extras) {\n if (Platform.OS === 'android') {\n return await NativeLinking.sendIntent(action, extras);\n }\n throw new UnavailabilityError('Linking', 'sendIntent');\n}\n// @needsAudit\n/**\n * Open the operating system settings app and displays the app’s custom settings, if it has any.\n */\nexport async function openSettings() {\n if (Platform.OS === 'web') {\n throw new UnavailabilityError('Linking', 'openSettings');\n }\n if (NativeLinking.openSettings) {\n return await NativeLinking.openSettings();\n }\n await openURL('app-settings:');\n}\n// @needsAudit\n/**\n * Get the URL that was used to launch the app if it was launched by a link.\n * @return The URL string that launched your app, or `null`.\n */\nexport async function getInitialURL() {\n return (await NativeLinking.getInitialURL()) ?? null;\n}\n// @needsAudit\n/**\n * Attempt to open the given URL with an installed app. See the [Linking guide](/guides/linking)\n * for more information.\n * @param url A URL for the operating system to open, eg: `tel:5555555`, `exp://`.\n * @return A `Promise` that is fulfilled with `true` if the link is opened operating system\n * automatically or the user confirms the prompt to open the link. The `Promise` rejects if there\n * are no applications registered for the URL or the user cancels the dialog.\n */\nexport async function openURL(url) {\n validateURL(url);\n return await NativeLinking.openURL(url);\n}\n// @needsAudit\n/**\n * Determine whether or not an installed app can handle a given URL.\n * On web this always returns `true` because there is no API for detecting what URLs can be opened.\n * @param url The URL that you want to test can be opened.\n * @return A `Promise` object that is fulfilled with `true` if the URL can be handled, otherwise it\n * `false` if not.\n *\n * The `Promise` will reject on Android if it was impossible to check if the URL can be opened, and\n * on iOS if you didn't [add the specific scheme in the `LSApplicationQueriesSchemes` key inside **Info.plist**](/guides/linking#linking-from-your-app).\n */\nexport async function canOpenURL(url) {\n validateURL(url);\n return await NativeLinking.canOpenURL(url);\n}\n// @needsAudit\n/**\n * Returns the initial URL followed by any subsequent changes to the URL.\n * @return Returns the initial URL or `null`.\n */\nexport function useURL() {\n const [url, setLink] = useState(null);\n function onChange(event) {\n setLink(event.url);\n }\n useEffect(() => {\n getInitialURL().then((url) => setLink(url));\n const subscription = addEventListener('url', onChange);\n return () => subscription.remove();\n }, []);\n return url;\n}\nexport * from './Linking.types';\nexport * from './Schemes';\nexport { parse, createURL } from './createURL';\n//# sourceMappingURL=Linking.js.map","import invariant from 'invariant';\nconst listeners = [];\nexport default {\n addEventListener(type, listener) {\n // Do nothing in Node.js environments\n if (typeof window === 'undefined') {\n return { remove() { } };\n }\n invariant(type === 'url', `Linking.addEventListener(): ${type} is not a valid event`);\n const nativeListener = (nativeEvent) => listener({ url: window.location.href, nativeEvent });\n listeners.push({ listener, nativeListener });\n window.addEventListener('message', nativeListener, false);\n return {\n remove: () => {\n this.removeEventListener(type, listener);\n },\n };\n },\n removeEventListener(type, listener) {\n // Do nothing in Node.js environments\n if (typeof window === 'undefined') {\n return;\n }\n invariant(type === 'url', `Linking.addEventListener(): ${type} is not a valid event`);\n const listenerIndex = listeners.findIndex((pair) => pair.listener === listener);\n invariant(listenerIndex !== -1, 'Linking.removeEventListener(): cannot remove an unregistered event listener.');\n const nativeListener = listeners[listenerIndex].nativeListener;\n window.removeEventListener('message', nativeListener, false);\n listeners.splice(listenerIndex, 1);\n },\n async canOpenURL() {\n // In reality this should be able to return false for links like `chrome://` on chrome.\n return true;\n },\n async getInitialURL() {\n if (typeof window === 'undefined')\n return '';\n return window.location.href;\n },\n async openURL(url) {\n if (typeof window !== 'undefined') {\n // @ts-ignore\n window.location = new URL(url, window.location).toString();\n }\n },\n};\n//# sourceMappingURL=ExpoLinking.web.js.map","export function createURL(path, { queryParams = {} } = {}) {\n if (typeof window === 'undefined')\n return '';\n const url = new URL(path, window.location.origin);\n Object.entries(queryParams).forEach(([key, value]) => {\n if (typeof value === 'string') {\n url.searchParams.set(key, encodeURIComponent(value));\n }\n else if (value != null) {\n url.searchParams.set(key, \n // @ts-expect-error: browser supports using array\n value);\n }\n });\n return url.toString().replace(/\\/$/, '');\n}\nexport function parse(url) {\n let parsed;\n try {\n parsed = new URL(url);\n }\n catch {\n if (typeof window === 'undefined') {\n return {\n hostname: null,\n path: url,\n queryParams: {},\n scheme: null,\n };\n }\n return {\n hostname: 'localhost',\n path: url,\n queryParams: {},\n scheme: 'http',\n };\n }\n const queryParams = {};\n parsed.searchParams.forEach((value, key) => {\n queryParams[key] = decodeURIComponent(value);\n });\n return {\n hostname: parsed.hostname || null,\n // TODO: We should probably update native to follow the default URL behavior closer.\n path: !parsed.hostname && !parsed.pathname\n ? null\n : parsed.pathname === ''\n ? null\n : parsed.pathname.replace(/^\\//, ''),\n queryParams,\n scheme: parsed.protocol.replace(/:$/, ''),\n };\n}\n//# sourceMappingURL=createURL.web.js.map","import invariant from 'invariant';\nexport function validateURL(url) {\n invariant(typeof url === 'string', 'Invalid URL: should be a string. Was: ' + url);\n invariant(url, 'Invalid URL: cannot be empty');\n}\n//# sourceMappingURL=validateURL.js.map","export {};\n//# sourceMappingURL=Linking.types.js.map","export function hasCustomScheme() {\n return true;\n}\nexport function collectManifestSchemes() {\n return [];\n}\nexport function hasConstantsManifest() {\n return false;\n}\nexport function resolveScheme() {\n return 'https';\n}\n//# sourceMappingURL=Schemes.web.js.map","import ChangeEmailStepper from \"@common/account/ChangeEmailStepper\"\nimport SubscribtionContinuity from \"@common/account/SubscribtionContinuity\"\nimport ChapterFeelingQuiz from \"@common/chapters/feeling-quiz/ChapterFeelingQuiz\"\nimport CallStudentsStepper from \"@common/liveMode/CallStudentsStepper\"\nimport EndSessionScreen from \"@common/liveMode/EndSessionScreen\"\nimport EndSessionScreenStudent from \"@common/liveMode/EndSessionScreenStudent\"\nimport LaunchLiveScreen from \"@common/liveMode/LaunchLiveScreen\"\nimport LiveReportScreen from \"@common/liveMode/live-report/LiveReportScreen\"\nimport LiveMainLayout from \"@common/liveMode/LiveMainLayout\"\nimport PreCallScreen from \"@common/liveMode/PreCallScreen\"\nimport SatisfactionScreen from \"@common/liveMode/SatisfactionScreen\"\nimport TodoCheck from \"@common/liveMode/TodoCheck\"\nimport Analytics from \"../../admin/Analytics\"\nimport TutorApplicationDetailsScreen from \"../../admin/applications/TutorApplicationDetailsScreen\"\nimport TutorsApplicationsTabNavigator from \"../../admin/applications/TutorsApplicationsTabNavigator\"\nimport AssignTutor from \"../../admin/AssignTutor\"\nimport AssignTutorAndLives from \"../../admin/AssignTutorAndLives\"\nimport ChangePrivileges from \"../../admin/ChangePrivileges\"\nimport NewInterviewReportScreen from \"../../admin/interviewReports/NewInterviewReportScreen\"\nimport AcceptSubstitution from \"../../admin/live/AcceptSubstitution\"\nimport AddUsersToLiveStepper from \"../../admin/live/AddUsersToLiveStepper\"\nimport LivesHistoryScreen from \"../../admin/live/live-history/LivesHistoryScreen\"\nimport LiveReportsScreen from \"../../admin/live/LiveReportsScreen\"\nimport LiveShow from \"../../admin/live/LiveShow\"\nimport LivesScreen from \"../../admin/live/LivesScreen\"\nimport LiveStepper from \"../../admin/live/LiveStepper\"\nimport RescheduleLive from \"../../admin/live/RescheduleLive\"\nimport AddUsersToSessions from \"../../admin/live/rooms/AddUsersToSessions\"\nimport CreateEditRoom from \"../../admin/live/rooms/CreateEditRoom\"\nimport NewSessions from \"../../admin/live/rooms/NewSessions\"\nimport RoomsScreen from \"../../admin/live/rooms/RoomsScreen\"\nimport MetricsTabNavigator from \"../../admin/metrics/MetricsTabNavigator\"\nimport NewSubscriptionScreen from \"../../admin/NewSubscriptionScreen\"\nimport NewWeeklyReportScreen from \"../../admin/NewWeeklyReportScreen\"\nimport ReferralCodeScreen from \"../../admin/ReferralCodeScreen\"\nimport CreateEditReferralCode from \"../../admin/referrals/CreateEditReferralCode\"\nimport SendWeeklyReportScreen from \"../../admin/SendWeeklyReportScreen\"\nimport CreateEditStudyProgram from \"../../admin/studyPrograms/CreateEditStudyProgram\"\nimport AssignStudentTrial from \"../../admin/trials/AssignStudentTrial\"\nimport StudentsTrialTabScreen from \"../../admin/trials/StudentsTrialTabScreen\"\nimport AssignAdmin from \"../../admin/tutors/AssignAdmin\"\nimport FixSalaryScreen from \"../../admin/tutors/FixSalaryScreen\"\nimport TutorsScreen from \"../../admin/tutors/TutorsScreen\"\nimport UpdateMaxStudentsPerLive from \"../../admin/tutors/UpdateMaxStudentsPerLive\"\nimport UsersTabScreen from \"../../admin/UsersTabScreen\"\nimport { AccountTypeScreen } from \"../../auth/AccountTypeScreen\"\nimport { AuthNavigator } from \"../../auth/AuthNavigator\"\nimport AvailabilitySlotsScreen from \"../../auth/AvailabilitySlotsScreen\"\nimport EmailVerifyScreen from \"../../auth/EmailVerifyScreen\"\nimport ForgotPassword from \"../../auth/ForgotPassword\"\nimport LoginScreen from \"../../auth/LoginScreen\"\nimport PrioritySchoolSubjectsScreen from \"../../auth/PrioritizedSchoolSubjectsScreen\"\nimport RegisterNewScreen from \"../../auth/RegisterNewScreen\"\nimport RegisterReturnScreen from \"../../auth/RegisterReturnScreen\"\nimport RegisterScreen from \"../../auth/RegisterScreen\"\nimport ResetPasswordScreen from \"../../auth/ResetPasswordScreen\"\nimport SubscribeRedirectScreen from \"../../auth/SubscribeRedirectScreen\"\nimport SubscribeReturnScreen from \"../../auth/SubscribeReturnScreen\"\nimport SubscribeScreen from \"../../auth/SubscribeScreen\"\nimport TutorRegisterScreen from \"../../auth/TutorRegisterScreen\"\nimport ConfirmQuizzScreen from \"../../quiz/ConfirmQuizzScreen\"\nimport NewQuizzScreen from \"../../quiz/NewQuizzScreen\"\nimport ActivityReviewScreen from \"../../reviewer/ActivityReviewScreen\"\nimport NewScoringCommentScreen from \"../../reviewer/NewScoringCommentScreen\"\nimport NewScoringRuleScreen from \"../../reviewer/NewScoringRuleScreen\"\nimport ScanLoadingScreen from \"../../school-card-report/scan/ScanLoadingScreen\"\nimport ScanScreen from \"../../school-card-report/scan/ScanScreen\"\nimport Schools from \"../../school/Schools\"\nimport SchoolScreen from \"../../school/SchoolScreen\"\nimport AbsenceFormComponent from \"../../student/absence/AbsenceFormComponent\"\nimport CancelAbsenceFormComponent from \"../../student/absence/CancelAbsenceFormComponent\"\nimport RecoverFormComponent from \"../../student/absence/RecoverFormComponent\"\nimport JoinClassroomScreen from \"../../student/account/classroom/JoinClassroomScreen\"\nimport JoinSchoolScreen from \"../../student/account/classroom/JoinSchoolScreen\"\nimport UpdateClassScreen from \"../../student/account/classroom/UpdateClassScreen\"\nimport CreateAvatarScreen from \"../../student/account/CreateAvatarScreen\"\nimport DeleteAccountScreen from \"../../student/account/DeleteAccountScreen\"\nimport MyProfileTabScreen from \"../../student/account/MyAccountScreen\"\nimport TrialSessionPreparationForm from \"../../student/account/onboarding/preparation-form/TrialSessionPreparationForm\"\nimport RegisterSpecialScreen from \"../../student/account/onboarding/RegisterSpecialScreen\"\nimport RegisterTrialScreen from \"../../student/account/onboarding/RegisterTrialScreen\"\nimport RegisterTrialSessionScreen from \"../../student/account/onboarding/RegisterTrialSessionScreen\"\nimport RegisterWorkshopScreen from \"../../student/account/onboarding/RegisterWorkshopScreen\"\nimport SchoolSubjectForm from \"../../student/account/onboarding/SchoolSubjectForm\"\nimport StudentEvaluationForm from \"../../student/account/onboarding/StudentEvaluationForm\"\nimport TrialOnboardingScreen from \"../../student/account/onboarding/TrialOnboardingScreen\"\nimport MyAccountTabNavigation from \"../../student/account/SettingsTabNavigator\"\nimport SponsorshipScreen from \"../../student/account/SponsorshipScreen\"\nimport MySubscriptionScreen from \"../../student/account/subscription/MySubscriptionScreen\"\nimport UpdatePasswordScreen from \"../../student/account/UpdatePasswordScreen\"\nimport AllActivities from \"../../student/activity/AllActivities\"\nimport ActivityScreen from \"../../student/activity/execute/ActivityScreen\"\nimport ActivityPresentationScreen from \"../../student/activity/read/ActivityPresentationScreen\"\nimport ActivityResultScreen from \"../../student/activity/read/ActivityResultScreen\"\nimport NewTodoScreen from \"../../student/activity/todo/NewTodoScreen\"\nimport TodoListByChapterScreen from \"../../student/activity/todo/TodoListByChapterScreen\"\nimport ChampionIntroScreen from \"../../student/champions/ChampionIntroScreen\"\nimport ZoeIntroScreen from \"../../student/champions/ZoeIntroScreen\"\nimport LeagueHistoryScreen from \"../../student/league/LeagueHistoryScreen\"\nimport LeagueProgressScreen from \"../../student/league/LeagueProgressScreen\"\nimport ManageMaterialScreen from \"../../student/material/ManageMaterialScreen\"\nimport MaterialDetails from \"../../student/material/MaterialDetails\"\nimport ChallengeHistoryScreen from \"../../student/organize/challenges/ChallengeHistoryScreen\"\nimport NewChallengeScreen from \"../../student/organize/challenges/NewChallengeScreen\"\nimport StudentTabsNavigator from \"../../student/organize/StudentTabsNavigator\"\nimport MyProgressScreen from \"../../student/progress/my progress/MyProgressScreen\"\nimport MyPetalsTabScreen from \"../../student/shop/MyPetalsTabScreen\"\nimport ProfilAmi from \"../../student/social/ProfilFriendScreen\"\nimport ShareStatsScreen from \"../../student/social/ShareStatsScreen\"\nimport ClassroomNewChallenge from \"../../teacher/classrooms/ClassroomNewChallenge\"\nimport Classrooms from \"../../teacher/classrooms/Classrooms\"\nimport ClassroomScreen from \"../../teacher/classrooms/ClassroomScreen\"\nimport NewClassroomStepper from \"../../teacher/classrooms/NewClassroomStepper\"\nimport MotivationInterviewScreen from \"../../tutor/application/motivation/InterviewScreen\"\nimport VideoRecordingScreen from \"../../tutor/application/motivation/VideoRecordingScreen\"\nimport ApplicationPersonalInfos from \"../../tutor/application/personalInfos/ApplicationPersonalInfos\"\nimport TutorApplicationScreen from \"../../tutor/application/TutorApplicationScreen\"\nimport CompleteTutorProfileStepper from \"../../tutor/home/CompleteTutorProfileStepper\"\nimport Interview from \"../../tutor/home/interview/Interview\"\nimport InterviewSummary from \"../../tutor/home/interview/InterviewSummary\"\nimport InterviewHistory from \"../../tutor/home/InterviewHistory\"\nimport SubstitutionProposalScreen from \"../../tutor/home/substitution/SubstitutionProposalScreen\"\nimport BrowseActivities from \"../../tutor/home/tutorResources/BrowseActivites\"\nimport TutorVideos from \"../../tutor/home/tutorResources/TutorVideos\"\nimport TutoringInvoicesScreen from \"../../tutor/invoices/TutoringInvoicesScreen\"\nimport TutorLivesHistoryScreen from \"../../tutor/lives/live-history/TutorLivesHistoryScreen\"\nimport ManageRDVScreen from \"../../tutor/lives/ManageRDVScreen\"\nimport TutorNextLivesListScreen from \"../../tutor/lives/TutorNextLivesListScreen\"\nimport NewNoteScreen from \"../../tutor/notes/NewNoteScreen\"\nimport StudentNotesScreen from \"../../tutor/notes/StudentNotesScreen\"\nimport SlotUpdateScreen from \"../../tutor/SlotUpdateScreen\"\nimport StudentProfil from \"../../tutor/students/StudentProfil\"\nimport TutorSlotsScreen from \"../../tutor/TutorSlotsScreen\"\nimport ValidateEmailScreen from \"../account/ValidateEmailScreen\"\nimport CameraScreen from \"../camera/CameraScreen\"\nimport InterviewReportScreen from \"../interviewReports/InterviewReportScreen\"\nimport InterviewReportsScreen from \"../interviewReports/InterviewReportsScreen\"\nimport LiveChat from \"../liveMode/LiveChat\"\nimport LiveParticipants from \"../liveMode/LiveParticipants\"\nimport BottomTabsNavigator from \"../main-menu/BottomTabsNavigator\"\nimport TchatScreen from \"../messenger/ChatScreen\"\nimport CongratsScreen from \"../screens/CongratsScreen\"\nimport StudyProgramScreen from \"../studyPrograms/studyProgramScreen\"\nimport StudyProgramsScreen from \"../studyPrograms/StudyProgramsScreen\"\n\nimport { theme } from \"@common/theme/theme\"\nimport CTAScreen from \"../../school-card-report/cta/CTAScreen\"\nimport DiagnosticScreen from \"../../school-card-report/diagnostic/DiagnosticScreen\"\nimport MotivationSeeMoreScreen from \"../../school-card-report/diagnostic/see-more/MotivationSeeMoreScreen\"\nimport PerformanceRankingScreen from \"../../school-card-report/diagnostic/see-more/PerformanceRankingScreen\"\nimport StyleSeeMoreScreen from \"../../school-card-report/diagnostic/see-more/StyleSeeMoreScreen\"\nimport SendImageComponent from \"../messenger/SendImageComponent\"\nimport BulletPointsSeeMoreScreen from \"../../school-card-report/diagnostic/see-more/BulletPointsSeeMoreScreen\";\n/**\n * Main screens\n *\n * @type [{component: ((function({navigation: *}): *)|*), name: string, options: {animationTypeForReplace: string}}, {component: *, name: string}, {component: *, name: string}]\n */\nconst main = [\n // ** Main menu\n {\n name: \"menu\",\n titles: [\n {\n main: {\n component: BottomTabsNavigator,\n },\n },\n {\n live: {\n component: LiveMainLayout,\n options: {\n headerShown: true,\n headerTitle: \"LIVE\",\n },\n },\n },\n {\n auth: {\n component: AuthNavigator,\n options: {\n animationTypeForReplace: \"pop\",\n headerShown: false,\n headerTitle: \"Accueil\",\n },\n },\n },\n ],\n },\n // ** common\n {\n name: \"pre-call\",\n component: PreCallScreen,\n options: {\n headerTitle: \"Rejoindre le Live\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"subscribe\",\n component: SubscribeScreen,\n options: {\n headerShown: false,\n headerTitle: \"Abonnement\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"prioritized-school-subjects\",\n component: PrioritySchoolSubjectsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Matières prioritaires\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"availability-slots\",\n component: AvailabilitySlotsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Disponibilités\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"subscribe/redirect\",\n component: SubscribeRedirectScreen,\n options: {\n headerShown: false,\n headerTitle: \"Abonnement\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"subscribe/return\",\n component: SubscribeReturnScreen,\n options: {\n headerShown: false,\n headerTitle: \"Abonnement\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"email/verify/:id/:hash\",\n component: EmailVerifyScreen,\n options: {\n headerShown: false,\n headerTitle: \"Vérification de l'email\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"r\",\n component: LiveReportScreen,\n options: {\n headerShown: false,\n headerTitle: \"Rapport de LIVE\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"live-reports\",\n component: LiveReportsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Rapports de LIVE\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n // ** LIVE\n {\n name: \"launch-live\",\n component: LaunchLiveScreen,\n options: {\n headerShown: true,\n headerTitle: \"LaunchLive\",\n },\n titles: [{ live: {} }],\n },\n {\n name: \"call-students-stepper\",\n component: CallStudentsStepper,\n options: {\n headerShown: true,\n headerTitle: \"Appeler\",\n },\n titles: [{ live: {} }],\n },\n //Leave session\n {\n name: \"end-session-tutor\",\n component: EndSessionScreen,\n options: {\n headerShown: false,\n headerTitle: \"LIVE clôturé\",\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"end-session-student\",\n component: EndSessionScreenStudent,\n options: {\n headerShown: false,\n headerTitle: \"Clôturer le LIVE\",\n },\n titles: [{ live: {} }],\n },\n {\n name: \"live-satisfaction\",\n component: SatisfactionScreen,\n options: {\n headerShown: false,\n headerTitle: \"Satisfaction de l'élève\",\n },\n titles: [{ main: {}, live: {} }],\n },\n // ** Tutor students\n {\n name: \"student\",\n component: StudentTabsNavigator,\n options: {\n headerShown: false,\n headerTitle: \"Elève\",\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"student-profil\",\n component: StudentProfil,\n options: {\n headerTitle: \"Profil\",\n headerShown: false,\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"interview-summary\",\n component: InterviewSummary,\n options: {\n headerTitle: \"Relecture avant envoi\",\n headerShown: false,\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"interview\",\n component: Interview,\n options: {\n headerTitle: \"Entretien\",\n headerShown: false,\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"interviewHistory\",\n component: InterviewHistory,\n options: {\n headerTitle: \"Entretiens\",\n headerShown: false,\n },\n titles: [\n { main: {} },\n {\n live: {\n options: {\n headerTitle: \"Entretiens\",\n headerShown: true,\n },\n },\n },\n ],\n },\n {\n name: \"browse-activities\",\n component: BrowseActivities,\n options: {\n headerTitle: \"Référentiel des activités\",\n headerShown: false,\n },\n titles: [\n { main: {} },\n {\n live: {\n options: {\n headerTitle: \"Référentiel des activités\",\n headerShown: true,\n },\n },\n },\n ],\n },\n {\n name: \"videos-coaching\",\n component: TutorVideos,\n options: {\n headerTitle: \"Vidéos de formation\",\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"update-occupied-slots\",\n component: SlotUpdateScreen,\n options: {\n headerTitle: \"Modifier un créneau\",\n headerShown: false,\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"student-notes\",\n component: StudentNotesScreen,\n options: {\n headerTitle: \"Notes du Masteur\",\n headerShown: false,\n },\n titles: [\n { main: {} },\n {\n live: {\n options: {\n headerTitle: \"Notes du Masteur\",\n headerShown: true,\n },\n },\n },\n ],\n },\n {\n name: \"new-note\",\n component: NewNoteScreen,\n options: {\n headerTitle: \"Nouvelle note\",\n headerShown: false,\n },\n titles: [\n { main: {} },\n {\n live: {\n options: {\n headerTitle: \"Nouvelle note\",\n headerShown: true,\n },\n },\n },\n ],\n },\n {\n name: \"weeklyReport\",\n component: NewWeeklyReportScreen,\n options: {\n headerTitle: \"Nouveau rapport\",\n headerShown: true,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"interview-reports\",\n component: InterviewReportsScreen,\n options: {\n headerTitle: \"Liste des entretiens parent\",\n headerShown: false,\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"ir\",\n component: InterviewReportScreen,\n options: {\n headerTitle: \"Rapport hebdo\",\n headerShown: false,\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"interview-report\",\n component: NewInterviewReportScreen,\n options: {\n headerTitle: \"Entretien parent\",\n headerShown: false,\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"send-weekly-report\",\n component: SendWeeklyReportScreen,\n options: {\n headerTitle: \"Envoyer rapport\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"tutor-application\",\n component: TutorApplicationScreen,\n options: {\n headerTitle: \"Candidature tuteur\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"application-personal-infos\",\n component: ApplicationPersonalInfos,\n options: {\n headerTitle: \"Information personnelle\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"application-interview\",\n component: MotivationInterviewScreen,\n options: {\n headerTitle: \"Entretien de motivation\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"video-recording\",\n component: VideoRecordingScreen,\n options: {\n headerTitle: \"Enregistrement\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n\n // ** Reviewer\n {\n name: \"activity-review\",\n component: ActivityReviewScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Revue d'activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Revue d'activité\",\n },\n },\n },\n ],\n },\n {\n name: \"new-scoring-comment\",\n component: NewScoringCommentScreen,\n options: {\n headerShown: false,\n headerTitle: \"Nouveau commentaire\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-scoring-rule\",\n component: NewScoringRuleScreen,\n options: {\n headerShown: false,\n headerTitle: \"Nouvelle règle\",\n },\n titles: [{ main: {} }],\n },\n // ** School\n {\n name: \"schools\",\n component: Schools,\n options: {\n headerTitle: \"Ecoles\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"school\",\n component: SchoolScreen,\n options: {\n headerTitle: \"École\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n // ** Teacher\n {\n name: \"new-classroom\",\n component: NewClassroomStepper,\n options: {\n headerShown: false,\n headerTitle: \"Nouvelle classe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"classrooms\",\n component: Classrooms,\n options: {\n headerShown: false,\n headerTitle: \"Classes\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"classroom\",\n component: ClassroomScreen,\n options: {\n headerShown: false,\n headerTitle: \"Classe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-challenge-classroom\",\n component: ClassroomNewChallenge,\n options: {\n headerShown: false,\n headerTitle: \"Nouveau défis\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"tutor-lives-history\",\n component: TutorLivesHistoryScreen,\n options: {\n headerShown: false,\n headerTitle: \"Historique des lives\",\n },\n titles: [{ main: {} }],\n },\n // ** Student home\n {\n name: \"my-privileges\",\n component: MySubscriptionScreen,\n options: {\n headerShown: true,\n headerTitle: \"Mes privilèges\",\n },\n titles: [{ main: {} }],\n },\n // ** Student challenges / school subjects\n {\n name: \"challenges-history\",\n component: ChallengeHistoryScreen,\n titles: [\n {\n main: {\n options: {\n headerTitle: \"Historique défis\",\n headerShown: false,\n },\n },\n },\n {\n live: {\n options: {\n headerTitle: \"Historique défis\",\n headerShown: true,\n },\n },\n },\n ],\n },\n // ** Student activity\n {\n name: \"activity-presentation\",\n component: ActivityPresentationScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Présentation activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Présentation activité\",\n },\n },\n },\n ],\n },\n {\n name: \"activity-result\",\n component: ActivityResultScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Résultat activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Résultat activité\",\n },\n },\n },\n ],\n },\n {\n name: \"activity\",\n component: ActivityScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Activité\",\n },\n },\n },\n ],\n },\n {\n name: \"share-stats\",\n component: ShareStatsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Partager mes statistiques\",\n },\n titles: [{ main: {}, live: {} }],\n },\n\n // ** Study programs\n {\n name: \"study-program\",\n component: StudyProgramScreen,\n options: {\n headerShown: false,\n headerTitle: \"Programme d'étude\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"study-programs\",\n component: StudyProgramsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Programmes de révision\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-study-program\",\n component: CreateEditStudyProgram,\n options: {\n headerShown: false,\n headerTitle: \"Nouveau programme d'étude\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"trial-backoffice\",\n component: StudentsTrialTabScreen,\n options: {\n headerShown: false,\n headerTitle: \"Gestion des essais\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"assign-trial\",\n component: AssignStudentTrial,\n options: {\n headerShown: false,\n headerTitle: \"Attribuer\",\n },\n titles: [{ main: {} }],\n },\n\n // ** Profile\n {\n name: \"account\",\n component: MyProfileTabScreen,\n options: {\n headerShown: true,\n headerTitle: \"Mon compte\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"settings\",\n component: MyAccountTabNavigation,\n options: {\n headerShown: false,\n headerTitle: \"Paramètres\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-slots\",\n component: TutorSlotsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Modifier mes créneaux\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-class\",\n component: UpdateClassScreen,\n options: {\n headerShown: false,\n headerTitle: \"Modifier ma classe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"tutor/complete-profile\",\n component: CompleteTutorProfileStepper,\n options: {\n headerShown: false,\n headerTitle: \"Compléter mon profil tuteur\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"account-password\",\n component: UpdatePasswordScreen,\n options: {\n headerTitle: \"Mot de passe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"account-close\",\n component: DeleteAccountScreen,\n options: {\n headerTitle: \"Fermer mon compte\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"join-classroom\",\n component: JoinClassroomScreen,\n options: {\n headerTitle: \"Rejoindre une classe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"join-school\",\n component: JoinSchoolScreen,\n options: {\n headerTitle: \"Rejoindre une école\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"sponsorship\",\n component: SponsorshipScreen,\n options: {\n headerShown: false,\n headerTitle: \"Parrainage\",\n },\n titles: [{ main: {} }],\n },\n // ** Common\n {\n name: \"camera\",\n component: CameraScreen,\n options: {\n headerShown: false,\n headerTitle: \"Caméra\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"metrics\",\n component: MetricsTabNavigator,\n options: {\n headerShown: false,\n headerTitle: \"Dashboard\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"messenger\",\n component: TchatScreen,\n options: {\n headerShown: false,\n headerTitle: \"Messages\",\n },\n titles: [\n { main: {} },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Messages\",\n },\n },\n },\n ],\n },\n {\n name: \"Profile\",\n component: ProfilAmi,\n options: {\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"Historique\",\n component: LeagueHistoryScreen,\n options: {\n headerShown: true,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"League_progress\",\n component: LeagueProgressScreen,\n options: {\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"skill-set\",\n component: MyProgressScreen,\n options: {\n headerShown: false,\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"shop\",\n component: MyPetalsTabScreen,\n options: {\n headerShown: false,\n headerTitle: \"Boutique de gestes\",\n },\n titles: [\n {\n main: {},\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Boutique de gestes\",\n },\n },\n },\n ],\n },\n {\n name: \"all-activities\",\n component: AllActivities,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Toutes les activités\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Toutes les activités\",\n },\n },\n },\n ],\n },\n {\n name: \"avatar\",\n component: CreateAvatarScreen,\n options: {\n headerShown: true,\n headerTitle: \"Personnalise ton avatar\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"todos-by-chapter\",\n component: TodoListByChapterScreen,\n options: {\n headerShown: false,\n },\n titles: [{ main: {}, live: {} }],\n },\n {\n name: \"new-todo\",\n component: NewTodoScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Nouvelle activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Nouvelle activité\",\n },\n },\n },\n ],\n },\n {\n name: \"new-material\",\n component: ManageMaterialScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Nouvel énoncé\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Nouvel énoncé\",\n },\n },\n },\n ],\n },\n {\n name: \"update-material\",\n component: ManageMaterialScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Modifier énoncé\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Modifier énoncé\",\n },\n },\n },\n ],\n },\n {\n name: \"material-details\",\n component: MaterialDetails,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Énoncé\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Énoncé\",\n },\n },\n },\n ],\n },\n // {\n // name: \"pause-resume-subscription\",\n // component: SubscribtionSuspension,\n // options: {\n // headerShown: false,\n // headerTitle: \"Suspension abonnement\"\n // },\n // titles: [{\"main\": {}}, {\"auth\": {}}]\n // },\n {\n name: \"subscription-continuity\",\n component: SubscribtionContinuity,\n options: {\n headerShown: false,\n headerTitle: \"Suite de l'abonnement\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n // admin\n {\n name: \"analytics\",\n component: Analytics,\n options: {\n headerShown: true,\n headerTitle: \"Analytics\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"lives-history\",\n component: LivesHistoryScreen,\n options: {\n headerShown: false,\n headerTitle: \"Historique des lives\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"admin-live-reports\",\n component: LiveReportsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Rapports de LIVE\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"new-referral-code\",\n component: CreateEditReferralCode,\n options: {\n headerShown: false,\n headerTitle: \"Nouveau code d'affiliation\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"referrer/dashboard/:h\",\n component: ReferralCodeScreen,\n options: {\n headerShown: false,\n headerTitle: \"Mes affiliations\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"admin-users\",\n component: UsersTabScreen,\n options: {\n headerShown: false,\n headerTitle: \"Liste des utilisateurs\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"admin-lives\",\n component: LivesScreen,\n options: {\n headerShown: false,\n headerTitle: \"Liste des LIVES\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"lives-form\",\n component: LiveStepper,\n options: {\n headerShown: false,\n headerTitle: \"Configurer un LIVE\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"live-show\",\n component: LiveShow,\n options: {\n headerShown: false,\n headerTitle: \"Consulter un LIVE\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"add-user-live\",\n component: AddUsersToLiveStepper,\n options: {\n headerShown: false,\n headerTitle: \"Ajouter un utilisateur au live\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"assign-master-lives\",\n component: AssignTutorAndLives,\n options: {\n headerShown: false,\n headerTitle: \"Attribuer un élève\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"assign-tutor\",\n component: AssignTutor,\n options: {\n headerShown: false,\n headerTitle: \"Attribuer un Masteur\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"change-privileges\",\n component: ChangePrivileges,\n options: {\n headerShown: false,\n headerTitle: \"Modifier les privilèges\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"rooms\",\n component: RoomsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Liste des LIVES\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-room\",\n component: CreateEditRoom,\n options: {\n headerShown: false,\n headerTitle: \"Nouvelle salle\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"add-members-to-sessions\",\n component: AddUsersToSessions,\n options: {\n headerShown: false,\n headerTitle: \"Ajouter des membres\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-sessions\",\n component: NewSessions,\n options: {\n headerShown: false,\n headerTitle: \"Créer des sessions\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"next-lives\",\n component: TutorNextLivesListScreen,\n options: {\n headerShown: false,\n headerTitle: \"Mes prochains Lives\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"move-session\",\n component: ManageRDVScreen,\n options: {\n headerShown: false,\n headerTitle: \"Déplacer live\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"absence-form\",\n component: AbsenceFormComponent,\n options: {\n headerShown: false,\n headerTitle: \"Signaler une absence\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"recover-absence\",\n component: RecoverFormComponent,\n options: {\n headerShown: false,\n headerTitle: \"Rattraper une absence\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"cancel-absence\",\n component: CancelAbsenceFormComponent,\n options: {\n headerShown: false,\n headerTitle: \"Annuler une absence\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"tutors-applications\",\n component: TutorsApplicationsTabNavigator,\n options: {\n headerShown: false,\n headerTitle: \"Candidature des tuteurs\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"application-details\",\n component: TutorApplicationDetailsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Candidature\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"manage-tutors\",\n component: TutorsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Tuteurs\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-salary\",\n component: FixSalaryScreen,\n options: {\n headerShown: false,\n headerTitle: \"Mettre à jour le salaire\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-max-students-live\",\n component: UpdateMaxStudentsPerLive,\n options: {\n headerShown: false,\n headerTitle: \"Maximum d'élèves par LIVE\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"assign-admin\",\n component: AssignAdmin,\n options: {\n headerShown: false,\n headerTitle: \"Assigner un admin\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"reschedule-live\",\n component: RescheduleLive,\n options: {\n headerShown: false,\n headerTitle: \"Assigner un admin\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"accept-substitution\",\n component: AcceptSubstitution,\n options: {\n headerShown: false,\n headerTitle: \"Assigner un admin\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"quizz\",\n component: NewQuizzScreen,\n options: {\n headerShown: false,\n headerTitle: \"Lancer un quiz\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"quizz-confirm\",\n component: ConfirmQuizzScreen,\n options: {\n headerShown: false,\n headerTitle: \"Lancer un quiz\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"new-student\",\n component: RegisterScreen,\n options: {\n headerShown: false,\n headerTitle: \"Créer élève\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"offer-essential\",\n component: TrialOnboardingScreen,\n options: {\n headerShown: false,\n headerTitle: \"Offre Essentielle\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"start-trial\",\n component: RegisterTrialSessionScreen,\n options: {\n headerShown: false,\n headerTitle: \"Essai gratuit\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"trial-student-evaluation\",\n component: StudentEvaluationForm,\n options: {\n headerShown: false,\n headerTitle: \"évaluation\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"trial-school-subjects\",\n component: SchoolSubjectForm,\n options: {\n headerShown: false,\n headerTitle: \"\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"trial-preparation-form\",\n component: TrialSessionPreparationForm,\n options: {\n headerShown: false,\n headerTitle: \"\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"start-trial/confirm\",\n component: RegisterTrialScreen,\n options: {\n headerShown: false,\n headerTitle: \"Essai gratuit\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"validate-email\",\n component: ValidateEmailScreen,\n options: {\n headerShown: false,\n headerTitle: \"Validation email\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"edit-email\",\n component: ChangeEmailStepper,\n options: {\n headerShown: false,\n headerTitle: \"Modifier email\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"intro-zoe\",\n component: ZoeIntroScreen,\n options: {\n headerShown: false,\n headerTitle: \"Introduction\",\n },\n titles: [\"studentFirstChallenge\"],\n },\n {\n name: \"new-challenge\",\n component: NewChallengeScreen,\n options: {\n headerShown: true,\n headerTitle: \"Nouveau défi\",\n },\n titles: [\n \"studentFirstChallenge\",\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Nouveau défi\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Nouveau défi\",\n },\n },\n },\n ],\n },\n {\n name: \"presence\",\n component: LiveParticipants,\n options: {\n headerShown: false,\n headerTitle: \"LIVE\",\n },\n titles: [{ live: {} }],\n },\n {\n name: \"messages\",\n component: LiveChat,\n options: {\n headerShown: false,\n headerTitle: \"LIVE Messages\",\n },\n titles: [{ live: {} }],\n },\n {\n name: \"new-subscription\",\n component: NewSubscriptionScreen,\n options: {\n headerShown: false,\n headerTitle: \"Créer un abonnement\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-subscription\",\n component: NewSubscriptionScreen,\n options: {\n headerShown: false,\n headerTitle: \"Modifier un abonnement\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"school-card-report\",\n component: ScanScreen,\n options: {\n headerShown: false,\n detachPreviousScreen: false,\n },\n titles: [{ main: {}, auth: {} }],\n },\n {\n name: \"school-card-report/loading\",\n component: ScanLoadingScreen,\n options: {\n headerShown: false,\n detachPreviousScreen: false,\n },\n titles: [{ main: {}, auth: {} }],\n },\n {\n name: \"school-card-report/diagnostic\",\n component: DiagnosticScreen,\n options: {\n headerShown: false,\n detachPreviousScreen: false,\n },\n titles: [{ main: {}, auth: {} }],\n },\n {\n name: \"school-card-report/diagnostic/performance/ranking\",\n component: PerformanceRankingScreen,\n options: {\n headerShown: false,\n detachPreviousScreen: false,\n },\n titles: [{ main: {}, auth: {} }],\n },\n {\n name: \"school-card-report/diagnostic/motivation/see-more\",\n component: MotivationSeeMoreScreen,\n options: {\n headerShown: false,\n detachPreviousScreen: false,\n },\n titles: [{ main: {}, auth: {} }],\n },\n {\n name: \"school-card-report/diagnostic/style/see-more\",\n component: StyleSeeMoreScreen,\n options: {\n headerShown: false,\n detachPreviousScreen: false,\n },\n titles: [{ main: {}, auth: {} }],\n },\n {\n name: \"school-card-report/diagnostic/bullet-points/see-more\",\n component: BulletPointsSeeMoreScreen,\n options: {\n headerShown: false,\n detachPreviousScreen: false,\n },\n titles: [{ main: {}, auth: {} }],\n },\n {\n name: \"school-card-report/cta\",\n component: CTAScreen,\n options: {\n headerShown: false,\n detachPreviousScreen: false,\n },\n titles: [{ main: {}, auth: {} }],\n },\n /* {\n // ** Reviewer\n {\n name: \"activity-review\",\n component: ActivityReviewScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Revue d'activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Revue d'activité\",\n },\n },\n },\n ],\n },\n {\n name: \"new-scoring-comment\",\n component: NewScoringCommentScreen,\n options: {\n headerShown: false,\n headerTitle: \"Nouveau commentaire\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-scoring-rule\",\n component: NewScoringRuleScreen,\n options: {\n headerShown: false,\n headerTitle: \"Nouvelle règle\",\n },\n titles: [{ main: {} }],\n },\n // ** School\n {\n name: \"schools\",\n component: Schools,\n options: {\n headerTitle: \"Ecoles\",\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"school\",\n component: SchoolScreen,\n options: {\n headerTitle: \"École\",\n },\n titles: [{ main: {} }],\n },\n // ** Teacher\n {\n name: \"new-classroom\",\n component: NewClassroomStepper,\n options: {\n headerShown: false,\n headerTitle: \"Nouvelle classe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"classrooms\",\n component: Classrooms,\n options: {\n headerShown: false,\n headerTitle: \"Classes\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"classroom\",\n component: ClassroomScreen,\n options: {\n headerShown: false,\n headerTitle: \"Classe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-challenge-classroom\",\n component: ClassroomNewChallenge,\n options: {\n headerShown: false,\n headerTitle: \"Nouveau défis\",\n },\n titles: [{ main: {} }],\n },\n // ** Student home\n {\n name: \"my-privileges\",\n component: MySubscriptionScreen,\n options: {\n headerShown: true,\n headerTitle: \"Mes privilèges\",\n },\n titles: [{ main: {} }],\n },\n // ** Student challenges / school subjects\n {\n name: \"challenges-history\",\n component: ChallengeHistoryScreen,\n titles: [\n {\n main: {\n options: {\n headerTitle: \"Historique défis\",\n headerShown: false,\n },\n },\n },\n {\n live: {\n options: {\n headerTitle: \"Historique défis\",\n headerShown: true,\n },\n },\n },\n ],\n },\n // ** Student activity\n {\n name: \"activity-presentation\",\n component: ActivityPresentationScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Présentation activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Présentation activité\",\n },\n },\n },\n ],\n },\n {\n name: \"activity-result\",\n component: ActivityResultScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Résultat activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Résultat activité\",\n },\n },\n },\n ],\n },\n {\n name: \"activity\",\n component: ActivityScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Activité\",\n },\n },\n },\n ],\n },\n {\n name: \"share-stats\",\n component: ShareStatsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Partager mes statistiques\",\n },\n titles: [{ main: {}, live: {} }],\n },\n // ** Profile\n {\n name: \"account\",\n component: MyProfileTabScreen,\n options: {\n headerShown: true,\n headerTitle: \"Mon compte\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"settings\",\n component: MyAccountTabNavigation,\n options: {\n headerShown: false,\n headerTitle: \"Paramètres\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-slots\",\n component: TutorSlotsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Modifier mes créneaux\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-class\",\n component: UpdateClassScreen,\n options: {\n headerShown: false,\n headerTitle: \"Modifier ma classe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"tutor/complete-profile\",\n component: CompleteTutorProfileStepper,\n options: {\n headerShown: false,\n headerTitle: \"Compléter mon profil tuteur\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"account-password\",\n component: UpdatePasswordScreen,\n options: {\n headerTitle: \"Mot de passe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"account-close\",\n component: DeleteAccountScreen,\n options: {\n headerTitle: \"Fermer mon compte\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"join-classroom\",\n component: JoinClassroomScreen,\n options: {\n headerTitle: \"Rejoindre une classe\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"join-school\",\n component: JoinSchoolScreen,\n options: {\n headerTitle: \"Rejoindre une école\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"sponsorship\",\n component: SponsorshipScreen,\n options: {\n headerShown: false,\n headerTitle: \"Parrainage\",\n },\n titles: [{ main: {} }],\n },\n // ** Common\n {\n name: \"camera\",\n component: CameraScreen,\n options: {\n headerShown: false,\n headerTitle: \"Caméra\",\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"metrics\",\n component: MetricsTabNavigator,\n options: {\n headerShown: false,\n headerTitle: \"Dashboard\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"messenger\",\n component: TchatScreen,\n options: {\n headerShown: false,\n headerTitle: \"Messages\",\n },\n titles: [\n { main: {} },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Messages\",\n },\n },\n },\n ],\n },\n {\n name: \"Profile\",\n component: ProfilAmi,\n options: {\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"Historique\",\n component: LeagueHistoryScreen,\n options: {\n headerShown: true,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"League_progress\",\n component: LeagueProgressScreen,\n options: {\n headerShown: false,\n },\n titles: [{ main: {} }],\n },\n {\n name: \"skill-set\",\n component: MyProgressScreen,\n options: {\n headerShown: true,\n headerTitle: \"Mes quêtes\",\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"shop\",\n component: MyPetalsTabScreen,\n options: {\n headerShown: false,\n headerTitle: \"Boutique de gestes\",\n },\n titles: [\n {\n main: {},\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Boutique de gestes\",\n },\n },\n },\n ],\n },\n {\n name: \"all-activities\",\n component: AllActivities,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Toutes les activités\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Toutes les activités\",\n },\n },\n },\n ],\n },\n {\n name: \"avatar\",\n component: CreateAvatarScreen,\n options: {\n headerShown: true,\n headerTitle: \"Personnalise ton avatar\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-todo\",\n component: NewTodoScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Nouvelle activité\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Nouvelle activité\",\n },\n },\n },\n ],\n },\n {\n name: \"new-material\",\n component: ManageMaterialScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Nouvel énoncé\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Nouvel énoncé\",\n },\n },\n },\n ],\n },\n {\n name: \"update-material\",\n component: ManageMaterialScreen,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Modifier énoncé\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Modifier énoncé\",\n },\n },\n },\n ],\n },\n {\n name: \"material-details\",\n component: MaterialDetails,\n titles: [\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Énoncé\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Énoncé\",\n },\n },\n },\n ],\n },\n // {\n // name: \"pause-resume-subscription\",\n // component: SubscribtionSuspension,\n // options: {\n // headerShown: false,\n // headerTitle: \"Suspension abonnement\"\n // },\n // titles: [{\"main\": {}}, {\"auth\": {}}]\n // },\n {\n name: \"subscription-continuity\",\n component: SubscribtionContinuity,\n options: {\n headerShown: false,\n headerTitle: \"Suite de l'abonnement\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n // admin\n {\n name: \"analytics\",\n component: Analytics,\n options: {\n headerShown: true,\n headerTitle: \"Analytics\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"admin-live-reports\",\n component: LiveReportsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Rapports de LIVE\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"new-referral-code\",\n component: CreateEditReferralCode,\n options: {\n headerShown: false,\n headerTitle: \"Nouveau code d'affiliation\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"referrer/dashboard/:h\",\n component: ReferralCodeScreen,\n options: {\n headerShown: false,\n headerTitle: \"Mes affiliations\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"admin-users\",\n component: UsersTabScreen,\n options: {\n headerShown: false,\n headerTitle: \"Liste des utilisateurs\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"admin-lives\",\n component: LivesScreen,\n options: {\n headerShown: false,\n headerTitle: \"Liste des LIVES\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"lives-form\",\n component: LiveStepper,\n options: {\n headerShown: false,\n headerTitle: \"Configurer un LIVE\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"live-show\",\n component: LiveShow,\n options: {\n headerShown: false,\n headerTitle: \"Consulter un LIVE\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"add-user-live\",\n component: AddUsersToSessions,\n options: {\n headerShown: false,\n headerTitle: \"Ajouter un utilisateur au live\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"assign-master-lives\",\n component: AssignTutorAndLives,\n options: {\n headerShown: false,\n headerTitle: \"Attribuer un élève\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"assign-tutor\",\n component: AssignTutor,\n options: {\n headerShown: false,\n headerTitle: \"Attribuer un Masteur\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"change-privileges\",\n component: ChangePrivileges,\n options: {\n headerShown: false,\n headerTitle: \"Modifier les privilèges\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"rooms\",\n component: RoomsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Liste des LIVES\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-room\",\n component: CreateEditRoom,\n options: {\n headerShown: false,\n headerTitle: \"Nouvelle salle\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"add-members-to-sessions\",\n component: AddUsersToSessions,\n options: {\n headerShown: false,\n headerTitle: \"Ajouter des membres\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"new-sessions\",\n component: NewSessions,\n options: {\n headerShown: false,\n headerTitle: \"Créer des sessions\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"tutors-applications\",\n component: TutorsApplicationsTabNavigator,\n options: {\n headerShown: false,\n headerTitle: \"Candidature des tuteurs\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"application-details\",\n component: TutorApplicationDetailsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Candidature\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"manage-tutors\",\n component: TutorsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Tuteurs\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-salary\",\n component: FixSalaryScreen,\n options: {\n headerShown: false,\n headerTitle: \"Mettre à jour le salaire\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"update-max-students-live\",\n component: UpdateMaxStudentsPerLive,\n options: {\n headerShown: false,\n headerTitle: \"Maximum d'élèves par LIVE\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"assign-admin\",\n component: AssignAdmin,\n options: {\n headerShown: false,\n headerTitle: \"Assigner un admin\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"reschedule-live\",\n component: RescheduleLive,\n options: {\n headerShown: false,\n headerTitle: \"Assigner un admin\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"accept-substitution\",\n component: AcceptSubstitution,\n options: {\n headerShown: false,\n headerTitle: \"Assigner un admin\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"quizz\",\n component: NewQuizzScreen,\n options: {\n headerShown: false,\n headerTitle: \"Lancer un quiz\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"quizz-confirm\",\n component: ConfirmQuizzScreen,\n options: {\n headerShown: false,\n headerTitle: \"Lancer un quiz\",\n },\n titles: [{ main: {} }, { auth: {} }],\n },\n {\n name: \"new-student\",\n component: RegisterScreen,\n options: {\n headerShown: false,\n headerTitle: \"Créer élève\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"offer-essential\",\n component: TrialOnboardingScreen,\n options: {\n headerShown: false,\n headerTitle: \"Offre Essentielle\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"start-trial\",\n component: RegisterTrialSessionScreen,\n options: {\n headerShown: false,\n headerTitle: \"Essai gratuit\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"start-trial/confirm\",\n component: RegisterTrialScreen,\n options: {\n headerShown: false,\n headerTitle: \"Essai gratuit\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"validate-email\",\n component: ValidateEmailScreen,\n options: {\n headerShown: false,\n headerTitle: \"Validation email\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"edit-email\",\n component: ChangeEmailStepper,\n options: {\n headerShown: false,\n headerTitle: \"Modifier email\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"intro-zoe\",\n component: ZoeIntroScreen,\n options: {\n headerShown: false,\n headerTitle: \"Introduction\",\n },\n titles: [\"studentFirstChallenge\"],\n },\n {\n name: \"new-challenge\",\n component: NewChallengeScreen,\n options: {\n headerShown: true,\n headerTitle: \"Nouveau défi\",\n },\n titles: [\n \"studentFirstChallenge\",\n {\n main: {\n options: {\n headerShown: false,\n headerTitle: \"Nouveau défi\",\n },\n },\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Nouveau défi\",\n },\n },\n },\n ],\n },\n {\n name: \"presence\",\n component: LiveParticipants,\n options: {\n headerShown: true,\n headerTitle: \"LIVE\",\n },\n titles: [{ live: {} }],\n },\n {\n name: \"messages\",\n component: LiveChat,\n options: {\n headerShown: true,\n headerTitle: \"LIVE Messages\",\n },\n titles: [{ live: {} }],\n },\n /* {\n name: \"presentation\",\n component: IntroScreen,\n options: {\n headerShown: false,\n headerTitle: \"Présentation\"\n },\n titles: [\"auth\"]\n },*/\n {\n name: \"account-type\",\n component: AccountTypeScreen,\n options: {\n headerShown: false,\n headerTitle: \"Créer un compte\",\n },\n titles: [{ auth: {} }],\n },\n {\n name: \"register-tutor\",\n component: TutorRegisterScreen,\n options: {\n headerShown: false,\n headerTitle: \"Inscription\",\n },\n titles: [{ auth: {} }],\n },\n {\n name: \"login\",\n component: LoginScreen,\n options: {\n headerShown: false,\n headerTitle: \"Connexion\",\n },\n titles: [{ auth: {} }],\n },\n {\n name: \"register\",\n component: RegisterNewScreen,\n options: {\n headerShown: false,\n headerTitle: \"Inscription\",\n },\n // deepLinkConfig: {\n // platform: \"web&mobile\",\n // downloadRequired: false,\n // downloadBanner: false,\n // },\n titles: [{ auth: {} }],\n },\n {\n name: \"register-trial\",\n component: RegisterTrialSessionScreen,\n options: {\n headerShown: false,\n headerTitle: \"Inscription\",\n },\n titles: [\n { auth: {} },\n {\n menu: {\n component: RegisterReturnScreen,\n },\n },\n ],\n },\n {\n name: \"register-holidays\",\n component: RegisterTrialSessionScreen,\n options: {\n headerShown: false,\n headerTitle: \"Inscription vacances\",\n },\n titles: [\n { auth: {} },\n {\n menu: {\n component: RegisterReturnScreen,\n },\n },\n ],\n },\n {\n name: \"register-special\",\n component: RegisterSpecialScreen,\n options: {\n headerShown: false,\n headerTitle: \"Inscription Live Spécial\",\n },\n titles: [{ auth: {} }, { menu: {} }],\n },\n {\n name: \"register-workshop\",\n component: RegisterWorkshopScreen,\n options: {\n headerShown: false,\n headerTitle: \"Inscription Live Atelier\",\n },\n titles: [{ auth: {} }, { menu: {} }],\n },\n {\n name: \"register-trial/confirm\",\n component: RegisterTrialScreen,\n options: {\n headerShown: false,\n headerTitle: \"Inscription\",\n },\n titles: [{ auth: {} }],\n },\n {\n name: \"reset-password\",\n component: ForgotPassword,\n options: {\n headerShown: true,\n headerTitle: \"Mot de passe oublié\",\n },\n titles: [{ auth: {} }],\n },\n {\n name: \"password/reset/:passwordToken\",\n component: ResetPasswordScreen,\n options: {\n headerShown: false,\n headerTitle: \"Nouveau mot de passe\",\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"congrats\",\n component: CongratsScreen,\n options: {\n headerShown: false,\n headerTitle: \"Félicitations\",\n cardStyle: { backgroundColor: theme.colors.white },\n },\n titles: [{ main: {} }, { live: {} }, { auth: {} }],\n },\n {\n name: \"feeling\",\n component: ChapterFeelingQuiz,\n options: {\n headerShown: false,\n headerTitle: \"Questionnaire\",\n cardStyle: { backgroundColor: theme.colors.white },\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"todo-check\",\n component: TodoCheck,\n options: {\n headerShown: false,\n headerTitle: \"vérifier todos\",\n cardStyle: { backgroundColor: theme.colors.white },\n },\n titles: [{ live: {} }],\n },\n {\n name: \"image-chat\",\n component: SendImageComponent,\n options: {\n headerShown: false,\n headerTitle: \"image\",\n },\n titles: [{ main: {} }, { live: {} }],\n },\n {\n name: \"intro\",\n component: ChampionIntroScreen,\n options: {\n headerShown: false,\n headerTitle: \"Introduction\",\n },\n titles: [\n {\n main: {},\n },\n {\n live: {\n options: {\n headerShown: true,\n headerTitle: \"Introduction\",\n },\n },\n },\n { auth: {} },\n ],\n },\n {\n name: \"tutoring-invoices\",\n component: TutoringInvoicesScreen,\n options: {\n headerShown: false,\n headerTitle: \"Factures\",\n },\n titles: [{ main: {} }],\n },\n {\n name: \"substitution-proposals\",\n component: SubstitutionProposalScreen,\n options: {\n headerShown: false,\n headerTitle: \"Demande de remplacement\",\n },\n titles: [{ main: {} }, { live: {} }],\n },\n]\n\nexport const navigationScreens = {\n main,\n}\n","import React, {useState} from 'react';\nimport {View} from \"react-native\";\nimport {FormStepper} from \"@common/components/stepper/FormStepper\";\nimport {validation} from \"@data/utility/validation\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {useApiStatus} from \"@common/hooks/useApiStatus\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {authService} from \"@data/services/authService\";\n\nfunction ChangeEmailStepper(props) {\n const navigation = useNavigation()\n const [formValues, setFormValues] = useState({});\n const defaultValues = {}\n const formData = [\n {\n // is_masked: !currentChallenge?.needs_school_subject,\n label: \"Choisis une nouvelle adresse email\",\n type: \"text.multiple\", // select.single, select.multiple, text, date\n inputs: [\n {\n name: \"email\",\n placeholder: \"Adresse email\",\n keyboardType: \"email-address\",\n defaultValue: props.user?.email,\n liveCheck: {service: authService.checkEmailAddressAuth},\n validationRules: {\n ...validation.required(),\n ...validation.email()\n }\n }\n ]\n },\n ]\n const onSubmit = data => {\n if (props.updateEmailRequest || props.updateEmailError) return\n props.apiRequest(authService.updateEmail, {}, data)\n }\n\n useApiStatus(\n authService.updateEmail, // api service\n null, // success message on toast (string or null)\n true, // error message on toast (true) or keep it in redux state (false)\n (data) => {\n props.apiRequest(authService.getUser)\n if (navigation.canGoBack())\n navigation.goBack()\n else\n navigation.replace(\"menu\")\n } // success callback\n )\n return (\n \n !x.is_masked)}\n champion={{name: \"tina\", variant: \"main\"}}\n formValues={formValues}\n setFormValues={setFormValues}\n defaultValues={defaultValues}\n onSubmit={onSubmit}\n submitted={props.updateEmailRequest}\n previousRouteName={\"menu\"}\n submittedMessage=\"\"\n serverError={props.updateEmailError}\n hideProgressBar\n />\n );\n}\n\nconst mapStateToProps = state => {\n return {\n updateEmailRequest: state.api.updateEmail?.request,\n updateEmailError: state.api.updateEmail?.error,\n user: state.data.currentUser?.object,\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ChangeEmailStepper)","import React, { useEffect, useState } from \"react\";\nimport { View } from \"react-native\";\nimport ProgressStepper from \"./ProgressStepper\";\nimport { useForm } from \"react-hook-form\";\nimport { FormStep } from \"./FormStep\";\nimport * as amplitude from \"@amplitude/analytics-react-native\";\nimport moment from \"moment\";\nimport { theme } from \"@common/theme/theme\";\nimport { useSelector, useDispatch } from 'react-redux';\nimport { saveFormData, resetFormData } from \"@data/redux/actions/formData\";\nimport { SnackBarM } from \"../alert/snackbar/SnackBar\";\n\nexport const FormStepper = (props) => {\n // ** Component props\n const {\n navigation,\n formData,\n champion,\n formValues,\n setFormValues,\n onSubmit,\n submitted,\n submittedMessage,\n circularProgress,\n circularProgressValue,\n serverError,\n hideProgressBar = false,\n resetsToDefaultOnNext,\n previousRouteName = \"menu\",\n track = false,\n submitButtonText = \"Terminer\",\n submitButtonColor = theme.colors.success,\n noPrevious = false,\n noGoBack = false,\n exitHandler = () => {},\n exitWarning = false,\n exitWarningMessage = \"Les données entrées seront perdues.\",\n hideGoBack = false,\n noNavigation = false,\n flex = 1,\n additionalDefaultValues = {},\n formId,\n entryId,\n } = props;\n\n // Use useSelector to get form data from Redux\n const reduxFormData = useSelector(state => formId && entryId ? (state.data?.formData?.[formId]?.[entryId] ?? {}) : {});\n\n const defaultValues = {\n ...additionalDefaultValues,\n ...formData?.reduce((pValue, cValue) => {\n if (cValue?.name) {\n const nValue = { ...pValue };\n nValue[cValue?.name] = cValue?.defaultValue ?? null;\n return nValue;\n } else if (cValue?.inputs) {\n const nValue = { ...pValue };\n\n cValue?.inputs?.forEach((i) => {\n nValue[i?.name] = i?.defaultValue ?? null;\n });\n\n if (cValue?.checkBoxes) {\n cValue?.checkBoxes?.forEach((cb) => {\n nValue[cb?.name] = cb?.defaultValue ?? null;\n });\n }\n return nValue;\n }\n }, {}),\n // Fetch saved data from Redux based on formId and entryId\n ...(reduxFormData ? reduxFormData : {})\n };\n\n useEffect(() => {\n if (!formValues) setFormValues(defaultValues);\n if (formId && entryId && Object.keys(reduxFormData)?.length > 0) {\n SnackBarM.show({\n text1: `↪️ Dernières données de formulaire restaurées`,\n duration: 4000,\n })\n }\n }, []);\n\n const {\n control,\n handleSubmit,\n formState: { errors, dirtyFields, isValid, isDirty },\n resetField,\n trigger,\n register,\n setError,\n getValues,\n } = useForm({\n defaultValues: defaultValues,\n });\n\n const dispatch = useDispatch();\n\n const [currentStep, setCurrentStep] = useState(1);\n const isFirstStep = currentStep === 1;\n const isLastStep = currentStep === formData?.length;\n const goToNextStep = async () => {\n if (track)\n amplitude.track(\n \"form.step.finished:\" +\n (formData?.[currentStep - 1]?.name ??\n formData?.[currentStep - 1]?.inputs\n ?.map((x) => x?.name)\n .join(\",\") ??\n \"unknown\")\n );\n\n // Conditionally save form data based on formId and entryId\n if (formId && entryId) {\n dispatch(saveFormData(formId, entryId, control._formValues));\n }\n\n if (!isLastStep) {\n // update form values of parent screen to update form data accordingly\n setFormValues({ ...control._formValues });\n //console.log(formValues)\n const result = await trigger();\n // console.log(getValues())\n // console.log(result, isValid)\n\n if (!isLastStep && result) setCurrentStep((cs) => cs + 1);\n } else {\n await handleSubmit(onSubmit)();\n\n // Conditionally reset form data after submission\n if (formId && entryId) {\n dispatch(resetFormData(formId, entryId));\n }\n }\n };\n\n return (\n \n {\n if (x?.champion) {\n return x?.champion;\n } else return null;\n })}\n championLabels={formData?.map((x) => x?.label)}\n submitted={submitted}\n circularProgress={circularProgress}\n circularProgressValue={circularProgressValue}\n submittedMessage={submittedMessage}\n previousRouteName={previousRouteName}\n submitButtonText={submitButtonText}\n submitButtonColor={submitButtonColor}\n flex={flex}\n steps={formData?.map((x, index) => {\n const isRequired = (formDataItem) => {\n if (formDataItem?.type === \"text.multiple\") {\n return !!formDataItem?.validationRules?.required;\n } else {\n return !!formDataItem?.inputs?.reduce(\n (prev, cur) => prev && !!cur?.validationRules?.required,\n true\n );\n }\n };\n const customCondition = (formDataItem) => {\n return !!formDataItem?.validationRules?.customCondition;\n };\n const isMinLength = (formDataItem) => {\n if (formDataItem?.type === \"select.multiple\") {\n return !!formDataItem?.validationRules?.minLength;\n }\n return false;\n };\n\n const isEmpty = (formDataItem) => {\n if (formDataItem?.type === \"select.multiple\") {\n return control._formValues?.[formDataItem?.name]?.length === 0;\n } else if (formDataItem?.type === \"select.single\") {\n return (\n control._formValues?.[formDataItem?.name] === \"\" ||\n control._formValues?.[formDataItem?.name] === null\n );\n } else if (formDataItem?.type === \"photos\") {\n return (\n control._formValues?.[formDataItem?.name]?.file_keys?.length ===\n 0\n );\n }\n\n return false;\n };\n\n const isStepDirty =\n (x.type === \"text.multiple\" &&\n x.inputs?.reduce(\n (pValue, cValue) => pValue || dirtyFields[cValue.name],\n false\n )) ||\n (x.type === \"text.single\" && dirtyFields[x.name]);\n // console.log (\"length of \", x?.name, \" : \", control._formValues?.[x.name]?.length)\n\n const hideNextButton =\n !x?.showNextButton &&\n ((x.type === \"select.single\" && !isLastStep) ||\n (isRequired(x) &&\n x.type === \"text.multiple\" &&\n x.inputs?.reduce(\n (pValue, cValue) => pValue || !dirtyFields[cValue.name],\n false\n )) ||\n (x.type === \"select.multiple\" && isEmpty(x)) ||\n (x.type === \"select.single\" && isEmpty(x)) ||\n //TODO : delete this deprecated case (use text.multiple instead)\n (x.type === \"text.single\" && !dirtyFields[x.name]) ||\n (x.type === \"photos\" && !dirtyFields[x.name]) ||\n (x.type === \"day-time\" &&\n !moment(\n control._formValues?.[x.name],\n \"dddd HH:mm\"\n ).isValid()) ||\n (x.type === \"date-time\" &&\n !moment(\n control._formValues?.[x.name],\n \"YYYY-MM-DD HH:mm\",\n true\n ).isValid()) ||\n (isMinLength(x) &&\n control._formValues?.[x.name]?.length <\n x?.validationRules?.minLength?.value) ||\n (customCondition(x) &&\n x?.validationRules?.customCondition?.value) ||\n (x.type === \"custom\" && !x?.showNextButton) ||\n x.type === \"select.two.oriented\" ||\n x.type === \"select.card.single\" ||\n x.type === \"select.grouped.single\");\n\n const hideSubmitButton = x?.showSubmitButton === false && isLastStep;\n\n return {\n content: (\n \n ),\n hideNextButton,\n hideSubmitButton,\n };\n })}\n />\n \n );\n};\n","import React, { useContext } from \"react\"\nimport { Platform, View } from \"react-native\"\nimport { ActivityIndicator } from \"react-native-paper\"\nimport { theme } from \"../../theme/theme\"\nimport FilledButtonM from \"../button/FilledButtonM\"\nimport TextM from \"../text/TextM\"\nimport { DimensionsContext, IS_WEB } from \"../../utils/mobileUtils\"\nimport CircularProgress from \"react-native-circular-progress-indicator/src/circularProgress/index\"\n//import CircularProgress from 'react-native-circular-progress-indicator';\nimport ChampionBubble from \"../../../student/champions/ChampionBubble\"\nimport ProgressStepperHeader from \"@common/components/stepper/ProgressStepperHeader\"\n\nconst ProgressStepper = (props) => {\n const dimensions = useContext(DimensionsContext)\n\n // ** Component props\n const {\n navigation,\n steps,\n exitHandler,\n champion,\n championLabels,\n hideProgressBar = false,\n submitButtonText = \"Terminer\",\n submitButtonColor = theme.colors.success,\n currentStep,\n setCurrentStep,\n onNextButtonPress,\n submitted,\n headerRightComponent,\n submittedMessage,\n previousRouteName = \"menu\",\n exitWarning,\n noPrevious,\n noGoBack,\n noNavigation = false,\n hideGoBack = false,\n circularProgress,\n circularProgressValue,\n exitWarningMessage,\n track = false,\n champions,\n flex = 1,\n } = props\n\n const isFirstStep = currentStep === 1\n const isLastStep = currentStep === steps?.length\n\n const goToPreviousStep = () => {\n if (!isFirstStep) setCurrentStep((cs) => cs - 1)\n }\n\n return (\n \n {(!hideGoBack) && (\n \n )}\n\n {!submitted && (champion || champions?.some((x) => x !== null)) && (\n \n )}\n\n {!submitted ? (\n steps?.[currentStep - 1]?.content\n ) : (\n \n {circularProgress ? (\n IS_WEB ? (\n \n {circularProgressValue + \"%\"}\n \n ) : (\n \n )\n ) : (\n \n )}\n \n Chargement en cours...\n \n {!!submittedMessage && submittedMessage !== \"\" && (\n \n {submittedMessage}\n \n )}\n \n )}\n {!submitted &&\n !steps?.[currentStep - 1]?.hideNextButton &&\n !steps?.[currentStep - 1]?.hideSubmitButton && (\n \n {\n window.scrollTo(0, 0)\n onNextButtonPress()\n }\n : onNextButtonPress\n }\n style={{\n width:\n IS_WEB && dimensions.width > 800\n ? (dimensions.width * flex) / 1.2\n : dimensions.width * flex - 20,\n alignSelf: \"center\",\n marginTop: Platform.OS !== \"web\" ? null : 15,\n marginBottom: Platform.OS !== \"web\" ? null : 15,\n // bottom: 15\n }}\n label={isLastStep ? submitButtonText : \"Suivant\"}\n />\n \n )}\n \n )\n}\n\nexport default ProgressStepper\n","import * as amplitude from \"@amplitude/analytics-react-native\";\nimport { theme } from \"@common/theme/theme\";\nimport React, { useContext } from \"react\";\nimport { Platform, StyleSheet } from \"react-native\";\nimport { Button } from \"react-native-paper\";\nimport { DimensionsContext } from \"../../utils/mobileUtils\";\nimport withPreventDoubleClick from \"../../utils/withPreventDoubleClick\";\n\nconst FilledButtonM = (props) => {\n\n const { mode, label, fontWeight, color, trackingId, onPress } = props\n const dimensions = useContext(DimensionsContext)\n\n const styles = StyleSheet.create({\n button: {\n marginBottom: 10,\n // marginHorizontal: 15,\n // paddingVertical: 5,\n borderRadius: 15,\n width: Platform.OS !== \"web\" || dimensions?.width < 800 ? dimensions?.width - 40 : dimensions?.width / 2,\n alignSelf: Platform.OS !== \"web\" ? null : \"center\",\n },\n text: {\n fontFamily: \"Montserrat-\" + (fontWeight ?? \"ExtraBold\"),\n fontSize: 15,\n },\n content: {\n // paddingVertical: 5\n height: 50,\n },\n })\n\n return \n}\n\nexport default withPreventDoubleClick(FilledButtonM)","import React from \"react\";\n\nconst withPreventDoubleClick = (WrappedComponent) => {\n return (props) => ;\n};\n\nexport default withPreventDoubleClick;","import React from 'react';\nimport {Text} from \"react-native-paper\";\nimport {theme} from \"../../theme/theme\";\nimport {Platform} from \"react-native\";\n\nconst TextM = (props) => {\n\n const {fontWeight, fontSize, color, wrap} = props\n\n return \n {props.children}\n
\n}\n\nexport default TextM","import React, { useEffect } from \"react\";\nimport { StyleSheet, View, TextInput, Text } from \"react-native\";\nimport Svg, { G, Circle, Defs, LinearGradient, Stop } from \"react-native-svg\";\nimport Animated, {\n useSharedValue,\n withTiming,\n useAnimatedProps,\n withDelay,\n runOnJS,\n useDerivedValue,\n} from \"react-native-reanimated\";\nimport { CircularProgressProps } from \"./types\";\n\nconst AnimatedCircle = Animated.createAnimatedComponent(Circle);\nconst AnimatedInput = Animated.createAnimatedComponent(TextInput);\n\nconst CircularProgress: React.FC = ({\n value,\n initialValue = 0,\n title = \"\",\n titleStyle = {},\n titleColor,\n titleFontSize,\n circleBackgroundColor = \"transparent\",\n radius = 60,\n duration = 500,\n delay = 0,\n textColor,\n textStyle = {},\n fontSize,\n maxValue = 100,\n strokeLinecap = \"round\",\n onAnimationComplete = () => {},\n valuePrefix = \"\",\n valueSuffix = \"\",\n activeStrokeColor = \"#2ecc71\",\n activeStrokeSecondaryColor = \"\",\n activeStrokeWidth = 10,\n inActiveStrokeColor = \"rgba(0,0,0,0.3)\",\n inActiveStrokeWidth = 10,\n inActiveStrokeOpacity = 1,\n showProgressValue = true,\n clockwise = true,\n subtitle = \"\",\n subtitleStyle = {},\n subtitleColor,\n subtitleFontSize,\n}) => {\n const styleProps = {\n radius,\n textColor,\n fontSize,\n textStyle,\n activeStrokeColor,\n titleStyle,\n titleColor,\n titleFontSize,\n showProgressValue,\n subtitleColor,\n subtitleFontSize,\n };\n\n const animatedValue = useSharedValue(initialValue);\n const viewBox = radius + Math.max(activeStrokeWidth, inActiveStrokeWidth);\n const circleCircumference = 2 * Math.PI * radius;\n\n const animatedCircleProps = useAnimatedProps(() => {\n let biggestValue = Math.max(initialValue, maxValue);\n biggestValue = biggestValue <= 0 ? 1 : biggestValue;\n const maxPercentage: number = clockwise\n ? (100 * animatedValue.value) / biggestValue\n : (100 * -animatedValue.value) / biggestValue;\n return {\n strokeDashoffset:\n circleCircumference - (circleCircumference * maxPercentage) / 100,\n };\n });\n\n const progressValue = useDerivedValue(() => {\n return `${valuePrefix}${Math.round(animatedValue.value)}${valueSuffix}`;\n });\n\n const animatedTextProps = useAnimatedProps(() => {\n return {\n text: progressValue.value,\n } as any;\n });\n\n useEffect(() => {\n animatedValue.value = withDelay(\n delay,\n withTiming(value, { duration }, (isFinished) => {\n if (isFinished) {\n runOnJS(onAnimationComplete)?.();\n }\n })\n );\n }, [value]);\n\n return (\n \n \n {activeStrokeSecondaryColor ? (\n \n \n \n \n \n \n ) : null}\n \n \n \n \n \n \n {showProgressValue && (\n \n )}\n {title && title !== \"\" ? (\n \n {title}\n \n ) : null}\n {subtitle && subtitle !== \"\" ? (\n \n {subtitle}\n \n ) : null}\n \n \n );\n};\n\nexport const dynamicStyles = (props) => {\n return StyleSheet.create({\n fromProps: {\n fontSize: props.fontSize || props.textStyle?.fontSize || props.radius / 2,\n color:\n props.textColor || props.textStyle?.color || props.activeStrokeColor,\n },\n input: {\n fontWeight: \"bold\",\n textAlign: \"center\",\n },\n valueContainer: {\n flex: 1,\n alignItems: \"center\",\n justifyContent: \"center\",\n },\n title: {\n textAlign: \"center\",\n width: \"70%\",\n marginTop: props.showProgressValue ? props.radius * 0.05 : 0,\n color:\n props.titleColor || props.titleStyle?.color || props.activeStrokeColor,\n fontSize:\n props.titleFontSize ||\n props.titleStyle?.fontSize ||\n props.fontSize ||\n props.radius / 4,\n },\n subtitle: {\n color:\n props.subtitleColor ||\n props.subtitleStyle?.color ||\n props.activeStrokeColor,\n fontSize:\n props.subtitleFontSize ||\n props.subtitleStyle?.fontSize ||\n props.fontSize ||\n props.radius / 5,\n },\n });\n};\n\nexport default CircularProgress;","export * from './ReactNativeSVG';\nexport { default } from './ReactNativeSVG';\n//# sourceMappingURL=index.js.map","import * as React from 'react';\nimport {\n// @ts-ignore it is not seen in exports\nunstable_createElement as createElement } from 'react-native';\nimport SvgTouchableMixin from './lib/SvgTouchableMixin';\nimport { resolve } from './lib/resolve';\nimport { transformsArrayToProps } from './lib/extract/extractTransform';\nconst hasTouchableProperty = props => props.onPress || props.onPressIn || props.onPressOut || props.onLongPress;\nconst camelCaseToDashed = camelCase => {\n return camelCase.replace(/[A-Z]/g, m => '-' + m.toLowerCase());\n};\nfunction stringifyTransformProps(transformProps) {\n const transformArray = [];\n if (transformProps.translate != null) {\n transformArray.push(`translate(${transformProps.translate})`);\n }\n if (transformProps.translateX != null || transformProps.translateY != null) {\n transformArray.push(`translate(${transformProps.translateX || 0}, ${transformProps.translateY || 0})`);\n }\n if (transformProps.scale != null) {\n transformArray.push(`scale(${transformProps.scale})`);\n }\n if (transformProps.scaleX != null || transformProps.scaleY != null) {\n transformArray.push(`scale(${transformProps.scaleX || 1}, ${transformProps.scaleY || 1})`);\n }\n // rotation maps to rotate, not to collide with the text rotate attribute (which acts per glyph rather than block)\n if (transformProps.rotation != null) {\n transformArray.push(`rotate(${transformProps.rotation})`);\n }\n if (transformProps.skewX != null) {\n transformArray.push(`skewX(${transformProps.skewX})`);\n }\n if (transformProps.skewY != null) {\n transformArray.push(`skewY(${transformProps.skewY})`);\n }\n return transformArray;\n}\nfunction parseTransformProp(transform, props) {\n const transformArray = [];\n props && transformArray.push(...stringifyTransformProps(props));\n if (Array.isArray(transform)) {\n if (typeof transform[0] === 'number') {\n transformArray.push(`matrix(${transform.join(' ')})`);\n } else {\n const stringifiedProps = transformsArrayToProps(transform);\n transformArray.push(...stringifyTransformProps(stringifiedProps));\n }\n } else if (typeof transform === 'string') {\n transformArray.push(transform);\n }\n return transformArray.length ? transformArray.join(' ') : undefined;\n}\n\n/**\n * `react-native-svg` supports additional props that aren't defined in the spec.\n * This function replaces them in a spec conforming manner.\n *\n * @param {WebShape} self Instance given to us.\n * @param {Object?} props Optional overridden props given to us.\n * @returns {Object} Cleaned props object.\n * @private\n */\nconst prepare = function (self) {\n let props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : self.props;\n const {\n transform,\n origin,\n originX,\n originY,\n fontFamily,\n fontSize,\n fontWeight,\n fontStyle,\n style,\n forwardedRef,\n gradientTransform,\n patternTransform,\n ...rest\n } = props;\n const clean = {\n ...(hasTouchableProperty(props) ? {\n onStartShouldSetResponder: self.touchableHandleStartShouldSetResponder,\n onResponderTerminationRequest: self.touchableHandleResponderTerminationRequest,\n onResponderGrant: self.touchableHandleResponderGrant,\n onResponderMove: self.touchableHandleResponderMove,\n onResponderRelease: self.touchableHandleResponderRelease,\n onResponderTerminate: self.touchableHandleResponderTerminate\n } : null),\n ...rest\n };\n if (origin != null) {\n clean['transform-origin'] = origin.toString().replace(',', ' ');\n } else if (originX != null || originY != null) {\n clean['transform-origin'] = `${originX || 0} ${originY || 0}`;\n }\n\n // we do it like this because setting transform as undefined causes error in web\n const parsedTransform = parseTransformProp(transform, props);\n if (parsedTransform) {\n clean.transform = parsedTransform;\n }\n const parsedGradientTransform = parseTransformProp(gradientTransform);\n if (parsedGradientTransform) {\n clean.gradientTransform = parsedGradientTransform;\n }\n const parsedPatternTransform = parseTransformProp(patternTransform);\n if (parsedPatternTransform) {\n clean.patternTransform = parsedPatternTransform;\n }\n clean.ref = el => {\n self.elementRef.current = el;\n if (typeof forwardedRef === 'function') {\n forwardedRef(el);\n } else if (forwardedRef) {\n forwardedRef.current = el;\n }\n };\n const styles = {};\n if (fontFamily != null) {\n styles.fontFamily = fontFamily;\n }\n if (fontSize != null) {\n styles.fontSize = fontSize;\n }\n if (fontWeight != null) {\n styles.fontWeight = fontWeight;\n }\n if (fontStyle != null) {\n styles.fontStyle = fontStyle;\n }\n clean.style = resolve(style, styles);\n return clean;\n};\nconst getBoundingClientRect = node => {\n if (node) {\n const isElement = node.nodeType === 1; /* Node.ELEMENT_NODE */\n if (isElement && typeof node.getBoundingClientRect === 'function') {\n return node.getBoundingClientRect();\n }\n }\n throw new Error('Can not get boundingClientRect of ' + node || 'undefined');\n};\nconst measureLayout = (node, callback) => {\n const relativeNode = node === null || node === void 0 ? void 0 : node.parentNode;\n if (relativeNode) {\n setTimeout(() => {\n // @ts-expect-error TODO: handle it better\n const relativeRect = getBoundingClientRect(relativeNode);\n const {\n height,\n left,\n top,\n width\n } = getBoundingClientRect(node);\n const x = left - relativeRect.left;\n const y = top - relativeRect.top;\n callback(x, y, width, height, left, top);\n }, 0);\n }\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction remeasure() {\n const tag = this.state.touchable.responderID;\n if (tag === null) {\n return;\n }\n measureLayout(tag, this._handleQueryLayout);\n}\nexport class WebShape extends React.Component {\n prepareProps(props) {\n return props;\n }\n elementRef = /*#__PURE__*/React.createRef();\n lastMergedProps = {};\n\n /**\n * disclaimer: I am not sure why the props are wrapped in a `style` attribute here, but that's how reanimated calls it\n */\n setNativeProps(props) {\n const merged = Object.assign({}, this.props, this.lastMergedProps, props.style);\n this.lastMergedProps = merged;\n const clean = prepare(this, this.prepareProps(merged));\n const current = this.elementRef.current;\n if (current) {\n for (const cleanAttribute of Object.keys(clean)) {\n const cleanValue = clean[cleanAttribute];\n switch (cleanAttribute) {\n case 'ref':\n case 'children':\n break;\n case 'style':\n // style can be an object here or an array, so we convert it to an array and assign each element\n for (const partialStyle of [].concat(clean.style ?? [])) {\n Object.assign(current.style, partialStyle);\n }\n break;\n default:\n // apply all other incoming prop updates as attributes on the node\n // same logic as in https://github.com/software-mansion/react-native-reanimated/blob/d04720c82f5941532991b235787285d36d717247/src/reanimated2/js-reanimated/index.ts#L38-L39\n // @ts-expect-error TODO: fix this\n current.setAttribute(camelCaseToDashed(cleanAttribute), cleanValue);\n break;\n }\n }\n }\n }\n constructor(props) {\n super(props);\n\n // Do not attach touchable mixin handlers if SVG element doesn't have a touchable prop\n if (hasTouchableProperty(props)) {\n SvgTouchableMixin(this);\n }\n this._remeasureMetricsOnActivation = remeasure.bind(this);\n }\n render() {\n if (!this.tag) {\n throw new Error('When extending `WebShape` you need to overwrite either `tag` or `render`!');\n }\n this.lastMergedProps = {};\n return createElement(this.tag, prepare(this, this.prepareProps(this.props)));\n }\n}\nexport class Circle extends WebShape {\n tag = 'circle';\n}\nexport class ClipPath extends WebShape {\n tag = 'clipPath';\n}\nexport class Defs extends WebShape {\n tag = 'defs';\n}\nexport class Ellipse extends WebShape {\n tag = 'ellipse';\n}\nexport class G extends WebShape {\n tag = 'g';\n prepareProps(props) {\n const {\n x,\n y,\n ...rest\n } = props;\n if ((x || y) && !rest.translate) {\n rest.translate = `${x || 0}, ${y || 0}`;\n }\n return rest;\n }\n}\nexport class Image extends WebShape {\n tag = 'image';\n}\nexport class Line extends WebShape {\n tag = 'line';\n}\nexport class LinearGradient extends WebShape {\n tag = 'linearGradient';\n}\nexport class Path extends WebShape {\n tag = 'path';\n}\nexport class Polygon extends WebShape {\n tag = 'polygon';\n}\nexport class Polyline extends WebShape {\n tag = 'polyline';\n}\nexport class RadialGradient extends WebShape {\n tag = 'radialGradient';\n}\nexport class Rect extends WebShape {\n tag = 'rect';\n}\nexport class Stop extends WebShape {\n tag = 'stop';\n}\n\n/* Taken from here: https://gist.github.com/jennyknuth/222825e315d45a738ed9d6e04c7a88d0 */\nfunction encodeSvg(svgString) {\n return svgString.replace('/g, '%3E').replace(/\\s+/g, ' ');\n}\nexport class Svg extends WebShape {\n tag = 'svg';\n toDataURL(callback) {\n let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n const ref = this.elementRef.current;\n if (ref === null) {\n return;\n }\n const rect = getBoundingClientRect(ref);\n const width = Number(options.width) || rect.width;\n const height = Number(options.height) || rect.height;\n const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');\n svg.setAttribute('viewBox', `0 0 ${rect.width} ${rect.height}`);\n svg.setAttribute('width', String(width));\n svg.setAttribute('height', String(height));\n svg.appendChild(ref.cloneNode(true));\n const img = new window.Image();\n img.onload = () => {\n const canvas = document.createElement('canvas');\n canvas.width = width;\n canvas.height = height;\n const context = canvas.getContext('2d');\n context === null || context === void 0 ? void 0 : context.drawImage(img, 0, 0);\n callback(canvas.toDataURL().replace('data:image/png;base64,', ''));\n };\n img.src = `data:image/svg+xml;utf8,${encodeSvg(new window.XMLSerializer().serializeToString(svg))}`;\n }\n}\nexport class Symbol extends WebShape {\n tag = 'symbol';\n}\nexport class Text extends WebShape {\n tag = 'text';\n}\nexport class TSpan extends WebShape {\n tag = 'tspan';\n}\nexport class TextPath extends WebShape {\n tag = 'textPath';\n}\nexport class Use extends WebShape {\n tag = 'use';\n}\nexport class Mask extends WebShape {\n tag = 'mask';\n}\nexport class ForeignObject extends WebShape {\n tag = 'foreignObject';\n}\nexport class Marker extends WebShape {\n tag = 'marker';\n}\nexport class Pattern extends WebShape {\n tag = 'pattern';\n}\nexport default Svg;\n//# sourceMappingURL=ReactNativeSVG.web.js.map","import { Touchable } from 'react-native';\nconst PRESS_RETENTION_OFFSET = {\n top: 20,\n left: 20,\n right: 20,\n bottom: 30\n};\n// @ts-expect-error: Mixin is not typed\nconst {\n Mixin\n} = Touchable;\nconst {\n touchableHandleStartShouldSetResponder,\n touchableHandleResponderTerminationRequest,\n touchableHandleResponderGrant,\n touchableHandleResponderMove,\n touchableHandleResponderRelease,\n touchableHandleResponderTerminate,\n touchableGetInitialState\n} = Mixin;\nconst SvgTouchableMixin = {\n ...Mixin,\n touchableHandleStartShouldSetResponder(e) {\n const {\n onStartShouldSetResponder\n } = this.props;\n if (onStartShouldSetResponder) {\n return onStartShouldSetResponder(e);\n } else {\n return touchableHandleStartShouldSetResponder.call(this, e);\n }\n },\n touchableHandleResponderTerminationRequest(e) {\n const {\n onResponderTerminationRequest\n } = this.props;\n if (onResponderTerminationRequest) {\n return onResponderTerminationRequest(e);\n } else {\n return touchableHandleResponderTerminationRequest.call(this, e);\n }\n },\n touchableHandleResponderGrant(e) {\n const {\n onResponderGrant\n } = this.props;\n if (onResponderGrant) {\n return onResponderGrant(e);\n } else {\n return touchableHandleResponderGrant.call(this, e);\n }\n },\n touchableHandleResponderMove(e) {\n const {\n onResponderMove\n } = this.props;\n if (onResponderMove) {\n return onResponderMove(e);\n } else {\n return touchableHandleResponderMove.call(this, e);\n }\n },\n touchableHandleResponderRelease(e) {\n const {\n onResponderRelease\n } = this.props;\n if (onResponderRelease) {\n return onResponderRelease(e);\n } else {\n return touchableHandleResponderRelease.call(this, e);\n }\n },\n touchableHandleResponderTerminate(e) {\n const {\n onResponderTerminate\n } = this.props;\n if (onResponderTerminate) {\n return onResponderTerminate(e);\n } else {\n return touchableHandleResponderTerminate.call(this, e);\n }\n },\n touchableHandlePress(e) {\n const {\n onPress\n } = this.props;\n onPress && onPress(e);\n },\n touchableHandleActivePressIn(e) {\n const {\n onPressIn\n } = this.props;\n onPressIn && onPressIn(e);\n },\n touchableHandleActivePressOut(e) {\n const {\n onPressOut\n } = this.props;\n onPressOut && onPressOut(e);\n },\n touchableHandleLongPress(e) {\n const {\n onLongPress\n } = this.props;\n onLongPress && onLongPress(e);\n },\n touchableGetPressRectOffset() {\n const {\n pressRetentionOffset\n } = this.props;\n return pressRetentionOffset || PRESS_RETENTION_OFFSET;\n },\n touchableGetHitSlop() {\n const {\n hitSlop\n } = this.props;\n return hitSlop;\n },\n touchableGetHighlightDelayMS() {\n const {\n delayPressIn\n } = this.props;\n return delayPressIn || 0;\n },\n touchableGetLongPressDelayMS() {\n const {\n delayLongPress\n } = this.props;\n return delayLongPress === 0 ? 0 : delayLongPress || 500;\n },\n touchableGetPressOutDelayMS() {\n const {\n delayPressOut\n } = this.props;\n return delayPressOut || 0;\n }\n};\nconst touchKeys = Object.keys(SvgTouchableMixin);\nconst touchVals = touchKeys.map(key => SvgTouchableMixin[key]);\nconst numTouchKeys = touchKeys.length;\nexport default (target => {\n for (let i = 0; i < numTouchKeys; i++) {\n const key = touchKeys[i];\n const val = touchVals[i];\n if (typeof val === 'function') {\n target[key] = val.bind(target);\n } else {\n target[key] = val;\n }\n }\n target.state = touchableGetInitialState();\n});\n//# sourceMappingURL=SvgTouchableMixin.js.map","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nimport _objectSpread from \"@babel/runtime/helpers/objectSpread2\";\nimport AccessibilityUtil from '../../modules/AccessibilityUtil';\nimport BoundingDimensions from './BoundingDimensions';\nimport normalizeColor from '@react-native/normalize-colors';\nimport Position from './Position';\nimport React from 'react';\nimport UIManager from '../UIManager';\nimport View from '../View';\nimport { warnOnce } from '../../modules/warnOnce';\nvar extractSingleTouch = nativeEvent => {\n var touches = nativeEvent.touches;\n var changedTouches = nativeEvent.changedTouches;\n var hasTouches = touches && touches.length > 0;\n var hasChangedTouches = changedTouches && changedTouches.length > 0;\n return !hasTouches && hasChangedTouches ? changedTouches[0] : hasTouches ? touches[0] : nativeEvent;\n};\n\n/**\n * `Touchable`: Taps done right.\n *\n * You hook your `ResponderEventPlugin` events into `Touchable`. `Touchable`\n * will measure time/geometry and tells you when to give feedback to the user.\n *\n * ====================== Touchable Tutorial ===============================\n * The `Touchable` mixin helps you handle the \"press\" interaction. It analyzes\n * the geometry of elements, and observes when another responder (scroll view\n * etc) has stolen the touch lock. It notifies your component when it should\n * give feedback to the user. (bouncing/highlighting/unhighlighting).\n *\n * - When a touch was activated (typically you highlight)\n * - When a touch was deactivated (typically you unhighlight)\n * - When a touch was \"pressed\" - a touch ended while still within the geometry\n * of the element, and no other element (like scroller) has \"stolen\" touch\n * lock (\"responder\") (Typically you bounce the element).\n *\n * A good tap interaction isn't as simple as you might think. There should be a\n * slight delay before showing a highlight when starting a touch. If a\n * subsequent touch move exceeds the boundary of the element, it should\n * unhighlight, but if that same touch is brought back within the boundary, it\n * should rehighlight again. A touch can move in and out of that boundary\n * several times, each time toggling highlighting, but a \"press\" is only\n * triggered if that touch ends while within the element's boundary and no\n * scroller (or anything else) has stolen the lock on touches.\n *\n * To create a new type of component that handles interaction using the\n * `Touchable` mixin, do the following:\n *\n * - Initialize the `Touchable` state.\n *\n * getInitialState: function() {\n * return merge(this.touchableGetInitialState(), yourComponentState);\n * }\n *\n * - Add a method to get your touchable component's node.\n * getTouchableNode: function() {\n * return this.touchableRef.current\n * }\n *\n * - Choose the rendered component who's touches should start the interactive\n * sequence. On that rendered node, forward all `Touchable` responder\n * handlers. You can choose any rendered node you like. Choose a node whose\n * hit target you'd like to instigate the interaction sequence:\n *\n * // In render function:\n * return (\n * \n * \n * Even though the hit detection/interactions are triggered by the\n * wrapping (typically larger) node, we usually end up implementing\n * custom logic that highlights this inner one.\n * \n * \n * );\n *\n * - You may set up your own handlers for each of these events, so long as you\n * also invoke the `touchable*` handlers inside of your custom handler.\n *\n * - Implement the handlers on your component class in order to provide\n * feedback to the user. See documentation for each of these class methods\n * that you should implement.\n *\n * touchableHandlePress: function() {\n * this.performBounceAnimation(); // or whatever you want to do.\n * },\n * touchableHandleActivePressIn: function() {\n * this.beginHighlighting(...); // Whatever you like to convey activation\n * },\n * touchableHandleActivePressOut: function() {\n * this.endHighlighting(...); // Whatever you like to convey deactivation\n * },\n *\n * - There are more advanced methods you can implement (see documentation below):\n * touchableGetHighlightDelayMS: function() {\n * return 20;\n * }\n * // In practice, *always* use a predeclared constant (conserve memory).\n * touchableGetPressRectOffset: function() {\n * return {top: 20, left: 20, right: 20, bottom: 100};\n * }\n */\n\n/**\n * Touchable states.\n */\n\nvar States = {\n NOT_RESPONDER: 'NOT_RESPONDER',\n // Not the responder\n RESPONDER_INACTIVE_PRESS_IN: 'RESPONDER_INACTIVE_PRESS_IN',\n // Responder, inactive, in the `PressRect`\n RESPONDER_INACTIVE_PRESS_OUT: 'RESPONDER_INACTIVE_PRESS_OUT',\n // Responder, inactive, out of `PressRect`\n RESPONDER_ACTIVE_PRESS_IN: 'RESPONDER_ACTIVE_PRESS_IN',\n // Responder, active, in the `PressRect`\n RESPONDER_ACTIVE_PRESS_OUT: 'RESPONDER_ACTIVE_PRESS_OUT',\n // Responder, active, out of `PressRect`\n RESPONDER_ACTIVE_LONG_PRESS_IN: 'RESPONDER_ACTIVE_LONG_PRESS_IN',\n // Responder, active, in the `PressRect`, after long press threshold\n RESPONDER_ACTIVE_LONG_PRESS_OUT: 'RESPONDER_ACTIVE_LONG_PRESS_OUT',\n // Responder, active, out of `PressRect`, after long press threshold\n ERROR: 'ERROR'\n};\n/*\n * Quick lookup map for states that are considered to be \"active\"\n */\n\nvar baseStatesConditions = {\n NOT_RESPONDER: false,\n RESPONDER_INACTIVE_PRESS_IN: false,\n RESPONDER_INACTIVE_PRESS_OUT: false,\n RESPONDER_ACTIVE_PRESS_IN: false,\n RESPONDER_ACTIVE_PRESS_OUT: false,\n RESPONDER_ACTIVE_LONG_PRESS_IN: false,\n RESPONDER_ACTIVE_LONG_PRESS_OUT: false,\n ERROR: false\n};\nvar IsActive = _objectSpread(_objectSpread({}, baseStatesConditions), {}, {\n RESPONDER_ACTIVE_PRESS_OUT: true,\n RESPONDER_ACTIVE_PRESS_IN: true\n});\n\n/**\n * Quick lookup for states that are considered to be \"pressing\" and are\n * therefore eligible to result in a \"selection\" if the press stops.\n */\nvar IsPressingIn = _objectSpread(_objectSpread({}, baseStatesConditions), {}, {\n RESPONDER_INACTIVE_PRESS_IN: true,\n RESPONDER_ACTIVE_PRESS_IN: true,\n RESPONDER_ACTIVE_LONG_PRESS_IN: true\n});\nvar IsLongPressingIn = _objectSpread(_objectSpread({}, baseStatesConditions), {}, {\n RESPONDER_ACTIVE_LONG_PRESS_IN: true\n});\n\n/**\n * Inputs to the state machine.\n */\nvar Signals = {\n DELAY: 'DELAY',\n RESPONDER_GRANT: 'RESPONDER_GRANT',\n RESPONDER_RELEASE: 'RESPONDER_RELEASE',\n RESPONDER_TERMINATED: 'RESPONDER_TERMINATED',\n ENTER_PRESS_RECT: 'ENTER_PRESS_RECT',\n LEAVE_PRESS_RECT: 'LEAVE_PRESS_RECT',\n LONG_PRESS_DETECTED: 'LONG_PRESS_DETECTED'\n};\n/**\n * Mapping from States x Signals => States\n */\nvar Transitions = {\n NOT_RESPONDER: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.RESPONDER_INACTIVE_PRESS_IN,\n RESPONDER_RELEASE: States.ERROR,\n RESPONDER_TERMINATED: States.ERROR,\n ENTER_PRESS_RECT: States.ERROR,\n LEAVE_PRESS_RECT: States.ERROR,\n LONG_PRESS_DETECTED: States.ERROR\n },\n RESPONDER_INACTIVE_PRESS_IN: {\n DELAY: States.RESPONDER_ACTIVE_PRESS_IN,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_INACTIVE_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_INACTIVE_PRESS_OUT,\n LONG_PRESS_DETECTED: States.ERROR\n },\n RESPONDER_INACTIVE_PRESS_OUT: {\n DELAY: States.RESPONDER_ACTIVE_PRESS_OUT,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_INACTIVE_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_INACTIVE_PRESS_OUT,\n LONG_PRESS_DETECTED: States.ERROR\n },\n RESPONDER_ACTIVE_PRESS_IN: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_ACTIVE_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_ACTIVE_PRESS_OUT,\n LONG_PRESS_DETECTED: States.RESPONDER_ACTIVE_LONG_PRESS_IN\n },\n RESPONDER_ACTIVE_PRESS_OUT: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_ACTIVE_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_ACTIVE_PRESS_OUT,\n LONG_PRESS_DETECTED: States.ERROR\n },\n RESPONDER_ACTIVE_LONG_PRESS_IN: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_ACTIVE_LONG_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_ACTIVE_LONG_PRESS_OUT,\n LONG_PRESS_DETECTED: States.RESPONDER_ACTIVE_LONG_PRESS_IN\n },\n RESPONDER_ACTIVE_LONG_PRESS_OUT: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_ACTIVE_LONG_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_ACTIVE_LONG_PRESS_OUT,\n LONG_PRESS_DETECTED: States.ERROR\n },\n error: {\n DELAY: States.NOT_RESPONDER,\n RESPONDER_GRANT: States.RESPONDER_INACTIVE_PRESS_IN,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.NOT_RESPONDER,\n LEAVE_PRESS_RECT: States.NOT_RESPONDER,\n LONG_PRESS_DETECTED: States.NOT_RESPONDER\n }\n};\n\n// ==== Typical Constants for integrating into UI components ====\n// var HIT_EXPAND_PX = 20;\n// var HIT_VERT_OFFSET_PX = 10;\nvar HIGHLIGHT_DELAY_MS = 130;\nvar PRESS_EXPAND_PX = 20;\nvar LONG_PRESS_THRESHOLD = 500;\nvar LONG_PRESS_DELAY_MS = LONG_PRESS_THRESHOLD - HIGHLIGHT_DELAY_MS;\nvar LONG_PRESS_ALLOWED_MOVEMENT = 10;\n\n// Default amount \"active\" region protrudes beyond box\n\n/**\n * By convention, methods prefixed with underscores are meant to be @private,\n * and not @protected. Mixers shouldn't access them - not even to provide them\n * as callback handlers.\n *\n *\n * ========== Geometry =========\n * `Touchable` only assumes that there exists a `HitRect` node. The `PressRect`\n * is an abstract box that is extended beyond the `HitRect`.\n *\n * +--------------------------+\n * | | - \"Start\" events in `HitRect` cause `HitRect`\n * | +--------------------+ | to become the responder.\n * | | +--------------+ | | - `HitRect` is typically expanded around\n * | | | | | | the `VisualRect`, but shifted downward.\n * | | | VisualRect | | | - After pressing down, after some delay,\n * | | | | | | and before letting up, the Visual React\n * | | +--------------+ | | will become \"active\". This makes it eligible\n * | | HitRect | | for being highlighted (so long as the\n * | +--------------------+ | press remains in the `PressRect`).\n * | PressRect o |\n * +----------------------|---+\n * Out Region |\n * +-----+ This gap between the `HitRect` and\n * `PressRect` allows a touch to move far away\n * from the original hit rect, and remain\n * highlighted, and eligible for a \"Press\".\n * Customize this via\n * `touchableGetPressRectOffset()`.\n *\n *\n *\n * ======= State Machine =======\n *\n * +-------------+ <---+ RESPONDER_RELEASE\n * |NOT_RESPONDER|\n * +-------------+ <---+ RESPONDER_TERMINATED\n * +\n * | RESPONDER_GRANT (HitRect)\n * v\n * +---------------------------+ DELAY +-------------------------+ T + DELAY +------------------------------+\n * |RESPONDER_INACTIVE_PRESS_IN|+-------->|RESPONDER_ACTIVE_PRESS_IN| +------------> |RESPONDER_ACTIVE_LONG_PRESS_IN|\n * +---------------------------+ +-------------------------+ +------------------------------+\n * + ^ + ^ + ^\n * |LEAVE_ |ENTER_ |LEAVE_ |ENTER_ |LEAVE_ |ENTER_\n * |PRESS_RECT |PRESS_RECT |PRESS_RECT |PRESS_RECT |PRESS_RECT |PRESS_RECT\n * | | | | | |\n * v + v + v +\n * +----------------------------+ DELAY +--------------------------+ +-------------------------------+\n * |RESPONDER_INACTIVE_PRESS_OUT|+------->|RESPONDER_ACTIVE_PRESS_OUT| |RESPONDER_ACTIVE_LONG_PRESS_OUT|\n * +----------------------------+ +--------------------------+ +-------------------------------+\n *\n * T + DELAY => LONG_PRESS_DELAY_MS + DELAY\n *\n * Not drawn are the side effects of each transition. The most important side\n * effect is the `touchableHandlePress` abstract method invocation that occurs\n * when a responder is released while in either of the \"Press\" states.\n *\n * The other important side effects are the highlight abstract method\n * invocations (internal callbacks) to be implemented by the mixer.\n *\n *\n * @lends Touchable.prototype\n */\nvar TouchableMixin = {\n // HACK (part 1): basic support for touchable interactions using a keyboard\n componentDidMount: function componentDidMount() {\n warnOnce('TouchableMixin', 'TouchableMixin is deprecated. Please use Pressable.');\n var touchableNode = this.getTouchableNode && this.getTouchableNode();\n if (touchableNode && touchableNode.addEventListener) {\n this._touchableBlurListener = e => {\n if (this._isTouchableKeyboardActive) {\n if (this.state.touchable.touchState && this.state.touchable.touchState !== States.NOT_RESPONDER) {\n this.touchableHandleResponderTerminate({\n nativeEvent: e\n });\n }\n this._isTouchableKeyboardActive = false;\n }\n };\n touchableNode.addEventListener('blur', this._touchableBlurListener);\n }\n },\n /**\n * Clear all timeouts on unmount\n */\n componentWillUnmount: function componentWillUnmount() {\n var touchableNode = this.getTouchableNode && this.getTouchableNode();\n if (touchableNode && touchableNode.addEventListener) {\n touchableNode.removeEventListener('blur', this._touchableBlurListener);\n }\n this.touchableDelayTimeout && clearTimeout(this.touchableDelayTimeout);\n this.longPressDelayTimeout && clearTimeout(this.longPressDelayTimeout);\n this.pressOutDelayTimeout && clearTimeout(this.pressOutDelayTimeout);\n // Clear DOM nodes\n this.pressInLocation = null;\n this.state.touchable.responderID = null;\n },\n /**\n * It's prefer that mixins determine state in this way, having the class\n * explicitly mix the state in the one and only `getInitialState` method.\n *\n * @return {object} State object to be placed inside of\n * `this.state.touchable`.\n */\n touchableGetInitialState: function touchableGetInitialState() {\n return {\n touchable: {\n touchState: undefined,\n responderID: null\n }\n };\n },\n // ==== Hooks to Gesture Responder system ====\n /**\n * Must return true if embedded in a native platform scroll view.\n */\n touchableHandleResponderTerminationRequest: function touchableHandleResponderTerminationRequest() {\n return !this.props.rejectResponderTermination;\n },\n /**\n * Must return true to start the process of `Touchable`.\n */\n touchableHandleStartShouldSetResponder: function touchableHandleStartShouldSetResponder() {\n return !this.props.disabled;\n },\n /**\n * Return true to cancel press on long press.\n */\n touchableLongPressCancelsPress: function touchableLongPressCancelsPress() {\n return true;\n },\n /**\n * Place as callback for a DOM element's `onResponderGrant` event.\n * @param {SyntheticEvent} e Synthetic event from event system.\n *\n */\n touchableHandleResponderGrant: function touchableHandleResponderGrant(e) {\n var dispatchID = e.currentTarget;\n // Since e is used in a callback invoked on another event loop\n // (as in setTimeout etc), we need to call e.persist() on the\n // event to make sure it doesn't get reused in the event object pool.\n e.persist();\n this.pressOutDelayTimeout && clearTimeout(this.pressOutDelayTimeout);\n this.pressOutDelayTimeout = null;\n this.state.touchable.touchState = States.NOT_RESPONDER;\n this.state.touchable.responderID = dispatchID;\n this._receiveSignal(Signals.RESPONDER_GRANT, e);\n var delayMS = this.touchableGetHighlightDelayMS !== undefined ? Math.max(this.touchableGetHighlightDelayMS(), 0) : HIGHLIGHT_DELAY_MS;\n delayMS = isNaN(delayMS) ? HIGHLIGHT_DELAY_MS : delayMS;\n if (delayMS !== 0) {\n this.touchableDelayTimeout = setTimeout(this._handleDelay.bind(this, e), delayMS);\n } else {\n this._handleDelay(e);\n }\n var longDelayMS = this.touchableGetLongPressDelayMS !== undefined ? Math.max(this.touchableGetLongPressDelayMS(), 10) : LONG_PRESS_DELAY_MS;\n longDelayMS = isNaN(longDelayMS) ? LONG_PRESS_DELAY_MS : longDelayMS;\n this.longPressDelayTimeout = setTimeout(this._handleLongDelay.bind(this, e), longDelayMS + delayMS);\n },\n /**\n * Place as callback for a DOM element's `onResponderRelease` event.\n */\n touchableHandleResponderRelease: function touchableHandleResponderRelease(e) {\n this.pressInLocation = null;\n this._receiveSignal(Signals.RESPONDER_RELEASE, e);\n },\n /**\n * Place as callback for a DOM element's `onResponderTerminate` event.\n */\n touchableHandleResponderTerminate: function touchableHandleResponderTerminate(e) {\n this.pressInLocation = null;\n this._receiveSignal(Signals.RESPONDER_TERMINATED, e);\n },\n /**\n * Place as callback for a DOM element's `onResponderMove` event.\n */\n touchableHandleResponderMove: function touchableHandleResponderMove(e) {\n // Measurement may not have returned yet.\n if (!this.state.touchable.positionOnActivate) {\n return;\n }\n var positionOnActivate = this.state.touchable.positionOnActivate;\n var dimensionsOnActivate = this.state.touchable.dimensionsOnActivate;\n var pressRectOffset = this.touchableGetPressRectOffset ? this.touchableGetPressRectOffset() : {\n left: PRESS_EXPAND_PX,\n right: PRESS_EXPAND_PX,\n top: PRESS_EXPAND_PX,\n bottom: PRESS_EXPAND_PX\n };\n var pressExpandLeft = pressRectOffset.left;\n var pressExpandTop = pressRectOffset.top;\n var pressExpandRight = pressRectOffset.right;\n var pressExpandBottom = pressRectOffset.bottom;\n var hitSlop = this.touchableGetHitSlop ? this.touchableGetHitSlop() : null;\n if (hitSlop) {\n pressExpandLeft += hitSlop.left || 0;\n pressExpandTop += hitSlop.top || 0;\n pressExpandRight += hitSlop.right || 0;\n pressExpandBottom += hitSlop.bottom || 0;\n }\n var touch = extractSingleTouch(e.nativeEvent);\n var pageX = touch && touch.pageX;\n var pageY = touch && touch.pageY;\n if (this.pressInLocation) {\n var movedDistance = this._getDistanceBetweenPoints(pageX, pageY, this.pressInLocation.pageX, this.pressInLocation.pageY);\n if (movedDistance > LONG_PRESS_ALLOWED_MOVEMENT) {\n this._cancelLongPressDelayTimeout();\n }\n }\n var isTouchWithinActive = pageX > positionOnActivate.left - pressExpandLeft && pageY > positionOnActivate.top - pressExpandTop && pageX < positionOnActivate.left + dimensionsOnActivate.width + pressExpandRight && pageY < positionOnActivate.top + dimensionsOnActivate.height + pressExpandBottom;\n if (isTouchWithinActive) {\n var prevState = this.state.touchable.touchState;\n this._receiveSignal(Signals.ENTER_PRESS_RECT, e);\n var curState = this.state.touchable.touchState;\n if (curState === States.RESPONDER_INACTIVE_PRESS_IN && prevState !== States.RESPONDER_INACTIVE_PRESS_IN) {\n // fix for t7967420\n this._cancelLongPressDelayTimeout();\n }\n } else {\n this._cancelLongPressDelayTimeout();\n this._receiveSignal(Signals.LEAVE_PRESS_RECT, e);\n }\n },\n /**\n * Invoked when the item receives focus. Mixers might override this to\n * visually distinguish the `VisualRect` so that the user knows that it\n * currently has the focus. Most platforms only support a single element being\n * focused at a time, in which case there may have been a previously focused\n * element that was blurred just prior to this. This can be overridden when\n * using `Touchable.Mixin.withoutDefaultFocusAndBlur`.\n */\n touchableHandleFocus: function touchableHandleFocus(e) {\n this.props.onFocus && this.props.onFocus(e);\n },\n /**\n * Invoked when the item loses focus. Mixers might override this to\n * visually distinguish the `VisualRect` so that the user knows that it\n * no longer has focus. Most platforms only support a single element being\n * focused at a time, in which case the focus may have moved to another.\n * This can be overridden when using\n * `Touchable.Mixin.withoutDefaultFocusAndBlur`.\n */\n touchableHandleBlur: function touchableHandleBlur(e) {\n this.props.onBlur && this.props.onBlur(e);\n },\n // ==== Abstract Application Callbacks ====\n\n /**\n * Invoked when the item should be highlighted. Mixers should implement this\n * to visually distinguish the `VisualRect` so that the user knows that\n * releasing a touch will result in a \"selection\" (analog to click).\n *\n * @abstract\n * touchableHandleActivePressIn: function,\n */\n\n /**\n * Invoked when the item is \"active\" (in that it is still eligible to become\n * a \"select\") but the touch has left the `PressRect`. Usually the mixer will\n * want to unhighlight the `VisualRect`. If the user (while pressing) moves\n * back into the `PressRect` `touchableHandleActivePressIn` will be invoked\n * again and the mixer should probably highlight the `VisualRect` again. This\n * event will not fire on an `touchEnd/mouseUp` event, only move events while\n * the user is depressing the mouse/touch.\n *\n * @abstract\n * touchableHandleActivePressOut: function\n */\n\n /**\n * Invoked when the item is \"selected\" - meaning the interaction ended by\n * letting up while the item was either in the state\n * `RESPONDER_ACTIVE_PRESS_IN` or `RESPONDER_INACTIVE_PRESS_IN`.\n *\n * @abstract\n * touchableHandlePress: function\n */\n\n /**\n * Invoked when the item is long pressed - meaning the interaction ended by\n * letting up while the item was in `RESPONDER_ACTIVE_LONG_PRESS_IN`. If\n * `touchableHandleLongPress` is *not* provided, `touchableHandlePress` will\n * be called as it normally is. If `touchableHandleLongPress` is provided, by\n * default any `touchableHandlePress` callback will not be invoked. To\n * override this default behavior, override `touchableLongPressCancelsPress`\n * to return false. As a result, `touchableHandlePress` will be called when\n * lifting up, even if `touchableHandleLongPress` has also been called.\n *\n * @abstract\n * touchableHandleLongPress: function\n */\n\n /**\n * Returns the number of millis to wait before triggering a highlight.\n *\n * @abstract\n * touchableGetHighlightDelayMS: function\n */\n\n /**\n * Returns the amount to extend the `HitRect` into the `PressRect`. Positive\n * numbers mean the size expands outwards.\n *\n * @abstract\n * touchableGetPressRectOffset: function\n */\n\n // ==== Internal Logic ====\n\n /**\n * Measures the `HitRect` node on activation. The Bounding rectangle is with\n * respect to viewport - not page, so adding the `pageXOffset/pageYOffset`\n * should result in points that are in the same coordinate system as an\n * event's `globalX/globalY` data values.\n *\n * - Consider caching this for the lifetime of the component, or possibly\n * being able to share this cache between any `ScrollMap` view.\n *\n * @sideeffects\n * @private\n */\n _remeasureMetricsOnActivation: function _remeasureMetricsOnActivation() {\n var tag = this.state.touchable.responderID;\n if (tag == null) {\n return;\n }\n UIManager.measure(tag, this._handleQueryLayout);\n },\n _handleQueryLayout: function _handleQueryLayout(l, t, w, h, globalX, globalY) {\n //don't do anything UIManager failed to measure node\n if (!l && !t && !w && !h && !globalX && !globalY) {\n return;\n }\n this.state.touchable.positionOnActivate && Position.release(this.state.touchable.positionOnActivate);\n this.state.touchable.dimensionsOnActivate &&\n // $FlowFixMe\n BoundingDimensions.release(this.state.touchable.dimensionsOnActivate);\n this.state.touchable.positionOnActivate = Position.getPooled(globalX, globalY);\n // $FlowFixMe\n this.state.touchable.dimensionsOnActivate = BoundingDimensions.getPooled(w, h);\n },\n _handleDelay: function _handleDelay(e) {\n this.touchableDelayTimeout = null;\n this._receiveSignal(Signals.DELAY, e);\n },\n _handleLongDelay: function _handleLongDelay(e) {\n this.longPressDelayTimeout = null;\n var curState = this.state.touchable.touchState;\n if (curState !== States.RESPONDER_ACTIVE_PRESS_IN && curState !== States.RESPONDER_ACTIVE_LONG_PRESS_IN) {\n console.error('Attempted to transition from state `' + curState + '` to `' + States.RESPONDER_ACTIVE_LONG_PRESS_IN + '`, which is not supported. This is ' + 'most likely due to `Touchable.longPressDelayTimeout` not being cancelled.');\n } else {\n this._receiveSignal(Signals.LONG_PRESS_DETECTED, e);\n }\n },\n /**\n * Receives a state machine signal, performs side effects of the transition\n * and stores the new state. Validates the transition as well.\n *\n * @param {Signals} signal State machine signal.\n * @throws Error if invalid state transition or unrecognized signal.\n * @sideeffects\n */\n _receiveSignal: function _receiveSignal(signal, e) {\n var responderID = this.state.touchable.responderID;\n var curState = this.state.touchable.touchState;\n var nextState = Transitions[curState] && Transitions[curState][signal];\n if (!responderID && signal === Signals.RESPONDER_RELEASE) {\n return;\n }\n if (!nextState) {\n throw new Error('Unrecognized signal `' + signal + '` or state `' + curState + '` for Touchable responder `' + responderID + '`');\n }\n if (nextState === States.ERROR) {\n throw new Error('Touchable cannot transition from `' + curState + '` to `' + signal + '` for responder `' + responderID + '`');\n }\n if (curState !== nextState) {\n this._performSideEffectsForTransition(curState, nextState, signal, e);\n this.state.touchable.touchState = nextState;\n }\n },\n _cancelLongPressDelayTimeout: function _cancelLongPressDelayTimeout() {\n this.longPressDelayTimeout && clearTimeout(this.longPressDelayTimeout);\n this.longPressDelayTimeout = null;\n },\n _isHighlight: function _isHighlight(state) {\n return state === States.RESPONDER_ACTIVE_PRESS_IN || state === States.RESPONDER_ACTIVE_LONG_PRESS_IN;\n },\n _savePressInLocation: function _savePressInLocation(e) {\n var touch = extractSingleTouch(e.nativeEvent);\n var pageX = touch && touch.pageX;\n var pageY = touch && touch.pageY;\n var locationX = touch && touch.locationX;\n var locationY = touch && touch.locationY;\n this.pressInLocation = {\n pageX,\n pageY,\n locationX,\n locationY\n };\n },\n _getDistanceBetweenPoints: function _getDistanceBetweenPoints(aX, aY, bX, bY) {\n var deltaX = aX - bX;\n var deltaY = aY - bY;\n return Math.sqrt(deltaX * deltaX + deltaY * deltaY);\n },\n /**\n * Will perform a transition between touchable states, and identify any\n * highlighting or unhighlighting that must be performed for this particular\n * transition.\n *\n * @param {States} curState Current Touchable state.\n * @param {States} nextState Next Touchable state.\n * @param {Signal} signal Signal that triggered the transition.\n * @param {Event} e Native event.\n * @sideeffects\n */\n _performSideEffectsForTransition: function _performSideEffectsForTransition(curState, nextState, signal, e) {\n var curIsHighlight = this._isHighlight(curState);\n var newIsHighlight = this._isHighlight(nextState);\n var isFinalSignal = signal === Signals.RESPONDER_TERMINATED || signal === Signals.RESPONDER_RELEASE;\n if (isFinalSignal) {\n this._cancelLongPressDelayTimeout();\n }\n var isInitialTransition = curState === States.NOT_RESPONDER && nextState === States.RESPONDER_INACTIVE_PRESS_IN;\n var isActiveTransition = !IsActive[curState] && IsActive[nextState];\n if (isInitialTransition || isActiveTransition) {\n this._remeasureMetricsOnActivation();\n }\n if (IsPressingIn[curState] && signal === Signals.LONG_PRESS_DETECTED) {\n this.touchableHandleLongPress && this.touchableHandleLongPress(e);\n }\n if (newIsHighlight && !curIsHighlight) {\n this._startHighlight(e);\n } else if (!newIsHighlight && curIsHighlight) {\n this._endHighlight(e);\n }\n if (IsPressingIn[curState] && signal === Signals.RESPONDER_RELEASE) {\n var hasLongPressHandler = !!this.props.onLongPress;\n var pressIsLongButStillCallOnPress = IsLongPressingIn[curState] && (\n // We *are* long pressing.. // But either has no long handler\n !hasLongPressHandler || !this.touchableLongPressCancelsPress()); // or we're told to ignore it.\n\n var shouldInvokePress = !IsLongPressingIn[curState] || pressIsLongButStillCallOnPress;\n if (shouldInvokePress && this.touchableHandlePress) {\n if (!newIsHighlight && !curIsHighlight) {\n // we never highlighted because of delay, but we should highlight now\n this._startHighlight(e);\n this._endHighlight(e);\n }\n this.touchableHandlePress(e);\n }\n }\n this.touchableDelayTimeout && clearTimeout(this.touchableDelayTimeout);\n this.touchableDelayTimeout = null;\n },\n _playTouchSound: function _playTouchSound() {\n UIManager.playTouchSound();\n },\n _startHighlight: function _startHighlight(e) {\n this._savePressInLocation(e);\n this.touchableHandleActivePressIn && this.touchableHandleActivePressIn(e);\n },\n _endHighlight: function _endHighlight(e) {\n if (this.touchableHandleActivePressOut) {\n if (this.touchableGetPressOutDelayMS && this.touchableGetPressOutDelayMS()) {\n this.pressOutDelayTimeout = setTimeout(() => {\n this.touchableHandleActivePressOut(e);\n }, this.touchableGetPressOutDelayMS());\n } else {\n this.touchableHandleActivePressOut(e);\n }\n }\n },\n // HACK (part 2): basic support for touchable interactions using a keyboard (including\n // delays and longPress)\n touchableHandleKeyEvent: function touchableHandleKeyEvent(e) {\n var type = e.type,\n key = e.key;\n if (key === 'Enter' || key === ' ') {\n if (type === 'keydown') {\n if (!this._isTouchableKeyboardActive) {\n if (!this.state.touchable.touchState || this.state.touchable.touchState === States.NOT_RESPONDER) {\n this.touchableHandleResponderGrant(e);\n this._isTouchableKeyboardActive = true;\n }\n }\n } else if (type === 'keyup') {\n if (this._isTouchableKeyboardActive) {\n if (this.state.touchable.touchState && this.state.touchable.touchState !== States.NOT_RESPONDER) {\n this.touchableHandleResponderRelease(e);\n this._isTouchableKeyboardActive = false;\n }\n }\n }\n e.stopPropagation();\n // prevent the default behaviour unless the Touchable functions as a link\n // and Enter is pressed\n if (!(key === 'Enter' && AccessibilityUtil.propsToAriaRole(this.props) === 'link')) {\n e.preventDefault();\n }\n }\n },\n withoutDefaultFocusAndBlur: {}\n};\n\n/**\n * Provide an optional version of the mixin where `touchableHandleFocus` and\n * `touchableHandleBlur` can be overridden. This allows appropriate defaults to\n * be set on TV platforms, without breaking existing implementations of\n * `Touchable`.\n */\nvar touchableHandleFocus = TouchableMixin.touchableHandleFocus,\n touchableHandleBlur = TouchableMixin.touchableHandleBlur,\n TouchableMixinWithoutDefaultFocusAndBlur = _objectWithoutPropertiesLoose(TouchableMixin, [\"touchableHandleFocus\", \"touchableHandleBlur\"]);\nTouchableMixin.withoutDefaultFocusAndBlur = TouchableMixinWithoutDefaultFocusAndBlur;\nvar Touchable = {\n Mixin: TouchableMixin,\n TOUCH_TARGET_DEBUG: false,\n // Highlights all touchable targets. Toggle with Inspector.\n /**\n * Renders a debugging overlay to visualize touch target with hitSlop (might not work on Android).\n */\n renderDebugView: _ref => {\n var color = _ref.color,\n hitSlop = _ref.hitSlop;\n if (!Touchable.TOUCH_TARGET_DEBUG) {\n return null;\n }\n if (process.env.NODE_ENV !== 'production') {\n throw Error('Touchable.TOUCH_TARGET_DEBUG should not be enabled in prod!');\n }\n var debugHitSlopStyle = {};\n hitSlop = hitSlop || {\n top: 0,\n bottom: 0,\n left: 0,\n right: 0\n };\n for (var key in hitSlop) {\n debugHitSlopStyle[key] = -hitSlop[key];\n }\n var normalizedColor = normalizeColor(color);\n if (typeof normalizedColor !== 'number') {\n return null;\n }\n var hexColor = '#' + ('00000000' + normalizedColor.toString(16)).substr(-8);\n return /*#__PURE__*/React.createElement(View, {\n pointerEvents: \"none\",\n style: _objectSpread({\n position: 'absolute',\n borderColor: hexColor.slice(0, -2) + '55',\n // More opaque\n borderWidth: 1,\n borderStyle: 'dashed',\n backgroundColor: hexColor.slice(0, -2) + '0F'\n }, debugHitSlopStyle)\n });\n }\n};\nexport default Touchable;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport PooledClass from '../../vendor/react-native/PooledClass';\nvar twoArgumentPooler = PooledClass.twoArgumentPooler;\n\n/**\n * PooledClass representing the bounding rectangle of a region.\n */\nfunction BoundingDimensions(width, height) {\n this.width = width;\n this.height = height;\n}\nBoundingDimensions.prototype.destructor = function () {\n this.width = null;\n this.height = null;\n};\nBoundingDimensions.getPooledFromElement = function (element) {\n return BoundingDimensions.getPooled(element.offsetWidth, element.offsetHeight);\n};\nPooledClass.addPoolingTo(BoundingDimensions, twoArgumentPooler);\nexport default BoundingDimensions;","/* eslint-disable */\n\n/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * From React 16.0.0\n */\n\nimport invariant from 'fbjs/lib/invariant';\nvar twoArgumentPooler = function twoArgumentPooler(a1, a2) {\n var Klass = this;\n if (Klass.instancePool.length) {\n var instance = Klass.instancePool.pop();\n Klass.call(instance, a1, a2);\n return instance;\n } else {\n return new Klass(a1, a2);\n }\n};\nvar standardReleaser = function standardReleaser(instance) {\n var Klass = this;\n instance.destructor();\n if (Klass.instancePool.length < Klass.poolSize) {\n Klass.instancePool.push(instance);\n }\n};\nvar DEFAULT_POOL_SIZE = 10;\nvar DEFAULT_POOLER = twoArgumentPooler;\n\n/**\n * Augments `CopyConstructor` to be a poolable class, augmenting only the class\n * itself (statically) not adding any prototypical fields. Any CopyConstructor\n * you give this may have a `poolSize` property, and will look for a\n * prototypical `destructor` on instances.\n *\n * @param {Function} CopyConstructor Constructor that can be used to reset.\n * @param {Function} pooler Customizable pooler.\n */\nvar addPoolingTo = function addPoolingTo(CopyConstructor, pooler) {\n // Casting as any so that flow ignores the actual implementation and trusts\n // it to match the type we declared\n var NewKlass = CopyConstructor;\n NewKlass.instancePool = [];\n NewKlass.getPooled = pooler || DEFAULT_POOLER;\n if (!NewKlass.poolSize) {\n NewKlass.poolSize = DEFAULT_POOL_SIZE;\n }\n NewKlass.release = standardReleaser;\n return NewKlass;\n};\nvar PooledClass = {\n addPoolingTo: addPoolingTo,\n twoArgumentPooler: twoArgumentPooler\n};\nexport default PooledClass;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport PooledClass from '../../vendor/react-native/PooledClass';\nvar twoArgumentPooler = PooledClass.twoArgumentPooler;\nfunction Position(left, top) {\n this.left = left;\n this.top = top;\n}\nPosition.prototype.destructor = function () {\n this.left = null;\n this.top = null;\n};\nPooledClass.addPoolingTo(Position, twoArgumentPooler);\nexport default Position;","import { StyleSheet } from 'react-native';\n\n// Kept in separate file, to avoid name collision with Symbol element\nexport function resolve(styleProp, cleanedProps) {\n if (styleProp) {\n return StyleSheet ? [styleProp, cleanedProps] :\n // Compatibility for arrays of styles in plain react web\n styleProp[Symbol.iterator] ? Object.assign({}, ...styleProp, cleanedProps) : Object.assign({}, styleProp, cleanedProps);\n } else {\n return cleanedProps;\n }\n}\n//# sourceMappingURL=resolve.js.map","import { append, appendTransform, identity, reset, toArray } from '../Matrix2D';\nimport { parse } from './transform';\nfunction appendTransformProps(props) {\n const {\n x,\n y,\n originX,\n originY,\n scaleX,\n scaleY,\n rotation,\n skewX,\n skewY\n } = props;\n appendTransform(x + originX, y + originY, scaleX, scaleY, rotation, skewX, skewY, originX, originY);\n}\nfunction universal2axis(universal, axisX, axisY, defaultValue) {\n let x;\n let y;\n if (typeof universal === 'number') {\n x = y = universal;\n } else if (typeof universal === 'string') {\n const coords = universal.split(/\\s*,\\s*/);\n if (coords.length === 2) {\n x = +coords[0];\n y = +coords[1];\n } else if (coords.length === 1) {\n x = y = +coords[0];\n }\n } else if (Array.isArray(universal)) {\n if (universal.length === 2) {\n x = +universal[0];\n y = +universal[1];\n } else if (universal.length === 1) {\n x = y = +universal[0];\n }\n }\n axisX = +axisX;\n if (!isNaN(axisX)) {\n x = axisX;\n }\n axisY = +axisY;\n if (!isNaN(axisY)) {\n y = axisY;\n }\n return [x || defaultValue || 0, y || defaultValue || 0];\n}\nexport function transformsArrayToProps(transformObjectsArray) {\n const props = {};\n transformObjectsArray === null || transformObjectsArray === void 0 ? void 0 : transformObjectsArray.forEach(transformObject => {\n const keys = Object.keys(transformObject);\n if (keys.length !== 1) {\n console.error('You must specify exactly one property per transform object.');\n }\n const key = keys[0];\n const value = transformObject[key];\n props[key] = value;\n });\n return props;\n}\nexport function props2transform(props) {\n if (!props) {\n return null;\n }\n const {\n rotation,\n translate,\n translateX,\n translateY,\n origin,\n originX,\n originY,\n scale,\n scaleX,\n scaleY,\n skew,\n skewX,\n skewY,\n x,\n y\n } = props;\n if (rotation == null && translate == null && translateX == null && translateY == null && origin == null && originX == null && originY == null && scale == null && scaleX == null && scaleY == null && skew == null && skewX == null && skewY == null && x == null && y == null) {\n return null;\n }\n if (Array.isArray(x) || Array.isArray(y)) {\n console.warn('Passing SvgLengthList to x or y attribute where SvgLength expected');\n }\n const tr = universal2axis(translate, translateX || (Array.isArray(x) ? x[0] : x), translateY || (Array.isArray(y) ? y[0] : y));\n const or = universal2axis(origin, originX, originY);\n const sc = universal2axis(scale, scaleX, scaleY, 1);\n const sk = universal2axis(skew, skewX, skewY);\n return {\n rotation: rotation == null ? 0 : +rotation || 0,\n originX: or[0],\n originY: or[1],\n scaleX: sc[0],\n scaleY: sc[1],\n skewX: sk[0],\n skewY: sk[1],\n x: tr[0],\n y: tr[1]\n };\n}\nexport function transformToMatrix(props, transform) {\n if (!props && !transform) {\n return null;\n }\n reset();\n props && appendTransformProps(props);\n if (transform) {\n if (Array.isArray(transform)) {\n if (typeof transform[0] === 'number') {\n const columnMatrix = transform;\n append(columnMatrix[0], columnMatrix[1], columnMatrix[2], columnMatrix[3], columnMatrix[4], columnMatrix[5]);\n } else {\n const transformProps = props2transform(transformsArrayToProps(transform));\n transformProps && appendTransformProps(transformProps);\n }\n } else if (typeof transform === 'string') {\n try {\n const t = parse(transform);\n append(t[0], t[3], t[1], t[4], t[2], t[5]);\n } catch (e) {\n console.error(e);\n }\n } else {\n const transformProps = props2transform(transform);\n transformProps && appendTransformProps(transformProps);\n }\n }\n return toArray();\n}\nexport default function extractTransform(props) {\n if (Array.isArray(props) && typeof props[0] === 'number') {\n return props;\n }\n if (typeof props === 'string') {\n try {\n const t = parse(props);\n return [t[0], t[3], t[1], t[4], t[2], t[5]];\n } catch (e) {\n console.error(e);\n return identity;\n }\n }\n // this type is not correct since props can be of type TransformsStyle['transform'] too\n // but it satisfies TS and should not produce any type errors\n const transformProps = props;\n return transformToMatrix(props2transform(transformProps), transformProps === null || transformProps === void 0 ? void 0 : transformProps.transform);\n}\n//# sourceMappingURL=extractTransform.js.map","/**\n * based on\n * https://github.com/CreateJS/EaselJS/blob/631cdffb85eff9413dab43b4676f059b4232d291/src/easeljs/geom/Matrix2D.js\n */\nconst DEG_TO_RAD = Math.PI / 180;\nexport const identity = [1, 0, 0, 1, 0, 0];\nlet a = 1;\nlet b = 0;\nlet c = 0;\nlet d = 1;\nlet tx = 0;\nlet ty = 0;\nlet hasInitialState = true;\n\n/**\n * Represents an affine transformation matrix, and provides tools for concatenating transforms.\n *\n * This matrix can be visualized as:\n *\n * \t[ a c tx\n * \t b d ty\n * \t 0 0 1 ]\n *\n * Note the locations of b and c.\n **/\n\n/**\n * Reset current matrix to an identity matrix.\n * @method reset\n **/\nexport function reset() {\n if (hasInitialState) {\n return;\n }\n a = d = 1;\n b = c = tx = ty = 0;\n hasInitialState = true;\n}\n\n/**\n * Returns an array with current matrix values.\n * @method toArray\n * @return {Array} an array with current matrix values.\n **/\nexport function toArray() {\n if (hasInitialState) {\n return identity;\n }\n return [a, b, c, d, tx, ty];\n}\n\n/**\n * Appends the specified matrix properties to this matrix. All parameters are required.\n * This is the equivalent of multiplying `(this matrix) * (specified matrix)`.\n * @method append\n * @param {Number} a2\n * @param {Number} b2\n * @param {Number} c2\n * @param {Number} d2\n * @param {Number} tx2\n * @param {Number} ty2\n **/\nexport function append(a2, b2, c2, d2, tx2, ty2) {\n const change = a2 !== 1 || b2 !== 0 || c2 !== 0 || d2 !== 1;\n const translate = tx2 !== 0 || ty2 !== 0;\n if (!change && !translate) {\n return;\n }\n if (hasInitialState) {\n hasInitialState = false;\n a = a2;\n b = b2;\n c = c2;\n d = d2;\n tx = tx2;\n ty = ty2;\n return;\n }\n const a1 = a;\n const b1 = b;\n const c1 = c;\n const d1 = d;\n if (change) {\n a = a1 * a2 + c1 * b2;\n b = b1 * a2 + d1 * b2;\n c = a1 * c2 + c1 * d2;\n d = b1 * c2 + d1 * d2;\n }\n if (translate) {\n tx = a1 * tx2 + c1 * ty2 + tx;\n ty = b1 * tx2 + d1 * ty2 + ty;\n }\n}\n\n/**\n * Generates matrix properties from the specified display object transform properties, and appends them to this matrix.\n * For example, you can use this to generate a matrix representing the transformations of a display object:\n *\n * \treset();\n * \tappendTransform(o.x, o.y, o.scaleX, o.scaleY, o.rotation);\n * \tvar matrix = toArray()\n *\n * @method appendTransform\n * @param {Number} x\n * @param {Number} y\n * @param {Number} scaleX\n * @param {Number} scaleY\n * @param {Number} rotation\n * @param {Number} skewX\n * @param {Number} skewY\n * @param {Number} regX Optional.\n * @param {Number} regY Optional.\n **/\nexport function appendTransform(x, y, scaleX, scaleY, rotation, skewX, skewY, regX, regY) {\n if (x === 0 && y === 0 && scaleX === 1 && scaleY === 1 && rotation === 0 && skewX === 0 && skewY === 0 && regX === 0 && regY === 0) {\n return;\n }\n let cos, sin;\n if (rotation % 360) {\n const r = rotation * DEG_TO_RAD;\n cos = Math.cos(r);\n sin = Math.sin(r);\n } else {\n cos = 1;\n sin = 0;\n }\n const a2 = cos * scaleX;\n const b2 = sin * scaleX;\n const c2 = -sin * scaleY;\n const d2 = cos * scaleY;\n if (skewX || skewY) {\n const b1 = Math.tan(skewY * DEG_TO_RAD);\n const c1 = Math.tan(skewX * DEG_TO_RAD);\n append(a2 + c1 * b2, b1 * a2 + b2, c2 + c1 * d2, b1 * c2 + d2, x, y);\n } else {\n append(a2, b2, c2, d2, x, y);\n }\n if (regX || regY) {\n // append the registration offset:\n tx -= regX * a + regY * c;\n ty -= regX * b + regY * d;\n hasInitialState = false;\n }\n}\n//# sourceMappingURL=Matrix2D.js.map","/*\n * Generated by PEG.js 0.10.0.\n *\n * http://pegjs.org/\n */\n\n\"use strict\";\n\nfunction peg$subclass(child, parent) {\n function ctor() {\n this.constructor = child;\n }\n ctor.prototype = parent.prototype;\n child.prototype = new ctor();\n}\nfunction peg$SyntaxError(message, expected, found, location) {\n this.message = message;\n this.expected = expected;\n this.found = found;\n this.location = location;\n this.name = \"SyntaxError\";\n if (typeof Error.captureStackTrace === \"function\") {\n Error.captureStackTrace(this, peg$SyntaxError);\n }\n}\npeg$subclass(peg$SyntaxError, Error);\npeg$SyntaxError.buildMessage = function (expected, found) {\n var DESCRIBE_EXPECTATION_FNS = {\n literal: function (expectation) {\n return \"\\\"\" + literalEscape(expectation.text) + \"\\\"\";\n },\n \"class\": function (expectation) {\n var escapedParts = \"\",\n i;\n for (i = 0; i < expectation.parts.length; i++) {\n escapedParts += expectation.parts[i] instanceof Array ? classEscape(expectation.parts[i][0]) + \"-\" + classEscape(expectation.parts[i][1]) : classEscape(expectation.parts[i]);\n }\n return \"[\" + (expectation.inverted ? \"^\" : \"\") + escapedParts + \"]\";\n },\n any: function (expectation) {\n return \"any character\";\n },\n end: function (expectation) {\n return \"end of input\";\n },\n other: function (expectation) {\n return expectation.description;\n }\n };\n function hex(ch) {\n return ch.charCodeAt(0).toString(16).toUpperCase();\n }\n function literalEscape(s) {\n return s.replace(/\\\\/g, '\\\\\\\\').replace(/\"/g, '\\\\\"').replace(/\\0/g, '\\\\0').replace(/\\t/g, '\\\\t').replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r').replace(/[\\x00-\\x0F]/g, function (ch) {\n return '\\\\x0' + hex(ch);\n }).replace(/[\\x10-\\x1F\\x7F-\\x9F]/g, function (ch) {\n return '\\\\x' + hex(ch);\n });\n }\n function classEscape(s) {\n return s.replace(/\\\\/g, '\\\\\\\\').replace(/\\]/g, '\\\\]').replace(/\\^/g, '\\\\^').replace(/-/g, '\\\\-').replace(/\\0/g, '\\\\0').replace(/\\t/g, '\\\\t').replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r').replace(/[\\x00-\\x0F]/g, function (ch) {\n return '\\\\x0' + hex(ch);\n }).replace(/[\\x10-\\x1F\\x7F-\\x9F]/g, function (ch) {\n return '\\\\x' + hex(ch);\n });\n }\n function describeExpectation(expectation) {\n return DESCRIBE_EXPECTATION_FNS[expectation.type](expectation);\n }\n function describeExpected(expected) {\n var descriptions = new Array(expected.length),\n i,\n j;\n for (i = 0; i < expected.length; i++) {\n descriptions[i] = describeExpectation(expected[i]);\n }\n descriptions.sort();\n if (descriptions.length > 0) {\n for (i = 1, j = 1; i < descriptions.length; i++) {\n if (descriptions[i - 1] !== descriptions[i]) {\n descriptions[j] = descriptions[i];\n j++;\n }\n }\n descriptions.length = j;\n }\n switch (descriptions.length) {\n case 1:\n return descriptions[0];\n case 2:\n return descriptions[0] + \" or \" + descriptions[1];\n default:\n return descriptions.slice(0, -1).join(\", \") + \", or \" + descriptions[descriptions.length - 1];\n }\n }\n function describeFound(found) {\n return found ? \"\\\"\" + literalEscape(found) + \"\\\"\" : \"end of input\";\n }\n return \"Expected \" + describeExpected(expected) + \" but \" + describeFound(found) + \" found.\";\n};\nfunction peg$parse(input, options) {\n options = options !== void 0 ? options : {};\n var peg$FAILED = {},\n peg$startRuleFunctions = {\n transformList: peg$parsetransformList\n },\n peg$startRuleFunction = peg$parsetransformList,\n peg$c0 = function (ts) {\n return ts;\n },\n peg$c1 = function (t, ts) {\n return multiply_matrices(t, ts);\n },\n peg$c2 = \"matrix\",\n peg$c3 = peg$literalExpectation(\"matrix\", false),\n peg$c4 = \"(\",\n peg$c5 = peg$literalExpectation(\"(\", false),\n peg$c6 = \")\",\n peg$c7 = peg$literalExpectation(\")\", false),\n peg$c8 = function (a, b, c, d, e, f) {\n return [a, c, e, b, d, f];\n },\n peg$c9 = \"translate\",\n peg$c10 = peg$literalExpectation(\"translate\", false),\n peg$c11 = function (tx, ty) {\n return [1, 0, tx, 0, 1, ty || 0];\n },\n peg$c12 = \"scale\",\n peg$c13 = peg$literalExpectation(\"scale\", false),\n peg$c14 = function (sx, sy) {\n return [sx, 0, 0, 0, sy === null ? sx : sy, 0];\n },\n peg$c15 = \"rotate\",\n peg$c16 = peg$literalExpectation(\"rotate\", false),\n peg$c17 = function (angle, c) {\n var cos = Math.cos(deg2rad * angle);\n var sin = Math.sin(deg2rad * angle);\n if (c !== null) {\n var x = c[0];\n var y = c[1];\n return [cos, -sin, cos * -x + -sin * -y + x, sin, cos, sin * -x + cos * -y + y];\n }\n return [cos, -sin, 0, sin, cos, 0];\n },\n peg$c18 = \"skewX\",\n peg$c19 = peg$literalExpectation(\"skewX\", false),\n peg$c20 = function (angle) {\n return [1, Math.tan(deg2rad * angle), 0, 0, 1, 0];\n },\n peg$c21 = \"skewY\",\n peg$c22 = peg$literalExpectation(\"skewY\", false),\n peg$c23 = function (angle) {\n return [1, 0, 0, Math.tan(deg2rad * angle), 1, 0];\n },\n peg$c24 = function (f) {\n return parseFloat(f.join(\"\"));\n },\n peg$c25 = function (i) {\n return parseInt(i.join(\"\"));\n },\n peg$c26 = function (n) {\n return n;\n },\n peg$c27 = function (n1, n2) {\n return [n1, n2];\n },\n peg$c28 = \",\",\n peg$c29 = peg$literalExpectation(\",\", false),\n peg$c30 = function (ds) {\n return ds.join(\"\");\n },\n peg$c31 = function (f) {\n return f.join(\"\");\n },\n peg$c32 = function (d) {\n return d.join(\"\");\n },\n peg$c33 = peg$otherExpectation(\"fractionalConstant\"),\n peg$c34 = \".\",\n peg$c35 = peg$literalExpectation(\".\", false),\n peg$c36 = function (d1, d2) {\n return [d1 ? d1.join(\"\") : null, \".\", d2.join(\"\")].join(\"\");\n },\n peg$c37 = /^[eE]/,\n peg$c38 = peg$classExpectation([\"e\", \"E\"], false, false),\n peg$c39 = function (e) {\n return [e[0], e[1], e[2].join(\"\")].join(\"\");\n },\n peg$c40 = /^[+\\-]/,\n peg$c41 = peg$classExpectation([\"+\", \"-\"], false, false),\n peg$c42 = /^[0-9]/,\n peg$c43 = peg$classExpectation([[\"0\", \"9\"]], false, false),\n peg$c44 = /^[ \\t\\r\\n]/,\n peg$c45 = peg$classExpectation([\" \", \"\\t\", \"\\r\", \"\\n\"], false, false),\n peg$currPos = 0,\n peg$savedPos = 0,\n peg$posDetailsCache = [{\n line: 1,\n column: 1\n }],\n peg$maxFailPos = 0,\n peg$maxFailExpected = [],\n peg$silentFails = 0,\n peg$result;\n if (\"startRule\" in options) {\n if (!(options.startRule in peg$startRuleFunctions)) {\n throw new Error(\"Can't start parsing from rule \\\"\" + options.startRule + \"\\\".\");\n }\n peg$startRuleFunction = peg$startRuleFunctions[options.startRule];\n }\n function text() {\n return input.substring(peg$savedPos, peg$currPos);\n }\n function location() {\n return peg$computeLocation(peg$savedPos, peg$currPos);\n }\n function expected(description, location) {\n location = location !== void 0 ? location : peg$computeLocation(peg$savedPos, peg$currPos);\n throw peg$buildStructuredError([peg$otherExpectation(description)], input.substring(peg$savedPos, peg$currPos), location);\n }\n function error(message, location) {\n location = location !== void 0 ? location : peg$computeLocation(peg$savedPos, peg$currPos);\n throw peg$buildSimpleError(message, location);\n }\n function peg$literalExpectation(text, ignoreCase) {\n return {\n type: \"literal\",\n text: text,\n ignoreCase: ignoreCase\n };\n }\n function peg$classExpectation(parts, inverted, ignoreCase) {\n return {\n type: \"class\",\n parts: parts,\n inverted: inverted,\n ignoreCase: ignoreCase\n };\n }\n function peg$anyExpectation() {\n return {\n type: \"any\"\n };\n }\n function peg$endExpectation() {\n return {\n type: \"end\"\n };\n }\n function peg$otherExpectation(description) {\n return {\n type: \"other\",\n description: description\n };\n }\n function peg$computePosDetails(pos) {\n var details = peg$posDetailsCache[pos],\n p;\n if (details) {\n return details;\n } else {\n p = pos - 1;\n while (!peg$posDetailsCache[p]) {\n p--;\n }\n details = peg$posDetailsCache[p];\n details = {\n line: details.line,\n column: details.column\n };\n while (p < pos) {\n if (input.charCodeAt(p) === 10) {\n details.line++;\n details.column = 1;\n } else {\n details.column++;\n }\n p++;\n }\n peg$posDetailsCache[pos] = details;\n return details;\n }\n }\n function peg$computeLocation(startPos, endPos) {\n var startPosDetails = peg$computePosDetails(startPos),\n endPosDetails = peg$computePosDetails(endPos);\n return {\n start: {\n offset: startPos,\n line: startPosDetails.line,\n column: startPosDetails.column\n },\n end: {\n offset: endPos,\n line: endPosDetails.line,\n column: endPosDetails.column\n }\n };\n }\n function peg$fail(expected) {\n if (peg$currPos < peg$maxFailPos) {\n return;\n }\n if (peg$currPos > peg$maxFailPos) {\n peg$maxFailPos = peg$currPos;\n peg$maxFailExpected = [];\n }\n peg$maxFailExpected.push(expected);\n }\n function peg$buildSimpleError(message, location) {\n return new peg$SyntaxError(message, null, null, location);\n }\n function peg$buildStructuredError(expected, found, location) {\n return new peg$SyntaxError(peg$SyntaxError.buildMessage(expected, found), expected, found, location);\n }\n function peg$parsetransformList() {\n var s0, s1, s2, s3, s4;\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parsewsp();\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parsewsp();\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsetransforms();\n if (s2 === peg$FAILED) {\n s2 = null;\n }\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parsewsp();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parsewsp();\n }\n if (s3 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c0(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parsetransforms() {\n var s0, s1, s2, s3;\n s0 = peg$currPos;\n s1 = peg$parsetransform();\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsecommaWsp();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsecommaWsp();\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parsetransforms();\n if (s3 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c1(s1, s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$parsetransform();\n }\n return s0;\n }\n function peg$parsetransform() {\n var s0;\n s0 = peg$parsematrix();\n if (s0 === peg$FAILED) {\n s0 = peg$parsetranslate();\n if (s0 === peg$FAILED) {\n s0 = peg$parsescale();\n if (s0 === peg$FAILED) {\n s0 = peg$parserotate();\n if (s0 === peg$FAILED) {\n s0 = peg$parseskewX();\n if (s0 === peg$FAILED) {\n s0 = peg$parseskewY();\n }\n }\n }\n }\n }\n return s0;\n }\n function peg$parsematrix() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13, s14, s15, s16, s17;\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 6) === peg$c2) {\n s1 = peg$c2;\n peg$currPos += 6;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c3);\n }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsewsp();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsewsp();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 40) {\n s3 = peg$c4;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c5);\n }\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parsewsp();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parsewsp();\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parsenumber();\n if (s5 !== peg$FAILED) {\n s6 = peg$parsecommaWsp();\n if (s6 !== peg$FAILED) {\n s7 = peg$parsenumber();\n if (s7 !== peg$FAILED) {\n s8 = peg$parsecommaWsp();\n if (s8 !== peg$FAILED) {\n s9 = peg$parsenumber();\n if (s9 !== peg$FAILED) {\n s10 = peg$parsecommaWsp();\n if (s10 !== peg$FAILED) {\n s11 = peg$parsenumber();\n if (s11 !== peg$FAILED) {\n s12 = peg$parsecommaWsp();\n if (s12 !== peg$FAILED) {\n s13 = peg$parsenumber();\n if (s13 !== peg$FAILED) {\n s14 = peg$parsecommaWsp();\n if (s14 !== peg$FAILED) {\n s15 = peg$parsenumber();\n if (s15 !== peg$FAILED) {\n s16 = [];\n s17 = peg$parsewsp();\n while (s17 !== peg$FAILED) {\n s16.push(s17);\n s17 = peg$parsewsp();\n }\n if (s16 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 41) {\n s17 = peg$c6;\n peg$currPos++;\n } else {\n s17 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c7);\n }\n }\n if (s17 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c8(s5, s7, s9, s11, s13, s15);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parsetranslate() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8;\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 9) === peg$c9) {\n s1 = peg$c9;\n peg$currPos += 9;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c10);\n }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsewsp();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsewsp();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 40) {\n s3 = peg$c4;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c5);\n }\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parsewsp();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parsewsp();\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parsenumber();\n if (s5 !== peg$FAILED) {\n s6 = peg$parsecommaWspNumber();\n if (s6 === peg$FAILED) {\n s6 = null;\n }\n if (s6 !== peg$FAILED) {\n s7 = [];\n s8 = peg$parsewsp();\n while (s8 !== peg$FAILED) {\n s7.push(s8);\n s8 = peg$parsewsp();\n }\n if (s7 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 41) {\n s8 = peg$c6;\n peg$currPos++;\n } else {\n s8 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c7);\n }\n }\n if (s8 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c11(s5, s6);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parsescale() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8;\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 5) === peg$c12) {\n s1 = peg$c12;\n peg$currPos += 5;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c13);\n }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsewsp();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsewsp();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 40) {\n s3 = peg$c4;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c5);\n }\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parsewsp();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parsewsp();\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parsenumber();\n if (s5 !== peg$FAILED) {\n s6 = peg$parsecommaWspNumber();\n if (s6 === peg$FAILED) {\n s6 = null;\n }\n if (s6 !== peg$FAILED) {\n s7 = [];\n s8 = peg$parsewsp();\n while (s8 !== peg$FAILED) {\n s7.push(s8);\n s8 = peg$parsewsp();\n }\n if (s7 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 41) {\n s8 = peg$c6;\n peg$currPos++;\n } else {\n s8 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c7);\n }\n }\n if (s8 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c14(s5, s6);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parserotate() {\n var s0, s1, s2, s3, s4, s5, s6, s7, s8;\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 6) === peg$c15) {\n s1 = peg$c15;\n peg$currPos += 6;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c16);\n }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsewsp();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsewsp();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 40) {\n s3 = peg$c4;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c5);\n }\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parsewsp();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parsewsp();\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parsenumber();\n if (s5 !== peg$FAILED) {\n s6 = peg$parsecommaWspTwoNumbers();\n if (s6 === peg$FAILED) {\n s6 = null;\n }\n if (s6 !== peg$FAILED) {\n s7 = [];\n s8 = peg$parsewsp();\n while (s8 !== peg$FAILED) {\n s7.push(s8);\n s8 = peg$parsewsp();\n }\n if (s7 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 41) {\n s8 = peg$c6;\n peg$currPos++;\n } else {\n s8 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c7);\n }\n }\n if (s8 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c17(s5, s6);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parseskewX() {\n var s0, s1, s2, s3, s4, s5, s6, s7;\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 5) === peg$c18) {\n s1 = peg$c18;\n peg$currPos += 5;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c19);\n }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsewsp();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsewsp();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 40) {\n s3 = peg$c4;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c5);\n }\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parsewsp();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parsewsp();\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parsenumber();\n if (s5 !== peg$FAILED) {\n s6 = [];\n s7 = peg$parsewsp();\n while (s7 !== peg$FAILED) {\n s6.push(s7);\n s7 = peg$parsewsp();\n }\n if (s6 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 41) {\n s7 = peg$c6;\n peg$currPos++;\n } else {\n s7 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c7);\n }\n }\n if (s7 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c20(s5);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parseskewY() {\n var s0, s1, s2, s3, s4, s5, s6, s7;\n s0 = peg$currPos;\n if (input.substr(peg$currPos, 5) === peg$c21) {\n s1 = peg$c21;\n peg$currPos += 5;\n } else {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c22);\n }\n }\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsewsp();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsewsp();\n }\n if (s2 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 40) {\n s3 = peg$c4;\n peg$currPos++;\n } else {\n s3 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c5);\n }\n }\n if (s3 !== peg$FAILED) {\n s4 = [];\n s5 = peg$parsewsp();\n while (s5 !== peg$FAILED) {\n s4.push(s5);\n s5 = peg$parsewsp();\n }\n if (s4 !== peg$FAILED) {\n s5 = peg$parsenumber();\n if (s5 !== peg$FAILED) {\n s6 = [];\n s7 = peg$parsewsp();\n while (s7 !== peg$FAILED) {\n s6.push(s7);\n s7 = peg$parsewsp();\n }\n if (s6 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 41) {\n s7 = peg$c6;\n peg$currPos++;\n } else {\n s7 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c7);\n }\n }\n if (s7 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c23(s5);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parsenumber() {\n var s0, s1, s2, s3;\n s0 = peg$currPos;\n s1 = peg$currPos;\n s2 = peg$parsesign();\n if (s2 === peg$FAILED) {\n s2 = null;\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parsefloatingPointConstant();\n if (s3 !== peg$FAILED) {\n s2 = [s2, s3];\n s1 = s2;\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n if (s1 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c24(s1);\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$currPos;\n s2 = peg$parsesign();\n if (s2 === peg$FAILED) {\n s2 = null;\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parseintegerConstant();\n if (s3 !== peg$FAILED) {\n s2 = [s2, s3];\n s1 = s2;\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n if (s1 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c25(s1);\n }\n s0 = s1;\n }\n return s0;\n }\n function peg$parsecommaWspNumber() {\n var s0, s1, s2;\n s0 = peg$currPos;\n s1 = peg$parsecommaWsp();\n if (s1 !== peg$FAILED) {\n s2 = peg$parsenumber();\n if (s2 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c26(s2);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parsecommaWspTwoNumbers() {\n var s0, s1, s2, s3, s4;\n s0 = peg$currPos;\n s1 = peg$parsecommaWsp();\n if (s1 !== peg$FAILED) {\n s2 = peg$parsenumber();\n if (s2 !== peg$FAILED) {\n s3 = peg$parsecommaWsp();\n if (s3 !== peg$FAILED) {\n s4 = peg$parsenumber();\n if (s4 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c27(s2, s4);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parsecommaWsp() {\n var s0, s1, s2, s3, s4;\n s0 = peg$currPos;\n s1 = [];\n s2 = peg$parsewsp();\n if (s2 !== peg$FAILED) {\n while (s2 !== peg$FAILED) {\n s1.push(s2);\n s2 = peg$parsewsp();\n }\n } else {\n s1 = peg$FAILED;\n }\n if (s1 !== peg$FAILED) {\n s2 = peg$parsecomma();\n if (s2 === peg$FAILED) {\n s2 = null;\n }\n if (s2 !== peg$FAILED) {\n s3 = [];\n s4 = peg$parsewsp();\n while (s4 !== peg$FAILED) {\n s3.push(s4);\n s4 = peg$parsewsp();\n }\n if (s3 !== peg$FAILED) {\n s1 = [s1, s2, s3];\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$parsecomma();\n if (s1 !== peg$FAILED) {\n s2 = [];\n s3 = peg$parsewsp();\n while (s3 !== peg$FAILED) {\n s2.push(s3);\n s3 = peg$parsewsp();\n }\n if (s2 !== peg$FAILED) {\n s1 = [s1, s2];\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n }\n return s0;\n }\n function peg$parsecomma() {\n var s0;\n if (input.charCodeAt(peg$currPos) === 44) {\n s0 = peg$c28;\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c29);\n }\n }\n return s0;\n }\n function peg$parseintegerConstant() {\n var s0, s1;\n s0 = peg$currPos;\n s1 = peg$parsedigitSequence();\n if (s1 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c30(s1);\n }\n s0 = s1;\n return s0;\n }\n function peg$parsefloatingPointConstant() {\n var s0, s1, s2, s3;\n s0 = peg$currPos;\n s1 = peg$currPos;\n s2 = peg$parsefractionalConstant();\n if (s2 !== peg$FAILED) {\n s3 = peg$parseexponent();\n if (s3 === peg$FAILED) {\n s3 = null;\n }\n if (s3 !== peg$FAILED) {\n s2 = [s2, s3];\n s1 = s2;\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n if (s1 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c31(s1);\n }\n s0 = s1;\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$currPos;\n s2 = peg$parsedigitSequence();\n if (s2 !== peg$FAILED) {\n s3 = peg$parseexponent();\n if (s3 !== peg$FAILED) {\n s2 = [s2, s3];\n s1 = s2;\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n if (s1 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c32(s1);\n }\n s0 = s1;\n }\n return s0;\n }\n function peg$parsefractionalConstant() {\n var s0, s1, s2, s3;\n peg$silentFails++;\n s0 = peg$currPos;\n s1 = peg$parsedigitSequence();\n if (s1 === peg$FAILED) {\n s1 = null;\n }\n if (s1 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 46) {\n s2 = peg$c34;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c35);\n }\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parsedigitSequence();\n if (s3 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c36(s1, s3);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n if (s0 === peg$FAILED) {\n s0 = peg$currPos;\n s1 = peg$parsedigitSequence();\n if (s1 !== peg$FAILED) {\n if (input.charCodeAt(peg$currPos) === 46) {\n s2 = peg$c34;\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c35);\n }\n }\n if (s2 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c32(s1);\n s0 = s1;\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n } else {\n peg$currPos = s0;\n s0 = peg$FAILED;\n }\n }\n peg$silentFails--;\n if (s0 === peg$FAILED) {\n s1 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c33);\n }\n }\n return s0;\n }\n function peg$parseexponent() {\n var s0, s1, s2, s3, s4;\n s0 = peg$currPos;\n s1 = peg$currPos;\n if (peg$c37.test(input.charAt(peg$currPos))) {\n s2 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s2 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c38);\n }\n }\n if (s2 !== peg$FAILED) {\n s3 = peg$parsesign();\n if (s3 === peg$FAILED) {\n s3 = null;\n }\n if (s3 !== peg$FAILED) {\n s4 = peg$parsedigitSequence();\n if (s4 !== peg$FAILED) {\n s2 = [s2, s3, s4];\n s1 = s2;\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n } else {\n peg$currPos = s1;\n s1 = peg$FAILED;\n }\n if (s1 !== peg$FAILED) {\n peg$savedPos = s0;\n s1 = peg$c39(s1);\n }\n s0 = s1;\n return s0;\n }\n function peg$parsesign() {\n var s0;\n if (peg$c40.test(input.charAt(peg$currPos))) {\n s0 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c41);\n }\n }\n return s0;\n }\n function peg$parsedigitSequence() {\n var s0, s1;\n s0 = [];\n s1 = peg$parsedigit();\n if (s1 !== peg$FAILED) {\n while (s1 !== peg$FAILED) {\n s0.push(s1);\n s1 = peg$parsedigit();\n }\n } else {\n s0 = peg$FAILED;\n }\n return s0;\n }\n function peg$parsedigit() {\n var s0;\n if (peg$c42.test(input.charAt(peg$currPos))) {\n s0 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c43);\n }\n }\n return s0;\n }\n function peg$parsewsp() {\n var s0;\n if (peg$c44.test(input.charAt(peg$currPos))) {\n s0 = input.charAt(peg$currPos);\n peg$currPos++;\n } else {\n s0 = peg$FAILED;\n if (peg$silentFails === 0) {\n peg$fail(peg$c45);\n }\n }\n return s0;\n }\n var deg2rad = Math.PI / 180;\n\n /*\n ╔═ ═╗ ╔═ ═╗ ╔═ ═╗\n ║ al cl el ║ ║ ar cr er ║ ║ a c e ║\n ║ bl dl fl ║ * ║ br dr fr ║ = ║ b d f ║\n ║ 0 0 1 ║ ║ 0 0 1 ║ ║ 0 0 1 ║\n ╚═ ═╝ ╚═ ═╝ ╚═ ═╝\n */\n function multiply_matrices(l, r) {\n var al = l[0];\n var cl = l[1];\n var el = l[2];\n var bl = l[3];\n var dl = l[4];\n var fl = l[5];\n var ar = r[0];\n var cr = r[1];\n var er = r[2];\n var br = r[3];\n var dr = r[4];\n var fr = r[5];\n var a = al * ar + cl * br;\n var c = al * cr + cl * dr;\n var e = al * er + cl * fr + el;\n var b = bl * ar + dl * br;\n var d = bl * cr + dl * dr;\n var f = bl * er + dl * fr + fl;\n return [a, c, e, b, d, f];\n }\n peg$result = peg$startRuleFunction();\n if (peg$result !== peg$FAILED && peg$currPos === input.length) {\n return peg$result;\n } else {\n if (peg$result !== peg$FAILED && peg$currPos < input.length) {\n peg$fail(peg$endExpectation());\n }\n throw peg$buildStructuredError(peg$maxFailExpected, peg$maxFailPos < input.length ? input.charAt(peg$maxFailPos) : null, peg$maxFailPos < input.length ? peg$computeLocation(peg$maxFailPos, peg$maxFailPos + 1) : peg$computeLocation(peg$maxFailPos, peg$maxFailPos));\n }\n}\nmodule.exports = {\n SyntaxError: peg$SyntaxError,\n parse: peg$parse\n};\n//# sourceMappingURL=transform.js.map","import React, {useContext, useEffect, useImperativeHandle, useRef, useState} from \"react\";\nimport {Platform, View} from \"react-native\";\nimport {ChampionImageM} from \"./ChampionImageM\";\nimport {SpeechBubbleM} from \"@common/components/speech-bubble/SpeechBubbleM\";\nimport {whatIsIt} from \"@data/utility/Utils\";\nimport {connect} from \"react-redux\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\n\nconst ChampionBubble = React.forwardRef((props, ref) => {\n\n const {\n name,\n variant,\n texts,\n onNextPress,\n championPosition,\n style,\n noAnimation = false,\n allowSpeechReplay = false,\n hideIcons = true,\n } = props\n\n\n useEffect(() => {\n // console.log(\"HEY\")\n\n // if (!props.user?.champion_intros_viewed_at?.[name])\n // championModalRef?.current?.showChampion(\n // name,\n // championsConstants?.[name + \"_intro\"]?.variant,\n // championsConstants?.[name + \"_intro\"]?.texts,\n // () => {\n // }\n // )\n\n }, []);\n\n const championWidthLeft = 90\n const paddingHorizontalLeft = 20\n\n const speechBubbleRef = useRef()\n\n // variant can be array or string\n const isVariantArray = whatIsIt(variant) === \"Array\"\n const [variantIndex, setVariantIndex] = useState(0)\n const goToNextVariant = () => {\n if (variantIndex < variant?.length - 1)\n setVariantIndex(index => index + 1)\n }\n const dimensions = useContext(DimensionsContext)\n\n useImperativeHandle(ref, () => ({\n onChampionBubbleNext() {\n if (isVariantArray) {\n goToNextVariant()\n }\n speechBubbleRef.current?.onSpeechBubblePress()\n }\n }));\n\n\n\n\n\n if (championPosition === \"left\") {\n return \n \n \n {texts && \n }\n \n ;\n } else {\n return \n \n\n \n ;\n }\n});\n\nconst mapStateToProps = state => {\n return {\n\n user: state.data.currentUser?.object\n }\n}\n\nconst mapDispatchToProps = {}\n\nexport default connect(mapStateToProps, mapDispatchToProps, null, {forwardRef: true})(ChampionBubble)","import React from \"react\";\nimport SpeechBubble from \"./index\";\nimport {theme} from \"../../theme/theme\";\nimport {Platform, View} from \"react-native\";\n\nexport const SpeechBubbleM = React.forwardRef((props, ref) => {\n const {\n texts,\n onNextPress,\n containerStyle,\n textStyle,\n position,\n noAnimation = false,\n allowSpeechReplay = false,\n hideIcons = true,\n } = props\n return \n\n \n\n \n});","// import PropTypes from 'prop-types';\nimport React from 'react';\nimport {Animated, Image, StyleSheet, Text, TouchableOpacity, View} from 'react-native';\n\nimport TypeWriter from './TypeWriter';\nimport {theme} from \"../../theme/theme\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\n\n// const propTypes = {\n// allowSkip: PropTypes.bool,\n// allowSpeechReplay: PropTypes.bool,\n// noAnimation: PropTypes.bool,\n// onSpeechEnd: PropTypes.func,\n// onSpeechNext: PropTypes.func,\n// onSpeechReplay: PropTypes.func,\n// speaker: PropTypes.string,\n// speakerStyle: ViewPropTypes.style,\n// speakerTextStyle: Text.propTypes.style,\n// speechBubbleActiveOpacity: PropTypes.number,\n// speechBubbleStyle: ViewPropTypes.style,\n// speechBubbleTextStyle: ViewPropTypes.style,\n// speeches: PropTypes.array.isRequired,\n// typeWriterStyle: Text.propTypes.style,\n// nextStyle: ViewPropTypes.style,\n// style: ViewPropTypes.style,\n// hideIcons: PropTypes.bool,\n// position: PropTypes.string,\n// animateTouchIcon: PropTypes.bool,\n// touchIcon: Image.propTypes.source,\n// animateReplayIcon: PropTypes.bool,\n// replayIcon: Image.propTypes.source,\n// writingDelay: PropTypes.number\n// };\n\nconst defaultProps = {\n animateTouchIcon: true,\n touchIcon: require('./assets/ic_touch_app.png'),\n animateReplayIcon: true,\n replayIcon: require('./assets/ic_replay.png'),\n writingDelay: 100\n};\n\nconst styles = StyleSheet.create({\n dialog: {\n flexDirection: 'row',\n borderRadius: 50,\n backgroundColor: 'white',\n marginLeft: 20,\n marginRight: 20,\n marginBottom: 20,\n paddingLeft: 20,\n paddingRight: 10,\n paddingTop: 20,\n paddingBottom: 20,\n overflow: 'hidden'\n },\n dialogText: {\n flexShrink: 1\n },\n dialogNext: {\n padding: 5,\n justifyContent: 'center',\n backgroundColor: 'transparent'\n },\n typeWriter: {\n backgroundColor: 'transparent'\n },\n triangle: {\n position: 'absolute',\n width: 0,\n height: 0,\n backgroundColor: 'transparent',\n borderStyle: 'solid',\n borderTopWidth: 20,\n borderRightWidth: 8,\n borderBottomWidth: 20,\n borderLeftWidth: 8,\n borderTopColor: 'transparent',\n borderRightColor: 'transparent',\n borderLeftColor: 'transparent',\n zIndex: -10,\n },\n bottomTriangle: {\n alignSelf: \"center\",\n borderBottomColor: theme.colors.lighter,\n bottom: -40,\n transform: [{ rotate: '180deg' }],\n },\n leftTriangle: {\n top: 0,\n borderBottomColor: theme.colors.lighter,\n left: -22,\n transform: [{ rotate: '-90deg' }],\n },\n});\n\n\nclass SpeechBubble extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n speechIndex: 0,\n speechBubbleScale: new Animated.Value(1),\n nextDialogAnimation: new Animated.ValueXY(),\n replaySpeechBubbleAnimation: new Animated.Value(0),\n typeEnd: false,\n lastSpeech: false\n };\n\n this.onSpeechBubblePress = this.onSpeechBubblePress.bind(this);\n this.onSpeechBubblePressIn = this.onSpeechBubblePressIn.bind(this);\n this.onSpeechBubblePressOut = this.onSpeechBubblePressOut.bind(this);\n this.nextSpeechBubbleAnimation = this.nextSpeechBubbleAnimation.bind(this);\n this.replaySpeechBubbleAnimation = this.replaySpeechBubbleAnimation.bind(this);\n }\n\n get NextSpeechBubble() {\n return !this.state.lastSpeech ? (\n \n \n \n ) : null;\n }\n\n get ReplaySpeechBubble() {\n const interpolatedRotateAnimation = this.state.replaySpeechBubbleAnimation.interpolate({\n inputRange: [0, 1],\n outputRange: ['0deg', '360deg']\n });\n\n return this.state.lastSpeech ? (\n \n ) : null;\n }\n\n componentDidMount() {\n this.nextSpeechBubbleAnimation();\n this.replaySpeechBubbleAnimation();\n }\n\n onSpeechBubblePress() {\n\n const {speechIndex, typeEnd} = this.state;\n const {allowSkip, onSpeechNext, onSpeechReplay, speeches} = this.props;\n\n if (allowSkip || typeEnd) {\n if (speechIndex + 1 < speeches.length) {\n const lastSpeech = (speechIndex + 1) + 1 === speeches.length;\n\n // Next speech\n if (onSpeechNext) {\n onSpeechNext();\n }\n\n this.setState({\n speechIndex: speechIndex + 1,\n typeEnd: false,\n lastSpeech\n });\n } else {\n // Replay speech\n if (onSpeechReplay) {\n onSpeechReplay();\n // console.log(\"on speech replay\")\n }\n\n if (this.props.allowSpeechReplay) {\n this.setState({\n speechIndex: 0,\n typeEnd: false,\n lastSpeech: speeches.length === 1\n });\n }\n }\n }\n }\n\n onSpeechBubblePressIn() {\n Animated.spring(this.state.speechBubbleScale, {\n toValue: 0.9,\n tension: 40,\n friction: 3,\n useNativeDriver: true\n }).start();\n }\n\n onSpeechBubblePressOut() {\n Animated.spring(this.state.speechBubbleScale, {\n toValue: 1,\n tension: 40,\n friction: 3,\n useNativeDriver: true\n }).start();\n }\n\n nextSpeechBubbleAnimation() {\n const anim = this.state.nextDialogAnimation;\n const translateDuration = 200;\n\n Animated.sequence([\n Animated.timing(anim.y, {\n toValue: -5,\n duration: translateDuration,\n useNativeDriver: true\n }),\n Animated.timing(anim.y, {\n toValue: 5,\n duration: translateDuration,\n useNativeDriver: true\n })\n ]).start(() => {\n this.nextSpeechBubbleAnimation();\n });\n }\n\n replaySpeechBubbleAnimation() {\n const anim = this.state.replaySpeechBubbleAnimation;\n const rotateDuration = 750;\n\n Animated.sequence([\n Animated.timing(anim, {\n toValue: 1,\n duration: rotateDuration,\n useNativeDriver: true\n // easing: Easing.linear,\n }),\n Animated.delay(1000),\n Animated.timing(anim, {\n toValue: 0,\n duration: rotateDuration,\n useNativeDriver: true\n })\n ]).start(() => {\n this.replaySpeechBubbleAnimation();\n });\n }\n\n render() {\n return (\n \n \n {this.props.speaker} \n \n {\n if(this.props.numberOflines>=6)\n DialogM.show({text1: this.props.speeches})\n }}\n onPressIn={!this.props.hideIcons ? this.onSpeechBubblePressIn : () => {\n }}\n onPressOut={!this.props.hideIcons ? this.onSpeechBubblePressOut : () => {\n }}\n >\n \n \n {\n if (this.props.onSpeechEnd) {\n this.props.onSpeechEnd();\n }\n\n this.setState({typeEnd: true});\n }}\n typeWriterStyle={this.props.typeWriterStyle || styles.typeWriter}\n numberOfLines={this.props.numberOflines}\n />\n \n \n\n \n {this.props.numberOflines>=6 && }\n \n {!this.props.hideIcons && this.NextSpeechBubble}\n {!this.props.hideIcons && this.ReplaySpeechBubble}\n \n \n );\n }\n}\n\n// SpeechBubble.propTypes = propTypes;\nSpeechBubble.defaultProps = defaultProps;\n\nexport default SpeechBubble;\n","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"activeOpacity\", \"delayPressIn\", \"delayPressOut\", \"delayLongPress\", \"disabled\", \"focusable\", \"onLongPress\", \"onPress\", \"onPressIn\", \"onPressOut\", \"rejectResponderTermination\", \"style\"];\nimport * as React from 'react';\nimport { useCallback, useMemo, useState, useRef } from 'react';\nimport useMergeRefs from '../../modules/useMergeRefs';\nimport usePressEvents from '../../modules/usePressEvents';\nimport StyleSheet from '../StyleSheet';\nimport View from '../View';\nimport { warnOnce } from '../../modules/warnOnce';\n/**\n * A wrapper for making views respond properly to touches.\n * On press down, the opacity of the wrapped view is decreased, dimming it.\n */\nfunction TouchableOpacity(props, forwardedRef) {\n warnOnce('TouchableOpacity', 'TouchableOpacity is deprecated. Please use Pressable.');\n var activeOpacity = props.activeOpacity,\n delayPressIn = props.delayPressIn,\n delayPressOut = props.delayPressOut,\n delayLongPress = props.delayLongPress,\n disabled = props.disabled,\n focusable = props.focusable,\n onLongPress = props.onLongPress,\n onPress = props.onPress,\n onPressIn = props.onPressIn,\n onPressOut = props.onPressOut,\n rejectResponderTermination = props.rejectResponderTermination,\n style = props.style,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n var hostRef = useRef(null);\n var setRef = useMergeRefs(forwardedRef, hostRef);\n var _useState = useState('0s'),\n duration = _useState[0],\n setDuration = _useState[1];\n var _useState2 = useState(null),\n opacityOverride = _useState2[0],\n setOpacityOverride = _useState2[1];\n var setOpacityTo = useCallback((value, duration) => {\n setOpacityOverride(value);\n setDuration(duration ? duration / 1000 + \"s\" : '0s');\n }, [setOpacityOverride, setDuration]);\n var setOpacityActive = useCallback(duration => {\n setOpacityTo(activeOpacity !== null && activeOpacity !== void 0 ? activeOpacity : 0.2, duration);\n }, [activeOpacity, setOpacityTo]);\n var setOpacityInactive = useCallback(duration => {\n setOpacityTo(null, duration);\n }, [setOpacityTo]);\n var pressConfig = useMemo(() => ({\n cancelable: !rejectResponderTermination,\n disabled,\n delayLongPress,\n delayPressStart: delayPressIn,\n delayPressEnd: delayPressOut,\n onLongPress,\n onPress,\n onPressStart(event) {\n var isGrant = event.dispatchConfig != null ? event.dispatchConfig.registrationName === 'onResponderGrant' : event.type === 'keydown';\n setOpacityActive(isGrant ? 0 : 150);\n if (onPressIn != null) {\n onPressIn(event);\n }\n },\n onPressEnd(event) {\n setOpacityInactive(250);\n if (onPressOut != null) {\n onPressOut(event);\n }\n }\n }), [delayLongPress, delayPressIn, delayPressOut, disabled, onLongPress, onPress, onPressIn, onPressOut, rejectResponderTermination, setOpacityActive, setOpacityInactive]);\n var pressEventHandlers = usePressEvents(hostRef, pressConfig);\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, pressEventHandlers, {\n accessibilityDisabled: disabled,\n focusable: !disabled && focusable !== false,\n pointerEvents: disabled ? 'box-none' : undefined,\n ref: setRef,\n style: [styles.root, !disabled && styles.actionable, style, opacityOverride != null && {\n opacity: opacityOverride\n }, {\n transitionDuration: duration\n }]\n }));\n}\nvar styles = StyleSheet.create({\n root: {\n transitionProperty: 'opacity',\n transitionDuration: '0.15s',\n userSelect: 'none'\n },\n actionable: {\n cursor: 'pointer',\n touchAction: 'manipulation'\n }\n});\nvar MemoedTouchableOpacity = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(TouchableOpacity));\nMemoedTouchableOpacity.displayName = 'TouchableOpacity';\nexport default MemoedTouchableOpacity;","import React from 'react';\nimport { Text } from 'react-native';\n\n// const delayShape = PropTypes.shape({\n// at: PropTypes.oneOfType([\n// PropTypes.string,\n// PropTypes.number,\n// PropTypes.instanceOf(RegExp),\n// ]),\n// delay: PropTypes.number,\n// });\n//\n// const propTypes = {\n// fixed: PropTypes.bool,\n// delayMap: PropTypes.arrayOf(PropTypes.shape(delayShape)),\n// typing: PropTypes.number,\n// maxDelay: PropTypes.number,\n// minDelay: PropTypes.number,\n// onTypingEnd: PropTypes.func,\n// onTyped: PropTypes.func,\n// text: PropTypes.string,\n// typeWriterStyle: Text.propTypes.style,\n// };\n\nconst defaultProps = {\n typing: 0,\n maxDelay: 100,\n minDelay: 20,\n};\n\nclass TypeWriter extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n visibleChars: 0,\n };\n\n this._handleTimeout = this._handleTimeout.bind(this);\n }\n\n componentDidMount() {\n this._timeoutId = setTimeout(this._handleTimeout, this.props.minDelay);\n }\n\n UNSAFE_componentWillReceiveProps(nextProps) {\n const next = nextProps.typing;\n const active = this.props.typing;\n\n if (this.props.text !== nextProps.text) {\n this.setState({\n visibleChars: 0,\n });\n } else {\n if (active > 0 && next < 0) {\n this.setState({\n visibleChars: this.state.visibleChars - 1,\n });\n } else if (active <= 0 && next > 0) {\n this.setState({\n visibleChars: this.state.visibleChars + 1,\n });\n }\n }\n }\n\n shouldComponentUpdate(nextProps, nextState) {\n return (\n this.state.visibleChars !== nextState.visibleChars ||\n this.props.text !== nextProps.text\n );\n }\n\n componentDidUpdate(prevProps, prevState) {\n const {\n text = \"\",\n maxDelay,\n minDelay,\n delayMap,\n onTyped,\n onTypingEnd,\n } = this.props;\n const { visibleChars } = prevState;\n const token = text?.[visibleChars];\n const nextToken = text[this.state.visibleChars];\n\n if (token && onTyped) {\n onTyped(token, visibleChars);\n }\n\n if (nextToken) {\n let timeout = ~~(Math.random() * (maxDelay - minDelay) + minDelay);\n\n if (delayMap) {\n delayMap.forEach(({ at, delay }) => {\n if (at === visibleChars || token.match(at)) {\n timeout += delay;\n }\n });\n }\n\n this._timeoutId = setTimeout(this._handleTimeout, timeout);\n } else if (onTypingEnd) {\n onTypingEnd();\n }\n }\n\n componentWillUnmount() {\n clearInterval(this._timeoutId);\n }\n\n _handleTimeout() {\n const { typing } = this.props;\n const { visibleChars } = this.state;\n\n this.setState({\n visibleChars: visibleChars + typing,\n });\n }\n\n render() {\n const { text, typeWriterStyle, ...props } = this.props;\n const { visibleChars } = this.state;\n\n return {text?.slice(0, visibleChars)};\n }\n}\n\n// TypeWriter.propTypes = propTypes;\nTypeWriter.defaultProps = defaultProps;\n\nexport default TypeWriter;\n","","","import { useFocusEffect, useRoute } from \"@react-navigation/native\";\nimport React, { useContext } from \"react\";\nimport { BackHandler, Dimensions, Platform, View } from \"react-native\";\nimport { useSafeAreaInsets } from \"react-native-safe-area-context\";\nimport * as amplitude from \"@amplitude/analytics-react-native\";\nimport { DialogM } from \"@common/components/alert/dialog/Dialog\";\nimport { theme } from \"@common/theme/theme\";\nimport { DimensionsContext , IS_WEB } from '@common/utils/mobileUtils'\nimport { IconButton, ProgressBar } from \"react-native-paper\";\nimport { apiIdle, apiRequest } from \"@data/redux/actions/api\";\nimport { connect } from \"react-redux\";\n\nconst ProgressStepperHeader = (props) => {\n // ** Component props\n const {\n navigation,\n currentStep,\n goToPreviousStep,\n exitHandler = () => {},\n countSteps,\n submitted,\n headerRightComponent,\n hideProgressBar,\n exitWarning,\n noPrevious,\n noGoBack,\n hideGoBack,\n track,\n previousRouteName = \"menu\",\n exitWarningMessage = \"Tous tes progrès dans cette activité seront perdus.\",\n noNavigation = false,\n flex = 1,\n } = props\n\n // if (navigation && !IS_WEB) {\n // // ** React Navigation callback\n // useFocusEffect(\n // React.useCallback(() => {\n // BackHandler.addEventListener('hardwareBackPress', backPressed);\n // return () =>\n // BackHandler.removeEventListener('hardwareBackPress', backPressed);\n // }, [currentStep])\n // );\n // }\n\n const insets = useSafeAreaInsets();\n\n const backPressed = () => {\n // console.log('back pressed, current step :', currentStep)\n if (track) amplitude.track(\"button.clicked:progress-stepper.exit\");\n\n if (noPrevious || currentStep <= 1) {\n // console.log('back pressed, no previous')\n if (!exitWarning) {\n exit()\n } else {\n // alertBeforeExit()\n DialogM.show({\n text1: \"Veux-tu vraiment quitter ?\",\n text2: exitWarningMessage,\n buttonText1: \"Quitter\",\n buttonColor1: theme.colors.error,\n onPress: exit,\n buttonText2: \"Annuler\",\n });\n }\n } else {\n goToPreviousStep();\n }\n return true;\n };\n\n\n const exit = () => {\n exitHandler()\n if (noNavigation) return\n\n if (navigation.canGoBack()) {\n navigation.goBack();\n } else {\n navigation.replace(previousRouteName)\n }\n };\n const dimensions = useContext(DimensionsContext);\n\n return (\n \n { 1 ? \"arrow-left\" : \"times\"}\n iconColor={theme.colors.primary}\n containerColor={theme.colors.transparent}\n size={32}\n onPress={backPressed}\n disabled={noGoBack || (hideGoBack && currentStep === 1)}\n style={{ opacity: hideGoBack && currentStep === 1 ? 0 : 1 }}\n />}\n\n {!hideProgressBar && (\n \n \n \n )}\n {!!headerRightComponent && (\n \n {headerRightComponent}\n \n )}\n \n );\n};\n\nconst mapStateToProps = (state) => {\n return {\n isLive: state.liveMode.isLiveModeEnabled,\n };\n};\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle,\n};\n\nexport default connect(\n mapStateToProps,\n mapDispatchToProps\n)(ProgressStepperHeader);\n","function emptyFunction() {}\nvar BackHandler = {\n exitApp: emptyFunction,\n addEventListener: () => ({ remove: emptyFunction }),\n removeEventListener: emptyFunction,\n};\nexport default BackHandler;\n","import React from 'react';\n\nvar isCheckBoxInput = (element) => element.type === 'checkbox';\n\nvar isDateObject = (value) => value instanceof Date;\n\nvar isNullOrUndefined = (value) => value == null;\n\nconst isObjectType = (value) => typeof value === 'object';\nvar isObject = (value) => !isNullOrUndefined(value) &&\n !Array.isArray(value) &&\n isObjectType(value) &&\n !isDateObject(value);\n\nvar getEventValue = (event) => isObject(event) && event.target\n ? isCheckBoxInput(event.target)\n ? event.target.checked\n : event.target.value\n : event;\n\nvar getNodeParentName = (name) => name.substring(0, name.search(/\\.\\d+(\\.|$)/)) || name;\n\nvar isNameInFieldArray = (names, name) => names.has(getNodeParentName(name));\n\nvar isPlainObject = (tempObject) => {\n const prototypeCopy = tempObject.constructor && tempObject.constructor.prototype;\n return (isObject(prototypeCopy) && prototypeCopy.hasOwnProperty('isPrototypeOf'));\n};\n\nvar isWeb = typeof window !== 'undefined' &&\n typeof window.HTMLElement !== 'undefined' &&\n typeof document !== 'undefined';\n\nfunction cloneObject(data) {\n let copy;\n const isArray = Array.isArray(data);\n if (data instanceof Date) {\n copy = new Date(data);\n }\n else if (data instanceof Set) {\n copy = new Set(data);\n }\n else if (!(isWeb && (data instanceof Blob || data instanceof FileList)) &&\n (isArray || isObject(data))) {\n copy = isArray ? [] : {};\n if (!isArray && !isPlainObject(data)) {\n copy = data;\n }\n else {\n for (const key in data) {\n if (data.hasOwnProperty(key)) {\n copy[key] = cloneObject(data[key]);\n }\n }\n }\n }\n else {\n return data;\n }\n return copy;\n}\n\nvar compact = (value) => Array.isArray(value) ? value.filter(Boolean) : [];\n\nvar isUndefined = (val) => val === undefined;\n\nvar get = (obj, path, defaultValue) => {\n if (!path || !isObject(obj)) {\n return defaultValue;\n }\n const result = compact(path.split(/[,[\\].]+?/)).reduce((result, key) => isNullOrUndefined(result) ? result : result[key], obj);\n return isUndefined(result) || result === obj\n ? isUndefined(obj[path])\n ? defaultValue\n : obj[path]\n : result;\n};\n\nvar isBoolean = (value) => typeof value === 'boolean';\n\nconst EVENTS = {\n BLUR: 'blur',\n FOCUS_OUT: 'focusout',\n CHANGE: 'change',\n};\nconst VALIDATION_MODE = {\n onBlur: 'onBlur',\n onChange: 'onChange',\n onSubmit: 'onSubmit',\n onTouched: 'onTouched',\n all: 'all',\n};\nconst INPUT_VALIDATION_RULES = {\n max: 'max',\n min: 'min',\n maxLength: 'maxLength',\n minLength: 'minLength',\n pattern: 'pattern',\n required: 'required',\n validate: 'validate',\n};\n\nconst HookFormContext = React.createContext(null);\n/**\n * This custom hook allows you to access the form context. useFormContext is intended to be used in deeply nested structures, where it would become inconvenient to pass the context as a prop. To be used with {@link FormProvider}.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/useformcontext) • [Demo](https://codesandbox.io/s/react-hook-form-v7-form-context-ytudi)\n *\n * @returns return all useForm methods\n *\n * @example\n * ```tsx\n * function App() {\n * const methods = useForm();\n * const onSubmit = data => console.log(data);\n *\n * return (\n * \n *
\n * \n * \n * \n *
\n * );\n * }\n *\n * function NestedInput() {\n * const { register } = useFormContext(); // retrieve all hook methods\n * return ;\n * }\n * ```\n */\nconst useFormContext = () => React.useContext(HookFormContext);\n/**\n * A provider component that propagates the `useForm` methods to all children components via [React Context](https://reactjs.org/docs/context.html) API. To be used with {@link useFormContext}.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/useformcontext) • [Demo](https://codesandbox.io/s/react-hook-form-v7-form-context-ytudi)\n *\n * @param props - all useFrom methods\n *\n * @example\n * ```tsx\n * function App() {\n * const methods = useForm();\n * const onSubmit = data => console.log(data);\n *\n * return (\n * \n *
\n * \n * \n * \n *
\n * );\n * }\n *\n * function NestedInput() {\n * const { register } = useFormContext(); // retrieve all hook methods\n * return ;\n * }\n * ```\n */\nconst FormProvider = (props) => {\n const { children, ...data } = props;\n return (React.createElement(HookFormContext.Provider, { value: data }, children));\n};\n\nvar getProxyFormState = (formState, control, localProxyFormState, isRoot = true) => {\n const result = {\n defaultValues: control._defaultValues,\n };\n for (const key in formState) {\n Object.defineProperty(result, key, {\n get: () => {\n const _key = key;\n if (control._proxyFormState[_key] !== VALIDATION_MODE.all) {\n control._proxyFormState[_key] = !isRoot || VALIDATION_MODE.all;\n }\n localProxyFormState && (localProxyFormState[_key] = true);\n return formState[_key];\n },\n });\n }\n return result;\n};\n\nvar isEmptyObject = (value) => isObject(value) && !Object.keys(value).length;\n\nvar shouldRenderFormState = (formStateData, _proxyFormState, updateFormState, isRoot) => {\n updateFormState(formStateData);\n const { name, ...formState } = formStateData;\n return (isEmptyObject(formState) ||\n Object.keys(formState).length >= Object.keys(_proxyFormState).length ||\n Object.keys(formState).find((key) => _proxyFormState[key] ===\n (!isRoot || VALIDATION_MODE.all)));\n};\n\nvar convertToArrayPayload = (value) => (Array.isArray(value) ? value : [value]);\n\nvar shouldSubscribeByName = (name, signalName, exact) => exact && signalName\n ? name === signalName ||\n (Array.isArray(name) &&\n name.some((currentName) => currentName && exact && currentName === signalName))\n : !name ||\n !signalName ||\n name === signalName ||\n convertToArrayPayload(name).some((currentName) => currentName &&\n (currentName.startsWith(signalName) ||\n signalName.startsWith(currentName)));\n\nfunction useSubscribe(props) {\n const _props = React.useRef(props);\n _props.current = props;\n React.useEffect(() => {\n const subscription = !props.disabled &&\n _props.current.subject &&\n _props.current.subject.subscribe({\n next: _props.current.next,\n });\n return () => {\n subscription && subscription.unsubscribe();\n };\n }, [props.disabled]);\n}\n\n/**\n * This custom hook allows you to subscribe to each form state, and isolate the re-render at the custom hook level. It has its scope in terms of form state subscription, so it would not affect other useFormState and useForm. Using this hook can reduce the re-render impact on large and complex form application.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/useformstate) • [Demo](https://codesandbox.io/s/useformstate-75xly)\n *\n * @param props - include options on specify fields to subscribe. {@link UseFormStateReturn}\n *\n * @example\n * ```tsx\n * function App() {\n * const { register, handleSubmit, control } = useForm({\n * defaultValues: {\n * firstName: \"firstName\"\n * }});\n * const { dirtyFields } = useFormState({\n * control\n * });\n * const onSubmit = (data) => console.log(data);\n *\n * return (\n *
\n * \n * {dirtyFields.firstName &&

Field is dirty.

}\n * \n *
\n * );\n * }\n * ```\n */\nfunction useFormState(props) {\n const methods = useFormContext();\n const { control = methods.control, disabled, name, exact } = props || {};\n const [formState, updateFormState] = React.useState(control._formState);\n const _mounted = React.useRef(true);\n const _localProxyFormState = React.useRef({\n isDirty: false,\n isLoading: false,\n dirtyFields: false,\n touchedFields: false,\n isValidating: false,\n isValid: false,\n errors: false,\n });\n const _name = React.useRef(name);\n _name.current = name;\n useSubscribe({\n disabled,\n next: (value) => _mounted.current &&\n shouldSubscribeByName(_name.current, value.name, exact) &&\n shouldRenderFormState(value, _localProxyFormState.current, control._updateFormState) &&\n updateFormState({\n ...control._formState,\n ...value,\n }),\n subject: control._subjects.state,\n });\n React.useEffect(() => {\n _mounted.current = true;\n _localProxyFormState.current.isValid && control._updateValid(true);\n return () => {\n _mounted.current = false;\n };\n }, [control]);\n return getProxyFormState(formState, control, _localProxyFormState.current, false);\n}\n\nvar isString = (value) => typeof value === 'string';\n\nvar generateWatchOutput = (names, _names, formValues, isGlobal, defaultValue) => {\n if (isString(names)) {\n isGlobal && _names.watch.add(names);\n return get(formValues, names, defaultValue);\n }\n if (Array.isArray(names)) {\n return names.map((fieldName) => (isGlobal && _names.watch.add(fieldName), get(formValues, fieldName)));\n }\n isGlobal && (_names.watchAll = true);\n return formValues;\n};\n\n/**\n * Custom hook to subscribe to field change and isolate re-rendering at the component level.\n *\n * @remarks\n *\n * [API](https://react-hook-form.com/docs/usewatch) • [Demo](https://codesandbox.io/s/react-hook-form-v7-ts-usewatch-h9i5e)\n *\n * @example\n * ```tsx\n * const { watch } = useForm();\n * const values = useWatch({\n * name: \"fieldName\"\n * control,\n * })\n * ```\n */\nfunction useWatch(props) {\n const methods = useFormContext();\n const { control = methods.control, name, defaultValue, disabled, exact, } = props || {};\n const _name = React.useRef(name);\n _name.current = name;\n useSubscribe({\n disabled,\n subject: control._subjects.values,\n next: (formState) => {\n if (shouldSubscribeByName(_name.current, formState.name, exact)) {\n updateValue(cloneObject(generateWatchOutput(_name.current, control._names, formState.values || control._formValues, false, defaultValue)));\n }\n },\n });\n const [value, updateValue] = React.useState(control._getWatch(name, defaultValue));\n React.useEffect(() => control._removeUnmounted());\n return value;\n}\n\nvar isKey = (value) => /^\\w*$/.test(value);\n\nvar stringToPath = (input) => compact(input.replace(/[\"|']|\\]/g, '').split(/\\.|\\[/));\n\nfunction set(object, path, value) {\n let index = -1;\n const tempPath = isKey(path) ? [path] : stringToPath(path);\n const length = tempPath.length;\n const lastIndex = length - 1;\n while (++index < length) {\n const key = tempPath[index];\n let newValue = value;\n if (index !== lastIndex) {\n const objValue = object[key];\n newValue =\n isObject(objValue) || Array.isArray(objValue)\n ? objValue\n : !isNaN(+tempPath[index + 1])\n ? []\n : {};\n }\n object[key] = newValue;\n object = object[key];\n }\n return object;\n}\n\n/**\n * Custom hook to work with controlled component, this function provide you with both form and field level state. Re-render is isolated at the hook level.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/usecontroller) • [Demo](https://codesandbox.io/s/usecontroller-0o8px)\n *\n * @param props - the path name to the form field value, and validation rules.\n *\n * @returns field properties, field and form state. {@link UseControllerReturn}\n *\n * @example\n * ```tsx\n * function Input(props) {\n * const { field, fieldState, formState } = useController(props);\n * return (\n *
\n * \n *

{fieldState.isTouched && \"Touched\"}

\n *

{formState.isSubmitted ? \"submitted\" : \"\"}

\n *
\n * );\n * }\n * ```\n */\nfunction useController(props) {\n const methods = useFormContext();\n const { name, disabled, control = methods.control, shouldUnregister } = props;\n const isArrayField = isNameInFieldArray(control._names.array, name);\n const value = useWatch({\n control,\n name,\n defaultValue: get(control._formValues, name, get(control._defaultValues, name, props.defaultValue)),\n exact: true,\n });\n const formState = useFormState({\n control,\n name,\n });\n const _registerProps = React.useRef(control.register(name, {\n ...props.rules,\n value,\n }));\n _registerProps.current = control.register(name, props.rules);\n React.useEffect(() => {\n const _shouldUnregisterField = control._options.shouldUnregister || shouldUnregister;\n const updateMounted = (name, value) => {\n const field = get(control._fields, name);\n if (field) {\n field._f.mount = value;\n }\n };\n updateMounted(name, true);\n if (_shouldUnregisterField) {\n const value = cloneObject(get(control._options.defaultValues, name));\n set(control._defaultValues, name, value);\n if (isUndefined(get(control._formValues, name))) {\n set(control._formValues, name, value);\n }\n }\n return () => {\n (isArrayField\n ? _shouldUnregisterField && !control._state.action\n : _shouldUnregisterField)\n ? control.unregister(name)\n : updateMounted(name, false);\n };\n }, [name, control, isArrayField, shouldUnregister]);\n React.useEffect(() => {\n control._updateDisabledField({\n disabled,\n fields: control._fields,\n name,\n });\n }, [disabled, name, control]);\n return {\n field: {\n name,\n value,\n ...(isBoolean(disabled) ? { disabled } : {}),\n onChange: React.useCallback((event) => _registerProps.current.onChange({\n target: {\n value: getEventValue(event),\n name: name,\n },\n type: EVENTS.CHANGE,\n }), [name]),\n onBlur: React.useCallback(() => _registerProps.current.onBlur({\n target: {\n value: get(control._formValues, name),\n name: name,\n },\n type: EVENTS.BLUR,\n }), [name, control]),\n ref: (elm) => {\n const field = get(control._fields, name);\n if (field && elm) {\n field._f.ref = {\n focus: () => elm.focus(),\n select: () => elm.select(),\n setCustomValidity: (message) => elm.setCustomValidity(message),\n reportValidity: () => elm.reportValidity(),\n };\n }\n },\n },\n formState,\n fieldState: Object.defineProperties({}, {\n invalid: {\n enumerable: true,\n get: () => !!get(formState.errors, name),\n },\n isDirty: {\n enumerable: true,\n get: () => !!get(formState.dirtyFields, name),\n },\n isTouched: {\n enumerable: true,\n get: () => !!get(formState.touchedFields, name),\n },\n error: {\n enumerable: true,\n get: () => get(formState.errors, name),\n },\n }),\n };\n}\n\n/**\n * Component based on `useController` hook to work with controlled component.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/usecontroller/controller) • [Demo](https://codesandbox.io/s/react-hook-form-v6-controller-ts-jwyzw) • [Video](https://www.youtube.com/watch?v=N2UNk_UCVyA)\n *\n * @param props - the path name to the form field value, and validation rules.\n *\n * @returns provide field handler functions, field and form state.\n *\n * @example\n * ```tsx\n * function App() {\n * const { control } = useForm({\n * defaultValues: {\n * test: \"\"\n * }\n * });\n *\n * return (\n *
\n * (\n * <>\n * \n *

{formState.isSubmitted ? \"submitted\" : \"\"}

\n *

{fieldState.isTouched ? \"touched\" : \"\"}

\n * \n * )}\n * />\n * \n * );\n * }\n * ```\n */\nconst Controller = (props) => props.render(useController(props));\n\nconst POST_REQUEST = 'post';\n/**\n * Form component to manage submission.\n *\n * @param props - to setup submission detail. {@link FormProps}\n *\n * @returns form component or headless render prop.\n *\n * @example\n * ```tsx\n * function App() {\n * const { control, formState: { errors } } = useForm();\n *\n * return (\n *
\n * \n *

{errors?.root?.server && 'Server error'}

\n * \n *
\n * );\n * }\n * ```\n */\nfunction Form(props) {\n const methods = useFormContext();\n const [mounted, setMounted] = React.useState(false);\n const { control = methods.control, onSubmit, children, action, method = POST_REQUEST, headers, encType, onError, render, onSuccess, validateStatus, ...rest } = props;\n const submit = async (event) => {\n let hasError = false;\n let type = '';\n await control.handleSubmit(async (data) => {\n const formData = new FormData();\n let formDataJson = '';\n try {\n formDataJson = JSON.stringify(data);\n }\n catch (_a) { }\n for (const name of control._names.mount) {\n formData.append(name, get(data, name));\n }\n if (onSubmit) {\n await onSubmit({\n data,\n event,\n method,\n formData,\n formDataJson,\n });\n }\n if (action) {\n try {\n const shouldStringifySubmissionData = [\n headers && headers['Content-Type'],\n encType,\n ].some((value) => value && value.includes('json'));\n const response = await fetch(action, {\n method,\n headers: {\n ...headers,\n ...(encType ? { 'Content-Type': encType } : {}),\n },\n body: shouldStringifySubmissionData ? formDataJson : formData,\n });\n if (response &&\n (validateStatus\n ? !validateStatus(response.status)\n : response.status < 200 || response.status >= 300)) {\n hasError = true;\n onError && onError({ response });\n type = String(response.status);\n }\n else {\n onSuccess && onSuccess({ response });\n }\n }\n catch (error) {\n hasError = true;\n onError && onError({ error });\n }\n }\n })(event);\n if (hasError && props.control) {\n props.control._subjects.state.next({\n isSubmitSuccessful: false,\n });\n props.control.setError('root.server', {\n type,\n });\n }\n };\n React.useEffect(() => {\n setMounted(true);\n }, []);\n return render ? (React.createElement(React.Fragment, null, render({\n submit,\n }))) : (React.createElement(\"form\", { noValidate: mounted, action: action, method: method, encType: encType, onSubmit: submit, ...rest }, children));\n}\n\nvar appendErrors = (name, validateAllFieldCriteria, errors, type, message) => validateAllFieldCriteria\n ? {\n ...errors[name],\n types: {\n ...(errors[name] && errors[name].types ? errors[name].types : {}),\n [type]: message || true,\n },\n }\n : {};\n\nconst focusFieldBy = (fields, callback, fieldsNames) => {\n for (const key of fieldsNames || Object.keys(fields)) {\n const field = get(fields, key);\n if (field) {\n const { _f, ...currentField } = field;\n if (_f && callback(_f.name)) {\n if (_f.ref.focus) {\n _f.ref.focus();\n break;\n }\n else if (_f.refs && _f.refs[0].focus) {\n _f.refs[0].focus();\n break;\n }\n }\n else if (isObject(currentField)) {\n focusFieldBy(currentField, callback);\n }\n }\n }\n};\n\nvar generateId = () => {\n const d = typeof performance === 'undefined' ? Date.now() : performance.now() * 1000;\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = (Math.random() * 16 + d) % 16 | 0;\n return (c == 'x' ? r : (r & 0x3) | 0x8).toString(16);\n });\n};\n\nvar getFocusFieldName = (name, index, options = {}) => options.shouldFocus || isUndefined(options.shouldFocus)\n ? options.focusName ||\n `${name}.${isUndefined(options.focusIndex) ? index : options.focusIndex}.`\n : '';\n\nvar getValidationModes = (mode) => ({\n isOnSubmit: !mode || mode === VALIDATION_MODE.onSubmit,\n isOnBlur: mode === VALIDATION_MODE.onBlur,\n isOnChange: mode === VALIDATION_MODE.onChange,\n isOnAll: mode === VALIDATION_MODE.all,\n isOnTouch: mode === VALIDATION_MODE.onTouched,\n});\n\nvar isWatched = (name, _names, isBlurEvent) => !isBlurEvent &&\n (_names.watchAll ||\n _names.watch.has(name) ||\n [..._names.watch].some((watchName) => name.startsWith(watchName) &&\n /^\\.\\w+/.test(name.slice(watchName.length))));\n\nvar updateFieldArrayRootError = (errors, error, name) => {\n const fieldArrayErrors = compact(get(errors, name));\n set(fieldArrayErrors, 'root', error[name]);\n set(errors, name, fieldArrayErrors);\n return errors;\n};\n\nvar isFileInput = (element) => element.type === 'file';\n\nvar isFunction = (value) => typeof value === 'function';\n\nvar isHTMLElement = (value) => {\n if (!isWeb) {\n return false;\n }\n const owner = value ? value.ownerDocument : 0;\n return (value instanceof\n (owner && owner.defaultView ? owner.defaultView.HTMLElement : HTMLElement));\n};\n\nvar isMessage = (value) => isString(value);\n\nvar isRadioInput = (element) => element.type === 'radio';\n\nvar isRegex = (value) => value instanceof RegExp;\n\nconst defaultResult = {\n value: false,\n isValid: false,\n};\nconst validResult = { value: true, isValid: true };\nvar getCheckboxValue = (options) => {\n if (Array.isArray(options)) {\n if (options.length > 1) {\n const values = options\n .filter((option) => option && option.checked && !option.disabled)\n .map((option) => option.value);\n return { value: values, isValid: !!values.length };\n }\n return options[0].checked && !options[0].disabled\n ? // @ts-expect-error expected to work in the browser\n options[0].attributes && !isUndefined(options[0].attributes.value)\n ? isUndefined(options[0].value) || options[0].value === ''\n ? validResult\n : { value: options[0].value, isValid: true }\n : validResult\n : defaultResult;\n }\n return defaultResult;\n};\n\nconst defaultReturn = {\n isValid: false,\n value: null,\n};\nvar getRadioValue = (options) => Array.isArray(options)\n ? options.reduce((previous, option) => option && option.checked && !option.disabled\n ? {\n isValid: true,\n value: option.value,\n }\n : previous, defaultReturn)\n : defaultReturn;\n\nfunction getValidateError(result, ref, type = 'validate') {\n if (isMessage(result) ||\n (Array.isArray(result) && result.every(isMessage)) ||\n (isBoolean(result) && !result)) {\n return {\n type,\n message: isMessage(result) ? result : '',\n ref,\n };\n }\n}\n\nvar getValueAndMessage = (validationData) => isObject(validationData) && !isRegex(validationData)\n ? validationData\n : {\n value: validationData,\n message: '',\n };\n\nvar validateField = async (field, formValues, validateAllFieldCriteria, shouldUseNativeValidation, isFieldArray) => {\n const { ref, refs, required, maxLength, minLength, min, max, pattern, validate, name, valueAsNumber, mount, disabled, } = field._f;\n const inputValue = get(formValues, name);\n if (!mount || disabled) {\n return {};\n }\n const inputRef = refs ? refs[0] : ref;\n const setCustomValidity = (message) => {\n if (shouldUseNativeValidation && inputRef.reportValidity) {\n inputRef.setCustomValidity(isBoolean(message) ? '' : message || '');\n inputRef.reportValidity();\n }\n };\n const error = {};\n const isRadio = isRadioInput(ref);\n const isCheckBox = isCheckBoxInput(ref);\n const isRadioOrCheckbox = isRadio || isCheckBox;\n const isEmpty = ((valueAsNumber || isFileInput(ref)) &&\n isUndefined(ref.value) &&\n isUndefined(inputValue)) ||\n (isHTMLElement(ref) && ref.value === '') ||\n inputValue === '' ||\n (Array.isArray(inputValue) && !inputValue.length);\n const appendErrorsCurry = appendErrors.bind(null, name, validateAllFieldCriteria, error);\n const getMinMaxMessage = (exceedMax, maxLengthMessage, minLengthMessage, maxType = INPUT_VALIDATION_RULES.maxLength, minType = INPUT_VALIDATION_RULES.minLength) => {\n const message = exceedMax ? maxLengthMessage : minLengthMessage;\n error[name] = {\n type: exceedMax ? maxType : minType,\n message,\n ref,\n ...appendErrorsCurry(exceedMax ? maxType : minType, message),\n };\n };\n if (isFieldArray\n ? !Array.isArray(inputValue) || !inputValue.length\n : required &&\n ((!isRadioOrCheckbox && (isEmpty || isNullOrUndefined(inputValue))) ||\n (isBoolean(inputValue) && !inputValue) ||\n (isCheckBox && !getCheckboxValue(refs).isValid) ||\n (isRadio && !getRadioValue(refs).isValid))) {\n const { value, message } = isMessage(required)\n ? { value: !!required, message: required }\n : getValueAndMessage(required);\n if (value) {\n error[name] = {\n type: INPUT_VALIDATION_RULES.required,\n message,\n ref: inputRef,\n ...appendErrorsCurry(INPUT_VALIDATION_RULES.required, message),\n };\n if (!validateAllFieldCriteria) {\n setCustomValidity(message);\n return error;\n }\n }\n }\n if (!isEmpty && (!isNullOrUndefined(min) || !isNullOrUndefined(max))) {\n let exceedMax;\n let exceedMin;\n const maxOutput = getValueAndMessage(max);\n const minOutput = getValueAndMessage(min);\n if (!isNullOrUndefined(inputValue) && !isNaN(inputValue)) {\n const valueNumber = ref.valueAsNumber ||\n (inputValue ? +inputValue : inputValue);\n if (!isNullOrUndefined(maxOutput.value)) {\n exceedMax = valueNumber > maxOutput.value;\n }\n if (!isNullOrUndefined(minOutput.value)) {\n exceedMin = valueNumber < minOutput.value;\n }\n }\n else {\n const valueDate = ref.valueAsDate || new Date(inputValue);\n const convertTimeToDate = (time) => new Date(new Date().toDateString() + ' ' + time);\n const isTime = ref.type == 'time';\n const isWeek = ref.type == 'week';\n if (isString(maxOutput.value) && inputValue) {\n exceedMax = isTime\n ? convertTimeToDate(inputValue) > convertTimeToDate(maxOutput.value)\n : isWeek\n ? inputValue > maxOutput.value\n : valueDate > new Date(maxOutput.value);\n }\n if (isString(minOutput.value) && inputValue) {\n exceedMin = isTime\n ? convertTimeToDate(inputValue) < convertTimeToDate(minOutput.value)\n : isWeek\n ? inputValue < minOutput.value\n : valueDate < new Date(minOutput.value);\n }\n }\n if (exceedMax || exceedMin) {\n getMinMaxMessage(!!exceedMax, maxOutput.message, minOutput.message, INPUT_VALIDATION_RULES.max, INPUT_VALIDATION_RULES.min);\n if (!validateAllFieldCriteria) {\n setCustomValidity(error[name].message);\n return error;\n }\n }\n }\n if ((maxLength || minLength) &&\n !isEmpty &&\n (isString(inputValue) || (isFieldArray && Array.isArray(inputValue)))) {\n const maxLengthOutput = getValueAndMessage(maxLength);\n const minLengthOutput = getValueAndMessage(minLength);\n const exceedMax = !isNullOrUndefined(maxLengthOutput.value) &&\n inputValue.length > +maxLengthOutput.value;\n const exceedMin = !isNullOrUndefined(minLengthOutput.value) &&\n inputValue.length < +minLengthOutput.value;\n if (exceedMax || exceedMin) {\n getMinMaxMessage(exceedMax, maxLengthOutput.message, minLengthOutput.message);\n if (!validateAllFieldCriteria) {\n setCustomValidity(error[name].message);\n return error;\n }\n }\n }\n if (pattern && !isEmpty && isString(inputValue)) {\n const { value: patternValue, message } = getValueAndMessage(pattern);\n if (isRegex(patternValue) && !inputValue.match(patternValue)) {\n error[name] = {\n type: INPUT_VALIDATION_RULES.pattern,\n message,\n ref,\n ...appendErrorsCurry(INPUT_VALIDATION_RULES.pattern, message),\n };\n if (!validateAllFieldCriteria) {\n setCustomValidity(message);\n return error;\n }\n }\n }\n if (validate) {\n if (isFunction(validate)) {\n const result = await validate(inputValue, formValues);\n const validateError = getValidateError(result, inputRef);\n if (validateError) {\n error[name] = {\n ...validateError,\n ...appendErrorsCurry(INPUT_VALIDATION_RULES.validate, validateError.message),\n };\n if (!validateAllFieldCriteria) {\n setCustomValidity(validateError.message);\n return error;\n }\n }\n }\n else if (isObject(validate)) {\n let validationResult = {};\n for (const key in validate) {\n if (!isEmptyObject(validationResult) && !validateAllFieldCriteria) {\n break;\n }\n const validateError = getValidateError(await validate[key](inputValue, formValues), inputRef, key);\n if (validateError) {\n validationResult = {\n ...validateError,\n ...appendErrorsCurry(key, validateError.message),\n };\n setCustomValidity(validateError.message);\n if (validateAllFieldCriteria) {\n error[name] = validationResult;\n }\n }\n }\n if (!isEmptyObject(validationResult)) {\n error[name] = {\n ref: inputRef,\n ...validationResult,\n };\n if (!validateAllFieldCriteria) {\n return error;\n }\n }\n }\n }\n setCustomValidity(true);\n return error;\n};\n\nfunction append(data, value) {\n return [...data, ...convertToArrayPayload(value)];\n}\n\nvar fillEmptyArray = (value) => Array.isArray(value) ? value.map(() => undefined) : undefined;\n\nfunction insert(data, index, value) {\n return [\n ...data.slice(0, index),\n ...convertToArrayPayload(value),\n ...data.slice(index),\n ];\n}\n\nvar moveArrayAt = (data, from, to) => {\n if (!Array.isArray(data)) {\n return [];\n }\n if (isUndefined(data[to])) {\n data[to] = undefined;\n }\n data.splice(to, 0, data.splice(from, 1)[0]);\n return data;\n};\n\nfunction prepend(data, value) {\n return [...convertToArrayPayload(value), ...convertToArrayPayload(data)];\n}\n\nfunction removeAtIndexes(data, indexes) {\n let i = 0;\n const temp = [...data];\n for (const index of indexes) {\n temp.splice(index - i, 1);\n i++;\n }\n return compact(temp).length ? temp : [];\n}\nvar removeArrayAt = (data, index) => isUndefined(index)\n ? []\n : removeAtIndexes(data, convertToArrayPayload(index).sort((a, b) => a - b));\n\nvar swapArrayAt = (data, indexA, indexB) => {\n data[indexA] = [data[indexB], (data[indexB] = data[indexA])][0];\n};\n\nfunction baseGet(object, updatePath) {\n const length = updatePath.slice(0, -1).length;\n let index = 0;\n while (index < length) {\n object = isUndefined(object) ? index++ : object[updatePath[index++]];\n }\n return object;\n}\nfunction isEmptyArray(obj) {\n for (const key in obj) {\n if (obj.hasOwnProperty(key) && !isUndefined(obj[key])) {\n return false;\n }\n }\n return true;\n}\nfunction unset(object, path) {\n const paths = Array.isArray(path)\n ? path\n : isKey(path)\n ? [path]\n : stringToPath(path);\n const childObject = paths.length === 1 ? object : baseGet(object, paths);\n const index = paths.length - 1;\n const key = paths[index];\n if (childObject) {\n delete childObject[key];\n }\n if (index !== 0 &&\n ((isObject(childObject) && isEmptyObject(childObject)) ||\n (Array.isArray(childObject) && isEmptyArray(childObject)))) {\n unset(object, paths.slice(0, -1));\n }\n return object;\n}\n\nvar updateAt = (fieldValues, index, value) => {\n fieldValues[index] = value;\n return fieldValues;\n};\n\n/**\n * A custom hook that exposes convenient methods to perform operations with a list of dynamic inputs that need to be appended, updated, removed etc. • [Demo](https://codesandbox.io/s/react-hook-form-usefieldarray-ssugn) • [Video](https://youtu.be/4MrbfGSFY2A)\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/usefieldarray) • [Demo](https://codesandbox.io/s/react-hook-form-usefieldarray-ssugn)\n *\n * @param props - useFieldArray props\n *\n * @returns methods - functions to manipulate with the Field Arrays (dynamic inputs) {@link UseFieldArrayReturn}\n *\n * @example\n * ```tsx\n * function App() {\n * const { register, control, handleSubmit, reset, trigger, setError } = useForm({\n * defaultValues: {\n * test: []\n * }\n * });\n * const { fields, append } = useFieldArray({\n * control,\n * name: \"test\"\n * });\n *\n * return (\n *
console.log(data))}>\n * {fields.map((item, index) => (\n * \n * ))}\n * \n * \n *
\n * );\n * }\n * ```\n */\nfunction useFieldArray(props) {\n const methods = useFormContext();\n const { control = methods.control, name, keyName = 'id', shouldUnregister, } = props;\n const [fields, setFields] = React.useState(control._getFieldArray(name));\n const ids = React.useRef(control._getFieldArray(name).map(generateId));\n const _fieldIds = React.useRef(fields);\n const _name = React.useRef(name);\n const _actioned = React.useRef(false);\n _name.current = name;\n _fieldIds.current = fields;\n control._names.array.add(name);\n props.rules &&\n control.register(name, props.rules);\n useSubscribe({\n next: ({ values, name: fieldArrayName, }) => {\n if (fieldArrayName === _name.current || !fieldArrayName) {\n const fieldValues = get(values, _name.current);\n if (Array.isArray(fieldValues)) {\n setFields(fieldValues);\n ids.current = fieldValues.map(generateId);\n }\n }\n },\n subject: control._subjects.array,\n });\n const updateValues = React.useCallback((updatedFieldArrayValues) => {\n _actioned.current = true;\n control._updateFieldArray(name, updatedFieldArrayValues);\n }, [control, name]);\n const append$1 = (value, options) => {\n const appendValue = convertToArrayPayload(cloneObject(value));\n const updatedFieldArrayValues = append(control._getFieldArray(name), appendValue);\n control._names.focus = getFocusFieldName(name, updatedFieldArrayValues.length - 1, options);\n ids.current = append(ids.current, appendValue.map(generateId));\n updateValues(updatedFieldArrayValues);\n setFields(updatedFieldArrayValues);\n control._updateFieldArray(name, updatedFieldArrayValues, append, {\n argA: fillEmptyArray(value),\n });\n };\n const prepend$1 = (value, options) => {\n const prependValue = convertToArrayPayload(cloneObject(value));\n const updatedFieldArrayValues = prepend(control._getFieldArray(name), prependValue);\n control._names.focus = getFocusFieldName(name, 0, options);\n ids.current = prepend(ids.current, prependValue.map(generateId));\n updateValues(updatedFieldArrayValues);\n setFields(updatedFieldArrayValues);\n control._updateFieldArray(name, updatedFieldArrayValues, prepend, {\n argA: fillEmptyArray(value),\n });\n };\n const remove = (index) => {\n const updatedFieldArrayValues = removeArrayAt(control._getFieldArray(name), index);\n ids.current = removeArrayAt(ids.current, index);\n updateValues(updatedFieldArrayValues);\n setFields(updatedFieldArrayValues);\n control._updateFieldArray(name, updatedFieldArrayValues, removeArrayAt, {\n argA: index,\n });\n };\n const insert$1 = (index, value, options) => {\n const insertValue = convertToArrayPayload(cloneObject(value));\n const updatedFieldArrayValues = insert(control._getFieldArray(name), index, insertValue);\n control._names.focus = getFocusFieldName(name, index, options);\n ids.current = insert(ids.current, index, insertValue.map(generateId));\n updateValues(updatedFieldArrayValues);\n setFields(updatedFieldArrayValues);\n control._updateFieldArray(name, updatedFieldArrayValues, insert, {\n argA: index,\n argB: fillEmptyArray(value),\n });\n };\n const swap = (indexA, indexB) => {\n const updatedFieldArrayValues = control._getFieldArray(name);\n swapArrayAt(updatedFieldArrayValues, indexA, indexB);\n swapArrayAt(ids.current, indexA, indexB);\n updateValues(updatedFieldArrayValues);\n setFields(updatedFieldArrayValues);\n control._updateFieldArray(name, updatedFieldArrayValues, swapArrayAt, {\n argA: indexA,\n argB: indexB,\n }, false);\n };\n const move = (from, to) => {\n const updatedFieldArrayValues = control._getFieldArray(name);\n moveArrayAt(updatedFieldArrayValues, from, to);\n moveArrayAt(ids.current, from, to);\n updateValues(updatedFieldArrayValues);\n setFields(updatedFieldArrayValues);\n control._updateFieldArray(name, updatedFieldArrayValues, moveArrayAt, {\n argA: from,\n argB: to,\n }, false);\n };\n const update = (index, value) => {\n const updateValue = cloneObject(value);\n const updatedFieldArrayValues = updateAt(control._getFieldArray(name), index, updateValue);\n ids.current = [...updatedFieldArrayValues].map((item, i) => !item || i === index ? generateId() : ids.current[i]);\n updateValues(updatedFieldArrayValues);\n setFields([...updatedFieldArrayValues]);\n control._updateFieldArray(name, updatedFieldArrayValues, updateAt, {\n argA: index,\n argB: updateValue,\n }, true, false);\n };\n const replace = (value) => {\n const updatedFieldArrayValues = convertToArrayPayload(cloneObject(value));\n ids.current = updatedFieldArrayValues.map(generateId);\n updateValues([...updatedFieldArrayValues]);\n setFields([...updatedFieldArrayValues]);\n control._updateFieldArray(name, [...updatedFieldArrayValues], (data) => data, {}, true, false);\n };\n React.useEffect(() => {\n control._state.action = false;\n isWatched(name, control._names) &&\n control._subjects.state.next({\n ...control._formState,\n });\n if (_actioned.current &&\n (!getValidationModes(control._options.mode).isOnSubmit ||\n control._formState.isSubmitted)) {\n if (control._options.resolver) {\n control._executeSchema([name]).then((result) => {\n const error = get(result.errors, name);\n const existingError = get(control._formState.errors, name);\n if (existingError\n ? (!error && existingError.type) ||\n (error &&\n (existingError.type !== error.type ||\n existingError.message !== error.message))\n : error && error.type) {\n error\n ? set(control._formState.errors, name, error)\n : unset(control._formState.errors, name);\n control._subjects.state.next({\n errors: control._formState.errors,\n });\n }\n });\n }\n else {\n const field = get(control._fields, name);\n if (field && field._f) {\n validateField(field, control._formValues, control._options.criteriaMode === VALIDATION_MODE.all, control._options.shouldUseNativeValidation, true).then((error) => !isEmptyObject(error) &&\n control._subjects.state.next({\n errors: updateFieldArrayRootError(control._formState.errors, error, name),\n }));\n }\n }\n }\n control._subjects.values.next({\n name,\n values: { ...control._formValues },\n });\n control._names.focus &&\n focusFieldBy(control._fields, (key) => !!key && key.startsWith(control._names.focus || ''));\n control._names.focus = '';\n control._updateValid();\n _actioned.current = false;\n }, [fields, name, control]);\n React.useEffect(() => {\n !get(control._formValues, name) && control._updateFieldArray(name);\n return () => {\n (control._options.shouldUnregister || shouldUnregister) &&\n control.unregister(name);\n };\n }, [name, control, keyName, shouldUnregister]);\n return {\n swap: React.useCallback(swap, [updateValues, name, control]),\n move: React.useCallback(move, [updateValues, name, control]),\n prepend: React.useCallback(prepend$1, [updateValues, name, control]),\n append: React.useCallback(append$1, [updateValues, name, control]),\n remove: React.useCallback(remove, [updateValues, name, control]),\n insert: React.useCallback(insert$1, [updateValues, name, control]),\n update: React.useCallback(update, [updateValues, name, control]),\n replace: React.useCallback(replace, [updateValues, name, control]),\n fields: React.useMemo(() => fields.map((field, index) => ({\n ...field,\n [keyName]: ids.current[index] || generateId(),\n })), [fields, keyName]),\n };\n}\n\nfunction createSubject() {\n let _observers = [];\n const next = (value) => {\n for (const observer of _observers) {\n observer.next && observer.next(value);\n }\n };\n const subscribe = (observer) => {\n _observers.push(observer);\n return {\n unsubscribe: () => {\n _observers = _observers.filter((o) => o !== observer);\n },\n };\n };\n const unsubscribe = () => {\n _observers = [];\n };\n return {\n get observers() {\n return _observers;\n },\n next,\n subscribe,\n unsubscribe,\n };\n}\n\nvar isPrimitive = (value) => isNullOrUndefined(value) || !isObjectType(value);\n\nfunction deepEqual(object1, object2) {\n if (isPrimitive(object1) || isPrimitive(object2)) {\n return object1 === object2;\n }\n if (isDateObject(object1) && isDateObject(object2)) {\n return object1.getTime() === object2.getTime();\n }\n const keys1 = Object.keys(object1);\n const keys2 = Object.keys(object2);\n if (keys1.length !== keys2.length) {\n return false;\n }\n for (const key of keys1) {\n const val1 = object1[key];\n if (!keys2.includes(key)) {\n return false;\n }\n if (key !== 'ref') {\n const val2 = object2[key];\n if ((isDateObject(val1) && isDateObject(val2)) ||\n (isObject(val1) && isObject(val2)) ||\n (Array.isArray(val1) && Array.isArray(val2))\n ? !deepEqual(val1, val2)\n : val1 !== val2) {\n return false;\n }\n }\n }\n return true;\n}\n\nvar isMultipleSelect = (element) => element.type === `select-multiple`;\n\nvar isRadioOrCheckbox = (ref) => isRadioInput(ref) || isCheckBoxInput(ref);\n\nvar live = (ref) => isHTMLElement(ref) && ref.isConnected;\n\nvar objectHasFunction = (data) => {\n for (const key in data) {\n if (isFunction(data[key])) {\n return true;\n }\n }\n return false;\n};\n\nfunction markFieldsDirty(data, fields = {}) {\n const isParentNodeArray = Array.isArray(data);\n if (isObject(data) || isParentNodeArray) {\n for (const key in data) {\n if (Array.isArray(data[key]) ||\n (isObject(data[key]) && !objectHasFunction(data[key]))) {\n fields[key] = Array.isArray(data[key]) ? [] : {};\n markFieldsDirty(data[key], fields[key]);\n }\n else if (!isNullOrUndefined(data[key])) {\n fields[key] = true;\n }\n }\n }\n return fields;\n}\nfunction getDirtyFieldsFromDefaultValues(data, formValues, dirtyFieldsFromValues) {\n const isParentNodeArray = Array.isArray(data);\n if (isObject(data) || isParentNodeArray) {\n for (const key in data) {\n if (Array.isArray(data[key]) ||\n (isObject(data[key]) && !objectHasFunction(data[key]))) {\n if (isUndefined(formValues) ||\n isPrimitive(dirtyFieldsFromValues[key])) {\n dirtyFieldsFromValues[key] = Array.isArray(data[key])\n ? markFieldsDirty(data[key], [])\n : { ...markFieldsDirty(data[key]) };\n }\n else {\n getDirtyFieldsFromDefaultValues(data[key], isNullOrUndefined(formValues) ? {} : formValues[key], dirtyFieldsFromValues[key]);\n }\n }\n else {\n dirtyFieldsFromValues[key] = !deepEqual(data[key], formValues[key]);\n }\n }\n }\n return dirtyFieldsFromValues;\n}\nvar getDirtyFields = (defaultValues, formValues) => getDirtyFieldsFromDefaultValues(defaultValues, formValues, markFieldsDirty(formValues));\n\nvar getFieldValueAs = (value, { valueAsNumber, valueAsDate, setValueAs }) => isUndefined(value)\n ? value\n : valueAsNumber\n ? value === ''\n ? NaN\n : value\n ? +value\n : value\n : valueAsDate && isString(value)\n ? new Date(value)\n : setValueAs\n ? setValueAs(value)\n : value;\n\nfunction getFieldValue(_f) {\n const ref = _f.ref;\n if (_f.refs ? _f.refs.every((ref) => ref.disabled) : ref.disabled) {\n return;\n }\n if (isFileInput(ref)) {\n return ref.files;\n }\n if (isRadioInput(ref)) {\n return getRadioValue(_f.refs).value;\n }\n if (isMultipleSelect(ref)) {\n return [...ref.selectedOptions].map(({ value }) => value);\n }\n if (isCheckBoxInput(ref)) {\n return getCheckboxValue(_f.refs).value;\n }\n return getFieldValueAs(isUndefined(ref.value) ? _f.ref.value : ref.value, _f);\n}\n\nvar getResolverOptions = (fieldsNames, _fields, criteriaMode, shouldUseNativeValidation) => {\n const fields = {};\n for (const name of fieldsNames) {\n const field = get(_fields, name);\n field && set(fields, name, field._f);\n }\n return {\n criteriaMode,\n names: [...fieldsNames],\n fields,\n shouldUseNativeValidation,\n };\n};\n\nvar getRuleValue = (rule) => isUndefined(rule)\n ? rule\n : isRegex(rule)\n ? rule.source\n : isObject(rule)\n ? isRegex(rule.value)\n ? rule.value.source\n : rule.value\n : rule;\n\nvar hasValidation = (options) => options.mount &&\n (options.required ||\n options.min ||\n options.max ||\n options.maxLength ||\n options.minLength ||\n options.pattern ||\n options.validate);\n\nfunction schemaErrorLookup(errors, _fields, name) {\n const error = get(errors, name);\n if (error || isKey(name)) {\n return {\n error,\n name,\n };\n }\n const names = name.split('.');\n while (names.length) {\n const fieldName = names.join('.');\n const field = get(_fields, fieldName);\n const foundError = get(errors, fieldName);\n if (field && !Array.isArray(field) && name !== fieldName) {\n return { name };\n }\n if (foundError && foundError.type) {\n return {\n name: fieldName,\n error: foundError,\n };\n }\n names.pop();\n }\n return {\n name,\n };\n}\n\nvar skipValidation = (isBlurEvent, isTouched, isSubmitted, reValidateMode, mode) => {\n if (mode.isOnAll) {\n return false;\n }\n else if (!isSubmitted && mode.isOnTouch) {\n return !(isTouched || isBlurEvent);\n }\n else if (isSubmitted ? reValidateMode.isOnBlur : mode.isOnBlur) {\n return !isBlurEvent;\n }\n else if (isSubmitted ? reValidateMode.isOnChange : mode.isOnChange) {\n return isBlurEvent;\n }\n return true;\n};\n\nvar unsetEmptyArray = (ref, name) => !compact(get(ref, name)).length && unset(ref, name);\n\nconst defaultOptions = {\n mode: VALIDATION_MODE.onSubmit,\n reValidateMode: VALIDATION_MODE.onChange,\n shouldFocusError: true,\n};\nfunction createFormControl(props = {}, flushRootRender) {\n let _options = {\n ...defaultOptions,\n ...props,\n };\n let _formState = {\n submitCount: 0,\n isDirty: false,\n isLoading: isFunction(_options.defaultValues),\n isValidating: false,\n isSubmitted: false,\n isSubmitting: false,\n isSubmitSuccessful: false,\n isValid: false,\n touchedFields: {},\n dirtyFields: {},\n errors: {},\n };\n let _fields = {};\n let _defaultValues = isObject(_options.defaultValues) || isObject(_options.values)\n ? cloneObject(_options.defaultValues || _options.values) || {}\n : {};\n let _formValues = _options.shouldUnregister\n ? {}\n : cloneObject(_defaultValues);\n let _state = {\n action: false,\n mount: false,\n watch: false,\n };\n let _names = {\n mount: new Set(),\n unMount: new Set(),\n array: new Set(),\n watch: new Set(),\n };\n let delayErrorCallback;\n let timer = 0;\n const _proxyFormState = {\n isDirty: false,\n dirtyFields: false,\n touchedFields: false,\n isValidating: false,\n isValid: false,\n errors: false,\n };\n const _subjects = {\n values: createSubject(),\n array: createSubject(),\n state: createSubject(),\n };\n const shouldCaptureDirtyFields = props.resetOptions && props.resetOptions.keepDirtyValues;\n const validationModeBeforeSubmit = getValidationModes(_options.mode);\n const validationModeAfterSubmit = getValidationModes(_options.reValidateMode);\n const shouldDisplayAllAssociatedErrors = _options.criteriaMode === VALIDATION_MODE.all;\n const debounce = (callback) => (wait) => {\n clearTimeout(timer);\n timer = setTimeout(callback, wait);\n };\n const _updateValid = async (shouldUpdateValid) => {\n if (_proxyFormState.isValid || shouldUpdateValid) {\n const isValid = _options.resolver\n ? isEmptyObject((await _executeSchema()).errors)\n : await executeBuiltInValidation(_fields, true);\n if (isValid !== _formState.isValid) {\n _subjects.state.next({\n isValid,\n });\n }\n }\n };\n const _updateIsValidating = (value) => _proxyFormState.isValidating &&\n _subjects.state.next({\n isValidating: value,\n });\n const _updateFieldArray = (name, values = [], method, args, shouldSetValues = true, shouldUpdateFieldsAndState = true) => {\n if (args && method) {\n _state.action = true;\n if (shouldUpdateFieldsAndState && Array.isArray(get(_fields, name))) {\n const fieldValues = method(get(_fields, name), args.argA, args.argB);\n shouldSetValues && set(_fields, name, fieldValues);\n }\n if (shouldUpdateFieldsAndState &&\n Array.isArray(get(_formState.errors, name))) {\n const errors = method(get(_formState.errors, name), args.argA, args.argB);\n shouldSetValues && set(_formState.errors, name, errors);\n unsetEmptyArray(_formState.errors, name);\n }\n if (_proxyFormState.touchedFields &&\n shouldUpdateFieldsAndState &&\n Array.isArray(get(_formState.touchedFields, name))) {\n const touchedFields = method(get(_formState.touchedFields, name), args.argA, args.argB);\n shouldSetValues && set(_formState.touchedFields, name, touchedFields);\n }\n if (_proxyFormState.dirtyFields) {\n _formState.dirtyFields = getDirtyFields(_defaultValues, _formValues);\n }\n _subjects.state.next({\n name,\n isDirty: _getDirty(name, values),\n dirtyFields: _formState.dirtyFields,\n errors: _formState.errors,\n isValid: _formState.isValid,\n });\n }\n else {\n set(_formValues, name, values);\n }\n };\n const updateErrors = (name, error) => {\n set(_formState.errors, name, error);\n _subjects.state.next({\n errors: _formState.errors,\n });\n };\n const updateValidAndValue = (name, shouldSkipSetValueAs, value, ref) => {\n const field = get(_fields, name);\n if (field) {\n const defaultValue = get(_formValues, name, isUndefined(value) ? get(_defaultValues, name) : value);\n isUndefined(defaultValue) ||\n (ref && ref.defaultChecked) ||\n shouldSkipSetValueAs\n ? set(_formValues, name, shouldSkipSetValueAs ? defaultValue : getFieldValue(field._f))\n : setFieldValue(name, defaultValue);\n _state.mount && _updateValid();\n }\n };\n const updateTouchAndDirty = (name, fieldValue, isBlurEvent, shouldDirty, shouldRender) => {\n let shouldUpdateField = false;\n let isPreviousDirty = false;\n const output = {\n name,\n };\n if (!isBlurEvent || shouldDirty) {\n if (_proxyFormState.isDirty) {\n isPreviousDirty = _formState.isDirty;\n _formState.isDirty = output.isDirty = _getDirty();\n shouldUpdateField = isPreviousDirty !== output.isDirty;\n }\n const isCurrentFieldPristine = deepEqual(get(_defaultValues, name), fieldValue);\n isPreviousDirty = get(_formState.dirtyFields, name);\n isCurrentFieldPristine\n ? unset(_formState.dirtyFields, name)\n : set(_formState.dirtyFields, name, true);\n output.dirtyFields = _formState.dirtyFields;\n shouldUpdateField =\n shouldUpdateField ||\n (_proxyFormState.dirtyFields &&\n isPreviousDirty !== !isCurrentFieldPristine);\n }\n if (isBlurEvent) {\n const isPreviousFieldTouched = get(_formState.touchedFields, name);\n if (!isPreviousFieldTouched) {\n set(_formState.touchedFields, name, isBlurEvent);\n output.touchedFields = _formState.touchedFields;\n shouldUpdateField =\n shouldUpdateField ||\n (_proxyFormState.touchedFields &&\n isPreviousFieldTouched !== isBlurEvent);\n }\n }\n shouldUpdateField && shouldRender && _subjects.state.next(output);\n return shouldUpdateField ? output : {};\n };\n const shouldRenderByError = (name, isValid, error, fieldState) => {\n const previousFieldError = get(_formState.errors, name);\n const shouldUpdateValid = _proxyFormState.isValid &&\n isBoolean(isValid) &&\n _formState.isValid !== isValid;\n if (props.delayError && error) {\n delayErrorCallback = debounce(() => updateErrors(name, error));\n delayErrorCallback(props.delayError);\n }\n else {\n clearTimeout(timer);\n delayErrorCallback = null;\n error\n ? set(_formState.errors, name, error)\n : unset(_formState.errors, name);\n }\n if ((error ? !deepEqual(previousFieldError, error) : previousFieldError) ||\n !isEmptyObject(fieldState) ||\n shouldUpdateValid) {\n const updatedFormState = {\n ...fieldState,\n ...(shouldUpdateValid && isBoolean(isValid) ? { isValid } : {}),\n errors: _formState.errors,\n name,\n };\n _formState = {\n ..._formState,\n ...updatedFormState,\n };\n _subjects.state.next(updatedFormState);\n }\n _updateIsValidating(false);\n };\n const _executeSchema = async (name) => _options.resolver(_formValues, _options.context, getResolverOptions(name || _names.mount, _fields, _options.criteriaMode, _options.shouldUseNativeValidation));\n const executeSchemaAndUpdateState = async (names) => {\n const { errors } = await _executeSchema(names);\n if (names) {\n for (const name of names) {\n const error = get(errors, name);\n error\n ? set(_formState.errors, name, error)\n : unset(_formState.errors, name);\n }\n }\n else {\n _formState.errors = errors;\n }\n return errors;\n };\n const executeBuiltInValidation = async (fields, shouldOnlyCheckValid, context = {\n valid: true,\n }) => {\n for (const name in fields) {\n const field = fields[name];\n if (field) {\n const { _f, ...fieldValue } = field;\n if (_f) {\n const isFieldArrayRoot = _names.array.has(_f.name);\n const fieldError = await validateField(field, _formValues, shouldDisplayAllAssociatedErrors, _options.shouldUseNativeValidation && !shouldOnlyCheckValid, isFieldArrayRoot);\n if (fieldError[_f.name]) {\n context.valid = false;\n if (shouldOnlyCheckValid) {\n break;\n }\n }\n !shouldOnlyCheckValid &&\n (get(fieldError, _f.name)\n ? isFieldArrayRoot\n ? updateFieldArrayRootError(_formState.errors, fieldError, _f.name)\n : set(_formState.errors, _f.name, fieldError[_f.name])\n : unset(_formState.errors, _f.name));\n }\n fieldValue &&\n (await executeBuiltInValidation(fieldValue, shouldOnlyCheckValid, context));\n }\n }\n return context.valid;\n };\n const _removeUnmounted = () => {\n for (const name of _names.unMount) {\n const field = get(_fields, name);\n field &&\n (field._f.refs\n ? field._f.refs.every((ref) => !live(ref))\n : !live(field._f.ref)) &&\n unregister(name);\n }\n _names.unMount = new Set();\n };\n const _getDirty = (name, data) => (name && data && set(_formValues, name, data),\n !deepEqual(getValues(), _defaultValues));\n const _getWatch = (names, defaultValue, isGlobal) => generateWatchOutput(names, _names, {\n ...(_state.mount\n ? _formValues\n : isUndefined(defaultValue)\n ? _defaultValues\n : isString(names)\n ? { [names]: defaultValue }\n : defaultValue),\n }, isGlobal, defaultValue);\n const _getFieldArray = (name) => compact(get(_state.mount ? _formValues : _defaultValues, name, props.shouldUnregister ? get(_defaultValues, name, []) : []));\n const setFieldValue = (name, value, options = {}) => {\n const field = get(_fields, name);\n let fieldValue = value;\n if (field) {\n const fieldReference = field._f;\n if (fieldReference) {\n !fieldReference.disabled &&\n set(_formValues, name, getFieldValueAs(value, fieldReference));\n fieldValue =\n isHTMLElement(fieldReference.ref) && isNullOrUndefined(value)\n ? ''\n : value;\n if (isMultipleSelect(fieldReference.ref)) {\n [...fieldReference.ref.options].forEach((optionRef) => (optionRef.selected = fieldValue.includes(optionRef.value)));\n }\n else if (fieldReference.refs) {\n if (isCheckBoxInput(fieldReference.ref)) {\n fieldReference.refs.length > 1\n ? fieldReference.refs.forEach((checkboxRef) => (!checkboxRef.defaultChecked || !checkboxRef.disabled) &&\n (checkboxRef.checked = Array.isArray(fieldValue)\n ? !!fieldValue.find((data) => data === checkboxRef.value)\n : fieldValue === checkboxRef.value))\n : fieldReference.refs[0] &&\n (fieldReference.refs[0].checked = !!fieldValue);\n }\n else {\n fieldReference.refs.forEach((radioRef) => (radioRef.checked = radioRef.value === fieldValue));\n }\n }\n else if (isFileInput(fieldReference.ref)) {\n fieldReference.ref.value = '';\n }\n else {\n fieldReference.ref.value = fieldValue;\n if (!fieldReference.ref.type) {\n _subjects.values.next({\n name,\n values: { ..._formValues },\n });\n }\n }\n }\n }\n (options.shouldDirty || options.shouldTouch) &&\n updateTouchAndDirty(name, fieldValue, options.shouldTouch, options.shouldDirty, true);\n options.shouldValidate && trigger(name);\n };\n const setValues = (name, value, options) => {\n for (const fieldKey in value) {\n const fieldValue = value[fieldKey];\n const fieldName = `${name}.${fieldKey}`;\n const field = get(_fields, fieldName);\n (_names.array.has(name) ||\n !isPrimitive(fieldValue) ||\n (field && !field._f)) &&\n !isDateObject(fieldValue)\n ? setValues(fieldName, fieldValue, options)\n : setFieldValue(fieldName, fieldValue, options);\n }\n };\n const setValue = (name, value, options = {}) => {\n const field = get(_fields, name);\n const isFieldArray = _names.array.has(name);\n const cloneValue = cloneObject(value);\n set(_formValues, name, cloneValue);\n if (isFieldArray) {\n _subjects.array.next({\n name,\n values: { ..._formValues },\n });\n if ((_proxyFormState.isDirty || _proxyFormState.dirtyFields) &&\n options.shouldDirty) {\n _subjects.state.next({\n name,\n dirtyFields: getDirtyFields(_defaultValues, _formValues),\n isDirty: _getDirty(name, cloneValue),\n });\n }\n }\n else {\n field && !field._f && !isNullOrUndefined(cloneValue)\n ? setValues(name, cloneValue, options)\n : setFieldValue(name, cloneValue, options);\n }\n isWatched(name, _names) && _subjects.state.next({ ..._formState });\n _subjects.values.next({\n name,\n values: { ..._formValues },\n });\n !_state.mount && flushRootRender();\n };\n const onChange = async (event) => {\n const target = event.target;\n let name = target.name;\n let isFieldValueUpdated = true;\n const field = get(_fields, name);\n const getCurrentFieldValue = () => target.type ? getFieldValue(field._f) : getEventValue(event);\n if (field) {\n let error;\n let isValid;\n const fieldValue = getCurrentFieldValue();\n const isBlurEvent = event.type === EVENTS.BLUR || event.type === EVENTS.FOCUS_OUT;\n const shouldSkipValidation = (!hasValidation(field._f) &&\n !_options.resolver &&\n !get(_formState.errors, name) &&\n !field._f.deps) ||\n skipValidation(isBlurEvent, get(_formState.touchedFields, name), _formState.isSubmitted, validationModeAfterSubmit, validationModeBeforeSubmit);\n const watched = isWatched(name, _names, isBlurEvent);\n set(_formValues, name, fieldValue);\n if (isBlurEvent) {\n field._f.onBlur && field._f.onBlur(event);\n delayErrorCallback && delayErrorCallback(0);\n }\n else if (field._f.onChange) {\n field._f.onChange(event);\n }\n const fieldState = updateTouchAndDirty(name, fieldValue, isBlurEvent, false);\n const shouldRender = !isEmptyObject(fieldState) || watched;\n !isBlurEvent &&\n _subjects.values.next({\n name,\n type: event.type,\n values: { ..._formValues },\n });\n if (shouldSkipValidation) {\n _proxyFormState.isValid && _updateValid();\n return (shouldRender &&\n _subjects.state.next({ name, ...(watched ? {} : fieldState) }));\n }\n !isBlurEvent && watched && _subjects.state.next({ ..._formState });\n _updateIsValidating(true);\n if (_options.resolver) {\n const { errors } = await _executeSchema([name]);\n const previousErrorLookupResult = schemaErrorLookup(_formState.errors, _fields, name);\n const errorLookupResult = schemaErrorLookup(errors, _fields, previousErrorLookupResult.name || name);\n error = errorLookupResult.error;\n name = errorLookupResult.name;\n isValid = isEmptyObject(errors);\n }\n else {\n error = (await validateField(field, _formValues, shouldDisplayAllAssociatedErrors, _options.shouldUseNativeValidation))[name];\n isFieldValueUpdated =\n Number.isNaN(fieldValue) ||\n fieldValue === get(_formValues, name, fieldValue);\n if (isFieldValueUpdated) {\n if (error) {\n isValid = false;\n }\n else if (_proxyFormState.isValid) {\n isValid = await executeBuiltInValidation(_fields, true);\n }\n }\n }\n if (isFieldValueUpdated) {\n field._f.deps &&\n trigger(field._f.deps);\n shouldRenderByError(name, isValid, error, fieldState);\n }\n }\n };\n const trigger = async (name, options = {}) => {\n let isValid;\n let validationResult;\n const fieldNames = convertToArrayPayload(name);\n _updateIsValidating(true);\n if (_options.resolver) {\n const errors = await executeSchemaAndUpdateState(isUndefined(name) ? name : fieldNames);\n isValid = isEmptyObject(errors);\n validationResult = name\n ? !fieldNames.some((name) => get(errors, name))\n : isValid;\n }\n else if (name) {\n validationResult = (await Promise.all(fieldNames.map(async (fieldName) => {\n const field = get(_fields, fieldName);\n return await executeBuiltInValidation(field && field._f ? { [fieldName]: field } : field);\n }))).every(Boolean);\n !(!validationResult && !_formState.isValid) && _updateValid();\n }\n else {\n validationResult = isValid = await executeBuiltInValidation(_fields);\n }\n _subjects.state.next({\n ...(!isString(name) ||\n (_proxyFormState.isValid && isValid !== _formState.isValid)\n ? {}\n : { name }),\n ...(_options.resolver || !name ? { isValid } : {}),\n errors: _formState.errors,\n isValidating: false,\n });\n options.shouldFocus &&\n !validationResult &&\n focusFieldBy(_fields, (key) => key && get(_formState.errors, key), name ? fieldNames : _names.mount);\n return validationResult;\n };\n const getValues = (fieldNames) => {\n const values = {\n ..._defaultValues,\n ...(_state.mount ? _formValues : {}),\n };\n return isUndefined(fieldNames)\n ? values\n : isString(fieldNames)\n ? get(values, fieldNames)\n : fieldNames.map((name) => get(values, name));\n };\n const getFieldState = (name, formState) => ({\n invalid: !!get((formState || _formState).errors, name),\n isDirty: !!get((formState || _formState).dirtyFields, name),\n isTouched: !!get((formState || _formState).touchedFields, name),\n error: get((formState || _formState).errors, name),\n });\n const clearErrors = (name) => {\n name &&\n convertToArrayPayload(name).forEach((inputName) => unset(_formState.errors, inputName));\n _subjects.state.next({\n errors: name ? _formState.errors : {},\n });\n };\n const setError = (name, error, options) => {\n const ref = (get(_fields, name, { _f: {} })._f || {}).ref;\n set(_formState.errors, name, {\n ...error,\n ref,\n });\n _subjects.state.next({\n name,\n errors: _formState.errors,\n isValid: false,\n });\n options && options.shouldFocus && ref && ref.focus && ref.focus();\n };\n const watch = (name, defaultValue) => isFunction(name)\n ? _subjects.values.subscribe({\n next: (payload) => name(_getWatch(undefined, defaultValue), payload),\n })\n : _getWatch(name, defaultValue, true);\n const unregister = (name, options = {}) => {\n for (const fieldName of name ? convertToArrayPayload(name) : _names.mount) {\n _names.mount.delete(fieldName);\n _names.array.delete(fieldName);\n if (!options.keepValue) {\n unset(_fields, fieldName);\n unset(_formValues, fieldName);\n }\n !options.keepError && unset(_formState.errors, fieldName);\n !options.keepDirty && unset(_formState.dirtyFields, fieldName);\n !options.keepTouched && unset(_formState.touchedFields, fieldName);\n !_options.shouldUnregister &&\n !options.keepDefaultValue &&\n unset(_defaultValues, fieldName);\n }\n _subjects.values.next({\n values: { ..._formValues },\n });\n _subjects.state.next({\n ..._formState,\n ...(!options.keepDirty ? {} : { isDirty: _getDirty() }),\n });\n !options.keepIsValid && _updateValid();\n };\n const _updateDisabledField = ({ disabled, name, field, fields, }) => {\n if (isBoolean(disabled)) {\n const value = disabled\n ? undefined\n : get(_formValues, name, getFieldValue(field ? field._f : get(fields, name)._f));\n set(_formValues, name, value);\n updateTouchAndDirty(name, value, false, false, true);\n }\n };\n const register = (name, options = {}) => {\n let field = get(_fields, name);\n const disabledIsDefined = isBoolean(options.disabled);\n set(_fields, name, {\n ...(field || {}),\n _f: {\n ...(field && field._f ? field._f : { ref: { name } }),\n name,\n mount: true,\n ...options,\n },\n });\n _names.mount.add(name);\n if (field) {\n _updateDisabledField({\n field,\n disabled: options.disabled,\n name,\n });\n }\n else {\n updateValidAndValue(name, true, options.value);\n }\n return {\n ...(disabledIsDefined ? { disabled: options.disabled } : {}),\n ...(_options.progressive\n ? {\n required: !!options.required,\n min: getRuleValue(options.min),\n max: getRuleValue(options.max),\n minLength: getRuleValue(options.minLength),\n maxLength: getRuleValue(options.maxLength),\n pattern: getRuleValue(options.pattern),\n }\n : {}),\n name,\n onChange,\n onBlur: onChange,\n ref: (ref) => {\n if (ref) {\n register(name, options);\n field = get(_fields, name);\n const fieldRef = isUndefined(ref.value)\n ? ref.querySelectorAll\n ? ref.querySelectorAll('input,select,textarea')[0] || ref\n : ref\n : ref;\n const radioOrCheckbox = isRadioOrCheckbox(fieldRef);\n const refs = field._f.refs || [];\n if (radioOrCheckbox\n ? refs.find((option) => option === fieldRef)\n : fieldRef === field._f.ref) {\n return;\n }\n set(_fields, name, {\n _f: {\n ...field._f,\n ...(radioOrCheckbox\n ? {\n refs: [\n ...refs.filter(live),\n fieldRef,\n ...(Array.isArray(get(_defaultValues, name)) ? [{}] : []),\n ],\n ref: { type: fieldRef.type, name },\n }\n : { ref: fieldRef }),\n },\n });\n updateValidAndValue(name, false, undefined, fieldRef);\n }\n else {\n field = get(_fields, name, {});\n if (field._f) {\n field._f.mount = false;\n }\n (_options.shouldUnregister || options.shouldUnregister) &&\n !(isNameInFieldArray(_names.array, name) && _state.action) &&\n _names.unMount.add(name);\n }\n },\n };\n };\n const _focusError = () => _options.shouldFocusError &&\n focusFieldBy(_fields, (key) => key && get(_formState.errors, key), _names.mount);\n const handleSubmit = (onValid, onInvalid) => async (e) => {\n if (e) {\n e.preventDefault && e.preventDefault();\n e.persist && e.persist();\n }\n let fieldValues = cloneObject(_formValues);\n _subjects.state.next({\n isSubmitting: true,\n });\n if (_options.resolver) {\n const { errors, values } = await _executeSchema();\n _formState.errors = errors;\n fieldValues = values;\n }\n else {\n await executeBuiltInValidation(_fields);\n }\n unset(_formState.errors, 'root');\n if (isEmptyObject(_formState.errors)) {\n _subjects.state.next({\n errors: {},\n });\n await onValid(fieldValues, e);\n }\n else {\n if (onInvalid) {\n await onInvalid({ ..._formState.errors }, e);\n }\n _focusError();\n setTimeout(_focusError);\n }\n _subjects.state.next({\n isSubmitted: true,\n isSubmitting: false,\n isSubmitSuccessful: isEmptyObject(_formState.errors),\n submitCount: _formState.submitCount + 1,\n errors: _formState.errors,\n });\n };\n const resetField = (name, options = {}) => {\n if (get(_fields, name)) {\n if (isUndefined(options.defaultValue)) {\n setValue(name, get(_defaultValues, name));\n }\n else {\n setValue(name, options.defaultValue);\n set(_defaultValues, name, options.defaultValue);\n }\n if (!options.keepTouched) {\n unset(_formState.touchedFields, name);\n }\n if (!options.keepDirty) {\n unset(_formState.dirtyFields, name);\n _formState.isDirty = options.defaultValue\n ? _getDirty(name, get(_defaultValues, name))\n : _getDirty();\n }\n if (!options.keepError) {\n unset(_formState.errors, name);\n _proxyFormState.isValid && _updateValid();\n }\n _subjects.state.next({ ..._formState });\n }\n };\n const _reset = (formValues, keepStateOptions = {}) => {\n const updatedValues = formValues ? cloneObject(formValues) : _defaultValues;\n const cloneUpdatedValues = cloneObject(updatedValues);\n const values = formValues && !isEmptyObject(formValues)\n ? cloneUpdatedValues\n : _defaultValues;\n if (!keepStateOptions.keepDefaultValues) {\n _defaultValues = updatedValues;\n }\n if (!keepStateOptions.keepValues) {\n if (keepStateOptions.keepDirtyValues || shouldCaptureDirtyFields) {\n for (const fieldName of _names.mount) {\n get(_formState.dirtyFields, fieldName)\n ? set(values, fieldName, get(_formValues, fieldName))\n : setValue(fieldName, get(values, fieldName));\n }\n }\n else {\n if (isWeb && isUndefined(formValues)) {\n for (const name of _names.mount) {\n const field = get(_fields, name);\n if (field && field._f) {\n const fieldReference = Array.isArray(field._f.refs)\n ? field._f.refs[0]\n : field._f.ref;\n if (isHTMLElement(fieldReference)) {\n const form = fieldReference.closest('form');\n if (form) {\n form.reset();\n break;\n }\n }\n }\n }\n }\n _fields = {};\n }\n _formValues = props.shouldUnregister\n ? keepStateOptions.keepDefaultValues\n ? cloneObject(_defaultValues)\n : {}\n : cloneObject(values);\n _subjects.array.next({\n values: { ...values },\n });\n _subjects.values.next({\n values: { ...values },\n });\n }\n _names = {\n mount: new Set(),\n unMount: new Set(),\n array: new Set(),\n watch: new Set(),\n watchAll: false,\n focus: '',\n };\n !_state.mount && flushRootRender();\n _state.mount = !_proxyFormState.isValid || !!keepStateOptions.keepIsValid;\n _state.watch = !!props.shouldUnregister;\n _subjects.state.next({\n submitCount: keepStateOptions.keepSubmitCount\n ? _formState.submitCount\n : 0,\n isDirty: keepStateOptions.keepDirty\n ? _formState.isDirty\n : !!(keepStateOptions.keepDefaultValues &&\n !deepEqual(formValues, _defaultValues)),\n isSubmitted: keepStateOptions.keepIsSubmitted\n ? _formState.isSubmitted\n : false,\n dirtyFields: keepStateOptions.keepDirtyValues\n ? _formState.dirtyFields\n : keepStateOptions.keepDefaultValues && formValues\n ? getDirtyFields(_defaultValues, formValues)\n : {},\n touchedFields: keepStateOptions.keepTouched\n ? _formState.touchedFields\n : {},\n errors: keepStateOptions.keepErrors ? _formState.errors : {},\n isSubmitting: false,\n isSubmitSuccessful: false,\n });\n };\n const reset = (formValues, keepStateOptions) => _reset(isFunction(formValues)\n ? formValues(_formValues)\n : formValues, keepStateOptions);\n const setFocus = (name, options = {}) => {\n const field = get(_fields, name);\n const fieldReference = field && field._f;\n if (fieldReference) {\n const fieldRef = fieldReference.refs\n ? fieldReference.refs[0]\n : fieldReference.ref;\n if (fieldRef.focus) {\n fieldRef.focus();\n options.shouldSelect && fieldRef.select();\n }\n }\n };\n const _updateFormState = (updatedFormState) => {\n _formState = {\n ..._formState,\n ...updatedFormState,\n };\n };\n const _resetDefaultValues = () => isFunction(_options.defaultValues) &&\n _options.defaultValues().then((values) => {\n reset(values, _options.resetOptions);\n _subjects.state.next({\n isLoading: false,\n });\n });\n return {\n control: {\n register,\n unregister,\n getFieldState,\n handleSubmit,\n setError,\n _executeSchema,\n _getWatch,\n _getDirty,\n _updateValid,\n _removeUnmounted,\n _updateFieldArray,\n _updateDisabledField,\n _getFieldArray,\n _reset,\n _resetDefaultValues,\n _updateFormState,\n _subjects,\n _proxyFormState,\n get _fields() {\n return _fields;\n },\n get _formValues() {\n return _formValues;\n },\n get _state() {\n return _state;\n },\n set _state(value) {\n _state = value;\n },\n get _defaultValues() {\n return _defaultValues;\n },\n get _names() {\n return _names;\n },\n set _names(value) {\n _names = value;\n },\n get _formState() {\n return _formState;\n },\n set _formState(value) {\n _formState = value;\n },\n get _options() {\n return _options;\n },\n set _options(value) {\n _options = {\n ..._options,\n ...value,\n };\n },\n },\n trigger,\n register,\n handleSubmit,\n watch,\n setValue,\n getValues,\n reset,\n resetField,\n clearErrors,\n unregister,\n setError,\n setFocus,\n getFieldState,\n };\n}\n\n/**\n * Custom hook to manage the entire form.\n *\n * @remarks\n * [API](https://react-hook-form.com/docs/useform) • [Demo](https://codesandbox.io/s/react-hook-form-get-started-ts-5ksmm) • [Video](https://www.youtube.com/watch?v=RkXv4AXXC_4)\n *\n * @param props - form configuration and validation parameters.\n *\n * @returns methods - individual functions to manage the form state. {@link UseFormReturn}\n *\n * @example\n * ```tsx\n * function App() {\n * const { register, handleSubmit, watch, formState: { errors } } = useForm();\n * const onSubmit = data => console.log(data);\n *\n * console.log(watch(\"example\"));\n *\n * return (\n *
\n * \n * \n * {errors.exampleRequired && This field is required}\n * \n *
\n * );\n * }\n * ```\n */\nfunction useForm(props = {}) {\n const _formControl = React.useRef();\n const _values = React.useRef();\n const [formState, updateFormState] = React.useState({\n isDirty: false,\n isValidating: false,\n isLoading: isFunction(props.defaultValues),\n isSubmitted: false,\n isSubmitting: false,\n isSubmitSuccessful: false,\n isValid: false,\n submitCount: 0,\n dirtyFields: {},\n touchedFields: {},\n errors: {},\n defaultValues: isFunction(props.defaultValues)\n ? undefined\n : props.defaultValues,\n });\n if (!_formControl.current) {\n _formControl.current = {\n ...createFormControl(props, () => updateFormState((formState) => ({ ...formState }))),\n formState,\n };\n }\n const control = _formControl.current.control;\n control._options = props;\n useSubscribe({\n subject: control._subjects.state,\n next: (value) => {\n if (shouldRenderFormState(value, control._proxyFormState, control._updateFormState, true)) {\n updateFormState({ ...control._formState });\n }\n },\n });\n React.useEffect(() => {\n if (props.values && !deepEqual(props.values, _values.current)) {\n control._reset(props.values, control._options.resetOptions);\n _values.current = props.values;\n }\n else {\n control._resetDefaultValues();\n }\n }, [props.values, control]);\n React.useEffect(() => {\n if (!control._state.mount) {\n control._updateValid();\n control._state.mount = true;\n }\n if (control._state.watch) {\n control._state.watch = false;\n control._subjects.state.next({ ...control._formState });\n }\n control._removeUnmounted();\n });\n _formControl.current.formState = getProxyFormState(formState, control);\n return _formControl.current;\n}\n\nexport { Controller, Form, FormProvider, appendErrors, get, set, useController, useFieldArray, useForm, useFormContext, useFormState, useWatch };\n//# sourceMappingURL=index.esm.mjs.map\n","import {\n Dimensions,\n KeyboardAvoidingView,\n ScrollView,\n TouchableOpacity,\n View,\n} from \"react-native\";\nimport { useController } from \"react-hook-form\";\nimport { ListGroupM } from \"../list/ListGroupM\";\nimport { ListItemM } from \"../list/ListItemM\";\nimport TitleM from \"../text/TitleM\";\nimport TextM from \"../text/TextM\";\nimport React, { useContext, useEffect, useRef, useState } from \"react\";\nimport TextInputM from \"../input/TextInputM\";\nimport ErrorTextM from \"../text/ErrorTextM\";\nimport FilledButtonM from \"../button/FilledButtonM\";\nimport TextButtonM from \"../button/TextButtonM\";\nimport { theme } from \"../../theme/theme\";\nimport { DimensionsContext, IS_WEB } from \"../../utils/mobileUtils\";\n//import CameraImagesM from \"../../camera/CameraImagesM\";\nimport { useSafeAreaInsets } from \"react-native-safe-area-context\";\nimport * as amplitude from \"@amplitude/analytics-react-native\";\nimport { PaginatedFlatList } from \"@common/screens/PaginatedFlatList\";\nimport DateTimePicker from \"../../../admin/DateTimePicker\";\nimport CameraImagesM from \"@common/camera/CameraImagesM\";\nimport { addMediaToField, plr } from \"@data/utility/Utils\";\nimport { formIds } from \"@data/constants/formConstants\";\nimport { IconTextM } from \"@common/components/icons/IconTextM\";\nimport { ActivityIndicator, Switch, TouchableRipple } from \"react-native-paper\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport { IconImageM } from \"@common/components/icons/IconsM\";\nimport ServerSearch from \"../../../admin/ServerSearch\";\nimport { useSelector } from \"react-redux\";\nimport { useApiStatus } from \"@common/hooks/useApiStatus\";\n\nexport const FormStep = (props) => {\n // ** Component props\n const {\n data,\n control,\n setError,\n track = false,\n errors,\n goToNextStep,\n isLastStep,\n trigger,\n formValues,\n setFormValues,\n register,\n resetsToDefaultOnNext,\n hideNextButton,\n isStepDirty,\n champion,\n serverError,\n index,\n flex = 1,\n } = props;\n\n const { field } = useController({\n control,\n name: data?.name ?? \"\",\n });\n const insets = useSafeAreaInsets();\n\n useEffect(() => {\n amplitude.track(\n \"form.step.started:\" +\n (data?.name ?? data?.inputs?.map((x) => x?.name).join(\",\") ?? \"unknown\")\n );\n }, []);\n\n useEffect(() => {\n if (data?.defaultValue !== field.value && !field.value) {\n field.onChange(data?.defaultValue);\n setFormValues({\n ...control._formValues,\n [field?.name]: data?.defaultValue,\n });\n }\n }, []);\n\n const renderBottomComponent = () => {\n return (\n !!data?.bottomComponent && (\n \n {typeof data?.bottomComponent === \"function\"\n ? data?.bottomComponent(control, goToNextStep, errors, formValues)\n : data?.bottomComponent}\n \n )\n );\n };\n const renderTopComponent = () => {\n return (\n !!data?.topComponent && (\n \n {data?.topComponent}\n \n )\n );\n };\n const dimensions = useContext(DimensionsContext);\n\n const renderInput = () => {\n switch (data?.type) {\n case \"select.single\":\n if (data?.loading)\n return (\n \n \n \n );\n else if (data?.options?.length === 0)\n return (\n \n {!!data?.emptyIconName && (\n \n )}\n {!!data?.emptyIcon && (\n \n )}\n \n {data?.emptyMessage ?? \"Aucun élément\"}\n \n \n );\n else\n return (\n {\n //const sectionData = options?.find(option => option?.title === title)?.data\n\n return (\n \n {title}\n \n );\n }}\n renderItem={(item) => {\n return (\n {\n field.onChange(item.item?.value);\n setFormValues({\n ...control._formValues,\n [field?.name]: item.item?.value,\n });\n if (!isLastStep) goToNextStep();\n }}\n itemHeight={data?.height ? data?.height : 70}\n selected={item.item?.value === field.value}\n option={item.item}\n disabled={item.item?.disabled}\n />\n );\n }}\n />\n );\n\n case \"select.card.single\":\n return (\n \n {data?.options?.map((option, index) => {\n const isSelected = option?.value === field?.value;\n\n return (\n {\n field.onChange(option?.value);\n goToNextStep();\n }\n }\n style={{\n alignItems: \"center\",\n justifyContent: \"center\",\n alignSelf: \"center\",\n backgroundColor: !isSelected\n ? theme.colors.white\n : theme.colors.linkLighter,\n borderWidth: !isSelected ? 1 : 2,\n borderColor: !isSelected\n ? theme.colors.lightMore\n : theme.colors.primary,\n borderRadius: 15,\n width: dimensions?.width - 40,\n marginTop: 20,\n }}\n disabled={option?.disabled}\n underlayColor={theme.colors.lightMore}\n >\n {React.createElement(data?.cardContentComponent, {\n labelData: option?.labelData,\n })}\n \n );\n })}\n \n );\n\n case \"select.grouped.single\":\n return (\n \n {data?.options?.map((option, index) => {\n return (\n option?.subOptions?.length > 0 && (\n {\n // field.onChange(option?.value)\n // goToNextStep()\n // }}\n style={{\n alignItems: \"flex-start\",\n justifyContent: \"center\",\n alignSelf: \"center\",\n backgroundColor: theme.colors.white,\n borderWidth: 1,\n borderColor: theme.colors.lightMore,\n borderRadius: 15,\n width: dimensions?.width - 40,\n marginTop: 20,\n padding: 10,\n }}\n >\n \n {option?.label}\n \n \n {option?.subOptions?.map((subOption, subIndex) => {\n const isSelected = subOption?.value === field?.value;\n\n return (\n {\n field.onChange(subOption?.value);\n goToNextStep();\n }}\n style={{\n alignItems: \"center\",\n justifyContent: \"center\",\n backgroundColor: isSelected\n ? theme.colors.linkLighter\n : theme.colors.white,\n borderWidth: isSelected ? 2 : 1,\n borderColor: isSelected\n ? theme.colors.primary\n : theme.colors.lightMore,\n borderRadius: 15,\n paddingHorizontal: 25,\n paddingVertical: 20,\n margin: 5,\n }}\n underlayColor={theme.colors.lightMore}\n >\n \n {subOption?.label}\n \n \n );\n })}\n \n \n )\n );\n })}\n \n );\n\n case \"select.multiple\":\n useEffect(() => {\n if (resetsToDefaultOnNext) field.onChange(data?.defaultValue);\n }, []);\n\n return (\n {\n //const sectionData = options?.find(option => option?.title === title)?.data\n\n return (\n \n {title}\n \n );\n }}\n renderItem={(item) => {\n const selected = field.value?.includes(item.item?.value);\n\n return (\n {\n // console.log(control._formValues)\n const value = field.value ? field.value?.slice() : [];\n if (selected) {\n value?.splice(value?.indexOf(item.item?.value), 1);\n } else {\n value?.push(item.item?.value);\n }\n field.onChange(value);\n setFormValues({\n ...control._formValues,\n [field?.name]: value,\n });\n // console.log(control._formValues)\n trigger();\n }}\n itemHeight={data?.height ? data?.height : null}\n selected={selected}\n option={item.item}\n style={{\n paddingVertical: 20,\n }}\n />\n );\n }}\n />\n );\n //TODO : delete this deprecated case (use text.multiple instead)\n case \"text.single\":\n return (\n \n );\n\n case \"photos\":\n const [images, setImages] = useState(\n data.defaultValue?.map((x) => {\n return {\n uri: x,\n width: IS_WEB ? dimensions?.width * 0.4 : dimensions?.width * 0.6,\n height: dimensions?.height * 0.4,\n };\n }) ?? []\n );\n\n //console.log(field.value)\n\n // console.log(field?.value?.file_keys)\n useEffect(() => {\n // console.log(\"images change\", images)\n addMediaToField(field, images, true);\n\n setFormValues({\n ...control._formValues,\n [field?.name]: images?.map((file) => {\n return {\n type: \"image/png\",\n height: file?.height,\n width: file?.width,\n uri: file?.uri,\n };\n }),\n });\n //console.log(field)\n }, [images]);\n\n return (\n \n );\n\n case \"text.multiple\":\n const inputRefs = data?.inputs?.map((i, index) => useRef());\n\n // const inputControllers = data?.inputs?.map((i, index) => useController({\n // control,\n // name: i?.name\n // }))\n\n useEffect(() => {\n // inputRefs[0].current.focus()\n if (!isStepDirty)\n setTimeout(function () {\n inputRefs[0]?.current?.focus();\n }, 100);\n }, []);\n\n return (\n \n {data?.inputs?.map((i, index) => {\n // console.log(i?.validationRules)\n\n return (\n \n {!!i?.label && (\n \n {i?.label}\n \n )}\n {\n setFormValues({\n ...control._formValues,\n [i?.name]: value,\n });\n }}\n disabled={i?.disabled}\n hidden={i?.hidden}\n setError={setError}\n liveCheck={i?.liveCheck}\n liveCheckPreRequest={i?.liveCheckPreRequest}\n placeholder={i?.placeholder}\n ref={inputRefs[index]}\n // autofocus={index === 0}\n keyboardType={i?.keyboardType ?? null}\n inputMode={i?.inputMode ?? null}\n onSubmitEditing={(e) => {\n if (index < data?.inputs?.length - 1)\n inputRefs[index + 1].current?.focus();\n // else\n // goToNextStep()\n }}\n returnKeyType={\n index === data?.inputs?.length - 1 ? \"done\" : \"next\"\n }\n contentContainerStyle={\n {\n // width: IS_WEB ? dimensions?.width * 3 / 5 : \"100%\"\n }\n }\n multiline={!!i?.height}\n style={{\n // marginHorizontal: 20\n height: i?.height ?? null,\n }}\n password={i?.password}\n key={index}\n // name={i?.name}\n control={control}\n errors={errors}\n />\n \n );\n })}\n {!!data?.checkBoxes &&\n data?.checkBoxes?.map((cb, key) => {\n const { field } = useController({\n control,\n name: cb?.name ?? \"\",\n });\n\n return (\n \n \n {\n // console.log(\"formValues\", formValues)\n field.onChange(value);\n setFormValues({\n ...control._formValues,\n [cb?.name]: value,\n });\n // field.onChange(value)\n }}\n />\n \n );\n })}\n \n );\n\n case \"select.two.oriented\":\n return (\n \n {\n field.onChange(data?.options[0]?.value);\n goToNextStep();\n }\n }\n color={data?.options[0]?.color}\n label={data?.options[0]?.label}\n />\n\n {\n field.onChange(data?.options[1]?.value);\n goToNextStep();\n }}\n fontWeight=\"ExtraBold\"\n label={data?.options[1]?.label?.toUpperCase()}\n />\n \n );\n case \"select.paginated\":\n const flatListRef = useRef();\n const [urlParams, setUrlParams] = useState({\n search: \"\",\n ...data?.additionalUrlParams,\n });\n\n // const request = data?.service ? (useSelector((state) => state.api[data?.service?.name]?.request) ?? false) : null\n // const success = data?.service ? useSelector((state) => state.api[data?.service?.name]?.success) : null\n const error = data?.service\n ? useSelector((state) => state.api[data?.service?.name]?.error)\n : null;\n\n const [paginatedOptions, setPaginatedOptions] = useState([]);\n\n const initialSelectedItemsIds = data?.singleMode\n ? [field.value]\n : field.value;\n const initialSelectedItems =\n initialSelectedItemsIds\n ?.map(\n (id) =>\n data?.defaultSelectedItems?.find((item) => item?.id === id) ??\n null\n )\n ?.filter((item) => !!item) ?? [];\n\n const [selectedItems, setSelectedItems] =\n useState(initialSelectedItems);\n\n const options = data?.withNull\n ? [{ id: null, display_name: \"Aucun\" }].concat(paginatedOptions)\n : paginatedOptions;\n\n // Header component to display selected items\n const SelectedItemsHeader = React.memo(\n ({ selectedItems }) =>\n !data?.singleMode && (\n \n \n {selectedItems.length}{\" \"}\n {plr(\"sélectionné\", selectedItems.length)}\n \n {selectedItems.map((item, index) =>\n renderItem({ item: item, index: index }, true)\n )}\n \n )\n );\n\n useApiStatus(\n data?.service, // api service\n false, // success message on toast (string or null)\n false, // error message on toast (true) or keep it in redux state (false)\n (successData) => {\n if (successData?.meta?.current_page === 1) {\n // refresh\n setPaginatedOptions(successData?.[data?.responseKey]);\n } else {\n // concat\n setPaginatedOptions(\n paginatedOptions.concat(successData?.[data?.responseKey])\n );\n }\n } // success callback\n );\n\n const renderItem = (item, header = false) => {\n const selected = data?.singleMode\n ? field.value === item.item?.id\n : field.value?.includes(item.item?.id);\n return (\n {\n if (data?.singleMode) {\n field.onChange(item.item?.id);\n setSelectedItems([item.item]);\n setFormValues({\n ...control._formValues,\n [field?.name]: item.item?.id,\n });\n if (!isLastStep) goToNextStep();\n } else {\n const value = field.value ? field.value?.slice() : [];\n if (selected) {\n value?.splice(value?.indexOf(item.item?.id), 1);\n setSelectedItems(\n selectedItems.filter((i) => i.id !== item.item.id)\n );\n } else {\n value?.push(item.item?.id);\n setSelectedItems(selectedItems.concat(item.item));\n }\n field.onChange(value);\n setFormValues({\n ...control._formValues,\n [field?.name]: value,\n });\n }\n\n // console.log(control._formValues)\n trigger();\n }}\n >\n {data?.renderItem(item?.item, selected)}\n \n );\n };\n return (\n \n \n \n\n \n }\n data={options}\n // contentContainerStyle={{paddingBottom: 100}}\n additionalOnRefresh={() => {}}\n additionalRefreshing={false}\n requestApiService={data?.service}\n requestRouteParams={data?.routeParams}\n requestUrlParams={urlParams}\n requestData={null}\n renderItem={renderItem}\n />\n \n );\n case \"date\":\n return (\n \n );\n case \"time\":\n return (\n \n );\n case \"date-time\":\n return (\n \n );\n case \"day-time\":\n return (\n \n );\n case \"date-multiple\":\n return (\n \n {data?.inputs?.map((i, index) => {\n const { field: localField } = useController({\n control,\n name: i?.name ?? \"\",\n });\n\n return (\n \n {!!i?.title && (\n \n {i?.title}\n \n )}\n \n \n );\n })}\n \n );\n case \"custom\":\n return React.createElement(data.component, {\n control,\n goToNextStep,\n errors,\n register,\n serverError,\n formValues,\n setFormValues,\n field,\n trigger,\n ...data?.componentProps,\n });\n\n default:\n return <>;\n }\n };\n\n const renderDescription = () => {\n if (React.isValidElement(data?.description)) {\n return data.description;\n }\n return (\n \n {data?.description}\n \n );\n };\n\n return (\n <>\n {!champion && (\n \n {!!data?.label && (\n \n {data?.label}\n \n )}\n {!!data?.description && renderDescription()}\n \n )}\n \n {/*behavior={Platform.OS === 'ios' ? 'position' : 'height'}>*/}\n \n {renderTopComponent()}\n\n {!!data?.icon && (\n \n {data?.icon}\n \n )}\n {renderInput()}\n {!!data?.indication && data?.indication !== \"\" && (\n \n {data?.indication}\n \n )}\n {isLastStep && (\n \n )}\n {renderBottomComponent()}\n \n \n \n );\n};\n","import _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"behavior\", \"contentContainerStyle\", \"keyboardVerticalOffset\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport View from '../View';\nclass KeyboardAvoidingView extends React.Component {\n constructor() {\n super(...arguments);\n this.frame = null;\n this.onLayout = event => {\n this.frame = event.nativeEvent.layout;\n };\n }\n relativeKeyboardHeight(keyboardFrame) {\n var frame = this.frame;\n if (!frame || !keyboardFrame) {\n return 0;\n }\n var keyboardY = keyboardFrame.screenY - (this.props.keyboardVerticalOffset || 0);\n return Math.max(frame.y + frame.height - keyboardY, 0);\n }\n onKeyboardChange(event) {}\n render() {\n var _this$props = this.props,\n behavior = _this$props.behavior,\n contentContainerStyle = _this$props.contentContainerStyle,\n keyboardVerticalOffset = _this$props.keyboardVerticalOffset,\n rest = _objectWithoutPropertiesLoose(_this$props, _excluded);\n return /*#__PURE__*/React.createElement(View, _extends({\n onLayout: this.onLayout\n }, rest));\n }\n}\nexport default KeyboardAvoidingView;","import React from \"react\";\nimport {FlatList, SectionList} from \"react-native\";\nimport {theme} from \"../../theme/theme\";\nimport {IS_WEB} from \"../../utils/mobileUtils\";\n\nexport function ListGroupM(props) {\n\n // ** Component props\n const {\n options,\n renderItem,\n initialScrollIndex = 0,\n itemHeight,\n style,\n sectionMode = false,\n renderSectionHeader,\n contentContainerStyle,\n scrollEnabled = true\n } = props\n\n return <>\n {!sectionMode ? (\n {length: itemHeight, offset: itemHeight * index, index}\n )}\n scrollEnabled={scrollEnabled}\n style={{\n borderWidth: 1,\n borderRadius: 15,\n borderColor: theme.colors.lightMore,\n marginTop: 10,\n marginBottom: 20,\n flexGrow: IS_WEB ? null : 0,\n width: \"100%\",\n ...style\n }}\n contentContainerStyle={{\n borderRadius: 15,\n overflow: \"hidden\",\n ...contentContainerStyle\n }}\n keyExtractor={(item, index) => index.toString()}\n renderItem={renderItem}/> : item + index}\n renderSectionHeader={renderSectionHeader}\n getItemLayout={(data, index) => (\n {\n length: itemHeight,\n offset: itemHeight * index,\n index\n }\n )}\n style={{\n borderWidth: 1,\n borderRadius: 15,\n borderColor: theme.colors.lightMore,\n marginTop: 10,\n marginBottom: 20,\n flexGrow: 0,\n width: \"100%\",\n ...style\n }}\n contentContainerStyle={{\n ...contentContainerStyle\n }}\n renderItem={renderItem}/>}\n \n}","import {View} from \"react-native\";\nimport {theme} from \"../../theme/theme\";\nimport {IconImageM} from \"../icons/IconsM\";\nimport TextM from \"../text/TextM\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport React from \"react\";\nimport {IconButton, TouchableRipple} from \"react-native-paper\";\nimport * as Clipboard from 'expo-clipboard';\nimport AvatarM from \"@common/components/avatar/AvatarM\";\n\nexport function ListItemM(props) {\n\n // ** Component props\n const {isFirst, isLast, option, selected, itemHeight, noBorder, disabled, withClipBoard = false} = props\n\n return \n \n {option?.leftComponent ? option?.leftComponent : null}\n\n {!!option?.icon && 70 ? itemHeight / 3 : 0,\n tintColor: option?.tintColor ?? null\n }}\n width={40}/>}\n\n {option?.source && }\n {option?.avatar && 70 ? itemHeight / 3 : 0\n }}\n />}\n\n \n {option?.label}\n {option?.description && {option?.description}}\n \n {selected && }\n {withClipBoard && {\n Clipboard.setStringAsync(option?.label).then();\n }}\n />}\n \n ;\n}","import { EventEmitter, UnavailabilityError, Platform } from 'expo-modules-core';\nimport { ClipboardPasteButton } from './ClipboardPasteButton';\nimport ExpoClipboard from './ExpoClipboard';\nconst emitter = new EventEmitter(ExpoClipboard);\nconst onClipboardEventName = 'onClipboardChanged';\n/**\n * Gets the content of the user's clipboard. Please note that calling this method on web will prompt\n * the user to grant your app permission to \"see text and images copied to the clipboard.\"\n *\n * @param options Options for the clipboard content to be retrieved.\n * @returns A promise that resolves to the content of the clipboard.\n */\nexport async function getStringAsync(options = {}) {\n if (!ExpoClipboard.getStringAsync) {\n throw new UnavailabilityError('Clipboard', 'getStringAsync');\n }\n return await ExpoClipboard.getStringAsync(options);\n}\n/**\n * Sets the content of the user's clipboard.\n *\n * @param text The string to save to the clipboard.\n * @param options Options for the clipboard content to be set.\n * @returns On web, this returns a promise that fulfills to a boolean value indicating whether or not\n * the string was saved to the user's clipboard. On iOS and Android, the promise always resolves to `true`.\n */\nexport async function setStringAsync(text, options = {}) {\n if (!ExpoClipboard.setStringAsync) {\n throw new UnavailabilityError('Clipboard', 'setStringAsync');\n }\n return ExpoClipboard.setStringAsync(text, options);\n}\n/**\n * Sets the content of the user's clipboard.\n * @deprecated Use [`setStringAsync()`](#setstringasynctext-options) instead.\n *\n * @returns On web, this returns a boolean value indicating whether or not the string was saved to\n * the user's clipboard. On iOS and Android, nothing is returned.\n */\nexport function setString(text) {\n if (Platform.OS === 'web') {\n // on web, we need to return legacy method,\n // because of different return type\n return ExpoClipboard.setString(text);\n }\n else {\n setStringAsync(text);\n }\n}\n/**\n * Returns whether the clipboard has text content. Returns true for both plain text and rich text (e.g. HTML).\n *\n * On web, this requires the user to grant your app permission to _\"see text and images copied to the clipboard\"_.\n *\n * @returns A promise that fulfills to `true` if clipboard has text content, resolves to `false` otherwise.\n */\nexport function hasStringAsync() {\n if (!ExpoClipboard.hasStringAsync) {\n throw new UnavailabilityError('Clipboard', 'hasStringAsync');\n }\n return ExpoClipboard.hasStringAsync();\n}\n/**\n * Gets the URL from the user's clipboard.\n *\n * @returns A promise that fulfills to the URL in the clipboard.\n * @platform ios\n */\nexport async function getUrlAsync() {\n if (!ExpoClipboard.getUrlAsync) {\n throw new UnavailabilityError('Clipboard', 'getUrlAsync');\n }\n return await ExpoClipboard.getUrlAsync();\n}\n/**\n * Sets a URL in the user's clipboard.\n *\n * This function behaves the same as [`setStringAsync()`](#setstringasynctext-options), except that\n * it sets the clipboard content type to be a URL. It lets your app or other apps know that the\n * clipboard contains a URL and behave accordingly.\n *\n * @param url The URL to save to the clipboard.\n * @platform ios\n */\nexport async function setUrlAsync(url) {\n if (!ExpoClipboard.setUrlAsync) {\n throw new UnavailabilityError('Clipboard', 'setUrlAsync');\n }\n return ExpoClipboard.setUrlAsync(url);\n}\n/**\n * Returns whether the clipboard has a URL content.\n *\n * @returns A promise that fulfills to `true` if clipboard has URL content, resolves to `false` otherwise.\n * @platform ios\n */\nexport async function hasUrlAsync() {\n if (!ExpoClipboard.hasUrlAsync) {\n throw new UnavailabilityError('Clipboard', 'hasUrlAsync');\n }\n return await ExpoClipboard.hasUrlAsync();\n}\n/**\n * Gets the image from the user's clipboard and returns it in the specified format. Please note that calling\n * this method on web will prompt the user to grant your app permission to \"see text and images copied to the clipboard.\"\n *\n * @param options A `GetImageOptions` object to specify the desired format of the image.\n * @returns If there was an image in the clipboard, the promise resolves to\n * a [`ClipboardImage`](#clipboardimage) object containing the base64 string and metadata of the image.\n * Otherwise, it resolves to `null`.\n *\n * @example\n * ```tsx\n * const img = await Clipboard.getImageAsync({ format: 'png' });\n * // ...\n * \n * ```\n */\nexport async function getImageAsync(options) {\n if (!ExpoClipboard.getImageAsync) {\n throw new UnavailabilityError('Clipboard', 'getImageAsync');\n }\n return await ExpoClipboard.getImageAsync(options);\n}\n/**\n * Sets an image in the user's clipboard.\n *\n * @param base64Image Image encoded as a base64 string, without MIME type.\n *\n * @example\n * ```tsx\n * const result = await ImagePicker.launchImageLibraryAsync({\n * mediaTypes: ImagePicker.MediaTypeOptions.Images,\n * base64: true,\n * });\n * await Clipboard.setImageAsync(result.base64);\n * ```\n */\nexport async function setImageAsync(base64Image) {\n if (!ExpoClipboard.setImageAsync) {\n throw new UnavailabilityError('Clipboard', 'setImageAsync');\n }\n return ExpoClipboard.setImageAsync(base64Image);\n}\n/**\n * Returns whether the clipboard has an image content.\n *\n * On web, this requires the user to grant your app permission to _\"see text and images copied to the clipboard\"_.\n *\n * @returns A promise that fulfills to `true` if clipboard has image content, resolves to `false` otherwise.\n */\nexport async function hasImageAsync() {\n if (!ExpoClipboard.hasImageAsync) {\n throw new UnavailabilityError('Clipboard', 'hasImageAsync');\n }\n return ExpoClipboard.hasImageAsync();\n}\n/**\n * Adds a listener that will fire whenever the content of the user's clipboard changes. This method\n * is a no-op on Web.\n *\n * @param listener Callback to execute when listener is triggered. The callback is provided a\n * single argument that is an object containing information about clipboard contents.\n *\n * @example\n * ```typescript\n * Clipboard.addClipboardListener(({ contentTypes }: ClipboardEvent) => {\n * if (contentTypes.includes(Clipboard.ContentType.PLAIN_TEXT)) {\n * Clipboard.getStringAsync().then(content => {\n * alert('Copy pasta! Here\\'s the string that was copied: ' + content)\n * });\n * } else if (contentTypes.includes(Clipboard.ContentType.IMAGE)) {\n * alert('Yay! Clipboard contains an image');\n * }\n * });\n * ```\n */\nexport function addClipboardListener(listener) {\n // TODO: Get rid of this wrapper once we remove deprecated `content` property (not before SDK47)\n const listenerWrapper = (event) => {\n const wrappedEvent = {\n ...event,\n get content() {\n console.warn(\"The 'content' property of the clipboard event is deprecated. Use 'getStringAsync()' instead to get clipboard content\");\n return '';\n },\n };\n listener(wrappedEvent);\n };\n return emitter.addListener(onClipboardEventName, listenerWrapper);\n}\n/**\n * Removes the listener added by addClipboardListener. This method is a no-op on Web.\n *\n * @param subscription The subscription to remove (created by addClipboardListener).\n *\n * @example\n * ```typescript\n * const subscription = addClipboardListener(() => {\n * alert('Copy pasta!');\n * });\n * removeClipboardListener(subscription);\n * ```\n */\nexport function removeClipboardListener(subscription) {\n emitter.removeSubscription(subscription);\n}\n/**\n * Property that determines if the `ClipboardPasteButton` is available.\n *\n * This requires the users device to be using at least iOS 16.\n *\n * `true` if the component is available, and `false` otherwise.\n */\nexport const isPasteButtonAvailable = Platform.OS === 'ios' ? ExpoClipboard.isPasteButtonAvailable : false;\nexport * from './Clipboard.types';\nexport { ClipboardPasteButton };\n//# sourceMappingURL=Clipboard.js.map","import React from 'react';\nimport ExpoClipboardPasteButton from './ExpoClipboardPasteButton';\n// @needsAudit\n/**\n * This component displays the `UIPasteControl` button on your screen. This allows pasting from the clipboard without requesting permission from the user.\n *\n * You should only attempt to render this if [`Clipboard.isPasteButtonAvailable`](#ispastebuttonavailable)\n * is `true`. This component will render nothing if it is not available, and you will get\n * a warning in development mode (`__DEV__ === true`).\n *\n * The properties of this component extend from `View`; however, you should not attempt to set\n * `backgroundColor`, `color` or `borderRadius` with the `style` property. Apple restricts customisation of this view.\n * Instead, you should use the backgroundColor and foregroundColor properties to set the colors of the button, the cornerStyle property to change the border radius,\n * and the displayMode property to change the appearance of the icon and label. The word \"Paste\" is not editable and neither is the icon.\n *\n * Make sure to attach height and width via the style props as without these styles, the button will\n * not appear on the screen.\n *\n * @see [Apple Documentation](https://developer.apple.com/documentation/uikit/uipastecontrol) for more details.\n */\nexport function ClipboardPasteButton({ onPress, ...restProps }) {\n if (!ExpoClipboardPasteButton) {\n if (__DEV__) {\n console.warn(\"'ApplePasteButton' is not available.\");\n }\n return null;\n }\n const onPastePressed = ({ nativeEvent }) => {\n onPress(nativeEvent);\n };\n return ;\n}\n//# sourceMappingURL=ClipboardPasteButton.js.map","import { requireNativeViewManager } from 'expo-modules-core';\nimport { Platform } from 'react-native';\nlet ExpoClipboard;\nif (Platform.OS === 'ios') {\n ExpoClipboard = requireNativeViewManager('ExpoClipboard');\n}\nexport default ExpoClipboard;\n//# sourceMappingURL=ExpoClipboardPasteButton.js.map","export { default } from './web/ClipboardModule';\n//# sourceMappingURL=ExpoClipboard.web.js.map","import { ClipboardUnavailableException, CopyFailureException, NoPermissionException, PasteFailureException, } from './Exceptions';\nimport { base64toBlob, blobToBase64Async, findHtmlInClipboardAsync, findImageInClipboardAsync, getImageSizeFromBlobAsync, htmlToPlainText, isClipboardPermissionDeniedAsync, } from './Utils';\nimport { StringFormat, } from '../Clipboard.types';\nexport default {\n async getStringAsync(options) {\n if (!navigator.clipboard) {\n throw new ClipboardUnavailableException();\n }\n try {\n switch (options.preferredFormat) {\n case StringFormat.HTML: {\n // Try reading HTML first\n const clipboardItems = await navigator.clipboard.read();\n const blob = await findHtmlInClipboardAsync(clipboardItems);\n if (!blob) {\n // Fall back to plain text\n return await navigator.clipboard.readText();\n }\n return await new Response(blob).text();\n }\n default: {\n let text = await navigator.clipboard.readText();\n if (!text || text === '') {\n // If there's no direct plain text, try reading HTML\n const clipboardItems = await navigator.clipboard.read();\n const blob = await findHtmlInClipboardAsync(clipboardItems);\n const blobText = await blob?.text();\n text = htmlToPlainText(blobText ?? '');\n }\n return text;\n }\n }\n }\n catch (e) {\n // it might fail, because user denied permission\n if (e.name === 'NotAllowedError' || (await isClipboardPermissionDeniedAsync())) {\n throw new NoPermissionException();\n }\n try {\n // Internet Explorer\n // @ts-ignore\n return window.clipboardData.getData('Text');\n }\n catch {\n return Promise.reject(new Error('Unable to retrieve item from clipboard'));\n }\n }\n },\n // TODO: (barthap) The `setString` was deprecated in SDK 45. Remove this function in a few SDK cycles.\n setString(text) {\n const textField = document.createElement('textarea');\n textField.textContent = text;\n document.body.appendChild(textField);\n textField.select();\n try {\n document.execCommand('copy');\n return true;\n }\n catch {\n return false;\n }\n finally {\n document.body.removeChild(textField);\n }\n },\n async setStringAsync(text, options) {\n switch (options.inputFormat) {\n case StringFormat.HTML: {\n if (!navigator.clipboard) {\n throw new ClipboardUnavailableException();\n }\n try {\n const clipboardItemInput = createHtmlClipboardItem(text);\n await navigator.clipboard.write([clipboardItemInput]);\n return true;\n }\n catch (e) {\n // it might fail, because user denied permission\n if (e.name === 'NotAllowedError' || (await isClipboardPermissionDeniedAsync())) {\n throw new NoPermissionException();\n }\n throw new CopyFailureException(e.message);\n }\n }\n default: {\n try {\n if (!navigator.clipboard) {\n throw new Error();\n }\n await navigator.clipboard.writeText(text);\n return true;\n }\n catch {\n // we can fall back to legacy behavior in any kind of failure\n // including navigator.clipboard unavailability\n return this.setString(text);\n }\n }\n }\n },\n async hasStringAsync() {\n return await clipboardHasTypesAsync(['text/plain', 'text/html']);\n },\n async getImageAsync(_options) {\n if (!navigator.clipboard) {\n throw new ClipboardUnavailableException();\n }\n try {\n const clipboardItems = await navigator.clipboard.read();\n const blob = await findImageInClipboardAsync(clipboardItems);\n if (!blob) {\n return null;\n }\n const [data, size] = await Promise.all([\n blobToBase64Async(blob),\n getImageSizeFromBlobAsync(blob),\n ]);\n return { data, size };\n }\n catch (e) {\n // it might fail, because user denied permission\n if (e.name === 'NotAllowedError' || (await isClipboardPermissionDeniedAsync())) {\n throw new NoPermissionException();\n }\n throw new PasteFailureException(e.message);\n }\n },\n async setImageAsync(base64image) {\n if (!navigator.clipboard) {\n throw new ClipboardUnavailableException();\n }\n try {\n // we set it always to `image/png` because it's the only format supported by the clipboard\n // but it seems to work even when provided jpeg data\n const blob = base64toBlob(base64image, 'image/png');\n await navigator.clipboard.write([\n new ClipboardItem({\n [blob.type]: blob,\n }),\n ]);\n }\n catch (err) {\n throw new CopyFailureException(err.message);\n }\n },\n async hasImageAsync() {\n return await clipboardHasTypesAsync(['image/png', 'image/jpeg']);\n },\n addClipboardListener() { },\n removeClipboardListener() { },\n};\n/**\n * Resolves to true if clipboard has one of provided {@link types}.\n * @throws `ClipboardUnavailableException` if AsyncClipboard API is not available\n * @throws `NoPermissionException` if user denied permission\n */\nasync function clipboardHasTypesAsync(types) {\n if (!navigator.clipboard) {\n throw new ClipboardUnavailableException();\n }\n try {\n const clipboardItems = await navigator.clipboard.read();\n return clipboardItems.flatMap((item) => item.types).some((type) => types.includes(type));\n }\n catch (e) {\n // it might fail, because user denied permission\n if (e.name === 'NotAllowedError' || (await isClipboardPermissionDeniedAsync())) {\n throw new NoPermissionException();\n }\n throw e;\n }\n}\nfunction createHtmlClipboardItem(htmlString) {\n return new ClipboardItem({\n // @ts-ignore `Blob` from `lib.dom.d.ts` and the one from `@types/react-native` differ\n 'text/html': new Blob([htmlString], { type: 'text/html' }),\n // @ts-ignore `Blob` from `lib.dom.d.ts` and the one from `@types/react-native` differ\n 'text/plain': new Blob([htmlToPlainText(htmlString)], { type: 'text/plain' }),\n });\n}\n//# sourceMappingURL=ClipboardModule.js.map","import { CodedError } from 'expo-modules-core';\nexport class ClipboardUnavailableException extends CodedError {\n constructor() {\n super('ERR_CLIPBOARD_UNAVAILABLE', \"The 'AsyncClipboard' API is not available on this browser\");\n }\n}\nexport class CopyFailureException extends CodedError {\n constructor(cause) {\n super('ERR_COPY_FAILURE', `Failed to copy to clipboard: ${cause}`);\n }\n}\nexport class PasteFailureException extends CodedError {\n constructor(cause) {\n super('ERR_COPY_FAILURE', `Failed to paste from clipboard: ${cause}`);\n }\n}\nexport class NoPermissionException extends CodedError {\n constructor() {\n super('ERR_NO_PERMISSION', 'User denied permission to access clipboard');\n }\n}\n//# sourceMappingURL=Exceptions.js.map","/**\n * Converts base64-encoded data to a `Blob` object.\n * @see https://stackoverflow.com/a/20151856\n */\nexport function base64toBlob(base64Data, contentType) {\n contentType = contentType || '';\n const sliceSize = 1024;\n const byteCharacters = atob(base64Data);\n const bytesLength = byteCharacters.length;\n const slicesCount = Math.ceil(bytesLength / sliceSize);\n const byteArrays = new Array(slicesCount);\n for (let sliceIndex = 0; sliceIndex < slicesCount; ++sliceIndex) {\n const begin = sliceIndex * sliceSize;\n const end = Math.min(begin + sliceSize, bytesLength);\n const bytes = new Array(end - begin);\n for (let offset = begin, i = 0; offset < end; ++i, ++offset) {\n bytes[i] = byteCharacters[offset].charCodeAt(0);\n }\n byteArrays[sliceIndex] = new Uint8Array(bytes);\n }\n // I cannot use `@ts-expect-error` here because some environments consider this correct:\n // expo-module build - OK,\n // expo-module test - error\n // @ts-ignore `Blob` from `lib.dom.d.ts` and the one from `@types/react-native` differ somehow\n return new Blob(byteArrays, { type: contentType });\n}\n/**\n * Converts blob to base64-encoded string with Data-URL prefix.\n */\nexport function blobToBase64Async(blob) {\n return new Promise((resolve, _) => {\n const reader = new FileReader();\n reader.onloadend = () => resolve(reader.result);\n reader.readAsDataURL(blob);\n });\n}\nexport function htmlToPlainText(html) {\n const tempDivElement = document.createElement('div');\n tempDivElement.innerHTML = html;\n return tempDivElement.textContent || tempDivElement.innerText || '';\n}\nexport function getImageSizeFromBlobAsync(blob) {\n return new Promise((resolve, _) => {\n const blobUrl = URL.createObjectURL(blob);\n const img = document.createElement('img');\n img.src = blobUrl;\n img.onload = function () {\n resolve({ width: img.width, height: img.height });\n };\n });\n}\nexport async function findImageInClipboardAsync(items) {\n for (const clipboardItem of items) {\n // first look for png\n if (clipboardItem.types.some((type) => type === 'image/png')) {\n return await clipboardItem.getType('image/png');\n }\n // alternatively, an image might be a jpeg\n // NOTE: Currently, this is not supported by browsers yet. They only support PNG now\n if (clipboardItem.types.some((type) => type === 'image/jpeg')) {\n return await clipboardItem.getType('image/jpeg');\n }\n }\n return null;\n}\nexport async function findHtmlInClipboardAsync(items) {\n for (const clipboardItem of items) {\n if (clipboardItem.types.some((type) => type === 'text/html')) {\n return await clipboardItem.getType('text/html');\n }\n }\n return null;\n}\nexport async function isClipboardPermissionDeniedAsync() {\n const queryOpts = { name: 'clipboard-read' };\n const permissionStatus = await navigator.permissions.query(queryOpts);\n return permissionStatus.state === 'denied';\n}\n//# sourceMappingURL=Utils.js.map","/**\n * Type used to define what type of data is stored in the clipboard.\n */\nexport var ContentType;\n(function (ContentType) {\n ContentType[\"PLAIN_TEXT\"] = \"plain-text\";\n ContentType[\"HTML\"] = \"html\";\n ContentType[\"IMAGE\"] = \"image\";\n /**\n * @platform iOS\n */\n ContentType[\"URL\"] = \"url\";\n})(ContentType || (ContentType = {}));\n/**\n * Type used to determine string format stored in the clipboard.\n */\nexport var StringFormat;\n(function (StringFormat) {\n StringFormat[\"PLAIN_TEXT\"] = \"plainText\";\n StringFormat[\"HTML\"] = \"html\";\n})(StringFormat || (StringFormat = {}));\n//# sourceMappingURL=Clipboard.types.js.map","import {theme} from \"../../theme/theme\";\nimport {Avatar} from \"react-native-paper\";\nimport React from \"react\";\nimport {cleanMediaUrl} from \"@data/constants/apiConstants\";\nimport {avatarColors} from \"@data/constants/studentsConstants\";\nimport {hasRole} from \"@data/utility/ability\";\nimport {View} from \"react-native\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport bowTie0 from \"../../../../assets/icons/bow-tie/bow-tie-0.png\";\nimport bowTie1 from \"../../../../assets/icons/bow-tie/bow-tie-1.png\";\nimport bowTie2 from \"../../../../assets/icons/bow-tie/bow-tie-2.png\";\nimport bowTie3 from \"../../../../assets/icons/bow-tie/bow-tie-3.png\";\nimport bowTie4 from \"../../../../assets/icons/bow-tie/bow-tie-4.png\";\nimport prof from \"../../../../assets/icons/menus-new/prof-gris.png\";\n\nconst championTies = {\n \"zoe\": bowTie1,\n \"abou\": bowTie2,\n \"sam\": bowTie3,\n \"tina\": bowTie4\n}\n\nexport const championForTutorSkillSetId = (skillSetId) => {\n return {\n 101: \"zoe\",\n 102: \"abou\",\n 103: \"sam\",\n 104: \"tina\"\n }?.[skillSetId]\n}\n\nexport const championBowTieForTutorSkillSetId = (skillSetId) => {\n const champion = championForTutorSkillSetId(skillSetId) ?? \"zoe\"\n return championTies[champion]\n}\nexport const championColorForTutorSkillSetId = (skillSetId) => {\n const champion = championForTutorSkillSetId(skillSetId) ?? \"zoe\"\n return theme.colors[champion]\n}\nexport const championLightColorForTutorSkillSetId = (skillSetId) => {\n const champion = championForTutorSkillSetId(skillSetId) ?? \"zoe\"\n return theme.colors[champion + \"Light\"]\n}\n\n\nconst AvatarM = ({size = 40, user, style, onboardingMode = false}) => {\n\n const borderWidth = size > 80 ? 6 : size > 60 ? 4 : 3\n\n const isTutor = hasRole(user, \"tutor\") || user?.is_tutor\n\n const tutorAvatarStyle = isTutor ? {\n borderColor: onboardingMode ? theme.colors.link : championColorForTutorSkillSetId(user?.title_skill_set_id),\n borderWidth\n } : {}\n\n return \n {!user?.avatar && isTutor\n ? \n : user?.avatar\n ? \n : }\n {isTutor && }\n {isTutor && }\n \n\n}\n\nexport default AvatarM","import {theme} from \"@common/theme/theme\";\n\nexport const studentsConstants = {\n CHANGE_LIST_SURVEY: 'CHANGE_LIST_SURVEY'\n}\n\nexport const avatarColors = [\n theme.colors.lightMore,\n theme.colors.purpleLight,\n theme.colors.primaryLighter,\n theme.colors.accentLighter,\n theme.colors.warningLight,\n theme.colors.linkLighter,\n theme.colors.successLight,\n theme.colors.gemsLight,\n]\n\n","import React from \"react\"\nimport {rolesAbilities} from \"@data/utility/initialAbility\";\n\nexport const hasRole = (user, role) => {\n return user?.roles?.includes(role)\n}\n\nexport const abilitiesForRoles = (roles) => {\n let abilities = []\n\n if (roles) {\n roles.forEach(item => {\n abilities = abilities.concat(rolesAbilities[item])\n })\n }\n abilities = abilities.concat(rolesAbilities[\"any\"])\n// console.log(`abilities : ${JSON.stringify(abilities)}`)\n return abilities\n}\n\nexport const offersNames = {\n \"basic\": \"Basic\",\n \"plus\": \"Plus\",\n \"premium\": \"Premium\",\n \"initial\": \"Initiale\",\n \"essential\": \"Essentielle\",\n \"integral\": \"Intégrale\",\n \"holidaycourse\": \"Stage\"\n}\n\n\nexport const getPrivilegedRole = (user) => {\n\n const products = [\"plus\", \"premium\", 'initial', \"essential\", \"integral\"]\n\n for(let i = 0; i< products?.length; i++){\n if (hasRole(user, products?.[i]+\"-student\")) {\n return products?.[i]\n }\n }\n\n return \"basic\"\n}\n\n\nexport const isOnTrial = (user) => {\n return (user?.subscription_state?.status === \"on_generic_trial\") || (user?.subscription_state?.status === \"on_trial\")\n}\n\n// export default new Ability(existingAbility || initialAbility)\n// export default new Ability(abilitiesForRoles(currentRoles) || initialAbility)\n","// ** Initial user ability\n\nexport const initialAbility = [\n\n {\n action: 'read',\n subject: 'Auth'\n }\n]\n\nexport const rolesAbilities = {\n\n 'super-admin': [\n {\n action: 'read',\n subject: 'backOffice'\n },\n {\n action: 'read',\n subject: 'interviews'\n },\n {\n action: 'read',\n subject: 'analytics'\n },\n {\n action: 'read',\n subject: 'manage_referrals'\n },\n ],\n admin: [\n {\n action: 'read',\n subject: 'backOffice'\n },\n {\n action: 'read',\n subject: 'interviews'\n },\n {\n action: 'read',\n subject: 'analytics'\n },\n {\n action: 'read',\n subject: 'manage_referrals'\n },\n ],\n \"referral-admin\": [\n {\n action: 'read',\n subject: 'manage_referrals'\n },\n ],\n reviewer: [\n {\n action: 'read',\n subject: 'review_activities'\n }\n ],\n 'school-admin': [\n {\n action: 'read',\n subject: 'schools'\n }\n ],\n student: [\n {\n action: 'read',\n subject: 'my_activities'\n },\n {\n action: 'read',\n subject: 'tutor_name'\n },\n {\n action: 'read',\n subject: 'survey_statistics'\n },\n {\n action: 'read',\n subject: 'student_survey'\n },\n {\n action: 'read',\n subject: 'my_student_profile_completion'\n },\n {\n action: 'read',\n subject: 'my_student_profile_update'\n },\n {\n action: 'read',\n subject: 'subscribe'\n },\n {\n action: 'read',\n subject: 'my_subscription'\n },\n {\n action: 'read',\n subject: 'my_successes'\n },\n {\n action: 'read',\n subject: 'my_friends'\n },\n {\n action: 'read',\n subject: 'realize_activity'\n }\n ],\n 'integral-student': [\n {\n action: 'read',\n subject: 'have_tutor'\n },\n {\n action: 'read',\n subject: 'have_many_challenges'\n },\n {\n action: 'read',\n subject: 'premium_icon'\n },\n {\n action: 'read',\n subject: 'request_activity_review'\n },\n ],\n 'essential-student': [\n {\n action: 'read',\n subject: 'have_tutor'\n },\n {\n action: 'read',\n subject: 'have_many_challenges'\n },\n {\n action: 'read',\n subject: 'plus_icon'\n },\n {\n action: 'read',\n subject: 'request_activity_review'\n }\n\n ],\n 'initial-student': [\n {\n action: 'read',\n subject: 'have_tutor'\n },\n {\n action: 'read',\n subject: 'have_many_challenges'\n },\n {\n action: 'read',\n subject: 'initial_icon'\n },\n {\n action: 'read',\n subject: 'request_activity_review'\n }\n\n ],\n 'holidaycourse-student': [\n {\n action: 'read',\n subject: 'have_tutor'\n },\n {\n action: 'read',\n subject: 'have_many_challenges'\n },\n {\n action: 'read',\n subject: 'plus_icon'\n },\n {\n action: 'read',\n subject: 'request_activity_review'\n },\n {\n action: 'read',\n subject: 'holiday_course_views'\n }\n ],\n 'premium-student': [\n {\n action: 'read',\n subject: 'have_tutor'\n },\n {\n action: 'read',\n subject: 'have_many_challenges'\n },\n {\n action: 'read',\n subject: 'premium_icon'\n },\n {\n action: 'read',\n subject: 'request_activity_review'\n },\n {\n action: 'read',\n subject: 'my_interviews'\n },\n\n ],\n 'plus-student': [\n {\n action: 'read',\n subject: 'have_many_challenges'\n },\n {\n action: 'read',\n subject: 'plus_icon'\n },\n {\n action: 'read',\n subject: 'request_activity_review'\n }\n\n ],\n parent: [],\n teacher: [\n {\n action: 'read',\n subject: 'my_teacher_classrooms'\n },\n {\n action: 'read',\n subject: 'classroom'\n }\n ],\n \"tutor-candidate\": [\n {\n action: 'read',\n subject: 'my_tutor_profile_completion'\n },\n {\n action: 'read',\n subject: 'my_tutor_slot_completion'\n },\n // {\n // action: 'read',\n // subject: 'my_students'\n // },\n // {\n // action: 'read',\n // subject: 'my_tutor_profile_update'\n // }\n ],\n tutor: [\n {\n action: 'read',\n subject: 'my_tutor_profile_completion'\n },\n {\n action: 'read',\n subject: 'my_tutor_slot_completion'\n },\n {\n action: 'read',\n subject: 'my_tutor_profile_update'\n },\n {\n action: 'read',\n subject: 'my_students'\n },\n {\n action: 'read',\n subject: 'my_slot'\n },\n {\n action: 'read',\n subject: 'student_details'\n },\n {\n action: 'read',\n subject: 'interviews'\n },\n {\n action: 'read',\n subject: 'tutor_resources'\n },\n {\n action: 'write',\n subject: 'interviews'\n },\n {\n action: 'assign',\n subject: 'activities'\n }\n ],\n any: [\n {\n action: 'read',\n subject: 'dashboard'\n },\n {\n action: 'read',\n subject: 'account'\n },\n {\n action: 'read',\n subject: 'email_verify'\n },\n {\n action: 'read',\n subject: 'logout'\n }\n ]\n}\n","","","","","","","import React from 'react';\nimport {Title} from \"react-native-paper\";\nimport {theme} from \"../../theme/theme\";\n\nconst TitleM = (props) => {\n\n const {text, fontWeight, color} = props\n\n return \n {props.children}\n \n}\n\nexport default TitleM","import React, { useContext, useEffect } from \"react\"\nimport { ActivityIndicator, Text, TextInput, TouchableRipple } from \"react-native-paper\"\nimport { theme } from \"../../theme/theme\"\nimport { useController } from \"react-hook-form\"\nimport { Platform, View } from \"react-native\"\nimport TextM from \"../text/TextM\"\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\"\nimport ErrorTextM from \"../text/ErrorTextM\"\nimport { useDispatch, useSelector } from \"react-redux\"\nimport { apiIdle, apiRequest, apiRequestWithPrerequest } from \"@data/redux/actions/api\"\nimport { DimensionsContext } from \"../../utils/mobileUtils\"\n\nconst TextInputM = React.forwardRef((props, ref) => {\n\n const {\n password,\n control,\n name,\n errors,\n style,\n labelTop,\n right,\n suggestions,\n onChangeAdditional = () => {\n },\n contentContainerStyle,\n liveCheck,\n liveCheckUrlParams = {},\n liveCheckPreRequest = false,\n searchMode = false,\n disabled = false,\n hidden = false,\n decimalOnly = false,\n } = props\n\n const { field } = useController({\n control,\n name,\n })\n\n const request = liveCheck?.service ? (useSelector((state) => state.api[liveCheck?.service?.name]?.request) ?? false) : null\n const success = liveCheck?.service ? useSelector((state) => state.api[liveCheck?.service?.name]?.success) : null\n const error = liveCheck?.service ? useSelector((state) => state.api[liveCheck?.service?.name]?.error) : null\n const successData = liveCheck?.service ? useSelector((state) => state.api[liveCheck?.service?.name]?.data) : null\n const dispatch = useDispatch()\n\n\n useEffect(() => {\n if (success && !!liveCheck?.successCallback) {\n liveCheck?.successCallback(successData)\n }\n if (error && !!liveCheck?.errorCallback) {\n liveCheck?.errorCallback(error)\n }\n\n }, [success, error])\n\n useEffect(() => {\n const delayDebounceFn = liveCheck?.service ? setTimeout(() => {\n\n const apiRequestFonction = liveCheckPreRequest ? apiRequestWithPrerequest : apiRequest\n // console.log(fieldPromoCode?.value)\n if (field?.value !== \"\")\n dispatch(apiRequestFonction(liveCheck?.service, {}, {\n ...liveCheckUrlParams,\n [name]: field?.value,\n }, { ...liveCheckUrlParams, [name]: field?.value }))\n else {\n dispatch(apiIdle(liveCheck?.service))\n }\n }, 1000) : null\n\n return liveCheck?.service ? () => clearTimeout(delayDebounceFn) : undefined\n }, [field?.value])\n\n //for users searching (get users when field is empty)\n useEffect(() => {\n const apiRequestFonction = liveCheckPreRequest ? apiRequestWithPrerequest : apiRequest\n\n const delayDebounceFn = liveCheck?.service ? setTimeout(() => {\n // console.log(fieldPromoCode?.value)\n if (searchMode && field?.value === \"\")\n dispatch(apiRequestFonction(liveCheck?.service))\n }, 1000) : null\n\n return liveCheck?.service ? () => clearTimeout(delayDebounceFn) : undefined\n }, [field?.value])\n\n const [secure, setSecure] = React.useState(true)\n\n const dimensions = useContext(DimensionsContext)\n return \n\n {suggestions?.map((c, index) => {\n return {\n field?.onChange(field.value + c)\n }}>\n {c}\n \n })}\n\n {labelTop && {labelTop}}\n {!hidden && \n {\n const val = decimalOnly ? value.replace(/[^0-9.]/g, \"\") : value\n field?.onChange(val)\n onChangeAdditional(val)\n }}\n secureTextEntry={password && secure}\n right={right ?? (password && theme.colors.primary}\n style={{\n color: theme.colors.primary,\n }}\n icon={secure ? \"eye\" : \"eye-slash\"}\n onPress={() => {\n setSecure(!secure)\n }} />)}\n error={errors && errors[name]}\n />\n {!!liveCheck?.service && <>\n \n {request\n ? \n : success\n ? \n : error\n ? \n : null}\n \n {error\n ? \n : (success && !!liveCheck?.successMessage)\n ? {liveCheck?.successMessage}\n : null}\n }\n }\n\n {errors && errors[name] && {errors[name].message}}\n \n },\n)\n\nexport default TextInputM","import React from 'react';\nimport {Text} from \"react-native-paper\";\nimport {theme} from \"../../theme/theme\";\nimport {StyleSheet} from \"react-native\";\n\nconst ErrorTextM = (props) => {\n\n const {fontWeight, errorData, style, marginTop = 10} = props\n const styles = StyleSheet.create({\n error: {\n color: theme.colors.error,\n fontFamily: \"Montserrat-\" + (fontWeight ?? \"Regular\"),\n // height: 30,\n marginTop: marginTop\n }\n });\n\n // console.log(errorData)\n\n return <>\n {(errorData && errorData?.errors) ?\n Object.keys(errorData?.errors)?.map(key => {errorData?.errors[key][0]}) :\n (errorData && errorData?.message) ? \n {errorData?.message ? errorData?.message : \"\"}\n : null\n }\n \n}\n\nexport default ErrorTextM","import React from 'react';\nimport {Text} from \"react-native-paper\";\nimport withPreventDoubleClick from \"../../utils/withPreventDoubleClick\";\n//import Pressable from \"react-native/Libraries/Components/Pressable/Pressable\";\nimport { Pressable } from 'react-native';\nimport {theme} from \"../../theme/theme\";\nimport * as amplitude from \"@amplitude/analytics-react-native\";\n\nconst TextButtonM = (props) => {\n\n const {label, fontWeight, style, onPress, color, numberOfLines, trackingId, disabled} = props\n\n return {\n if (trackingId) {\n amplitude.track(\"textbutton.clicked.\" + trackingId)\n }\n onPress(e)\n }}\n disabled={disabled}\n children={({pressed}) => (\n \n {label}\n \n )}/>\n}\n\nexport default withPreventDoubleClick(TextButtonM)","import React, {forwardRef, useCallback, useState} from \"react\";\nimport {useDispatch, useSelector} from \"react-redux\";\nimport {apiRequest} from \"@data/redux/actions/api\";\nimport {useFocusEffect} from \"@react-navigation/native\";\nimport {PaginatedFlatListContent} from \"@common/screens/PaginatedFlatListContent\";\n\nexport const PaginatedFlatList = forwardRef((props, ref) => {\n\n const {\n data,\n ListHeaderComponent,\n renderItem,\n style,\n additionalOnRefresh,\n additionalRefreshing = false,\n requestApiService,\n requestRouteParams,\n requestUrlParams,\n requestData,\n contentContainerStyle,\n tooManyColumns = false,\n ListEmptyComponent,\n noRefreshWhenNoResults = false,\n noActivityIndicator = false,\n stickyHeader = false\n } = props\n\n const [currentPage, setCurrentPage] = useState(1)\n const [lastPage, setLastPage] = useState(0)\n const [totalCount, setTotalCount] = useState(-1)\n\n const resetCounters = () => {\n setCurrentPage(1)\n setLastPage(0)\n // setTotalCount(0)\n }\n\n const request = useSelector((state) => state.api[requestApiService?.name]?.request) ?? false\n const refreshing = additionalRefreshing || request\n const dispatch = useDispatch();\n\n const refresh = () => {\n // console.log(\"REFRESH\")\n\n dispatch(apiRequest(requestApiService, requestRouteParams ?? {}, requestData ?? {}, {\n ...requestUrlParams,\n page: 1\n }))\n additionalOnRefresh()\n resetCounters()\n }\n\n useFocusEffect(\n useCallback(() => {\n // console.log(\"callback\")\n if (!refreshing && (totalCount > 0 && data?.length === 0) && !noRefreshWhenNoResults) {\n // console.log(\"FOCUS CALLBACK\")\n // console.log(\"totalCount\", totalCount)\n // console.log(\"data?.length\", data?.length)\n refresh()\n\n }\n return () => {\n }\n }, [data])\n );\n\n\n return \n})","import React, {forwardRef, useContext, useEffect} from \"react\";\nimport {useDispatch, useSelector} from \"react-redux\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {Dimensions, FlatList, ScrollView, View} from \"react-native\";\nimport {DimensionsContext, IS_WEB} from \"../utils/mobileUtils\";\nimport {theme} from \"../theme/theme\";\nimport {ActivityIndicator} from \"react-native-paper\";\nimport TextM from \"../components/text/TextM\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\n\nexport const PaginatedFlatListContent = forwardRef((props, ref) => {\n\n const {\n data,\n ListHeaderComponent = <>,\n renderItem,\n style,\n additionalOnRefresh,\n additionalRefreshing = false,\n requestApiService,\n requestRouteParams,\n requestUrlParams,\n requestData,\n contentContainerStyle,\n tooManyColumns = false,\n ListEmptyComponent,\n noRefreshWhenNoResults = false,\n noActivityIndicator = false,\n totalCount,\n setTotalCount,\n currentPage,\n setCurrentPage,\n lastPage,\n setLastPage,\n refresh,\n refreshing,\n stickyHeader = false\n } = props\n\n useEffect(() => {\n if (totalCount !== -1 && noRefreshWhenNoResults) {\n // console.log(\"SEARCH CHANGE\")\n refresh()\n }\n }, [requestUrlParams])\n\n useEffect(() => {\n if (totalCount !== -1) {\n // console.log(\"SEARCH CHANGE\")\n refresh()\n }\n }, [requestUrlParams?.search])\n const renderList = () => {\n return <>\n {!noActivityIndicator && IS_WEB && refreshing && (currentPage === 1) &&\n }\n <>\n {renderHeader()}\n {ListEmptyComponent ? ListEmptyComponent : totalCount === 0 && !refreshing && data?.length === 0 &&\n Aucun élément}\n }\n ListFooterComponent={renderFooter}\n keyExtractor={(item, index) => index.toString()}\n onEndReachedThreshold={0.2}\n onEndReached={() => {\n // console.log(\"END REACHED\")\n loadMore()\n }}\n renderItem={renderItem}/>\n \n }\n\n const success = useSelector((state) => state.api[requestApiService?.name]?.success)\n const error = useSelector((state) => state.api[requestApiService?.name]?.error)\n const successData = useSelector((state) => state.api[requestApiService?.name]?.data)\n const dispatch = useDispatch();\n\n\n const loadMore = () => {\n if (!refreshing && currentPage < lastPage && data?.length > 0) {\n // console.log(\"current page before request\", currentPage)\n dispatch(apiRequest(requestApiService, requestRouteParams ?? {}, requestData ?? {}, {\n ...requestUrlParams,\n page: currentPage + 1\n }))\n setCurrentPage(p => p + 1)\n }\n }\n\n useEffect(() => {\n // console.log(\"load\")\n if (!refreshing)\n refresh()\n }, []);\n\n\n useEffect(() => {\n //console.log(\"data_returned\")\n if (success) {\n dispatch(apiIdle(requestApiService))\n // console.log(successData?.meta)\n setCurrentPage(successData?.meta?.current_page)\n setLastPage(successData?.meta?.last_page)\n setTotalCount(successData?.meta?.total)\n }\n if (error) {\n console.log(error)\n let errorMessages = []\n if (error?.errors) {\n errorMessages = Object.keys(error?.errors)?.map(key => error?.errors[key][0])\n }\n DialogM.show({\n text1: 'Erreur',\n text2: error?.message + (errorMessages ? \"\\n\" + errorMessages.join(\"\\n\") : \"\")\n })\n //alertPolyfill('Erreur', serviceApiSelector?.error?.message)\n dispatch(apiIdle(requestApiService))\n }\n }, [success, error]);\n const dimensions = useContext(DimensionsContext)\n\n const renderFooter = () => {\n //it will show indicator at the bottom of the list when data is loading otherwise it returns null\n return \n {(refreshing && currentPage > 1) && }\n\n \n {data?.length > 0 && totalCount > 0 &&\n {data?.length} / {totalCount}}\n \n\n \n\n };\n\n const renderHeader = () => {\n return (ListHeaderComponent)\n }\n\n\n return <>\n {tooManyColumns ?\n \n \n {renderList()}\n \n :\n renderList()\n\n\n }\n \n})","import React, {useEffect, useState} from 'react';\nimport {TouchableOpacity, View} from \"react-native\";\nimport {DatePickerModal, TimePickerModal} from \"react-native-paper-dates\";\nimport moment from \"moment\";\nimport {theme} from \"@common/theme/theme\";\nimport TextM from \"@common/components/text/TextM\";\nimport {SafeAreaProvider} from \"react-native-safe-area-context\";\nimport SelectDayModal from \"./live/rooms/SelectDayModal\";\nimport {daysOptions} from \"@data/constants/formConstants\";\n\nconst DayTimeItem = ({\n onPress = () => {\n }, label,\n disabled = false\n }) => \n \n \n {label ?? \" \"}\n \n \n\nconst DateTimePicker = (props) => {\n const {control, setFormValues, field, type, range = undefined} = props\n const [isTimePickerVisible, setTimePickerVisibility] = useState(false);\n const [isDatePickerVisible, setDatePickerVisibility] = useState(false);\n\n const [date, setDate] = useState(field?.value ? type === \"day-time\" ? new Date(field?.value?.day + \" \" + field?.value?.time) : new Date(field?.value) : null);\n const [dateLabel, setDateLabel] = useState(type === \"day-time\" || type === \"time\" ? null : moment(field.value, 'DD-MM-YYYY HH:mm').isValid() ? moment(field?.value?.split(\" \")?.[0]).format(\"DD-MM-YYYY\") : \"Date\");\n const [timeLabel, setTimeLabel] = useState(field?.value?.split(\" \")?.[1] ?? \"Heure\");\n const [dayLabel, setDayLabel] = useState(daysOptions?.find(d => d.value === field?.value?.split(\" \")?.[0])?.label ?? \"Jour\");\n const [dayValue, setDayValue] = useState(field?.value?.split(\" \")?.[0] ?? null);\n\n useEffect(() => {\n\n if (field?.value) {\n if (type === \"day-time\") {\n const day = daysOptions?.find(d => d.value === field?.value?.split(\" \")?.[0])?.label\n setDayLabel(day)\n setDayValue(field?.value?.split(\" \")?.[0])\n setTimeLabel(field?.value?.split(\" \")?.[1])\n } else if (type === \"time\") {\n setTimeLabel(field?.value)\n } else if (type === \"date-time\") {\n const dd = new moment(field?.value?.split(\" \")?.[0]).format(\"YYYY-MM-DD\")\n const dl = new moment(field?.value?.split(\" \")?.[0]).format(\"DD-MM-YYYY\")\n setDate(new Date(dd))\n setDateLabel(dl)\n setTimeLabel(field?.value?.split(\" \")?.[1])\n } else {\n const dd = new moment(field?.value?.split(\" \")?.[0]).format(\"YYYY-MM-DD\")\n const dl = new moment(field?.value?.split(\" \")?.[0]).format(\"DD-MM-YYYY\")\n setDate(new Date(dd))\n setDateLabel(dl)\n }\n }\n\n }, [field.value]);\n\n\n const showDatePicker = () => {\n setDatePickerVisibility(true);\n };\n const hideDatePicker = () => {\n setDatePickerVisibility(false);\n };\n const showTimePicker = () => {\n setTimePickerVisibility(true);\n };\n const hideTimePicker = () => {\n setTimePickerVisibility(false);\n };\n const [visibleModal, setVisibleModal] = useState(false)\n const handleShowModal = () => {\n setVisibleModal(!visibleModal)\n }\n\n const onConfirmDay = (day, index, valueDay) => {\n setDayLabel(day)\n setDayValue(valueDay)\n field.onChange(valueDay + \" \" + timeLabel)\n setFormValues({\n ...control._formValues,\n [field?.name]: valueDay + \" \" + timeLabel\n })\n }\n\n useEffect(() => {\n if (field.value && !moment(field.value, 'DD-MM-YYYY HH:mm').isValid() && type === \"date-time\") {\n setDate(new Date())\n }\n }, []);\n\n return <>\n \n \n \n {(type === \"day-time\") &&\n handleShowModal()} label={dayLabel} disabled={props.disabled}/>}\n {(type === \"date\" || type === \"date-time\") &&\n showDatePicker()} label={dateLabel} disabled={props.disabled}/>}\n {(type === \"time\" || type === \"date-time\" || type === \"day-time\") &&\n showTimePicker()} label={timeLabel} disabled={props.disabled}/>}\n \n \n {(type === \"time\" || type === \"date-time\" || type === \"day-time\") &&\n {\n const hours = e.hours?.toString().length > 1 ? e.hours : \"0\" + e.hours\n const minutes = e.minutes?.toString().length > 1 ? e.minutes : \"0\" + e.minutes\n const time = hours + \":\" + minutes\n const dd = new moment(date).format(\"YYYY-MM-DD\")\n\n // console.log(\"dd\", date.date)\n // console.log(\"dd\", dd)\n\n setTimeLabel(time)\n hideTimePicker()\n field.onChange(type === \"time\" ? time : type === \"day-time\" ? (dayValue) + \" \" + time : dd + \" \" + time)\n setFormValues({\n ...control._formValues,\n [field?.name]: type === \"time\" ? time : type === \"day-time\" ? dayValue + \" \" + time : dd + \" \" + time\n })\n }}\n />}\n {(type === \"date\" || type === \"date-time\") && {\n // console.log(\"date.date\", e.date)\n hideDatePicker()\n const dd = new moment(e.date).format(\"YYYY-MM-DD\")\n const dl = new moment(e.date).format(\"DD-MM-YYYY\")\n setDate(new Date(dd))\n setDateLabel(dl)\n field.onChange(type === \"date\" ? dd : dd + \" \" + timeLabel)\n setFormValues({\n ...control._formValues,\n [field?.name]: type === \"date\" ? dd : dd + \" \" + timeLabel\n })\n }}\n />}\n \n \n \n};\n\nexport default DateTimePicker;","\"use strict\";\n\nexport { default as Calendar } from './Date/Calendar';\nexport { default as DatePickerModal } from './Date/DatePickerModal';\nexport * from './Date/DatePickerModal';\nexport { default as DatePickerModalContent } from './Date/DatePickerModalContent';\nexport { default as TimePickerModal } from './Time/TimePickerModal';\nexport { default as TimePicker } from './Time/TimePicker';\nexport { default as DatePickerInput } from './Date/DatePickerInput';\nexport { registerTranslation, getTranslation } from './translations/utils';\nexport { default as ar } from './translations/ar';\nexport { default as ca } from './translations/ca';\nexport { default as de } from './translations/de';\nexport { default as en } from './translations/en';\nexport { default as enGB } from './translations/enGB';\nexport { default as es } from './translations/es';\nexport { default as fr } from './translations/fr';\nexport { default as he } from './translations/he';\nexport { default as hi } from './translations/hi';\nexport { default as it } from './translations/it';\nexport { default as ko } from './translations/ko';\nexport { default as nl } from './translations/nl';\nexport { default as pl } from './translations/pl';\nexport { default as pt } from './translations/pt';\nexport { default as tr } from './translations/tr';\nexport { default as zh } from './translations/zh';\nexport { default as zhTW } from './translations/zhTW';\nexport { default as cs } from './translations/cs';\nexport { default as el } from './translations/el';\nexport { default as ru } from './translations/ru';\nexport { default as ro } from './translations/ro';\nexport { default as id } from './translations/id';\nexport { default as ja } from './translations/ja';\nexport { default as th } from './translations/th';\nexport { default as ukUA } from './translations/ukUA';\nexport { default as noNO } from './translations/noNO';\n//# sourceMappingURL=index.js.map","\"use strict\";\n\nimport { View } from 'react-native';\nimport Swiper from './Swiper';\nimport Month from './Month';\nimport { areDatesOnSameDay, dateToUnix, getEndOfDay, getInitialIndex } from './dateUtils';\nimport CalendarHeader from './CalendarHeader';\nimport { memo, useCallback, useMemo, useState } from 'react';\nimport YearPicker from './YearPicker';\nimport Color from 'color';\nimport { useTheme } from 'react-native-paper';\nimport { useLatest, lightenBy, darkenBy } from '../shared/utils';\nimport React from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction Calendar(props) {\n const {\n locale,\n mode,\n onChange,\n startDate,\n endDate,\n date,\n disableWeekDays,\n startYear,\n endYear,\n dates,\n validRange,\n dateMode,\n startWeekOnMonday\n } = props;\n const scrollMode = mode === 'range' || mode === 'multiple' ? 'vertical' : 'horizontal';\n const firstDate = startDate || date || dates?.[0];\n const theme = useTheme();\n const [selectedYear, setSelectedYear] = useState(undefined);\n const [selectingYear, setSelectingYear] = useState(false);\n\n // prevent re-rendering all months when something changed we only need the\n // latest version of the props and we don't want the useCallback to change\n const startDateRef = useLatest(startDate);\n const endDateRef = useLatest(endDate);\n const onChangeRef = useLatest(onChange);\n const datesRef = useLatest(dates);\n const onPressYear = useCallback(year => {\n setSelectedYear(year);\n setSelectingYear(prev => !prev);\n }, [setSelectingYear]);\n const onPressDate = useCallback(d => {\n if (mode === 'single') {\n ;\n onChangeRef.current({\n date: dateMode === 'start' ? d : getEndOfDay(d)\n });\n } else if (mode === 'range') {\n const sd = startDateRef.current;\n const ed = endDateRef.current;\n let isStart = true;\n if (sd && !ed && dateToUnix(d) >= dateToUnix(sd)) {\n isStart = false;\n }\n ;\n onChangeRef.current({\n startDate: isStart ? d : sd,\n endDate: !isStart ? getEndOfDay(d) : undefined\n });\n } else if (mode === 'multiple') {\n datesRef.current = datesRef.current || [];\n const exists = datesRef.current.some(ed => areDatesOnSameDay(ed, d));\n const newDates = exists ? datesRef.current.filter(ed => !areDatesOnSameDay(ed, d)) : [...datesRef.current, d];\n newDates.sort((a, b) => a.getTime() - b.getTime());\n onChangeRef.current({\n dates: newDates,\n datePressed: d,\n change: exists ? 'removed' : 'added'\n });\n }\n }, [mode, dateMode, onChangeRef, startDateRef, endDateRef, datesRef]);\n const selectColor = useMemo(() => {\n if (theme.isV3) {\n return theme.colors.primaryContainer;\n }\n if (theme.dark) {\n return darkenBy(Color(theme.colors.primary), 0.1).hex();\n }\n return lightenBy(Color(theme.colors.primary), 0.9).hex();\n }, [theme]);\n return /*#__PURE__*/_jsxs(View, {\n style: sharedStyles.root,\n children: [/*#__PURE__*/_jsx(Swiper, {\n initialIndex: getInitialIndex(firstDate),\n selectedYear: selectedYear,\n scrollMode: scrollMode,\n startWeekOnMonday: startWeekOnMonday || false,\n renderItem: ({\n index\n }) => /*#__PURE__*/_jsx(Month, {\n locale: locale,\n mode: mode,\n validRange: validRange,\n index: index,\n startDate: startDate,\n endDate: endDate,\n date: date,\n dates: dates,\n onPressYear: onPressYear,\n selectingYear: selectingYear,\n onPressDate: onPressDate,\n scrollMode: scrollMode,\n primaryColor: theme.colors.primary,\n selectColor: selectColor,\n roundness: theme.roundness,\n disableWeekDays: disableWeekDays,\n startWeekOnMonday: startWeekOnMonday || false\n }, index),\n renderHeader: ({\n onPrev,\n onNext\n }) => /*#__PURE__*/_jsx(CalendarHeader, {\n locale: locale,\n onPrev: onPrev,\n onNext: onNext,\n scrollMode: scrollMode,\n disableWeekDays: disableWeekDays,\n startWeekOnMonday: startWeekOnMonday || false\n })\n }), scrollMode === 'horizontal' ? /*#__PURE__*/_jsx(YearPicker, {\n selectedYear: selectedYear,\n selectingYear: selectingYear,\n onPressYear: onPressYear,\n startYear: startYear || 1800,\n endYear: endYear || 2200\n }) : null]\n });\n}\nexport default /*#__PURE__*/memo(Calendar);\n//# sourceMappingURL=Calendar.js.map","\"use strict\";\n\nimport { View } from 'react-native';\nimport { getIndexFromVerticalOffset, getMonthHeight, getVerticalMonthsOffset, montHeaderHeight } from './Month';\nimport { beginOffset, estimatedMonthHeight, totalMonths } from './dateUtils';\nimport { useLatest } from '../shared/utils';\nimport { useYearChange } from './SwiperUtils';\nimport AutoSizer from './AutoSizer';\nimport React, { memo, useCallback, useEffect, useLayoutEffect, useRef, useState } from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useIsomorphicLayoutEffect = typeof window !== 'undefined' ? useLayoutEffect : useEffect;\nfunction Swiper({\n scrollMode,\n renderItem,\n renderHeader,\n renderFooter,\n selectedYear,\n initialIndex,\n startWeekOnMonday\n}) {\n const isHorizontal = scrollMode === 'horizontal';\n const [index, setIndex] = useState(initialIndex);\n const onPrev = useCallback(() => {\n setIndex(prev => prev - 1);\n }, [setIndex]);\n const onNext = useCallback(() => {\n setIndex(prev => prev + 1);\n }, [setIndex]);\n const renderProps = {\n index,\n onPrev,\n onNext\n };\n const indexRef = useLatest(index);\n useYearChange(newIndex => {\n if (newIndex) {\n setIndex(newIndex);\n }\n }, {\n selectedYear,\n currentIndexRef: indexRef\n });\n return /*#__PURE__*/_jsxs(_Fragment, {\n children: [renderHeader && renderHeader(renderProps), isHorizontal ? /*#__PURE__*/_jsx(View, {\n style: sharedStyles.root,\n children: renderItem({\n index,\n onPrev,\n onNext\n })\n }) : /*#__PURE__*/_jsx(AutoSizer, {\n children: ({\n width,\n height\n }) => /*#__PURE__*/_jsx(VerticalScroller, {\n width: width,\n height: height,\n initialIndex: initialIndex,\n estimatedHeight: estimatedMonthHeight,\n renderItem: renderItem,\n startWeekOnMonday: startWeekOnMonday\n })\n }), renderFooter && renderFooter(renderProps)]\n });\n}\nconst visibleArray = i => [i - 2, i - 1, i, i + 1, i + 2];\nfunction VerticalScroller({\n width,\n height,\n initialIndex,\n estimatedHeight,\n renderItem,\n startWeekOnMonday\n}) {\n const [visibleIndexes, setVisibleIndexes] = useState(visibleArray(initialIndex));\n const idx = useRef(initialIndex);\n const parentRef = useRef(null);\n useIsomorphicLayoutEffect(() => {\n const element = parentRef.current;\n if (!element) {\n return;\n }\n const top = getVerticalMonthsOffset(idx.current, startWeekOnMonday) - montHeaderHeight;\n element.scrollTo({\n top\n });\n }, [parentRef, idx]);\n const setVisibleIndexesThrottled = useDebouncedCallback(setVisibleIndexes);\n const onScroll = useCallback(e => {\n const top = e.currentTarget?.scrollTop;\n if (top === 0) {\n return;\n }\n const offset = top - beginOffset;\n const index = getIndexFromVerticalOffset(offset, startWeekOnMonday);\n if (idx.current !== index) {\n idx.current = index;\n setVisibleIndexesThrottled(visibleArray(index));\n }\n }, [setVisibleIndexesThrottled, startWeekOnMonday]);\n return /*#__PURE__*/_jsx(\"div\", {\n ref: parentRef\n // eslint-disable-next-line react-native/no-inline-styles\n ,\n style: {\n height,\n width,\n overflow: 'auto'\n },\n onScroll: onScroll,\n children: /*#__PURE__*/_jsx(\"div\", {\n // eslint-disable-next-line react-native/no-inline-styles\n style: {\n height: estimatedHeight * totalMonths,\n position: 'relative'\n },\n children: [0, 1, 2, 3, 4].map(vi => /*#__PURE__*/_jsx(\"div\", {\n // eslint-disable-next-line react-native/no-inline-styles\n style: {\n willChange: 'transform',\n transform: `translateY(${getVerticalMonthsOffset(visibleIndexes[vi], startWeekOnMonday)}px)`,\n left: 0,\n right: 0,\n position: 'absolute',\n height: getMonthHeight('vertical', visibleIndexes[vi], startWeekOnMonday)\n },\n children: renderItem({\n index: visibleIndexes[vi],\n onPrev: empty,\n onNext: empty\n })\n }, vi))\n })\n });\n}\nconst empty = () => null;\nexport function useDebouncedCallback(callback) {\n const mounted = useRef(true);\n const timerId = useRef(null);\n const latest = useLatest(callback);\n useEffect(() => {\n return () => {\n mounted.current = false;\n if (timerId.current) {\n window.cancelAnimationFrame(timerId.current);\n }\n };\n }, [mounted, timerId]);\n return useCallback(args => {\n if (timerId.current) {\n window.cancelAnimationFrame(timerId.current);\n }\n timerId.current = window.requestAnimationFrame(function () {\n if (mounted.current) {\n latest.current(args);\n }\n });\n }, [mounted, timerId, latest]);\n}\nexport default /*#__PURE__*/memo(Swiper);\n//# sourceMappingURL=Swiper.js.map","\"use strict\";\n\nimport { StyleSheet, View } from 'react-native';\nimport { Text, useTheme, TouchableRipple, Icon } from 'react-native-paper';\nimport Day, { EmptyDay } from './Day';\nimport { addMonths, areDatesOnSameDay, daySize, getDaysInMonth, getFirstDayOfMonth, getRealIndex, getGridCount, isDateBetween, gridCounts, showWeekDay, startAtIndex, beginOffset, estimatedMonthHeight, useRangeChecker } from './dateUtils';\nimport { getCalendarHeaderHeight } from './CalendarHeader';\nimport { dayNamesHeight } from './DayNames';\nimport { useTextColorOnPrimary } from '../shared/utils';\nimport { memo, useMemo } from 'react';\nimport React from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsxs as _jsxs, jsx as _jsx } from \"react/jsx-runtime\";\nfunction Month(props) {\n const {\n index,\n mode,\n date,\n dates,\n startDate,\n endDate,\n onPressYear,\n selectingYear,\n onPressDate,\n scrollMode,\n primaryColor,\n selectColor,\n roundness,\n disableWeekDays,\n locale,\n validRange,\n startWeekOnMonday\n } = props;\n const isHorizontal = scrollMode === 'horizontal';\n const theme = useTheme();\n const textColorOnPrimary = useTextColorOnPrimary();\n const realIndex = getRealIndex(index);\n const {\n isDisabled,\n isWithinValidRange\n } = useRangeChecker(validRange);\n const {\n monthName,\n month,\n year\n } = useMemo(() => {\n const md = addMonths(new Date(), realIndex);\n const y = md.getFullYear();\n const m = md.getMonth();\n const formatter = new Intl.DateTimeFormat(locale, {\n month: 'long'\n });\n return {\n monthName: formatter.format(md),\n month: m,\n year: y\n };\n }, [realIndex, locale]);\n const grid = useMemo(() => {\n const today = new Date();\n const daysInMonth = getDaysInMonth({\n year,\n month\n });\n const dayOfWeek = getFirstDayOfMonth({\n year,\n month,\n startWeekOnMonday\n });\n const emptyDays = dayOfWeek;\n return monthGrid(index, startWeekOnMonday).map(({\n days,\n weekGrid\n }) => {\n return {\n weekIndex: weekGrid,\n generatedDays: days.map((_, dayIndex) => {\n const isFirstWeek = weekGrid === 0;\n const realDayIndex = emptyDays - dayIndex;\n const beforeWeekDay = isFirstWeek && realDayIndex > 0;\n const dayOfMonth = weekGrid * 7 + dayIndex - emptyDays + 1;\n const afterWeekDay = dayOfMonth > daysInMonth;\n const day = new Date(year, month, dayOfMonth);\n const isToday = areDatesOnSameDay(day, today);\n let inRange = false;\n let disabled = isDisabled(day);\n let selected = false;\n let leftCrop = dayOfMonth === 1;\n let rightCrop = dayOfMonth === daysInMonth;\n const isFirstDayOfMonth = dayOfMonth === 1;\n const isLastDayOfMonth = dayOfMonth === daysInMonth;\n if (mode === 'range') {\n const selectedStartDay = areDatesOnSameDay(day, startDate);\n const selectedEndDay = areDatesOnSameDay(day, endDate);\n selected = selectedStartDay || selectedEndDay;\n inRange = isDateBetween(day, {\n startDate,\n endDate\n });\n if (selectedStartDay) {\n leftCrop = true;\n }\n if (selectedEndDay) {\n rightCrop = true;\n }\n if (dayIndex === 0 && !selectedStartDay) {\n leftCrop = false;\n }\n if (dayIndex === 6 && !selectedEndDay) {\n rightCrop = false;\n }\n if (isFirstDayOfMonth && selectedEndDay || isLastDayOfMonth && selectedStartDay) {\n inRange = false;\n }\n } else if (mode === 'multiple') {\n const safeDates = dates || [];\n selected = safeDates.some(d => areDatesOnSameDay(day, d));\n const yesterday = new Date(year, month, dayOfMonth - 1);\n const tomorrow = new Date(year, month, dayOfMonth + 1);\n const yesterdaySelected = safeDates.some(d => areDatesOnSameDay(d, yesterday));\n const tomorrowSelected = safeDates.some(d => areDatesOnSameDay(d, tomorrow));\n if (selected) {\n if (tomorrowSelected && yesterdaySelected) {\n inRange = true;\n }\n if (tomorrowSelected && !yesterdaySelected) {\n inRange = true;\n leftCrop = true;\n }\n if (yesterdaySelected && !tomorrowSelected) {\n inRange = true;\n rightCrop = true;\n }\n if (isFirstDayOfMonth && !tomorrowSelected) {\n inRange = false;\n }\n if (isLastDayOfMonth && !yesterdaySelected) {\n inRange = false;\n }\n if (inRange && !leftCrop && !rightCrop) {\n selected = false;\n }\n }\n } else if (mode === 'single') {\n selected = areDatesOnSameDay(day, date);\n }\n const isWithinOptionalValidRange = isWithinValidRange(day);\n if (inRange && !disabled) {\n disabled = false;\n }\n if (!isWithinOptionalValidRange) {\n disabled = true;\n }\n return {\n beforeWeekDay,\n afterWeekDay,\n year,\n month,\n dayOfMonth,\n dayIndex,\n mode,\n selected,\n inRange,\n leftCrop,\n rightCrop,\n isToday,\n disabled\n };\n })\n };\n });\n }, [year, month, index, isDisabled, mode, isWithinValidRange, startDate, endDate, dates, date, startWeekOnMonday]);\n let textFont = theme?.isV3 ? theme.fonts.titleSmall : theme.fonts.medium;\n const iconColor = theme.isV3 ? theme.colors.onSurfaceVariant : theme.colors.onSurface;\n const iconSourceV3 = selectingYear ? 'menu-up' : 'menu-down';\n const iconSourceV2 = selectingYear ? 'chevron-up' : 'chevron-down';\n const iconSource = theme.isV3 ? iconSourceV3 : iconSourceV2;\n return /*#__PURE__*/_jsxs(View, {\n style: {\n height: getMonthHeight(scrollMode, index, startWeekOnMonday)\n },\n children: [/*#__PURE__*/_jsx(View, {\n style: [styles.monthHeader, isHorizontal ? {\n marginTop: monthHeaderSingleMarginTop,\n marginBottom: monthHeaderSingleMarginBottom\n } : null],\n children: /*#__PURE__*/_jsx(TouchableRipple, {\n disabled: !isHorizontal,\n onPress: isHorizontal ? () => onPressYear(year) : undefined,\n accessibilityRole: \"button\",\n accessibilityLabel: `${monthName} ${year}`,\n style: [styles.yearButton, {\n borderRadius: roundness\n }],\n children: /*#__PURE__*/_jsxs(View, {\n style: [styles.yearButtonInner, {\n borderRadius: roundness\n }],\n children: [/*#__PURE__*/_jsxs(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.monthLabel, {\n ...textFont,\n color: theme.isV3 ? theme.colors.onSurfaceVariant : theme.colors.onSurface\n }],\n selectable: false,\n children: [monthName, \" \", year]\n }), /*#__PURE__*/_jsx(View, {\n style: [styles.iconWrapper, isHorizontal ? sharedStyles.opacity1 : sharedStyles.opacity0],\n children: /*#__PURE__*/_jsx(Icon, {\n size: 24,\n color: iconColor,\n source: iconSource\n })\n })]\n })\n })\n }), grid.map(({\n weekIndex,\n generatedDays\n }) => /*#__PURE__*/_jsx(View, {\n style: styles.week,\n children: generatedDays.filter(gd => showWeekDay(gd.dayIndex, disableWeekDays)).map(gd => gd.beforeWeekDay || gd.afterWeekDay ? /*#__PURE__*/_jsx(EmptyDay, {}, gd.dayIndex) : /*#__PURE__*/_jsx(Day, {\n theme: theme,\n day: gd.dayOfMonth,\n month: gd.month,\n year: gd.year,\n selected: gd.selected,\n inRange: gd.inRange,\n leftCrop: gd.leftCrop,\n rightCrop: gd.rightCrop,\n onPressDate: onPressDate,\n isToday: gd.isToday,\n selectColor: selectColor,\n primaryColor: primaryColor,\n disabled: gd.disabled,\n textColorOnPrimary: textColorOnPrimary\n }, gd.dayIndex))\n }, weekIndex))]\n });\n}\nexport const weekMargin = 6;\nexport const weekSize = daySize + weekMargin;\nexport const montHeaderHeight = 56;\nexport const monthHeaderSingleMarginTop = 4;\nexport const monthHeaderSingleMarginBottom = 8 + 44 + 12;\nexport const monthHeaderSingleHeight = monthHeaderSingleMarginTop + monthHeaderSingleMarginBottom;\nconst styles = StyleSheet.create({\n iconWrapper: {\n padding: 8\n },\n monthHeader: {\n height: montHeaderHeight,\n justifyContent: 'center',\n overflow: 'hidden'\n },\n monthLabel: {\n fontSize: 14,\n opacity: 0.7\n },\n week: {\n flexDirection: 'row',\n marginBottom: weekMargin,\n height: daySize\n },\n yearButton: {\n alignSelf: 'flex-start',\n marginLeft: 6\n },\n yearButtonInner: {\n paddingLeft: 16,\n flexDirection: 'row',\n alignItems: 'center'\n }\n});\nconst monthGrid = (index, startWeekOnMonday) => {\n return Array(getGridCount(index, startWeekOnMonday)).fill(null).map((_, weekGrid) => {\n const days = Array(7).fill(null);\n return {\n weekGrid,\n days\n };\n });\n};\nfunction getIndexCount(index) {\n if (index > startAtIndex) {\n return index - startAtIndex;\n }\n return -(startAtIndex - index);\n}\nfunction weeksOffset(index, startWeekOnMonday) {\n if (index === startAtIndex) {\n return 0;\n }\n let off = 0;\n if (index > startAtIndex) {\n for (let i = 0; i < index - startAtIndex; i++) {\n const cIndex = startAtIndex + i;\n off += gridCounts[cIndex] || getGridCount(cIndex, startWeekOnMonday);\n }\n } else {\n for (let i = 0; i < startAtIndex - index; i++) {\n const cIndex = startAtIndex - i - 1;\n off -= gridCounts[cIndex] || getGridCount(cIndex, startWeekOnMonday);\n }\n }\n return off;\n}\nexport function getIndexFromHorizontalOffset(offset, width) {\n return startAtIndex + Math.floor(offset / width);\n}\nexport function getIndexFromVerticalOffset(offset, startWeekOnMonday) {\n let estimatedIndex = startAtIndex + Math.ceil(offset / estimatedMonthHeight);\n const realOffset = getVerticalMonthsOffset(estimatedIndex, startWeekOnMonday);\n const difference = (realOffset - beginOffset - offset) / estimatedMonthHeight;\n if (difference >= 1 || difference <= -1) {\n estimatedIndex -= Math.floor(difference);\n }\n return estimatedIndex;\n}\nexport function getHorizontalMonthOffset(index, width) {\n if (index < 0) {\n return 0;\n }\n return width * index;\n}\nexport function getVerticalMonthsOffset(index, startWeekOnMonday) {\n const count = getIndexCount(index);\n const ob = weeksOffset(index, startWeekOnMonday);\n const monthsHeight = weekSize * ob;\n const c = monthsHeight + count * (dayNamesHeight + montHeaderHeight);\n return (c || 0) + beginOffset;\n}\nexport function getMonthHeight(scrollMode, index, startWeekOnMonday) {\n const calendarHeight = getCalendarHeaderHeight(scrollMode);\n const gc = getGridCount(index, startWeekOnMonday);\n const currentMonthHeight = weekSize * gc;\n const extraHeight = scrollMode === 'horizontal' ? monthHeaderSingleHeight : montHeaderHeight;\n const c = calendarHeight + currentMonthHeight + extraHeight;\n return c || 0;\n}\nexport default /*#__PURE__*/memo(Month);\n//# sourceMappingURL=Month.js.map","\"use strict\";\n\nimport { Text, TouchableRipple } from 'react-native-paper';\nimport { StyleSheet, View } from 'react-native';\nimport DayRange from './DayRange';\nimport { daySize } from './dateUtils';\nimport { memo, useCallback } from 'react';\nimport React from 'react';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction EmptyDayPure() {\n return /*#__PURE__*/_jsx(View, {\n style: styles.empty\n });\n}\nexport const EmptyDay = /*#__PURE__*/memo(EmptyDayPure);\nfunction Day(props) {\n const {\n day,\n month,\n year,\n selected,\n inRange,\n leftCrop,\n rightCrop,\n onPressDate,\n primaryColor,\n selectColor,\n isToday,\n disabled,\n textColorOnPrimary,\n theme\n } = props;\n const borderColorFallback = theme.dark ? '#fff' : '#000';\n const selectedOrInRangeDarkMode = selected || inRange && theme.dark;\n const v2BorderColor = selectedOrInRangeDarkMode ? textColorOnPrimary : borderColorFallback;\n const borderColor = theme.isV3 ? theme.colors.primary : v2BorderColor;\n const onPress = useCallback(() => {\n onPressDate(new Date(year, month, day));\n }, [onPressDate, year, month, day]);\n\n // TODO: check if this can be simplified\n // converted with Chat-GPT for now from enormous conditional to if-else\n let baseTextColor;\n let finalTextColor;\n if (theme.isV3) {\n // Theme V3 specific logic for base text color\n if (selected) {\n baseTextColor = theme.colors.onPrimary;\n } else if (inRange && theme.dark) {\n baseTextColor = theme.colors.onPrimaryContainer;\n } else {\n baseTextColor = theme.colors.onSurface;\n }\n\n // Theme V3 specific logic for final text color\n if (isToday) {\n finalTextColor = selected ? baseTextColor : theme.colors.primary;\n } else {\n finalTextColor = baseTextColor;\n }\n } else {\n // Logic for themes other than V3\n if (selected || inRange && theme.dark) {\n baseTextColor = textColorOnPrimary;\n }\n // Since there's no additional logic provided for non-V3 themes in the step 2,\n // the final text color for non-V3 themes will simply be the base text color.\n finalTextColor = baseTextColor;\n }\n let textFont = theme?.isV3 ? theme.fonts.bodySmall : theme.fonts.medium;\n return /*#__PURE__*/_jsxs(View, {\n style: [styles.root, disabled && styles.disabled],\n children: [/*#__PURE__*/_jsx(DayRange, {\n inRange: inRange,\n leftCrop: leftCrop,\n rightCrop: rightCrop,\n selectColor: selectColor\n }), /*#__PURE__*/_jsx(TouchableRipple, {\n testID: `react-native-paper-dates-day-${year}-${month}-${day}`,\n disabled: disabled,\n borderless: true,\n onPress: disabled ? undefined : onPress,\n style: [styles.button, {\n backgroundColor: inRange ? selectColor : undefined\n }],\n accessibilityRole: \"button\",\n children: /*#__PURE__*/_jsx(View, {\n style: [styles.day, isToday ? {\n borderColor: borderColor\n } : null, selected ? {\n backgroundColor: primaryColor\n } : null],\n children: /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [baseTextColor ? {\n color: finalTextColor\n } : undefined, {\n ...textFont\n }],\n selectable: false,\n children: day\n })\n })\n })]\n });\n}\nconst styles = StyleSheet.create({\n button: {\n width: daySize,\n height: daySize,\n overflow: 'hidden',\n borderRadius: daySize / 2\n },\n day: {\n flexBasis: 0,\n flex: 1,\n borderRadius: daySize / 2,\n width: daySize,\n height: daySize,\n justifyContent: 'center',\n alignItems: 'center',\n borderWidth: 1,\n borderColor: 'transparent'\n },\n disabled: {\n opacity: 0.3\n },\n empty: {\n flex: 1,\n flexBasis: 0\n },\n root: {\n flexBasis: 0,\n flex: 1,\n justifyContent: 'center',\n alignItems: 'center',\n position: 'relative'\n }\n});\nexport default /*#__PURE__*/memo(Day);\n//# sourceMappingURL=Day.js.map","\"use strict\";\n\nimport { StyleSheet, View } from 'react-native';\nimport { daySize } from './dateUtils';\nimport React, { memo } from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction DayRange({\n leftCrop,\n rightCrop,\n inRange,\n selectColor\n}) {\n const bothWays = inRange && leftCrop && rightCrop;\n const isCrop = inRange && (leftCrop || rightCrop) && !(leftCrop && rightCrop);\n if (inRange || isCrop) {\n return /*#__PURE__*/_jsx(View, {\n pointerEvents: \"none\",\n style: [StyleSheet.absoluteFill, sharedStyles.flexDirectionRow, bothWays && styles.rangeRootBoth, inRange && !isCrop ? {\n backgroundColor: selectColor\n } : null],\n children: isCrop && /*#__PURE__*/_jsxs(_Fragment, {\n children: [/*#__PURE__*/_jsx(View, {\n style: [sharedStyles.root, rightCrop ? {\n backgroundColor: selectColor\n } : null]\n }), /*#__PURE__*/_jsx(View, {\n style: [{\n backgroundColor: selectColor,\n minWidth: daySize,\n minHeight: daySize\n }, leftCrop ? styles.leftRadius : null, rightCrop ? styles.rightRadius : null]\n }), /*#__PURE__*/_jsx(View, {\n style: [sharedStyles.root, leftCrop ? {\n backgroundColor: selectColor\n } : null]\n })]\n })\n });\n }\n return null;\n}\nconst styles = StyleSheet.create({\n leftRadius: {\n borderBottomLeftRadius: daySize / 2,\n borderTopLeftRadius: daySize / 2\n },\n rightRadius: {\n borderBottomRightRadius: daySize / 2,\n borderTopRightRadius: daySize / 2\n },\n rangeRootBoth: {\n borderRadius: daySize / 2\n }\n});\nexport default /*#__PURE__*/memo(DayRange);\n//# sourceMappingURL=DayRange.js.map","\"use strict\";\n\nimport { useCallback, useMemo } from 'react';\nimport { useLatest } from '../shared/utils';\nexport function showWeekDay(dayIndex, disableWeekDays) {\n return !(disableWeekDays && disableWeekDays.some(di => di === dayIndex));\n}\nexport function dateToUnix(d) {\n return Math.round(d.getTime() / 1000);\n}\nexport function addMonths(date, count) {\n let n = date.getDate();\n let n2 = new Date(date.getTime());\n n2.setDate(1);\n n2.setMonth(n2.getMonth() + count);\n n2.setDate(Math.min(n, getDaysInMonth({\n year: n2.getFullYear(),\n month: n2.getMonth()\n })));\n return n2;\n}\n\n// https://stackoverflow.com/a/1185068/2508481\n// pass in any date as parameter anyDateInMonth based on dayjs\nexport function getDaysInMonth({\n year,\n month\n}) {\n return [31, isLeapYear({\n year\n }) ? 29 : 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][month];\n}\nexport function getFirstDayOfMonth({\n year,\n month,\n startWeekOnMonday\n}) {\n let dayOfWeek = new Date(year, month, 1).getDay();\n if (startWeekOnMonday) {\n // Map Sunday (0) to 6, Monday (1) to 0, etc.\n dayOfWeek = (dayOfWeek + 6) % 7;\n }\n return dayOfWeek;\n}\nexport function useRangeChecker(validRange) {\n const validStart = validRange?.startDate;\n const validEnd = validRange?.endDate;\n const startUnix = validStart instanceof Date ? dateToUnix(getStartOfDay(validStart)) : undefined;\n const endUnix = validEnd instanceof Date ? dateToUnix(getEndOfDay(validEnd)) : undefined;\n const validDisabledDatesRef = useLatest(validRange?.disabledDates);\n const isWithinValidRange = useCallback(day => {\n return isDateWithinOptionalRange(day, {\n startUnix: startUnix,\n endUnix: endUnix\n });\n }, [startUnix, endUnix]);\n const isDisabled = useCallback(day => {\n return validDisabledDatesRef.current ? validDisabledDatesRef.current.some(disabledDate => areDatesOnSameDay(disabledDate, day)) : false;\n }, [validDisabledDatesRef]);\n return {\n isDisabled,\n isWithinValidRange,\n validStart,\n validEnd\n };\n}\nexport function areDatesOnSameDay(a, b) {\n if (!b) {\n return false;\n }\n return a.getFullYear() === b.getFullYear() && a.getMonth() === b.getMonth() && a.getDate() === b.getDate();\n}\nexport function isDateBetween(date, {\n startDate,\n endDate\n}) {\n if (!startDate || !endDate) {\n return false;\n }\n return date <= endDate && date >= startDate;\n}\n\n/**\n * Check if a date is within an optional range.\n *\n * If the range doesn't exist, it defaults to `true`.\n */\nexport function isDateWithinOptionalRange(date, {\n startUnix,\n endUnix\n}) {\n const dateUnix = dateToUnix(date);\n // if startUnix is provided and date is before start\n if (startUnix && dateUnix < startUnix) {\n return false;\n }\n\n // if endUnix is provided and date is after end\n if (endUnix && dateUnix > endUnix) {\n return false;\n }\n return true;\n}\nexport function isLeapYear({\n year\n}) {\n return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0;\n}\nexport const daySize = 46;\nexport const estimatedMonthHeight = 360;\nexport const startAtIndex = 1200;\nexport const totalMonths = startAtIndex * 2;\nexport const beginOffset = estimatedMonthHeight * startAtIndex;\nexport const gridCounts = new Array(totalMonths);\nexport function getGridCount(index, startWeekOnMonday) {\n const cHeight = gridCounts[index];\n if (cHeight) {\n return cHeight;\n }\n const monthDate = addMonths(new Date(), getRealIndex(index));\n const h = getGridCountForDate(monthDate, startWeekOnMonday);\n gridCounts[index] = h;\n return h;\n}\nexport function getGridCountForDate(date, startWeekOnMonday) {\n const year = date.getFullYear();\n const month = date.getMonth();\n const daysInMonth = getDaysInMonth({\n year,\n month\n });\n const dayOfWeek = getFirstDayOfMonth({\n year,\n month,\n startWeekOnMonday\n });\n return Math.ceil((daysInMonth + dayOfWeek) / 7);\n}\nexport function getRealIndex(index) {\n return index - startAtIndex;\n}\nexport function getInitialIndex(date) {\n if (!date) {\n return startAtIndex;\n }\n const today = new Date();\n const months = differenceInMonths(today, date);\n return startAtIndex + months;\n}\nexport function useInputFormatter({\n locale\n}) {\n return useMemo(() => {\n return new Intl.DateTimeFormat(locale, {\n month: '2-digit',\n day: '2-digit',\n year: 'numeric'\n });\n }, [locale]);\n}\nexport function getStartOfDay(d) {\n const startOfDay = new Date(d);\n startOfDay.setUTCHours(0, 0, 0, 0);\n return startOfDay;\n}\nexport function getEndOfDay(d) {\n const endOfDay = new Date(d);\n endOfDay.setUTCHours(23, 59, 59, 999);\n return endOfDay;\n}\nexport function useInputFormat({\n formatter,\n locale\n}) {\n return useMemo(() => {\n // TODO: something cleaner and more universal?\n const inputDate = formatter.format(new Date(2020, 10 - 1, 1));\n if (inputDate.includes('٢٠٢٠')) {\n return inputDate.replace('٢٠٢٠', 'YYYY').replace('١٠', 'MM').replace('٠١', 'DD');\n }\n return inputDate.replace('2020', locale === 'pt' ? 'AAAA' : 'YYYY').replace('10', 'MM').replace('01', 'DD');\n }, [formatter, locale]);\n}\nexport function differenceInMonths(firstDate, secondDate) {\n let diffMonths = (secondDate.getFullYear() - firstDate.getFullYear()) * 12;\n diffMonths -= firstDate.getMonth();\n diffMonths += secondDate.getMonth();\n return diffMonths;\n}\n//# sourceMappingURL=dateUtils.js.map","\"use strict\";\n\nimport { useRef } from 'react';\nimport { overlay, useTheme } from 'react-native-paper';\nimport Color from 'color';\nexport const supportedOrientations = ['portrait', 'portrait-upside-down', 'landscape', 'landscape-left', 'landscape-right'];\nexport function useLatest(value) {\n const ref = useRef(value);\n ref.current = value;\n return ref;\n}\nexport function useHeaderBackgroundColor() {\n const theme = useTheme();\n if (theme.isV3) {\n return theme.colors.surface;\n }\n return theme.dark && theme.mode === 'adaptive' ? overlay(4, theme.colors.surface) : theme.colors.primary;\n}\nexport function useHeaderColorIsLight() {\n const theme = useTheme();\n const background = theme.dark && theme.mode === 'adaptive' ? theme.colors.surface : theme.colors.primary;\n return Color(background).isLight();\n}\nexport function useHeaderTextColor() {\n const theme = useTheme();\n const isLight = useHeaderColorIsLight();\n if (theme.isV3) {\n return theme.colors.onSurfaceVariant;\n }\n return !isLight ? '#fff' : '#000';\n}\nexport function useTextColorOnPrimary() {\n const theme = useTheme();\n const isDark = !Color(theme.colors.primary).isLight();\n if (theme.isV3) {\n if (isDark && theme.dark) {\n return theme.colors.onSurface;\n } else {\n return theme.colors.onPrimary;\n }\n }\n return isDark ? '#fff' : '#000';\n}\nexport function range(start, end) {\n return Array(end - start + 1).fill(null).map((_, i) => start + i);\n}\nexport function lightenBy(color, ratio) {\n const lightness = color.lightness();\n return color.lightness(lightness + (100 - lightness) * ratio);\n}\nexport function darkenBy(color, ratio) {\n const lightness = color.lightness();\n return color.lightness(lightness - lightness * ratio);\n}\n//# sourceMappingURL=utils.js.map","const colorString = require('color-string');\nconst convert = require('color-convert');\n\nconst skippedModels = [\n\t// To be honest, I don't really feel like keyword belongs in color convert, but eh.\n\t'keyword',\n\n\t// Gray conflicts with some method names, and has its own method defined.\n\t'gray',\n\n\t// Shouldn't really be in color-convert either...\n\t'hex',\n];\n\nconst hashedModelKeys = {};\nfor (const model of Object.keys(convert)) {\n\thashedModelKeys[[...convert[model].labels].sort().join('')] = model;\n}\n\nconst limiters = {};\n\nfunction Color(object, model) {\n\tif (!(this instanceof Color)) {\n\t\treturn new Color(object, model);\n\t}\n\n\tif (model && model in skippedModels) {\n\t\tmodel = null;\n\t}\n\n\tif (model && !(model in convert)) {\n\t\tthrow new Error('Unknown model: ' + model);\n\t}\n\n\tlet i;\n\tlet channels;\n\n\tif (object == null) { // eslint-disable-line no-eq-null,eqeqeq\n\t\tthis.model = 'rgb';\n\t\tthis.color = [0, 0, 0];\n\t\tthis.valpha = 1;\n\t} else if (object instanceof Color) {\n\t\tthis.model = object.model;\n\t\tthis.color = [...object.color];\n\t\tthis.valpha = object.valpha;\n\t} else if (typeof object === 'string') {\n\t\tconst result = colorString.get(object);\n\t\tif (result === null) {\n\t\t\tthrow new Error('Unable to parse color from string: ' + object);\n\t\t}\n\n\t\tthis.model = result.model;\n\t\tchannels = convert[this.model].channels;\n\t\tthis.color = result.value.slice(0, channels);\n\t\tthis.valpha = typeof result.value[channels] === 'number' ? result.value[channels] : 1;\n\t} else if (object.length > 0) {\n\t\tthis.model = model || 'rgb';\n\t\tchannels = convert[this.model].channels;\n\t\tconst newArray = Array.prototype.slice.call(object, 0, channels);\n\t\tthis.color = zeroArray(newArray, channels);\n\t\tthis.valpha = typeof object[channels] === 'number' ? object[channels] : 1;\n\t} else if (typeof object === 'number') {\n\t\t// This is always RGB - can be converted later on.\n\t\tthis.model = 'rgb';\n\t\tthis.color = [\n\t\t\t(object >> 16) & 0xFF,\n\t\t\t(object >> 8) & 0xFF,\n\t\t\tobject & 0xFF,\n\t\t];\n\t\tthis.valpha = 1;\n\t} else {\n\t\tthis.valpha = 1;\n\n\t\tconst keys = Object.keys(object);\n\t\tif ('alpha' in object) {\n\t\t\tkeys.splice(keys.indexOf('alpha'), 1);\n\t\t\tthis.valpha = typeof object.alpha === 'number' ? object.alpha : 0;\n\t\t}\n\n\t\tconst hashedKeys = keys.sort().join('');\n\t\tif (!(hashedKeys in hashedModelKeys)) {\n\t\t\tthrow new Error('Unable to parse color from object: ' + JSON.stringify(object));\n\t\t}\n\n\t\tthis.model = hashedModelKeys[hashedKeys];\n\n\t\tconst {labels} = convert[this.model];\n\t\tconst color = [];\n\t\tfor (i = 0; i < labels.length; i++) {\n\t\t\tcolor.push(object[labels[i]]);\n\t\t}\n\n\t\tthis.color = zeroArray(color);\n\t}\n\n\t// Perform limitations (clamping, etc.)\n\tif (limiters[this.model]) {\n\t\tchannels = convert[this.model].channels;\n\t\tfor (i = 0; i < channels; i++) {\n\t\t\tconst limit = limiters[this.model][i];\n\t\t\tif (limit) {\n\t\t\t\tthis.color[i] = limit(this.color[i]);\n\t\t\t}\n\t\t}\n\t}\n\n\tthis.valpha = Math.max(0, Math.min(1, this.valpha));\n\n\tif (Object.freeze) {\n\t\tObject.freeze(this);\n\t}\n}\n\nColor.prototype = {\n\ttoString() {\n\t\treturn this.string();\n\t},\n\n\ttoJSON() {\n\t\treturn this[this.model]();\n\t},\n\n\tstring(places) {\n\t\tlet self = this.model in colorString.to ? this : this.rgb();\n\t\tself = self.round(typeof places === 'number' ? places : 1);\n\t\tconst args = self.valpha === 1 ? self.color : [...self.color, this.valpha];\n\t\treturn colorString.to[self.model](args);\n\t},\n\n\tpercentString(places) {\n\t\tconst self = this.rgb().round(typeof places === 'number' ? places : 1);\n\t\tconst args = self.valpha === 1 ? self.color : [...self.color, this.valpha];\n\t\treturn colorString.to.rgb.percent(args);\n\t},\n\n\tarray() {\n\t\treturn this.valpha === 1 ? [...this.color] : [...this.color, this.valpha];\n\t},\n\n\tobject() {\n\t\tconst result = {};\n\t\tconst {channels} = convert[this.model];\n\t\tconst {labels} = convert[this.model];\n\n\t\tfor (let i = 0; i < channels; i++) {\n\t\t\tresult[labels[i]] = this.color[i];\n\t\t}\n\n\t\tif (this.valpha !== 1) {\n\t\t\tresult.alpha = this.valpha;\n\t\t}\n\n\t\treturn result;\n\t},\n\n\tunitArray() {\n\t\tconst rgb = this.rgb().color;\n\t\trgb[0] /= 255;\n\t\trgb[1] /= 255;\n\t\trgb[2] /= 255;\n\n\t\tif (this.valpha !== 1) {\n\t\t\trgb.push(this.valpha);\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tunitObject() {\n\t\tconst rgb = this.rgb().object();\n\t\trgb.r /= 255;\n\t\trgb.g /= 255;\n\t\trgb.b /= 255;\n\n\t\tif (this.valpha !== 1) {\n\t\t\trgb.alpha = this.valpha;\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tround(places) {\n\t\tplaces = Math.max(places || 0, 0);\n\t\treturn new Color([...this.color.map(roundToPlace(places)), this.valpha], this.model);\n\t},\n\n\talpha(value) {\n\t\tif (value !== undefined) {\n\t\t\treturn new Color([...this.color, Math.max(0, Math.min(1, value))], this.model);\n\t\t}\n\n\t\treturn this.valpha;\n\t},\n\n\t// Rgb\n\tred: getset('rgb', 0, maxfn(255)),\n\tgreen: getset('rgb', 1, maxfn(255)),\n\tblue: getset('rgb', 2, maxfn(255)),\n\n\thue: getset(['hsl', 'hsv', 'hsl', 'hwb', 'hcg'], 0, value => ((value % 360) + 360) % 360),\n\n\tsaturationl: getset('hsl', 1, maxfn(100)),\n\tlightness: getset('hsl', 2, maxfn(100)),\n\n\tsaturationv: getset('hsv', 1, maxfn(100)),\n\tvalue: getset('hsv', 2, maxfn(100)),\n\n\tchroma: getset('hcg', 1, maxfn(100)),\n\tgray: getset('hcg', 2, maxfn(100)),\n\n\twhite: getset('hwb', 1, maxfn(100)),\n\twblack: getset('hwb', 2, maxfn(100)),\n\n\tcyan: getset('cmyk', 0, maxfn(100)),\n\tmagenta: getset('cmyk', 1, maxfn(100)),\n\tyellow: getset('cmyk', 2, maxfn(100)),\n\tblack: getset('cmyk', 3, maxfn(100)),\n\n\tx: getset('xyz', 0, maxfn(95.047)),\n\ty: getset('xyz', 1, maxfn(100)),\n\tz: getset('xyz', 2, maxfn(108.833)),\n\n\tl: getset('lab', 0, maxfn(100)),\n\ta: getset('lab', 1),\n\tb: getset('lab', 2),\n\n\tkeyword(value) {\n\t\tif (value !== undefined) {\n\t\t\treturn new Color(value);\n\t\t}\n\n\t\treturn convert[this.model].keyword(this.color);\n\t},\n\n\thex(value) {\n\t\tif (value !== undefined) {\n\t\t\treturn new Color(value);\n\t\t}\n\n\t\treturn colorString.to.hex(this.rgb().round().color);\n\t},\n\n\thexa(value) {\n\t\tif (value !== undefined) {\n\t\t\treturn new Color(value);\n\t\t}\n\n\t\tconst rgbArray = this.rgb().round().color;\n\n\t\tlet alphaHex = Math.round(this.valpha * 255).toString(16).toUpperCase();\n\t\tif (alphaHex.length === 1) {\n\t\t\talphaHex = '0' + alphaHex;\n\t\t}\n\n\t\treturn colorString.to.hex(rgbArray) + alphaHex;\n\t},\n\n\trgbNumber() {\n\t\tconst rgb = this.rgb().color;\n\t\treturn ((rgb[0] & 0xFF) << 16) | ((rgb[1] & 0xFF) << 8) | (rgb[2] & 0xFF);\n\t},\n\n\tluminosity() {\n\t\t// http://www.w3.org/TR/WCAG20/#relativeluminancedef\n\t\tconst rgb = this.rgb().color;\n\n\t\tconst lum = [];\n\t\tfor (const [i, element] of rgb.entries()) {\n\t\t\tconst chan = element / 255;\n\t\t\tlum[i] = (chan <= 0.04045) ? chan / 12.92 : ((chan + 0.055) / 1.055) ** 2.4;\n\t\t}\n\n\t\treturn 0.2126 * lum[0] + 0.7152 * lum[1] + 0.0722 * lum[2];\n\t},\n\n\tcontrast(color2) {\n\t\t// http://www.w3.org/TR/WCAG20/#contrast-ratiodef\n\t\tconst lum1 = this.luminosity();\n\t\tconst lum2 = color2.luminosity();\n\n\t\tif (lum1 > lum2) {\n\t\t\treturn (lum1 + 0.05) / (lum2 + 0.05);\n\t\t}\n\n\t\treturn (lum2 + 0.05) / (lum1 + 0.05);\n\t},\n\n\tlevel(color2) {\n\t\t// https://www.w3.org/TR/WCAG/#contrast-enhanced\n\t\tconst contrastRatio = this.contrast(color2);\n\t\tif (contrastRatio >= 7) {\n\t\t\treturn 'AAA';\n\t\t}\n\n\t\treturn (contrastRatio >= 4.5) ? 'AA' : '';\n\t},\n\n\tisDark() {\n\t\t// YIQ equation from http://24ways.org/2010/calculating-color-contrast\n\t\tconst rgb = this.rgb().color;\n\t\tconst yiq = (rgb[0] * 2126 + rgb[1] * 7152 + rgb[2] * 722) / 10000;\n\t\treturn yiq < 128;\n\t},\n\n\tisLight() {\n\t\treturn !this.isDark();\n\t},\n\n\tnegate() {\n\t\tconst rgb = this.rgb();\n\t\tfor (let i = 0; i < 3; i++) {\n\t\t\trgb.color[i] = 255 - rgb.color[i];\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tlighten(ratio) {\n\t\tconst hsl = this.hsl();\n\t\thsl.color[2] += hsl.color[2] * ratio;\n\t\treturn hsl;\n\t},\n\n\tdarken(ratio) {\n\t\tconst hsl = this.hsl();\n\t\thsl.color[2] -= hsl.color[2] * ratio;\n\t\treturn hsl;\n\t},\n\n\tsaturate(ratio) {\n\t\tconst hsl = this.hsl();\n\t\thsl.color[1] += hsl.color[1] * ratio;\n\t\treturn hsl;\n\t},\n\n\tdesaturate(ratio) {\n\t\tconst hsl = this.hsl();\n\t\thsl.color[1] -= hsl.color[1] * ratio;\n\t\treturn hsl;\n\t},\n\n\twhiten(ratio) {\n\t\tconst hwb = this.hwb();\n\t\thwb.color[1] += hwb.color[1] * ratio;\n\t\treturn hwb;\n\t},\n\n\tblacken(ratio) {\n\t\tconst hwb = this.hwb();\n\t\thwb.color[2] += hwb.color[2] * ratio;\n\t\treturn hwb;\n\t},\n\n\tgrayscale() {\n\t\t// http://en.wikipedia.org/wiki/Grayscale#Converting_color_to_grayscale\n\t\tconst rgb = this.rgb().color;\n\t\tconst value = rgb[0] * 0.3 + rgb[1] * 0.59 + rgb[2] * 0.11;\n\t\treturn Color.rgb(value, value, value);\n\t},\n\n\tfade(ratio) {\n\t\treturn this.alpha(this.valpha - (this.valpha * ratio));\n\t},\n\n\topaquer(ratio) {\n\t\treturn this.alpha(this.valpha + (this.valpha * ratio));\n\t},\n\n\trotate(degrees) {\n\t\tconst hsl = this.hsl();\n\t\tlet hue = hsl.color[0];\n\t\thue = (hue + degrees) % 360;\n\t\thue = hue < 0 ? 360 + hue : hue;\n\t\thsl.color[0] = hue;\n\t\treturn hsl;\n\t},\n\n\tmix(mixinColor, weight) {\n\t\t// Ported from sass implementation in C\n\t\t// https://github.com/sass/libsass/blob/0e6b4a2850092356aa3ece07c6b249f0221caced/functions.cpp#L209\n\t\tif (!mixinColor || !mixinColor.rgb) {\n\t\t\tthrow new Error('Argument to \"mix\" was not a Color instance, but rather an instance of ' + typeof mixinColor);\n\t\t}\n\n\t\tconst color1 = mixinColor.rgb();\n\t\tconst color2 = this.rgb();\n\t\tconst p = weight === undefined ? 0.5 : weight;\n\n\t\tconst w = 2 * p - 1;\n\t\tconst a = color1.alpha() - color2.alpha();\n\n\t\tconst w1 = (((w * a === -1) ? w : (w + a) / (1 + w * a)) + 1) / 2;\n\t\tconst w2 = 1 - w1;\n\n\t\treturn Color.rgb(\n\t\t\tw1 * color1.red() + w2 * color2.red(),\n\t\t\tw1 * color1.green() + w2 * color2.green(),\n\t\t\tw1 * color1.blue() + w2 * color2.blue(),\n\t\t\tcolor1.alpha() * p + color2.alpha() * (1 - p));\n\t},\n};\n\n// Model conversion methods and static constructors\nfor (const model of Object.keys(convert)) {\n\tif (skippedModels.includes(model)) {\n\t\tcontinue;\n\t}\n\n\tconst {channels} = convert[model];\n\n\t// Conversion methods\n\tColor.prototype[model] = function (...args) {\n\t\tif (this.model === model) {\n\t\t\treturn new Color(this);\n\t\t}\n\n\t\tif (args.length > 0) {\n\t\t\treturn new Color(args, model);\n\t\t}\n\n\t\treturn new Color([...assertArray(convert[this.model][model].raw(this.color)), this.valpha], model);\n\t};\n\n\t// 'static' construction methods\n\tColor[model] = function (...args) {\n\t\tlet color = args[0];\n\t\tif (typeof color === 'number') {\n\t\t\tcolor = zeroArray(args, channels);\n\t\t}\n\n\t\treturn new Color(color, model);\n\t};\n}\n\nfunction roundTo(number, places) {\n\treturn Number(number.toFixed(places));\n}\n\nfunction roundToPlace(places) {\n\treturn function (number) {\n\t\treturn roundTo(number, places);\n\t};\n}\n\nfunction getset(model, channel, modifier) {\n\tmodel = Array.isArray(model) ? model : [model];\n\n\tfor (const m of model) {\n\t\t(limiters[m] || (limiters[m] = []))[channel] = modifier;\n\t}\n\n\tmodel = model[0];\n\n\treturn function (value) {\n\t\tlet result;\n\n\t\tif (value !== undefined) {\n\t\t\tif (modifier) {\n\t\t\t\tvalue = modifier(value);\n\t\t\t}\n\n\t\t\tresult = this[model]();\n\t\t\tresult.color[channel] = value;\n\t\t\treturn result;\n\t\t}\n\n\t\tresult = this[model]().color[channel];\n\t\tif (modifier) {\n\t\t\tresult = modifier(result);\n\t\t}\n\n\t\treturn result;\n\t};\n}\n\nfunction maxfn(max) {\n\treturn function (v) {\n\t\treturn Math.max(0, Math.min(max, v));\n\t};\n}\n\nfunction assertArray(value) {\n\treturn Array.isArray(value) ? value : [value];\n}\n\nfunction zeroArray(array, length) {\n\tfor (let i = 0; i < length; i++) {\n\t\tif (typeof array[i] !== 'number') {\n\t\t\tarray[i] = 0;\n\t\t}\n\t}\n\n\treturn array;\n}\n\nmodule.exports = Color;\n","const conversions = require('./conversions');\nconst route = require('./route');\n\nconst convert = {};\n\nconst models = Object.keys(conversions);\n\nfunction wrapRaw(fn) {\n\tconst wrappedFn = function (...args) {\n\t\tconst arg0 = args[0];\n\t\tif (arg0 === undefined || arg0 === null) {\n\t\t\treturn arg0;\n\t\t}\n\n\t\tif (arg0.length > 1) {\n\t\t\targs = arg0;\n\t\t}\n\n\t\treturn fn(args);\n\t};\n\n\t// Preserve .conversion property if there is one\n\tif ('conversion' in fn) {\n\t\twrappedFn.conversion = fn.conversion;\n\t}\n\n\treturn wrappedFn;\n}\n\nfunction wrapRounded(fn) {\n\tconst wrappedFn = function (...args) {\n\t\tconst arg0 = args[0];\n\n\t\tif (arg0 === undefined || arg0 === null) {\n\t\t\treturn arg0;\n\t\t}\n\n\t\tif (arg0.length > 1) {\n\t\t\targs = arg0;\n\t\t}\n\n\t\tconst result = fn(args);\n\n\t\t// We're assuming the result is an array here.\n\t\t// see notice in conversions.js; don't use box types\n\t\t// in conversion functions.\n\t\tif (typeof result === 'object') {\n\t\t\tfor (let len = result.length, i = 0; i < len; i++) {\n\t\t\t\tresult[i] = Math.round(result[i]);\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t};\n\n\t// Preserve .conversion property if there is one\n\tif ('conversion' in fn) {\n\t\twrappedFn.conversion = fn.conversion;\n\t}\n\n\treturn wrappedFn;\n}\n\nmodels.forEach(fromModel => {\n\tconvert[fromModel] = {};\n\n\tObject.defineProperty(convert[fromModel], 'channels', {value: conversions[fromModel].channels});\n\tObject.defineProperty(convert[fromModel], 'labels', {value: conversions[fromModel].labels});\n\n\tconst routes = route(fromModel);\n\tconst routeModels = Object.keys(routes);\n\n\trouteModels.forEach(toModel => {\n\t\tconst fn = routes[toModel];\n\n\t\tconvert[fromModel][toModel] = wrapRounded(fn);\n\t\tconvert[fromModel][toModel].raw = wrapRaw(fn);\n\t});\n});\n\nmodule.exports = convert;\n","/* MIT license */\n/* eslint-disable no-mixed-operators */\nconst cssKeywords = require('color-name');\n\n// NOTE: conversions should only return primitive values (i.e. arrays, or\n// values that give correct `typeof` results).\n// do not use box values types (i.e. Number(), String(), etc.)\n\nconst reverseKeywords = {};\nfor (const key of Object.keys(cssKeywords)) {\n\treverseKeywords[cssKeywords[key]] = key;\n}\n\nconst convert = {\n\trgb: {channels: 3, labels: 'rgb'},\n\thsl: {channels: 3, labels: 'hsl'},\n\thsv: {channels: 3, labels: 'hsv'},\n\thwb: {channels: 3, labels: 'hwb'},\n\tcmyk: {channels: 4, labels: 'cmyk'},\n\txyz: {channels: 3, labels: 'xyz'},\n\tlab: {channels: 3, labels: 'lab'},\n\tlch: {channels: 3, labels: 'lch'},\n\thex: {channels: 1, labels: ['hex']},\n\tkeyword: {channels: 1, labels: ['keyword']},\n\tansi16: {channels: 1, labels: ['ansi16']},\n\tansi256: {channels: 1, labels: ['ansi256']},\n\thcg: {channels: 3, labels: ['h', 'c', 'g']},\n\tapple: {channels: 3, labels: ['r16', 'g16', 'b16']},\n\tgray: {channels: 1, labels: ['gray']}\n};\n\nmodule.exports = convert;\n\n// Hide .channels and .labels properties\nfor (const model of Object.keys(convert)) {\n\tif (!('channels' in convert[model])) {\n\t\tthrow new Error('missing channels property: ' + model);\n\t}\n\n\tif (!('labels' in convert[model])) {\n\t\tthrow new Error('missing channel labels property: ' + model);\n\t}\n\n\tif (convert[model].labels.length !== convert[model].channels) {\n\t\tthrow new Error('channel and label counts mismatch: ' + model);\n\t}\n\n\tconst {channels, labels} = convert[model];\n\tdelete convert[model].channels;\n\tdelete convert[model].labels;\n\tObject.defineProperty(convert[model], 'channels', {value: channels});\n\tObject.defineProperty(convert[model], 'labels', {value: labels});\n}\n\nconvert.rgb.hsl = function (rgb) {\n\tconst r = rgb[0] / 255;\n\tconst g = rgb[1] / 255;\n\tconst b = rgb[2] / 255;\n\tconst min = Math.min(r, g, b);\n\tconst max = Math.max(r, g, b);\n\tconst delta = max - min;\n\tlet h;\n\tlet s;\n\n\tif (max === min) {\n\t\th = 0;\n\t} else if (r === max) {\n\t\th = (g - b) / delta;\n\t} else if (g === max) {\n\t\th = 2 + (b - r) / delta;\n\t} else if (b === max) {\n\t\th = 4 + (r - g) / delta;\n\t}\n\n\th = Math.min(h * 60, 360);\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tconst l = (min + max) / 2;\n\n\tif (max === min) {\n\t\ts = 0;\n\t} else if (l <= 0.5) {\n\t\ts = delta / (max + min);\n\t} else {\n\t\ts = delta / (2 - max - min);\n\t}\n\n\treturn [h, s * 100, l * 100];\n};\n\nconvert.rgb.hsv = function (rgb) {\n\tlet rdif;\n\tlet gdif;\n\tlet bdif;\n\tlet h;\n\tlet s;\n\n\tconst r = rgb[0] / 255;\n\tconst g = rgb[1] / 255;\n\tconst b = rgb[2] / 255;\n\tconst v = Math.max(r, g, b);\n\tconst diff = v - Math.min(r, g, b);\n\tconst diffc = function (c) {\n\t\treturn (v - c) / 6 / diff + 1 / 2;\n\t};\n\n\tif (diff === 0) {\n\t\th = 0;\n\t\ts = 0;\n\t} else {\n\t\ts = diff / v;\n\t\trdif = diffc(r);\n\t\tgdif = diffc(g);\n\t\tbdif = diffc(b);\n\n\t\tif (r === v) {\n\t\t\th = bdif - gdif;\n\t\t} else if (g === v) {\n\t\t\th = (1 / 3) + rdif - bdif;\n\t\t} else if (b === v) {\n\t\t\th = (2 / 3) + gdif - rdif;\n\t\t}\n\n\t\tif (h < 0) {\n\t\t\th += 1;\n\t\t} else if (h > 1) {\n\t\t\th -= 1;\n\t\t}\n\t}\n\n\treturn [\n\t\th * 360,\n\t\ts * 100,\n\t\tv * 100\n\t];\n};\n\nconvert.rgb.hwb = function (rgb) {\n\tconst r = rgb[0];\n\tconst g = rgb[1];\n\tlet b = rgb[2];\n\tconst h = convert.rgb.hsl(rgb)[0];\n\tconst w = 1 / 255 * Math.min(r, Math.min(g, b));\n\n\tb = 1 - 1 / 255 * Math.max(r, Math.max(g, b));\n\n\treturn [h, w * 100, b * 100];\n};\n\nconvert.rgb.cmyk = function (rgb) {\n\tconst r = rgb[0] / 255;\n\tconst g = rgb[1] / 255;\n\tconst b = rgb[2] / 255;\n\n\tconst k = Math.min(1 - r, 1 - g, 1 - b);\n\tconst c = (1 - r - k) / (1 - k) || 0;\n\tconst m = (1 - g - k) / (1 - k) || 0;\n\tconst y = (1 - b - k) / (1 - k) || 0;\n\n\treturn [c * 100, m * 100, y * 100, k * 100];\n};\n\nfunction comparativeDistance(x, y) {\n\t/*\n\t\tSee https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance\n\t*/\n\treturn (\n\t\t((x[0] - y[0]) ** 2) +\n\t\t((x[1] - y[1]) ** 2) +\n\t\t((x[2] - y[2]) ** 2)\n\t);\n}\n\nconvert.rgb.keyword = function (rgb) {\n\tconst reversed = reverseKeywords[rgb];\n\tif (reversed) {\n\t\treturn reversed;\n\t}\n\n\tlet currentClosestDistance = Infinity;\n\tlet currentClosestKeyword;\n\n\tfor (const keyword of Object.keys(cssKeywords)) {\n\t\tconst value = cssKeywords[keyword];\n\n\t\t// Compute comparative distance\n\t\tconst distance = comparativeDistance(rgb, value);\n\n\t\t// Check if its less, if so set as closest\n\t\tif (distance < currentClosestDistance) {\n\t\t\tcurrentClosestDistance = distance;\n\t\t\tcurrentClosestKeyword = keyword;\n\t\t}\n\t}\n\n\treturn currentClosestKeyword;\n};\n\nconvert.keyword.rgb = function (keyword) {\n\treturn cssKeywords[keyword];\n};\n\nconvert.rgb.xyz = function (rgb) {\n\tlet r = rgb[0] / 255;\n\tlet g = rgb[1] / 255;\n\tlet b = rgb[2] / 255;\n\n\t// Assume sRGB\n\tr = r > 0.04045 ? (((r + 0.055) / 1.055) ** 2.4) : (r / 12.92);\n\tg = g > 0.04045 ? (((g + 0.055) / 1.055) ** 2.4) : (g / 12.92);\n\tb = b > 0.04045 ? (((b + 0.055) / 1.055) ** 2.4) : (b / 12.92);\n\n\tconst x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805);\n\tconst y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722);\n\tconst z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505);\n\n\treturn [x * 100, y * 100, z * 100];\n};\n\nconvert.rgb.lab = function (rgb) {\n\tconst xyz = convert.rgb.xyz(rgb);\n\tlet x = xyz[0];\n\tlet y = xyz[1];\n\tlet z = xyz[2];\n\n\tx /= 95.047;\n\ty /= 100;\n\tz /= 108.883;\n\n\tx = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);\n\ty = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);\n\tz = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);\n\n\tconst l = (116 * y) - 16;\n\tconst a = 500 * (x - y);\n\tconst b = 200 * (y - z);\n\n\treturn [l, a, b];\n};\n\nconvert.hsl.rgb = function (hsl) {\n\tconst h = hsl[0] / 360;\n\tconst s = hsl[1] / 100;\n\tconst l = hsl[2] / 100;\n\tlet t2;\n\tlet t3;\n\tlet val;\n\n\tif (s === 0) {\n\t\tval = l * 255;\n\t\treturn [val, val, val];\n\t}\n\n\tif (l < 0.5) {\n\t\tt2 = l * (1 + s);\n\t} else {\n\t\tt2 = l + s - l * s;\n\t}\n\n\tconst t1 = 2 * l - t2;\n\n\tconst rgb = [0, 0, 0];\n\tfor (let i = 0; i < 3; i++) {\n\t\tt3 = h + 1 / 3 * -(i - 1);\n\t\tif (t3 < 0) {\n\t\t\tt3++;\n\t\t}\n\n\t\tif (t3 > 1) {\n\t\t\tt3--;\n\t\t}\n\n\t\tif (6 * t3 < 1) {\n\t\t\tval = t1 + (t2 - t1) * 6 * t3;\n\t\t} else if (2 * t3 < 1) {\n\t\t\tval = t2;\n\t\t} else if (3 * t3 < 2) {\n\t\t\tval = t1 + (t2 - t1) * (2 / 3 - t3) * 6;\n\t\t} else {\n\t\t\tval = t1;\n\t\t}\n\n\t\trgb[i] = val * 255;\n\t}\n\n\treturn rgb;\n};\n\nconvert.hsl.hsv = function (hsl) {\n\tconst h = hsl[0];\n\tlet s = hsl[1] / 100;\n\tlet l = hsl[2] / 100;\n\tlet smin = s;\n\tconst lmin = Math.max(l, 0.01);\n\n\tl *= 2;\n\ts *= (l <= 1) ? l : 2 - l;\n\tsmin *= lmin <= 1 ? lmin : 2 - lmin;\n\tconst v = (l + s) / 2;\n\tconst sv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s);\n\n\treturn [h, sv * 100, v * 100];\n};\n\nconvert.hsv.rgb = function (hsv) {\n\tconst h = hsv[0] / 60;\n\tconst s = hsv[1] / 100;\n\tlet v = hsv[2] / 100;\n\tconst hi = Math.floor(h) % 6;\n\n\tconst f = h - Math.floor(h);\n\tconst p = 255 * v * (1 - s);\n\tconst q = 255 * v * (1 - (s * f));\n\tconst t = 255 * v * (1 - (s * (1 - f)));\n\tv *= 255;\n\n\tswitch (hi) {\n\t\tcase 0:\n\t\t\treturn [v, t, p];\n\t\tcase 1:\n\t\t\treturn [q, v, p];\n\t\tcase 2:\n\t\t\treturn [p, v, t];\n\t\tcase 3:\n\t\t\treturn [p, q, v];\n\t\tcase 4:\n\t\t\treturn [t, p, v];\n\t\tcase 5:\n\t\t\treturn [v, p, q];\n\t}\n};\n\nconvert.hsv.hsl = function (hsv) {\n\tconst h = hsv[0];\n\tconst s = hsv[1] / 100;\n\tconst v = hsv[2] / 100;\n\tconst vmin = Math.max(v, 0.01);\n\tlet sl;\n\tlet l;\n\n\tl = (2 - s) * v;\n\tconst lmin = (2 - s) * vmin;\n\tsl = s * vmin;\n\tsl /= (lmin <= 1) ? lmin : 2 - lmin;\n\tsl = sl || 0;\n\tl /= 2;\n\n\treturn [h, sl * 100, l * 100];\n};\n\n// http://dev.w3.org/csswg/css-color/#hwb-to-rgb\nconvert.hwb.rgb = function (hwb) {\n\tconst h = hwb[0] / 360;\n\tlet wh = hwb[1] / 100;\n\tlet bl = hwb[2] / 100;\n\tconst ratio = wh + bl;\n\tlet f;\n\n\t// Wh + bl cant be > 1\n\tif (ratio > 1) {\n\t\twh /= ratio;\n\t\tbl /= ratio;\n\t}\n\n\tconst i = Math.floor(6 * h);\n\tconst v = 1 - bl;\n\tf = 6 * h - i;\n\n\tif ((i & 0x01) !== 0) {\n\t\tf = 1 - f;\n\t}\n\n\tconst n = wh + f * (v - wh); // Linear interpolation\n\n\tlet r;\n\tlet g;\n\tlet b;\n\t/* eslint-disable max-statements-per-line,no-multi-spaces */\n\tswitch (i) {\n\t\tdefault:\n\t\tcase 6:\n\t\tcase 0: r = v; g = n; b = wh; break;\n\t\tcase 1: r = n; g = v; b = wh; break;\n\t\tcase 2: r = wh; g = v; b = n; break;\n\t\tcase 3: r = wh; g = n; b = v; break;\n\t\tcase 4: r = n; g = wh; b = v; break;\n\t\tcase 5: r = v; g = wh; b = n; break;\n\t}\n\t/* eslint-enable max-statements-per-line,no-multi-spaces */\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.cmyk.rgb = function (cmyk) {\n\tconst c = cmyk[0] / 100;\n\tconst m = cmyk[1] / 100;\n\tconst y = cmyk[2] / 100;\n\tconst k = cmyk[3] / 100;\n\n\tconst r = 1 - Math.min(1, c * (1 - k) + k);\n\tconst g = 1 - Math.min(1, m * (1 - k) + k);\n\tconst b = 1 - Math.min(1, y * (1 - k) + k);\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.xyz.rgb = function (xyz) {\n\tconst x = xyz[0] / 100;\n\tconst y = xyz[1] / 100;\n\tconst z = xyz[2] / 100;\n\tlet r;\n\tlet g;\n\tlet b;\n\n\tr = (x * 3.2406) + (y * -1.5372) + (z * -0.4986);\n\tg = (x * -0.9689) + (y * 1.8758) + (z * 0.0415);\n\tb = (x * 0.0557) + (y * -0.2040) + (z * 1.0570);\n\n\t// Assume sRGB\n\tr = r > 0.0031308\n\t\t? ((1.055 * (r ** (1.0 / 2.4))) - 0.055)\n\t\t: r * 12.92;\n\n\tg = g > 0.0031308\n\t\t? ((1.055 * (g ** (1.0 / 2.4))) - 0.055)\n\t\t: g * 12.92;\n\n\tb = b > 0.0031308\n\t\t? ((1.055 * (b ** (1.0 / 2.4))) - 0.055)\n\t\t: b * 12.92;\n\n\tr = Math.min(Math.max(0, r), 1);\n\tg = Math.min(Math.max(0, g), 1);\n\tb = Math.min(Math.max(0, b), 1);\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.xyz.lab = function (xyz) {\n\tlet x = xyz[0];\n\tlet y = xyz[1];\n\tlet z = xyz[2];\n\n\tx /= 95.047;\n\ty /= 100;\n\tz /= 108.883;\n\n\tx = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);\n\ty = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);\n\tz = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);\n\n\tconst l = (116 * y) - 16;\n\tconst a = 500 * (x - y);\n\tconst b = 200 * (y - z);\n\n\treturn [l, a, b];\n};\n\nconvert.lab.xyz = function (lab) {\n\tconst l = lab[0];\n\tconst a = lab[1];\n\tconst b = lab[2];\n\tlet x;\n\tlet y;\n\tlet z;\n\n\ty = (l + 16) / 116;\n\tx = a / 500 + y;\n\tz = y - b / 200;\n\n\tconst y2 = y ** 3;\n\tconst x2 = x ** 3;\n\tconst z2 = z ** 3;\n\ty = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787;\n\tx = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787;\n\tz = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787;\n\n\tx *= 95.047;\n\ty *= 100;\n\tz *= 108.883;\n\n\treturn [x, y, z];\n};\n\nconvert.lab.lch = function (lab) {\n\tconst l = lab[0];\n\tconst a = lab[1];\n\tconst b = lab[2];\n\tlet h;\n\n\tconst hr = Math.atan2(b, a);\n\th = hr * 360 / 2 / Math.PI;\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tconst c = Math.sqrt(a * a + b * b);\n\n\treturn [l, c, h];\n};\n\nconvert.lch.lab = function (lch) {\n\tconst l = lch[0];\n\tconst c = lch[1];\n\tconst h = lch[2];\n\n\tconst hr = h / 360 * 2 * Math.PI;\n\tconst a = c * Math.cos(hr);\n\tconst b = c * Math.sin(hr);\n\n\treturn [l, a, b];\n};\n\nconvert.rgb.ansi16 = function (args, saturation = null) {\n\tconst [r, g, b] = args;\n\tlet value = saturation === null ? convert.rgb.hsv(args)[2] : saturation; // Hsv -> ansi16 optimization\n\n\tvalue = Math.round(value / 50);\n\n\tif (value === 0) {\n\t\treturn 30;\n\t}\n\n\tlet ansi = 30\n\t\t+ ((Math.round(b / 255) << 2)\n\t\t| (Math.round(g / 255) << 1)\n\t\t| Math.round(r / 255));\n\n\tif (value === 2) {\n\t\tansi += 60;\n\t}\n\n\treturn ansi;\n};\n\nconvert.hsv.ansi16 = function (args) {\n\t// Optimization here; we already know the value and don't need to get\n\t// it converted for us.\n\treturn convert.rgb.ansi16(convert.hsv.rgb(args), args[2]);\n};\n\nconvert.rgb.ansi256 = function (args) {\n\tconst r = args[0];\n\tconst g = args[1];\n\tconst b = args[2];\n\n\t// We use the extended greyscale palette here, with the exception of\n\t// black and white. normal palette only has 4 greyscale shades.\n\tif (r === g && g === b) {\n\t\tif (r < 8) {\n\t\t\treturn 16;\n\t\t}\n\n\t\tif (r > 248) {\n\t\t\treturn 231;\n\t\t}\n\n\t\treturn Math.round(((r - 8) / 247) * 24) + 232;\n\t}\n\n\tconst ansi = 16\n\t\t+ (36 * Math.round(r / 255 * 5))\n\t\t+ (6 * Math.round(g / 255 * 5))\n\t\t+ Math.round(b / 255 * 5);\n\n\treturn ansi;\n};\n\nconvert.ansi16.rgb = function (args) {\n\tlet color = args % 10;\n\n\t// Handle greyscale\n\tif (color === 0 || color === 7) {\n\t\tif (args > 50) {\n\t\t\tcolor += 3.5;\n\t\t}\n\n\t\tcolor = color / 10.5 * 255;\n\n\t\treturn [color, color, color];\n\t}\n\n\tconst mult = (~~(args > 50) + 1) * 0.5;\n\tconst r = ((color & 1) * mult) * 255;\n\tconst g = (((color >> 1) & 1) * mult) * 255;\n\tconst b = (((color >> 2) & 1) * mult) * 255;\n\n\treturn [r, g, b];\n};\n\nconvert.ansi256.rgb = function (args) {\n\t// Handle greyscale\n\tif (args >= 232) {\n\t\tconst c = (args - 232) * 10 + 8;\n\t\treturn [c, c, c];\n\t}\n\n\targs -= 16;\n\n\tlet rem;\n\tconst r = Math.floor(args / 36) / 5 * 255;\n\tconst g = Math.floor((rem = args % 36) / 6) / 5 * 255;\n\tconst b = (rem % 6) / 5 * 255;\n\n\treturn [r, g, b];\n};\n\nconvert.rgb.hex = function (args) {\n\tconst integer = ((Math.round(args[0]) & 0xFF) << 16)\n\t\t+ ((Math.round(args[1]) & 0xFF) << 8)\n\t\t+ (Math.round(args[2]) & 0xFF);\n\n\tconst string = integer.toString(16).toUpperCase();\n\treturn '000000'.substring(string.length) + string;\n};\n\nconvert.hex.rgb = function (args) {\n\tconst match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);\n\tif (!match) {\n\t\treturn [0, 0, 0];\n\t}\n\n\tlet colorString = match[0];\n\n\tif (match[0].length === 3) {\n\t\tcolorString = colorString.split('').map(char => {\n\t\t\treturn char + char;\n\t\t}).join('');\n\t}\n\n\tconst integer = parseInt(colorString, 16);\n\tconst r = (integer >> 16) & 0xFF;\n\tconst g = (integer >> 8) & 0xFF;\n\tconst b = integer & 0xFF;\n\n\treturn [r, g, b];\n};\n\nconvert.rgb.hcg = function (rgb) {\n\tconst r = rgb[0] / 255;\n\tconst g = rgb[1] / 255;\n\tconst b = rgb[2] / 255;\n\tconst max = Math.max(Math.max(r, g), b);\n\tconst min = Math.min(Math.min(r, g), b);\n\tconst chroma = (max - min);\n\tlet grayscale;\n\tlet hue;\n\n\tif (chroma < 1) {\n\t\tgrayscale = min / (1 - chroma);\n\t} else {\n\t\tgrayscale = 0;\n\t}\n\n\tif (chroma <= 0) {\n\t\thue = 0;\n\t} else\n\tif (max === r) {\n\t\thue = ((g - b) / chroma) % 6;\n\t} else\n\tif (max === g) {\n\t\thue = 2 + (b - r) / chroma;\n\t} else {\n\t\thue = 4 + (r - g) / chroma;\n\t}\n\n\thue /= 6;\n\thue %= 1;\n\n\treturn [hue * 360, chroma * 100, grayscale * 100];\n};\n\nconvert.hsl.hcg = function (hsl) {\n\tconst s = hsl[1] / 100;\n\tconst l = hsl[2] / 100;\n\n\tconst c = l < 0.5 ? (2.0 * s * l) : (2.0 * s * (1.0 - l));\n\n\tlet f = 0;\n\tif (c < 1.0) {\n\t\tf = (l - 0.5 * c) / (1.0 - c);\n\t}\n\n\treturn [hsl[0], c * 100, f * 100];\n};\n\nconvert.hsv.hcg = function (hsv) {\n\tconst s = hsv[1] / 100;\n\tconst v = hsv[2] / 100;\n\n\tconst c = s * v;\n\tlet f = 0;\n\n\tif (c < 1.0) {\n\t\tf = (v - c) / (1 - c);\n\t}\n\n\treturn [hsv[0], c * 100, f * 100];\n};\n\nconvert.hcg.rgb = function (hcg) {\n\tconst h = hcg[0] / 360;\n\tconst c = hcg[1] / 100;\n\tconst g = hcg[2] / 100;\n\n\tif (c === 0.0) {\n\t\treturn [g * 255, g * 255, g * 255];\n\t}\n\n\tconst pure = [0, 0, 0];\n\tconst hi = (h % 1) * 6;\n\tconst v = hi % 1;\n\tconst w = 1 - v;\n\tlet mg = 0;\n\n\t/* eslint-disable max-statements-per-line */\n\tswitch (Math.floor(hi)) {\n\t\tcase 0:\n\t\t\tpure[0] = 1; pure[1] = v; pure[2] = 0; break;\n\t\tcase 1:\n\t\t\tpure[0] = w; pure[1] = 1; pure[2] = 0; break;\n\t\tcase 2:\n\t\t\tpure[0] = 0; pure[1] = 1; pure[2] = v; break;\n\t\tcase 3:\n\t\t\tpure[0] = 0; pure[1] = w; pure[2] = 1; break;\n\t\tcase 4:\n\t\t\tpure[0] = v; pure[1] = 0; pure[2] = 1; break;\n\t\tdefault:\n\t\t\tpure[0] = 1; pure[1] = 0; pure[2] = w;\n\t}\n\t/* eslint-enable max-statements-per-line */\n\n\tmg = (1.0 - c) * g;\n\n\treturn [\n\t\t(c * pure[0] + mg) * 255,\n\t\t(c * pure[1] + mg) * 255,\n\t\t(c * pure[2] + mg) * 255\n\t];\n};\n\nconvert.hcg.hsv = function (hcg) {\n\tconst c = hcg[1] / 100;\n\tconst g = hcg[2] / 100;\n\n\tconst v = c + g * (1.0 - c);\n\tlet f = 0;\n\n\tif (v > 0.0) {\n\t\tf = c / v;\n\t}\n\n\treturn [hcg[0], f * 100, v * 100];\n};\n\nconvert.hcg.hsl = function (hcg) {\n\tconst c = hcg[1] / 100;\n\tconst g = hcg[2] / 100;\n\n\tconst l = g * (1.0 - c) + 0.5 * c;\n\tlet s = 0;\n\n\tif (l > 0.0 && l < 0.5) {\n\t\ts = c / (2 * l);\n\t} else\n\tif (l >= 0.5 && l < 1.0) {\n\t\ts = c / (2 * (1 - l));\n\t}\n\n\treturn [hcg[0], s * 100, l * 100];\n};\n\nconvert.hcg.hwb = function (hcg) {\n\tconst c = hcg[1] / 100;\n\tconst g = hcg[2] / 100;\n\tconst v = c + g * (1.0 - c);\n\treturn [hcg[0], (v - c) * 100, (1 - v) * 100];\n};\n\nconvert.hwb.hcg = function (hwb) {\n\tconst w = hwb[1] / 100;\n\tconst b = hwb[2] / 100;\n\tconst v = 1 - b;\n\tconst c = v - w;\n\tlet g = 0;\n\n\tif (c < 1) {\n\t\tg = (v - c) / (1 - c);\n\t}\n\n\treturn [hwb[0], c * 100, g * 100];\n};\n\nconvert.apple.rgb = function (apple) {\n\treturn [(apple[0] / 65535) * 255, (apple[1] / 65535) * 255, (apple[2] / 65535) * 255];\n};\n\nconvert.rgb.apple = function (rgb) {\n\treturn [(rgb[0] / 255) * 65535, (rgb[1] / 255) * 65535, (rgb[2] / 255) * 65535];\n};\n\nconvert.gray.rgb = function (args) {\n\treturn [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255];\n};\n\nconvert.gray.hsl = function (args) {\n\treturn [0, 0, args[0]];\n};\n\nconvert.gray.hsv = convert.gray.hsl;\n\nconvert.gray.hwb = function (gray) {\n\treturn [0, 100, gray[0]];\n};\n\nconvert.gray.cmyk = function (gray) {\n\treturn [0, 0, 0, gray[0]];\n};\n\nconvert.gray.lab = function (gray) {\n\treturn [gray[0], 0, 0];\n};\n\nconvert.gray.hex = function (gray) {\n\tconst val = Math.round(gray[0] / 100 * 255) & 0xFF;\n\tconst integer = (val << 16) + (val << 8) + val;\n\n\tconst string = integer.toString(16).toUpperCase();\n\treturn '000000'.substring(string.length) + string;\n};\n\nconvert.rgb.gray = function (rgb) {\n\tconst val = (rgb[0] + rgb[1] + rgb[2]) / 3;\n\treturn [val / 255 * 100];\n};\n","const conversions = require('./conversions');\n\n/*\n\tThis function routes a model to all other models.\n\n\tall functions that are routed have a property `.conversion` attached\n\tto the returned synthetic function. This property is an array\n\tof strings, each with the steps in between the 'from' and 'to'\n\tcolor models (inclusive).\n\n\tconversions that are not possible simply are not included.\n*/\n\nfunction buildGraph() {\n\tconst graph = {};\n\t// https://jsperf.com/object-keys-vs-for-in-with-closure/3\n\tconst models = Object.keys(conversions);\n\n\tfor (let len = models.length, i = 0; i < len; i++) {\n\t\tgraph[models[i]] = {\n\t\t\t// http://jsperf.com/1-vs-infinity\n\t\t\t// micro-opt, but this is simple.\n\t\t\tdistance: -1,\n\t\t\tparent: null\n\t\t};\n\t}\n\n\treturn graph;\n}\n\n// https://en.wikipedia.org/wiki/Breadth-first_search\nfunction deriveBFS(fromModel) {\n\tconst graph = buildGraph();\n\tconst queue = [fromModel]; // Unshift -> queue -> pop\n\n\tgraph[fromModel].distance = 0;\n\n\twhile (queue.length) {\n\t\tconst current = queue.pop();\n\t\tconst adjacents = Object.keys(conversions[current]);\n\n\t\tfor (let len = adjacents.length, i = 0; i < len; i++) {\n\t\t\tconst adjacent = adjacents[i];\n\t\t\tconst node = graph[adjacent];\n\n\t\t\tif (node.distance === -1) {\n\t\t\t\tnode.distance = graph[current].distance + 1;\n\t\t\t\tnode.parent = current;\n\t\t\t\tqueue.unshift(adjacent);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn graph;\n}\n\nfunction link(from, to) {\n\treturn function (args) {\n\t\treturn to(from(args));\n\t};\n}\n\nfunction wrapConversion(toModel, graph) {\n\tconst path = [graph[toModel].parent, toModel];\n\tlet fn = conversions[graph[toModel].parent][toModel];\n\n\tlet cur = graph[toModel].parent;\n\twhile (graph[cur].parent) {\n\t\tpath.unshift(graph[cur].parent);\n\t\tfn = link(conversions[graph[cur].parent][cur], fn);\n\t\tcur = graph[cur].parent;\n\t}\n\n\tfn.conversion = path;\n\treturn fn;\n}\n\nmodule.exports = function (fromModel) {\n\tconst graph = deriveBFS(fromModel);\n\tconst conversion = {};\n\n\tconst models = Object.keys(graph);\n\tfor (let len = models.length, i = 0; i < len; i++) {\n\t\tconst toModel = models[i];\n\t\tconst node = graph[toModel];\n\n\t\tif (node.parent === null) {\n\t\t\t// No possible conversion, or this node is the source model.\n\t\t\tcontinue;\n\t\t}\n\n\t\tconversion[toModel] = wrapConversion(toModel, graph);\n\t}\n\n\treturn conversion;\n};\n\n","\"use strict\";\n\nimport { StyleSheet } from 'react-native';\nexport const sharedStyles = StyleSheet.create({\n flexDirectionRow: {\n flexDirection: 'row'\n },\n opacity0: {\n opacity: 0\n },\n opacity1: {\n opacity: 1\n },\n overflowHidden: {\n overflow: 'hidden'\n },\n root: {\n flex: 1\n }\n});\n//# sourceMappingURL=styles.js.map","\"use strict\";\n\nimport { StyleSheet, View } from 'react-native';\nimport { IconButton, useTheme } from 'react-native-paper';\nimport DayNames, { dayNamesHeight } from './DayNames';\nimport { getTranslation } from '../translations/utils';\nimport { sharedStyles } from '../shared/styles';\nimport React, { memo } from 'react';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nconst buttonContainerHeight = 56;\nconst buttonContainerMarginTop = 4;\nconst buttonContainerMarginBottom = 8;\nexport function getCalendarHeaderHeight(scrollMode) {\n if (scrollMode === 'horizontal') {\n return buttonContainerHeight + buttonContainerMarginTop + buttonContainerMarginBottom + dayNamesHeight;\n }\n return dayNamesHeight;\n}\nfunction CalendarHeader({\n scrollMode,\n onPrev,\n onNext,\n disableWeekDays,\n locale,\n startWeekOnMonday\n}) {\n const isHorizontal = scrollMode === 'horizontal';\n const theme = useTheme();\n return /*#__PURE__*/_jsxs(View, {\n style: styles.datePickerHeader,\n pointerEvents: 'box-none',\n children: [isHorizontal ? /*#__PURE__*/_jsxs(View, {\n style: styles.buttonContainer,\n pointerEvents: 'box-none',\n children: [/*#__PURE__*/_jsx(View, {\n style: sharedStyles.root,\n pointerEvents: 'box-none'\n }), /*#__PURE__*/_jsx(View, {\n style: {\n backgroundColor: theme.colors.surface\n },\n children: /*#__PURE__*/_jsx(IconButton, {\n icon: \"chevron-left\",\n accessibilityLabel: getTranslation(locale, 'previous'),\n onPress: onPrev\n })\n }), /*#__PURE__*/_jsx(View, {\n style: {\n backgroundColor: theme.colors.surface\n },\n children: /*#__PURE__*/_jsx(IconButton, {\n icon: \"chevron-right\",\n accessibilityLabel: getTranslation(locale, 'next'),\n onPress: onNext\n })\n })]\n }) : null, /*#__PURE__*/_jsx(DayNames, {\n disableWeekDays: disableWeekDays,\n locale: locale,\n startWeekOnMonday: startWeekOnMonday\n })]\n });\n}\nconst styles = StyleSheet.create({\n datePickerHeader: {\n position: 'absolute',\n top: 0,\n right: 0,\n left: 0,\n zIndex: 10\n },\n buttonContainer: {\n height: buttonContainerHeight,\n marginTop: buttonContainerMarginTop,\n marginBottom: buttonContainerMarginBottom,\n flexDirection: 'row',\n alignItems: 'center'\n }\n});\nexport default /*#__PURE__*/memo(CalendarHeader);\n//# sourceMappingURL=CalendarHeader.js.map","\"use strict\";\n\nimport { StyleSheet, View } from 'react-native';\nimport DayName from './DayName';\nimport { useTheme } from 'react-native-paper';\nimport { showWeekDay } from './dateUtils';\nimport React, { memo, useMemo } from 'react';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport const dayNamesHeight = 44;\nfunction DayNames({\n disableWeekDays,\n locale,\n startWeekOnMonday\n}) {\n const theme = useTheme();\n const shortDayNames = useMemo(() => {\n // TODO: wait for a better Intl api ;-)\n const weekdays = [new Date(2020, 7, 2), new Date(2020, 7, 3), new Date(2020, 7, 4), new Date(2020, 7, 5), new Date(2020, 7, 6), new Date(2020, 7, 7), new Date(2020, 7, 8)];\n if (startWeekOnMonday) {\n weekdays.push(weekdays.shift());\n }\n const formatter = new Intl.DateTimeFormat(locale, {\n weekday: 'narrow'\n });\n return weekdays.map(date => formatter.format(date));\n }, [locale, startWeekOnMonday]);\n return /*#__PURE__*/_jsx(View, {\n style: [styles.dayNames, {\n backgroundColor: theme.colors.surface\n }],\n pointerEvents: \"none\",\n children: shortDayNames.filter((_, dayIndex) => showWeekDay(dayIndex, disableWeekDays)).map((dayName, i) => /*#__PURE__*/_jsx(DayName, {\n label: dayName\n }, `${dayName}_${i}`))\n });\n}\nconst styles = StyleSheet.create({\n dayNames: {\n alignItems: 'center',\n backgroundColor: '#fff',\n flexDirection: 'row',\n height: dayNamesHeight\n }\n});\nexport default /*#__PURE__*/memo(DayNames);\n//# sourceMappingURL=DayNames.js.map","\"use strict\";\n\nimport React, { memo } from 'react';\nimport { StyleSheet, View } from 'react-native';\nimport { Text, useTheme } from 'react-native-paper';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction DayName({\n label\n}) {\n const theme = useTheme();\n let textFont = theme?.isV3 ? theme.fonts.bodySmall : theme.fonts.medium;\n return /*#__PURE__*/_jsx(View, {\n style: styles.dayName,\n children: /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.dayNameLabel, {\n ...textFont,\n color: theme.colors.onSurface\n }],\n selectable: false,\n children: label\n })\n });\n}\nconst styles = StyleSheet.create({\n dayName: {\n alignItems: 'center',\n flex: 1\n },\n dayNameLabel: {\n fontSize: 14,\n opacity: 0.7\n }\n});\nexport default /*#__PURE__*/memo(DayName);\n//# sourceMappingURL=DayName.js.map","\"use strict\";\n\nlet translationsPerLocale = {};\nexport function getTranslation(locale, key, fallback) {\n const l = locale || 'en';\n const translationForLocale = translationsPerLocale[l];\n if (!translationForLocale) {\n console.warn(`[react-native-paper-dates] The locale ${locale} is not registered, see README!, key: ${key}`);\n return fallback || key;\n }\n const translation = translationsPerLocale[l][key];\n if (!translation) {\n console.warn(`[react-native-paper-dates] The locale ${locale} is registered, but ${key} is missing`);\n }\n return translation || fallback || key;\n}\nexport function registerTranslation(locale, translations) {\n translationsPerLocale[locale] = translations;\n}\n//# sourceMappingURL=utils.js.map","\"use strict\";\n\nimport { useEffect } from 'react';\nimport { useLatest } from '../shared/utils';\nimport { addMonths, differenceInMonths, getRealIndex, startAtIndex } from './dateUtils';\nexport function useYearChange(onChange, {\n selectedYear,\n currentIndexRef\n}) {\n const onChangeRef = useLatest(onChange);\n useEffect(() => {\n if (selectedYear) {\n const currentIndex = currentIndexRef.current || 0;\n const currentDate = addMonths(new Date(), getRealIndex(currentIndex));\n currentDate.setFullYear(selectedYear);\n const today = new Date();\n const months = differenceInMonths(today, currentDate);\n const newIndex = startAtIndex + months;\n if (currentIndex !== newIndex) {\n onChangeRef.current(newIndex);\n }\n }\n }, [currentIndexRef, onChangeRef, selectedYear]);\n}\n//# sourceMappingURL=SwiperUtils.js.map","\"use strict\";\n\nimport React from 'react';\nimport { useCallback, useState } from 'react';\nimport { View } from 'react-native';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function AutoSizer({\n children\n}) {\n const [layout, setLayout] = useState(null);\n const onLayout = useCallback(event => {\n const nl = event.nativeEvent.layout;\n // https://github.com/necolas/react-native-web/issues/1704\n if (!layout || layout.width !== nl.width || layout.height !== nl.height) {\n setLayout({\n width: nl.width,\n height: nl.height\n });\n }\n }, [layout, setLayout]);\n return /*#__PURE__*/_jsx(View, {\n onLayout: onLayout,\n style: [sharedStyles.overflowHidden, sharedStyles.root, layout && layout],\n children: layout ? children(layout) : null\n });\n}\n//# sourceMappingURL=AutoSizer.js.map","\"use strict\";\n\nimport { FlatList, StyleSheet, View, ScrollView } from 'react-native';\nimport { Text, TouchableRipple, useTheme } from 'react-native-paper';\nimport { range } from '../shared/utils';\nimport { memo, useEffect, useRef } from 'react';\nimport React from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst ITEM_HEIGHT = 62;\nexport default function YearPicker({\n selectedYear,\n selectingYear,\n onPressYear,\n startYear,\n endYear\n}) {\n const theme = useTheme();\n const flatList = useRef(null);\n const years = range(isNaN(startYear) ? 1800 : startYear, isNaN(endYear) ? 2200 : endYear);\n\n // scroll to selected year\n useEffect(() => {\n if (flatList.current && selectedYear) {\n const indexToGo = selectedYear - startYear;\n flatList.current.scrollToOffset({\n offset: indexToGo / 3 * ITEM_HEIGHT - ITEM_HEIGHT,\n animated: false\n });\n }\n }, [flatList, selectedYear, startYear]);\n return /*#__PURE__*/_jsx(View, {\n style: [StyleSheet.absoluteFill, styles.root, {\n backgroundColor: theme.colors.surface\n }, selectingYear ? sharedStyles.opacity1 : sharedStyles.opacity0],\n pointerEvents: selectingYear ? 'auto' : 'none',\n children: /*#__PURE__*/_jsx(FlatList, {\n ref: flatList,\n style: sharedStyles.root,\n data: years,\n renderScrollComponent: sProps => {\n return /*#__PURE__*/_jsx(ScrollView, {\n ...sProps\n });\n },\n renderItem: ({\n item\n }) => /*#__PURE__*/_jsx(Year, {\n year: item,\n selected: selectedYear === item,\n onPressYear: onPressYear\n }),\n keyExtractor: item => `${item}`,\n numColumns: 3\n })\n });\n}\nfunction YearPure({\n year,\n selected,\n onPressYear\n}) {\n const theme = useTheme();\n let textFont = theme?.isV3 ? theme.fonts.bodyLarge : theme.fonts.medium;\n return /*#__PURE__*/_jsx(View, {\n style: styles.year,\n children: /*#__PURE__*/_jsx(TouchableRipple, {\n onPress: () => onPressYear(year),\n accessibilityRole: \"button\",\n accessibilityLabel: String(year),\n style: styles.yearButton,\n children: /*#__PURE__*/_jsx(View, {\n style: [styles.yearInner, selected ? {\n backgroundColor: theme.colors.primary\n } : null],\n children: /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.yearLabel, selected ?\n // eslint-disable-next-line react-native/no-inline-styles\n {\n color: theme.isV3 ? theme.colors.onPrimary : '#fff'\n } : {\n color: theme.isV3 ? theme.colors.onSurfaceVariant : theme.colors.onSurface\n }, {\n ...textFont\n }],\n selectable: false,\n children: year\n })\n })\n })\n });\n}\nconst styles = StyleSheet.create({\n root: {\n flex: 1,\n top: 56,\n zIndex: 100\n },\n year: {\n flex: 1,\n marginLeft: 16,\n marginRight: 16,\n height: ITEM_HEIGHT,\n justifyContent: 'center'\n },\n yearButton: {\n borderRadius: 46 / 2,\n overflow: 'hidden'\n },\n yearInner: {\n borderRadius: 46 / 2,\n height: 46,\n alignItems: 'center',\n justifyContent: 'center'\n },\n yearLabel: {\n fontSize: 16\n }\n});\nconst Year = /*#__PURE__*/memo(YearPure);\n//# sourceMappingURL=YearPicker.js.map","\"use strict\";\n\nimport { Modal, StyleSheet, TouchableWithoutFeedback, useWindowDimensions, View, Platform } from 'react-native';\nimport { useTheme } from 'react-native-paper';\nimport DatePickerModalContent from './DatePickerModalContent';\nimport React, { memo } from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { supportedOrientations } from '../shared/utils';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nexport function DatePickerModal(props) {\n const {\n visible,\n animationType,\n disableStatusBar,\n disableStatusBarPadding,\n inputEnabled,\n presentationStyle,\n statusBarOnTopOfBackdrop,\n ...rest\n } = props;\n const animationTypeCalculated = animationType || Platform.select({\n web: 'none',\n default: 'slide'\n });\n const isPageSheet = presentationStyle === 'pageSheet' && Platform.OS === 'ios';\n const theme = useTheme();\n const dimensions = useWindowDimensions();\n return /*#__PURE__*/_jsx(View, {\n style: StyleSheet.absoluteFill,\n pointerEvents: \"box-none\",\n children: /*#__PURE__*/_jsxs(Modal, {\n animationType: animationTypeCalculated,\n transparent: !isPageSheet,\n visible: visible,\n onRequestClose: rest.onDismiss,\n presentationStyle: isPageSheet ? 'pageSheet' : 'overFullScreen',\n supportedOrientations: supportedOrientations,\n statusBarTranslucent: true,\n children: [/*#__PURE__*/_jsx(TouchableWithoutFeedback, {\n onPress: rest.onDismiss,\n children: /*#__PURE__*/_jsx(View, {\n style: [StyleSheet.absoluteFill, sharedStyles.root, {\n backgroundColor: theme.colors.backdrop\n }]\n })\n }), /*#__PURE__*/_jsx(View, {\n style: [StyleSheet.absoluteFill, styles.modalRoot],\n pointerEvents: \"box-none\",\n children: /*#__PURE__*/_jsx(View, {\n style: [styles.modalContent, {\n backgroundColor: theme.colors.surface\n }, dimensions.width > 650 ? styles.modalContentBig : null],\n children: /*#__PURE__*/_jsx(DatePickerModalContent, {\n ...rest,\n inputEnabled: inputEnabled,\n disableSafeTop: disableStatusBarPadding,\n disableStatusBar: disableStatusBar,\n statusBarOnTopOfBackdrop: isPageSheet || statusBarOnTopOfBackdrop\n })\n })\n })]\n })\n });\n}\nconst styles = StyleSheet.create({\n modalContent: {\n flex: 1,\n width: '100%'\n },\n modalContentBig: {\n maxWidth: 600,\n maxHeight: 800,\n borderRadius: 10,\n width: '100%',\n overflow: 'hidden'\n },\n modalRoot: {\n justifyContent: 'center',\n alignItems: 'center',\n flex: 1\n }\n});\nexport default /*#__PURE__*/memo(DatePickerModal);\n//# sourceMappingURL=DatePickerModal.js.map","import _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"animationType\", \"children\", \"onDismiss\", \"onRequestClose\", \"onShow\", \"transparent\", \"visible\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport ModalPortal from './ModalPortal';\nimport ModalAnimation from './ModalAnimation';\nimport ModalContent from './ModalContent';\nimport ModalFocusTrap from './ModalFocusTrap';\nvar uniqueModalIdentifier = 0;\nvar activeModalStack = [];\nvar activeModalListeners = {};\nfunction notifyActiveModalListeners() {\n if (activeModalStack.length === 0) {\n return;\n }\n var activeModalId = activeModalStack[activeModalStack.length - 1];\n activeModalStack.forEach(modalId => {\n if (modalId in activeModalListeners) {\n activeModalListeners[modalId](modalId === activeModalId);\n }\n });\n}\nfunction removeActiveModal(modalId) {\n if (modalId in activeModalListeners) {\n // Before removing this listener we should probably tell it\n // that it's no longer the active modal for sure.\n activeModalListeners[modalId](false);\n delete activeModalListeners[modalId];\n }\n var index = activeModalStack.indexOf(modalId);\n if (index !== -1) {\n activeModalStack.splice(index, 1);\n notifyActiveModalListeners();\n }\n}\nfunction addActiveModal(modalId, listener) {\n removeActiveModal(modalId);\n activeModalStack.push(modalId);\n activeModalListeners[modalId] = listener;\n notifyActiveModalListeners();\n}\nvar Modal = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var animationType = props.animationType,\n children = props.children,\n onDismiss = props.onDismiss,\n onRequestClose = props.onRequestClose,\n onShow = props.onShow,\n transparent = props.transparent,\n _props$visible = props.visible,\n visible = _props$visible === void 0 ? true : _props$visible,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n\n // Set a unique model identifier so we can correctly route\n // dismissals and check the layering of modals.\n var modalId = React.useMemo(() => uniqueModalIdentifier++, []);\n var _React$useState = React.useState(false),\n isActive = _React$useState[0],\n setIsActive = _React$useState[1];\n var onDismissCallback = React.useCallback(() => {\n removeActiveModal(modalId);\n if (onDismiss) {\n onDismiss();\n }\n }, [modalId, onDismiss]);\n var onShowCallback = React.useCallback(() => {\n addActiveModal(modalId, setIsActive);\n if (onShow) {\n onShow();\n }\n }, [modalId, onShow]);\n React.useEffect(() => {\n return () => removeActiveModal(modalId);\n }, [modalId]);\n return /*#__PURE__*/React.createElement(ModalPortal, null, /*#__PURE__*/React.createElement(ModalAnimation, {\n animationType: animationType,\n onDismiss: onDismissCallback,\n onShow: onShowCallback,\n visible: visible\n }, /*#__PURE__*/React.createElement(ModalFocusTrap, {\n active: isActive\n }, /*#__PURE__*/React.createElement(ModalContent, _extends({}, rest, {\n active: isActive,\n onRequestClose: onRequestClose,\n ref: forwardedRef,\n transparent: transparent\n }), children))));\n});\nexport default Modal;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport ReactDOM from 'react-dom';\nimport canUseDOM from '../../modules/canUseDom';\nfunction ModalPortal(props) {\n var children = props.children;\n var elementRef = React.useRef(null);\n if (canUseDOM && !elementRef.current) {\n var element = document.createElement('div');\n if (element && document.body) {\n document.body.appendChild(element);\n elementRef.current = element;\n }\n }\n React.useEffect(() => {\n if (canUseDOM) {\n return () => {\n if (document.body && elementRef.current) {\n document.body.removeChild(elementRef.current);\n elementRef.current = null;\n }\n };\n }\n }, []);\n return elementRef.current && canUseDOM ? /*#__PURE__*/ReactDOM.createPortal(children, elementRef.current) : null;\n}\nexport default ModalPortal;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport StyleSheet from '../StyleSheet';\nimport createElement from '../createElement';\nvar ANIMATION_DURATION = 300;\nfunction getAnimationStyle(animationType, visible) {\n if (animationType === 'slide') {\n return visible ? animatedSlideInStyles : animatedSlideOutStyles;\n }\n if (animationType === 'fade') {\n return visible ? animatedFadeInStyles : animatedFadeOutStyles;\n }\n return visible ? styles.container : styles.hidden;\n}\nfunction ModalAnimation(props) {\n var animationType = props.animationType,\n children = props.children,\n onDismiss = props.onDismiss,\n onShow = props.onShow,\n visible = props.visible;\n var _React$useState = React.useState(false),\n isRendering = _React$useState[0],\n setIsRendering = _React$useState[1];\n var wasVisible = React.useRef(false);\n var wasRendering = React.useRef(false);\n var isAnimated = animationType && animationType !== 'none';\n var animationEndCallback = React.useCallback(e => {\n if (e && e.currentTarget !== e.target) {\n // If the event was generated for something NOT this element we\n // should ignore it as it's not relevant to us\n return;\n }\n if (visible) {\n if (onShow) {\n onShow();\n }\n } else {\n setIsRendering(false);\n }\n }, [onShow, visible]);\n React.useEffect(() => {\n if (wasRendering.current && !isRendering && onDismiss) {\n onDismiss();\n }\n wasRendering.current = isRendering;\n }, [isRendering, onDismiss]);\n React.useEffect(() => {\n if (visible) {\n setIsRendering(true);\n }\n if (visible !== wasVisible.current && !isAnimated) {\n // Manually call `animationEndCallback` if no animation is used\n animationEndCallback();\n }\n wasVisible.current = visible;\n }, [isAnimated, visible, animationEndCallback]);\n return isRendering || visible ? createElement('div', {\n style: isRendering ? getAnimationStyle(animationType, visible) : styles.hidden,\n onAnimationEnd: animationEndCallback,\n children\n }) : null;\n}\nvar styles = StyleSheet.create({\n container: {\n position: 'fixed',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n zIndex: 9999\n },\n animatedIn: {\n animationDuration: ANIMATION_DURATION + \"ms\",\n animationTimingFunction: 'ease-in'\n },\n animatedOut: {\n pointerEvents: 'none',\n animationDuration: ANIMATION_DURATION + \"ms\",\n animationTimingFunction: 'ease-out'\n },\n fadeIn: {\n opacity: 1,\n animationKeyframes: {\n '0%': {\n opacity: 0\n },\n '100%': {\n opacity: 1\n }\n }\n },\n fadeOut: {\n opacity: 0,\n animationKeyframes: {\n '0%': {\n opacity: 1\n },\n '100%': {\n opacity: 0\n }\n }\n },\n slideIn: {\n transform: 'translateY(0%)',\n animationKeyframes: {\n '0%': {\n transform: 'translateY(100%)'\n },\n '100%': {\n transform: 'translateY(0%)'\n }\n }\n },\n slideOut: {\n transform: 'translateY(100%)',\n animationKeyframes: {\n '0%': {\n transform: 'translateY(0%)'\n },\n '100%': {\n transform: 'translateY(100%)'\n }\n }\n },\n hidden: {\n opacity: 0\n }\n});\nvar animatedSlideInStyles = [styles.container, styles.animatedIn, styles.slideIn];\nvar animatedSlideOutStyles = [styles.container, styles.animatedOut, styles.slideOut];\nvar animatedFadeInStyles = [styles.container, styles.animatedIn, styles.fadeIn];\nvar animatedFadeOutStyles = [styles.container, styles.animatedOut, styles.fadeOut];\nexport default ModalAnimation;","import _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"active\", \"children\", \"onRequestClose\", \"transparent\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport View from '../View';\nimport StyleSheet from '../StyleSheet';\nimport canUseDOM from '../../modules/canUseDom';\nvar ModalContent = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var active = props.active,\n children = props.children,\n onRequestClose = props.onRequestClose,\n transparent = props.transparent,\n rest = _objectWithoutPropertiesLoose(props, _excluded);\n React.useEffect(() => {\n if (canUseDOM) {\n var closeOnEscape = e => {\n if (active && e.key === 'Escape') {\n e.stopPropagation();\n if (onRequestClose) {\n onRequestClose();\n }\n }\n };\n document.addEventListener('keyup', closeOnEscape, false);\n return () => document.removeEventListener('keyup', closeOnEscape, false);\n }\n }, [active, onRequestClose]);\n var style = React.useMemo(() => {\n return [styles.modal, transparent ? styles.modalTransparent : styles.modalOpaque];\n }, [transparent]);\n return /*#__PURE__*/React.createElement(View, _extends({}, rest, {\n \"aria-modal\": true,\n ref: forwardedRef,\n role: active ? 'dialog' : null,\n style: style\n }), /*#__PURE__*/React.createElement(View, {\n style: styles.container\n }, children));\n});\nvar styles = StyleSheet.create({\n modal: {\n position: 'fixed',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n },\n modalTransparent: {\n backgroundColor: 'transparent'\n },\n modalOpaque: {\n backgroundColor: 'white'\n },\n container: {\n top: 0,\n flex: 1\n }\n});\nexport default ModalContent;","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport View from '../View';\nimport createElement from '../createElement';\nimport StyleSheet from '../StyleSheet';\nimport UIManager from '../UIManager';\nimport canUseDOM from '../../modules/canUseDom';\n\n/**\n * This Component is used to \"wrap\" the modal we're opening\n * so that changing focus via tab will never leave the document.\n *\n * This allows us to properly trap the focus within a modal\n * even if the modal is at the start or end of a document.\n */\n\nvar FocusBracket = () => {\n return createElement('div', {\n role: 'none',\n tabIndex: 0,\n style: styles.focusBracket\n });\n};\nfunction attemptFocus(element) {\n if (!canUseDOM) {\n return false;\n }\n try {\n element.focus();\n } catch (e) {\n // Do nothing\n }\n return document.activeElement === element;\n}\nfunction focusFirstDescendant(element) {\n for (var i = 0; i < element.childNodes.length; i++) {\n var child = element.childNodes[i];\n if (attemptFocus(child) || focusFirstDescendant(child)) {\n return true;\n }\n }\n return false;\n}\nfunction focusLastDescendant(element) {\n for (var i = element.childNodes.length - 1; i >= 0; i--) {\n var child = element.childNodes[i];\n if (attemptFocus(child) || focusLastDescendant(child)) {\n return true;\n }\n }\n return false;\n}\nvar ModalFocusTrap = _ref => {\n var active = _ref.active,\n children = _ref.children;\n var trapElementRef = React.useRef();\n var focusRef = React.useRef({\n trapFocusInProgress: false,\n lastFocusedElement: null\n });\n React.useEffect(() => {\n if (canUseDOM) {\n var trapFocus = () => {\n // We should not trap focus if:\n // - The modal hasn't fully initialized with an HTMLElement ref\n // - Focus is already in the process of being trapped (e.g., we're refocusing)\n // - isTrapActive prop being falsey tells us to do nothing\n if (trapElementRef.current == null || focusRef.current.trapFocusInProgress || !active) {\n return;\n }\n try {\n focusRef.current.trapFocusInProgress = true;\n if (document.activeElement instanceof Node && !trapElementRef.current.contains(document.activeElement)) {\n // To handle keyboard focusing we can make an assumption here.\n // If you're tabbing through the focusable elements, the previously\n // active element will either be the first or the last.\n // If the previously selected element is the \"first\" descendant\n // and we're leaving it - this means that we should be looping\n // around to the other side of the modal.\n var hasFocused = focusFirstDescendant(trapElementRef.current);\n if (focusRef.current.lastFocusedElement === document.activeElement) {\n hasFocused = focusLastDescendant(trapElementRef.current);\n }\n // If we couldn't focus a new element then we need to focus onto the trap target\n if (!hasFocused && trapElementRef.current != null && document.activeElement) {\n UIManager.focus(trapElementRef.current);\n }\n }\n } finally {\n focusRef.current.trapFocusInProgress = false;\n }\n focusRef.current.lastFocusedElement = document.activeElement;\n };\n\n // Call the trapFocus callback at least once when this modal has been activated.\n trapFocus();\n document.addEventListener('focus', trapFocus, true);\n return () => document.removeEventListener('focus', trapFocus, true);\n }\n }, [active]);\n\n // To be fully compliant with WCAG we need to refocus element that triggered opening modal\n // after closing it\n React.useEffect(function () {\n if (canUseDOM) {\n var lastFocusedElementOutsideTrap = document.activeElement;\n return function () {\n if (lastFocusedElementOutsideTrap && document.contains(lastFocusedElementOutsideTrap)) {\n UIManager.focus(lastFocusedElementOutsideTrap);\n }\n };\n }\n }, []);\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(FocusBracket, null), /*#__PURE__*/React.createElement(View, {\n ref: trapElementRef\n }, children), /*#__PURE__*/React.createElement(FocusBracket, null));\n};\nexport default ModalFocusTrap;\nvar styles = StyleSheet.create({\n focusBracket: {\n outlineStyle: 'none'\n }\n});","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport * as React from 'react';\nimport { useMemo, useRef } from 'react';\nimport pick from '../../modules/pick';\nimport useMergeRefs from '../../modules/useMergeRefs';\nimport usePressEvents from '../../modules/usePressEvents';\nimport { warnOnce } from '../../modules/warnOnce';\nvar forwardPropsList = {\n accessibilityDisabled: true,\n accessibilityLabel: true,\n accessibilityLiveRegion: true,\n accessibilityRole: true,\n accessibilityState: true,\n accessibilityValue: true,\n children: true,\n disabled: true,\n focusable: true,\n nativeID: true,\n onBlur: true,\n onFocus: true,\n onLayout: true,\n testID: true\n};\nvar pickProps = props => pick(props, forwardPropsList);\nfunction TouchableWithoutFeedback(props, forwardedRef) {\n warnOnce('TouchableWithoutFeedback', 'TouchableWithoutFeedback is deprecated. Please use Pressable.');\n var delayPressIn = props.delayPressIn,\n delayPressOut = props.delayPressOut,\n delayLongPress = props.delayLongPress,\n disabled = props.disabled,\n focusable = props.focusable,\n onLongPress = props.onLongPress,\n onPress = props.onPress,\n onPressIn = props.onPressIn,\n onPressOut = props.onPressOut,\n rejectResponderTermination = props.rejectResponderTermination;\n var hostRef = useRef(null);\n var pressConfig = useMemo(() => ({\n cancelable: !rejectResponderTermination,\n disabled,\n delayLongPress,\n delayPressStart: delayPressIn,\n delayPressEnd: delayPressOut,\n onLongPress,\n onPress,\n onPressStart: onPressIn,\n onPressEnd: onPressOut\n }), [disabled, delayPressIn, delayPressOut, delayLongPress, onLongPress, onPress, onPressIn, onPressOut, rejectResponderTermination]);\n var pressEventHandlers = usePressEvents(hostRef, pressConfig);\n var element = React.Children.only(props.children);\n var children = [element.props.children];\n var supportedProps = pickProps(props);\n supportedProps.accessibilityDisabled = disabled;\n supportedProps.focusable = !disabled && focusable !== false;\n supportedProps.ref = useMergeRefs(forwardedRef, hostRef, element.ref);\n var elementProps = Object.assign(supportedProps, pressEventHandlers);\n return /*#__PURE__*/React.cloneElement(element, elementProps, ...children);\n}\nvar MemoedTouchableWithoutFeedback = /*#__PURE__*/React.memo( /*#__PURE__*/React.forwardRef(TouchableWithoutFeedback));\nMemoedTouchableWithoutFeedback.displayName = 'TouchableWithoutFeedback';\nexport default MemoedTouchableWithoutFeedback;","\"use strict\";\n\nimport Calendar from './Calendar';\nimport AnimatedCrossView from './AnimatedCrossView';\nimport DatePickerModalHeader from './DatePickerModalHeader';\nimport DatePickerModalContentHeader from './DatePickerModalContentHeader';\nimport CalendarEdit from './CalendarEdit';\nimport DatePickerModalHeaderBackground from './DatePickerModalHeaderBackground';\nimport { useTheme } from 'react-native-paper';\nimport DatePickerModalStatusBar from './DatePickerModalStatusBar';\nimport React, { memo, useCallback, useEffect, useState } from 'react';\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nexport function DatePickerModalContent(props) {\n const {\n mode,\n onChange,\n onConfirm,\n onDismiss,\n disableSafeTop,\n disableStatusBar,\n disableWeekDays,\n locale,\n validRange,\n dateMode,\n startYear,\n endYear,\n statusBarOnTopOfBackdrop,\n startWeekOnMonday\n } = props;\n const theme = useTheme();\n const anyProps = props;\n const defaultUppercase = !theme.isV3;\n\n // use local state to add only onConfirm state changes\n const [state, setState] = useState({\n date: anyProps.date,\n startDate: anyProps.startDate,\n endDate: anyProps.endDate,\n dates: anyProps.dates\n });\n const [collapsed, setCollapsed] = useState(true);\n\n // update local state if changed from outside or if modal is opened\n useEffect(() => {\n setState({\n date: anyProps.date,\n startDate: anyProps.startDate,\n endDate: anyProps.endDate,\n dates: anyProps.dates\n });\n }, [anyProps.date, anyProps.startDate, anyProps.endDate, anyProps.dates]);\n const onInnerChange = useCallback(params => {\n onChange && onChange(params);\n setState(prev => ({\n ...prev,\n ...params\n }));\n }, [onChange, setState]);\n const onInnerConfirm = useCallback(() => {\n if (mode === 'single') {\n ;\n onConfirm({\n date: state.date\n });\n } else if (mode === 'range') {\n ;\n onConfirm({\n startDate: state.startDate,\n endDate: state.endDate\n });\n } else if (mode === 'multiple') {\n ;\n onConfirm({\n dates: state.dates || []\n });\n }\n }, [state, mode, onConfirm]);\n const onToggleCollapse = useCallback(() => {\n setCollapsed(prev => !prev);\n }, [setCollapsed]);\n return /*#__PURE__*/_jsxs(_Fragment, {\n children: [/*#__PURE__*/_jsxs(DatePickerModalHeaderBackground, {\n children: [/*#__PURE__*/_jsx(DatePickerModalStatusBar, {\n disableSafeTop: !!disableSafeTop,\n disableStatusBar: !!disableStatusBar,\n statusBarOnTopOfBackdrop: !!statusBarOnTopOfBackdrop\n }), /*#__PURE__*/_jsx(DatePickerModalHeader, {\n locale: locale,\n onSave: onInnerConfirm,\n onDismiss: onDismiss,\n saveLabel: props.saveLabel,\n saveLabelDisabled: props.saveLabelDisabled ?? false,\n uppercase: props.uppercase ?? defaultUppercase,\n closeIcon: props.closeIcon\n }), /*#__PURE__*/_jsx(DatePickerModalContentHeader, {\n state: state,\n mode: mode,\n collapsed: collapsed,\n onToggle: onToggleCollapse,\n headerSeparator: props.headerSeparator,\n emptyLabel: props.emptyLabel,\n label: props.label,\n moreLabel: props.moreLabel,\n startLabel: props.startLabel,\n endLabel: props.endLabel,\n uppercase: props.uppercase ?? defaultUppercase,\n locale: locale,\n editIcon: props?.editIcon,\n calendarIcon: props.calendarIcon,\n allowEditing: props.allowEditing ?? true\n })]\n }), /*#__PURE__*/_jsx(AnimatedCrossView, {\n collapsed: collapsed,\n calendar: /*#__PURE__*/_jsx(Calendar, {\n locale: locale,\n mode: mode,\n startDate: state.startDate,\n endDate: state.endDate,\n date: state.date,\n onChange: onInnerChange,\n disableWeekDays: disableWeekDays,\n dates: state.dates,\n validRange: validRange,\n dateMode: dateMode,\n startYear: startYear,\n endYear: endYear,\n startWeekOnMonday: startWeekOnMonday\n }),\n calendarEdit: /*#__PURE__*/_jsx(CalendarEdit, {\n mode: mode,\n state: state,\n label: props.label,\n startLabel: props.startLabel,\n endLabel: props.endLabel,\n collapsed: collapsed,\n onChange: onInnerChange,\n validRange: validRange,\n locale: locale,\n inputEnabled: props.inputEnabled\n })\n })]\n });\n}\nexport default /*#__PURE__*/memo(DatePickerModalContent);\n//# sourceMappingURL=DatePickerModalContent.js.map","\"use strict\";\n\nimport React from 'react';\nimport { useEffect, useRef } from 'react';\nimport { Animated, StyleSheet, View } from 'react-native';\nimport { useTheme } from 'react-native-paper';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nexport default function AnimatedCrossView({\n collapsed,\n calendar,\n calendarEdit\n}) {\n const theme = useTheme();\n const calendarOpacity = useRef(new Animated.Value(collapsed ? 1 : 0));\n useEffect(() => {\n Animated.timing(calendarOpacity.current, {\n toValue: collapsed ? 1 : 0,\n duration: 250,\n useNativeDriver: true\n }).start();\n }, [collapsed]);\n return /*#__PURE__*/_jsxs(View, {\n style: sharedStyles.root,\n children: [/*#__PURE__*/_jsx(Animated.View, {\n pointerEvents: collapsed ? 'auto' : 'none',\n style: [sharedStyles.root, {\n opacity: calendarOpacity.current,\n transform: [{\n scaleY: calendarOpacity.current.interpolate({\n inputRange: [0, 1],\n outputRange: [0.85, 1]\n })\n }, {\n scaleX: calendarOpacity.current.interpolate({\n inputRange: [0, 1],\n outputRange: [0.95, 1]\n })\n }]\n }],\n children: calendar\n }), /*#__PURE__*/_jsx(Animated.View, {\n pointerEvents: collapsed ? 'none' : 'auto',\n style: [styles.calendarEdit, {\n backgroundColor: theme.colors.surface,\n opacity: calendarOpacity.current.interpolate({\n inputRange: [0, 1],\n outputRange: [1, 0]\n }),\n transform: [{\n scale: calendarOpacity.current.interpolate({\n inputRange: [0, 1],\n outputRange: [1, 0.95]\n })\n }]\n }],\n children: calendarEdit\n })]\n });\n}\nconst styles = StyleSheet.create({\n calendarEdit: {\n position: 'absolute',\n left: 0,\n right: 0\n }\n});\n//# sourceMappingURL=AnimatedCrossView.js.map","\"use strict\";\n\nimport React from 'react';\nimport { Animated, StyleSheet } from 'react-native';\nimport { Appbar, Button, useTheme } from 'react-native-paper';\nimport { useHeaderTextColor } from '../shared/utils';\nimport { getTranslation } from '../translations/utils';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nexport default function DatePickerModalHeader(props) {\n const {\n locale,\n closeIcon = 'close'\n } = props;\n const saveLabel = props.saveLabel || getTranslation(locale, 'save');\n const color = useHeaderTextColor();\n const insets = useSafeAreaInsets();\n const theme = useTheme();\n return /*#__PURE__*/_jsx(_Fragment, {\n children: /*#__PURE__*/_jsx(Animated.View, {\n style: [styles.animated, {\n paddingLeft: insets.left,\n paddingRight: insets.right\n }],\n children: /*#__PURE__*/_jsxs(Appbar, {\n style: styles.appbarHeader,\n children: [/*#__PURE__*/_jsx(Appbar.Action, {\n icon: closeIcon,\n accessibilityLabel: getTranslation(locale, 'close'),\n onPress: props.onDismiss,\n color: color,\n testID: \"react-native-paper-dates-close\"\n }), /*#__PURE__*/_jsx(Appbar.Content, {\n title: ''\n }), /*#__PURE__*/_jsx(Button, {\n textColor: theme.isV3 ? theme.colors.primary : color,\n onPress: props.onSave,\n disabled: props.saveLabelDisabled ?? false,\n uppercase: props.uppercase ?? true,\n testID: \"react-native-paper-dates-save\",\n children: saveLabel\n })]\n })\n })\n });\n}\nconst styles = StyleSheet.create({\n animated: {\n elevation: 4\n },\n appbarHeader: {\n elevation: 0,\n backgroundColor: 'transparent'\n }\n});\n//# sourceMappingURL=DatePickerModalHeader.js.map","\"use strict\";\n\nimport { View, StyleSheet } from 'react-native';\nimport { IconButton, Text, useTheme } from 'react-native-paper';\nimport { useHeaderTextColor } from '../shared/utils';\nimport Color from 'color';\nimport { getTranslation } from '../translations/utils';\nimport React, { useMemo } from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nfunction getLabel(locale, mode, configuredLabel) {\n if (configuredLabel) {\n return configuredLabel;\n }\n if (mode === 'range') {\n return getTranslation(locale, 'selectRange');\n }\n if (mode === 'multiple') {\n return getTranslation(locale, 'selectMultiple');\n }\n if (mode === 'single') {\n return getTranslation(locale, 'selectSingle');\n }\n return '...?';\n}\nexport default function DatePickerModalContentHeader(props) {\n const {\n onToggle,\n collapsed,\n mode,\n moreLabel,\n uppercase,\n editIcon,\n calendarIcon,\n allowEditing\n } = props;\n const theme = useTheme();\n const label = getLabel(props.locale, props.mode, props.label);\n const color = useHeaderTextColor();\n const isEditingEnabled = allowEditing && mode !== 'multiple';\n const supportingTextColor = theme.isV3 ? theme.colors.onSurfaceVariant : color;\n const textFont = theme?.isV3 ? theme.fonts.labelMedium : theme.fonts.medium;\n const collapsedIcon = theme.isV3 ? 'pencil-outline' : 'pencil';\n const expandedIcon = theme.isV3 ? 'calendar-blank' : 'calendar';\n const finalCollapsedIcon = editIcon ?? collapsedIcon;\n const finalExpandedIcon = calendarIcon ?? expandedIcon;\n return /*#__PURE__*/_jsxs(View, {\n style: styles.header,\n children: [/*#__PURE__*/_jsxs(View, {\n children: [/*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.label, {\n color: supportingTextColor,\n ...textFont\n }],\n children: uppercase ? label.toUpperCase() : label\n }), /*#__PURE__*/_jsxs(View, {\n style: styles.headerContentContainer,\n children: [mode === 'range' ? /*#__PURE__*/_jsx(HeaderContentRange, {\n ...props,\n color: color\n }) : null, mode === 'single' ? /*#__PURE__*/_jsx(HeaderContentSingle, {\n ...props,\n color: color\n }) : null, mode === 'multiple' ? /*#__PURE__*/_jsx(HeaderContentMulti, {\n ...props,\n color: color,\n moreLabel: moreLabel\n }) : null]\n })]\n }), /*#__PURE__*/_jsx(View, {\n style: sharedStyles.root\n }), isEditingEnabled ? /*#__PURE__*/_jsx(IconButton, {\n icon: collapsed ? finalCollapsedIcon : finalExpandedIcon,\n accessibilityLabel: collapsed ? getTranslation(props.locale, 'typeInDate') : getTranslation(props.locale, 'pickDateFromCalendar'),\n iconColor: theme.isV3 ? theme.colors.onSurface : color,\n onPress: onToggle\n }) : null]\n });\n}\nexport function HeaderContentSingle({\n state,\n emptyLabel = ' ',\n color,\n locale\n}) {\n const theme = useTheme();\n const lighterColor = Color(color).fade(0.5).rgb().toString();\n const dateColor = state.date ? theme.isV3 ? theme.colors.onSurface : color : lighterColor;\n const formatter = useMemo(() => {\n return new Intl.DateTimeFormat(locale, {\n month: 'short',\n day: 'numeric'\n });\n }, [locale]);\n return /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.text, {\n color: dateColor\n }],\n children: state.date ? formatter.format(state.date) : emptyLabel\n });\n}\nexport function HeaderContentMulti({\n state,\n emptyLabel = ' ',\n moreLabel = 'more',\n color,\n locale\n}) {\n const theme = useTheme();\n const dateCount = state.dates?.length || 0;\n const lighterColor = Color(color).fade(0.5).rgb().toString();\n const dateColor = dateCount ? theme.isV3 ? theme.colors.onSurface : color : lighterColor;\n const formatter = useMemo(() => {\n return new Intl.DateTimeFormat(locale, {\n month: 'short',\n day: 'numeric'\n });\n }, [locale]);\n let label = emptyLabel;\n if (dateCount) {\n if (dateCount <= 2) {\n label = state.dates.map(date => formatter.format(date)).join(', ');\n } else {\n label = formatter.format(state.dates[0]) + ` (+ ${dateCount - 1} ${moreLabel})`;\n }\n }\n return /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.text, {\n color: dateColor\n }],\n children: label\n });\n}\nexport function HeaderContentRange({\n locale,\n state,\n headerSeparator = '-',\n startLabel = 'Start',\n endLabel = 'End',\n color\n}) {\n const theme = useTheme();\n const lighterColor = Color(color).fade(0.5).rgb().toString();\n const startColorFilled = theme.isV3 ? theme.colors.onSurface : color;\n const endColorFilled = theme.isV3 ? theme.colors.onSurface : color;\n const startColor = state.startDate ? startColorFilled : lighterColor;\n const endColor = state.endDate ? endColorFilled : lighterColor;\n const formatter = useMemo(() => {\n return new Intl.DateTimeFormat(locale, {\n month: 'short',\n day: 'numeric'\n });\n }, [locale]);\n return /*#__PURE__*/_jsxs(_Fragment, {\n children: [/*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.text, {\n color: startColor\n }],\n children: state.startDate ? formatter.format(state.startDate) : startLabel\n }), /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.headerSeparator, {\n color\n }],\n children: headerSeparator\n }), /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.text, {\n color: endColor\n }],\n children: state.endDate ? formatter.format(state.endDate) : endLabel\n })]\n });\n}\nconst styles = StyleSheet.create({\n header: {\n height: 75,\n alignItems: 'center',\n flexDirection: 'row',\n paddingLeft: 24,\n paddingRight: 12\n },\n headerContentContainer: {\n flexDirection: 'row',\n marginTop: 5\n },\n headerSeparator: {\n color: 'rgba(255,255,255,1)',\n fontSize: 25,\n paddingLeft: 6,\n paddingRight: 6\n },\n label: {\n color: '#fff',\n fontSize: 13,\n letterSpacing: 1\n },\n text: {\n color: '#fff',\n fontSize: 25\n }\n});\n//# sourceMappingURL=DatePickerModalContentHeader.js.map","\"use strict\";\n\nimport { View, StyleSheet, Keyboard } from 'react-native';\nimport DatePickerInputWithoutModal from './DatePickerInputWithoutModal';\nimport { memo, useCallback, useEffect, useRef } from 'react';\nimport React from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction CalendarEdit({\n mode,\n state,\n label = '',\n startLabel = 'Start',\n endLabel = 'End',\n collapsed,\n onChange,\n validRange,\n locale,\n inputEnabled\n}) {\n const dateInput = useRef(null);\n const startInput = useRef(null);\n const endInput = useRef(null);\n\n // when switching views focus, or un-focus text input\n useEffect(() => {\n // hide open keyboard\n if (collapsed) {\n Keyboard.dismiss();\n }\n const inputsToFocus = [dateInput.current, startInput.current].filter(n => n);\n const inputsToBlur = [dateInput.current, startInput.current, endInput.current].filter(n => n);\n if (collapsed) {\n inputsToBlur.forEach(ip => ip.blur());\n } else {\n inputsToFocus.forEach(ip => ip.focus());\n }\n }, [mode, startInput, endInput, dateInput, collapsed]);\n const onSubmitStartInput = useCallback(() => {\n if (endInput.current) {\n endInput.current.focus();\n }\n }, [endInput]);\n const onSubmitEndInput = useCallback(() => {\n // TODO: close modal and persist range\n }, []);\n const onSubmitInput = useCallback(() => {\n // TODO: close modal and persist range\n }, []);\n return /*#__PURE__*/_jsxs(View, {\n style: styles.root,\n children: [mode === 'single' ? /*#__PURE__*/_jsx(DatePickerInputWithoutModal, {\n inputMode: \"start\",\n ref: dateInput,\n label: label,\n value: state.date,\n onChange: date => onChange({\n ...state,\n date\n }),\n onSubmitEditing: onSubmitInput,\n validRange: validRange,\n locale: locale,\n withModal: false,\n autoComplete: 'off',\n inputEnabled: inputEnabled\n }) : null, mode === 'range' ? /*#__PURE__*/_jsxs(View, {\n style: sharedStyles.flexDirectionRow,\n children: [/*#__PURE__*/_jsx(DatePickerInputWithoutModal, {\n inputMode: \"start\",\n ref: startInput,\n label: startLabel,\n value: state.startDate,\n onChange: startDate => onChange({\n ...state,\n startDate\n }),\n returnKeyType: 'next',\n onSubmitEditing: onSubmitStartInput,\n validRange: validRange,\n locale: locale,\n withModal: false,\n autoComplete: 'off',\n inputEnabled: inputEnabled\n }), /*#__PURE__*/_jsx(View, {\n style: styles.separator\n }), /*#__PURE__*/_jsx(DatePickerInputWithoutModal, {\n inputMode: \"end\",\n ref: endInput,\n label: endLabel,\n value: state.endDate,\n onChange: endDate => onChange({\n ...state,\n endDate\n }),\n onSubmitEditing: onSubmitEndInput,\n validRange: validRange,\n locale: locale,\n withModal: false,\n autoComplete: \"off\",\n inputEnabled: inputEnabled\n })]\n }) : null]\n });\n}\nconst styles = StyleSheet.create({\n root: {\n padding: 12\n },\n separator: {\n width: 12\n }\n});\nexport default /*#__PURE__*/memo(CalendarEdit);\n//# sourceMappingURL=CalendarEdit.js.map","\"use strict\";\n\nimport TextInputWithMask from '../TextInputMask';\nimport { HelperText, useTheme } from 'react-native-paper';\nimport { View, StyleSheet } from 'react-native';\nimport useDateInput from './inputUtils';\nimport React, { forwardRef } from 'react';\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nfunction DatePickerInputWithoutModal({\n label,\n value,\n onChange,\n style,\n locale,\n validRange,\n inputMode,\n withDateFormatInLabel = true,\n hasError,\n hideValidationErrors,\n onValidationError,\n modal,\n inputButton,\n saveLabel,\n saveLabelDisabled,\n uppercase,\n startYear,\n endYear,\n onChangeText,\n inputEnabled,\n disableStatusBarPadding,\n startWeekOnMonday,\n ...rest\n}, ref) {\n const theme = useTheme();\n const {\n formattedValue,\n inputFormat,\n onChangeText: onDateInputChangeText,\n error\n } = useDateInput({\n locale,\n value,\n validRange,\n inputMode,\n onChange,\n onValidationError\n });\n let disabled;\n if (inputEnabled !== undefined) {\n disabled = !inputEnabled;\n }\n if (rest.disabled) {\n disabled = rest.disabled;\n }\n return /*#__PURE__*/_jsxs(_Fragment, {\n children: [/*#__PURE__*/_jsxs(View, {\n style: styles.root,\n children: [/*#__PURE__*/_jsx(View, {\n style: styles.inputContainer,\n children: /*#__PURE__*/_jsx(TextInputWithMask, {\n ...rest,\n ref: ref,\n label: getLabel({\n // TODO: support label components?\n label: label,\n inputFormat,\n withDateFormatInLabel\n }),\n value: formattedValue,\n keyboardType: rest.keyboardType ?? 'number-pad',\n mask: inputFormat,\n disabled: disabled,\n onChangeText: onDateInputChangeText,\n onChange: e => onChangeText && onChangeText(e.nativeEvent.text),\n keyboardAppearance: rest.keyboardAppearance ?? (theme.dark ? 'dark' : 'default'),\n error: !!error && !hideValidationErrors || !!hasError,\n style: [styles.input, style],\n inputButton: inputButton\n })\n }), error && !hideValidationErrors ? /*#__PURE__*/_jsx(HelperText, {\n type: \"error\",\n visible: !!error,\n children: error\n }) : null]\n }), modal?.({\n value,\n locale,\n inputMode,\n validRange,\n saveLabel,\n saveLabelDisabled,\n uppercase,\n startYear,\n endYear,\n inputEnabled,\n disableStatusBarPadding,\n startWeekOnMonday\n })]\n });\n}\nfunction getLabel({\n withDateFormatInLabel,\n inputFormat,\n label\n}) {\n if (withDateFormatInLabel) {\n return label ? `${label} (${inputFormat})` : inputFormat;\n }\n return label || '';\n}\nconst styles = StyleSheet.create({\n root: {\n flex: 1,\n flexGrow: 1,\n justifyContent: 'center',\n alignItems: 'flex-start',\n width: '100%'\n },\n inputContainer: {\n flexGrow: 1,\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'flex-start',\n width: '100%'\n },\n input: {\n flexGrow: 1,\n width: '100%'\n }\n});\nexport default /*#__PURE__*/forwardRef(DatePickerInputWithoutModal);\n//# sourceMappingURL=DatePickerInputWithoutModal.js.map","\"use strict\";\n\nimport React, { useEffect, useState } from 'react';\nimport { forwardRef } from 'react';\nimport { TextInput } from 'react-native-paper';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst splitCharacters = ['-', '/', '.', '年', ' '];\nfunction detectCharacter(mask) {\n const c = splitCharacters.find(ch => mask.includes(ch));\n return c || '';\n}\nfunction escapeForRegExp(value) {\n return value.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n}\nfunction TextInputWithMask({\n inputButton,\n onChangeText,\n onChange,\n value,\n mask,\n disabled,\n ...rest\n}, ref) {\n const [controlledValue, setControlledValue] = useState(value || '');\n useEffect(() => {\n setControlledValue(value || '');\n }, [value]);\n const onInnerChange = text => {\n const splitCharacter = detectCharacter(mask);\n const maskParts = mask.split(splitCharacter);\n let trimmedText = text.trim();\n const format = maskParts[0].toLowerCase() + splitCharacter + maskParts[1].toLowerCase() + splitCharacter + maskParts[2].toLowerCase();\n const match = new RegExp(format.replace(/(\\w+)\\W(\\w+)\\W(\\w+)/, '^\\\\s*($1)\\\\W*($2)?\\\\W*($3)?([0-9]*).*').replace(/m|d|y/g, '\\\\d'));\n const replaceValue = format.match(/\\W/);\n const replace = `$1${splitCharacter}$2${splitCharacter}$3$4`.replace(new RegExp(escapeForRegExp(splitCharacter), 'g'), replaceValue ?? '');\n const isBackSpace = controlledValue.length > trimmedText.length;\n if (!isBackSpace) {\n trimmedText = trimmedText.replace(/(^|\\W)(?=\\d\\W)/g, '$10').replace(match, replace).replace(/(\\W)+/g, '$1');\n }\n if (trimmedText.length === mask.length) {\n onChangeText && onChangeText(trimmedText);\n }\n setControlledValue(trimmedText);\n };\n return /*#__PURE__*/_jsx(TextInput, {\n ref: ref,\n ...rest,\n disabled: disabled,\n value: controlledValue,\n onChangeText: onInnerChange,\n onChange: e => {\n onChange && onChange(e);\n },\n maxLength: 10,\n right: inputButton\n });\n}\nexport default /*#__PURE__*/forwardRef(TextInputWithMask);\n//# sourceMappingURL=TextInputMask.js.map","\"use strict\";\n\nimport { useInputFormat, useInputFormatter, useRangeChecker } from './dateUtils';\nimport { getTranslation } from '../translations/utils';\nimport { useState } from 'react';\nexport default function useDateInput({\n locale,\n value,\n validRange,\n inputMode,\n onChange,\n onValidationError\n}) {\n const formatter = useInputFormatter({\n locale\n });\n const inputFormat = useInputFormat({\n formatter,\n locale\n });\n const formattedValue = value ? formatter.format(value) : '';\n const [error, setError] = useState(null);\n const {\n isDisabled,\n isWithinValidRange,\n validStart,\n validEnd\n } = useRangeChecker(validRange);\n const onChangeText = date => {\n const dayIndex = inputFormat.indexOf('DD');\n const monthIndex = inputFormat.indexOf('MM');\n const yearIndex = locale === 'pt' ? inputFormat.indexOf('AAAA') : inputFormat.indexOf('YYYY');\n const day = Number(date.slice(dayIndex, dayIndex + 2));\n const year = Number(date.slice(yearIndex, yearIndex + 4));\n const month = Number(date.slice(monthIndex, monthIndex + 2));\n if (Number.isNaN(day) || Number.isNaN(year) || Number.isNaN(month)) {\n const inputError = getTranslation(locale, 'notAccordingToDateFormat', () => 'notAccordingToDateFormat')(inputFormat);\n setError(inputError);\n onValidationError && onValidationError(inputError);\n return;\n }\n const finalDate = inputMode === 'end' ? new Date(year, month - 1, day, 23, 59, 59) : new Date(year, month - 1, day);\n if (isDisabled(finalDate)) {\n const inputError = getTranslation(locale, 'dateIsDisabled');\n setError(inputError);\n onValidationError && onValidationError(inputError);\n return;\n }\n if (!isWithinValidRange(finalDate)) {\n let errors = validStart && validEnd ? [`${getTranslation(locale, 'mustBeBetween', () => 'mustBeBetween')(formatter.format(validStart), formatter.format(validEnd))}`] : [validStart ? getTranslation(locale, 'mustBeHigherThan', () => 'mustBeHigherThan')(formatter.format(validStart)) : '', validEnd ? getTranslation(locale, 'mustBeLowerThan', () => 'mustBeLowerThan')(formatter.format(validEnd)) : ''];\n const inputError = errors.filter(n => n).join(' ');\n setError(errors.filter(n => n).join(' '));\n onValidationError && onValidationError(inputError);\n return;\n }\n setError(null);\n onValidationError && onValidationError(null);\n if (inputMode === 'end') {\n onChange(finalDate);\n } else {\n onChange(finalDate);\n }\n };\n return {\n onChange,\n error,\n formattedValue,\n onChangeText,\n inputFormat\n };\n}\n//# sourceMappingURL=inputUtils.js.map","\"use strict\";\n\nimport React from 'react';\nimport { Animated, StyleSheet } from 'react-native';\nimport { useHeaderBackgroundColor } from '../shared/utils';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function DatePickerModalHeaderBackground({\n children\n}) {\n const backgroundColor = useHeaderBackgroundColor();\n const insets = useSafeAreaInsets();\n return /*#__PURE__*/_jsx(Animated.View, {\n style: [styles.animated, {\n backgroundColor,\n paddingLeft: insets.left,\n paddingRight: insets.right\n }],\n children: children\n });\n}\nconst styles = StyleSheet.create({\n animated: {\n elevation: 4\n }\n});\n//# sourceMappingURL=DatePickerModalHeaderBackground.js.map","\"use strict\";\n\nimport React, { memo } from 'react';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport { useHeaderBackgroundColor } from '../shared/utils';\nimport Color from 'color';\nimport { Animated, StatusBar } from 'react-native';\nimport { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction DatePickerModalStatusBar({\n disableSafeTop,\n disableStatusBar,\n statusBarOnTopOfBackdrop\n}) {\n const insets = useSafeAreaInsets();\n const headerBackgroundColor = useHeaderBackgroundColor();\n const onDarkBackground = Color(headerBackgroundColor).isDark() || statusBarOnTopOfBackdrop;\n const statusBarTheme = onDarkBackground ? 'light-content' : 'dark-content';\n const statusBarBackground = statusBarOnTopOfBackdrop ? 'transparent' : headerBackgroundColor;\n return /*#__PURE__*/_jsxs(_Fragment, {\n children: [!disableSafeTop && !statusBarOnTopOfBackdrop && /*#__PURE__*/_jsx(Animated.View, {\n style: [{\n backgroundColor: statusBarBackground,\n height: insets.top || StatusBar.currentHeight\n }]\n }), !disableStatusBar && /*#__PURE__*/_jsx(StatusBar, {\n barStyle: statusBarTheme,\n translucent: true,\n backgroundColor: \"transparent\"\n })]\n });\n}\nexport default /*#__PURE__*/memo(DatePickerModalStatusBar);\n//# sourceMappingURL=DatePickerModalStatusBar.js.map","\"use strict\";\n\nimport { Modal, StyleSheet, View, Text, Animated, TouchableWithoutFeedback, KeyboardAvoidingView } from 'react-native';\nimport { Button, IconButton, overlay, useTheme } from 'react-native-paper';\nimport TimePicker from './TimePicker';\nimport { clockTypes, getTimeInputTypeIcon, inputTypes, reverseInputTypes } from './timeUtils';\nimport React, { memo, useCallback, useEffect, useState } from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { supportedOrientations } from '../shared/utils';\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nexport function TimePickerModal({\n visible,\n onDismiss,\n onConfirm,\n hours,\n minutes,\n label = 'Select time',\n uppercase: _uppercase,\n cancelLabel = 'Cancel',\n confirmLabel = 'Ok',\n animationType = 'none',\n locale,\n keyboardIcon = 'keyboard-outline',\n clockIcon = 'clock-outline',\n use24HourClock,\n inputFontSize,\n defaultInputType\n}) {\n const theme = useTheme();\n const [inputType, setInputType] = useState(defaultInputType || inputTypes.picker);\n const [focused, setFocused] = useState(clockTypes.hours);\n const [localHours, setLocalHours] = useState(getHours(hours));\n const [localMinutes, setLocalMinutes] = useState(getMinutes(minutes));\n useEffect(() => {\n setLocalHours(getHours(hours));\n }, [setLocalHours, hours]);\n useEffect(() => {\n setLocalMinutes(getMinutes(minutes));\n }, [setLocalMinutes, minutes]);\n const onFocusInput = useCallback(type => setFocused(type), []);\n const onChange = useCallback(params => {\n if (params.focused) {\n setFocused(params.focused);\n }\n setLocalHours(params.hours);\n setLocalMinutes(params.minutes);\n }, [setFocused, setLocalHours, setLocalMinutes]);\n const defaultUppercase = !theme.isV3;\n const uppercase = _uppercase ?? defaultUppercase;\n let textFont;\n let labelText = label;\n if (theme.isV3) {\n textFont = theme.fonts.labelMedium;\n } else {\n textFont = theme?.fonts.medium;\n }\n if (inputType === inputTypes.keyboard && !label) {\n labelText = 'Enter time';\n }\n let color;\n if (theme.isV3) {\n color = theme.dark ? theme.colors.elevation.level3 : theme.colors.surface;\n } else {\n color = theme.dark ? overlay(10, theme.colors.surface) : theme.colors.surface;\n }\n return /*#__PURE__*/_jsx(Modal, {\n animationType: animationType,\n transparent: true,\n visible: visible,\n onRequestClose: onDismiss,\n presentationStyle: \"overFullScreen\",\n supportedOrientations: supportedOrientations,\n statusBarTranslucent: true,\n children: /*#__PURE__*/_jsxs(_Fragment, {\n children: [/*#__PURE__*/_jsx(TouchableWithoutFeedback, {\n onPress: onDismiss,\n children: /*#__PURE__*/_jsx(View, {\n style: [StyleSheet.absoluteFill, sharedStyles.root, {\n backgroundColor: theme.colors?.backdrop\n }]\n })\n }), /*#__PURE__*/_jsx(View, {\n style: [StyleSheet.absoluteFill, styles.center],\n pointerEvents: \"box-none\",\n children: /*#__PURE__*/_jsx(KeyboardAvoidingView, {\n style: styles.center,\n behavior: \"padding\",\n children: /*#__PURE__*/_jsxs(Animated.View, {\n style: [styles.modalContent,\n // eslint-disable-next-line react-native/no-inline-styles\n {\n backgroundColor: color,\n borderRadius: theme.isV3 ? 28 : undefined\n }],\n children: [/*#__PURE__*/_jsx(View, {\n style: styles.labelContainer,\n children: /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: [styles.label, {\n ...textFont,\n color: theme?.isV3 ? theme.colors.onSurfaceVariant : theme.colors.text\n }],\n children: uppercase ? labelText.toUpperCase() : labelText\n })\n }), /*#__PURE__*/_jsx(View, {\n style: styles.timePickerContainer,\n children: /*#__PURE__*/_jsx(TimePicker, {\n locale: locale,\n inputType: inputType,\n use24HourClock: use24HourClock,\n inputFontSize: inputFontSize,\n focused: focused,\n hours: localHours,\n minutes: localMinutes,\n onChange: onChange,\n onFocusInput: onFocusInput\n })\n }), /*#__PURE__*/_jsxs(View, {\n style: styles.bottom,\n children: [/*#__PURE__*/_jsx(IconButton, {\n icon: getTimeInputTypeIcon(inputType, {\n keyboard: keyboardIcon,\n picker: clockIcon\n }),\n onPress: () => setInputType(reverseInputTypes[inputType]),\n size: 24,\n style: styles.inputTypeToggle,\n accessibilityLabel: \"toggle keyboard\"\n }), /*#__PURE__*/_jsx(View, {\n style: sharedStyles.root\n }), /*#__PURE__*/_jsx(Button, {\n onPress: onDismiss,\n uppercase: uppercase,\n children: cancelLabel\n }), /*#__PURE__*/_jsx(Button, {\n onPress: () => onConfirm({\n hours: localHours,\n minutes: localMinutes\n }),\n uppercase: uppercase,\n children: confirmLabel\n })]\n })]\n })\n })\n })]\n })\n });\n}\nfunction getMinutes(minutes) {\n return minutes === undefined || minutes === null ? new Date().getMinutes() : minutes;\n}\nfunction getHours(hours) {\n return hours === undefined || hours === null ? new Date().getHours() : hours;\n}\nconst styles = StyleSheet.create({\n bottom: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 8\n },\n center: {\n justifyContent: 'center',\n alignItems: 'center',\n flex: 1\n },\n inputTypeToggle: {\n margin: 4\n },\n labelContainer: {\n justifyContent: 'flex-end',\n paddingLeft: 24,\n paddingRight: 24,\n paddingTop: 16\n },\n label: {\n letterSpacing: 1,\n fontSize: 13\n },\n modalContent: {\n shadowColor: '#000',\n shadowOffset: {\n width: 0,\n height: 5\n },\n shadowOpacity: 0.34,\n shadowRadius: 6.27,\n elevation: 3,\n minWidth: 287,\n paddingVertical: 8\n },\n timePickerContainer: {\n paddingLeft: 24,\n paddingTop: 20,\n paddingBottom: 16,\n paddingRight: 24\n }\n});\nexport default /*#__PURE__*/memo(TimePickerModal);\n//# sourceMappingURL=TimePickerModal.js.map","\"use strict\";\n\nimport { View, StyleSheet, useWindowDimensions } from 'react-native';\nimport React, { memo } from 'react';\nimport { inputTypes, toHourInputFormat, toHourOutputFormat } from './timeUtils';\nimport AnalogClock from './AnalogClock';\nimport { circleSize } from './timeUtils';\nimport TimeInputs from './TimeInputs';\nimport { DisplayModeContext } from '../contexts/DisplayModeContext';\nimport { useCallback, useEffect, useMemo, useState } from 'react';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction TimePicker({\n hours,\n minutes,\n onFocusInput,\n focused,\n inputType,\n onChange,\n locale,\n use24HourClock,\n inputFontSize\n}) {\n const dimensions = useWindowDimensions();\n const isLandscape = dimensions.width > dimensions.height;\n const [displayMode, setDisplayMode] = useState(undefined);\n\n // method to check whether we have 24 hours in clock or 12\n const is24Hour = useMemo(() => {\n if (use24HourClock !== undefined) {\n return use24HourClock;\n }\n const formatter = new Intl.DateTimeFormat(locale, {\n hour: '2-digit',\n minute: '2-digit',\n timeZone: 'UTC'\n });\n const formatted = formatter.format(new Date(Date.UTC(2020, 1, 1, 23)));\n return formatted.includes('23');\n }, [locale, use24HourClock]);\n\n // Initialize display Mode according the hours value\n useEffect(() => {\n if (hours >= 12) {\n setDisplayMode('PM');\n } else {\n setDisplayMode('AM');\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n const onInnerChange = useCallback(params => {\n params.hours = toHourOutputFormat(params.hours, hours, is24Hour);\n onChange(params);\n }, [onChange, hours, is24Hour]);\n return /*#__PURE__*/_jsx(DisplayModeContext.Provider, {\n value: {\n mode: displayMode,\n setMode: setDisplayMode\n },\n children: /*#__PURE__*/_jsxs(View, {\n style: isLandscape ? [styles.rootLandscape, {\n width: 24 * 3 + 96 * 2 + 52 + (inputType === inputTypes.picker ? circleSize : -circleSize)\n }] : styles.rootPortrait,\n children: [/*#__PURE__*/_jsx(TimeInputs, {\n inputType: inputType,\n inputFontSize: inputFontSize,\n hours: hours,\n minutes: minutes,\n is24Hour: is24Hour,\n onChange: onChange,\n onFocusInput: onFocusInput,\n focused: focused,\n locale: locale\n }), inputType === inputTypes.picker ? /*#__PURE__*/_jsx(View, {\n style: styles.clockContainer,\n children: /*#__PURE__*/_jsx(AnalogClock, {\n hours: toHourInputFormat(hours, is24Hour),\n minutes: minutes,\n focused: focused,\n is24Hour: is24Hour,\n onChange: onInnerChange\n })\n }) : null]\n })\n });\n}\nconst styles = StyleSheet.create({\n clockContainer: {\n paddingTop: 36,\n paddingLeft: 12,\n paddingRight: 12\n },\n rootLandscape: {\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'center'\n },\n rootPortrait: {\n alignItems: 'center',\n justifyContent: 'center'\n }\n});\nexport default /*#__PURE__*/memo(TimePicker);\n//# sourceMappingURL=TimePicker.js.map","\"use strict\";\n\nimport Color from 'color';\nimport { useMemo } from 'react';\nimport { useTheme } from 'react-native-paper';\nexport const circleSize = 256;\nexport const hourTypes = {\n am: 'am',\n pm: 'pm'\n};\nexport function getHourType(hours) {\n if (hours >= 0 && hours <= 12) {\n return hourTypes.am;\n }\n if (hours > 12 && hours <= 24) {\n return hourTypes.pm;\n }\n return undefined;\n}\nexport const inputTypes = {\n keyboard: 'keyboard',\n picker: 'picker'\n};\nexport const reverseInputTypes = {\n keyboard: 'picker',\n picker: 'keyboard'\n};\nexport const inputTypeIcons = {\n keyboard: 'keyboard-outline',\n picker: 'clock-outline'\n};\nexport const getTimeInputTypeIcon = (inputType, inputIconMap) => {\n return inputIconMap?.[reverseInputTypes[inputType]] || inputTypeIcons?.[reverseInputTypes[inputType]];\n};\nexport const clockTypes = {\n minutes: 'minutes',\n hours: 'hours'\n};\n\n// Code inspiration and copied from: https://github.com/ShaneGH/analogue-time-picker/blob/master/src/utils/angle.ts\nconst outerHeight = 34;\nconst _30 = Math.PI / 6;\nconst _12 = Math.PI / 30;\nconst _360 = Math.PI * 2;\nconst _90 = Math.PI / 2;\n\n/** Snap an angle to a given step. E.g. if angle = 22° and step = 10°, round down to 20° */\nexport function snap(angle, step) {\n let a = angle;\n while (a < 0) a += _360;\n let diff = a % step;\n if (diff <= step / 2) {\n return angle - diff;\n }\n return angle - diff + step;\n}\n\n// detect am / pm based on offset\nexport function getHourTypeFromOffset(left, top, size) {\n const w = size / 2;\n const x = w - left;\n const y = size / 2 - top;\n const distance = Math.sqrt(x * x + y * y);\n const maxPm = w - outerHeight;\n return distance > maxPm ? hourTypes.am : hourTypes.pm;\n}\n\n// Calculate the minute from the hand angle\nexport function getMinutes(handAngle) {\n handAngle = snap(handAngle, _12);\n let minute = parseInt(((handAngle - _90) % _360 / _12).toFixed(), 10);\n while (minute < 0) minute += 60;\n while (minute >= 60) minute -= 60;\n return minute;\n}\n\n// Calculate the hour from the hand angle\nexport function getHours(handAngle, hourType) {\n handAngle = snap(handAngle, _30);\n let hour = parseInt(((handAngle - _90) % _360 / _30).toFixed(), 10);\n if (hour < 0) hour += 12;\n if (hour >= 12) hour -= 12;\n if (hourType === hourTypes.am) {\n if (hour <= 0) {\n hour += 12;\n } else if (hour >= 12) {\n hour -= 12;\n }\n }\n if (hourType === hourTypes.pm) {\n if (hour <= 0) {\n hour += 12;\n } else if (hour > 12) {\n hour -= 12;\n }\n }\n return hour;\n}\n\n/** Get the angle of the left/top co-ordinate from the center of the width.height box */\nexport function getAngle(left, top, size) {\n const x = size / 2 - left;\n const y = size / 2 - top;\n\n // tan O = y / x\n let angle = x ? Math.atan(y / x) : y < 0 ? -_90 : _90;\n if (x < 0) {\n // reflect along vertical axis\n angle = -angle + 2 * (_90 + angle);\n }\n return angle;\n}\nexport function useSwitchColors(highlighted) {\n const theme = useTheme();\n const backgroundColor = useMemo(() => {\n if (theme.dark) {\n if (highlighted) {\n return theme.isV3 ? theme.colors.tertiaryContainer : Color(theme.colors.primary).hex();\n }\n return theme.colors.backdrop;\n }\n if (highlighted) {\n if (theme.isV3) {\n return theme.colors.primaryContainer;\n }\n return Color(theme.colors.primary).lighten(1).hex();\n }\n return theme.colors.surface;\n }, [highlighted, theme]);\n const color = useMemo(() => {\n if (highlighted && !theme.dark) {\n return theme.isV3 ? theme.colors.onSurfaceVariant : theme.colors.primary;\n }\n if (highlighted && theme.dark) {\n return theme.isV3 ? theme.colors.onTertiaryContainer : theme.colors.background;\n }\n if (theme.isV3) {\n return theme.colors.onSurfaceVariant;\n } else {\n return theme.colors.placeholder;\n }\n }, [highlighted, theme]);\n return {\n backgroundColor,\n color\n };\n}\nexport function useInputColors(highlighted) {\n const theme = useTheme();\n const backgroundColor = useMemo(() => {\n if (theme.dark) {\n if (highlighted) {\n return theme.isV3 ? theme.colors.primaryContainer : Color(theme.colors.primary).hex();\n }\n return theme.isV3 ? theme.colors.surfaceVariant : Color(theme.colors.surface).lighten(1.4).hex();\n }\n if (highlighted) {\n if (theme.isV3) {\n return theme.colors.secondaryContainer;\n }\n return Color(theme.colors.primary).lighten(1).hex();\n }\n if (theme.isV3) {\n return theme.colors.surfaceVariant;\n }\n return Color(theme.colors.surface).darken(0.1).hex();\n }, [highlighted, theme]);\n const color = useMemo(() => {\n if (theme.isV3) {\n if (!highlighted) {\n return theme.isV3 ? theme.colors.onSurface : theme.colors.onBackground;\n }\n return theme.isV3 ? theme.colors.onPrimaryContainer : theme.colors.onBackground;\n } else {\n const t = theme;\n if (highlighted && !theme.dark) {\n const primary = Color(t.colors.primary);\n const background = Color(backgroundColor);\n return background.isDark() && primary.isDark() ? '#ffffffff' : t.colors.primary;\n }\n return theme.colors.text;\n }\n }, [highlighted, theme, backgroundColor]);\n return {\n backgroundColor,\n color\n };\n}\nexport function toHourInputFormat(hours, is24Hour) {\n if (is24Hour) {\n if (hours === 24) {\n return 0;\n }\n return hours;\n }\n if (hours > 12) {\n return hours - 12;\n }\n if (hours === 0) {\n return hours + 12;\n }\n return hours;\n}\nexport function toHourOutputFormat(newHours, previousHours, is24Hour) {\n if (is24Hour) {\n return newHours;\n }\n if (previousHours === 0 && newHours !== 0) {\n return newHours - 12 < 0 ? newHours : newHours - 12;\n }\n if (previousHours >= 12 && newHours < 12) {\n return newHours + 12;\n }\n return newHours;\n}\n//# sourceMappingURL=timeUtils.js.map","\"use strict\";\n\nimport Color from 'color';\nimport { PanResponder, StyleSheet, View } from 'react-native';\nimport { useTheme } from 'react-native-paper';\nimport { circleSize, clockTypes, getAngle, getHours, getHourType, getHourTypeFromOffset, getMinutes, hourTypes } from './timeUtils';\nimport { useLatest } from '../shared/utils';\nimport AnalogClockHours from './AnalogClockHours';\nimport AnimatedClockSwitcher from './AnimatedClockSwitcher';\nimport AnalogClockMinutes from './AnalogClockMinutes';\nimport { DisplayModeContext } from '../contexts/DisplayModeContext';\nimport { memo, useCallback, useContext, useRef } from 'react';\nimport React from 'react';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction returnTrue() {\n return true;\n}\nfunction AnalogClock({\n hours,\n minutes,\n focused,\n is24Hour,\n onChange\n}) {\n const shortPointer = hours >= 12 && is24Hour;\n const theme = useTheme();\n const {\n mode\n } = useContext(DisplayModeContext);\n\n // used to make pointer shorter if hours are selected and above 12\n const clockRef = useRef(null);\n\n // Hooks are nice, sometimes... :-)..\n // We need the latest values, since the onPointerMove uses a closure to the function\n const hoursRef = useLatest(hours);\n const onChangeRef = useLatest(onChange);\n const minutesRef = useLatest(minutes);\n const focusedRef = useLatest(focused);\n const is24HourRef = useLatest(is24Hour);\n const modeRef = useLatest(mode);\n const onPointerMove = useCallback((e, final) => {\n let x = e.nativeEvent.locationX;\n let y = e.nativeEvent.locationY;\n let angle = getAngle(x, y, circleSize);\n if (focusedRef.current === clockTypes.hours) {\n let hours24 = is24HourRef.current;\n let previousHourType = getHourType(hoursRef.current);\n let pickedHours = getHours(angle, previousHourType);\n let hours12AndPm = !hours24 && modeRef.current === 'PM';\n let hourTypeFromOffset = getHourTypeFromOffset(x, y, circleSize);\n let hours24AndPM = hours24 && hourTypeFromOffset === hourTypes.pm;\n\n // Avoiding the \"24h\"\n // Should be 12h for 12 hours and PM mode\n\n if (hours12AndPm || hours24AndPM) {\n pickedHours += 12;\n }\n if ((modeRef.current === 'AM' || hours24) && pickedHours === 12) {\n pickedHours = 0;\n }\n if (!hours24 && modeRef.current === 'AM' && pickedHours === 12) {\n pickedHours = 0;\n }\n if (pickedHours === 24) {\n pickedHours = 12;\n }\n if (hoursRef.current !== pickedHours || final) {\n onChangeRef.current({\n hours: pickedHours,\n minutes: minutesRef.current,\n focused: final ? clockTypes.minutes : undefined\n });\n }\n } else if (focusedRef.current === clockTypes.minutes) {\n let pickedMinutes = getMinutes(angle);\n if (minutesRef.current !== pickedMinutes) {\n onChangeRef.current({\n hours: hoursRef.current,\n minutes: pickedMinutes\n });\n }\n }\n }, [focusedRef, is24HourRef, hoursRef, onChangeRef, minutesRef, modeRef]);\n const panResponder = useRef(PanResponder.create({\n onPanResponderGrant: e => onPointerMove(e, false),\n onPanResponderMove: e => onPointerMove(e, false),\n onPanResponderRelease: e => onPointerMove(e, true),\n onStartShouldSetPanResponder: returnTrue,\n onStartShouldSetPanResponderCapture: () => false,\n onMoveShouldSetPanResponder: returnTrue,\n onMoveShouldSetPanResponderCapture: returnTrue,\n onPanResponderTerminationRequest: returnTrue,\n onShouldBlockNativeResponder: returnTrue\n })).current;\n const dynamicSize = focused === clockTypes.hours && shortPointer ? 33 : 0;\n const pointerNumber = focused === clockTypes.hours ? hours : minutes;\n const degreesPerNumber = focused === clockTypes.hours ? 30 : 6;\n const v3Color = theme.colors.surfaceVariant;\n const v2Color = theme.dark ? Color(theme.colors.surface).lighten(1.4).hex() : Color(theme.colors.surface).darken(0.1).hex();\n return /*#__PURE__*/_jsxs(View, {\n ref: clockRef,\n ...panResponder.panHandlers,\n style: [styles.clock, {\n backgroundColor: theme.isV3 ? v3Color : v2Color\n }]\n // @ts-ignore -> https://github.com/necolas/react-native-web/issues/506\n ,\n cursor: 'pointer',\n children: [/*#__PURE__*/_jsx(View, {\n style: [styles.line, {\n backgroundColor: theme.colors.primary,\n transform: [{\n rotate: -90 + pointerNumber * degreesPerNumber + 'deg'\n }, {\n translateX: circleSize / 4 - (focused === clockTypes.hours && pointerNumber >= 0 && pointerNumber < 13 ? 0 : 4) + (focused === clockTypes.minutes ? 4 : 0) - dynamicSize / 2\n }],\n width: circleSize / 2 - 4 - dynamicSize\n }],\n pointerEvents: \"none\",\n children: /*#__PURE__*/_jsx(View, {\n style: [styles.endPoint, {\n backgroundColor: theme.colors.primary\n }]\n })\n }), /*#__PURE__*/_jsx(View, {\n style: [StyleSheet.absoluteFill, styles.center],\n pointerEvents: \"none\",\n children: /*#__PURE__*/_jsx(View, {\n style: [styles.middlePoint, {\n backgroundColor: theme.colors.primary\n }]\n })\n }), /*#__PURE__*/_jsx(AnimatedClockSwitcher, {\n focused: focused,\n hours: /*#__PURE__*/_jsx(AnalogClockHours, {\n is24Hour: is24Hour,\n hours: hours\n }),\n minutes: /*#__PURE__*/_jsx(AnalogClockMinutes, {\n minutes: minutes\n })\n })]\n });\n}\nconst styles = StyleSheet.create({\n center: {\n alignItems: 'center',\n justifyContent: 'center'\n },\n clock: {\n alignItems: 'center',\n borderRadius: circleSize / 2,\n height: circleSize,\n justifyContent: 'center',\n position: 'relative',\n width: circleSize\n },\n endPoint: {\n borderRadius: 24,\n bottom: -23,\n height: 48,\n position: 'absolute',\n right: 0,\n width: 48\n },\n line: {\n borderRadius: 4,\n height: 2,\n position: 'absolute'\n },\n middlePoint: {\n borderRadius: 4,\n height: 8,\n width: 8\n }\n});\nexport default /*#__PURE__*/memo(AnalogClock);\n//# sourceMappingURL=AnalogClock.js.map","import PanResponder from '../../vendor/react-native/PanResponder';\nexport default PanResponder;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n * @format\n */\n\n'use strict';\n\nimport InteractionManager from '../../../exports/InteractionManager';\nimport TouchHistoryMath from '../TouchHistoryMath';\nvar currentCentroidXOfTouchesChangedAfter = TouchHistoryMath.currentCentroidXOfTouchesChangedAfter;\nvar currentCentroidYOfTouchesChangedAfter = TouchHistoryMath.currentCentroidYOfTouchesChangedAfter;\nvar previousCentroidXOfTouchesChangedAfter = TouchHistoryMath.previousCentroidXOfTouchesChangedAfter;\nvar previousCentroidYOfTouchesChangedAfter = TouchHistoryMath.previousCentroidYOfTouchesChangedAfter;\nvar currentCentroidX = TouchHistoryMath.currentCentroidX;\nvar currentCentroidY = TouchHistoryMath.currentCentroidY;\n\n/**\n * `PanResponder` reconciles several touches into a single gesture. It makes\n * single-touch gestures resilient to extra touches, and can be used to\n * recognize simple multi-touch gestures.\n *\n * By default, `PanResponder` holds an `InteractionManager` handle to block\n * long-running JS events from interrupting active gestures.\n *\n * It provides a predictable wrapper of the responder handlers provided by the\n * [gesture responder system](docs/gesture-responder-system.html).\n * For each handler, it provides a new `gestureState` object alongside the\n * native event object:\n *\n * ```\n * onPanResponderMove: (event, gestureState) => {}\n * ```\n *\n * A native event is a synthetic touch event with the following form:\n *\n * - `nativeEvent`\n * + `changedTouches` - Array of all touch events that have changed since the last event\n * + `identifier` - The ID of the touch\n * + `locationX` - The X position of the touch, relative to the element\n * + `locationY` - The Y position of the touch, relative to the element\n * + `pageX` - The X position of the touch, relative to the root element\n * + `pageY` - The Y position of the touch, relative to the root element\n * + `target` - The node id of the element receiving the touch event\n * + `timestamp` - A time identifier for the touch, useful for velocity calculation\n * + `touches` - Array of all current touches on the screen\n *\n * A `gestureState` object has the following:\n *\n * - `stateID` - ID of the gestureState- persisted as long as there at least\n * one touch on screen\n * - `moveX` - the latest screen coordinates of the recently-moved touch\n * - `moveY` - the latest screen coordinates of the recently-moved touch\n * - `x0` - the screen coordinates of the responder grant\n * - `y0` - the screen coordinates of the responder grant\n * - `dx` - accumulated distance of the gesture since the touch started\n * - `dy` - accumulated distance of the gesture since the touch started\n * - `vx` - current velocity of the gesture\n * - `vy` - current velocity of the gesture\n * - `numberActiveTouches` - Number of touches currently on screen\n *\n * ### Basic Usage\n *\n * ```\n * componentWillMount: function() {\n * this._panResponder = PanResponder.create({\n * // Ask to be the responder:\n * onStartShouldSetPanResponder: (evt, gestureState) => true,\n * onStartShouldSetPanResponderCapture: (evt, gestureState) => true,\n * onMoveShouldSetPanResponder: (evt, gestureState) => true,\n * onMoveShouldSetPanResponderCapture: (evt, gestureState) => true,\n *\n * onPanResponderGrant: (evt, gestureState) => {\n * // The gesture has started. Show visual feedback so the user knows\n * // what is happening!\n *\n * // gestureState.d{x,y} will be set to zero now\n * },\n * onPanResponderMove: (evt, gestureState) => {\n * // The most recent move distance is gestureState.move{X,Y}\n *\n * // The accumulated gesture distance since becoming responder is\n * // gestureState.d{x,y}\n * },\n * onPanResponderTerminationRequest: (evt, gestureState) => true,\n * onPanResponderRelease: (evt, gestureState) => {\n * // The user has released all touches while this view is the\n * // responder. This typically means a gesture has succeeded\n * },\n * onPanResponderTerminate: (evt, gestureState) => {\n * // Another component has become the responder, so this gesture\n * // should be cancelled\n * },\n * onShouldBlockNativeResponder: (evt, gestureState) => {\n * // Returns whether this component should block native components from becoming the JS\n * // responder. Returns true by default. Is currently only supported on android.\n * return true;\n * },\n * });\n * },\n *\n * render: function() {\n * return (\n * \n * );\n * },\n *\n * ```\n *\n * ### Working Example\n *\n * To see it in action, try the\n * [PanResponder example in RNTester](https://github.com/facebook/react-native/blob/master/RNTester/js/PanResponderExample.js)\n */\n\nvar PanResponder = {\n /**\n *\n * A graphical explanation of the touch data flow:\n *\n * +----------------------------+ +--------------------------------+\n * | ResponderTouchHistoryStore | |TouchHistoryMath |\n * +----------------------------+ +----------+---------------------+\n * |Global store of touchHistory| |Allocation-less math util |\n * |including activeness, start | |on touch history (centroids |\n * |position, prev/cur position.| |and multitouch movement etc) |\n * | | | |\n * +----^-----------------------+ +----^---------------------------+\n * | |\n * | (records relevant history |\n * | of touches relevant for |\n * | implementing higher level |\n * | gestures) |\n * | |\n * +----+-----------------------+ +----|---------------------------+\n * | ResponderEventPlugin | | | Your App/Component |\n * +----------------------------+ +----|---------------------------+\n * |Negotiates which view gets | Low level | | High level |\n * |onResponderMove events. | events w/ | +-+-------+ events w/ |\n * |Also records history into | touchHistory| | Pan | multitouch + |\n * |ResponderTouchHistoryStore. +---------------->Responder+-----> accumulative|\n * +----------------------------+ attached to | | | distance and |\n * each event | +---------+ velocity. |\n * | |\n * | |\n * +--------------------------------+\n *\n *\n *\n * Gesture that calculates cumulative movement over time in a way that just\n * \"does the right thing\" for multiple touches. The \"right thing\" is very\n * nuanced. When moving two touches in opposite directions, the cumulative\n * distance is zero in each dimension. When two touches move in parallel five\n * pixels in the same direction, the cumulative distance is five, not ten. If\n * two touches start, one moves five in a direction, then stops and the other\n * touch moves fives in the same direction, the cumulative distance is ten.\n *\n * This logic requires a kind of processing of time \"clusters\" of touch events\n * so that two touch moves that essentially occur in parallel but move every\n * other frame respectively, are considered part of the same movement.\n *\n * Explanation of some of the non-obvious fields:\n *\n * - moveX/moveY: If no move event has been observed, then `(moveX, moveY)` is\n * invalid. If a move event has been observed, `(moveX, moveY)` is the\n * centroid of the most recently moved \"cluster\" of active touches.\n * (Currently all move have the same timeStamp, but later we should add some\n * threshold for what is considered to be \"moving\"). If a palm is\n * accidentally counted as a touch, but a finger is moving greatly, the palm\n * will move slightly, but we only want to count the single moving touch.\n * - x0/y0: Centroid location (non-cumulative) at the time of becoming\n * responder.\n * - dx/dy: Cumulative touch distance - not the same thing as sum of each touch\n * distance. Accounts for touch moves that are clustered together in time,\n * moving the same direction. Only valid when currently responder (otherwise,\n * it only represents the drag distance below the threshold).\n * - vx/vy: Velocity.\n */\n\n _initializeGestureState(gestureState) {\n gestureState.moveX = 0;\n gestureState.moveY = 0;\n gestureState.x0 = 0;\n gestureState.y0 = 0;\n gestureState.dx = 0;\n gestureState.dy = 0;\n gestureState.vx = 0;\n gestureState.vy = 0;\n gestureState.numberActiveTouches = 0;\n // All `gestureState` accounts for timeStamps up until:\n gestureState._accountsForMovesUpTo = 0;\n },\n /**\n * This is nuanced and is necessary. It is incorrect to continuously take all\n * active *and* recently moved touches, find the centroid, and track how that\n * result changes over time. Instead, we must take all recently moved\n * touches, and calculate how the centroid has changed just for those\n * recently moved touches, and append that change to an accumulator. This is\n * to (at least) handle the case where the user is moving three fingers, and\n * then one of the fingers stops but the other two continue.\n *\n * This is very different than taking all of the recently moved touches and\n * storing their centroid as `dx/dy`. For correctness, we must *accumulate\n * changes* in the centroid of recently moved touches.\n *\n * There is also some nuance with how we handle multiple moved touches in a\n * single event. With the way `ReactNativeEventEmitter` dispatches touches as\n * individual events, multiple touches generate two 'move' events, each of\n * them triggering `onResponderMove`. But with the way `PanResponder` works,\n * all of the gesture inference is performed on the first dispatch, since it\n * looks at all of the touches (even the ones for which there hasn't been a\n * native dispatch yet). Therefore, `PanResponder` does not call\n * `onResponderMove` passed the first dispatch. This diverges from the\n * typical responder callback pattern (without using `PanResponder`), but\n * avoids more dispatches than necessary.\n */\n _updateGestureStateOnMove(gestureState, touchHistory) {\n gestureState.numberActiveTouches = touchHistory.numberActiveTouches;\n gestureState.moveX = currentCentroidXOfTouchesChangedAfter(touchHistory, gestureState._accountsForMovesUpTo);\n gestureState.moveY = currentCentroidYOfTouchesChangedAfter(touchHistory, gestureState._accountsForMovesUpTo);\n var movedAfter = gestureState._accountsForMovesUpTo;\n var prevX = previousCentroidXOfTouchesChangedAfter(touchHistory, movedAfter);\n var x = currentCentroidXOfTouchesChangedAfter(touchHistory, movedAfter);\n var prevY = previousCentroidYOfTouchesChangedAfter(touchHistory, movedAfter);\n var y = currentCentroidYOfTouchesChangedAfter(touchHistory, movedAfter);\n var nextDX = gestureState.dx + (x - prevX);\n var nextDY = gestureState.dy + (y - prevY);\n\n // TODO: This must be filtered intelligently.\n var dt = touchHistory.mostRecentTimeStamp - gestureState._accountsForMovesUpTo;\n gestureState.vx = (nextDX - gestureState.dx) / dt;\n gestureState.vy = (nextDY - gestureState.dy) / dt;\n gestureState.dx = nextDX;\n gestureState.dy = nextDY;\n gestureState._accountsForMovesUpTo = touchHistory.mostRecentTimeStamp;\n },\n /**\n * @param {object} config Enhanced versions of all of the responder callbacks\n * that provide not only the typical `ResponderSyntheticEvent`, but also the\n * `PanResponder` gesture state. Simply replace the word `Responder` with\n * `PanResponder` in each of the typical `onResponder*` callbacks. For\n * example, the `config` object would look like:\n *\n * - `onMoveShouldSetPanResponder: (e, gestureState) => {...}`\n * - `onMoveShouldSetPanResponderCapture: (e, gestureState) => {...}`\n * - `onStartShouldSetPanResponder: (e, gestureState) => {...}`\n * - `onStartShouldSetPanResponderCapture: (e, gestureState) => {...}`\n * - `onPanResponderReject: (e, gestureState) => {...}`\n * - `onPanResponderGrant: (e, gestureState) => {...}`\n * - `onPanResponderStart: (e, gestureState) => {...}`\n * - `onPanResponderEnd: (e, gestureState) => {...}`\n * - `onPanResponderRelease: (e, gestureState) => {...}`\n * - `onPanResponderMove: (e, gestureState) => {...}`\n * - `onPanResponderTerminate: (e, gestureState) => {...}`\n * - `onPanResponderTerminationRequest: (e, gestureState) => {...}`\n * - `onShouldBlockNativeResponder: (e, gestureState) => {...}`\n *\n * In general, for events that have capture equivalents, we update the\n * gestureState once in the capture phase and can use it in the bubble phase\n * as well.\n *\n * Be careful with onStartShould* callbacks. They only reflect updated\n * `gestureState` for start/end events that bubble/capture to the Node.\n * Once the node is the responder, you can rely on every start/end event\n * being processed by the gesture and `gestureState` being updated\n * accordingly. (numberActiveTouches) may not be totally accurate unless you\n * are the responder.\n */\n create(config) {\n var interactionState = {\n handle: null,\n shouldCancelClick: false,\n timeout: null\n };\n var gestureState = {\n // Useful for debugging\n stateID: Math.random(),\n moveX: 0,\n moveY: 0,\n x0: 0,\n y0: 0,\n dx: 0,\n dy: 0,\n vx: 0,\n vy: 0,\n numberActiveTouches: 0,\n _accountsForMovesUpTo: 0\n };\n var panHandlers = {\n onStartShouldSetResponder(event) {\n return config.onStartShouldSetPanResponder == null ? false : config.onStartShouldSetPanResponder(event, gestureState);\n },\n onMoveShouldSetResponder(event) {\n return config.onMoveShouldSetPanResponder == null ? false : config.onMoveShouldSetPanResponder(event, gestureState);\n },\n onStartShouldSetResponderCapture(event) {\n // TODO: Actually, we should reinitialize the state any time\n // touches.length increases from 0 active to > 0 active.\n if (event.nativeEvent.touches.length === 1) {\n PanResponder._initializeGestureState(gestureState);\n }\n gestureState.numberActiveTouches = event.touchHistory.numberActiveTouches;\n return config.onStartShouldSetPanResponderCapture != null ? config.onStartShouldSetPanResponderCapture(event, gestureState) : false;\n },\n onMoveShouldSetResponderCapture(event) {\n var touchHistory = event.touchHistory;\n // Responder system incorrectly dispatches should* to current responder\n // Filter out any touch moves past the first one - we would have\n // already processed multi-touch geometry during the first event.\n if (gestureState._accountsForMovesUpTo === touchHistory.mostRecentTimeStamp) {\n return false;\n }\n PanResponder._updateGestureStateOnMove(gestureState, touchHistory);\n return config.onMoveShouldSetPanResponderCapture ? config.onMoveShouldSetPanResponderCapture(event, gestureState) : false;\n },\n onResponderGrant(event) {\n if (!interactionState.handle) {\n interactionState.handle = InteractionManager.createInteractionHandle();\n }\n if (interactionState.timeout) {\n clearInteractionTimeout(interactionState);\n }\n interactionState.shouldCancelClick = true;\n gestureState.x0 = currentCentroidX(event.touchHistory);\n gestureState.y0 = currentCentroidY(event.touchHistory);\n gestureState.dx = 0;\n gestureState.dy = 0;\n if (config.onPanResponderGrant) {\n config.onPanResponderGrant(event, gestureState);\n }\n // TODO: t7467124 investigate if this can be removed\n return config.onShouldBlockNativeResponder == null ? true : config.onShouldBlockNativeResponder(event, gestureState);\n },\n onResponderReject(event) {\n clearInteractionHandle(interactionState, config.onPanResponderReject, event, gestureState);\n },\n onResponderRelease(event) {\n clearInteractionHandle(interactionState, config.onPanResponderRelease, event, gestureState);\n setInteractionTimeout(interactionState);\n PanResponder._initializeGestureState(gestureState);\n },\n onResponderStart(event) {\n var touchHistory = event.touchHistory;\n gestureState.numberActiveTouches = touchHistory.numberActiveTouches;\n if (config.onPanResponderStart) {\n config.onPanResponderStart(event, gestureState);\n }\n },\n onResponderMove(event) {\n var touchHistory = event.touchHistory;\n // Guard against the dispatch of two touch moves when there are two\n // simultaneously changed touches.\n if (gestureState._accountsForMovesUpTo === touchHistory.mostRecentTimeStamp) {\n return;\n }\n // Filter out any touch moves past the first one - we would have\n // already processed multi-touch geometry during the first event.\n PanResponder._updateGestureStateOnMove(gestureState, touchHistory);\n if (config.onPanResponderMove) {\n config.onPanResponderMove(event, gestureState);\n }\n },\n onResponderEnd(event) {\n var touchHistory = event.touchHistory;\n gestureState.numberActiveTouches = touchHistory.numberActiveTouches;\n clearInteractionHandle(interactionState, config.onPanResponderEnd, event, gestureState);\n },\n onResponderTerminate(event) {\n clearInteractionHandle(interactionState, config.onPanResponderTerminate, event, gestureState);\n setInteractionTimeout(interactionState);\n PanResponder._initializeGestureState(gestureState);\n },\n onResponderTerminationRequest(event) {\n return config.onPanResponderTerminationRequest == null ? true : config.onPanResponderTerminationRequest(event, gestureState);\n },\n // We do not want to trigger 'click' activated gestures or native behaviors\n // on any pan target that is under a mouse cursor when it is released.\n // Browsers will natively cancel 'click' events on a target if a non-mouse\n // active pointer moves.\n onClickCapture: event => {\n if (interactionState.shouldCancelClick === true) {\n event.stopPropagation();\n event.preventDefault();\n }\n }\n };\n return {\n panHandlers,\n getInteractionHandle() {\n return interactionState.handle;\n }\n };\n }\n};\nfunction clearInteractionHandle(interactionState, callback, event, gestureState) {\n if (interactionState.handle) {\n InteractionManager.clearInteractionHandle(interactionState.handle);\n interactionState.handle = null;\n }\n if (callback) {\n callback(event, gestureState);\n }\n}\nfunction clearInteractionTimeout(interactionState) {\n clearTimeout(interactionState.timeout);\n}\nfunction setInteractionTimeout(interactionState) {\n interactionState.timeout = setTimeout(() => {\n interactionState.shouldCancelClick = false;\n }, 250);\n}\nexport default PanResponder;","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * @format\n */\n\nvar TouchHistoryMath = {\n /**\n * This code is optimized and not intended to look beautiful. This allows\n * computing of touch centroids that have moved after `touchesChangedAfter`\n * timeStamp. You can compute the current centroid involving all touches\n * moves after `touchesChangedAfter`, or you can compute the previous\n * centroid of all touches that were moved after `touchesChangedAfter`.\n *\n * @param {TouchHistoryMath} touchHistory Standard Responder touch track\n * data.\n * @param {number} touchesChangedAfter timeStamp after which moved touches\n * are considered \"actively moving\" - not just \"active\".\n * @param {boolean} isXAxis Consider `x` dimension vs. `y` dimension.\n * @param {boolean} ofCurrent Compute current centroid for actively moving\n * touches vs. previous centroid of now actively moving touches.\n * @return {number} value of centroid in specified dimension.\n */\n centroidDimension: function centroidDimension(touchHistory, touchesChangedAfter, isXAxis, ofCurrent) {\n var touchBank = touchHistory.touchBank;\n var total = 0;\n var count = 0;\n var oneTouchData = touchHistory.numberActiveTouches === 1 ? touchHistory.touchBank[touchHistory.indexOfSingleActiveTouch] : null;\n if (oneTouchData !== null) {\n if (oneTouchData.touchActive && oneTouchData.currentTimeStamp > touchesChangedAfter) {\n total += ofCurrent && isXAxis ? oneTouchData.currentPageX : ofCurrent && !isXAxis ? oneTouchData.currentPageY : !ofCurrent && isXAxis ? oneTouchData.previousPageX : oneTouchData.previousPageY;\n count = 1;\n }\n } else {\n for (var i = 0; i < touchBank.length; i++) {\n var touchTrack = touchBank[i];\n if (touchTrack !== null && touchTrack !== undefined && touchTrack.touchActive && touchTrack.currentTimeStamp >= touchesChangedAfter) {\n var toAdd = void 0; // Yuck, program temporarily in invalid state.\n if (ofCurrent && isXAxis) {\n toAdd = touchTrack.currentPageX;\n } else if (ofCurrent && !isXAxis) {\n toAdd = touchTrack.currentPageY;\n } else if (!ofCurrent && isXAxis) {\n toAdd = touchTrack.previousPageX;\n } else {\n toAdd = touchTrack.previousPageY;\n }\n total += toAdd;\n count++;\n }\n }\n }\n return count > 0 ? total / count : TouchHistoryMath.noCentroid;\n },\n currentCentroidXOfTouchesChangedAfter: function currentCentroidXOfTouchesChangedAfter(touchHistory, touchesChangedAfter) {\n return TouchHistoryMath.centroidDimension(touchHistory, touchesChangedAfter, true,\n // isXAxis\n true // ofCurrent\n );\n },\n\n currentCentroidYOfTouchesChangedAfter: function currentCentroidYOfTouchesChangedAfter(touchHistory, touchesChangedAfter) {\n return TouchHistoryMath.centroidDimension(touchHistory, touchesChangedAfter, false,\n // isXAxis\n true // ofCurrent\n );\n },\n\n previousCentroidXOfTouchesChangedAfter: function previousCentroidXOfTouchesChangedAfter(touchHistory, touchesChangedAfter) {\n return TouchHistoryMath.centroidDimension(touchHistory, touchesChangedAfter, true,\n // isXAxis\n false // ofCurrent\n );\n },\n\n previousCentroidYOfTouchesChangedAfter: function previousCentroidYOfTouchesChangedAfter(touchHistory, touchesChangedAfter) {\n return TouchHistoryMath.centroidDimension(touchHistory, touchesChangedAfter, false,\n // isXAxis\n false // ofCurrent\n );\n },\n\n currentCentroidX: function currentCentroidX(touchHistory) {\n return TouchHistoryMath.centroidDimension(touchHistory, 0,\n // touchesChangedAfter\n true,\n // isXAxis\n true // ofCurrent\n );\n },\n\n currentCentroidY: function currentCentroidY(touchHistory) {\n return TouchHistoryMath.centroidDimension(touchHistory, 0,\n // touchesChangedAfter\n false,\n // isXAxis\n true // ofCurrent\n );\n },\n\n noCentroid: -1\n};\nexport default TouchHistoryMath;","\"use strict\";\n\nimport { View, StyleSheet } from 'react-native';\nimport { Text } from 'react-native-paper';\nimport { circleSize } from './timeUtils';\nimport { useTextColorOnPrimary } from '../shared/utils';\nimport React, { memo } from 'react';\nimport { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction AnalogClockHours({\n is24Hour,\n hours\n}) {\n const outerRange = getHourNumbers(false, circleSize, 12, 12);\n const innerRange = getHourNumbers(true, circleSize, 12, 12);\n const color = useTextColorOnPrimary();\n return /*#__PURE__*/_jsxs(_Fragment, {\n children: [outerRange.map((a, i) => /*#__PURE__*/_jsx(View, {\n pointerEvents: \"none\",\n style: [styles.hourRoot, {\n top: a[1] || 0,\n left: a[0] || 0\n }],\n children: /*#__PURE__*/_jsx(View, {\n style: styles.hourInner,\n children: /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: !is24Hour && i + 1 === hours || hours === i + 1 && hours !== 12 || i + 1 === 12 && hours === 0 ? {\n color\n } : null,\n variant: \"bodyLarge\",\n selectable: false,\n children: is24Hour && i + 1 === 12 ? '00' : i + 1\n })\n })\n }, i)), is24Hour ? innerRange.map((a, i) => /*#__PURE__*/_jsx(View, {\n pointerEvents: \"none\",\n style: [styles.hourRoot, {\n top: a[1] || 0,\n left: a[0] || 0\n }],\n children: /*#__PURE__*/_jsx(View, {\n style: styles.hourInner,\n children: /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n selectable: false,\n style: [i + 13 === hours || i + 13 === 24 && hours === 12 ? {\n color\n } : null],\n variant: \"bodyLarge\",\n children: i + 13 === 24 ? '12' : i + 13\n })\n })\n }, i)) : null]\n });\n}\nconst styles = StyleSheet.create({\n hourInner: {\n borderRadius: 24\n },\n hourRoot: {\n position: 'absolute',\n justifyContent: 'center',\n alignItems: 'center',\n zIndex: 20,\n width: 48,\n height: 48,\n marginLeft: -24,\n marginTop: -24,\n borderRadius: 24\n }\n});\nfunction getHourNumbers(is24Hour, size, count, arrayLength) {\n let angle = 0;\n let step = 2 * Math.PI / count;\n let radius = size / (is24Hour ? 4 : 2.5);\n angle = -90 * Math.PI / 180 + Math.PI / 6;\n return Array(arrayLength).fill(true).map(() => {\n let x = Math.round(size / 2 + radius * Math.cos(angle));\n let y = Math.round(size / 2 + radius * Math.sin(angle));\n angle += step;\n return [x, y];\n });\n}\nexport default /*#__PURE__*/memo(AnalogClockHours);\n//# sourceMappingURL=AnalogClockHours.js.map","\"use strict\";\n\nimport { Animated, StyleSheet, View } from 'react-native';\nimport { clockTypes } from './timeUtils';\nimport React, { useEffect, useRef } from 'react';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nexport default function AnimatedClockSwitcher({\n focused,\n hours,\n minutes\n}) {\n const collapsed = focused === clockTypes.hours;\n const animatedCollapsed = useRef(new Animated.Value(collapsed ? 1 : 0));\n useEffect(() => {\n Animated.timing(animatedCollapsed.current, {\n toValue: collapsed ? 1 : 0,\n duration: 250,\n useNativeDriver: true\n }).start();\n }, [collapsed]);\n return /*#__PURE__*/_jsxs(View, {\n style: StyleSheet.absoluteFill,\n children: [/*#__PURE__*/_jsx(Animated.View, {\n pointerEvents: collapsed ? 'auto' : 'none',\n style: [StyleSheet.absoluteFill, {\n opacity: animatedCollapsed.current,\n transform: [{\n scale: animatedCollapsed.current.interpolate({\n inputRange: [0, 1],\n outputRange: [0.95, 1]\n })\n }]\n }],\n children: hours\n }), /*#__PURE__*/_jsx(Animated.View, {\n pointerEvents: collapsed ? 'none' : 'auto',\n style: [StyleSheet.absoluteFill, {\n opacity: animatedCollapsed.current.interpolate({\n inputRange: [0, 1],\n outputRange: [1, 0]\n }),\n transform: [{\n scale: animatedCollapsed.current.interpolate({\n inputRange: [0, 1],\n outputRange: [1, 0.95]\n })\n }]\n }],\n children: minutes\n })]\n });\n}\n//# sourceMappingURL=AnimatedClockSwitcher.js.map","\"use strict\";\n\nimport { View, StyleSheet } from 'react-native';\nimport { Text } from 'react-native-paper';\nimport { circleSize } from './timeUtils';\nimport { useTextColorOnPrimary } from '../shared/utils';\nimport React, { memo } from 'react';\nimport { jsx as _jsx, Fragment as _Fragment } from \"react/jsx-runtime\";\nfunction AnalogClockMinutes({\n minutes\n}) {\n const range = getMinuteNumbers(circleSize, 12);\n const color = useTextColorOnPrimary();\n return /*#__PURE__*/_jsx(_Fragment, {\n children: range.map((a, i) => {\n const currentMinutes = i * 5;\n const isZero = currentMinutes === 0;\n let isCurrent = currentMinutes - 1 <= minutes && currentMinutes + 1 >= minutes;\n if (isZero) {\n isCurrent = minutes >= 59 || currentMinutes + 1 >= minutes;\n }\n return /*#__PURE__*/_jsx(View, {\n pointerEvents: \"none\",\n style: [styles.outerHourRoot, {\n top: a[1] || 0,\n left: a[0] || 0\n }],\n children: /*#__PURE__*/_jsx(View, {\n style: styles.outerHourInner,\n children: /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n style: isCurrent ? {\n color\n } : undefined,\n selectable: false,\n variant: \"bodyLarge\",\n children: isZero ? '00' : currentMinutes\n })\n })\n }, i);\n })\n });\n}\nfunction getMinuteNumbers(size, count) {\n let angle = 0;\n let step = 2 * Math.PI / count;\n let radius = size / 2.5;\n angle = angle = -90 * Math.PI / 180;\n return Array(12).fill(true).map(() => {\n let x = Math.round(size / 2 + radius * Math.cos(angle));\n let y = Math.round(size / 2 + radius * Math.sin(angle));\n angle += step;\n return [x, y];\n });\n}\nconst styles = StyleSheet.create({\n outerHourRoot: {\n position: 'absolute',\n justifyContent: 'center',\n alignItems: 'center',\n zIndex: 20,\n width: 48,\n height: 48,\n marginLeft: -24,\n marginTop: -24,\n borderRadius: 24\n },\n outerHourInner: {\n borderRadius: 24\n }\n});\nexport default /*#__PURE__*/memo(AnalogClockMinutes);\n//# sourceMappingURL=AnalogClockMinutes.js.map","\"use strict\";\n\nimport { createContext } from 'react';\nexport const DisplayModeContext = /*#__PURE__*/createContext({\n mode: 'AM',\n setMode: () => {}\n});\n//# sourceMappingURL=DisplayModeContext.js.map","\"use strict\";\n\nimport { View, StyleSheet, useWindowDimensions } from 'react-native';\nimport { Text, useTheme } from 'react-native-paper';\nimport { clockTypes, toHourInputFormat, toHourOutputFormat } from './timeUtils';\nimport TimeInput from './TimeInput';\nimport AmPmSwitcher from './AmPmSwitcher';\nimport { useLatest } from '../shared/utils';\nimport Color from 'color';\nimport { getTranslation } from '../translations/utils';\nimport { memo, useCallback, useRef } from 'react';\nimport React from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from \"react/jsx-runtime\";\nfunction TimeInputs({\n hours,\n minutes,\n onFocusInput,\n focused,\n inputType,\n onChange,\n is24Hour,\n inputFontSize,\n locale\n}) {\n const theme = useTheme();\n const startInput = useRef(null);\n const endInput = useRef(null);\n const dimensions = useWindowDimensions();\n const isLandscape = dimensions.width > dimensions.height;\n const minutesRef = useLatest(minutes);\n const onSubmitStartInput = useCallback(() => {\n if (endInput.current) {\n endInput.current.focus();\n }\n }, [endInput]);\n const onSubmitEndInput = useCallback(() => {\n // TODO: close modal and persist time\n }, []);\n const onChangeHours = useCallback(newHours => {\n onChange({\n hours: newHours,\n minutes: minutesRef.current,\n focused: clockTypes.hours\n });\n }, [onChange, minutesRef]);\n return /*#__PURE__*/_jsxs(View, {\n style: [styles.inputContainer, isLandscape && sharedStyles.root],\n children: [/*#__PURE__*/_jsxs(View, {\n style: styles.column,\n children: [/*#__PURE__*/_jsx(TimeInput, {\n ref: startInput,\n inputFontSize: inputFontSize,\n placeholder: '00',\n value: toHourInputFormat(hours, is24Hour),\n clockType: clockTypes.hours,\n pressed: focused === clockTypes.hours,\n onPress: onFocusInput,\n inputType: inputType,\n maxFontSizeMultiplier: 1.2,\n selectionColor: theme.dark ? Color(theme.colors.primary).darken(0.2).hex() : theme.colors.primary,\n returnKeyType: 'next',\n onSubmitEditing: onSubmitStartInput,\n blurOnSubmit: false,\n onChanged: newHoursFromInput => {\n let newHours = toHourOutputFormat(newHoursFromInput, hours, is24Hour);\n if (newHoursFromInput > 24) {\n newHours = 24;\n }\n onChange({\n hours: newHours,\n minutes\n });\n }\n }), inputType === 'keyboard' ? /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n variant: \"bodySmall\",\n children: getTranslation(locale, 'hour', 'Hour')\n }) : null]\n }), /*#__PURE__*/_jsxs(View, {\n style: [styles.hoursAndMinutesSeparator,\n // eslint-disable-next-line react-native/no-inline-styles\n {\n marginBottom: inputType === 'keyboard' ? 24 : 0\n }],\n children: [/*#__PURE__*/_jsx(View, {\n style: sharedStyles.root\n }), /*#__PURE__*/_jsx(View, {\n style: [styles.dot, {\n backgroundColor: theme?.isV3 ? theme.colors.onSurface : theme.colors.text\n }]\n }), /*#__PURE__*/_jsx(View, {\n style: styles.betweenDot\n }), /*#__PURE__*/_jsx(View, {\n style: [styles.dot, {\n backgroundColor: theme?.isV3 ? theme.colors.onSurface : theme.colors.text\n }]\n }), /*#__PURE__*/_jsx(View, {\n style: sharedStyles.root\n })]\n }), /*#__PURE__*/_jsxs(View, {\n style: styles.column,\n children: [/*#__PURE__*/_jsx(TimeInput, {\n ref: endInput,\n inputFontSize: inputFontSize,\n placeholder: '00',\n value: minutes,\n clockType: clockTypes.minutes,\n pressed: focused === clockTypes.minutes,\n onPress: onFocusInput,\n inputType: inputType,\n maxFontSizeMultiplier: 1.2,\n selectionColor: theme.dark ? Color(theme.colors.primary).darken(0.2).hex() : theme.colors.primary,\n onSubmitEditing: onSubmitEndInput,\n onChanged: newMinutesFromInput => {\n let newMinutes = newMinutesFromInput;\n if (newMinutesFromInput > 59) {\n newMinutes = 59;\n }\n onChange({\n hours,\n minutes: newMinutes\n });\n }\n }), inputType === 'keyboard' ? /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n variant: \"bodySmall\",\n children: getTranslation(locale, 'minute', 'Minute')\n }) : null]\n }), !is24Hour && /*#__PURE__*/_jsxs(_Fragment, {\n children: [/*#__PURE__*/_jsx(View, {\n style: styles.spaceBetweenInputsAndSwitcher\n }), /*#__PURE__*/_jsx(AmPmSwitcher, {\n hours: hours,\n onChange: onChangeHours,\n inputType: inputType\n })]\n })]\n });\n}\nconst styles = StyleSheet.create({\n betweenDot: {\n height: 12\n },\n column: {\n flexDirection: 'column'\n },\n dot: {\n width: 7,\n height: 7,\n borderRadius: 7 / 2\n },\n hoursAndMinutesSeparator: {\n fontSize: 65,\n width: 24,\n alignItems: 'center'\n },\n inputContainer: {\n flexDirection: 'row',\n alignItems: 'center'\n },\n spaceBetweenInputsAndSwitcher: {\n width: 12\n }\n});\nexport default /*#__PURE__*/memo(TimeInputs);\n//# sourceMappingURL=TimeInputs.js.map","\"use strict\";\n\nimport { View, TextInput, StyleSheet, Platform } from 'react-native';\nimport { useTheme, TouchableRipple } from 'react-native-paper';\nimport Color from 'color';\nimport { inputTypes, useInputColors } from './timeUtils';\nimport { forwardRef, useEffect, useState } from 'react';\nimport React from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction TimeInput({\n value,\n clockType,\n pressed,\n onPress,\n onChanged,\n inputType,\n inputFontSize = 57,\n ...rest\n}, ref) {\n const theme = useTheme();\n const [inputFocused, setInputFocused] = useState(false);\n const [controlledValue, setControlledValue] = useState(`${value}`);\n const highlighted = inputType === inputTypes.picker ? pressed : inputFocused;\n const {\n color,\n backgroundColor\n } = useInputColors(highlighted);\n useEffect(() => {\n setControlledValue(`${value}`);\n }, [value]);\n const onInnerChange = number => {\n setControlledValue(`${number}`);\n if (number >= 0) {\n onChanged(Number(number));\n }\n };\n let formattedValue = controlledValue;\n if (!inputFocused) {\n formattedValue = controlledValue.length === 1 ? `0${controlledValue}` : `${controlledValue}`;\n }\n return /*#__PURE__*/_jsxs(View, {\n style: styles.root,\n children: [/*#__PURE__*/_jsx(TextInput, {\n ref: ref,\n style: [styles.input,\n // eslint-disable-next-line react-native/no-inline-styles\n {\n color,\n fontFamily: theme?.isV3 ? theme.fonts.titleMedium.fontFamily : theme.fonts.medium.fontFamily,\n fontSize: inputFontSize,\n backgroundColor,\n borderRadius: theme.roundness * 2,\n borderColor: theme.isV3 && highlighted ? theme.colors.onPrimaryContainer : undefined,\n borderWidth: theme.isV3 && highlighted ? 2 : 0,\n height: inputType === inputTypes.keyboard ? 72 : 80\n }],\n maxFontSizeMultiplier: 1.5,\n value: formattedValue,\n maxLength: 2,\n onFocus: () => setInputFocused(true),\n onBlur: () => setInputFocused(false),\n keyboardAppearance: theme.dark ? 'dark' : 'default',\n keyboardType: \"number-pad\",\n onChangeText: e => {\n onInnerChange(Number(e));\n },\n ...rest\n }), onPress && inputType === inputTypes.picker ? /*#__PURE__*/_jsx(TouchableRipple, {\n style: [StyleSheet.absoluteFill, sharedStyles.overflowHidden, {\n borderRadius: theme.roundness\n }],\n rippleColor: Platform.OS !== 'ios' ? Color(theme.colors.onSurface).fade(0.7).hex() : undefined,\n onPress: () => onPress(clockType),\n borderless: true,\n children: /*#__PURE__*/_jsx(View, {})\n }) : null]\n });\n}\nconst styles = StyleSheet.create({\n input: {\n textAlign: 'center',\n textAlignVertical: 'center',\n width: 96\n },\n root: {\n height: 80,\n position: 'relative',\n width: 96\n }\n});\nexport default /*#__PURE__*/forwardRef(TimeInput);\n//# sourceMappingURL=TimeInput.js.map","\"use strict\";\n\nimport { View, StyleSheet } from 'react-native';\nimport { Text, TouchableRipple, useTheme } from 'react-native-paper';\nimport { useContext, useMemo } from 'react';\nimport Color from 'color';\nimport { inputTypes, useSwitchColors } from './timeUtils';\nimport { DisplayModeContext } from '../contexts/DisplayModeContext';\nimport React from 'react';\nimport { sharedStyles } from '../shared/styles';\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nexport default function AmPmSwitcher({\n onChange,\n hours,\n inputType\n}) {\n const theme = useTheme();\n const {\n setMode,\n mode\n } = useContext(DisplayModeContext);\n const backgroundColor = useMemo(() => {\n if (theme.isV3) {\n return theme.colors.outline;\n }\n return Color(theme.dark ? Color(theme.colors.surface).lighten(1.2).hex() : theme.colors.surface).darken(0.1).hex();\n }, [theme]);\n const isAM = mode === 'AM';\n return /*#__PURE__*/_jsxs(View, {\n style: [styles.root,\n // eslint-disable-next-line react-native/no-inline-styles\n {\n borderColor: backgroundColor,\n borderRadius: theme.roundness * 2,\n height: inputType === inputTypes.keyboard ? 72 : 80,\n marginBottom: inputType === 'keyboard' ? 24 : 0\n }],\n children: [/*#__PURE__*/_jsx(SwitchButton, {\n label: \"AM\",\n onPress: () => {\n setMode('AM');\n if (hours - 12 >= 0) {\n onChange(hours - 12);\n }\n },\n selected: isAM,\n disabled: isAM\n }), /*#__PURE__*/_jsx(View, {\n style: [styles.switchSeparator, {\n backgroundColor\n }]\n }), /*#__PURE__*/_jsx(SwitchButton, {\n label: \"PM\",\n onPress: () => {\n setMode('PM');\n if (hours + 12 <= 24) {\n onChange(hours + 12);\n }\n },\n selected: !isAM,\n disabled: !isAM\n })]\n });\n}\nfunction SwitchButton({\n label,\n onPress,\n selected,\n disabled\n}) {\n const theme = useTheme();\n const {\n backgroundColor,\n color\n } = useSwitchColors(selected);\n let textFont = theme?.isV3 ? theme.fonts.titleMedium : theme.fonts.medium;\n return /*#__PURE__*/_jsx(TouchableRipple, {\n onPress: onPress,\n style: sharedStyles.root,\n accessibilityLabel: label\n // @ts-ignore old React Native versions\n ,\n accessibilityTraits: disabled ? ['button', 'disabled'] : 'button'\n // @ts-ignore old React Native versions\n ,\n accessibilityComponentType: \"button\",\n accessibilityRole: \"button\",\n accessibilityState: {\n disabled\n },\n disabled: disabled,\n children: /*#__PURE__*/_jsx(View, {\n style: [styles.switchButtonInner, {\n backgroundColor\n }],\n children: /*#__PURE__*/_jsx(Text, {\n maxFontSizeMultiplier: 1.5,\n selectable: false,\n style: [{\n ...textFont,\n color: color\n }],\n children: label\n })\n })\n });\n}\nconst styles = StyleSheet.create({\n root: {\n width: 52,\n borderWidth: 1,\n overflow: 'hidden'\n },\n switchSeparator: {\n height: 1,\n width: 52\n },\n switchButtonInner: {\n flex: 1,\n alignItems: 'center',\n justifyContent: 'center'\n }\n});\n//# sourceMappingURL=AmPmSwitcher.js.map","\"use strict\";\n\nimport { TextInput } from 'react-native-paper';\nimport DatePickerModal from './DatePickerModal';\nimport { useLatest } from '../shared/utils';\nimport DatePickerInputWithoutModal from './DatePickerInputWithoutModal';\nimport { Platform } from 'react-native';\nimport { forwardRef, useCallback, useState } from 'react';\nimport React from 'react';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction DatePickerInput({\n withModal = true,\n calendarIcon = 'calendar',\n animationType = Platform.select({\n web: 'none',\n default: 'slide'\n }),\n presentationStyle = 'overFullScreen',\n ...rest\n}, ref) {\n const [visible, setVisible] = useState(false);\n const onChangeRef = useLatest(rest.onChange);\n const onDismiss = useCallback(() => {\n setVisible(false);\n }, [setVisible]);\n const onInnerConfirm = useCallback(({\n date\n }) => {\n setVisible(false);\n onChangeRef.current(date);\n }, [setVisible, onChangeRef]);\n return /*#__PURE__*/_jsx(DatePickerInputWithoutModal, {\n ref: ref,\n ...rest,\n inputButton: withModal ? /*#__PURE__*/_jsx(TextInput.Icon, {\n size: rest.iconSize ?? 24,\n icon: calendarIcon,\n color: rest.iconColor ?? undefined,\n forceTextInputFocus: false,\n disabled: rest.disabled,\n onPress: () => setVisible(true),\n style: rest.iconStyle,\n testID: `${rest.testID || 'date-picker'}-icon-button`\n }) : null\n // eslint-disable-next-line react/no-unstable-nested-components\n ,\n modal: ({\n value,\n locale,\n inputMode,\n validRange,\n saveLabel,\n saveLabelDisabled,\n uppercase,\n startYear,\n endYear,\n inputEnabled,\n disableStatusBarPadding,\n startWeekOnMonday\n }) => withModal ? /*#__PURE__*/_jsx(DatePickerModal, {\n date: value,\n mode: \"single\",\n visible: visible,\n onDismiss: onDismiss,\n onConfirm: onInnerConfirm,\n locale: locale,\n dateMode: inputMode,\n validRange: validRange,\n saveLabel: saveLabel,\n saveLabelDisabled: saveLabelDisabled ?? false,\n uppercase: uppercase,\n startYear: startYear ?? 1800,\n endYear: endYear ?? 2200,\n inputEnabled: inputEnabled,\n disableStatusBarPadding: disableStatusBarPadding ?? false,\n animationType: animationType,\n presentationStyle: presentationStyle,\n label: rest.label,\n startWeekOnMonday: startWeekOnMonday\n }) : null\n });\n}\nexport default /*#__PURE__*/forwardRef(DatePickerInput);\n//# sourceMappingURL=DatePickerInput.js.map","\"use strict\";\n\nconst ar = {\n save: 'حفظ',\n selectSingle: 'حدد تاريخ',\n selectMultiple: 'حدد التواريخ',\n selectRange: 'حدد الفترة',\n notAccordingToDateFormat: inputFormat => `يجب أن يكون تنسيق التاريخ ${inputFormat}`,\n mustBeHigherThan: date => `يجب أن يكون بعد ${date}`,\n mustBeLowerThan: date => `يجب أن يكون قبل ${date}`,\n mustBeBetween: (startDate, endDate) => `يجب أن يكون بين ${startDate} - ${endDate}`,\n dateIsDisabled: 'اليوم غير مسموح به',\n previous: 'السابق',\n next: 'التالي',\n typeInDate: 'اكتب التاريخ',\n pickDateFromCalendar: 'اختر التاريخ من التقويم',\n close: 'أغلق',\n hour: 'ساعة',\n minute: 'دقيقة'\n};\nexport default ar;\n//# sourceMappingURL=ar.js.map","\"use strict\";\n\nconst ca = {\n save: 'Guardar',\n selectSingle: 'Seleccionar data',\n selectMultiple: 'Seleccionar dates',\n selectRange: 'Seleccionar període',\n notAccordingToDateFormat: inputFormat => `El format de la data ha de ser ${inputFormat}`,\n mustBeHigherThan: date => `Ha de ser posterior a ${date}`,\n mustBeLowerThan: date => `Ha de ser anterior a ${date}`,\n mustBeBetween: (startDate, endDate) => `Ha d'estar entre ${startDate} - ${endDate}`,\n dateIsDisabled: 'Dia no permès',\n previous: 'Anterior',\n next: 'Següent',\n typeInDate: 'Escriu la data',\n pickDateFromCalendar: 'Seleccionar la data del calendari',\n close: 'Tancar',\n minute: 'Minut',\n hour: 'Hora'\n};\nexport default ca;\n//# sourceMappingURL=ca.js.map","\"use strict\";\n\nconst de = {\n save: 'Speichern',\n selectSingle: 'Wähle Datum',\n selectMultiple: 'Wähle Daten',\n selectRange: 'Wähle Zeitspanne',\n notAccordingToDateFormat: inputFormat => `Das Format sollte ${inputFormat} sein`,\n mustBeHigherThan: date => `Muss nach dem ${date} sein`,\n mustBeLowerThan: date => `Muss vor dem ${date} sein`,\n mustBeBetween: (startDate, endDate) => `Muss in dieser Zeitspanne liegen ${startDate} - ${endDate}`,\n dateIsDisabled: 'Datum nicht wählbar',\n previous: 'Vorheriges',\n next: 'Nächstes',\n typeInDate: 'Datum eingeben',\n pickDateFromCalendar: 'Datum vom Kalender auswählen',\n close: 'Schliessen',\n minute: 'Minute',\n hour: 'Stunde'\n};\nexport default de;\n//# sourceMappingURL=de.js.map","\"use strict\";\n\nconst en = {\n save: 'Save',\n selectSingle: 'Select date',\n selectMultiple: 'Select dates',\n selectRange: 'Select period',\n notAccordingToDateFormat: inputFormat => `Date format must be ${inputFormat}`,\n mustBeHigherThan: date => `Must be later then ${date}`,\n mustBeLowerThan: date => `Must be earlier then ${date}`,\n mustBeBetween: (startDate, endDate) => `Must be between ${startDate} - ${endDate}`,\n dateIsDisabled: 'Day is not allowed',\n previous: 'Previous',\n next: 'Next',\n typeInDate: 'Type in date',\n pickDateFromCalendar: 'Pick date from calendar',\n close: 'Close',\n minute: 'Minute',\n hour: 'Hour'\n};\nexport default en;\n//# sourceMappingURL=en.js.map","\"use strict\";\n\nconst enGB = {\n save: 'Save',\n selectSingle: 'Select date',\n selectMultiple: 'Select dates',\n selectRange: 'Select period',\n notAccordingToDateFormat: inputFormat => `Date format must be ${inputFormat}`,\n mustBeHigherThan: date => `Must be later then ${date}`,\n mustBeLowerThan: date => `Must be earlier then ${date}`,\n mustBeBetween: (startDate, endDate) => `Must be between ${startDate} - ${endDate}`,\n dateIsDisabled: 'Day is not allowed',\n previous: 'Previous',\n next: 'Next',\n typeInDate: 'Type in date',\n pickDateFromCalendar: 'Pick date from calendar',\n close: 'Close',\n hour: 'Hour',\n minute: 'Minute'\n};\nexport default enGB;\n//# sourceMappingURL=enGB.js.map","\"use strict\";\n\nconst es = {\n save: 'Guardar',\n selectSingle: 'Seleccionar fecha',\n selectMultiple: 'Seleccionar fechas',\n selectRange: 'Seleccionar periodo',\n notAccordingToDateFormat: inputFormat => `Formato de fecha debe ser ${inputFormat}`,\n mustBeHigherThan: date => `Debe ser posterior a ${date}`,\n mustBeLowerThan: date => `Debe ser anterior a ${date}`,\n mustBeBetween: (startDate, endDate) => `Debe estar entre ${startDate} - ${endDate}`,\n dateIsDisabled: 'Día no permitido',\n previous: 'Anterior',\n next: 'Siguiente',\n typeInDate: 'Escribir fecha',\n pickDateFromCalendar: 'Seleccionar fecha del calendario',\n close: 'Cerrar',\n hour: 'Hora',\n minute: 'Minuto'\n};\nexport default es;\n//# sourceMappingURL=es.js.map","\"use strict\";\n\nconst fr = {\n save: 'Enregistrer',\n selectSingle: 'Sélectionner une date',\n selectMultiple: 'Sélectionner plusieurs dates',\n selectRange: 'Sélectionner une période',\n notAccordingToDateFormat: inputFormat => `La date doit être au format ${inputFormat}`,\n mustBeHigherThan: date => `La date doit être après le ${date}`,\n mustBeLowerThan: date => `La date doit être avant le ${date}`,\n mustBeBetween: (startDate, endDate) => `La date doit être entre le ${startDate} et le ${endDate}`,\n dateIsDisabled: \"Le jour n'est pas autorisé\",\n previous: 'Précédent',\n next: 'Suivant',\n typeInDate: 'Entrer la date',\n pickDateFromCalendar: 'Sélectionner une date dans le calendrier',\n close: 'Fermer',\n minute: 'minutes',\n hour: 'heures'\n};\nexport default fr;\n//# sourceMappingURL=fr.js.map","\"use strict\";\n\nconst he = {\n save: 'שמור',\n selectSingle: 'בחר תאריך',\n selectMultiple: 'בחר תאריכים',\n selectRange: 'בחר טווח',\n notAccordingToDateFormat: inputFormat => `פורמט של תאריך צריך להיות ${inputFormat}`,\n mustBeHigherThan: date => `חייב להיות אחרי ${date}`,\n mustBeLowerThan: date => `חייב להיות לפני ${date}`,\n mustBeBetween: (startDate, endDate) => `חייב להיות בין ${startDate} - ${endDate}`,\n dateIsDisabled: 'יום לא מורשה',\n previous: 'הקודם',\n next: 'הבא',\n typeInDate: 'הקש תאריך',\n pickDateFromCalendar: 'בחר תאריך מהלוח שנה',\n close: 'סגור',\n hour: 'שעה',\n minute: 'דקה'\n};\nexport default he;\n//# sourceMappingURL=he.js.map","\"use strict\";\n\nconst hi = {\n save: 'जमा करें',\n selectSingle: 'तारीख़ चुनें',\n selectMultiple: 'तारीख़ें चुनें',\n selectRange: 'अवधि चुनें',\n notAccordingToDateFormat: inputFormat => `तारीख़ का प्रारूप ${inputFormat} होना चाहिए`,\n mustBeHigherThan: date => `${date} के बाद होना चाहिए`,\n mustBeLowerThan: date => `${date} से पहले होना चाहिए`,\n mustBeBetween: (startDate, endDate) => `${startDate} - ${endDate} के बीच होना चाहिए`,\n dateIsDisabled: 'दिन की अनुमति नहीं है',\n previous: 'पिछला',\n next: 'अगला',\n typeInDate: 'तारीख़ लिखें',\n pickDateFromCalendar: 'कैलेंडर से तारीख़ चुनें',\n close: 'बंद करें',\n minute: 'मिनट',\n hour: 'घंटा'\n};\nexport default hi;\n//# sourceMappingURL=hi.js.map","\"use strict\";\n\nconst it = {\n save: 'Salva',\n selectSingle: 'Seleziona la data',\n selectMultiple: 'Seleziona le date',\n selectRange: 'Seleziona il periodo',\n notAccordingToDateFormat: inputFormat => `Il formato della data deve essere ${inputFormat}`,\n mustBeHigherThan: date => `Deve essere successivo a ${date}`,\n mustBeLowerThan: date => `Deve essere precedente a ${date}`,\n mustBeBetween: (startDate, endDate) => `Deve essere compreso tra ${startDate} - ${endDate}`,\n dateIsDisabled: 'Il giorno non è consentito',\n previous: 'Precedente',\n next: 'Successivo',\n typeInDate: 'Digita la data',\n pickDateFromCalendar: 'Scegli data dal calendario',\n close: 'Chiudi',\n hour: 'Ora',\n minute: 'Minuto'\n};\nexport default it;\n//# sourceMappingURL=it.js.map","\"use strict\";\n\nconst ko = {\n save: '저장',\n selectSingle: '날짜 선택',\n selectMultiple: '여러 날짜 선택',\n selectRange: '기간 선택',\n notAccordingToDateFormat: inputFormat => `날짜 형식은 ${inputFormat}가 되어야 합니다`,\n mustBeHigherThan: date => `${date} 보다 커야 합니다`,\n mustBeLowerThan: date => `${date} 보다 작아야 합니다`,\n mustBeBetween: (startDate, endDate) => `${startDate} - ${endDate} 사이여야 합니다`,\n dateIsDisabled: '날짜는 허용되지 않습니다',\n previous: '이전',\n next: '다음',\n typeInDate: '날짜 입력',\n pickDateFromCalendar: '달력에서 날짜 선택',\n close: '닫기',\n minute: '분',\n hour: '시'\n};\nexport default ko;\n//# sourceMappingURL=ko.js.map","\"use strict\";\n\nconst nl = {\n save: 'Opslaan',\n selectSingle: 'Selecteer datum',\n selectMultiple: 'Selecteer datums',\n selectRange: 'Selecteer periode',\n notAccordingToDateFormat: inputFormat => `Datumformaat moet ${inputFormat} zijn`,\n mustBeHigherThan: date => `Moet later dan ${date}`,\n mustBeLowerThan: date => `Moet eerder dan ${date}`,\n mustBeBetween: (startDate, endDate) => `Moet tussen ${startDate} - ${endDate}`,\n dateIsDisabled: 'Deze dag mag niet',\n previous: 'Vorige',\n next: 'Volgende',\n typeInDate: 'Typ datum',\n pickDateFromCalendar: 'Kies datum van kalender',\n close: 'Sluit',\n hour: 'Uur',\n minute: 'Minuut'\n};\nexport default nl;\n//# sourceMappingURL=nl.js.map","\"use strict\";\n\nconst pl = {\n save: 'Zapisz',\n selectSingle: 'Wybierz datę',\n selectMultiple: 'Wybierz daty',\n selectRange: 'Wybierz zakres',\n notAccordingToDateFormat: inputFormat => `Data musi mieć format ${inputFormat}`,\n mustBeHigherThan: date => `Nie wcześniej niżn ${date}`,\n mustBeLowerThan: date => `Nie później niż ${date}`,\n mustBeBetween: (startDate, endDate) => `Pomiędzy ${startDate} - ${endDate}`,\n dateIsDisabled: 'Niedozwolona data',\n previous: 'Poprzedni',\n next: 'Dalej',\n typeInDate: 'Wpisz datę',\n pickDateFromCalendar: 'Wybierz datę z kalendarza',\n close: 'Zamknij',\n minute: 'Minuta',\n hour: 'Godzina'\n};\nexport default pl;\n//# sourceMappingURL=pl.js.map","\"use strict\";\n\nconst pt = {\n save: 'Salvar',\n selectSingle: 'Selecione a data',\n selectMultiple: 'Selecione as datas',\n selectRange: 'Selecione o período',\n notAccordingToDateFormat: inputFormat => `O formato da data deve ser ${inputFormat}`,\n mustBeHigherThan: date => `Deve ser depois de ${date}`,\n mustBeLowerThan: date => `Deve ser antes de ${date}`,\n mustBeBetween: (startDate, endDate) => `Deve estar entre ${startDate} - ${endDate}`,\n dateIsDisabled: 'Data não é permitida',\n previous: 'Anterior',\n next: 'Próximo',\n typeInDate: 'Digite a data',\n pickDateFromCalendar: 'Escolha a data do calendário',\n close: 'Fechar',\n hour: 'Hora',\n minute: 'Minuto'\n};\nexport default pt;\n//# sourceMappingURL=pt.js.map","\"use strict\";\n\nconst tr = {\n save: 'Kaydet',\n selectSingle: 'Tarih seç',\n selectMultiple: 'Tarihleri seç',\n selectRange: 'Periyot seç',\n notAccordingToDateFormat: inputFormat => `Tarih formatı ${inputFormat} olmalı`,\n mustBeHigherThan: date => `${date} tarihinden sonra olmalı`,\n mustBeLowerThan: date => `${date} tarihinden önce olmalı`,\n mustBeBetween: (startDate, endDate) => `${startDate} - ${endDate} tarihleri arasında olmalı`,\n dateIsDisabled: 'Gün seçilemez',\n previous: 'Önceki',\n next: 'Sonraki',\n typeInDate: 'Tarihi yazın',\n pickDateFromCalendar: 'Takvimden tarih seçin',\n close: 'Kapat',\n minute: 'Dakika',\n hour: 'Saat'\n};\nexport default tr;\n//# sourceMappingURL=tr.js.map","\"use strict\";\n\nconst zh = {\n save: '保存',\n selectSingle: '选择日期',\n selectMultiple: '选择多个日期',\n selectRange: '选择期间',\n notAccordingToDateFormat: inputFormat => `日期格式必须是 ${inputFormat}`,\n mustBeHigherThan: date => `必须晚于 ${date}`,\n mustBeLowerThan: date => `必须早于 ${date}`,\n mustBeBetween: (startDate, endDate) => `必须在 ${startDate} - ${endDate} 之间`,\n dateIsDisabled: '日期不可选',\n previous: '上一个',\n next: '下一个',\n typeInDate: '输入日期',\n pickDateFromCalendar: '从日历中选择日期',\n close: '关闭',\n hour: '小时',\n minute: '分钟'\n};\nexport default zh;\n//# sourceMappingURL=zh.js.map","\"use strict\";\n\nconst zhTW = {\n save: '保存',\n selectSingle: '選擇日期',\n selectMultiple: '選擇多個日期',\n selectRange: '選擇期間',\n notAccordingToDateFormat: inputFormat => `日期格式必須是 ${inputFormat}`,\n mustBeHigherThan: date => `必須晚於 ${date}`,\n mustBeLowerThan: date => `必須早於 ${date}`,\n mustBeBetween: (startDate, endDate) => `必須在 ${startDate} - ${endDate} 之間`,\n dateIsDisabled: '日期不可選',\n previous: '上一個',\n next: '下一個',\n typeInDate: '輸入日期',\n pickDateFromCalendar: '從日曆中選擇日期',\n close: '關閉',\n minute: '分鐘',\n hour: '小時'\n};\nexport default zhTW;\n//# sourceMappingURL=zhTW.js.map","\"use strict\";\n\nconst cs = {\n save: 'Uložit',\n selectSingle: 'Vyberte datum',\n selectMultiple: 'Vyberte data',\n selectRange: 'Vyberte období',\n notAccordingToDateFormat: inputFormat => `Formát data musí být ${inputFormat}`,\n mustBeHigherThan: date => `Musí to být později ${date}`,\n mustBeLowerThan: date => `Musí to být dříve ${date}`,\n mustBeBetween: (startDate, endDate) => `Musí být mezi ${startDate} - ${endDate}`,\n dateIsDisabled: 'Den není povolen',\n previous: 'Předchozí',\n next: 'další ',\n typeInDate: 'Zadejte datum',\n pickDateFromCalendar: 'Vyberte datum z kalendáře',\n close: 'Zavřít',\n minute: 'minuta',\n hour: 'hodina'\n};\nexport default cs;\n//# sourceMappingURL=cs.js.map","\"use strict\";\n\nconst el = {\n save: 'Αποθηκεύσετε',\n selectSingle: 'Επιλέξτε ημερομηνία',\n selectMultiple: 'Επιλέξτε ημερομηνίες',\n selectRange: 'Επιλέξτε περίοδο',\n notAccordingToDateFormat: inputFormat => `Η μορφή ημερομηνίας πρέπει να είναι ${inputFormat}`,\n mustBeHigherThan: date => `Πρέπει να είναι αργότερα${date}`,\n mustBeLowerThan: date => `Πρέπει να είναι νωρίτερα τότε ${date}`,\n mustBeBetween: (startDate, endDate) => `Πρέπει να είναι μεταξύ ${startDate} - ${endDate}`,\n dateIsDisabled: 'Ημέρα δεν επιτρέπεται',\n previous: 'Προηγούμενος',\n next: 'Επόμενο',\n typeInDate: 'Πληκτρολογήστε την ημερομηνία',\n pickDateFromCalendar: 'Επιλέξτε ημερομηνία από το ημερολόγιο',\n close: 'Κλείσε',\n minute: 'λεπτό',\n hour: 'ώρα'\n};\nexport default el;\n//# sourceMappingURL=el.js.map","\"use strict\";\n\nconst ru = {\n save: 'Сохранить',\n selectSingle: 'Выбор даты',\n selectMultiple: 'Выбор дат',\n selectRange: 'Выбор диапазона',\n notAccordingToDateFormat: inputFormat => `Формат даты должен быть ${inputFormat}`,\n mustBeHigherThan: date => `Должен быть позже, чем ${date}`,\n mustBeLowerThan: date => `Должен быть ранее, чем ${date}`,\n mustBeBetween: (startDate, endDate) => `Должен быть между ${startDate} - ${endDate}`,\n dateIsDisabled: 'День не разрешён',\n previous: 'Предыдущий',\n next: 'Следующий',\n typeInDate: 'Ввод в дате',\n pickDateFromCalendar: 'Выбор даты из календаря',\n close: 'Закрыть',\n hour: 'Час',\n minute: 'Минута'\n};\nexport default ru;\n//# sourceMappingURL=ru.js.map","\"use strict\";\n\nconst ro = {\n save: 'Salvează',\n selectSingle: 'Selectează data',\n selectMultiple: 'Selectează datele',\n selectRange: 'Selectează perioada',\n notAccordingToDateFormat: inputFormat => `Formatul datei trebuie să fie ${inputFormat}`,\n mustBeHigherThan: date => `Trebuie să fie mai târziu de ${date}`,\n mustBeLowerThan: date => `Trebuie să fie mai devreme de ${date}`,\n mustBeBetween: (startDate, endDate) => `Trebuie să fie între ${startDate} - ${endDate}`,\n dateIsDisabled: 'Data nu este permisă',\n previous: 'Anterior',\n next: 'Următorul',\n typeInDate: 'Tipul în dată',\n pickDateFromCalendar: 'Alege o dată din calendar',\n close: 'Închide',\n minute: 'Minut',\n hour: 'Oră'\n};\nexport default ro;\n//# sourceMappingURL=ro.js.map","\"use strict\";\n\nconst id = {\n save: 'Simpan',\n selectSingle: 'Pilih tanggal',\n selectMultiple: 'Pilih tanggal',\n selectRange: 'Pilih periode',\n notAccordingToDateFormat: inputFormat => `Format tanggal harus ${inputFormat}`,\n mustBeHigherThan: date => `Harus lebih besar dari ${date}`,\n mustBeLowerThan: date => `Harus lebih kecil dari ${date}`,\n mustBeBetween: (startDate, endDate) => `Harus di antara ${startDate} - ${endDate}`,\n dateIsDisabled: 'Hari tidak diperbolehkan',\n previous: 'Sebelumnya',\n next: 'Berikutnya',\n typeInDate: 'Ketik tanggal',\n pickDateFromCalendar: 'Pilih tanggal dari kalender',\n close: 'Tutup',\n minute: 'Menit',\n hour: 'Jam'\n};\nexport default id;\n//# sourceMappingURL=id.js.map","\"use strict\";\n\nconst ja = {\n save: '保存',\n selectSingle: '日付を選択',\n selectMultiple: '日付を選択',\n selectRange: '期間を選択',\n notAccordingToDateFormat: inputFormat => `形式が無効です。使用:${inputFormat}`,\n mustBeHigherThan: date => `${date}より後にする必要があります`,\n mustBeLowerThan: date => `${date}より前にする必要があります`,\n mustBeBetween: (startDate, endDate) => `${startDate} - ${endDate}の範囲で入力してください`,\n dateIsDisabled: '日付は入力できません',\n previous: '前へ',\n next: '次へ',\n typeInDate: '日付を入力',\n pickDateFromCalendar: 'カレンダーから日付を選択',\n close: '閉じる',\n minute: '分',\n hour: '時'\n};\nexport default ja;\n//# sourceMappingURL=ja.js.map","\"use strict\";\n\nconst th = {\n save: 'บันทึก',\n selectSingle: 'เลือกวันที่',\n selectMultiple: 'เลือกวันที่',\n selectRange: 'เลือกช่วงวันที่',\n notAccordingToDateFormat: inputFormat => `รูปแบบวันที่จะต้องเป็น ${inputFormat}`,\n mustBeHigherThan: date => `ต้องอยู่ภายหลังวันที่ ${date}`,\n mustBeLowerThan: date => `ต้องอยู่ก่อนวันที่ ${date}`,\n mustBeBetween: (startDate, endDate) => `ต้องอยู่ในช่วงวันที่ ${startDate} - ${endDate}`,\n dateIsDisabled: 'ไม่สามารถใช้วันที่นี้ได้',\n previous: 'ก่อนหน้า',\n next: 'ถัดไป',\n typeInDate: 'พิมพ์วันที่',\n pickDateFromCalendar: 'เลือกวันที่จากปฏิทิน',\n close: 'ปิด',\n minute: 'นาที',\n hour: 'ชั่วโมง'\n};\nexport default th;\n//# sourceMappingURL=th.js.map","\"use strict\";\n\nconst ukUA = {\n save: 'Зберегти',\n selectSingle: 'Оберіть дату',\n selectMultiple: 'Оберіть дати',\n selectRange: 'Оберіть період',\n notAccordingToDateFormat: inputFormat => `Формат дати має бути ${inputFormat}`,\n mustBeHigherThan: date => `Має бути пізніше ніж ${date}`,\n mustBeLowerThan: date => `Має бути раніше ніж ${date}`,\n mustBeBetween: (startDate, endDate) => `Має бути між ${startDate} - ${endDate}`,\n dateIsDisabled: 'Цей день не дозволено обирати',\n previous: 'Попередній',\n next: 'Наступний',\n typeInDate: 'Введіть дату',\n pickDateFromCalendar: 'Оберіть дату з календаря',\n close: 'Закрити',\n hour: 'Година',\n minute: 'Хвилина'\n};\nexport default ukUA;\n//# sourceMappingURL=ukUA.js.map","\"use strict\";\n\nconst noNO = {\n save: 'Lagre',\n selectSingle: 'Velg dato',\n selectMultiple: 'Velg datoer',\n selectRange: 'Velg periode',\n notAccordingToDateFormat: inputFormat => `Datoformatet må være ${inputFormat}`,\n mustBeHigherThan: date => `Må være senere enn ${date}`,\n mustBeLowerThan: date => `Må være tidligere enn ${date}`,\n mustBeBetween: (startDate, endDate) => `Må være mellom ${startDate} - ${endDate}`,\n dateIsDisabled: 'Denne dagen er ikke tillatt',\n previous: 'Forrige',\n next: 'Neste',\n typeInDate: 'Skriv inn dato',\n pickDateFromCalendar: 'Velg dato fra kalenderen',\n close: 'Lukk',\n hour: 'Time',\n minute: 'Minutt'\n};\nexport default noNO;\n//# sourceMappingURL=noNO.js.map","import React, {useContext} from \"react\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport {ModalM} from \"@common/components/modal/ModalM\";\nimport {ScrollView, View} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport {ListItemM} from \"@common/components/list/ListItemM\";\nimport {ListGroupM} from \"@common/components/list/ListGroupM\";\nimport {daysOptions} from \"@data/constants/formConstants\";\nimport {useController} from \"react-hook-form\";\nimport TitleM from \"@common/components/text/TitleM\";\n\nexport default function SelectDayModal({\n isOpen,\n handleShowModal,\n navigation,\n initialValue = null,\n control,\n index,\n fieldName = \"days\",\n onConfirmDay\n }) {\n const dimensions = useContext(DimensionsContext)\n const {field} = useController({\n control,\n name: fieldName\n })\n return (\n 800 ? \"50%\" : \"90%\", maxHeight: \"80%\"}}>\n 800 ? \"row\" : \"column\",\n flexWrap: \"wrap\",\n justifyContent: \"center\",\n paddingBottom: 30\n }}>\n Sélectionner un jour\n \n {\n return {\n field.onChange(item.item?.value)\n onConfirmDay(item.item?.label, index, item.item.value)\n handleShowModal()\n }}\n itemHeight={70}\n selected={item.item?.value === field.value || item.item?.value === initialValue}\n option={item.item}\n disabled={item.item?.disabled}\n />\n }}\n />\n \n \n \n )\n}","import React, { useContext } from \"react\";\nimport { Modal, Portal } from \"react-native-paper\";\nimport { theme } from \"../../theme/theme\";\nimport { DimensionsContext } from \"../../utils/mobileUtils\";\n\nexport const ModalM = (props) => {\n const {visible, onDismiss, children, style, dismissable = true, takeFullScreenWidth = false} = props\n const dimensions = useContext(DimensionsContext)\n\n return \n \n \n {children}\n \n \n \n}","import * as ImagePicker from \"expo-image-picker\"\nimport React, { useContext, useEffect, useRef, useState } from \"react\"\nimport { Dimensions, FlatList, Vibration, View } from \"react-native\"\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\"\nimport TextM from \"../components/text/TextM\"\nimport { theme } from \"../theme/theme\"\nimport { DimensionsContext, IS_WEB } from \"../utils/mobileUtils\"\nimport PhotoElement from \"./PhotoElement\"\n//import ImageView from \"react-native-image-viewing\";\nimport { DialogM } from \"@common/components/alert/dialog/Dialog\"\nimport FilledButtonM from \"@common/components/button/FilledButtonM\"\nimport { useCamera } from \"@common/hooks/useCamera\"\nimport { apiIdle, apiRequest } from \"@data/redux/actions/api\"\nimport { clearLastPhoto, clearPhotos } from \"@data/redux/actions/camera\"\nimport { activitiesService } from \"@data/services/activitiesService\"\nimport { GestureHandlerRootView } from \"react-native-gesture-handler\"\nimport { TouchableRipple } from \"react-native-paper\"\nimport { connect } from \"react-redux\"\nimport ImageViewer from \"../components/image/ImageViewer\"\nimport { ModalM } from \"../components/modal/ModalM\"\n\nexport const pickImage = async (images, setImages) => {\n // No permissions request is necessary for launching the image library\n let result = await ImagePicker.launchImageLibraryAsync({\n mediaTypes: ImagePicker.MediaTypeOptions.Images,\n // allowsEditing: true,\n // aspect: [4, 3],\n quality: 1,\n })\n\n //console.log(result);\n if (!result.canceled) {\n const imagesCopy = images?.map((x) => x) ?? []\n imagesCopy?.push({\n uri: result.assets[0].uri,\n width: result.assets[0].width,\n height: result.assets[0].height,\n selected: false,\n })\n setImages(imagesCopy)\n }\n}\n\nexport const ImagesList = (props) => {\n const {\n listHeaderComponent = () => <>,\n listFooterComponent = () => <>,\n contentHeight,\n style,\n images,\n photoLongPress = () => {},\n\n withChrono = false,\n time,\n isSelecting = false,\n useFullWidthToScroll = false,\n longPressDisabled = false,\n resendComponent,\n noResend = false,\n } = props\n\n const dimensions = useContext(DimensionsContext)\n const flatListRef = useRef()\n // ** Image viewer\n // const [visible, setVisible] = useState(false)\n const [openImageViewer, setOpenImageViewer] = useState(false)\n const [visibleIndex, setVisibleIndex] = useState(0)\n const hideImageViewer = () => {\n return setOpenImageViewer(false)\n }\n\n useEffect(() => {\n flatListRef?.current?.scrollToEnd({ animated: false })\n }, [])\n\n // const hideImageView = () => {\n // setVisible(false)\n // setVisibleIndex(0)\n // }\n\n return (\n <>\n ({\n length: contentHeight,\n offset: contentHeight * index,\n index,\n })}\n horizontal\n style={{\n // marginTop: 10,\n //backgroundColor: \"red\",\n width: dimensions?.width,\n alignSelf: \"center\",\n ...style,\n }}\n contentContainerStyle={{\n // backgroundColor: \"blue\",\n alignItems: \"center\",\n justifyContent: \"center\",\n height: contentHeight,\n }}\n ListHeaderComponent={listHeaderComponent}\n ListFooterComponent={listFooterComponent}\n keyExtractor={(item, index) => index.toString()}\n renderItem={(itemInfo) => {\n return (\n photoLongPress(itemInfo.index)\n : () => {}\n }\n longPressDisabled={longPressDisabled}\n onPress={() => {\n // press(itemInfo.index)\n setOpenImageViewer(true)\n setVisibleIndex(itemInfo.index)\n }}\n showResend={!itemInfo.item?.id && !noResend}\n resendComponent={resendComponent}\n />\n )\n }}\n />\n\n i?.uri)}\n withChrono={withChrono}\n time={time}\n useFullWidthToScroll={useFullWidthToScroll}\n />\n \n )\n}\n\nexport function ImageViewerModal(props) {\n const {\n visible,\n onDismiss,\n imageIndex = 0,\n images,\n withChrono,\n time,\n useFullWidthToScroll = false,\n } = props\n const dimensions = useContext(DimensionsContext)\n\n return (\n \n \n \n \n \n )\n}\n\nfunction CameraImagesM(props) {\n const {\n images,\n setImages,\n formId,\n style,\n dismissModal = () => {},\n useFullWidthToScroll = false,\n activityId = null,\n noButton = false,\n longPressDisabled = false,\n imagesDimensions = null,\n onRetry,\n noResend = false,\n } = props\n\n //const navigation = useNavigation()\n const [isSelecting, setIsSelecting] = useState(false)\n const bottomSheetRef = useRef()\n\n const [permissionStatus, requestPermission] =\n ImagePicker.useCameraPermissions()\n const dimensions = useContext(DimensionsContext)\n\n // console.log(\"images\", images)\n\n // function useForceUpdate() {\n // const [value, setValue] = useState(0); // integer state\n // return () => setValue(value => value + 1); // update state to force render\n // // A function that increment 👆🏻 the previous state like here\n // // is better than directly setting `setValue(value + 1)`\n // }\n\n // const forceUpdate = useForceUpdate()\n // const pickImage = async () => {\n // // No permissions request is necessary for launching the image library\n // let result = await ImagePicker.launchImageLibraryAsync({\n // mediaTypes: ImagePicker.MediaTypeOptions.Images,\n // allowsEditing: true,\n // aspect: [4, 3],\n // quality: 1,\n // });\n //\n // //console.log(result);\n // if (!result.canceled) {\n // const imagesCopy = images?.map(x => x) ?? []\n // imagesCopy?.push({\n // uri: result.assets[0].uri,\n // width: result.assets[0].width,\n // height: result.assets[0].height,\n // selected: false\n // })\n // setImages(imagesCopy);\n // }\n // forceUpdate();\n // };\n\n //console.log(dimensions)\n useEffect(() => {\n if (\n props.lastPhotoFormId === formId &&\n !!props.lastPhoto &&\n !images?.map((x) => x?.uri)?.includes(props.lastPhoto?.uri)\n ) {\n const imagesCopy = images?.map((x) => x) ?? []\n imagesCopy?.push(props.lastPhoto)\n setImages(imagesCopy)\n props.clearLastPhoto()\n // navigation.navigate(\"Activité\", {\n // newImage: null\n // })\n // console.log(imagesCopy)\n } else if (\n props.lastPhotoFormId === formId &&\n props.lastPhotos?.length > 0\n ) {\n const imagesCopy = images?.map((x) => x) ?? []\n imagesCopy?.push(...props.lastPhotos)\n setImages(imagesCopy)\n props.clearPhotos()\n }\n //console.log(props.lastPhotos)\n }, [props.lastPhoto, props.lastPhotos])\n\n const longPress = (index) => {\n if (isSelecting || longPressDisabled) return\n Vibration.vibrate(50)\n // setIsSelecting(true)\n const copy = images?.slice()\n copy[index].selected = true\n setImages(copy)\n // bottomSheetRef.current.present()\n dismissModal()\n DialogM.show({\n text1: \"Supprimer la photo ?\",\n text2: \"\",\n buttonText1: \"Supprimer\",\n buttonColor1: theme.colors.error,\n onPress: () => {\n setImages((images) => images.filter((x) => !x.selected))\n if (activityId && images[index]?.id)\n props.apiRequest(\n activitiesService.deleteActivityLog,\n { id: images[index]?.id },\n {\n live_mode: !!props.liveSessionId,\n live_session_id: props.liveSessionId ?? undefined,\n }\n )\n resetSelection()\n },\n buttonText2: \"Annuler\",\n onPressBack: resetSelection,\n })\n }\n\n const press = (index) => {\n if (isSelecting) {\n const copy = images?.slice()\n copy[index].selected = !copy[index].selected\n setImages(copy)\n }\n }\n\n const resetSelection = () => {\n setIsSelecting(false)\n //bottomSheetRef.current.dismiss()\n setImages((images) => images.map((x) => ({ ...x, selected: false })))\n }\n\n const height = imagesDimensions\n ? imagesDimensions?.height + 100\n : dimensions?.height * 0.4\n\n const [launchCamera] = useCamera(formId, true, true)\n\n const resendComponent = () => {\n return (\n \n )\n }\n\n return (\n \n !noButton && (\n \n {\n launchCamera()\n dismissModal()\n }}\n underlayColor={theme.colors.lighter}\n disabled={isSelecting}\n style={{\n flex: 1,\n width: images?.length === 0 ? \"100%\" : 190,\n //height: height\n // alignSelf: \"center\"\n }}\n >\n \n \n \n {images?.length === 0\n ? \"Prendre une photo\"\n : \"Ajouter une photo\"}\n \n \n \n {props.useGallery && (\n {\n pickImage(images, setImages).then()\n }}\n underlayColor={theme.colors.lighter}\n disabled={isSelecting}\n style={{\n flex: 1,\n width: images?.length === 0 ? \"100%\" : 190,\n //height: height,\n // alignSelf: \"center\"\n }}\n >\n \n \n \n Galerie\n \n \n \n )}\n \n )\n }\n photoLongPress={longPress}\n longPressDisabled={longPressDisabled}\n images={images}\n contentHeight={height}\n style={style}\n />\n )\n}\n\nconst mapStateToProps = (state) => {\n return {\n user: state.data.currentUser?.object,\n lastPhoto: state.camera?.lastPhoto,\n lastPhotos: state.camera?.lastPhotos,\n lastPhotoFormId: state.camera?.formId,\n liveSessionId: state.liveMode?.liveSessionId,\n postActivityLogsError: state.api.postActivityLogs?.error,\n audioStatus: state.activity?.audioStatus,\n }\n}\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle,\n clearLastPhoto,\n clearPhotos,\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CameraImagesM)","import { PermissionStatus, createPermissionHook, UnavailabilityError, CodedError, } from 'expo-modules-core';\nimport ExponentImagePicker from './ExponentImagePicker';\nfunction validateOptions(options) {\n const { aspect, quality, videoMaxDuration } = options;\n if (aspect != null) {\n const [x, y] = aspect;\n if (x <= 0 || y <= 0) {\n throw new CodedError('ERR_INVALID_ARGUMENT', `Invalid aspect ratio values ${x}:${y}. Provide positive numbers.`);\n }\n }\n if (quality && (quality < 0 || quality > 1)) {\n throw new CodedError('ERR_INVALID_ARGUMENT', `Invalid 'quality' value ${quality}. Provide a value between 0 and 1.`);\n }\n if (videoMaxDuration && videoMaxDuration < 0) {\n throw new CodedError('ERR_INVALID_ARGUMENT', `Invalid 'videoMaxDuration' value ${videoMaxDuration}. Provide a non-negative number.`);\n }\n return options;\n}\n// @needsAudit\n/**\n * Checks user's permissions for accessing camera.\n * @return A promise that fulfills with an object of type [CameraPermissionResponse](#camerapermissionresponse).\n */\nexport async function getCameraPermissionsAsync() {\n return ExponentImagePicker.getCameraPermissionsAsync();\n}\n// @needsAudit\n/**\n * Checks user's permissions for accessing photos.\n * @param writeOnly Whether to request write or read and write permissions. Defaults to `false`\n * @return A promise that fulfills with an object of type [MediaLibraryPermissionResponse](#medialibrarypermissionresponse).\n */\nexport async function getMediaLibraryPermissionsAsync(writeOnly = false) {\n return ExponentImagePicker.getMediaLibraryPermissionsAsync(writeOnly);\n}\n// @needsAudit\n/**\n * Asks the user to grant permissions for accessing camera. This does nothing on web because the\n * browser camera is not used.\n * @return A promise that fulfills with an object of type [CameraPermissionResponse](#camerarollpermissionresponse).\n */\nexport async function requestCameraPermissionsAsync() {\n return ExponentImagePicker.requestCameraPermissionsAsync();\n}\n// @needsAudit\n/**\n * Asks the user to grant permissions for accessing user's photo. This method does nothing on web.\n * @param writeOnly Whether to request write or read and write permissions. Defaults to `false`\n * @return A promise that fulfills with an object of type [MediaLibraryPermissionResponse](#medialibrarypermissionresponse).\n */\nexport async function requestMediaLibraryPermissionsAsync(writeOnly = false) {\n const imagePickerMethod = ExponentImagePicker.requestMediaLibraryPermissionsAsync;\n return imagePickerMethod(writeOnly);\n}\n// @needsAudit\n/**\n * Check or request permissions to access the media library.\n * This uses both `requestMediaLibraryPermissionsAsync` and `getMediaLibraryPermissionsAsync` to interact with the permissions.\n *\n * @example\n * ```ts\n * const [status, requestPermission] = ImagePicker.useMediaLibraryPermissions();\n * ```\n */\nexport const useMediaLibraryPermissions = createPermissionHook({\n // TODO(cedric): permission requesters should have an options param or a different requester\n getMethod: (options) => getMediaLibraryPermissionsAsync(options?.writeOnly),\n requestMethod: (options) => requestMediaLibraryPermissionsAsync(options?.writeOnly),\n});\n// @needsAudit\n/**\n * Check or request permissions to access the camera.\n * This uses both `requestCameraPermissionsAsync` and `getCameraPermissionsAsync` to interact with the permissions.\n *\n * @example\n * ```ts\n * const [status, requestPermission] = ImagePicker.useCameraPermissions();\n * ```\n */\nexport const useCameraPermissions = createPermissionHook({\n getMethod: getCameraPermissionsAsync,\n requestMethod: requestCameraPermissionsAsync,\n});\n// @needsAudit\n/**\n * Android system sometimes kills the `MainActivity` after the `ImagePicker` finishes. When this\n * happens, we lost the data selected from the `ImagePicker`. However, you can retrieve the lost\n * data by calling `getPendingResultAsync`. You can test this functionality by turning on\n * `Don't keep activities` in the developer options.\n * @return\n * - **On Android:** a promise that resolves to an array of objects of exactly same type as in\n * `ImagePicker.launchImageLibraryAsync` or `ImagePicker.launchCameraAsync` if the `ImagePicker`\n * finished successfully. Otherwise, to the array of [`ImagePickerErrorResult`](#imagepickerimagepickererrorresult).\n * - **On other platforms:** an empty array.\n */\nexport async function getPendingResultAsync() {\n if (ExponentImagePicker.getPendingResultAsync) {\n return ExponentImagePicker.getPendingResultAsync();\n }\n return [];\n}\n// @needsAudit\n/**\n * Display the system UI for taking a photo with the camera. Requires `Permissions.CAMERA`.\n * On Android and iOS 10 `Permissions.CAMERA_ROLL` is also required. On mobile web, this must be\n * called immediately in a user interaction like a button press, otherwise the browser will block\n * the request without a warning.\n * > **Note:** Make sure that you handle `MainActivity` destruction on **Android**. See [ImagePicker.getPendingResultAsync](#imagepickergetpendingresultasync).\n * > **Notes for Web:** The system UI can only be shown after user activation (e.g. a `Button` press).\n * Therefore, calling `launchCameraAsync` in `componentDidMount`, for example, will **not** work as\n * intended. The `cancelled` event will not be returned in the browser due to platform restrictions\n * and inconsistencies across browsers.\n * @param options An `ImagePickerOptions` object.\n * @return A promise that resolves to an object with `canceled` and `assets` fields.\n * When the user canceled the action the `assets` is always `null`, otherwise it's an array of\n * the selected media assets which have a form of [`ImagePickerAsset`](#imagepickerasset).\n */\nexport async function launchCameraAsync(options = {}) {\n if (!ExponentImagePicker.launchCameraAsync) {\n throw new UnavailabilityError('ImagePicker', 'launchCameraAsync');\n }\n return await ExponentImagePicker.launchCameraAsync(validateOptions(options));\n}\n// @needsAudit\n/**\n * Display the system UI for choosing an image or a video from the phone's library.\n * Requires `Permissions.MEDIA_LIBRARY` on iOS 10 only. On mobile web, this must be called\n * immediately in a user interaction like a button press, otherwise the browser will block the\n * request without a warning.\n *\n * **Animated GIFs support:** On Android, if the selected image is an animated GIF, the result image will be an\n * animated GIF too if and only if `quality` is explicitly set to `1.0` and `allowsEditing` is set to `false`.\n * Otherwise compression and/or cropper will pick the first frame of the GIF and return it as the\n * result (on Android the result will be a PNG). On iOS, both quality and cropping are supported.\n *\n * > **Notes for Web:** The system UI can only be shown after user activation (e.g. a `Button` press).\n * Therefore, calling `launchImageLibraryAsync` in `componentDidMount`, for example, will **not**\n * work as intended. The `cancelled` event will not be returned in the browser due to platform\n * restrictions and inconsistencies across browsers.\n * @param options An object extended by [`ImagePickerOptions`](#imagepickeroptions).\n * @return A promise that resolves to an object with `canceled` and `assets` fields.\n * When the user canceled the action the `assets` is always `null`, otherwise it's an array of\n * the selected media assets which have a form of [`ImagePickerAsset`](#imagepickerasset).\n */\nexport async function launchImageLibraryAsync(options) {\n if (!ExponentImagePicker.launchImageLibraryAsync) {\n throw new UnavailabilityError('ImagePicker', 'launchImageLibraryAsync');\n }\n if (options?.allowsEditing && options.allowsMultipleSelection) {\n console.warn('[expo-image-picker] `allowsEditing` is not supported when `allowsMultipleSelection` is enabled and will be ignored.' +\n \"Disable either 'allowsEditing' or 'allowsMultipleSelection' in 'launchImageLibraryAsync' \" +\n 'to fix this warning.');\n }\n return await ExponentImagePicker.launchImageLibraryAsync(options ?? {});\n}\nexport * from './ImagePicker.types';\nexport { PermissionStatus };\n//# sourceMappingURL=ImagePicker.js.map","import { PermissionStatus, Platform } from 'expo-modules-core';\nimport { MediaTypeOptions, } from './ImagePicker.types';\nconst MediaTypeInput = {\n [MediaTypeOptions.All]: 'video/mp4,video/quicktime,video/x-m4v,video/*,image/*',\n [MediaTypeOptions.Images]: 'image/*',\n [MediaTypeOptions.Videos]: 'video/mp4,video/quicktime,video/x-m4v,video/*',\n};\nexport default {\n async launchImageLibraryAsync({ mediaTypes = MediaTypeOptions.Images, allowsMultipleSelection = false, base64 = false, }) {\n // SSR guard\n if (!Platform.isDOMAvailable) {\n return { canceled: true, assets: null };\n }\n return await openFileBrowserAsync({\n mediaTypes,\n allowsMultipleSelection,\n base64,\n });\n },\n async launchCameraAsync({ mediaTypes = MediaTypeOptions.Images, allowsMultipleSelection = false, base64 = false, }) {\n // SSR guard\n if (!Platform.isDOMAvailable) {\n return { canceled: true, assets: null };\n }\n return await openFileBrowserAsync({\n mediaTypes,\n allowsMultipleSelection,\n capture: true,\n base64,\n });\n },\n /*\n * Delegate to expo-permissions to request camera permissions\n */\n async getCameraPermissionsAsync() {\n return permissionGrantedResponse();\n },\n async requestCameraPermissionsAsync() {\n return permissionGrantedResponse();\n },\n /*\n * Camera roll permissions don't need to be requested on web, so we always\n * respond with granted.\n */\n async getMediaLibraryPermissionsAsync(_writeOnly) {\n return permissionGrantedResponse();\n },\n async requestMediaLibraryPermissionsAsync(_writeOnly) {\n return permissionGrantedResponse();\n },\n};\nfunction permissionGrantedResponse() {\n return {\n status: PermissionStatus.GRANTED,\n expires: 'never',\n granted: true,\n canAskAgain: true,\n };\n}\nfunction openFileBrowserAsync({ mediaTypes, capture = false, allowsMultipleSelection = false, base64, }) {\n const mediaTypeFormat = MediaTypeInput[mediaTypes];\n const input = document.createElement('input');\n input.style.display = 'none';\n input.setAttribute('type', 'file');\n input.setAttribute('accept', mediaTypeFormat);\n input.setAttribute('id', String(Math.random()));\n if (allowsMultipleSelection) {\n input.setAttribute('multiple', 'multiple');\n }\n if (capture) {\n input.setAttribute('capture', 'camera');\n }\n document.body.appendChild(input);\n return new Promise((resolve) => {\n input.addEventListener('change', async () => {\n if (input.files) {\n const files = allowsMultipleSelection ? input.files : [input.files[0]];\n const assets = await Promise.all(Array.from(files).map((file) => readFile(file, { base64 })));\n resolve({ canceled: false, assets });\n }\n else {\n resolve({ canceled: true, assets: null });\n }\n document.body.removeChild(input);\n });\n const event = new MouseEvent('click');\n input.dispatchEvent(event);\n });\n}\nfunction readFile(targetFile, options) {\n return new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onerror = () => {\n reject(new Error(`Failed to read the selected media because the operation failed.`));\n };\n reader.onload = ({ target }) => {\n const uri = target.result;\n const returnRaw = () => resolve({ uri, width: 0, height: 0 });\n if (typeof uri === 'string') {\n const image = new Image();\n image.src = uri;\n image.onload = () => {\n resolve({\n uri,\n width: image.naturalWidth ?? image.width,\n height: image.naturalHeight ?? image.height,\n mimeType: targetFile.type,\n fileName: targetFile.name,\n // The blob's result cannot be directly decoded as Base64 without\n // first removing the Data-URL declaration preceding the\n // Base64-encoded data. To retrieve only the Base64 encoded string,\n // first remove data:*/*;base64, from the result.\n // https://developer.mozilla.org/en-US/docs/Web/API/FileReader/readAsDataURL\n ...(options.base64 && { base64: uri.substr(uri.indexOf(',') + 1) }),\n });\n };\n image.onerror = () => returnRaw();\n }\n else {\n returnRaw();\n }\n };\n reader.readAsDataURL(targetFile);\n });\n}\n//# sourceMappingURL=ExponentImagePicker.web.js.map","// @needsAudit\nexport var MediaTypeOptions;\n(function (MediaTypeOptions) {\n /**\n * Images and videos.\n */\n MediaTypeOptions[\"All\"] = \"All\";\n /**\n * Only videos.\n */\n MediaTypeOptions[\"Videos\"] = \"Videos\";\n /**\n * Only images.\n */\n MediaTypeOptions[\"Images\"] = \"Images\";\n})(MediaTypeOptions || (MediaTypeOptions = {}));\n// @needsAudit\nexport var VideoExportPreset;\n(function (VideoExportPreset) {\n /**\n * Resolution: __Unchanged__ •\n * Video compression: __None__ •\n * Audio compression: __None__\n */\n VideoExportPreset[VideoExportPreset[\"Passthrough\"] = 0] = \"Passthrough\";\n /**\n * Resolution: __Depends on the device__ •\n * Video compression: __H.264__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"LowQuality\"] = 1] = \"LowQuality\";\n /**\n * Resolution: __Depends on the device__ •\n * Video compression: __H.264__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"MediumQuality\"] = 2] = \"MediumQuality\";\n /**\n * Resolution: __Depends on the device__ •\n * Video compression: __H.264__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"HighestQuality\"] = 3] = \"HighestQuality\";\n /**\n * Resolution: __640 × 480__ •\n * Video compression: __H.264__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"H264_640x480\"] = 4] = \"H264_640x480\";\n /**\n * Resolution: __960 × 540__ •\n * Video compression: __H.264__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"H264_960x540\"] = 5] = \"H264_960x540\";\n /**\n * Resolution: __1280 × 720__ •\n * Video compression: __H.264__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"H264_1280x720\"] = 6] = \"H264_1280x720\";\n /**\n * Resolution: __1920 × 1080__ •\n * Video compression: __H.264__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"H264_1920x1080\"] = 7] = \"H264_1920x1080\";\n /**\n * Resolution: __3840 × 2160__ •\n * Video compression: __H.264__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"H264_3840x2160\"] = 8] = \"H264_3840x2160\";\n /**\n * Resolution: __1920 × 1080__ •\n * Video compression: __HEVC__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"HEVC_1920x1080\"] = 9] = \"HEVC_1920x1080\";\n /**\n * Resolution: __3840 × 2160__ •\n * Video compression: __HEVC__ •\n * Audio compression: __AAC__\n */\n VideoExportPreset[VideoExportPreset[\"HEVC_3840x2160\"] = 10] = \"HEVC_3840x2160\";\n})(VideoExportPreset || (VideoExportPreset = {}));\n// @needsAudit\nexport var UIImagePickerControllerQualityType;\n(function (UIImagePickerControllerQualityType) {\n /**\n * Highest available resolution.\n */\n UIImagePickerControllerQualityType[UIImagePickerControllerQualityType[\"High\"] = 0] = \"High\";\n /**\n * Depends on the device.\n */\n UIImagePickerControllerQualityType[UIImagePickerControllerQualityType[\"Medium\"] = 1] = \"Medium\";\n /**\n * Depends on the device.\n */\n UIImagePickerControllerQualityType[UIImagePickerControllerQualityType[\"Low\"] = 2] = \"Low\";\n /**\n * 640 × 480\n */\n UIImagePickerControllerQualityType[UIImagePickerControllerQualityType[\"VGA640x480\"] = 3] = \"VGA640x480\";\n /**\n * 1280 × 720\n */\n UIImagePickerControllerQualityType[UIImagePickerControllerQualityType[\"IFrame1280x720\"] = 4] = \"IFrame1280x720\";\n /**\n * 960 × 540\n */\n UIImagePickerControllerQualityType[UIImagePickerControllerQualityType[\"IFrame960x540\"] = 5] = \"IFrame960x540\";\n})(UIImagePickerControllerQualityType || (UIImagePickerControllerQualityType = {}));\n/**\n * Picker presentation style. Its values are directly mapped to the [`UIModalPresentationStyle`](https://developer.apple.com/documentation/uikit/uiviewcontroller/1621355-modalpresentationstyle).\n *\n * @platform ios\n */\nexport var UIImagePickerPresentationStyle;\n(function (UIImagePickerPresentationStyle) {\n /**\n * A presentation style in which the presented picker covers the screen.\n */\n UIImagePickerPresentationStyle[\"FULL_SCREEN\"] = \"fullScreen\";\n /**\n * A presentation style that partially covers the underlying content.\n */\n UIImagePickerPresentationStyle[\"PAGE_SHEET\"] = \"pageSheet\";\n /**\n * A presentation style that displays the picker centered in the screen.\n */\n UIImagePickerPresentationStyle[\"FORM_SHEET\"] = \"formSheet\";\n /**\n * A presentation style where the picker is displayed over the app's content.\n */\n UIImagePickerPresentationStyle[\"CURRENT_CONTEXT\"] = \"currentContext\";\n /**\n * A presentation style in which the picker view covers the screen.\n */\n UIImagePickerPresentationStyle[\"OVER_FULL_SCREEN\"] = \"overFullScreen\";\n /**\n * A presentation style where the picker is displayed over the app's content.\n */\n UIImagePickerPresentationStyle[\"OVER_CURRENT_CONTEXT\"] = \"overCurrentContext\";\n /**\n * A presentation style where the picker is displayed in a popover view.\n */\n UIImagePickerPresentationStyle[\"POPOVER\"] = \"popover\";\n /**\n * The default presentation style chosen by the system.\n * On older iOS versions, falls back to `WebBrowserPresentationStyle.FullScreen`.\n *\n * @platform ios\n */\n UIImagePickerPresentationStyle[\"AUTOMATIC\"] = \"automatic\";\n})(UIImagePickerPresentationStyle || (UIImagePickerPresentationStyle = {}));\n/**\n * Picker preferred asset representation mode. Its values are directly mapped to the [`PHPickerConfigurationAssetRepresentationMode`](https://developer.apple.com/documentation/photokit/phpickerconfigurationassetrepresentationmode).\n *\n * @platform ios\n */\nexport var UIImagePickerPreferredAssetRepresentationMode;\n(function (UIImagePickerPreferredAssetRepresentationMode) {\n /**\n * A mode that indicates that the system chooses the appropriate asset representation.\n */\n UIImagePickerPreferredAssetRepresentationMode[\"Automatic\"] = \"automatic\";\n /**\n * A mode that uses the most compatible asset representation.\n */\n UIImagePickerPreferredAssetRepresentationMode[\"Compatible\"] = \"compatible\";\n /**\n * A mode that uses the current representation to avoid transcoding, if possible.\n */\n UIImagePickerPreferredAssetRepresentationMode[\"Current\"] = \"current\";\n})(UIImagePickerPreferredAssetRepresentationMode || (UIImagePickerPreferredAssetRepresentationMode = {}));\nexport var CameraType;\n(function (CameraType) {\n /**\n * Back/rear camera.\n */\n CameraType[\"back\"] = \"back\";\n /**\n * Front camera\n */\n CameraType[\"front\"] = \"front\";\n})(CameraType || (CameraType = {}));\n//# sourceMappingURL=ImagePicker.types.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nvar vibrate = pattern => {\n if ('vibrate' in window.navigator) {\n window.navigator.vibrate(pattern);\n }\n};\nvar Vibration = {\n cancel() {\n vibrate(0);\n },\n vibrate(pattern) {\n if (pattern === void 0) {\n pattern = 400;\n }\n vibrate(pattern);\n }\n};\nexport default Vibration;","import {theme} from \"../theme/theme\";\nimport {Image, Pressable, View} from \"react-native\";\nimport React from \"react\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport IconButtonM from \"@common/components/button/IconButtonM\";\n\nconst PhotoElement = (props) => {\n\n // ** Component props\n const {\n uri,\n height,\n width,\n isSelecting,\n selected,\n parentHeight,\n onLongPress,\n onPress,\n longPressDisabled = true,\n resendComponent,\n showResend = false\n } = props\n\n return \n \n \n \n {resendComponent && showResend && resendComponent()}\n\n {!longPressDisabled && }\n\n {isSelecting && }\n \n}\n\nexport default PhotoElement","import React from \"react\";\nimport withPreventDoubleClick from \"../../utils/withPreventDoubleClick\";\nimport {IconButton} from \"react-native-paper\";\nimport {theme} from \"@common/theme/theme\";\n\n\nconst IconButtonM = ({...props}) => {\n return (\n \n )\n}\nexport default withPreventDoubleClick(IconButtonM)","function _objectDestructuringEmpty(obj) {\n if (obj == null) throw new TypeError(\"Cannot destructure \" + obj);\n}\nmodule.exports = _objectDestructuringEmpty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","import { NavigationRefContext } from \"@common/utils/mobileUtils\";\nimport { setCameraStatus } from \"@data/redux/actions/activity\";\nimport { useContext } from \"react\";\nimport { useDispatch } from \"react-redux\";\nexport function useCamera(formId = \"default\") {\n const navigationRefContext = useContext(NavigationRefContext)\n\n const dispatch = useDispatch()\n\n const launchCamera = () => {\n dispatch(setCameraStatus(true))\n\n setTimeout(() => {\n navigationRefContext?.navigationRef?.current?.navigate(\"camera\", {\n formId,\n })\n }, 1000)\n }\n\n return [launchCamera]\n}","import {activitiesConstants} from \"@data/constants/activitiesConstants\";\n\nexport function pauseActivity(paused) {\n return {type: activitiesConstants.PAUSE_ACTIVITY, data: paused}\n}\n\nexport function setOngoingActivity(data) {\n return {type: activitiesConstants.ONGOING_ACTIVITY, data}\n}\n\nexport function setCameraStatus(cameraOn) {\n return {type: activitiesConstants.SET_CAMERA_STATUS, cameraOn}\n}\n\nexport function audioRecordingStatus(data) {\n return {type: activitiesConstants.AUDIO_STATUS, data}\n}\n\nexport function updateActivityEvent(data) {\n return {type: activitiesConstants.UPDATE_ACTIVITY_CHRONO, data}\n}","import {cameraConstants} from \"@data/constants/cameraConstants\";\n\nexport function setLastPhoto(formId, newPhoto) {\n return {type: cameraConstants.NEW_PHOTO, formId, newPhoto}\n}\n\nexport function setPhotos(formId, newPhotos) {\n return {type: cameraConstants.NEW_PHOTOS, formId, newPhotos}\n}\n\nexport function clearLastPhoto() {\n return {type: cameraConstants.PHOTO_CLEAR}\n}\n\nexport function clearPhotos() {\n return {type: cameraConstants.PHOTOS_CLEAR}\n}\n\nexport function recordCameraSettings(imagePadding, ratio) {\n // console.log(\"saved new settings : ratio \", ratio, \", imagePadding \", imagePadding)\n return {type: cameraConstants.RECORD_CAMERA_SETTINGS, ratio, imagePadding}\n}\n\nexport function resetCameraSettings() {\n return {type: cameraConstants.RESET_CAMERA_SETTINGS}\n}\n\nexport function setVideoRecord(video) {\n return {type: cameraConstants.SET_VIDEO_RECORD, video}\n}","import React, {useContext, useEffect, useRef, useState} from \"react\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {clearLastPhoto} from \"@data/redux/actions/camera\";\nimport {connect} from \"react-redux\";\nimport {Dimensions, FlatList, View} from \"react-native\";\nimport {DimensionsContext, IS_WEB} from \"../../utils/mobileUtils\";\nimport {theme} from \"../../theme/theme\";\nimport {PinchableBox} from \"./PinchableBox\";\nimport {IconButton} from \"react-native-paper\";\nimport TextM from \"@common/components/text/TextM\";\nimport {displayTimeSeconds} from \"@data/utility/Utils\";\nimport {TapGestureHandler} from \"react-native-gesture-handler\";\nimport {useSafeAreaInsets} from \"react-native-safe-area-context\";\nimport IconButtonM from \"@common/components/button/IconButtonM\";\n\nfunction ImageViewer(props) {\n\n const {images, imageIndex = 0, close, withChrono, time, useFullWidthToScroll = false} = props\n const flatListRef = useRef()\n const [currentIndex, setCurrentIndex] = useState(imageIndex)\n\n // const zoomRef = useRef()\n\n const zoomRefs = images?.map((i, index) => useRef())\n\n\n const dimensions = useContext(DimensionsContext)\n const insets = useSafeAreaInsets()\n\n useEffect(() => {\n\n // console.log(\"imageIndex\", imageIndex)\n\n if (imageIndex !== undefined) {\n flatListRef?.current?.scrollToIndex({index: imageIndex})\n setCurrentIndex(imageIndex)\n }\n }, [imageIndex]);\n\n let mWidth = (dimensions?.width / 2 - 60)\n\n let adaptedWidth = mWidth < 140 ? mWidth : 140\n\n return \n \n {withChrono && \n \n {displayTimeSeconds(time)}\n \n }\n \n \n\n ({\n length: useFullWidthToScroll ? Dimensions.get(\"window\").width : dimensions?.height,\n offset: useFullWidthToScroll ? Dimensions.get(\"window\").width * index : dimensions?.height * index,\n index,\n })}\n renderItem={(item, index) => {\n return \n\n }}\n />\n \n {\n if (currentIndex > 0) {\n flatListRef?.current?.scrollToIndex({index: currentIndex - 1})\n setCurrentIndex(currentIndex - 1)\n }\n }}\n />\n { {\n zoomRefs[currentIndex].current?.zoomOut()\n }}\n />}\n {\n zoomRefs[currentIndex].current?.rotate()\n }}\n />\n { {\n zoomRefs[currentIndex].current?.zoomIn()\n }}\n />}\n {\n if (currentIndex < images?.length - 1) {\n flatListRef?.current?.scrollToIndex({index: currentIndex + 1})\n setCurrentIndex(currentIndex + 1)\n }\n }}\n />\n\n \n ;\n}\n\nconst mapStateToProps = state => {\n return {\n user: state.data.currentUser?.object,\n lastPhoto: state.camera?.lastPhoto,\n lastPhotoFormId: state.camera?.formId\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle,\n clearLastPhoto\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ImageViewer)","import * as React from 'react'\n// import ImageZoom from \"./ImageZoom\";\nimport {Image} from \"react-native\";\nimport {Zoom} from \"@common/components/zoom\";\n\nexport const PinchableBox = React.forwardRef(({imageStyle, imageUri, onLayout}, ref) => {\n\n return \n \n \n\n // return \n});\n","export {Zoom} from './zoom';\nexport {\n createZoomListComponent,\n createZoomListWithReanimatedComponent,\n} from './createZoomListComponent';\n","import React, {useCallback, useContext, useImperativeHandle, useMemo} from 'react';\nimport type {ViewProps} from 'react-native';\nimport Animated, {\n cancelAnimation,\n runOnJS,\n useAnimatedStyle,\n useDerivedValue,\n useSharedValue,\n withTiming,\n} from 'react-native-reanimated';\nimport {Gesture, GestureDetector, GestureType,} from 'react-native-gesture-handler';\nimport {ZoomListContext} from './zoom-list-context';\n\ntype Props = {\n children: React.ReactNode;\n minimumZoomScale?: number;\n maximumZoomScale?: number;\n simultaneousGesture?: GestureType;\n onZoomBegin?: () => void;\n onZoomEnd?: () => void;\n} & ViewProps;\n\nexport const Zoom = React.forwardRef((props: Props, ref) => {\n const {\n minimumZoomScale = 1,\n maximumZoomScale = 4,\n style: propStyle,\n onLayout,\n onZoomBegin,\n onZoomEnd,\n simultaneousGesture,\n } = props;\n\n const rotate = useSharedValue(0);\n\n useImperativeHandle(\n ref,\n useCallback(\n () => ({\n zoomIn: () => {\n // translate the image to the focal point and zoom\n if (scale.value < 5)\n scale.value = withTiming(scale.value + 0.5);\n },\n zoomOut: () => {\n resetZoom()\n },\n rotate: () => {\n // console.log((rotate.value % 180))\n\n rotate.value = withTiming((rotate.value % 90) === 0 ? rotate.value + 90 : 90 * Math.ceil(rotate.value / 90));\n scaleAdjustment.value = (rotate.value % 360) === 0\n ? 0.7\n : (rotate.value % 360) === 180\n ? 0.7\n : 1\n // scale.value = withTiming((1 + height / width));\n // console.log('viewHeight', viewHeight.value, 'viewWidth', viewWidth.value)\n let height = viewHeight.value ?? 1;\n let width = viewWidth.value ?? 1;\n viewHeight.value = (rotate.value % 180) === 0 ? width : height;\n viewWidth.value = (rotate.value % 180) === 0 ? height : width;\n // console.log('viewHeight', viewHeight.value, 'viewWidth', viewWidth.value)\n }\n }),\n []\n )\n );\n\n const zoomListContext = useContext(ZoomListContext);\n\n const translationX = useSharedValue(0);\n const translationY = useSharedValue(0);\n const originX = useSharedValue(0);\n const originY = useSharedValue(0);\n const scale = useSharedValue(1);\n const isPinching = useSharedValue(false);\n const isZoomed = useSharedValue(false);\n const viewHeight = useSharedValue(0);\n const viewWidth = useSharedValue(0);\n\n const prevScale = useSharedValue(0);\n const offsetScale = useSharedValue(0);\n const prevTranslationX = useSharedValue(0);\n const prevTranslationY = useSharedValue(0);\n\n const panTranslateX = useSharedValue(0);\n const panTranslateY = useSharedValue(0);\n\n const scaleAdjustment = useSharedValue(1);\n // console.log(scaleAdjustment)\n\n const resetZoom = () => {\n // reset all state\n translationX.value = withTiming(0);\n translationY.value = withTiming(0);\n scale.value = withTiming(1);\n originX.value = 0;\n originY.value = 0;\n isPinching.value = false;\n prevScale.value = 0;\n prevTranslationX.value = 0;\n prevTranslationY.value = 0;\n panTranslateX.value = 0;\n panTranslateY.value = 0;\n }\n\n const gesture = useMemo(() => {\n const resetZoomState = () => {\n 'worklet';\n\n // reset all state\n translationX.value = withTiming(0);\n translationY.value = withTiming(0);\n scale.value = withTiming(1);\n originX.value = 0;\n originY.value = 0;\n isPinching.value = false;\n prevScale.value = 0;\n prevTranslationX.value = 0;\n prevTranslationY.value = 0;\n panTranslateX.value = 0;\n panTranslateY.value = 0;\n };\n\n // we only activate pan handler when the image is zoomed or user is not pinching\n const pan = Gesture.Pan()\n .onStart(() => {\n if (isPinching.value || !isZoomed.value) return;\n\n cancelAnimation(translationX);\n cancelAnimation(translationY);\n cancelAnimation(scale);\n\n prevTranslationX.value = translationX.value;\n prevTranslationY.value = translationY.value;\n })\n .onUpdate((e) => {\n if (isPinching.value || !isZoomed.value) {\n panTranslateX.value = e.translationX;\n panTranslateY.value = e.translationY;\n } else {\n // imagine what happens to pixels when we zoom in. (they get multiplied by x times scale)\n const maxTranslateX =\n (viewWidth.value / 2) * scale.value - viewWidth.value / 2;\n const minTranslateX = -maxTranslateX;\n\n const maxTranslateY =\n (viewHeight.value / 2) * scale.value - viewHeight.value / 2;\n const minTranslateY = -maxTranslateY;\n\n const nextTranslateX =\n prevTranslationX.value + e.translationX - panTranslateX.value;\n const nextTranslateY =\n prevTranslationY.value + e.translationY - panTranslateY.value;\n\n if (nextTranslateX > maxTranslateX) {\n translationX.value = maxTranslateX;\n } else if (nextTranslateX < minTranslateX) {\n translationX.value = minTranslateX;\n } else {\n translationX.value = nextTranslateX;\n }\n\n if (nextTranslateY > maxTranslateY) {\n translationY.value = maxTranslateY;\n } else if (nextTranslateY < minTranslateY) {\n translationY.value = minTranslateY;\n } else {\n translationY.value = nextTranslateY;\n }\n }\n })\n .onEnd(() => {\n if (isPinching.value || !isZoomed.value) return;\n\n panTranslateX.value = 0;\n panTranslateY.value = 0;\n\n prevTranslationX.value = translationX.value;\n prevTranslationY.value = translationY.value;\n });\n\n const pinch = Gesture.Pinch()\n .onStart(() => {\n cancelAnimation(translationX);\n cancelAnimation(translationY);\n cancelAnimation(scale);\n prevScale.value = scale.value;\n offsetScale.value = scale.value;\n })\n .onUpdate((e) => {\n // when pointer is 1 we don't want to translate origin\n if (e.numberOfPointers === 1 && isPinching.value) {\n prevTranslationX.value = translationX.value;\n prevTranslationY.value = translationY.value;\n isPinching.value = false;\n } else if (e.numberOfPointers === 2) {\n const newScale = prevScale.value * e.scale;\n\n if (newScale < minimumZoomScale || newScale > maximumZoomScale)\n return;\n\n scale.value = prevScale.value * e.scale;\n\n // reset the origin\n if (!isPinching.value) {\n isPinching.value = true;\n originX.value = e.focalX;\n originY.value = e.focalY;\n prevTranslationX.value = translationX.value;\n prevTranslationY.value = translationY.value;\n offsetScale.value = scale.value;\n }\n\n if (isPinching.value) {\n // translate the image to the focal point as we're zooming\n translationX.value =\n prevTranslationX.value +\n -1 *\n ((scale.value - offsetScale.value) *\n (originX.value - viewWidth.value / 2));\n translationY.value =\n prevTranslationY.value +\n -1 *\n ((scale.value - offsetScale.value) *\n (originY.value - viewHeight.value / 2));\n }\n }\n })\n .onEnd(() => {\n isPinching.value = false;\n prevTranslationX.value = translationX.value;\n prevTranslationY.value = translationY.value;\n\n if (scale.value < 1.1) {\n resetZoomState();\n }\n });\n\n const doubleTap = Gesture.Tap()\n .onStart((e) => {\n // if zoomed in or zoomed out, we want to reset\n if (scale.value !== 1) {\n resetZoomState();\n } else {\n // translate the image to the focal point and zoom\n scale.value = withTiming(maximumZoomScale);\n translationX.value = withTiming(\n -1 * (maximumZoomScale * (e.x - viewWidth.value / 2))\n );\n translationY.value = withTiming(\n -1 * (maximumZoomScale * (e.y - viewHeight.value / 2))\n );\n }\n })\n .numberOfTaps(2);\n\n if (zoomListContext?.simultaneousPanGestureRef) {\n pan.simultaneousWithExternalGesture(\n zoomListContext?.simultaneousPanGestureRef\n );\n }\n\n return Gesture.Race(\n doubleTap,\n simultaneousGesture\n ? Gesture.Simultaneous(pan, pinch, simultaneousGesture)\n : Gesture.Simultaneous(pan, pinch)\n );\n\n // only add prop dependencies\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n maximumZoomScale,\n minimumZoomScale,\n zoomListContext,\n simultaneousGesture,\n ]);\n\n useDerivedValue(() => {\n if (scale.value > 1 && !isZoomed.value) {\n isZoomed.value = true;\n if (zoomListContext) runOnJS(zoomListContext.onZoomBegin)();\n if (onZoomBegin) runOnJS(onZoomBegin)();\n } else if (scale.value === 1 && isZoomed.value) {\n isZoomed.value = false;\n if (zoomListContext) runOnJS(zoomListContext.onZoomEnd)();\n if (onZoomEnd) runOnJS(onZoomEnd)();\n }\n }, [zoomListContext, onZoomBegin, onZoomEnd]);\n\n const style = useAnimatedStyle(() => {\n return {\n transform: [\n {translateX: translationX.value},\n {translateY: translationY.value},\n // { scale: scale.value },\n {scale: scale.value * scaleAdjustment.value},\n {rotate: `${rotate.value}deg`},\n ],\n };\n }, []);\n\n const memoizedOnLayout = useCallback(\n (e) => {\n viewHeight.value = e.nativeEvent.layout.width;\n viewWidth.value = e.nativeEvent.layout.height;\n onLayout?.(e);\n },\n [viewHeight, viewWidth, onLayout]\n );\n\n const memoizedStyle = useMemo(() => [style, propStyle], [style, propStyle]);\n\n return (\n \n \n \n );\n});","import {createContext} from 'react';\nimport type {NativeGesture} from 'react-native-gesture-handler';\n\nexport const ZoomListContext = createContext(\n null as {\n onZoomBegin: () => void;\n onZoomEnd: () => void;\n simultaneousPanGestureRef: NativeGesture;\n } | null\n);\n","import React, {forwardRef, useMemo, useRef, useState} from 'react';\nimport {Gesture, GestureDetector} from 'react-native-gesture-handler';\nimport {useAnimatedProps, useSharedValue} from 'react-native-reanimated';\nimport {ZoomListContext} from './zoom-list-context';\n\nexport function createZoomListComponent(ScrollComponent: T): T {\n const ListComponent = forwardRef((props, ref) => {\n const [scrollEnabled, setScrollEnabled] = useState(true);\n const listRef = useRef(Gesture.Native());\n\n const contextValues = useMemo(\n () => ({\n onZoomBegin: () => setScrollEnabled(false),\n onZoomEnd: () => setScrollEnabled(true),\n simultaneousPanGestureRef: listRef.current,\n }),\n []\n );\n\n return (\n \n \n {/* @ts-ignore */}\n \n \n \n );\n });\n\n return ListComponent as unknown as T;\n}\n\nexport function createZoomListWithReanimatedComponent(\n ScrollComponent: T\n): T {\n const ListComponent = forwardRef((props, ref) => {\n const scrollEnabled = useSharedValue(true);\n const listRef = useRef(Gesture.Native());\n\n const contextValues = useMemo(\n () => ({\n onZoomBegin: () => {\n scrollEnabled.value = false;\n },\n onZoomEnd: () => {\n scrollEnabled.value = true;\n },\n simultaneousPanGestureRef: listRef.current,\n }),\n [scrollEnabled]\n );\n\n const animatedProps = useAnimatedProps(() => {\n return {\n scrollEnabled: scrollEnabled.value,\n };\n });\n\n return (\n \n \n {/* @ts-ignore */}\n \n \n \n );\n });\n\n return ListComponent as unknown as T;\n}\n","import {View} from \"react-native\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport {theme} from \"../../theme/theme\";\nimport TextM from \"../text/TextM\";\nimport React, {useContext} from \"react\";\nimport {DimensionsContext} from \"../../utils/mobileUtils\";\n\nexport const IconTextM = ({icon, color = theme.colors.grey, text, style, textStyle, fontSize, iconSize, iconStyle, right=false}) => {\n\n\n const dimensions = useContext(DimensionsContext)\n\n const renderIcon = () => \n\n return \n {!right && renderIcon()}\n \n {text}\n \n {right && renderIcon()}\n \n}","import React, {useEffect, useState} from \"react\";\nimport {Searchbar} from \"react-native-paper\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\n\nconst ServerSearch = (props) => {\n\n const {style, urlParams, setUrlParams, request, value = null} = props;\n // const [isSearching, setIsSearching] = useState(false)\n const [previousSearchQuery, setPreviousSearchQuery] = useState(\"\");\n const [searchQuery, setSearchQuery] = useState(urlParams?.search ?? \"\");\n const [nextQuery, setNextQuery] = useState(null);\n\n useEffect(() => {\n //console.log('textChanged')\n\n\n const delayDebounceFn = setTimeout(() => {\n if (searchQuery === previousSearchQuery) return;\n\n const updatedParams = { ...urlParams, search: nextQuery ?? searchQuery };\n\n if (request) {\n setNextQuery(updatedParams);\n } else if (JSON.stringify(urlParams) !== JSON.stringify(updatedParams)) {\n setUrlParams(updatedParams);\n setNextQuery(null);\n }\n\n setPreviousSearchQuery(searchQuery);\n }, 500);\n return () => clearTimeout(delayDebounceFn)\n }, [searchQuery, request])\n\n const onChangeSearch = query => setSearchQuery(query);\n\n return (\n {\n onChangeSearch(value)\n }}\n value={value ?? searchQuery}\n // loading={props.searchingRequest && isSearching}\n style={{\n ...style\n }}\n inputStyle={{\n fontSize: 14\n }}\n />\n );\n}\n\nconst mapStateToProps = state => {\n return {\n //liveSession: state.data.backOffice?.liveSession,\n users: state.data.users?.usersList\n //getUsersRequest: state.api.getAllUsers?.request,\n // searchingRequest: state.api.searchUser?.request\n //addUsersRequest: state.api.addUsersLive?.request,\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ServerSearch)","import { DialogM } from \"@common/components/alert/dialog/Dialog\";\nimport { apiIdle } from \"@data/redux/actions/api\";\nimport { useEffect } from 'react';\nimport { useDispatch, useSelector } from \"react-redux\";\n\nexport function useApiStatus(\n serviceName,\n successMessage = \"\",\n errorMessage = true,\n successCallback = (() => {\n }),\n errorCallback = (() => {\n }),\n noIdle = false\n) {\n\n const serviceApiSelector = useSelector(state => state.api?.[serviceName?.name])\n const dispatch = useDispatch()\n\n useEffect(() => {\n if (serviceApiSelector?.success) {\n // console.log(noIdle, noIdle)\n if (!noIdle) {\n // console.log(\"IDLE\")\n dispatch(apiIdle(serviceName))\n }\n if (successMessage)\n DialogM.show({\n text1: 'Succès', text2: successMessage\n })\n //alertPolyfill('Succès', successMessage)\n successCallback(serviceApiSelector?.data, serviceApiSelector?.all_data, serviceApiSelector?.urlParams, serviceApiSelector?.routeParams)\n }\n\n if (serviceApiSelector?.error) {\n console.log(serviceApiSelector?.error)\n if (errorMessage) {\n let errorMessages = []\n if (serviceApiSelector?.error?.errors) {\n errorMessages = Object.keys(serviceApiSelector?.error?.errors)?.map(key => serviceApiSelector?.error?.errors[key][0])\n }\n DialogM.show({\n text1: 'Erreur', text2: serviceApiSelector?.error?.message + (errorMessages ? \"\\n\" + errorMessages.join(\"\\n\") : \"\")\n })\n //alertPolyfill('Erreur', serviceApiSelector?.error?.message)\n dispatch(apiIdle(serviceName))\n }\n errorCallback(serviceApiSelector?.error, serviceApiSelector?.urlParams)\n }\n\n }, [serviceApiSelector?.success, serviceApiSelector?.error])\n}\n","import {formDataConstants} from \"@data/constants/formDataConstants\";\n\nexport function saveActivityData(data) {\n return {type: formDataConstants.SAVE_ACTIVITY, data}\n}\n\nexport function clearActivityData() {\n return {type: formDataConstants.CLEAR_ACTIVITY}\n}\n\nexport function setAnswerInput(data) {\n return {type: formDataConstants.SET_ANSWER_INPUT, data}\n}\n\nexport function saveFormData(formId, entryId, data) {\n return {type: formDataConstants.SAVE_FORM_DATA, formId, entryId, data}\n}\nexport const saveReportFile = (data) => (dispatch) => {\n dispatch({\n type: formDataConstants.SAVE_REPORT_FILE,\n data\n });\n \n return Promise.resolve();\n }\nexport function clearReportFile() {\n return {type: formDataConstants.CLEAR_REPORT_FILE}\n}\n\nexport function resetFormData(formId, entryId) {\n return {type: formDataConstants.RESET_FORM_DATA, formId, entryId}\n}","import {Portal, Snackbar} from \"react-native-paper\";\nimport {theme} from \"@common/theme/theme\";\nimport React, {forwardRef, useCallback, useContext, useImperativeHandle, useRef} from \"react\";\nimport {useSnackBar} from \"@common/components/alert/snackbar/useSnackBar\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\n\n\nlet currentRef = null\nexport const SnackBar = forwardRef((props, ref) => {\n const {config, ...defaultOptions} = props;\n const {show, hide, isVisible, options, data} = useSnackBar({\n defaultOptions\n })\n const dimensions = useContext(DimensionsContext)\n\n useImperativeHandle(\n ref,\n useCallback(\n () => ({\n show,\n hide\n }),\n [hide, show]\n )\n );\n\n return (\n \n {\n // Do something\n }\n }}>\n {data.text1}\n \n \n );\n\n})\n\nexport function SnackBarM(props) {\n const snackRef = useRef(null);\n\n const setRef = useCallback((ref) => {\n if (ref) {\n snackRef.current = ref;\n currentRef = ref;\n }\n }, []);\n\n return (\n \n );\n}\n\nSnackBarM.show = (params) => {\n currentRef?.show(params);\n};\n\nSnackBarM.hide = (params) => {\n currentRef?.hide(params);\n};","import * as yup from 'yup'\n\nyup.setLocale({\n mixed: {\n required: 'Champ obligatoire'\n },\n string: {\n email: 'Email invalide'\n }\n})\n\nexport default yup\n\nconst required = () => {\n return {required: \"Champ obligatoire\"}\n}\n\nconst maxLength = (value) => {\n return {\n maxLength: {\n value: value,\n message: `${value} caractères maximum`\n }\n }\n}\n\nconst number = () => pattern(numberRegExp, \"Nombre invalide\")\n\nconst min = (value) => {\n return {\n min: {\n value: value,\n message: `La valeur minimum est de ${value}`\n }\n }\n}\nconst max = (value) => {\n return {\n max: {\n value: value,\n message: `La valeur maximum est de ${value}`\n }\n }\n}\n\nconst differentFrom = (value) => {\n return {\n validate: val => {\n\n return val?.toLowerCase() !== value?.toLowerCase() ? true : `Doit être différent de ${value}`\n }\n }\n}\n\nconst minArrayLength = (value) => {\n return {\n validate: {\n value: val => val?.length >= value,\n message: `${value} choix minimum`\n }\n }\n}\n\nconst minLength = (value) => {\n return {\n minLength: {\n value: value,\n message: `${value} caractères minimum`\n }\n }\n}\nconst pattern = (value, message = `Champ invalide`) => {\n return {\n pattern: {\n value: value,\n message: message\n }\n }\n}\n\nconst iban = () => pattern(ibanRegExp, \"IBAN invalide\")\n\nexport function validateIbanChecksum(iban) {\n if (!iban) return false\n\n const ibanStripped = iban.replace(/[^A-Z0-9]+/gi,'') //keep numbers and letters only\n .toUpperCase(); //calculation expects upper-case\n const m = ibanStripped.match(/^([A-Z]{2})([0-9]{2})([A-Z0-9]{9,30})$/);\n if(!m) return false;\n\n const numbericed = (m[3] + m[1] + m[2]).replace(/[A-Z]/g,function(ch){\n //replace upper-case characters by numbers 10 to 35\n return (ch.charCodeAt(0)-55);\n });\n //The resulting number would be to long for javascript to handle without loosing precision.\n //So the trick is to chop the string up in smaller parts.\n const mod97 = numbericed.match(/\\d{1,7}/g)\n .reduce(function(total, curr){ return Number(total + curr)%97},'');\n\n return (mod97 === 1);\n}\nconst customCondition = (value, message = `Champ invalide`) => {\n return {\n customCondition: {\n value: value,\n message: message\n }\n }\n}\n\nexport const ibanRegExp = /^([A-Z]{2}[ \\-]?[0-9]{2})(?=(?:[ \\-]?[A-Z0-9]){9,30}$)((?:[ \\-]?[A-Z0-9]{3,5}){2,7})([ \\-]?[A-Z0-9]{1,3})?$/\nexport const emailRegExp = /^[\\w-.+]+@([\\w-]+\\.)+[\\w-]{2,4}$/\nexport const numberRegExp = /^[1-9][.\\d]*(,\\d+)?$/\n\nexport const phoneRegExp = /^((\\\\+[1-9]{1,4}[ \\\\-]*)|(\\\\([0-9]{2,3}\\\\)[ \\\\-]*)|([0-9]{2,4})[ \\\\-]*)*?[0-9]{3,4}?[ \\\\-]*[0-9]{3,4}?$/\nexport const urlRegExp = new RegExp(\n \"^\" +\n // protocol identifier\n \"(?:(?:https?|ftp)://)\" +\n // user:pass authentication\n \"(?:\\\\S+(?::\\\\S*)?@)?\" +\n \"(?:\" +\n // IP address exclusion\n // private & local networks\n \"(?!(?:10|127)(?:\\\\.\\\\d{1,3}){3})\" +\n \"(?!(?:169\\\\.254|192\\\\.168)(?:\\\\.\\\\d{1,3}){2})\" +\n \"(?!172\\\\.(?:1[6-9]|2\\\\d|3[0-1])(?:\\\\.\\\\d{1,3}){2})\" +\n // IP address dotted notation octets\n // excludes loopback network 0.0.0.0\n // excludes reserved space >= 224.0.0.0\n // excludes network & broacast addresses\n // (first & last IP address of each class)\n \"(?:[1-9]\\\\d?|1\\\\d\\\\d|2[01]\\\\d|22[0-3])\" +\n \"(?:\\\\.(?:1?\\\\d{1,2}|2[0-4]\\\\d|25[0-5])){2}\" +\n \"(?:\\\\.(?:[1-9]\\\\d?|1\\\\d\\\\d|2[0-4]\\\\d|25[0-4]))\" +\n \"|\" +\n // host name\n \"(?:(?:[a-z\\\\u00a1-\\\\uffff0-9]-*)*[a-z\\\\u00a1-\\\\uffff0-9]+)\" +\n // domain name\n \"(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff0-9]-*)*[a-z\\\\u00a1-\\\\uffff0-9]+)*\" +\n // TLD identifier\n \"(?:\\\\.(?:[a-z\\\\u00a1-\\\\uffff]{2,}))\" +\n // TLD may end with dot\n \"\\\\.?\" +\n \")\" +\n // port number\n \"(?::\\\\d{2,5})?\" +\n // resource path\n \"(?:[/?#]\\\\S*)?\" +\n \"$\",\n \"i\"\n)\n\nconst email = () => pattern(emailRegExp, \"Email invalide\")\n\nconst phone = () => pattern(phoneRegExp, \"Le numéro de téléphone est invalide\")\n\nconst url = (value) => {\n return {\n validate: {\n checkUrl: async () => await fetch(value) || 'URL invalide' // JS only:

error message

TS only support string\n }\n }\n}\nconst checkUrl = () => pattern(urlRegExp, \"URL invalide\")\n\nexport const validation = {\n required,\n differentFrom,\n minLength,\n minArrayLength,\n maxLength,\n pattern,\n email,\n phone,\n url,\n customCondition,\n checkUrl,\n min,\n max,\n number,\n iban\n}","import MixedSchema, { create as mixedCreate } from './mixed';\nimport BooleanSchema, { create as boolCreate } from './boolean';\nimport StringSchema, { create as stringCreate } from './string';\nimport NumberSchema, { create as numberCreate } from './number';\nimport DateSchema, { create as dateCreate } from './date';\nimport ObjectSchema, { create as objectCreate } from './object';\nimport ArraySchema, { create as arrayCreate } from './array';\nimport { create as refCreate } from './Reference';\nimport { create as lazyCreate } from './Lazy';\nimport ValidationError from './ValidationError';\nimport reach from './util/reach';\nimport isSchema from './util/isSchema';\nimport setLocale from './setLocale';\nimport BaseSchema from './schema';\n\nfunction addMethod(schemaType, name, fn) {\n if (!schemaType || !isSchema(schemaType.prototype)) throw new TypeError('You must provide a yup schema constructor function');\n if (typeof name !== 'string') throw new TypeError('A Method name must be provided');\n if (typeof fn !== 'function') throw new TypeError('Method function must be provided');\n schemaType.prototype[name] = fn;\n}\n\nexport { mixedCreate as mixed, boolCreate as bool, boolCreate as boolean, stringCreate as string, numberCreate as number, dateCreate as date, objectCreate as object, arrayCreate as array, refCreate as ref, lazyCreate as lazy, reach, isSchema, addMethod, setLocale, ValidationError };\nexport { BaseSchema, MixedSchema, BooleanSchema, StringSchema, NumberSchema, DateSchema, ObjectSchema, ArraySchema };","import BaseSchema from './schema';\nconst Mixed = BaseSchema;\nexport default Mixed;\nexport function create() {\n return new Mixed();\n} // XXX: this is using the Base schema so that `addMethod(mixed)` works as a base class\n\ncreate.prototype = Mixed.prototype;","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n// @ts-ignore\nimport cloneDeep from 'nanoclone';\nimport { mixed as locale } from './locale';\nimport Condition from './Condition';\nimport runTests from './util/runTests';\nimport createValidation from './util/createValidation';\nimport printValue from './util/printValue';\nimport Ref from './Reference';\nimport { getIn } from './util/reach';\nimport ValidationError from './ValidationError';\nimport ReferenceSet from './util/ReferenceSet';\nimport toArray from './util/toArray'; // const UNSET = 'unset' as const;\n\nexport default class BaseSchema {\n constructor(options) {\n this.deps = [];\n this.tests = void 0;\n this.transforms = void 0;\n this.conditions = [];\n this._mutate = void 0;\n this._typeError = void 0;\n this._whitelist = new ReferenceSet();\n this._blacklist = new ReferenceSet();\n this.exclusiveTests = Object.create(null);\n this.spec = void 0;\n this.tests = [];\n this.transforms = [];\n this.withMutation(() => {\n this.typeError(locale.notType);\n });\n this.type = (options == null ? void 0 : options.type) || 'mixed';\n this.spec = _extends({\n strip: false,\n strict: false,\n abortEarly: true,\n recursive: true,\n nullable: false,\n presence: 'optional'\n }, options == null ? void 0 : options.spec);\n } // TODO: remove\n\n\n get _type() {\n return this.type;\n }\n\n _typeCheck(_value) {\n return true;\n }\n\n clone(spec) {\n if (this._mutate) {\n if (spec) Object.assign(this.spec, spec);\n return this;\n } // if the nested value is a schema we can skip cloning, since\n // they are already immutable\n\n\n const next = Object.create(Object.getPrototypeOf(this)); // @ts-expect-error this is readonly\n\n next.type = this.type;\n next._typeError = this._typeError;\n next._whitelistError = this._whitelistError;\n next._blacklistError = this._blacklistError;\n next._whitelist = this._whitelist.clone();\n next._blacklist = this._blacklist.clone();\n next.exclusiveTests = _extends({}, this.exclusiveTests); // @ts-expect-error this is readonly\n\n next.deps = [...this.deps];\n next.conditions = [...this.conditions];\n next.tests = [...this.tests];\n next.transforms = [...this.transforms];\n next.spec = cloneDeep(_extends({}, this.spec, spec));\n return next;\n }\n\n label(label) {\n let next = this.clone();\n next.spec.label = label;\n return next;\n }\n\n meta(...args) {\n if (args.length === 0) return this.spec.meta;\n let next = this.clone();\n next.spec.meta = Object.assign(next.spec.meta || {}, args[0]);\n return next;\n } // withContext(): BaseSchema<\n // TCast,\n // TContext,\n // TOutput\n // > {\n // return this as any;\n // }\n\n\n withMutation(fn) {\n let before = this._mutate;\n this._mutate = true;\n let result = fn(this);\n this._mutate = before;\n return result;\n }\n\n concat(schema) {\n if (!schema || schema === this) return this;\n if (schema.type !== this.type && this.type !== 'mixed') throw new TypeError(`You cannot \\`concat()\\` schema's of different types: ${this.type} and ${schema.type}`);\n let base = this;\n let combined = schema.clone();\n\n const mergedSpec = _extends({}, base.spec, combined.spec); // if (combined.spec.nullable === UNSET)\n // mergedSpec.nullable = base.spec.nullable;\n // if (combined.spec.presence === UNSET)\n // mergedSpec.presence = base.spec.presence;\n\n\n combined.spec = mergedSpec;\n combined._typeError || (combined._typeError = base._typeError);\n combined._whitelistError || (combined._whitelistError = base._whitelistError);\n combined._blacklistError || (combined._blacklistError = base._blacklistError); // manually merge the blacklist/whitelist (the other `schema` takes\n // precedence in case of conflicts)\n\n combined._whitelist = base._whitelist.merge(schema._whitelist, schema._blacklist);\n combined._blacklist = base._blacklist.merge(schema._blacklist, schema._whitelist); // start with the current tests\n\n combined.tests = base.tests;\n combined.exclusiveTests = base.exclusiveTests; // manually add the new tests to ensure\n // the deduping logic is consistent\n\n combined.withMutation(next => {\n schema.tests.forEach(fn => {\n next.test(fn.OPTIONS);\n });\n });\n combined.transforms = [...base.transforms, ...combined.transforms];\n return combined;\n }\n\n isType(v) {\n if (this.spec.nullable && v === null) return true;\n return this._typeCheck(v);\n }\n\n resolve(options) {\n let schema = this;\n\n if (schema.conditions.length) {\n let conditions = schema.conditions;\n schema = schema.clone();\n schema.conditions = [];\n schema = conditions.reduce((schema, condition) => condition.resolve(schema, options), schema);\n schema = schema.resolve(options);\n }\n\n return schema;\n }\n /**\n *\n * @param {*} value\n * @param {Object} options\n * @param {*=} options.parent\n * @param {*=} options.context\n */\n\n\n cast(value, options = {}) {\n let resolvedSchema = this.resolve(_extends({\n value\n }, options));\n\n let result = resolvedSchema._cast(value, options);\n\n if (value !== undefined && options.assert !== false && resolvedSchema.isType(result) !== true) {\n let formattedValue = printValue(value);\n let formattedResult = printValue(result);\n throw new TypeError(`The value of ${options.path || 'field'} could not be cast to a value ` + `that satisfies the schema type: \"${resolvedSchema._type}\". \\n\\n` + `attempted value: ${formattedValue} \\n` + (formattedResult !== formattedValue ? `result of cast: ${formattedResult}` : ''));\n }\n\n return result;\n }\n\n _cast(rawValue, _options) {\n let value = rawValue === undefined ? rawValue : this.transforms.reduce((value, fn) => fn.call(this, value, rawValue, this), rawValue);\n\n if (value === undefined) {\n value = this.getDefault();\n }\n\n return value;\n }\n\n _validate(_value, options = {}, cb) {\n let {\n sync,\n path,\n from = [],\n originalValue = _value,\n strict = this.spec.strict,\n abortEarly = this.spec.abortEarly\n } = options;\n let value = _value;\n\n if (!strict) {\n // this._validating = true;\n value = this._cast(value, _extends({\n assert: false\n }, options)); // this._validating = false;\n } // value is cast, we can check if it meets type requirements\n\n\n let args = {\n value,\n path,\n options,\n originalValue,\n schema: this,\n label: this.spec.label,\n sync,\n from\n };\n let initialTests = [];\n if (this._typeError) initialTests.push(this._typeError);\n let finalTests = [];\n if (this._whitelistError) finalTests.push(this._whitelistError);\n if (this._blacklistError) finalTests.push(this._blacklistError);\n runTests({\n args,\n value,\n path,\n sync,\n tests: initialTests,\n endEarly: abortEarly\n }, err => {\n if (err) return void cb(err, value);\n runTests({\n tests: this.tests.concat(finalTests),\n args,\n path,\n sync,\n value,\n endEarly: abortEarly\n }, cb);\n });\n }\n\n validate(value, options, maybeCb) {\n let schema = this.resolve(_extends({}, options, {\n value\n })); // callback case is for nested validations\n\n return typeof maybeCb === 'function' ? schema._validate(value, options, maybeCb) : new Promise((resolve, reject) => schema._validate(value, options, (err, value) => {\n if (err) reject(err);else resolve(value);\n }));\n }\n\n validateSync(value, options) {\n let schema = this.resolve(_extends({}, options, {\n value\n }));\n let result;\n\n schema._validate(value, _extends({}, options, {\n sync: true\n }), (err, value) => {\n if (err) throw err;\n result = value;\n });\n\n return result;\n }\n\n isValid(value, options) {\n return this.validate(value, options).then(() => true, err => {\n if (ValidationError.isError(err)) return false;\n throw err;\n });\n }\n\n isValidSync(value, options) {\n try {\n this.validateSync(value, options);\n return true;\n } catch (err) {\n if (ValidationError.isError(err)) return false;\n throw err;\n }\n }\n\n _getDefault() {\n let defaultValue = this.spec.default;\n\n if (defaultValue == null) {\n return defaultValue;\n }\n\n return typeof defaultValue === 'function' ? defaultValue.call(this) : cloneDeep(defaultValue);\n }\n\n getDefault(options) {\n let schema = this.resolve(options || {});\n return schema._getDefault();\n }\n\n default(def) {\n if (arguments.length === 0) {\n return this._getDefault();\n }\n\n let next = this.clone({\n default: def\n });\n return next;\n }\n\n strict(isStrict = true) {\n let next = this.clone();\n next.spec.strict = isStrict;\n return next;\n }\n\n _isPresent(value) {\n return value != null;\n }\n\n defined(message = locale.defined) {\n return this.test({\n message,\n name: 'defined',\n exclusive: true,\n\n test(value) {\n return value !== undefined;\n }\n\n });\n }\n\n required(message = locale.required) {\n return this.clone({\n presence: 'required'\n }).withMutation(s => s.test({\n message,\n name: 'required',\n exclusive: true,\n\n test(value) {\n return this.schema._isPresent(value);\n }\n\n }));\n }\n\n notRequired() {\n let next = this.clone({\n presence: 'optional'\n });\n next.tests = next.tests.filter(test => test.OPTIONS.name !== 'required');\n return next;\n }\n\n nullable(isNullable = true) {\n let next = this.clone({\n nullable: isNullable !== false\n });\n return next;\n }\n\n transform(fn) {\n let next = this.clone();\n next.transforms.push(fn);\n return next;\n }\n /**\n * Adds a test function to the schema's queue of tests.\n * tests can be exclusive or non-exclusive.\n *\n * - exclusive tests, will replace any existing tests of the same name.\n * - non-exclusive: can be stacked\n *\n * If a non-exclusive test is added to a schema with an exclusive test of the same name\n * the exclusive test is removed and further tests of the same name will be stacked.\n *\n * If an exclusive test is added to a schema with non-exclusive tests of the same name\n * the previous tests are removed and further tests of the same name will replace each other.\n */\n\n\n test(...args) {\n let opts;\n\n if (args.length === 1) {\n if (typeof args[0] === 'function') {\n opts = {\n test: args[0]\n };\n } else {\n opts = args[0];\n }\n } else if (args.length === 2) {\n opts = {\n name: args[0],\n test: args[1]\n };\n } else {\n opts = {\n name: args[0],\n message: args[1],\n test: args[2]\n };\n }\n\n if (opts.message === undefined) opts.message = locale.default;\n if (typeof opts.test !== 'function') throw new TypeError('`test` is a required parameters');\n let next = this.clone();\n let validate = createValidation(opts);\n let isExclusive = opts.exclusive || opts.name && next.exclusiveTests[opts.name] === true;\n\n if (opts.exclusive) {\n if (!opts.name) throw new TypeError('Exclusive tests must provide a unique `name` identifying the test');\n }\n\n if (opts.name) next.exclusiveTests[opts.name] = !!opts.exclusive;\n next.tests = next.tests.filter(fn => {\n if (fn.OPTIONS.name === opts.name) {\n if (isExclusive) return false;\n if (fn.OPTIONS.test === validate.OPTIONS.test) return false;\n }\n\n return true;\n });\n next.tests.push(validate);\n return next;\n }\n\n when(keys, options) {\n if (!Array.isArray(keys) && typeof keys !== 'string') {\n options = keys;\n keys = '.';\n }\n\n let next = this.clone();\n let deps = toArray(keys).map(key => new Ref(key));\n deps.forEach(dep => {\n // @ts-ignore\n if (dep.isSibling) next.deps.push(dep.key);\n });\n next.conditions.push(new Condition(deps, options));\n return next;\n }\n\n typeError(message) {\n let next = this.clone();\n next._typeError = createValidation({\n message,\n name: 'typeError',\n\n test(value) {\n if (value !== undefined && !this.schema.isType(value)) return this.createError({\n params: {\n type: this.schema._type\n }\n });\n return true;\n }\n\n });\n return next;\n }\n\n oneOf(enums, message = locale.oneOf) {\n let next = this.clone();\n enums.forEach(val => {\n next._whitelist.add(val);\n\n next._blacklist.delete(val);\n });\n next._whitelistError = createValidation({\n message,\n name: 'oneOf',\n\n test(value) {\n if (value === undefined) return true;\n let valids = this.schema._whitelist;\n let resolved = valids.resolveAll(this.resolve);\n return resolved.includes(value) ? true : this.createError({\n params: {\n values: valids.toArray().join(', '),\n resolved\n }\n });\n }\n\n });\n return next;\n }\n\n notOneOf(enums, message = locale.notOneOf) {\n let next = this.clone();\n enums.forEach(val => {\n next._blacklist.add(val);\n\n next._whitelist.delete(val);\n });\n next._blacklistError = createValidation({\n message,\n name: 'notOneOf',\n\n test(value) {\n let invalids = this.schema._blacklist;\n let resolved = invalids.resolveAll(this.resolve);\n if (resolved.includes(value)) return this.createError({\n params: {\n values: invalids.toArray().join(', '),\n resolved\n }\n });\n return true;\n }\n\n });\n return next;\n }\n\n strip(strip = true) {\n let next = this.clone();\n next.spec.strip = strip;\n return next;\n }\n\n describe() {\n const next = this.clone();\n const {\n label,\n meta\n } = next.spec;\n const description = {\n meta,\n label,\n type: next.type,\n oneOf: next._whitelist.describe(),\n notOneOf: next._blacklist.describe(),\n tests: next.tests.map(fn => ({\n name: fn.OPTIONS.name,\n params: fn.OPTIONS.params\n })).filter((n, idx, list) => list.findIndex(c => c.name === n.name) === idx)\n };\n return description;\n }\n\n} // eslint-disable-next-line @typescript-eslint/no-unused-vars\n\n// @ts-expect-error\nBaseSchema.prototype.__isYupSchema__ = true;\n\nfor (const method of ['validate', 'validateSync']) BaseSchema.prototype[`${method}At`] = function (path, value, options = {}) {\n const {\n parent,\n parentPath,\n schema\n } = getIn(this, path, value, options.context);\n return schema[method](parent && parent[parentPath], _extends({}, options, {\n parent,\n path\n }));\n};\n\nfor (const alias of ['equals', 'is']) BaseSchema.prototype[alias] = BaseSchema.prototype.oneOf;\n\nfor (const alias of ['not', 'nope']) BaseSchema.prototype[alias] = BaseSchema.prototype.notOneOf;\n\nBaseSchema.prototype.optional = BaseSchema.prototype.notRequired;","// ES6 Map\nvar map\ntry {\n map = Map\n} catch (_) { }\nvar set\n\n// ES6 Set\ntry {\n set = Set\n} catch (_) { }\n\nfunction baseClone (src, circulars, clones) {\n // Null/undefined/functions/etc\n if (!src || typeof src !== 'object' || typeof src === 'function') {\n return src\n }\n\n // DOM Node\n if (src.nodeType && 'cloneNode' in src) {\n return src.cloneNode(true)\n }\n\n // Date\n if (src instanceof Date) {\n return new Date(src.getTime())\n }\n\n // RegExp\n if (src instanceof RegExp) {\n return new RegExp(src)\n }\n\n // Arrays\n if (Array.isArray(src)) {\n return src.map(clone)\n }\n\n // ES6 Maps\n if (map && src instanceof map) {\n return new Map(Array.from(src.entries()))\n }\n\n // ES6 Sets\n if (set && src instanceof set) {\n return new Set(Array.from(src.values()))\n }\n\n // Object\n if (src instanceof Object) {\n circulars.push(src)\n var obj = Object.create(src)\n clones.push(obj)\n for (var key in src) {\n var idx = circulars.findIndex(function (i) {\n return i === src[key]\n })\n obj[key] = idx > -1 ? clones[idx] : baseClone(src[key], circulars, clones)\n }\n return obj\n }\n\n // ???\n return src\n}\n\nexport default function clone (src) {\n return baseClone(src, [], [])\n}\n","import printValue from './util/printValue';\nexport let mixed = {\n default: '${path} is invalid',\n required: '${path} is a required field',\n oneOf: '${path} must be one of the following values: ${values}',\n notOneOf: '${path} must not be one of the following values: ${values}',\n notType: ({\n path,\n type,\n value,\n originalValue\n }) => {\n let isCast = originalValue != null && originalValue !== value;\n let msg = `${path} must be a \\`${type}\\` type, ` + `but the final value was: \\`${printValue(value, true)}\\`` + (isCast ? ` (cast from the value \\`${printValue(originalValue, true)}\\`).` : '.');\n\n if (value === null) {\n msg += `\\n If \"null\" is intended as an empty value be sure to mark the schema as \\`.nullable()\\``;\n }\n\n return msg;\n },\n defined: '${path} must be defined'\n};\nexport let string = {\n length: '${path} must be exactly ${length} characters',\n min: '${path} must be at least ${min} characters',\n max: '${path} must be at most ${max} characters',\n matches: '${path} must match the following: \"${regex}\"',\n email: '${path} must be a valid email',\n url: '${path} must be a valid URL',\n uuid: '${path} must be a valid UUID',\n trim: '${path} must be a trimmed string',\n lowercase: '${path} must be a lowercase string',\n uppercase: '${path} must be a upper case string'\n};\nexport let number = {\n min: '${path} must be greater than or equal to ${min}',\n max: '${path} must be less than or equal to ${max}',\n lessThan: '${path} must be less than ${less}',\n moreThan: '${path} must be greater than ${more}',\n positive: '${path} must be a positive number',\n negative: '${path} must be a negative number',\n integer: '${path} must be an integer'\n};\nexport let date = {\n min: '${path} field must be later than ${min}',\n max: '${path} field must be at earlier than ${max}'\n};\nexport let boolean = {\n isValue: '${path} field must be ${value}'\n};\nexport let object = {\n noUnknown: '${path} field has unspecified keys: ${unknown}'\n};\nexport let array = {\n min: '${path} field must have at least ${min} items',\n max: '${path} field must have less than or equal to ${max} items',\n length: '${path} must have ${length} items'\n};\nexport default Object.assign(Object.create(null), {\n mixed,\n string,\n number,\n date,\n object,\n array,\n boolean\n});","const toString = Object.prototype.toString;\nconst errorToString = Error.prototype.toString;\nconst regExpToString = RegExp.prototype.toString;\nconst symbolToString = typeof Symbol !== 'undefined' ? Symbol.prototype.toString : () => '';\nconst SYMBOL_REGEXP = /^Symbol\\((.*)\\)(.*)$/;\n\nfunction printNumber(val) {\n if (val != +val) return 'NaN';\n const isNegativeZero = val === 0 && 1 / val < 0;\n return isNegativeZero ? '-0' : '' + val;\n}\n\nfunction printSimpleValue(val, quoteStrings = false) {\n if (val == null || val === true || val === false) return '' + val;\n const typeOf = typeof val;\n if (typeOf === 'number') return printNumber(val);\n if (typeOf === 'string') return quoteStrings ? `\"${val}\"` : val;\n if (typeOf === 'function') return '[Function ' + (val.name || 'anonymous') + ']';\n if (typeOf === 'symbol') return symbolToString.call(val).replace(SYMBOL_REGEXP, 'Symbol($1)');\n const tag = toString.call(val).slice(8, -1);\n if (tag === 'Date') return isNaN(val.getTime()) ? '' + val : val.toISOString(val);\n if (tag === 'Error' || val instanceof Error) return '[' + errorToString.call(val) + ']';\n if (tag === 'RegExp') return regExpToString.call(val);\n return null;\n}\n\nexport default function printValue(value, quoteStrings) {\n let result = printSimpleValue(value, quoteStrings);\n if (result !== null) return result;\n return JSON.stringify(value, function (key, value) {\n let result = printSimpleValue(this[key], quoteStrings);\n if (result !== null) return result;\n return value;\n }, 2);\n}","import has from 'lodash/has';\nimport isSchema from './util/isSchema';\n\nclass Condition {\n constructor(refs, options) {\n this.fn = void 0;\n this.refs = refs;\n this.refs = refs;\n\n if (typeof options === 'function') {\n this.fn = options;\n return;\n }\n\n if (!has(options, 'is')) throw new TypeError('`is:` is required for `when()` conditions');\n if (!options.then && !options.otherwise) throw new TypeError('either `then:` or `otherwise:` is required for `when()` conditions');\n let {\n is,\n then,\n otherwise\n } = options;\n let check = typeof is === 'function' ? is : (...values) => values.every(value => value === is);\n\n this.fn = function (...args) {\n let options = args.pop();\n let schema = args.pop();\n let branch = check(...args) ? then : otherwise;\n if (!branch) return undefined;\n if (typeof branch === 'function') return branch(schema);\n return schema.concat(branch.resolve(options));\n };\n }\n\n resolve(base, options) {\n let values = this.refs.map(ref => ref.getValue(options == null ? void 0 : options.value, options == null ? void 0 : options.parent, options == null ? void 0 : options.context));\n let schema = this.fn.apply(base, values.concat(base, options));\n if (schema === undefined || schema === base) return base;\n if (!isSchema(schema)) throw new TypeError('conditions must return a schema object');\n return schema.resolve(options);\n }\n\n}\n\nexport default Condition;","var baseHas = require('./_baseHas'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct property of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = { 'a': { 'b': 2 } };\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.has(object, 'a');\n * // => true\n *\n * _.has(object, 'a.b');\n * // => true\n *\n * _.has(object, ['a', 'b']);\n * // => true\n *\n * _.has(other, 'a');\n * // => false\n */\nfunction has(object, path) {\n return object != null && hasPath(object, path, baseHas);\n}\n\nmodule.exports = has;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.has` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHas(object, key) {\n return object != null && hasOwnProperty.call(object, key);\n}\n\nmodule.exports = baseHas;\n","var castPath = require('./_castPath'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isIndex = require('./_isIndex'),\n isLength = require('./isLength'),\n toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n","var isArray = require('./isArray'),\n isKey = require('./_isKey'),\n stringToPath = require('./_stringToPath'),\n toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n","var isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nmodule.exports = stringToPath;\n","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nmodule.exports = memoizeCapped;\n","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n","var Symbol = require('./_Symbol'),\n arrayMap = require('./_arrayMap'),\n isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nmodule.exports = arrayMap;\n","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n","const isSchema = obj => obj && obj.__isYupSchema__;\n\nexport default isSchema;","import ValidationError from '../ValidationError';\n\nconst once = cb => {\n let fired = false;\n return (...args) => {\n if (fired) return;\n fired = true;\n cb(...args);\n };\n};\n\nexport default function runTests(options, cb) {\n let {\n endEarly,\n tests,\n args,\n value,\n errors,\n sort,\n path\n } = options;\n let callback = once(cb);\n let count = tests.length;\n const nestedErrors = [];\n errors = errors ? errors : [];\n if (!count) return errors.length ? callback(new ValidationError(errors, value, path)) : callback(null, value);\n\n for (let i = 0; i < tests.length; i++) {\n const test = tests[i];\n test(args, function finishTestRun(err) {\n if (err) {\n // always return early for non validation errors\n if (!ValidationError.isError(err)) {\n return callback(err, value);\n }\n\n if (endEarly) {\n err.value = value;\n return callback(err, value);\n }\n\n nestedErrors.push(err);\n }\n\n if (--count <= 0) {\n if (nestedErrors.length) {\n if (sort) nestedErrors.sort(sort); //show parent errors after the nested ones: name.first, name\n\n if (errors.length) nestedErrors.push(...errors);\n errors = nestedErrors;\n }\n\n if (errors.length) {\n callback(new ValidationError(errors, value, path), value);\n return;\n }\n\n callback(null, value);\n }\n });\n }\n}","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport printValue from './util/printValue';\nimport toArray from './util/toArray';\nlet strReg = /\\$\\{\\s*(\\w+)\\s*\\}/g;\nexport default class ValidationError extends Error {\n static formatError(message, params) {\n const path = params.label || params.path || 'this';\n if (path !== params.path) params = _extends({}, params, {\n path\n });\n if (typeof message === 'string') return message.replace(strReg, (_, key) => printValue(params[key]));\n if (typeof message === 'function') return message(params);\n return message;\n }\n\n static isError(err) {\n return err && err.name === 'ValidationError';\n }\n\n constructor(errorOrErrors, value, field, type) {\n super();\n this.value = void 0;\n this.path = void 0;\n this.type = void 0;\n this.errors = void 0;\n this.params = void 0;\n this.inner = void 0;\n this.name = 'ValidationError';\n this.value = value;\n this.path = field;\n this.type = type;\n this.errors = [];\n this.inner = [];\n toArray(errorOrErrors).forEach(err => {\n if (ValidationError.isError(err)) {\n this.errors.push(...err.errors);\n this.inner = this.inner.concat(err.inner.length ? err.inner : err);\n } else {\n this.errors.push(err);\n }\n });\n this.message = this.errors.length > 1 ? `${this.errors.length} errors occurred` : this.errors[0];\n if (Error.captureStackTrace) Error.captureStackTrace(this, ValidationError);\n }\n\n}","export default function toArray(value) {\n return value == null ? [] : [].concat(value);\n}","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport mapValues from 'lodash/mapValues';\nimport ValidationError from '../ValidationError';\nimport Ref from '../Reference';\nexport default function createValidation(config) {\n function validate(_ref, cb) {\n let {\n value,\n path = '',\n label,\n options,\n originalValue,\n sync\n } = _ref,\n rest = _objectWithoutPropertiesLoose(_ref, [\"value\", \"path\", \"label\", \"options\", \"originalValue\", \"sync\"]);\n\n const {\n name,\n test,\n params,\n message\n } = config;\n let {\n parent,\n context\n } = options;\n\n function resolve(item) {\n return Ref.isRef(item) ? item.getValue(value, parent, context) : item;\n }\n\n function createError(overrides = {}) {\n const nextParams = mapValues(_extends({\n value,\n originalValue,\n label,\n path: overrides.path || path\n }, params, overrides.params), resolve);\n const error = new ValidationError(ValidationError.formatError(overrides.message || message, nextParams), value, nextParams.path, overrides.type || name);\n error.params = nextParams;\n return error;\n }\n\n let ctx = _extends({\n path,\n parent,\n type: name,\n createError,\n resolve,\n options,\n originalValue\n }, rest);\n\n if (!sync) {\n try {\n Promise.resolve(test.call(ctx, value, ctx)).then(validOrError => {\n if (ValidationError.isError(validOrError)) cb(validOrError);else if (!validOrError) cb(createError());else cb(null, validOrError);\n }).catch(cb);\n } catch (err) {\n cb(err);\n }\n\n return;\n }\n\n let result;\n\n try {\n var _ref2;\n\n result = test.call(ctx, value, ctx);\n\n if (typeof ((_ref2 = result) == null ? void 0 : _ref2.then) === 'function') {\n throw new Error(`Validation test of type: \"${ctx.type}\" returned a Promise during a synchronous validate. ` + `This test will finish after the validate call has returned`);\n }\n } catch (err) {\n cb(err);\n return;\n }\n\n if (ValidationError.isError(result)) cb(result);else if (!result) cb(createError());else cb(null, result);\n }\n\n validate.OPTIONS = config;\n return validate;\n}","var baseAssignValue = require('./_baseAssignValue'),\n baseForOwn = require('./_baseForOwn'),\n baseIteratee = require('./_baseIteratee');\n\n/**\n * Creates an object with the same keys as `object` and values generated\n * by running each own enumerable string keyed property of `object` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapKeys\n * @example\n *\n * var users = {\n * 'fred': { 'user': 'fred', 'age': 40 },\n * 'pebbles': { 'user': 'pebbles', 'age': 1 }\n * };\n *\n * _.mapValues(users, function(o) { return o.age; });\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n *\n * // The `_.property` iteratee shorthand.\n * _.mapValues(users, 'age');\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n */\nfunction mapValues(object, iteratee) {\n var result = {};\n iteratee = baseIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, key, iteratee(value, key, object));\n });\n return result;\n}\n\nmodule.exports = mapValues;\n","var defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nmodule.exports = baseAssignValue;\n","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n","var baseFor = require('./_baseFor'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n}\n\nmodule.exports = baseForOwn;\n","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n}\n\nmodule.exports = createBaseFor;\n","var baseMatches = require('./_baseMatches'),\n baseMatchesProperty = require('./_baseMatchesProperty'),\n identity = require('./identity'),\n isArray = require('./isArray'),\n property = require('./property');\n\n/**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\nfunction baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n}\n\nmodule.exports = baseIteratee;\n","var baseIsMatch = require('./_baseIsMatch'),\n getMatchData = require('./_getMatchData'),\n matchesStrictComparable = require('./_matchesStrictComparable');\n\n/**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n}\n\nmodule.exports = baseMatches;\n","var Stack = require('./_Stack'),\n baseIsEqual = require('./_baseIsEqual');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n}\n\nmodule.exports = baseIsMatch;\n","var isStrictComparable = require('./_isStrictComparable'),\n keys = require('./keys');\n\n/**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n}\n\nmodule.exports = getMatchData;\n","var isObject = require('./isObject');\n\n/**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n return value === value && !isObject(value);\n}\n\nmodule.exports = isStrictComparable;\n","/**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n}\n\nmodule.exports = matchesStrictComparable;\n","var baseIsEqual = require('./_baseIsEqual'),\n get = require('./get'),\n hasIn = require('./hasIn'),\n isKey = require('./_isKey'),\n isStrictComparable = require('./_isStrictComparable'),\n matchesStrictComparable = require('./_matchesStrictComparable'),\n toKey = require('./_toKey');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n}\n\nmodule.exports = baseMatchesProperty;\n","var baseGet = require('./_baseGet');\n\n/**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\nfunction get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n}\n\nmodule.exports = get;\n","var castPath = require('./_castPath'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","var baseHasIn = require('./_baseHasIn'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\n","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n return object != null && key in Object(object);\n}\n\nmodule.exports = baseHasIn;\n","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\nmodule.exports = identity;\n","var baseProperty = require('./_baseProperty'),\n basePropertyDeep = require('./_basePropertyDeep'),\n isKey = require('./_isKey'),\n toKey = require('./_toKey');\n\n/**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': 2 } },\n * { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\nfunction property(path) {\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n}\n\nmodule.exports = property;\n","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n}\n\nmodule.exports = baseProperty;\n","var baseGet = require('./_baseGet');\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n}\n\nmodule.exports = basePropertyDeep;\n","import { getter } from 'property-expr';\nconst prefixes = {\n context: '$',\n value: '.'\n};\nexport function create(key, options) {\n return new Reference(key, options);\n}\nexport default class Reference {\n constructor(key, options = {}) {\n this.key = void 0;\n this.isContext = void 0;\n this.isValue = void 0;\n this.isSibling = void 0;\n this.path = void 0;\n this.getter = void 0;\n this.map = void 0;\n if (typeof key !== 'string') throw new TypeError('ref must be a string, got: ' + key);\n this.key = key.trim();\n if (key === '') throw new TypeError('ref must be a non-empty string');\n this.isContext = this.key[0] === prefixes.context;\n this.isValue = this.key[0] === prefixes.value;\n this.isSibling = !this.isContext && !this.isValue;\n let prefix = this.isContext ? prefixes.context : this.isValue ? prefixes.value : '';\n this.path = this.key.slice(prefix.length);\n this.getter = this.path && getter(this.path, true);\n this.map = options.map;\n }\n\n getValue(value, parent, context) {\n let result = this.isContext ? context : this.isValue ? value : parent;\n if (this.getter) result = this.getter(result || {});\n if (this.map) result = this.map(result);\n return result;\n }\n /**\n *\n * @param {*} value\n * @param {Object} options\n * @param {Object=} options.context\n * @param {Object=} options.parent\n */\n\n\n cast(value, options) {\n return this.getValue(value, options == null ? void 0 : options.parent, options == null ? void 0 : options.context);\n }\n\n resolve() {\n return this;\n }\n\n describe() {\n return {\n type: 'ref',\n key: this.key\n };\n }\n\n toString() {\n return `Ref(${this.key})`;\n }\n\n static isRef(value) {\n return value && value.__isYupRef;\n }\n\n} // @ts-ignore\n\nReference.prototype.__isYupRef = true;","/**\n * Based on Kendo UI Core expression code \n */\n'use strict'\n\nfunction Cache(maxSize) {\n this._maxSize = maxSize\n this.clear()\n}\nCache.prototype.clear = function () {\n this._size = 0\n this._values = Object.create(null)\n}\nCache.prototype.get = function (key) {\n return this._values[key]\n}\nCache.prototype.set = function (key, value) {\n this._size >= this._maxSize && this.clear()\n if (!(key in this._values)) this._size++\n\n return (this._values[key] = value)\n}\n\nvar SPLIT_REGEX = /[^.^\\]^[]+|(?=\\[\\]|\\.\\.)/g,\n DIGIT_REGEX = /^\\d+$/,\n LEAD_DIGIT_REGEX = /^\\d/,\n SPEC_CHAR_REGEX = /[~`!#$%\\^&*+=\\-\\[\\]\\\\';,/{}|\\\\\":<>\\?]/g,\n CLEAN_QUOTES_REGEX = /^\\s*(['\"]?)(.*?)(\\1)\\s*$/,\n MAX_CACHE_SIZE = 512\n\nvar pathCache = new Cache(MAX_CACHE_SIZE),\n setCache = new Cache(MAX_CACHE_SIZE),\n getCache = new Cache(MAX_CACHE_SIZE)\n\nvar config\n\nmodule.exports = {\n Cache: Cache,\n\n split: split,\n\n normalizePath: normalizePath,\n\n setter: function (path) {\n var parts = normalizePath(path)\n\n return (\n setCache.get(path) ||\n setCache.set(path, function setter(obj, value) {\n var index = 0\n var len = parts.length\n var data = obj\n\n while (index < len - 1) {\n var part = parts[index]\n if (\n part === '__proto__' ||\n part === 'constructor' ||\n part === 'prototype'\n ) {\n return obj\n }\n\n data = data[parts[index++]]\n }\n data[parts[index]] = value\n })\n )\n },\n\n getter: function (path, safe) {\n var parts = normalizePath(path)\n return (\n getCache.get(path) ||\n getCache.set(path, function getter(data) {\n var index = 0,\n len = parts.length\n while (index < len) {\n if (data != null || !safe) data = data[parts[index++]]\n else return\n }\n return data\n })\n )\n },\n\n join: function (segments) {\n return segments.reduce(function (path, part) {\n return (\n path +\n (isQuoted(part) || DIGIT_REGEX.test(part)\n ? '[' + part + ']'\n : (path ? '.' : '') + part)\n )\n }, '')\n },\n\n forEach: function (path, cb, thisArg) {\n forEach(Array.isArray(path) ? path : split(path), cb, thisArg)\n },\n}\n\nfunction normalizePath(path) {\n return (\n pathCache.get(path) ||\n pathCache.set(\n path,\n split(path).map(function (part) {\n return part.replace(CLEAN_QUOTES_REGEX, '$2')\n })\n )\n )\n}\n\nfunction split(path) {\n return path.match(SPLIT_REGEX) || ['']\n}\n\nfunction forEach(parts, iter, thisArg) {\n var len = parts.length,\n part,\n idx,\n isArray,\n isBracket\n\n for (idx = 0; idx < len; idx++) {\n part = parts[idx]\n\n if (part) {\n if (shouldBeQuoted(part)) {\n part = '\"' + part + '\"'\n }\n\n isBracket = isQuoted(part)\n isArray = !isBracket && /^\\d+$/.test(part)\n\n iter.call(thisArg, part, isBracket, isArray, idx, parts)\n }\n }\n}\n\nfunction isQuoted(str) {\n return (\n typeof str === 'string' && str && [\"'\", '\"'].indexOf(str.charAt(0)) !== -1\n )\n}\n\nfunction hasLeadingNumber(part) {\n return part.match(LEAD_DIGIT_REGEX) && !part.match(DIGIT_REGEX)\n}\n\nfunction hasSpecialChars(part) {\n return SPEC_CHAR_REGEX.test(part)\n}\n\nfunction shouldBeQuoted(part) {\n return !isQuoted(part) && (hasLeadingNumber(part) || hasSpecialChars(part))\n}\n","import { forEach } from 'property-expr';\n\nlet trim = part => part.substr(0, part.length - 1).substr(1);\n\nexport function getIn(schema, path, value, context = value) {\n let parent, lastPart, lastPartDebug; // root path: ''\n\n if (!path) return {\n parent,\n parentPath: path,\n schema\n };\n forEach(path, (_part, isBracket, isArray) => {\n let part = isBracket ? trim(_part) : _part;\n schema = schema.resolve({\n context,\n parent,\n value\n });\n\n if (schema.innerType) {\n let idx = isArray ? parseInt(part, 10) : 0;\n\n if (value && idx >= value.length) {\n throw new Error(`Yup.reach cannot resolve an array item at index: ${_part}, in the path: ${path}. ` + `because there is no value at that index. `);\n }\n\n parent = value;\n value = value && value[idx];\n schema = schema.innerType;\n } // sometimes the array index part of a path doesn't exist: \"nested.arr.child\"\n // in these cases the current part is the next schema and should be processed\n // in this iteration. For cases where the index signature is included this\n // check will fail and we'll handle the `child` part on the next iteration like normal\n\n\n if (!isArray) {\n if (!schema.fields || !schema.fields[part]) throw new Error(`The schema does not contain the path: ${path}. ` + `(failed at: ${lastPartDebug} which is a type: \"${schema._type}\")`);\n parent = value;\n value = value && value[part];\n schema = schema.fields[part];\n }\n\n lastPart = part;\n lastPartDebug = isBracket ? '[' + _part + ']' : '.' + _part;\n });\n return {\n schema,\n parent,\n parentPath: lastPart\n };\n}\n\nconst reach = (obj, path, value, context) => getIn(obj, path, value, context).schema;\n\nexport default reach;","import Reference from '../Reference';\nexport default class ReferenceSet {\n constructor() {\n this.list = void 0;\n this.refs = void 0;\n this.list = new Set();\n this.refs = new Map();\n }\n\n get size() {\n return this.list.size + this.refs.size;\n }\n\n describe() {\n const description = [];\n\n for (const item of this.list) description.push(item);\n\n for (const [, ref] of this.refs) description.push(ref.describe());\n\n return description;\n }\n\n toArray() {\n return Array.from(this.list).concat(Array.from(this.refs.values()));\n }\n\n resolveAll(resolve) {\n return this.toArray().reduce((acc, e) => acc.concat(Reference.isRef(e) ? resolve(e) : e), []);\n }\n\n add(value) {\n Reference.isRef(value) ? this.refs.set(value.key, value) : this.list.add(value);\n }\n\n delete(value) {\n Reference.isRef(value) ? this.refs.delete(value.key) : this.list.delete(value);\n }\n\n clone() {\n const next = new ReferenceSet();\n next.list = new Set(this.list);\n next.refs = new Map(this.refs);\n return next;\n }\n\n merge(newItems, removeItems) {\n const next = this.clone();\n newItems.list.forEach(value => next.add(value));\n newItems.refs.forEach(value => next.add(value));\n removeItems.list.forEach(value => next.delete(value));\n removeItems.refs.forEach(value => next.delete(value));\n return next;\n }\n\n}","import BaseSchema from './schema';\nimport { boolean as locale } from './locale';\nimport isAbsent from './util/isAbsent';\nexport function create() {\n return new BooleanSchema();\n}\nexport default class BooleanSchema extends BaseSchema {\n constructor() {\n super({\n type: 'boolean'\n });\n this.withMutation(() => {\n this.transform(function (value) {\n if (!this.isType(value)) {\n if (/^(true|1)$/i.test(String(value))) return true;\n if (/^(false|0)$/i.test(String(value))) return false;\n }\n\n return value;\n });\n });\n }\n\n _typeCheck(v) {\n if (v instanceof Boolean) v = v.valueOf();\n return typeof v === 'boolean';\n }\n\n isTrue(message = locale.isValue) {\n return this.test({\n message,\n name: 'is-value',\n exclusive: true,\n params: {\n value: 'true'\n },\n\n test(value) {\n return isAbsent(value) || value === true;\n }\n\n });\n }\n\n isFalse(message = locale.isValue) {\n return this.test({\n message,\n name: 'is-value',\n exclusive: true,\n params: {\n value: 'false'\n },\n\n test(value) {\n return isAbsent(value) || value === false;\n }\n\n });\n }\n\n}\ncreate.prototype = BooleanSchema.prototype;","const isAbsent = value => value == null;\n\nexport default isAbsent;","import { string as locale } from './locale';\nimport isAbsent from './util/isAbsent';\nimport BaseSchema from './schema'; // eslint-disable-next-line\n\nlet rEmail = /^((([a-z]|\\d|[!#\\$%&'\\*\\+\\-\\/=\\?\\^_`{\\|}~]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])+(\\.([a-z]|\\d|[!#\\$%&'\\*\\+\\-\\/=\\?\\^_`{\\|}~]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])+)*)|((\\x22)((((\\x20|\\x09)*(\\x0d\\x0a))?(\\x20|\\x09)+)?(([\\x01-\\x08\\x0b\\x0c\\x0e-\\x1f\\x7f]|\\x21|[\\x23-\\x5b]|[\\x5d-\\x7e]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(\\\\([\\x01-\\x09\\x0b\\x0c\\x0d-\\x7f]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF]))))*(((\\x20|\\x09)*(\\x0d\\x0a))?(\\x20|\\x09)+)?(\\x22)))@((([a-z]|\\d|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(([a-z]|\\d|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])*([a-z]|\\d|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])))\\.)+(([a-z]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(([a-z]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])*([a-z]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])))$/i; // eslint-disable-next-line\n\nlet rUrl = /^((https?|ftp):)?\\/\\/(((([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(%[\\da-f]{2})|[!\\$&'\\(\\)\\*\\+,;=]|:)*@)?(((\\d|[1-9]\\d|1\\d\\d|2[0-4]\\d|25[0-5])\\.(\\d|[1-9]\\d|1\\d\\d|2[0-4]\\d|25[0-5])\\.(\\d|[1-9]\\d|1\\d\\d|2[0-4]\\d|25[0-5])\\.(\\d|[1-9]\\d|1\\d\\d|2[0-4]\\d|25[0-5]))|((([a-z]|\\d|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(([a-z]|\\d|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])*([a-z]|\\d|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])))\\.)+(([a-z]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(([a-z]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])*([a-z]|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])))\\.?)(:\\d*)?)(\\/((([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(%[\\da-f]{2})|[!\\$&'\\(\\)\\*\\+,;=]|:|@)+(\\/(([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(%[\\da-f]{2})|[!\\$&'\\(\\)\\*\\+,;=]|:|@)*)*)?)?(\\?((([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(%[\\da-f]{2})|[!\\$&'\\(\\)\\*\\+,;=]|:|@)|[\\uE000-\\uF8FF]|\\/|\\?)*)?(\\#((([a-z]|\\d|-|\\.|_|~|[\\u00A0-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFEF])|(%[\\da-f]{2})|[!\\$&'\\(\\)\\*\\+,;=]|:|@)|\\/|\\?)*)?$/i; // eslint-disable-next-line\n\nlet rUUID = /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;\n\nlet isTrimmed = value => isAbsent(value) || value === value.trim();\n\nlet objStringTag = {}.toString();\nexport function create() {\n return new StringSchema();\n}\nexport default class StringSchema extends BaseSchema {\n constructor() {\n super({\n type: 'string'\n });\n this.withMutation(() => {\n this.transform(function (value) {\n if (this.isType(value)) return value;\n if (Array.isArray(value)) return value;\n const strValue = value != null && value.toString ? value.toString() : value;\n if (strValue === objStringTag) return value;\n return strValue;\n });\n });\n }\n\n _typeCheck(value) {\n if (value instanceof String) value = value.valueOf();\n return typeof value === 'string';\n }\n\n _isPresent(value) {\n return super._isPresent(value) && !!value.length;\n }\n\n length(length, message = locale.length) {\n return this.test({\n message,\n name: 'length',\n exclusive: true,\n params: {\n length\n },\n\n test(value) {\n return isAbsent(value) || value.length === this.resolve(length);\n }\n\n });\n }\n\n min(min, message = locale.min) {\n return this.test({\n message,\n name: 'min',\n exclusive: true,\n params: {\n min\n },\n\n test(value) {\n return isAbsent(value) || value.length >= this.resolve(min);\n }\n\n });\n }\n\n max(max, message = locale.max) {\n return this.test({\n name: 'max',\n exclusive: true,\n message,\n params: {\n max\n },\n\n test(value) {\n return isAbsent(value) || value.length <= this.resolve(max);\n }\n\n });\n }\n\n matches(regex, options) {\n let excludeEmptyString = false;\n let message;\n let name;\n\n if (options) {\n if (typeof options === 'object') {\n ({\n excludeEmptyString = false,\n message,\n name\n } = options);\n } else {\n message = options;\n }\n }\n\n return this.test({\n name: name || 'matches',\n message: message || locale.matches,\n params: {\n regex\n },\n test: value => isAbsent(value) || value === '' && excludeEmptyString || value.search(regex) !== -1\n });\n }\n\n email(message = locale.email) {\n return this.matches(rEmail, {\n name: 'email',\n message,\n excludeEmptyString: true\n });\n }\n\n url(message = locale.url) {\n return this.matches(rUrl, {\n name: 'url',\n message,\n excludeEmptyString: true\n });\n }\n\n uuid(message = locale.uuid) {\n return this.matches(rUUID, {\n name: 'uuid',\n message,\n excludeEmptyString: false\n });\n } //-- transforms --\n\n\n ensure() {\n return this.default('').transform(val => val === null ? '' : val);\n }\n\n trim(message = locale.trim) {\n return this.transform(val => val != null ? val.trim() : val).test({\n message,\n name: 'trim',\n test: isTrimmed\n });\n }\n\n lowercase(message = locale.lowercase) {\n return this.transform(value => !isAbsent(value) ? value.toLowerCase() : value).test({\n message,\n name: 'string_case',\n exclusive: true,\n test: value => isAbsent(value) || value === value.toLowerCase()\n });\n }\n\n uppercase(message = locale.uppercase) {\n return this.transform(value => !isAbsent(value) ? value.toUpperCase() : value).test({\n message,\n name: 'string_case',\n exclusive: true,\n test: value => isAbsent(value) || value === value.toUpperCase()\n });\n }\n\n}\ncreate.prototype = StringSchema.prototype; //\n// String Interfaces\n//","import { number as locale } from './locale';\nimport isAbsent from './util/isAbsent';\nimport BaseSchema from './schema';\n\nlet isNaN = value => value != +value;\n\nexport function create() {\n return new NumberSchema();\n}\nexport default class NumberSchema extends BaseSchema {\n constructor() {\n super({\n type: 'number'\n });\n this.withMutation(() => {\n this.transform(function (value) {\n let parsed = value;\n\n if (typeof parsed === 'string') {\n parsed = parsed.replace(/\\s/g, '');\n if (parsed === '') return NaN; // don't use parseFloat to avoid positives on alpha-numeric strings\n\n parsed = +parsed;\n }\n\n if (this.isType(parsed)) return parsed;\n return parseFloat(parsed);\n });\n });\n }\n\n _typeCheck(value) {\n if (value instanceof Number) value = value.valueOf();\n return typeof value === 'number' && !isNaN(value);\n }\n\n min(min, message = locale.min) {\n return this.test({\n message,\n name: 'min',\n exclusive: true,\n params: {\n min\n },\n\n test(value) {\n return isAbsent(value) || value >= this.resolve(min);\n }\n\n });\n }\n\n max(max, message = locale.max) {\n return this.test({\n message,\n name: 'max',\n exclusive: true,\n params: {\n max\n },\n\n test(value) {\n return isAbsent(value) || value <= this.resolve(max);\n }\n\n });\n }\n\n lessThan(less, message = locale.lessThan) {\n return this.test({\n message,\n name: 'max',\n exclusive: true,\n params: {\n less\n },\n\n test(value) {\n return isAbsent(value) || value < this.resolve(less);\n }\n\n });\n }\n\n moreThan(more, message = locale.moreThan) {\n return this.test({\n message,\n name: 'min',\n exclusive: true,\n params: {\n more\n },\n\n test(value) {\n return isAbsent(value) || value > this.resolve(more);\n }\n\n });\n }\n\n positive(msg = locale.positive) {\n return this.moreThan(0, msg);\n }\n\n negative(msg = locale.negative) {\n return this.lessThan(0, msg);\n }\n\n integer(message = locale.integer) {\n return this.test({\n name: 'integer',\n message,\n test: val => isAbsent(val) || Number.isInteger(val)\n });\n }\n\n truncate() {\n return this.transform(value => !isAbsent(value) ? value | 0 : value);\n }\n\n round(method) {\n var _method;\n\n let avail = ['ceil', 'floor', 'round', 'trunc'];\n method = ((_method = method) == null ? void 0 : _method.toLowerCase()) || 'round'; // this exists for symemtry with the new Math.trunc\n\n if (method === 'trunc') return this.truncate();\n if (avail.indexOf(method.toLowerCase()) === -1) throw new TypeError('Only valid options for round() are: ' + avail.join(', '));\n return this.transform(value => !isAbsent(value) ? Math[method](value) : value);\n }\n\n}\ncreate.prototype = NumberSchema.prototype; //\n// Number Interfaces\n//","// @ts-ignore\nimport isoParse from './util/isodate';\nimport { date as locale } from './locale';\nimport isAbsent from './util/isAbsent';\nimport Ref from './Reference';\nimport BaseSchema from './schema';\nlet invalidDate = new Date('');\n\nlet isDate = obj => Object.prototype.toString.call(obj) === '[object Date]';\n\nexport function create() {\n return new DateSchema();\n}\nexport default class DateSchema extends BaseSchema {\n constructor() {\n super({\n type: 'date'\n });\n this.withMutation(() => {\n this.transform(function (value) {\n if (this.isType(value)) return value;\n value = isoParse(value); // 0 is a valid timestamp equivalent to 1970-01-01T00:00:00Z(unix epoch) or before.\n\n return !isNaN(value) ? new Date(value) : invalidDate;\n });\n });\n }\n\n _typeCheck(v) {\n return isDate(v) && !isNaN(v.getTime());\n }\n\n prepareParam(ref, name) {\n let param;\n\n if (!Ref.isRef(ref)) {\n let cast = this.cast(ref);\n if (!this._typeCheck(cast)) throw new TypeError(`\\`${name}\\` must be a Date or a value that can be \\`cast()\\` to a Date`);\n param = cast;\n } else {\n param = ref;\n }\n\n return param;\n }\n\n min(min, message = locale.min) {\n let limit = this.prepareParam(min, 'min');\n return this.test({\n message,\n name: 'min',\n exclusive: true,\n params: {\n min\n },\n\n test(value) {\n return isAbsent(value) || value >= this.resolve(limit);\n }\n\n });\n }\n\n max(max, message = locale.max) {\n let limit = this.prepareParam(max, 'max');\n return this.test({\n message,\n name: 'max',\n exclusive: true,\n params: {\n max\n },\n\n test(value) {\n return isAbsent(value) || value <= this.resolve(limit);\n }\n\n });\n }\n\n}\nDateSchema.INVALID_DATE = invalidDate;\ncreate.prototype = DateSchema.prototype;\ncreate.INVALID_DATE = invalidDate;","/* eslint-disable */\n\n/**\n *\n * Date.parse with progressive enhancement for ISO 8601 \n * NON-CONFORMANT EDITION.\n * © 2011 Colin Snover \n * Released under MIT license.\n */\n// 1 YYYY 2 MM 3 DD 4 HH 5 mm 6 ss 7 msec 8 Z 9 ± 10 tzHH 11 tzmm\nvar isoReg = /^(\\d{4}|[+\\-]\\d{6})(?:-?(\\d{2})(?:-?(\\d{2}))?)?(?:[ T]?(\\d{2}):?(\\d{2})(?::?(\\d{2})(?:[,\\.](\\d{1,}))?)?(?:(Z)|([+\\-])(\\d{2})(?::?(\\d{2}))?)?)?$/;\nexport default function parseIsoDate(date) {\n var numericKeys = [1, 4, 5, 6, 7, 10, 11],\n minutesOffset = 0,\n timestamp,\n struct;\n\n if (struct = isoReg.exec(date)) {\n // avoid NaN timestamps caused by “undefined” values being passed to Date.UTC\n for (var i = 0, k; k = numericKeys[i]; ++i) struct[k] = +struct[k] || 0; // allow undefined days and months\n\n\n struct[2] = (+struct[2] || 1) - 1;\n struct[3] = +struct[3] || 1; // allow arbitrary sub-second precision beyond milliseconds\n\n struct[7] = struct[7] ? String(struct[7]).substr(0, 3) : 0; // timestamps without timezone identifiers should be considered local time\n\n if ((struct[8] === undefined || struct[8] === '') && (struct[9] === undefined || struct[9] === '')) timestamp = +new Date(struct[1], struct[2], struct[3], struct[4], struct[5], struct[6], struct[7]);else {\n if (struct[8] !== 'Z' && struct[9] !== undefined) {\n minutesOffset = struct[10] * 60 + struct[11];\n if (struct[9] === '+') minutesOffset = 0 - minutesOffset;\n }\n\n timestamp = Date.UTC(struct[1], struct[2], struct[3], struct[4], struct[5] + minutesOffset, struct[6], struct[7]);\n }\n } else timestamp = Date.parse ? Date.parse(date) : NaN;\n\n return timestamp;\n}","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport has from 'lodash/has';\nimport snakeCase from 'lodash/snakeCase';\nimport camelCase from 'lodash/camelCase';\nimport mapKeys from 'lodash/mapKeys';\nimport mapValues from 'lodash/mapValues';\nimport { getter } from 'property-expr';\nimport { object as locale } from './locale';\nimport sortFields from './util/sortFields';\nimport sortByKeyOrder from './util/sortByKeyOrder';\nimport runTests from './util/runTests';\nimport ValidationError from './ValidationError';\nimport BaseSchema from './schema';\n\nlet isObject = obj => Object.prototype.toString.call(obj) === '[object Object]';\n\nfunction unknown(ctx, value) {\n let known = Object.keys(ctx.fields);\n return Object.keys(value).filter(key => known.indexOf(key) === -1);\n}\n\nconst defaultSort = sortByKeyOrder([]);\nexport default class ObjectSchema extends BaseSchema {\n constructor(spec) {\n super({\n type: 'object'\n });\n this.fields = Object.create(null);\n this._sortErrors = defaultSort;\n this._nodes = [];\n this._excludedEdges = [];\n this.withMutation(() => {\n this.transform(function coerce(value) {\n if (typeof value === 'string') {\n try {\n value = JSON.parse(value);\n } catch (err) {\n value = null;\n }\n }\n\n if (this.isType(value)) return value;\n return null;\n });\n\n if (spec) {\n this.shape(spec);\n }\n });\n }\n\n _typeCheck(value) {\n return isObject(value) || typeof value === 'function';\n }\n\n _cast(_value, options = {}) {\n var _options$stripUnknown;\n\n let value = super._cast(_value, options); //should ignore nulls here\n\n\n if (value === undefined) return this.getDefault();\n if (!this._typeCheck(value)) return value;\n let fields = this.fields;\n let strip = (_options$stripUnknown = options.stripUnknown) != null ? _options$stripUnknown : this.spec.noUnknown;\n\n let props = this._nodes.concat(Object.keys(value).filter(v => this._nodes.indexOf(v) === -1));\n\n let intermediateValue = {}; // is filled during the transform below\n\n let innerOptions = _extends({}, options, {\n parent: intermediateValue,\n __validating: options.__validating || false\n });\n\n let isChanged = false;\n\n for (const prop of props) {\n let field = fields[prop];\n let exists = has(value, prop);\n\n if (field) {\n let fieldValue;\n let inputValue = value[prop]; // safe to mutate since this is fired in sequence\n\n innerOptions.path = (options.path ? `${options.path}.` : '') + prop; // innerOptions.value = value[prop];\n\n field = field.resolve({\n value: inputValue,\n context: options.context,\n parent: intermediateValue\n });\n let fieldSpec = 'spec' in field ? field.spec : undefined;\n let strict = fieldSpec == null ? void 0 : fieldSpec.strict;\n\n if (fieldSpec == null ? void 0 : fieldSpec.strip) {\n isChanged = isChanged || prop in value;\n continue;\n }\n\n fieldValue = !options.__validating || !strict ? // TODO: use _cast, this is double resolving\n field.cast(value[prop], innerOptions) : value[prop];\n\n if (fieldValue !== undefined) {\n intermediateValue[prop] = fieldValue;\n }\n } else if (exists && !strip) {\n intermediateValue[prop] = value[prop];\n }\n\n if (intermediateValue[prop] !== value[prop]) {\n isChanged = true;\n }\n }\n\n return isChanged ? intermediateValue : value;\n }\n\n _validate(_value, opts = {}, callback) {\n let errors = [];\n let {\n sync,\n from = [],\n originalValue = _value,\n abortEarly = this.spec.abortEarly,\n recursive = this.spec.recursive\n } = opts;\n from = [{\n schema: this,\n value: originalValue\n }, ...from]; // this flag is needed for handling `strict` correctly in the context of\n // validation vs just casting. e.g strict() on a field is only used when validating\n\n opts.__validating = true;\n opts.originalValue = originalValue;\n opts.from = from;\n\n super._validate(_value, opts, (err, value) => {\n if (err) {\n if (!ValidationError.isError(err) || abortEarly) {\n return void callback(err, value);\n }\n\n errors.push(err);\n }\n\n if (!recursive || !isObject(value)) {\n callback(errors[0] || null, value);\n return;\n }\n\n originalValue = originalValue || value;\n\n let tests = this._nodes.map(key => (_, cb) => {\n let path = key.indexOf('.') === -1 ? (opts.path ? `${opts.path}.` : '') + key : `${opts.path || ''}[\"${key}\"]`;\n let field = this.fields[key];\n\n if (field && 'validate' in field) {\n field.validate(value[key], _extends({}, opts, {\n // @ts-ignore\n path,\n from,\n // inner fields are always strict:\n // 1. this isn't strict so the casting will also have cast inner values\n // 2. this is strict in which case the nested values weren't cast either\n strict: true,\n parent: value,\n originalValue: originalValue[key]\n }), cb);\n return;\n }\n\n cb(null);\n });\n\n runTests({\n sync,\n tests,\n value,\n errors,\n endEarly: abortEarly,\n sort: this._sortErrors,\n path: opts.path\n }, callback);\n });\n }\n\n clone(spec) {\n const next = super.clone(spec);\n next.fields = _extends({}, this.fields);\n next._nodes = this._nodes;\n next._excludedEdges = this._excludedEdges;\n next._sortErrors = this._sortErrors;\n return next;\n }\n\n concat(schema) {\n let next = super.concat(schema);\n let nextFields = next.fields;\n\n for (let [field, schemaOrRef] of Object.entries(this.fields)) {\n const target = nextFields[field];\n\n if (target === undefined) {\n nextFields[field] = schemaOrRef;\n } else if (target instanceof BaseSchema && schemaOrRef instanceof BaseSchema) {\n nextFields[field] = schemaOrRef.concat(target);\n }\n }\n\n return next.withMutation(() => next.shape(nextFields, this._excludedEdges));\n }\n\n getDefaultFromShape() {\n let dft = {};\n\n this._nodes.forEach(key => {\n const field = this.fields[key];\n dft[key] = 'default' in field ? field.getDefault() : undefined;\n });\n\n return dft;\n }\n\n _getDefault() {\n if ('default' in this.spec) {\n return super._getDefault();\n } // if there is no default set invent one\n\n\n if (!this._nodes.length) {\n return undefined;\n }\n\n return this.getDefaultFromShape();\n }\n\n shape(additions, excludes = []) {\n let next = this.clone();\n let fields = Object.assign(next.fields, additions);\n next.fields = fields;\n next._sortErrors = sortByKeyOrder(Object.keys(fields));\n\n if (excludes.length) {\n // this is a convenience for when users only supply a single pair\n if (!Array.isArray(excludes[0])) excludes = [excludes];\n next._excludedEdges = [...next._excludedEdges, ...excludes];\n }\n\n next._nodes = sortFields(fields, next._excludedEdges);\n return next;\n }\n\n pick(keys) {\n const picked = {};\n\n for (const key of keys) {\n if (this.fields[key]) picked[key] = this.fields[key];\n }\n\n return this.clone().withMutation(next => {\n next.fields = {};\n return next.shape(picked);\n });\n }\n\n omit(keys) {\n const next = this.clone();\n const fields = next.fields;\n next.fields = {};\n\n for (const key of keys) {\n delete fields[key];\n }\n\n return next.withMutation(() => next.shape(fields));\n }\n\n from(from, to, alias) {\n let fromGetter = getter(from, true);\n return this.transform(obj => {\n if (obj == null) return obj;\n let newObj = obj;\n\n if (has(obj, from)) {\n newObj = _extends({}, obj);\n if (!alias) delete newObj[from];\n newObj[to] = fromGetter(obj);\n }\n\n return newObj;\n });\n }\n\n noUnknown(noAllow = true, message = locale.noUnknown) {\n if (typeof noAllow === 'string') {\n message = noAllow;\n noAllow = true;\n }\n\n let next = this.test({\n name: 'noUnknown',\n exclusive: true,\n message: message,\n\n test(value) {\n if (value == null) return true;\n const unknownKeys = unknown(this.schema, value);\n return !noAllow || unknownKeys.length === 0 || this.createError({\n params: {\n unknown: unknownKeys.join(', ')\n }\n });\n }\n\n });\n next.spec.noUnknown = noAllow;\n return next;\n }\n\n unknown(allow = true, message = locale.noUnknown) {\n return this.noUnknown(!allow, message);\n }\n\n transformKeys(fn) {\n return this.transform(obj => obj && mapKeys(obj, (_, key) => fn(key)));\n }\n\n camelCase() {\n return this.transformKeys(camelCase);\n }\n\n snakeCase() {\n return this.transformKeys(snakeCase);\n }\n\n constantCase() {\n return this.transformKeys(key => snakeCase(key).toUpperCase());\n }\n\n describe() {\n let base = super.describe();\n base.fields = mapValues(this.fields, value => value.describe());\n return base;\n }\n\n}\nexport function create(spec) {\n return new ObjectSchema(spec);\n}\ncreate.prototype = ObjectSchema.prototype;","var createCompounder = require('./_createCompounder');\n\n/**\n * Converts `string` to\n * [snake case](https://en.wikipedia.org/wiki/Snake_case).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the snake cased string.\n * @example\n *\n * _.snakeCase('Foo Bar');\n * // => 'foo_bar'\n *\n * _.snakeCase('fooBar');\n * // => 'foo_bar'\n *\n * _.snakeCase('--FOO-BAR--');\n * // => 'foo_bar'\n */\nvar snakeCase = createCompounder(function(result, word, index) {\n return result + (index ? '_' : '') + word.toLowerCase();\n});\n\nmodule.exports = snakeCase;\n","var arrayReduce = require('./_arrayReduce'),\n deburr = require('./deburr'),\n words = require('./words');\n\n/** Used to compose unicode capture groups. */\nvar rsApos = \"['\\u2019]\";\n\n/** Used to match apostrophes. */\nvar reApos = RegExp(rsApos, 'g');\n\n/**\n * Creates a function like `_.camelCase`.\n *\n * @private\n * @param {Function} callback The function to combine each word.\n * @returns {Function} Returns the new compounder function.\n */\nfunction createCompounder(callback) {\n return function(string) {\n return arrayReduce(words(deburr(string).replace(reApos, '')), callback, '');\n };\n}\n\nmodule.exports = createCompounder;\n","/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n if (initAccum && length) {\n accumulator = array[++index];\n }\n while (++index < length) {\n accumulator = iteratee(accumulator, array[index], index, array);\n }\n return accumulator;\n}\n\nmodule.exports = arrayReduce;\n","var deburrLetter = require('./_deburrLetter'),\n toString = require('./toString');\n\n/** Used to match Latin Unicode letters (excluding mathematical operators). */\nvar reLatin = /[\\xc0-\\xd6\\xd8-\\xf6\\xf8-\\xff\\u0100-\\u017f]/g;\n\n/** Used to compose unicode character classes. */\nvar rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange;\n\n/** Used to compose unicode capture groups. */\nvar rsCombo = '[' + rsComboRange + ']';\n\n/**\n * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and\n * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).\n */\nvar reComboMark = RegExp(rsCombo, 'g');\n\n/**\n * Deburrs `string` by converting\n * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)\n * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)\n * letters to basic Latin letters and removing\n * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to deburr.\n * @returns {string} Returns the deburred string.\n * @example\n *\n * _.deburr('déjà vu');\n * // => 'deja vu'\n */\nfunction deburr(string) {\n string = toString(string);\n return string && string.replace(reLatin, deburrLetter).replace(reComboMark, '');\n}\n\nmodule.exports = deburr;\n","var basePropertyOf = require('./_basePropertyOf');\n\n/** Used to map Latin Unicode letters to basic Latin letters. */\nvar deburredLetters = {\n // Latin-1 Supplement block.\n '\\xc0': 'A', '\\xc1': 'A', '\\xc2': 'A', '\\xc3': 'A', '\\xc4': 'A', '\\xc5': 'A',\n '\\xe0': 'a', '\\xe1': 'a', '\\xe2': 'a', '\\xe3': 'a', '\\xe4': 'a', '\\xe5': 'a',\n '\\xc7': 'C', '\\xe7': 'c',\n '\\xd0': 'D', '\\xf0': 'd',\n '\\xc8': 'E', '\\xc9': 'E', '\\xca': 'E', '\\xcb': 'E',\n '\\xe8': 'e', '\\xe9': 'e', '\\xea': 'e', '\\xeb': 'e',\n '\\xcc': 'I', '\\xcd': 'I', '\\xce': 'I', '\\xcf': 'I',\n '\\xec': 'i', '\\xed': 'i', '\\xee': 'i', '\\xef': 'i',\n '\\xd1': 'N', '\\xf1': 'n',\n '\\xd2': 'O', '\\xd3': 'O', '\\xd4': 'O', '\\xd5': 'O', '\\xd6': 'O', '\\xd8': 'O',\n '\\xf2': 'o', '\\xf3': 'o', '\\xf4': 'o', '\\xf5': 'o', '\\xf6': 'o', '\\xf8': 'o',\n '\\xd9': 'U', '\\xda': 'U', '\\xdb': 'U', '\\xdc': 'U',\n '\\xf9': 'u', '\\xfa': 'u', '\\xfb': 'u', '\\xfc': 'u',\n '\\xdd': 'Y', '\\xfd': 'y', '\\xff': 'y',\n '\\xc6': 'Ae', '\\xe6': 'ae',\n '\\xde': 'Th', '\\xfe': 'th',\n '\\xdf': 'ss',\n // Latin Extended-A block.\n '\\u0100': 'A', '\\u0102': 'A', '\\u0104': 'A',\n '\\u0101': 'a', '\\u0103': 'a', '\\u0105': 'a',\n '\\u0106': 'C', '\\u0108': 'C', '\\u010a': 'C', '\\u010c': 'C',\n '\\u0107': 'c', '\\u0109': 'c', '\\u010b': 'c', '\\u010d': 'c',\n '\\u010e': 'D', '\\u0110': 'D', '\\u010f': 'd', '\\u0111': 'd',\n '\\u0112': 'E', '\\u0114': 'E', '\\u0116': 'E', '\\u0118': 'E', '\\u011a': 'E',\n '\\u0113': 'e', '\\u0115': 'e', '\\u0117': 'e', '\\u0119': 'e', '\\u011b': 'e',\n '\\u011c': 'G', '\\u011e': 'G', '\\u0120': 'G', '\\u0122': 'G',\n '\\u011d': 'g', '\\u011f': 'g', '\\u0121': 'g', '\\u0123': 'g',\n '\\u0124': 'H', '\\u0126': 'H', '\\u0125': 'h', '\\u0127': 'h',\n '\\u0128': 'I', '\\u012a': 'I', '\\u012c': 'I', '\\u012e': 'I', '\\u0130': 'I',\n '\\u0129': 'i', '\\u012b': 'i', '\\u012d': 'i', '\\u012f': 'i', '\\u0131': 'i',\n '\\u0134': 'J', '\\u0135': 'j',\n '\\u0136': 'K', '\\u0137': 'k', '\\u0138': 'k',\n '\\u0139': 'L', '\\u013b': 'L', '\\u013d': 'L', '\\u013f': 'L', '\\u0141': 'L',\n '\\u013a': 'l', '\\u013c': 'l', '\\u013e': 'l', '\\u0140': 'l', '\\u0142': 'l',\n '\\u0143': 'N', '\\u0145': 'N', '\\u0147': 'N', '\\u014a': 'N',\n '\\u0144': 'n', '\\u0146': 'n', '\\u0148': 'n', '\\u014b': 'n',\n '\\u014c': 'O', '\\u014e': 'O', '\\u0150': 'O',\n '\\u014d': 'o', '\\u014f': 'o', '\\u0151': 'o',\n '\\u0154': 'R', '\\u0156': 'R', '\\u0158': 'R',\n '\\u0155': 'r', '\\u0157': 'r', '\\u0159': 'r',\n '\\u015a': 'S', '\\u015c': 'S', '\\u015e': 'S', '\\u0160': 'S',\n '\\u015b': 's', '\\u015d': 's', '\\u015f': 's', '\\u0161': 's',\n '\\u0162': 'T', '\\u0164': 'T', '\\u0166': 'T',\n '\\u0163': 't', '\\u0165': 't', '\\u0167': 't',\n '\\u0168': 'U', '\\u016a': 'U', '\\u016c': 'U', '\\u016e': 'U', '\\u0170': 'U', '\\u0172': 'U',\n '\\u0169': 'u', '\\u016b': 'u', '\\u016d': 'u', '\\u016f': 'u', '\\u0171': 'u', '\\u0173': 'u',\n '\\u0174': 'W', '\\u0175': 'w',\n '\\u0176': 'Y', '\\u0177': 'y', '\\u0178': 'Y',\n '\\u0179': 'Z', '\\u017b': 'Z', '\\u017d': 'Z',\n '\\u017a': 'z', '\\u017c': 'z', '\\u017e': 'z',\n '\\u0132': 'IJ', '\\u0133': 'ij',\n '\\u0152': 'Oe', '\\u0153': 'oe',\n '\\u0149': \"'n\", '\\u017f': 's'\n};\n\n/**\n * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A\n * letters to basic Latin letters.\n *\n * @private\n * @param {string} letter The matched letter to deburr.\n * @returns {string} Returns the deburred letter.\n */\nvar deburrLetter = basePropertyOf(deburredLetters);\n\nmodule.exports = deburrLetter;\n","/**\n * The base implementation of `_.propertyOf` without support for deep paths.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyOf(object) {\n return function(key) {\n return object == null ? undefined : object[key];\n };\n}\n\nmodule.exports = basePropertyOf;\n","var asciiWords = require('./_asciiWords'),\n hasUnicodeWord = require('./_hasUnicodeWord'),\n toString = require('./toString'),\n unicodeWords = require('./_unicodeWords');\n\n/**\n * Splits `string` into an array of its words.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {RegExp|string} [pattern] The pattern to match words.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the words of `string`.\n * @example\n *\n * _.words('fred, barney, & pebbles');\n * // => ['fred', 'barney', 'pebbles']\n *\n * _.words('fred, barney, & pebbles', /[^, ]+/g);\n * // => ['fred', 'barney', '&', 'pebbles']\n */\nfunction words(string, pattern, guard) {\n string = toString(string);\n pattern = guard ? undefined : pattern;\n\n if (pattern === undefined) {\n return hasUnicodeWord(string) ? unicodeWords(string) : asciiWords(string);\n }\n return string.match(pattern) || [];\n}\n\nmodule.exports = words;\n","/** Used to match words composed of alphanumeric characters. */\nvar reAsciiWord = /[^\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\x7f]+/g;\n\n/**\n * Splits an ASCII `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\nfunction asciiWords(string) {\n return string.match(reAsciiWord) || [];\n}\n\nmodule.exports = asciiWords;\n","/** Used to detect strings that need a more robust regexp to match words. */\nvar reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;\n\n/**\n * Checks if `string` contains a word composed of Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a word is found, else `false`.\n */\nfunction hasUnicodeWord(string) {\n return reHasUnicodeWord.test(string);\n}\n\nmodule.exports = hasUnicodeWord;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsDingbatRange = '\\\\u2700-\\\\u27bf',\n rsLowerRange = 'a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff',\n rsMathOpRange = '\\\\xac\\\\xb1\\\\xd7\\\\xf7',\n rsNonCharRange = '\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf',\n rsPunctuationRange = '\\\\u2000-\\\\u206f',\n rsSpaceRange = ' \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000',\n rsUpperRange = 'A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde',\n rsVarRange = '\\\\ufe0e\\\\ufe0f',\n rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange;\n\n/** Used to compose unicode capture groups. */\nvar rsApos = \"['\\u2019]\",\n rsBreak = '[' + rsBreakRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsDigits = '\\\\d+',\n rsDingbat = '[' + rsDingbatRange + ']',\n rsLower = '[' + rsLowerRange + ']',\n rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsUpper = '[' + rsUpperRange + ']',\n rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar rsMiscLower = '(?:' + rsLower + '|' + rsMisc + ')',\n rsMiscUpper = '(?:' + rsUpper + '|' + rsMisc + ')',\n rsOptContrLower = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?',\n rsOptContrUpper = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?',\n reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsOrdLower = '\\\\d*(?:1st|2nd|3rd|(?![123])\\\\dth)(?=\\\\b|[A-Z_])',\n rsOrdUpper = '\\\\d*(?:1ST|2ND|3RD|(?![123])\\\\dTH)(?=\\\\b|[a-z_])',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq;\n\n/** Used to match complex or compound words. */\nvar reUnicodeWord = RegExp([\n rsUpper + '?' + rsLower + '+' + rsOptContrLower + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')',\n rsMiscUpper + '+' + rsOptContrUpper + '(?=' + [rsBreak, rsUpper + rsMiscLower, '$'].join('|') + ')',\n rsUpper + '?' + rsMiscLower + '+' + rsOptContrLower,\n rsUpper + '+' + rsOptContrUpper,\n rsOrdUpper,\n rsOrdLower,\n rsDigits,\n rsEmoji\n].join('|'), 'g');\n\n/**\n * Splits a Unicode `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\nfunction unicodeWords(string) {\n return string.match(reUnicodeWord) || [];\n}\n\nmodule.exports = unicodeWords;\n","var capitalize = require('./capitalize'),\n createCompounder = require('./_createCompounder');\n\n/**\n * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the camel cased string.\n * @example\n *\n * _.camelCase('Foo Bar');\n * // => 'fooBar'\n *\n * _.camelCase('--foo-bar--');\n * // => 'fooBar'\n *\n * _.camelCase('__FOO_BAR__');\n * // => 'fooBar'\n */\nvar camelCase = createCompounder(function(result, word, index) {\n word = word.toLowerCase();\n return result + (index ? capitalize(word) : word);\n});\n\nmodule.exports = camelCase;\n","var toString = require('./toString'),\n upperFirst = require('./upperFirst');\n\n/**\n * Converts the first character of `string` to upper case and the remaining\n * to lower case.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to capitalize.\n * @returns {string} Returns the capitalized string.\n * @example\n *\n * _.capitalize('FRED');\n * // => 'Fred'\n */\nfunction capitalize(string) {\n return upperFirst(toString(string).toLowerCase());\n}\n\nmodule.exports = capitalize;\n","var createCaseFirst = require('./_createCaseFirst');\n\n/**\n * Converts the first character of `string` to upper case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.upperFirst('fred');\n * // => 'Fred'\n *\n * _.upperFirst('FRED');\n * // => 'FRED'\n */\nvar upperFirst = createCaseFirst('toUpperCase');\n\nmodule.exports = upperFirst;\n","var castSlice = require('./_castSlice'),\n hasUnicode = require('./_hasUnicode'),\n stringToArray = require('./_stringToArray'),\n toString = require('./toString');\n\n/**\n * Creates a function like `_.lowerFirst`.\n *\n * @private\n * @param {string} methodName The name of the `String` case method to use.\n * @returns {Function} Returns the new case function.\n */\nfunction createCaseFirst(methodName) {\n return function(string) {\n string = toString(string);\n\n var strSymbols = hasUnicode(string)\n ? stringToArray(string)\n : undefined;\n\n var chr = strSymbols\n ? strSymbols[0]\n : string.charAt(0);\n\n var trailing = strSymbols\n ? castSlice(strSymbols, 1).join('')\n : string.slice(1);\n\n return chr[methodName]() + trailing;\n };\n}\n\nmodule.exports = createCaseFirst;\n","var baseSlice = require('./_baseSlice');\n\n/**\n * Casts `array` to a slice if it's needed.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {number} start The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the cast slice.\n */\nfunction castSlice(array, start, end) {\n var length = array.length;\n end = end === undefined ? length : end;\n return (!start && end >= length) ? array : baseSlice(array, start, end);\n}\n\nmodule.exports = castSlice;\n","/**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n}\n\nmodule.exports = baseSlice;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsZWJ = '\\\\u200d';\n\n/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\nvar reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n\n/**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\nfunction hasUnicode(string) {\n return reHasUnicode.test(string);\n}\n\nmodule.exports = hasUnicode;\n","var asciiToArray = require('./_asciiToArray'),\n hasUnicode = require('./_hasUnicode'),\n unicodeToArray = require('./_unicodeToArray');\n\n/**\n * Converts `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction stringToArray(string) {\n return hasUnicode(string)\n ? unicodeToArray(string)\n : asciiToArray(string);\n}\n\nmodule.exports = stringToArray;\n","/**\n * Converts an ASCII `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction asciiToArray(string) {\n return string.split('');\n}\n\nmodule.exports = asciiToArray;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsAstral = '[' + rsAstralRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n/**\n * Converts a Unicode `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction unicodeToArray(string) {\n return string.match(reUnicode) || [];\n}\n\nmodule.exports = unicodeToArray;\n","var baseAssignValue = require('./_baseAssignValue'),\n baseForOwn = require('./_baseForOwn'),\n baseIteratee = require('./_baseIteratee');\n\n/**\n * The opposite of `_.mapValues`; this method creates an object with the\n * same values as `object` and keys generated by running each own enumerable\n * string keyed property of `object` thru `iteratee`. The iteratee is invoked\n * with three arguments: (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapValues\n * @example\n *\n * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) {\n * return key + value;\n * });\n * // => { 'a1': 1, 'b2': 2 }\n */\nfunction mapKeys(object, iteratee) {\n var result = {};\n iteratee = baseIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, iteratee(value, key, object), value);\n });\n return result;\n}\n\nmodule.exports = mapKeys;\n","import has from 'lodash/has'; // @ts-expect-error\n\nimport toposort from 'toposort';\nimport { split } from 'property-expr';\nimport Ref from '../Reference';\nimport isSchema from './isSchema';\nexport default function sortFields(fields, excludedEdges = []) {\n let edges = [];\n let nodes = new Set();\n let excludes = new Set(excludedEdges.map(([a, b]) => `${a}-${b}`));\n\n function addNode(depPath, key) {\n let node = split(depPath)[0];\n nodes.add(node);\n if (!excludes.has(`${key}-${node}`)) edges.push([key, node]);\n }\n\n for (const key in fields) if (has(fields, key)) {\n let value = fields[key];\n nodes.add(key);\n if (Ref.isRef(value) && value.isSibling) addNode(value.path, key);else if (isSchema(value) && 'deps' in value) value.deps.forEach(path => addNode(path, key));\n }\n\n return toposort.array(Array.from(nodes), edges).reverse();\n}","\n/**\n * Topological sorting function\n *\n * @param {Array} edges\n * @returns {Array}\n */\n\nmodule.exports = function(edges) {\n return toposort(uniqueNodes(edges), edges)\n}\n\nmodule.exports.array = toposort\n\nfunction toposort(nodes, edges) {\n var cursor = nodes.length\n , sorted = new Array(cursor)\n , visited = {}\n , i = cursor\n // Better data structures make algorithm much faster.\n , outgoingEdges = makeOutgoingEdges(edges)\n , nodesHash = makeNodesHash(nodes)\n\n // check for unknown nodes\n edges.forEach(function(edge) {\n if (!nodesHash.has(edge[0]) || !nodesHash.has(edge[1])) {\n throw new Error('Unknown node. There is an unknown node in the supplied edges.')\n }\n })\n\n while (i--) {\n if (!visited[i]) visit(nodes[i], i, new Set())\n }\n\n return sorted\n\n function visit(node, i, predecessors) {\n if(predecessors.has(node)) {\n var nodeRep\n try {\n nodeRep = \", node was:\" + JSON.stringify(node)\n } catch(e) {\n nodeRep = \"\"\n }\n throw new Error('Cyclic dependency' + nodeRep)\n }\n\n if (!nodesHash.has(node)) {\n throw new Error('Found unknown node. Make sure to provided all involved nodes. Unknown node: '+JSON.stringify(node))\n }\n\n if (visited[i]) return;\n visited[i] = true\n\n var outgoing = outgoingEdges.get(node) || new Set()\n outgoing = Array.from(outgoing)\n\n if (i = outgoing.length) {\n predecessors.add(node)\n do {\n var child = outgoing[--i]\n visit(child, nodesHash.get(child), predecessors)\n } while (i)\n predecessors.delete(node)\n }\n\n sorted[--cursor] = node\n }\n}\n\nfunction uniqueNodes(arr){\n var res = new Set()\n for (var i = 0, len = arr.length; i < len; i++) {\n var edge = arr[i]\n res.add(edge[0])\n res.add(edge[1])\n }\n return Array.from(res)\n}\n\nfunction makeOutgoingEdges(arr){\n var edges = new Map()\n for (var i = 0, len = arr.length; i < len; i++) {\n var edge = arr[i]\n if (!edges.has(edge[0])) edges.set(edge[0], new Set())\n if (!edges.has(edge[1])) edges.set(edge[1], new Set())\n edges.get(edge[0]).add(edge[1])\n }\n return edges\n}\n\nfunction makeNodesHash(arr){\n var res = new Map()\n for (var i = 0, len = arr.length; i < len; i++) {\n res.set(arr[i], i)\n }\n return res\n}\n","function findIndex(arr, err) {\n let idx = Infinity;\n arr.some((key, ii) => {\n var _err$path;\n\n if (((_err$path = err.path) == null ? void 0 : _err$path.indexOf(key)) !== -1) {\n idx = ii;\n return true;\n }\n });\n return idx;\n}\n\nexport default function sortByKeyOrder(keys) {\n return (a, b) => {\n return findIndex(keys, a) - findIndex(keys, b);\n };\n}","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport isAbsent from './util/isAbsent';\nimport isSchema from './util/isSchema';\nimport printValue from './util/printValue';\nimport { array as locale } from './locale';\nimport runTests from './util/runTests';\nimport ValidationError from './ValidationError';\nimport BaseSchema from './schema';\nexport function create(type) {\n return new ArraySchema(type);\n}\nexport default class ArraySchema extends BaseSchema {\n constructor(type) {\n super({\n type: 'array'\n }); // `undefined` specifically means uninitialized, as opposed to\n // \"no subtype\"\n\n this.innerType = void 0;\n this.innerType = type;\n this.withMutation(() => {\n this.transform(function (values) {\n if (typeof values === 'string') try {\n values = JSON.parse(values);\n } catch (err) {\n values = null;\n }\n return this.isType(values) ? values : null;\n });\n });\n }\n\n _typeCheck(v) {\n return Array.isArray(v);\n }\n\n get _subType() {\n return this.innerType;\n }\n\n _cast(_value, _opts) {\n const value = super._cast(_value, _opts); //should ignore nulls here\n\n\n if (!this._typeCheck(value) || !this.innerType) return value;\n let isChanged = false;\n const castArray = value.map((v, idx) => {\n const castElement = this.innerType.cast(v, _extends({}, _opts, {\n path: `${_opts.path || ''}[${idx}]`\n }));\n\n if (castElement !== v) {\n isChanged = true;\n }\n\n return castElement;\n });\n return isChanged ? castArray : value;\n }\n\n _validate(_value, options = {}, callback) {\n var _options$abortEarly, _options$recursive;\n\n let errors = [];\n let sync = options.sync;\n let path = options.path;\n let innerType = this.innerType;\n let endEarly = (_options$abortEarly = options.abortEarly) != null ? _options$abortEarly : this.spec.abortEarly;\n let recursive = (_options$recursive = options.recursive) != null ? _options$recursive : this.spec.recursive;\n let originalValue = options.originalValue != null ? options.originalValue : _value;\n\n super._validate(_value, options, (err, value) => {\n if (err) {\n if (!ValidationError.isError(err) || endEarly) {\n return void callback(err, value);\n }\n\n errors.push(err);\n }\n\n if (!recursive || !innerType || !this._typeCheck(value)) {\n callback(errors[0] || null, value);\n return;\n }\n\n originalValue = originalValue || value; // #950 Ensure that sparse array empty slots are validated\n\n let tests = new Array(value.length);\n\n for (let idx = 0; idx < value.length; idx++) {\n let item = value[idx];\n let path = `${options.path || ''}[${idx}]`; // object._validate note for isStrict explanation\n\n let innerOptions = _extends({}, options, {\n path,\n strict: true,\n parent: value,\n index: idx,\n originalValue: originalValue[idx]\n });\n\n tests[idx] = (_, cb) => innerType.validate(item, innerOptions, cb);\n }\n\n runTests({\n sync,\n path,\n value,\n errors,\n endEarly,\n tests\n }, callback);\n });\n }\n\n clone(spec) {\n const next = super.clone(spec);\n next.innerType = this.innerType;\n return next;\n }\n\n concat(schema) {\n let next = super.concat(schema);\n next.innerType = this.innerType;\n if (schema.innerType) next.innerType = next.innerType ? // @ts-expect-error Lazy doesn't have concat()\n next.innerType.concat(schema.innerType) : schema.innerType;\n return next;\n }\n\n of(schema) {\n // FIXME: this should return a new instance of array without the default to be\n let next = this.clone();\n if (!isSchema(schema)) throw new TypeError('`array.of()` sub-schema must be a valid yup schema not: ' + printValue(schema)); // FIXME(ts):\n\n next.innerType = schema;\n return next;\n }\n\n length(length, message = locale.length) {\n return this.test({\n message,\n name: 'length',\n exclusive: true,\n params: {\n length\n },\n\n test(value) {\n return isAbsent(value) || value.length === this.resolve(length);\n }\n\n });\n }\n\n min(min, message) {\n message = message || locale.min;\n return this.test({\n message,\n name: 'min',\n exclusive: true,\n params: {\n min\n },\n\n // FIXME(ts): Array\n test(value) {\n return isAbsent(value) || value.length >= this.resolve(min);\n }\n\n });\n }\n\n max(max, message) {\n message = message || locale.max;\n return this.test({\n message,\n name: 'max',\n exclusive: true,\n params: {\n max\n },\n\n test(value) {\n return isAbsent(value) || value.length <= this.resolve(max);\n }\n\n });\n }\n\n ensure() {\n return this.default(() => []).transform((val, original) => {\n // We don't want to return `null` for nullable schema\n if (this._typeCheck(val)) return val;\n return original == null ? [] : [].concat(original);\n });\n }\n\n compact(rejector) {\n let reject = !rejector ? v => !!v : (v, i, a) => !rejector(v, i, a);\n return this.transform(values => values != null ? values.filter(reject) : values);\n }\n\n describe() {\n let base = super.describe();\n if (this.innerType) base.innerType = this.innerType.describe();\n return base;\n }\n\n nullable(isNullable = true) {\n return super.nullable(isNullable);\n }\n\n defined() {\n return super.defined();\n }\n\n required(msg) {\n return super.required(msg);\n }\n\n}\ncreate.prototype = ArraySchema.prototype; //\n// Interfaces\n//","import isSchema from './util/isSchema';\nexport function create(builder) {\n return new Lazy(builder);\n}\n\nclass Lazy {\n constructor(builder) {\n this.type = 'lazy';\n this.__isYupSchema__ = true;\n this.__inputType = void 0;\n this.__outputType = void 0;\n\n this._resolve = (value, options = {}) => {\n let schema = this.builder(value, options);\n if (!isSchema(schema)) throw new TypeError('lazy() functions must return a valid schema');\n return schema.resolve(options);\n };\n\n this.builder = builder;\n }\n\n resolve(options) {\n return this._resolve(options.value, options);\n }\n\n cast(value, options) {\n return this._resolve(value, options).cast(value, options);\n }\n\n validate(value, options, maybeCb) {\n // @ts-expect-error missing public callback on type\n return this._resolve(value, options).validate(value, options, maybeCb);\n }\n\n validateSync(value, options) {\n return this._resolve(value, options).validateSync(value, options);\n }\n\n validateAt(path, value, options) {\n return this._resolve(value, options).validateAt(path, value, options);\n }\n\n validateSyncAt(path, value, options) {\n return this._resolve(value, options).validateSyncAt(path, value, options);\n }\n\n describe() {\n return null;\n }\n\n isValid(value, options) {\n return this._resolve(value, options).isValid(value, options);\n }\n\n isValidSync(value, options) {\n return this._resolve(value, options).isValidSync(value, options);\n }\n\n}\n\nexport default Lazy;","import locale from './locale';\nexport default function setLocale(custom) {\n Object.keys(custom).forEach(type => {\n // @ts-ignore\n Object.keys(custom[type]).forEach(method => {\n // @ts-ignore\n locale[type][method] = custom[type][method];\n });\n });\n}","import React, {useEffect, useState} from 'react';\nimport {FormStepper} from \"@common/components/stepper/FormStepper\";\nimport {StatusBar, View} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {connect} from \"react-redux\";\nimport {useApiStatus} from \"@common/hooks/useApiStatus\";\nimport {subscriptionService} from \"@data/services/subscriptionService\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport SuspensionRecap from \"@common/account/SuspensionRecap\";\nimport {ActivityIndicator} from \"react-native-paper\";\nimport TextM from \"@common/components/text/TextM\";\nimport ErrorTextM from \"@common/components/text/ErrorTextM\";\nimport base64 from \"@common/utils/base64\";\nimport SuspensionContinuityInformation from \"@common/account/SubscriptionContinuityInformation\";\nimport moment from \"moment\";\nimport {ChooseSubscriptionOffer} from \"../../auth/SubscribeScreen\";\nimport {isSubscribed} from \"@data/utility/dataUtils\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\n\nconst SubscriptionContinuity = (props) => {\n\n const user = props.route.params?.user ?? \"\"\n const navigation = useNavigation()\n const [formValues, setFormValues] = useState({});\n\n const defaultValues = {}\n const email = base64.decode(user)\n useEffect(() => {\n props.apiRequest(subscriptionService.getSubscribePricing, {}, {}, {\n email,\n continuity: 1\n })\n }, []);\n\n\n const isSubscriptionCanceled = props.subscriptionUser?.subscription_state?.status === \"ended\" || props.subscriptionUser?.subscription_state?.status === \"on_grace_period\"\n const subscriptionEndDate = isSubscriptionCanceled ? moment(props.subscriptionUser?.subscription_state?.end_date) : null\n\n // if subscription end date is between 15 of july and 5 of september, the next product is the holidayworkbook\n const nextProductHolidayWorkbook = subscriptionEndDate?.isValid() && !subscriptionEndDate.isBetween(moment().month(6).date(15), moment().month(8).date(5))\n\n const pricingTableData = props.pricingTableData\n const pricingTableDataNextMode = props.pricingTableDataNextMode\n const commitmentEndDate = props.commitmentEndDate\n const billingPortalUrl = props.billingPortalUrl\n const emailUser = props.user\n\n const formData = [\n {\n label: nextProductHolidayWorkbook ? \"Cet été : cahiers de vacances en live\" : \"Pendant l'année scolaire, l'accompagnement se poursuit !\",\n // description: `Compte élève : ${props.displayName}`,\n type: \"custom\",\n showNextButton: false,\n name: \"information\",\n component: SuspensionContinuityInformation,\n componentProps: {nextProductHolidayWorkbook},\n defaultValue: \"\",\n validationRules: null\n },\n {\n is_masked: nextProductHolidayWorkbook,\n label: \"Choisissez votre offre\", // 1h / semaine à partir de x, 2h / semaine à partir de x, 3h / semaine à partir de x\n description: `Compte élève : ${props.displayName}`,\n type: \"custom\",\n inputs: [\n {\n name: \"product_name\",\n defaultValue: \"essential\"\n },\n {\n name: \"with_commitment\",\n defaultValue: 1\n }\n ],\n component: ChooseSubscriptionOffer,\n componentProps: {\n userEmail: email,\n pricingTableData,\n pricingTableDataNextMode\n },\n defaultValue: \"\",\n validationRules: null\n },\n {\n label: \"Récapitulatif\",\n description: `Compte élève : ${props.displayName}`,\n type: \"custom\",\n showNextButton: false,\n options: [],\n component: SuspensionRecap,\n componentProps: {\n userEmail: email,\n pricingTableData,\n pricingTableDataNextMode,\n commitmentEndDate\n },\n defaultValue: false\n }\n ]\n\n useEffect(() => {\n formData?.forEach(x => {\n if (x?.name)\n defaultValues[x.name] = x.defaultValue\n else if (x?.inputs)\n x?.inputs?.forEach(i => {\n defaultValues[i.name] = i.defaultValue\n })\n })\n\n //console.log(formValues)\n\n }, [formValues])\n\n const onSubmit = data => {\n if (props.suspensionRequest) return\n // console.log(data)\n\n props.apiRequest(subscriptionService.suspendSubscription, {}, {\n ...data,\n \"email\": email\n })\n }\n\n useApiStatus(\n subscriptionService.getSubscribePricing, // api service\n null, // success message on toast (string or null)\n false, // error message on toast (true) or keep it in redux state (false)\n (data) => {\n\n // if user is not subscribed, redirect to main subscribe screen\n if (!isSubscribed(data?.user)) {\n navigation.replace(\"subscribe\", {\n user\n })\n }\n }, // success callback\n (error) => {\n console.log(error)\n }, // error callback\n true\n )\n\n useApiStatus(\n subscriptionService.suspendSubscription, // api service\n null, // success message on toast (string or null)\n false, // error message on toast (true) or keep it in redux state (false)\n (data) => {\n navigation.replace(\"subscribe\", {\n user,\n show_details: 1\n })\n DialogM.show({\n text1: \"Félicitations ! 🎉\",\n text2: \"Votre choix a bien été enregistré. Indiquez maintenant vos choix de matières et d'horaires.\"\n })\n } // success callback\n )\n return (\n \n {/**/}\n {/* */}\n {/* Suite de votre abonnement*/}\n\n {/* */}\n {/**/}\n\n {props.request ? \n : props.error ? \n ERREUR\n \n \n : !x.is_masked)}\n champion={null}\n formValues={formValues}\n setFormValues={setFormValues}\n defaultValues={defaultValues}\n onSubmit={onSubmit}\n submitted={props.suspensionRequest}\n previousRouteName={\"menu\"}\n submittedMessage=\"\"\n serverError={props.suspensionError}\n submitButtonText={\"Je confirme mon choix\"}\n />}\n \n \n )\n};\nconst mapStateToProps = state => {\n return {\n holidayOptions: state.data.formData?.holidayOptions,\n schoolSubjects: state.data.formData?.schoolSubjects,\n nextPaymentDate: state.data.formData?.nextPaymentDate,\n currentValues: state.data.formData?.currentValues,\n displayName: state.data.formData?.user?.display_name,\n remainingDiscounts: state.data.formData?.remainingDiscounts,\n subscriptionUser: state.data.formData?.user,\n discountPercentage: state.data.formData?.discountPercentage,\n request: state.api.getSubscribePricing?.request,\n success: state.api.getSubscribePricing?.success,\n error: state.api.getSubscribePricing?.error,\n suspensionRequest: state.api.suspendSubscription?.request,\n suspensionError: state.api.suspendSubscription?.error,\n user: state.data.formData?.user,\n billingPortalUrl: state.data.formData?.billingPortalUrl,\n pricingTableData: state.data.formData?.pricingTableData,\n pricingTableDataNextMode: state.data.formData?.pricingTableDataNextMode,\n commitmentEndDate: state.data.formData?.commitmentEndDate\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(SubscriptionContinuity)\n","import React, {useContext} from 'react';\nimport {Platform, ScrollView, View} from \"react-native\";\nimport TextM from \"@common/components/text/TextM\";\nimport {theme} from \"@common/theme/theme\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport moment from \"moment\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport LinkTextM from \"@common/components/text/LinkTextM\";\nimport {Text} from \"react-native-paper\";\nimport {PriceDataHeaderM} from \"../../auth/PricingColumnM\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\n\nconst SuspensionRecap = (props) => {\n const {\n control,\n goToNextStep,\n register,\n errors,\n serverError,\n setFormValues,\n field,\n pricingTableData,\n pricingTableDataNextMode,\n commitmentEndDate\n } = props\n\n const isSubscriptionCanceled = props.subscriptionUser?.subscription_state?.status === \"ended\" || props.subscriptionUser?.subscription_state?.status === \"on_grace_period\"\n\n const dimensions = useContext(DimensionsContext)\n\n const data = pricingTableData?.find(x => x?.product_name === control._formValues.product_name)\n const withCommitment = control._formValues.with_commitment\n\n return <>\n \n \n\n {/* Formule choisie section */}\n Offre choisie\n \n \n {data?.product_period_end}.\n Puis :\n \n \n Prélèvement automatique le 1er\n du mois.\n\n {/* Precisions section */}\n Précisions\n Juste après avoir confirmé votre choix, vous pourrez préciser les matières et\n horaires que vous souhaitez.\n\n \n En confirmant, vous acceptez les Conditions générales\n d'utilisation et la Politique de\n confidentialité, ainsi que les Conditions\n générales\n de vente de Masteur\n \n\n \n 800 ? dimensions.width / 1.2 : dimensions.width - 20,\n alignSelf: 'center',\n marginTop: Platform.OS !== 'web' ? null : 15,\n marginBottom: Platform.OS !== 'web' ? null : 15\n // bottom: 15\n }}\n label={\"Je confirme mon choix\"}/>\n \n \n};\nconst mapStateToProps = state => {\n return {\n holidayOptions: state.data.formData?.holidayOptions,\n daysBeforePayment: state.data.formData?.daysBeforePayment,\n discountPercentage: state.data.formData?.discountPercentage,\n remainingDiscounts: state.data.formData?.remainingDiscounts,\n subscriptionUser: state.data.formData?.user\n }\n}\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(SuspensionRecap)","import React from 'react';\nimport {Text} from \"react-native-paper\";\nimport {theme} from \"../../theme/theme\";\nimport * as WebBrowser from 'expo-web-browser';\n\nconst LinkTextM = (props) => {\n\n const {url, onPress, children, style} = props\n\n return {\n if (url) WebBrowser.openBrowserAsync(url)\n else onPress()\n }}\n style={{\n color: theme.colors.primary,\n fontFamily: \"Montserrat-SemiBold\",\n ...style\n }}>\n {children}\n \n}\n\nexport default LinkTextM","import { UnavailabilityError } from 'expo-modules-core';\nimport { AppState, Linking, Platform, processColor, } from 'react-native';\nimport ExponentWebBrowser from './ExpoWebBrowser';\nimport { WebBrowserResultType, WebBrowserPresentationStyle, } from './WebBrowser.types';\nexport { WebBrowserResultType, WebBrowserPresentationStyle, };\nconst emptyCustomTabsPackages = {\n defaultBrowserPackage: undefined,\n preferredBrowserPackage: undefined,\n browserPackages: [],\n servicePackages: [],\n};\n// @needsAudit\n/**\n * Returns a list of applications package names supporting Custom Tabs, Custom Tabs\n * service, user chosen and preferred one. This may not be fully reliable, since it uses\n * `PackageManager.getResolvingActivities` under the hood. (For example, some browsers might not be\n * present in browserPackages list once another browser is set to default.)\n *\n * @return The promise which fulfils with [`WebBrowserCustomTabsResults`](#webbrowsercustomtabsresults) object.\n * @platform android\n */\nexport async function getCustomTabsSupportingBrowsersAsync() {\n if (!ExponentWebBrowser.getCustomTabsSupportingBrowsersAsync) {\n throw new UnavailabilityError('WebBrowser', 'getCustomTabsSupportingBrowsersAsync');\n }\n if (Platform.OS !== 'android') {\n return emptyCustomTabsPackages;\n }\n else {\n return await ExponentWebBrowser.getCustomTabsSupportingBrowsersAsync();\n }\n}\n// @needsAudit\n/**\n * This method calls `warmUp` method on [CustomTabsClient](https://developer.android.com/reference/android/support/customtabs/CustomTabsClient.html#warmup(long))\n * for specified package.\n *\n * @param browserPackage Package of browser to be warmed up. If not set, preferred browser will be warmed.\n *\n * @return A promise which fulfils with `WebBrowserWarmUpResult` object.\n * @platform android\n */\nexport async function warmUpAsync(browserPackage) {\n if (!ExponentWebBrowser.warmUpAsync) {\n throw new UnavailabilityError('WebBrowser', 'warmUpAsync');\n }\n if (Platform.OS !== 'android') {\n return {};\n }\n else {\n return await ExponentWebBrowser.warmUpAsync(browserPackage);\n }\n}\n// @needsAudit\n/**\n * This method initiates (if needed) [CustomTabsSession](https://developer.android.com/reference/android/support/customtabs/CustomTabsSession.html#maylaunchurl)\n * and calls its `mayLaunchUrl` method for browser specified by the package.\n *\n * @param url The url of page that is likely to be loaded first when opening browser.\n * @param browserPackage Package of browser to be informed. If not set, preferred\n * browser will be used.\n *\n * @return A promise which fulfils with `WebBrowserMayInitWithUrlResult` object.\n * @platform android\n */\nexport async function mayInitWithUrlAsync(url, browserPackage) {\n if (!ExponentWebBrowser.mayInitWithUrlAsync) {\n throw new UnavailabilityError('WebBrowser', 'mayInitWithUrlAsync');\n }\n if (Platform.OS !== 'android') {\n return {};\n }\n else {\n return await ExponentWebBrowser.mayInitWithUrlAsync(url, browserPackage);\n }\n}\n// @needsAudit\n/**\n * This methods removes all bindings to services created by [`warmUpAsync`](#webbrowserwarmupasyncbrowserpackage)\n * or [`mayInitWithUrlAsync`](#webbrowsermayinitwithurlasyncurl-browserpackage). You should call\n * this method once you don't need them to avoid potential memory leaks. However, those binding\n * would be cleared once your application is destroyed, which might be sufficient in most cases.\n *\n * @param browserPackage Package of browser to be cooled. If not set, preferred browser will be used.\n *\n * @return The promise which fulfils with ` WebBrowserCoolDownResult` when cooling is performed, or\n * an empty object when there was no connection to be dismissed.\n * @platform android\n */\nexport async function coolDownAsync(browserPackage) {\n if (!ExponentWebBrowser.coolDownAsync) {\n throw new UnavailabilityError('WebBrowser', 'coolDownAsync');\n }\n if (Platform.OS !== 'android') {\n return {};\n }\n else {\n return await ExponentWebBrowser.coolDownAsync(browserPackage);\n }\n}\n// @needsAudit\n/**\n * Opens the url with Safari in a modal on iOS using [`SFSafariViewController`](https://developer.apple.com/documentation/safariservices/sfsafariviewcontroller),\n * and Chrome in a new [custom tab](https://developer.chrome.com/multidevice/android/customtabs)\n * on Android. On iOS, the modal Safari will not share cookies with the system Safari. If you need\n * this, use [`openAuthSessionAsync`](#webbrowseropenauthsessionasyncurl-redirecturl-options).\n *\n * @param url The url to open in the web browser.\n * @param browserParams A dictionary of key-value pairs.\n *\n * @return The promise behaves differently based on the platform.\n * On Android promise resolves with `{ type: 'opened' }` if we were able to open browser.\n * On iOS:\n * - If the user closed the web browser, the Promise resolves with `{ type: 'cancel' }`.\n * - If the browser is closed using [`dismissBrowser`](#webbrowserdismissbrowser), the Promise resolves with `{ type: 'dismiss' }`.\n */\nexport async function openBrowserAsync(url, browserParams = {}) {\n if (!ExponentWebBrowser.openBrowserAsync) {\n throw new UnavailabilityError('WebBrowser', 'openBrowserAsync');\n }\n let result;\n try {\n result = await ExponentWebBrowser.openBrowserAsync(url, _processOptions(browserParams));\n }\n catch {\n return { type: WebBrowserResultType.LOCKED };\n }\n return result;\n}\n// @needsAudit\n/**\n * Dismisses the presented web browser.\n *\n * @return The `void` on successful attempt, or throws error, if dismiss functionality is not avaiable.\n * @platform ios\n */\nexport function dismissBrowser() {\n ExponentWebBrowser.dismissBrowser?.();\n}\n// @needsAudit\n/**\n * # On Android:\n * This will be done using a \"custom Chrome tabs\" browser, [AppState](https://reactnative.dev/docs/appstate),\n * and [Linking](./linking/) APIs.\n *\n * # On iOS:\n * Opens the url with Safari in a modal using `ASWebAuthenticationSession`. The user will be asked\n * whether to allow the app to authenticate using the given url.\n * To handle redirection back to the mobile application, the redirect URI set in the authentication server\n * has to use the protocol provided as the scheme in **app.json** [`expo.scheme`](./../config/app/#scheme).\n * For example, `demo://` not `https://` protocol.\n * Using `Linking.addEventListener` is not needed and can have side effects.\n *\n * # On web:\n * > This API can only be used in a secure environment (localhost/https).\n * to test this. Otherwise, an error with code [`ERR_WEB_BROWSER_CRYPTO`](#err_web_browser_crypto) will be thrown.\n * This will use the browser's [`window.open()`](https://developer.mozilla.org/en-US/docs/Web/API/Window/open) API.\n * - _Desktop_: This will create a new web popup window in the browser that can be closed later using `WebBrowser.maybeCompleteAuthSession()`.\n * - _Mobile_: This will open a new tab in the browser which can be closed using `WebBrowser.maybeCompleteAuthSession()`.\n *\n * How this works on web:\n * - A crypto state will be created for verifying the redirect.\n * - This means you need to run with `npx expo start --https`\n * - The state will be added to the window's `localstorage`. This ensures that auth cannot complete\n * unless it's done from a page running with the same origin as it was started.\n * Ex: if `openAuthSessionAsync` is invoked on `https://localhost:19006`, then `maybeCompleteAuthSession`\n * must be invoked on a page hosted from the origin `https://localhost:19006`. Using a different\n * website, or even a different host like `https://128.0.0.*:19006` for example will not work.\n * - A timer will be started to check for every 1000 milliseconds (1 second) to detect if the window\n * has been closed by the user. If this happens then a promise will resolve with `{ type: 'dismiss' }`.\n *\n * > On mobile web, Chrome and Safari will block any call to [`window.open()`](https://developer.mozilla.org/en-US/docs/Web/API/Window/open)\n * which takes too long to fire after a user interaction. This method must be invoked immediately\n * after a user interaction. If the event is blocked, an error with code [`ERR_WEB_BROWSER_BLOCKED`](#err_web_browser_blocked) will be thrown.\n *\n * @param url The url to open in the web browser. This should be a login page.\n * @param redirectUrl _Optional_ - The url to deep link back into your app.\n * On web, this defaults to the output of [`Linking.createURL(\"\")`](./linking/#linkingcreateurlpath-namedparameters).\n * @param options _Optional_ - An object extending the [`WebBrowserOpenOptions`](#webbrowseropenoptions).\n * If there is no native AuthSession implementation available (which is the case on Android)\n * these params will be used in the browser polyfill. If there is a native AuthSession implementation,\n * these params will be ignored.\n *\n * @return\n * - If the user does not permit the application to authenticate with the given url, the Promise fulfills with `{ type: 'cancel' }` object.\n * - If the user closed the web browser, the Promise fulfills with `{ type: 'cancel' }` object.\n * - If the browser is closed using [`dismissBrowser`](#webbrowserdismissbrowser),\n * the Promise fulfills with `{ type: 'dismiss' }` object.\n */\nexport async function openAuthSessionAsync(url, redirectUrl, options = {}) {\n if (_authSessionIsNativelySupported()) {\n if (!ExponentWebBrowser.openAuthSessionAsync) {\n throw new UnavailabilityError('WebBrowser', 'openAuthSessionAsync');\n }\n if (['ios', 'web'].includes(Platform.OS)) {\n return ExponentWebBrowser.openAuthSessionAsync(url, redirectUrl, _processOptions(options));\n }\n return ExponentWebBrowser.openAuthSessionAsync(url, redirectUrl);\n }\n else {\n return _openAuthSessionPolyfillAsync(url, redirectUrl, options);\n }\n}\n// @docsMissing\nexport function dismissAuthSession() {\n if (_authSessionIsNativelySupported()) {\n if (!ExponentWebBrowser.dismissAuthSession) {\n throw new UnavailabilityError('WebBrowser', 'dismissAuthSession');\n }\n ExponentWebBrowser.dismissAuthSession();\n }\n else {\n if (!ExponentWebBrowser.dismissBrowser) {\n throw new UnavailabilityError('WebBrowser', 'dismissAuthSession');\n }\n ExponentWebBrowser.dismissBrowser();\n }\n}\n// @needsAudit\n/**\n * Possibly completes an authentication session on web in a window popup. The method\n * should be invoked on the page that the window redirects to.\n *\n * @param options\n *\n * @return Returns an object with message about why the redirect failed or succeeded:\n *\n * If `type` is set to `failed`, the reason depends on the message:\n * - `Not supported on this platform`: If the platform doesn't support this method (iOS, Android).\n * - `Cannot use expo-web-browser in a non-browser environment`: If the code was executed in an SSR\n * or node environment.\n * - `No auth session is currently in progress`: (the cached state wasn't found in local storage).\n * This can happen if the window redirects to an origin (website) that is different to the initial\n * website origin. If this happens in development, it may be because the auth started on localhost\n * and finished on your computer port (Ex: `128.0.0.*`). This is controlled by the `redirectUrl`\n * and `returnUrl`.\n * - `Current URL \"\" and original redirect URL \"\" do not match`: This can occur when the\n * redirect URL doesn't match what was initial defined as the `returnUrl`. You can skip this test\n * in development by passing `{ skipRedirectCheck: true }` to the function.\n *\n * If `type` is set to `success`, the parent window will attempt to close the child window immediately.\n *\n * If the error `ERR_WEB_BROWSER_REDIRECT` was thrown, it may mean that the parent window was\n * reloaded before the auth was completed. In this case you'll need to close the child window manually.\n *\n * @platform web\n */\nexport function maybeCompleteAuthSession(options = {}) {\n if (ExponentWebBrowser.maybeCompleteAuthSession) {\n return ExponentWebBrowser.maybeCompleteAuthSession(options);\n }\n return { type: 'failed', message: 'Not supported on this platform' };\n}\nfunction _processOptions(options) {\n return {\n ...options,\n controlsColor: processColor(options.controlsColor),\n toolbarColor: processColor(options.toolbarColor),\n secondaryToolbarColor: processColor(options.secondaryToolbarColor),\n };\n}\n/* iOS <= 10 and Android polyfill for SFAuthenticationSession flow */\nfunction _authSessionIsNativelySupported() {\n if (Platform.OS === 'android') {\n return false;\n }\n else if (Platform.OS === 'web') {\n return true;\n }\n const versionNumber = parseInt(String(Platform.Version), 10);\n return versionNumber >= 11;\n}\nlet _redirectSubscription = null;\n/*\n * openBrowserAsync on Android doesn't wait until closed, so we need to polyfill\n * it with AppState\n */\n// Store the `resolve` function from a Promise to fire when the AppState\n// returns to active\nlet _onWebBrowserCloseAndroid = null;\n// If the initial AppState.currentState is null, we assume that the first call to\n// AppState#change event is not actually triggered by a real change,\n// is triggered instead by the bridge capturing the current state\n// (https://reactnative.dev/docs/appstate#basic-usage)\nlet _isAppStateAvailable = AppState.currentState !== null;\nfunction _onAppStateChangeAndroid(state) {\n if (!_isAppStateAvailable) {\n _isAppStateAvailable = true;\n return;\n }\n if (state === 'active' && _onWebBrowserCloseAndroid) {\n _onWebBrowserCloseAndroid();\n }\n}\nasync function _openBrowserAndWaitAndroidAsync(startUrl, browserParams = {}) {\n const appStateChangedToActive = new Promise((resolve) => {\n _onWebBrowserCloseAndroid = resolve;\n });\n const stateChangeSubscription = AppState.addEventListener('change', _onAppStateChangeAndroid);\n let result = { type: WebBrowserResultType.CANCEL };\n let type = null;\n try {\n ({ type } = await openBrowserAsync(startUrl, browserParams));\n }\n catch (e) {\n stateChangeSubscription.remove();\n _onWebBrowserCloseAndroid = null;\n throw e;\n }\n if (type === 'opened') {\n await appStateChangedToActive;\n result = { type: WebBrowserResultType.DISMISS };\n }\n stateChangeSubscription.remove();\n _onWebBrowserCloseAndroid = null;\n return result;\n}\nasync function _openAuthSessionPolyfillAsync(startUrl, returnUrl, browserParams = {}) {\n if (_redirectSubscription) {\n throw new Error(`The WebBrowser's auth session is in an invalid state with a redirect handler set when it should not be`);\n }\n if (_onWebBrowserCloseAndroid) {\n throw new Error(`WebBrowser is already open, only one can be open at a time`);\n }\n try {\n if (Platform.OS === 'android') {\n return await Promise.race([\n _openBrowserAndWaitAndroidAsync(startUrl, browserParams),\n _waitForRedirectAsync(returnUrl),\n ]);\n }\n else {\n return await Promise.race([\n openBrowserAsync(startUrl, browserParams),\n _waitForRedirectAsync(returnUrl),\n ]);\n }\n }\n finally {\n // We can't dismiss the browser on Android, only call this when it's available.\n // Users on Android need to manually press the 'x' button in Chrome Custom Tabs, sadly.\n if (ExponentWebBrowser.dismissBrowser) {\n ExponentWebBrowser.dismissBrowser();\n }\n _stopWaitingForRedirect();\n }\n}\nfunction _stopWaitingForRedirect() {\n if (!_redirectSubscription) {\n throw new Error(`The WebBrowser auth session is in an invalid state with no redirect handler when one should be set`);\n }\n _redirectSubscription.remove();\n _redirectSubscription = null;\n}\nfunction _waitForRedirectAsync(returnUrl) {\n // Note that this Promise never resolves when `returnUrl` is nullish\n return new Promise((resolve) => {\n const redirectHandler = (event) => {\n if (returnUrl && event.url.startsWith(returnUrl)) {\n resolve({ url: event.url, type: 'success' });\n }\n };\n _redirectSubscription = Linking.addEventListener('url', redirectHandler);\n });\n}\n//# sourceMappingURL=WebBrowser.js.map","/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport invariant from 'fbjs/lib/invariant';\nimport canUseDOM from '../../modules/canUseDom';\nvar initialURL = canUseDOM ? window.location.href : '';\nclass Linking {\n constructor() {\n this._eventCallbacks = {};\n }\n /**\n * An object mapping of event name\n * and all the callbacks subscribing to it\n */\n _dispatchEvent(event) {\n for (var _len = arguments.length, data = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n data[_key - 1] = arguments[_key];\n }\n var listeners = this._eventCallbacks[event];\n if (listeners != null && Array.isArray(listeners)) {\n listeners.map(listener => {\n listener(...data);\n });\n }\n }\n\n /**\n * Adds a event listener for the specified event. The callback will be called when the\n * said event is dispatched.\n */\n addEventListener(eventType, callback) {\n var _this = this;\n if (!_this._eventCallbacks[eventType]) {\n _this._eventCallbacks[eventType] = [callback];\n }\n _this._eventCallbacks[eventType].push(callback);\n return {\n remove() {\n var callbacks = _this._eventCallbacks[eventType];\n var filteredCallbacks = callbacks.filter(c => c.toString() !== callback.toString());\n _this._eventCallbacks[eventType] = filteredCallbacks;\n }\n };\n }\n\n /**\n * Removes a previously added event listener for the specified event. The callback must\n * be the same object as the one passed to `addEventListener`.\n */\n removeEventListener(eventType, callback) {\n console.error(\"Linking.removeEventListener('\" + eventType + \"', ...): Method has been \" + 'deprecated. Please instead use `remove()` on the subscription ' + 'returned by `Linking.addEventListener`.');\n var callbacks = this._eventCallbacks[eventType];\n var filteredCallbacks = callbacks.filter(c => c.toString() !== callback.toString());\n this._eventCallbacks[eventType] = filteredCallbacks;\n }\n canOpenURL() {\n return Promise.resolve(true);\n }\n getInitialURL() {\n return Promise.resolve(initialURL);\n }\n\n /**\n * Try to open the given url in a secure fashion. The method returns a Promise object.\n * If a target is passed (including undefined) that target will be used, otherwise '_blank'.\n * If the url opens, the promise is resolved. If not, the promise is rejected.\n * Dispatches the `onOpen` event if `url` is opened successfully.\n */\n openURL(url, target) {\n if (arguments.length === 1) {\n target = '_blank';\n }\n try {\n open(url, target);\n this._dispatchEvent('onOpen', url);\n return Promise.resolve();\n } catch (e) {\n return Promise.reject(e);\n }\n }\n _validateURL(url) {\n invariant(typeof url === 'string', 'Invalid URL: should be a string. Was: ' + url);\n invariant(url, 'Invalid URL: cannot be empty');\n }\n}\nvar open = (url, target) => {\n if (canUseDOM) {\n var urlToOpen = new URL(url, window.location).toString();\n if (urlToOpen.indexOf('tel:') === 0) {\n window.location = urlToOpen;\n } else {\n window.open(urlToOpen, target, 'noopener');\n }\n }\n};\nexport default new Linking();","import { CodedError } from 'expo-modules-core';\nimport { AppState } from 'react-native';\nimport { WebBrowserResultType, } from './WebBrowser.types';\nconst POPUP_WIDTH = 500;\nconst POPUP_HEIGHT = 650;\nlet popupWindow = null;\nconst listenerMap = new Map();\nconst getHandle = () => 'ExpoWebBrowserRedirectHandle';\nconst getOriginUrlHandle = (hash) => `ExpoWebBrowser_OriginUrl_${hash}`;\nconst getRedirectUrlHandle = (hash) => `ExpoWebBrowser_RedirectUrl_${hash}`;\nexport function normalizeUrl(url) {\n const origin = url.origin.replace(url.protocol, '').replace(/^\\/+/, '').replace(/\\/+$/, '');\n return (origin + decodeURI(url.pathname.replace(/\\/{2,}/g, '/'))).toLowerCase();\n}\nfunction dismissPopup() {\n if (!popupWindow) {\n return;\n }\n popupWindow.close();\n if (listenerMap.has(popupWindow)) {\n const { listener, appStateSubscription, interval } = listenerMap.get(popupWindow);\n clearInterval(interval);\n window.removeEventListener('message', listener);\n appStateSubscription.remove();\n listenerMap.delete(popupWindow);\n const handle = window.localStorage.getItem(getHandle());\n if (handle) {\n window.localStorage.removeItem(getHandle());\n window.localStorage.removeItem(getOriginUrlHandle(handle));\n window.localStorage.removeItem(getRedirectUrlHandle(handle));\n }\n popupWindow = null;\n }\n}\nexport default {\n async openBrowserAsync(url, browserParams = {}) {\n if (typeof window === 'undefined') {\n return { type: WebBrowserResultType.CANCEL };\n }\n const { windowName = '_blank', windowFeatures } = browserParams;\n const features = getPopupFeaturesString(windowFeatures);\n window.open(url, windowName, features);\n return { type: WebBrowserResultType.OPENED };\n },\n dismissAuthSession() {\n if (typeof window === 'undefined')\n return;\n dismissPopup();\n },\n maybeCompleteAuthSession({ skipRedirectCheck }) {\n if (typeof window === 'undefined') {\n return {\n type: 'failed',\n message: 'Cannot use expo-web-browser in a non-browser environment',\n };\n }\n const handle = window.localStorage.getItem(getHandle());\n if (!handle) {\n return { type: 'failed', message: 'No auth session is currently in progress' };\n }\n const url = window.location.href;\n if (skipRedirectCheck !== true) {\n const redirectUrl = window.localStorage.getItem(getRedirectUrlHandle(handle));\n // Compare the original redirect url against the current url with it's query params removed.\n const currentUrl = normalizeUrl(window.location);\n if (redirectUrl !== currentUrl) {\n return {\n type: 'failed',\n message: `Current URL \"${currentUrl}\" and original redirect URL \"${redirectUrl}\" do not match.`,\n };\n }\n }\n // Save the link for app state listener\n window.localStorage.setItem(getOriginUrlHandle(handle), url);\n // Get the window that created the current popup\n const parent = window.opener ?? window.parent;\n if (!parent) {\n throw new CodedError('ERR_WEB_BROWSER_REDIRECT', `The window cannot complete the redirect request because the invoking window doesn't have a reference to it's parent. This can happen if the parent window was reloaded.`);\n }\n // Send the URL back to the opening window.\n parent.postMessage({ url, expoSender: handle }, parent.location.toString());\n return { type: 'success', message: `Attempting to complete auth` };\n // Maybe set timer to throw an error if the window is still open after attempting to complete.\n },\n // This method should be invoked from user input.\n async openAuthSessionAsync(url, redirectUrl, openOptions) {\n if (typeof window === 'undefined')\n return { type: WebBrowserResultType.CANCEL };\n redirectUrl = redirectUrl ?? getRedirectUrlFromUrlOrGenerate(url);\n if (popupWindow == null || popupWindow?.closed) {\n const features = getPopupFeaturesString(openOptions?.windowFeatures);\n popupWindow = window.open(url, openOptions?.windowName, features);\n if (popupWindow) {\n try {\n popupWindow.focus();\n }\n catch { }\n }\n else {\n throw new CodedError('ERR_WEB_BROWSER_BLOCKED', 'Popup window was blocked by the browser or failed to open. This can happen in mobile browsers when the window.open() method was invoked too long after a user input was fired.');\n }\n }\n const state = await getStateFromUrlOrGenerateAsync(url);\n // Save handle for session\n window.localStorage.setItem(getHandle(), state);\n const normalizedRedirectUrl = (() => {\n if (!redirectUrl)\n return redirectUrl;\n try {\n return normalizeUrl(new URL(redirectUrl));\n }\n catch {\n return redirectUrl;\n }\n })();\n // Save redirect Url for further verification\n window.localStorage.setItem(getRedirectUrlHandle(state), normalizedRedirectUrl);\n return new Promise(async (resolve) => {\n // Create a listener for messages sent from the popup\n const listener = (event) => {\n if (!event.isTrusted)\n return;\n // Ensure we trust the sender.\n if (event.origin !== window.location.origin) {\n return;\n }\n const { data } = event;\n // Use a crypto hash to invalid message.\n const handle = window.localStorage.getItem(getHandle());\n // Ensure the sender is also from expo-web-browser\n if (data.expoSender === handle) {\n dismissPopup();\n resolve({ type: 'success', url: data.url });\n }\n };\n // Add a listener for receiving messages from the popup.\n window.addEventListener('message', listener, false);\n // Create an app state listener as a fallback to the popup listener\n const appStateListener = (state) => {\n if (state !== 'active') {\n return;\n }\n const handle = window.localStorage.getItem(getHandle());\n if (handle) {\n const url = window.localStorage.getItem(getOriginUrlHandle(handle));\n if (url) {\n dismissPopup();\n resolve({ type: 'success', url });\n }\n }\n };\n const appStateSubscription = AppState.addEventListener('change', appStateListener);\n // Check if the window has been closed every second.\n const interval = setInterval(() => {\n if (popupWindow?.closed) {\n if (resolve)\n resolve({ type: WebBrowserResultType.DISMISS });\n clearInterval(interval);\n dismissPopup();\n }\n }, 1000);\n // Store the listener and interval for clean up.\n listenerMap.set(popupWindow, {\n listener,\n interval,\n appStateSubscription,\n });\n });\n },\n};\n// Crypto\nfunction isCryptoAvailable() {\n if (typeof window === 'undefined')\n return false;\n return !!window?.crypto;\n}\nfunction isSubtleCryptoAvailable() {\n if (!isCryptoAvailable())\n return false;\n return !!window.crypto.subtle;\n}\nasync function getStateFromUrlOrGenerateAsync(inputUrl) {\n const url = new URL(inputUrl);\n if (url.searchParams.has('state') && typeof url.searchParams.get('state') === 'string') {\n // Ensure we reuse the auth state if it's passed in.\n return url.searchParams.get('state');\n }\n // Generate a crypto state for verifying the return popup.\n return await generateStateAsync();\n}\nfunction getRedirectUrlFromUrlOrGenerate(inputUrl) {\n const url = new URL(inputUrl);\n if (url.searchParams.has('redirect_uri') &&\n typeof url.searchParams.get('redirect_uri') === 'string') {\n // Ensure we reuse the redirect_uri if it's passed in the input url.\n return url.searchParams.get('redirect_uri');\n }\n // Emulate how native uses Constants.linkingUrl\n return location.origin + location.pathname;\n}\nconst CHARSET = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\nasync function generateStateAsync() {\n if (!isSubtleCryptoAvailable()) {\n throw new CodedError('ERR_WEB_BROWSER_CRYPTO', `The current environment doesn't support crypto. Ensure you are running from a secure origin (localhost/https).`);\n }\n const encoder = new TextEncoder();\n const data = generateRandom(10);\n const buffer = encoder.encode(data);\n const hashedData = await crypto.subtle.digest('SHA-256', buffer);\n const state = btoa(String.fromCharCode(...new Uint8Array(hashedData)));\n return state;\n}\nfunction generateRandom(size) {\n let arr = new Uint8Array(size);\n if (arr.byteLength !== arr.length) {\n arr = new Uint8Array(arr.buffer);\n }\n const array = new Uint8Array(arr.length);\n if (isCryptoAvailable()) {\n window.crypto.getRandomValues(array);\n }\n else {\n for (let i = 0; i < size; i += 1) {\n array[i] = (Math.random() * CHARSET.length) | 0;\n }\n }\n return bufferToString(array);\n}\nfunction bufferToString(buffer) {\n const state = [];\n for (let i = 0; i < buffer.byteLength; i += 1) {\n const index = buffer[i] % CHARSET.length;\n state.push(CHARSET[index]);\n }\n return state.join('');\n}\n// Window Features\n// Ensure feature string is an object\nfunction normalizePopupFeaturesString(options) {\n let windowFeatures = {};\n // This should be avoided because it adds extra time to the popup command.\n if (typeof options === 'string') {\n // Convert string of `key=value,foo=bar` into an object\n const windowFeaturePairs = options.split(',');\n for (const pair of windowFeaturePairs) {\n const [key, value] = pair.trim().split('=');\n if (key && value) {\n windowFeatures[key] = value;\n }\n }\n }\n else if (options) {\n windowFeatures = options;\n }\n return windowFeatures;\n}\n// Apply default values to the input feature set\nfunction getPopupFeaturesString(options) {\n const windowFeatures = normalizePopupFeaturesString(options);\n const width = windowFeatures.width ?? POPUP_WIDTH;\n const height = windowFeatures.height ?? POPUP_HEIGHT;\n const top = windowFeatures.top ?? Math.max(0, (window.screen.height - height) * 0.5);\n const left = windowFeatures.left ?? Math.max(0, (window.screen.width - width) * 0.5);\n // Create a reasonable popup\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/open#Window_features\n return featureObjectToString({\n ...windowFeatures,\n // Toolbar buttons (Back, Forward, Reload, Stop buttons).\n toolbar: windowFeatures.toolbar ?? 'no',\n menubar: windowFeatures.menubar ?? 'no',\n // Shows the location bar or the address bar.\n location: windowFeatures.location ?? 'yes',\n resizable: windowFeatures.resizable ?? 'yes',\n // If this feature is on, then the new secondary window has a status bar.\n status: windowFeatures.status ?? 'no',\n scrollbars: windowFeatures.scrollbars ?? 'yes',\n top,\n left,\n width,\n height,\n });\n}\nexport function featureObjectToString(features) {\n return Object.keys(features).reduce((prev, current) => {\n let value = features[current];\n if (typeof value === 'boolean') {\n value = value ? 'yes' : 'no';\n }\n if (current && value) {\n if (prev)\n prev += ',';\n return `${prev}${current}=${value}`;\n }\n return prev;\n }, '');\n}\n//# sourceMappingURL=ExpoWebBrowser.web.js.map","// @needsAudit @docsMissing\nexport var WebBrowserResultType;\n(function (WebBrowserResultType) {\n /**\n * @platform ios\n */\n WebBrowserResultType[\"CANCEL\"] = \"cancel\";\n /**\n * @platform ios\n */\n WebBrowserResultType[\"DISMISS\"] = \"dismiss\";\n /**\n * @platform android\n */\n WebBrowserResultType[\"OPENED\"] = \"opened\";\n WebBrowserResultType[\"LOCKED\"] = \"locked\";\n})(WebBrowserResultType || (WebBrowserResultType = {}));\n// @needsAudit\n/**\n * A browser presentation style. Its values are directly mapped to the [`UIModalPresentationStyle`](https://developer.apple.com/documentation/uikit/uiviewcontroller/1621355-modalpresentationstyle).\n *\n * @platform ios\n */\nexport var WebBrowserPresentationStyle;\n(function (WebBrowserPresentationStyle) {\n /**\n * A presentation style in which the presented browser covers the screen.\n */\n WebBrowserPresentationStyle[\"FULL_SCREEN\"] = \"fullScreen\";\n /**\n * A presentation style that partially covers the underlying content.\n */\n WebBrowserPresentationStyle[\"PAGE_SHEET\"] = \"pageSheet\";\n /**\n * A presentation style that displays the browser centered in the screen.\n */\n WebBrowserPresentationStyle[\"FORM_SHEET\"] = \"formSheet\";\n /**\n * A presentation style where the browser is displayed over the app's content.\n */\n WebBrowserPresentationStyle[\"CURRENT_CONTEXT\"] = \"currentContext\";\n /**\n * A presentation style in which the browser view covers the screen.\n */\n WebBrowserPresentationStyle[\"OVER_FULL_SCREEN\"] = \"overFullScreen\";\n /**\n * A presentation style where the browser is displayed over the app's content.\n */\n WebBrowserPresentationStyle[\"OVER_CURRENT_CONTEXT\"] = \"overCurrentContext\";\n /**\n * A presentation style where the browser is displayed in a popover view.\n */\n WebBrowserPresentationStyle[\"POPOVER\"] = \"popover\";\n /**\n * The default presentation style chosen by the system.\n * On older iOS versions, falls back to `WebBrowserPresentationStyle.FullScreen`.\n *\n * @platform ios\n */\n WebBrowserPresentationStyle[\"AUTOMATIC\"] = \"automatic\";\n})(WebBrowserPresentationStyle || (WebBrowserPresentationStyle = {}));\n//# sourceMappingURL=WebBrowser.types.js.map","import React, {useContext} from \"react\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport {theme} from \"@common/theme/theme\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {View} from \"react-native\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport TextM from \"@common/components/text/TextM\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport * as WebBrowser from \"expo-web-browser\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport initial from \"../../assets/offers/initial.png\"\nimport essential from \"../../assets/offers/essential.png\"\nimport integral from \"../../assets/offers/integral.png\"\nimport holidays from \"../../assets/offers/holidays.png\"\nimport {useApiStatus} from \"@common/hooks/useApiStatus\";\nimport {subscriptionService} from \"@data/services/subscriptionService\";\nimport {apiIdle, apiRequest, apiRequestWithPrerequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {BadgeM} from \"@common/components/badge/BadgeM\";\n\nexport const offersImages = {\n plus: essential, premium: integral, initial, essential, integral, holidayworkbook: holidays\n}\n\nconst borderColors = [theme.colors.material.secondary[\"100\"], theme.colors.material.secondary[\"300\"], theme.colors.material.secondary[\"500\"]]\n\nconst textColors = [theme.colors.material.secondary[\"300\"], theme.colors.material.secondary[\"500\"], theme.colors.material.secondary[\"700\"]]\n\nexport function PriceDataHeaderM({\n data,\n withCommitment,\n index,\n nextMode = false,\n size = \"lg\",\n parentTitle = \"Essentielle\",\n lightMode = false\n }) {\n const priceData = data?.prices[\"monthly\"]\n const discountData = withCommitment ? priceData?.commitment_discount_data : priceData\n const successColor = nextMode ? theme.colors.grey : theme.colors.success\n\n const titleSize = size === \"lg\" ? 32 : size === \"md\" ? 24 : 16\n const descriptionSize = size === \"lg\" ? 14 : size === \"md\" ? 12 : 10\n const priceSize = size === \"lg\" ? 28 : size === \"md\" ? 20 : 18\n const priceSmallSize = size === \"lg\" ? 22 : size === \"md\" ? 16 : 12\n const marginBottom = size === \"lg\" ? 20 : size === \"md\" ? 10 : 5\n const imgWidth = size === \"lg\" ? 50 : size === \"md\" ? 30 : 25\n\n return \n \n {!nextMode && }\n {nextMode && }\n {!nextMode && data?.product_title?.replace(\"Révisions d'été\", parentTitle) + \" - \"}{data?.product_mode}\n {data?.product_tagline}\n {nextMode && !lightMode && {data?.product_slots}}\n \n \n {discountData?.hourly_amount ? <>{priceData?.hourly_amount?.toString()?.replace(\".\", \",\")}€{\" \" + discountData?.hourly_amount?.toString()?.replace(\".\", \",\")} : priceData?.hourly_amount?.toString()?.replace(\".\", \",\")}{priceData?.period}\n \n \n soit {discountData?.amount ? <>{priceData?.amount?.toString()?.replace(\".\", \",\")}€ {\" \" + discountData?.amount?.toString()?.replace(\".\", \",\")}€ : priceData?.amount?.toString()?.replace(\".\", \",\") + \"€\"} /mois\n \n {!lightMode && !nextMode && \n {discountData?.discount ? discountData?.advantage : null}\n }\n ;\n}\n\nexport function PrivilegesChecklistM({data, style = {}, tinyMode = false}) {\n\n const fontSize = tinyMode ? 12 : 14\n const iconSize = tinyMode ? 12 : 16\n return <>\n \n {data?.privileges_title}\n \n \n {data?.privileges_list?.map((privilege, index) => {\n return \n \n {privilege}\n \n })}\n\n \n \n}\n\nPrivilegesChecklistM.propTypes = {};\nexport const PricingColumnM = (props) => {\n const {index, withCommitment, data, userEmail, startNextMonth = false, nextModeData, onPress = null, selected = false, forceBigSize = false} = props\n\n const dimensions = useContext(DimensionsContext)\n\n const priceData = data?.prices[\"monthly\"]\n const discountData = withCommitment ? priceData?.commitment_discount_data : priceData?.discount_data\n\n const navigation = useNavigation()\n\n useApiStatus(subscriptionService.getSubscribeRedirectUrl, // api service\n null, // success message on toast (string or null)\n true, // error message on toast (true) or keep it in redux state (false)\n (data) => {\n\n if (IS_WEB) {\n window.open(data?.url, \"_self\")\n } else {\n // console.log(data)\n\n WebBrowser.openBrowserAsync(data?.url)\n navigation.goBack()\n }\n\n } // success callback\n )\n\n\n return \n {data?.most_popular && \n \n La plus populaire\n\n }\n \n \n {\n onPress(data?.product_name, withCommitment)\n } : () => {\n props.apiRequest(subscriptionService.getSubscribeRedirectUrl, {}, {}, {\n email: userEmail,\n price_slug: data?.product_name,\n with_commitment: withCommitment,\n next_month: startNextMonth ? 1 : 0\n })\n }}\n buttonColor={selected ? theme.colors.lightMore : textColors[index]}\n label={props.request && props.requestPriceSlug === priceData?.slug ? \"Redirection\" : \"Choisir cette offre\"}/>\n \n {data?.product_mode !== \"Individuel\" && \n {data?.product_period_end}, puis :\n \n }\n\n \n ;\n}\n\nconst mapStateToProps = state => {\n return {\n request: state.api.getSubscribeRedirectUrl?.request,\n success: state.api.getSubscribeRedirectUrl?.success,\n error: state.api.getSubscribeRedirectUrl?.error,\n requestPriceSlug: state.api.getSubscribeRedirectUrl?.urlParams?.price_slug,\n user: state.data.currentUser?.object\n }\n}\n\nconst mapDispatchToProps = {\n apiRequestWithPrerequest, apiRequest, apiIdle\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps)(PricingColumnM)","","","","","import {Badge} from \"react-native-paper\";\nimport {theme} from \"../../theme/theme\";\nimport React from \"react\";\n\nexport function BadgeM({count, style, size = null}) {\n\n if (!!size)\n return {count};\n else\n return {count};\n}","let keyStr = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\nexport default {\n encode: function (input) {\n var output = [];\n var chr1, chr2, chr3 = \"\";\n var enc1, enc2, enc3, enc4 = \"\";\n var i = 0;\n\n do {\n chr1 = input.charCodeAt(i++);\n chr2 = input.charCodeAt(i++);\n chr3 = input.charCodeAt(i++);\n\n enc1 = chr1 >> 2;\n enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);\n enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);\n enc4 = chr3 & 63;\n\n if (isNaN(chr2)) {\n enc3 = enc4 = 64;\n } else if (isNaN(chr3)) {\n enc4 = 64;\n }\n\n output.push(\n keyStr.charAt(enc1) +\n keyStr.charAt(enc2) +\n keyStr.charAt(enc3) +\n keyStr.charAt(enc4))\n chr1 = chr2 = chr3 = \"\";\n enc1 = enc2 = enc3 = enc4 = \"\";\n } while (i < input.length);\n\n return output.join('');\n },\n\n encodeFromByteArray: function (input) {\n var output = [];\n var chr1, chr2, chr3 = \"\";\n var enc1, enc2, enc3, enc4 = \"\";\n var i = 0;\n\n do {\n chr1 = input[i++];\n chr2 = input[i++];\n chr3 = input[i++];\n\n enc1 = chr1 >> 2;\n enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);\n enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);\n enc4 = chr3 & 63;\n\n if (isNaN(chr2)) {\n enc3 = enc4 = 64;\n } else if (isNaN(chr3)) {\n enc4 = 64;\n }\n\n output.push(\n keyStr.charAt(enc1) +\n keyStr.charAt(enc2) +\n keyStr.charAt(enc3) +\n keyStr.charAt(enc4))\n chr1 = chr2 = chr3 = \"\";\n enc1 = enc2 = enc3 = enc4 = \"\";\n } while (i < input.length);\n\n return output.join('');\n },\n\n decode: function (input) {\n var output = \"\";\n var chr1, chr2, chr3 = \"\";\n var enc1, enc2, enc3, enc4 = \"\";\n var i = 0;\n\n // remove all characters that are not A-Z, a-z, 0-9, +, /, or =\n var base64test = /[^A-Za-z0-9\\+\\/\\=]/g;\n if (base64test.exec(input)) {\n throw new Error(\"There were invalid base64 characters in the input text.\\n\" +\n \"Valid base64 characters are A-Z, a-z, 0-9, '+', '/',and '='\\n\" +\n \"Expect errors in decoding.\");\n }\n input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, \"\");\n\n do {\n enc1 = keyStr.indexOf(input.charAt(i++));\n enc2 = keyStr.indexOf(input.charAt(i++));\n enc3 = keyStr.indexOf(input.charAt(i++));\n enc4 = keyStr.indexOf(input.charAt(i++));\n\n chr1 = (enc1 << 2) | (enc2 >> 4);\n chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);\n chr3 = ((enc3 & 3) << 6) | enc4;\n\n output = output + String.fromCharCode(chr1);\n\n if (enc3 != 64) {\n output = output + String.fromCharCode(chr2);\n }\n if (enc4 != 64) {\n output = output + String.fromCharCode(chr3);\n }\n\n chr1 = chr2 = chr3 = \"\";\n enc1 = enc2 = enc3 = enc4 = \"\";\n\n } while (i < input.length);\n\n return output;\n }\n}","import React, {useContext} from 'react';\nimport {View, Platform, ScrollView} from \"react-native\";\nimport TextM from \"@common/components/text/TextM\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport {getPrivilegedRole} from \"@data/utility/ability\";\nimport live from \"../../../assets/icons/generic/live.png\";\nimport rituals from \"../../../assets/icons/generic/rituals.png\";\nimport books from \"../../../assets/icons/generic/books.png\";\nimport {essentialOffersPrivileges, OfferPrivilegesList} from \"../../student/account/onboarding/TrialOnboardingScreen\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport prof from \"../../../assets/icons/menus-new/prof.png\";\n\nexport const holidayModePrivileges = [\n {\n icon: rituals,\n title: \"Une thématique au choix : combler ses lacunes, se maintenir en forme ou prendre de l'avance\"\n },\n {\n icon: books,\n title: \"Des activités chaque semaine, sur 1 ou 2 matières, à faire en autonomie ou en live\"\n },\n {\n icon: live,\n title: \"Des sessions live les lundis, mardis et mercredis matins de 10h30 à 11h30\"\n },\n {\n icon: prof,\n title: \"Pour travailler en direct avec son tuteur dans un cadre stimulant\"\n }\n]\nconst SuspensionContinuityInformation = (props) => {\n const {control, goToNextStep, register, errors, serverError, setFormValues, field, nextProductHolidayWorkbook} = props\n\n const dimensions = useContext(DimensionsContext)\n\n\n return <>\n \n {nextProductHolidayWorkbook ? <>\n L'été est l'occasion de se ressourcer... mais il ne faut pas laisser les apprentissages s'effacer !\n Du 1er juillet au 1er septembre 2024, découvrez les cahiers vacances en live de Masteur\n :\n : <>\n Offrez à votre enfant un cadre stimulant, pour travailler dans la régularité et booster ses résultats !\n }\n\n \n \n \n \n};\nconst mapStateToProps = state => {\n return {\n holidayOptions: state.data.formData?.holidayOptions,\n subscriptionUser: state.data.formData?.user,\n daysBeforePayment: state.data.formData?.daysBeforePayment,\n discountPercentage: state.data.formData?.discountPercentage\n }\n}\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(SuspensionContinuityInformation)","","","","import React, {useContext, useEffect} from 'react';\nimport {Platform, ScrollView, StatusBar, View} from \"react-native\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {theme} from \"@common/theme/theme\";\nimport {connect} from \"react-redux\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport {useSafeAreaInsets} from \"react-native-safe-area-context\";\nimport {ActivityIndicator, IconButton, Text} from \"react-native-paper\";\nimport {authService} from \"@data/services/authService\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\nimport TextM from \"@common/components/text/TextM\";\nimport {IconImageM, PremiumPlus} from \"@common/components/icons/IconsM\";\nimport live from \"../../../../assets/icons/generic/live.png\"\nimport students from \"@assets/icons/menus/children.png\"\nimport books from \"../../../../assets/icons/generic/books.png\"\nimport report from \"../../../../assets/icons/generic/reportf.png\"\nimport rituals from \"../../../../assets/icons/generic/rituals.png\"\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport {getPrivilegedRole, isOnTrial} from \"@data/utility/ability\";\nimport {isSubscribed, isSubscriptionPaused} from \"@data/utility/dataUtils\";\nimport {URL} from 'react-native-url-polyfill';\nimport prof from \"../../../../assets/icons/menus-new/prof.png\";\n\nexport const trialPrivileges = [\n {\n icon: live,\n title: \"2 x 1h d’étude en Live Masteur chaque semaine\"\n },\n {\n icon: prof,\n title: \"Des tuteurs sélectionnés parmi les meilleures filières d'études\"\n },\n {\n icon: rituals,\n title: \"Une méthode stimulante de soutien scolaire, inspirée des neurosciences\"\n },\n {\n icon: books,\n title: \"Essai gratuit et sans engagement\"\n }\n]\n\nexport const essentialOffersPrivileges = [\n {\n icon: books,\n title: \"Objectif : retravailler les chapitres qu’il voit en classe, et préparer ses contrôles\"\n },\n {\n icon: live,\n title: \"1h, 2h ou 3h de Live Masteur chaque semaine\"\n },\n {\n icon: prof,\n title: \"Des tuteurs d'excellence, sélectionnés parmi les meilleures filières d'études\"\n },\n {\n icon: students,\n title: \"Des petits groupes de 4 élèves maximum\"\n },\n\n {\n icon: report,\n title: \"Un rapport personnalisé pour suivre sa progression au quotidien\"\n }\n]\n\nexport const OfferPrivilegesList = ({privilegesList, product = \"essential\", whiteBackgroundMode = false}) => {\n\n const dimensions = useContext(DimensionsContext)\n\n const productLiveText = product === \"essential\" ? \"2 x 1h\" : product === \"initial\" ? \"1h\" : \"3 x 1h\"\n\n return \n {privilegesList.map((privilege, index) => {\n\n return \n \n {privilege.title?.replace(\"2 x 1h\", productLiveText)}\n \n }\n )}\n \n}\n\nconst TrialOnboardingScreen = (props) => {\n\n // ** Component props\n const {navigation} = props\n const insets = useSafeAreaInsets();\n\n const onboardingMode = !props.user?.onboarding_viewed_at\n // const trialMode = !props.user?.onboarding_viewed_at || canSubscribeToTrialEssential(props.user)\n const product = getPrivilegedRole(props.user)\n\n const goToNextScreen = () => {\n navigation.push(onboardingMode ? \"start-trial\" : \"start-trial\")\n }\n\n useEffect(() => {\n if (props.loggedOut) {\n props.apiIdle(authService.revokeSanctumToken)\n } else if (props.error) {\n props.apiIdle(authService.revokeSanctumToken)\n DialogM.show({\n text1: 'Erreur', text2: props.error.message\n })\n }\n }, [props.loggedOut, props.error])\n\n useEffect(() => {\n if (props.loggedOutWeb) {\n props.apiIdle(authService.logout)\n } else if (props.error) {\n props.apiIdle(authService.logout)\n DialogM.show({\n text1: 'Erreur', text2: props.error.message\n })\n }\n }, [props.loggedOutWeb, props.errorWeb])\n\n const alertBeforeExit = () => {\n DialogM.show({\n text1: 'Veux-tu vraiment revenir en arrière ?',\n text2: 'Tu seras déconnecté de ton compte.',\n buttonText1: 'Quitter',\n onPress: () => {\n if (Platform.OS !== 'web') {\n props.apiRequest(authService.revokeSanctumToken, {}, {});\n } else {\n props.apiRequest(authService.logout, {}, {});\n }\n },\n buttonText2: 'Annuler'\n })\n }\n\n const exit = () => {\n navigation.goBack()\n }\n\n const dimensions = useContext(DimensionsContext)\n\n\n return (\n\n \n\n \n {(props.loggingOut || props.loggingOutWeb)\n ? \n : }\n\n {/*{trialMode && {\"Tu bénéficies d'1 semaine d'essai gratuit !\"}}*/}\n\n \n \n Offre Essentielle\n \n \n \n\n \n\n {/*{trialMode && <>*/}\n {/* {\"Sans engagement.\"}*/}\n {/* {\"Pas besoin de carte bancaire.\"}*/}\n {/*}*/}\n {/*{trialMode && }*/}\n\n {(product === \"basic\" || isOnTrial(props.user))\n && !isSubscriptionPaused(props.user)\n // && !trialMode\n && (Platform.OS !== \"ios\" ? {\n // navigation.replace(\"choose-trial\", {product: \"product\"})\n // navigation.push(\"\")\n const url = new URL(props.user?.subscribe_url)\n navigation.push(url.pathname.slice(1), {\n user: url.searchParams.get(\"user\")\n })\n }}\n // labelStyle={{color: theme.colors.white}}\n style={{\n // width: dimensions?.width - 20,\n marginTop: 30\n }}\n label={(isSubscribed(props.user)) ? \"Gérer l'abonnement\" : \"S'abonner\"}/> : (!isOnTrial(props.user)) ? null :\n \n On ne peut pas s'abonner dans l'appli. Ce n'est pas idéal, nous le savons.\n )}\n\n \n \n \n \n );\n};\nconst mapStateToProps = state => {\n return {\n user: state.data.currentUser?.object,\n\n loggingOutWeb: state.api.logout?.request,\n loggedOutWeb: state.api.logout?.success,\n errorWeb: state.api.logout?.error,\n\n loggingOut: state.api.revokeSanctumToken?.request,\n loggedOut: state.api.revokeSanctumToken?.success,\n error: state.api.revokeSanctumToken?.error\n }\n};\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\nexport default connect(mapStateToProps, mapDispatchToProps)(TrialOnboardingScreen)","","","import moment from \"moment\"\nimport {formatDate} from \"@data/utility/Utils\";\nimport {findClosestNextOccurrence} from \"../../student/account/onboarding/LiveRoomCard\";\n\nexport const subscriptionPausedStatuses = [\"on_grace_period_before_pause\", \"paused\", \"planned\"]\n\nexport const findItemInListWithId = (id, list, otherFieldName) => {\n\n return list?.find((item) => {\n return item?.id === parseInt(id) || item?.[otherFieldName] === id\n })\n\n}\n\nexport const idsToObjects = (idList, objectList) => {\n return idList?.map(x => objectList?.find(y => y.id === x))\n}\n\nexport const tasksForActivities = (activities) => {\n let tasks = []\n\n activities?.forEach((activity) => {\n tasks = tasks.concat(activity?.tasks)\n })\n return tasks\n}\n\nexport const filterTodayActivitiesForChallenge = (allActivities, challenge) => {\n\n const today = moment().format('YYYY-MM-DD')\n\n const challengeActivities = idsToObjects(challenge.activity_ids, allActivities)\n return challengeActivities?.filter(activity => moment(activity?.date).isSame(today, 'day'))\n\n}\n\nexport const countLateActivitiesForChallenge = (allActivities, challenge) => {\n\n const challengeActivities = idsToObjects(challenge.activity_ids, allActivities)\n return challengeActivities?.filter(activity => activity?.is_late)?.length\n\n}\n\nexport const interviewsForStudents = (students) => {\n\n let interviews = []\n\n students?.forEach((student) => {\n interviews = interviews.concat(student?.interviews)\n })\n\n return interviews.sort((a, b) => moment(a.date_time).diff(b.date_time))\n\n}\n\nexport const studentActivitiesForChallengeId = (student, challengeId) => {\n return student?.activities?.filter(x => x.challenge_id === challengeId)\n}\n\nexport const studentActivitiesForActivityTemplateId = (student, activityTemplateId) => {\n return student?.activities?.filter(x => x?.activity_template_id === activityTemplateId)\n}\n\nexport const studentSurveyForActivityTemplate = (student, activityTemplate) => {\n return student?.survey_answers?.filter(x => x.id === activityTemplate.student_survey_question_id)\n}\n\nexport const nextInterviewForStudent = (student) => {\n\n const nextOrTwoDaysBeforeList = student?.interviews\n ?.filter(x => !x.finalized_at && moment(x?.date_time).isAfter(moment().subtract(2, 'day')))\n ?.sort((a, b) => moment(a?.date_time)?.diff(b?.date_time))\n\n if (nextOrTwoDaysBeforeList?.length > 0) {\n return nextOrTwoDaysBeforeList[0]\n }\n\n return null\n}\n\nexport const todayLivesForStudent = (student) => {\n\n const sameDayList = student?.live_sessions\n ?.filter(x => moment(x?.day_time).isSame(moment(), \"day\"))\n ?.sort((a, b) => moment(a?.day_time)?.diff(b?.day_time))\n\n if (sameDayList?.length > 0) {\n return sameDayList\n }\n\n return null\n}\n\nexport const lastFinishedInterviewForStudent = (student) => {\n\n const finishedInterviews = student?.interviews?.filter(x => !!x?.finalized_at)?.sort((a, b) => moment(b.date_time).diff(a.date_time))\n\n if (finishedInterviews?.length > 0) {\n return finishedInterviews[0]\n }\n\n return null\n}\n\nexport const isWebConfVisibleForStudent = student => {\n const interview = nextInterviewForStudent(student)\n if (!interview) return false\n\n return moment(interview?.date_time).isSameOrBefore(moment(), 'day')\n}\n\nexport const isLiveVisibleForStudent = student => {\n const live = nextLiveForStudent(student)\n if (!live) return false\n\n return moment(interview?.date_time).isSameOrBefore(moment(), 'day')\n}\n\nexport const activitiesForStudent = (student) => {\n\n return student.activities?.tasks?.filter(x => moment(x?.date).isSame(moment(), 'day'))\n\n}\n\nexport const isSubscribed = (student) => {\n return student?.subscription_state?.status === \"recurring\"\n || student?.subscription_state?.status === \"on_trial\"\n || student?.subscription_state?.status === \"on_grace_period\"\n || student?.subscription_state?.status === \"on_grace_period_before_pause\"\n || student?.subscription_state?.status === \"planned\"\n || student?.subscription_state?.status === \"past_due\"\n\n}\nexport const countSameActivitiesToday = (activityTemplate, activities, challenge_id = null, school_subject_id = null) => {\n\n if (activityTemplate?.parent_type === \"challenge\") {\n\n return activities?.filter(x => x?.activity_template_id === activityTemplate?.id)\n ?.filter(x => x?.challenge_id === challenge_id)\n ?.filter(x => x?.finished_at && moment().isSame(x?.finished_at, 'day'))\n ?.filter(x => x?.status !== 'rejected')\n ?.length\n\n } else {\n return activities?.filter(x => x?.activity_template_id === activityTemplate?.id)\n ?.filter(x => x?.school_subject_id === school_subject_id)\n ?.filter(x => x?.finished_at && moment().isSame(x?.finished_at, 'day'))\n ?.filter(x => x?.status !== 'rejected')\n ?.length\n }\n\n}\n\nexport const countSameAgainActivities = (activityTemplate, activities, againActivityId) => {\n\n const activity = activities?.find(x => x?.id === againActivityId)\n\n if (!activity || !activity?.finished_at)\n return 0\n\n return 1 + activities\n ?.filter(x => x?.activity_template_id === activityTemplate?.id)\n ?.filter(x => x?.again_activity_id === againActivityId)\n ?.filter(x => !!x?.finished_at)\n ?.filter(x => x?.status !== 'rejected')\n ?.length\n\n}\n\nexport const todaySchoolSubjectActivities = (user, activityTemplates) => {\n\n let doneCount = 0\n let totalCount = 0\n\n const todaySchoolSubjects = user?.school_subjects\n ?.filter(s => s?.prioritized)\n\n const todaySchoolSubjectActivities = []\n\n const todayWeekDay = moment().format(\"dddd\")\n\n todaySchoolSubjects?.forEach(ts => {\n\n const titles = {\n lesson_day: 'Le ' + todayWeekDay + ' tu as cours de ' + ts?.name + \"...\",\n lesson_day_before: 'Prépare-toi pour ton cours de ' + ts?.name + \" de demain...\",\n lesson_day_after: 'Hier, tu as eu cours de ' + ts?.name + \"...\",\n week_end: \"On est le week-end, profite-en pour t'avancer en \" + ts?.name\n }\n\n let filteredATs = []\n\n Object.keys(titles)?.forEach(t => {\n if (ts?.today_status[t]) {\n\n filteredATs = filteredATs?.concat(activityTemplates?.filter(at => (at?.schedule_day === t)))\n\n }\n })\n\n if (filteredATs?.length > 0) {\n const filteredActivities = user?.activities\n ?.filter(a => filteredATs?.map(at => at?.id)?.includes(a?.activity_template_id))\n ?.filter(a => a?.school_subject_id === ts?.id)\n ?.filter(a => moment().isSame(a?.finished_at, 'day'))\n // ?.filter(a => !!a?.finished_at)\n\n // console.log(filteredActivities)\n\n const doneFilteredATs = filteredATs\n ?.filter(at => filteredActivities?.map(a => a?.activity_template_id)?.includes(at?.id))\n\n doneCount += doneFilteredATs?.length\n totalCount += filteredATs?.length\n\n filteredATs?.forEach(at => {\n todaySchoolSubjectActivities.push({\n // title: titles[t],\n school_subject: ts,\n activity_template: at,\n activities: filteredActivities?.filter(a => a?.activity_template_id === at?.id)\n })\n })\n\n // todaySchoolSubjectActivities.push({\n // // title: titles[t],\n // school_subject: ts,\n // activity_templates: filteredATs,\n // activities: filteredActivities\n // })\n }\n // else {\n // todaySchoolSubjectActivities.push({\n // // title: titles[t],\n // school_subject: ts,\n // activity_templates: [],\n // activities: []\n // })\n // }\n\n })\n\n return {\n items: todaySchoolSubjectActivities,\n total_count: totalCount,\n done_count: doneCount\n }\n}\n\nexport const todayChallengeActivities = (user, activityTemplates) => {\n\n let doneCount = 0\n let totalCount = 0\n const todayChallengeActivities = []\n\n user?.challenges\n ?.filter(c => {\n if (!c?.planning_mode)\n return false\n\n const todayActivities = user?.activities?.filter(a => a?.challenge_id === c?.id && a?.is_shown_today)\n return todayActivities?.length > 0\n })\n ?.forEach(c => {\n\n const todayActivities = user?.activities?.filter(a => a?.challenge_id === c?.id && a?.is_shown_today)\n const againActivities = user?.activities?.filter(a => a?.challenge_id === c?.id && a?.again_activity_id)\n const doneTodayActivities = todayActivities?.filter(a => !!a?.finished_at)\n totalCount += todayActivities?.length\n doneCount += doneTodayActivities?.length\n\n\n todayActivities?.forEach(ta => {\n todayChallengeActivities.push({\n challenge: c,\n activities: todayActivities\n ?.filter(a => a?.activity_template_id === ta?.activity_template_id)\n ?.concat(againActivities?.filter(a => a?.activity_template_id === ta?.activity_template_id)),\n activityPlanned: ta,\n activity_template: activityTemplates?.find(at => at?.id === ta?.activity_template_id)\n })\n })\n\n\n })\n\n return {\n items: todayChallengeActivities,\n total_count: totalCount,\n done_count: doneCount\n }\n}\n\n\nexport const sortByDateAttribute = (list, dateAttribute = \"date\", asc = true) => {\n return list?.sort((a, b) => moment(a?.[dateAttribute]).diff(b?.[dateAttribute]) * (asc ? 1 : -1))\n}\n\nexport const groupBy = (xs, key) => {\n return xs?.reduce(function (rv, x) {\n (rv[x[key]] = rv[x[key]] || []).push(x);\n return rv;\n }, {});\n};\n\nexport const isSameCalendarDay = (moment1, moment2) => {\n return moment(moment1?.format(\"YYYY-MM-DD\"))?.isSame(moment2?.format(\"YYYY-MM-DD\"))\n}\n\nexport const sortLiveSessionsCallback = (a, b) => {\n // const n = 7 * 24 * 60\n\n const closestNextOccurrenceA = findClosestNextOccurrence([a]) // 2023-10-02\n const closestNextOccurrenceB = findClosestNextOccurrence([b]) // 2023-09-28\n\n // if (a?.live_room_id === 3) {\n // console.log(\"closestNextOccurrenceA\", closestNextOccurrenceA)\n // console.log(\"closestNextOccurrenceB\", closestNextOccurrenceB)\n // }\n\n const liveMomentA = moment(closestNextOccurrenceA?.date)\n const liveMomentB = moment(closestNextOccurrenceB?.date)\n\n const diffA = isSameCalendarDay(liveMomentA, moment()) ? Math.abs(liveMomentA.diff(moment(), \"minutes\")) : liveMomentA.diff(moment(), \"minutes\")\n const diffB = isSameCalendarDay(liveMomentB, moment()) ? Math.abs(liveMomentB.diff(moment(), \"minutes\")) : liveMomentB.diff(moment(), \"minutes\")\n\n return diffB > diffA ? -1 : diffB < diffA ? 1 : 0\n}\n\nexport const isSubscriptionPaused = (user) => subscriptionPausedStatuses.includes(user?.subscription_state?.status)\nexport const isSubscriptionRecurring = (user) => user?.subscription_state?.status === \"recurring\" || user?.subscription_state?.status === \"past_due\"\nexport const isSubscriptionTrialing = (user) => user?.subscription_state?.status === \"on_trial\"\n\nexport const subscriptionPausePeriod = user => moment(user?.subscription_state?.end_date).isBefore(user?.subscription_state?.planned_start_date) ? `du ${formatDate(user?.subscription_state?.end_date)} au ${formatDate(moment(user?.subscription_state?.planned_start_date))}` : \"\"\n","import React, {useContext} from \"react\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport {TouchableOpacity, View} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport live from \"../../../../assets/icons/generic/live.png\";\nimport TextM from \"@common/components/text/TextM\";\nimport {formatFullDateTime, plr, readableDayTime} from \"@data/utility/Utils\";\nimport moment from \"moment\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport {BadgeM} from \"@common/components/badge/BadgeM\";\n\nexport const findClosestNextOccurrence = (liveSessions) => {\n\n // console.log(\"liveSessions\", liveSessions?.map(x => x?.id))\n\n // 1. Extract all next occurrences from the LiveSessions\n const notFinishedOccurrences = (liveSessions?.length > 0 && !!liveSessions?.[0])\n ? liveSessions?.reduce((pValue, cValue) => {\n\n return cValue?.next_occurrences ? [\n ...pValue,\n ...cValue.next_occurrences\n ] : [...pValue]\n }, [])\n // 2. Filter out any occurrence that is already finished\n ?.filter(occurrence => !occurrence?.finalized_at)\n // 3. Sort the remaining occurrences to find the closest one.\n ?.sort((a, b) => {\n return moment(a?.date).diff(b?.date)\n })\n : null\n\n // console.log(\"notFinishedOccurrences?.[0]\", notFinishedOccurrences?.[0])\n\n // 4. Return this closest occurrence\n return notFinishedOccurrences?.[0]\n\n\n // //old version to be deleted\n // if (!notFinishedOccurrences || notFinishedOccurrences?.length === 0) return null\n //\n // const todayNotFinishedOccurrences = notFinishedOccurrences?.filter(occurrence => moment(occurrence?.date).isSame(moment(), \"day\"))\n // // console.log(\"todayNotFinishedOccurrences\", todayNotFinishedOccurrences)\n //\n // if (todayNotFinishedOccurrences?.length > 0) {\n //\n // const sortedTodayNotFinishedOccurrences = todayNotFinishedOccurrences?.sort((a, b) => {\n // return Math.abs(moment().diff(a?.date)) - Math.abs(moment().diff(b?.date))\n // })\n // console.log(\"closest = today\", sortedTodayNotFinishedOccurrences?.[0])\n //\n // return sortedTodayNotFinishedOccurrences?.[0]\n // } else {\n // console.log(\"closest = NOT today\", notFinishedOccurrences?.sort((a, b) => {\n // return moment(a?.date).diff(b?.date)\n // })?.[0])\n //\n // return notFinishedOccurrences?.sort((a, b) => {\n // return moment(a?.date).diff(b?.date)\n // })?.[0]\n // }\n}\nconst LiveRoomCard = ({\n liveRoom,\n tutor,\n onPress = null,\n description,\n hideAvailablePlaces = false,\n style,\n badgeCount,\n disabled = false,\n width = null,\n showLiveRoomName = false,\n hideSlots = false\n }) => {\n\n const dimensions = useContext(DimensionsContext)\n\n const closestNextOccurrence = findClosestNextOccurrence(liveRoom?.live_sessions)\n\n // console.log(\"liveRoom\", liveRoom)\n\n const availablePlaces = tutor?.profile?.max_students_per_live - liveRoom?.students_count\n return \n \n \n \n {badgeCount > 0 && }\n \n {showLiveRoomName && LIVE - {liveRoom?.name}}\n\n {!hideSlots && <>{liveRoom?.live_sessions?.map((ls, index) => {readableDayTime(ls?.day_time, ls?.duration)})}}\n {\"Prochaine session \" + formatFullDateTime(closestNextOccurrence?.date)}\n {!!onPress && !hideAvailablePlaces && {availablePlaces} {plr(\"place\", availablePlaces)} {plr(\"disponible\", availablePlaces)}}\n {description && {description}}\n \n \n {!!onPress && !disabled && \n \n }\n \n \n}\nexport default LiveRoomCard","import './js/ios10Fix';\n\nimport packageJson from './package.json';\n\nexport * from './js/URL';\nexport * from './js/URLSearchParams';\n\nexport function setupURLPolyfill() {\n globalThis.REACT_NATIVE_URL_POLYFILL = `${packageJson.name}@${packageJson.version}`;\n\n globalThis.URL = require('./js/URL').URL;\n globalThis.URLSearchParams = require('./js/URLSearchParams').URLSearchParams;\n}\n","/**\n * There's a bug happening on iOS 10 where `ArrayBuffer.prototype.byteLength`\n * is not defined, but present on the object returned by the function/constructor\n * See https://github.com/charpeni/react-native-url-polyfill/issues/190\n * */\n\nimport {Platform} from 'react-native';\n\nconst majorVersionIOS = parseInt(Platform.Version, 10);\n\nif (Platform.OS === 'ios' && majorVersionIOS === 10) {\n if (\n Object.getOwnPropertyDescriptor(ArrayBuffer.prototype, 'byteLength') == null\n ) {\n // eslint-disable-next-line no-extend-native\n Object.defineProperty(ArrayBuffer.prototype, 'byteLength', {\n configurable: true,\n enumerable: false,\n get() {\n return null;\n },\n });\n }\n}\n","{\n \"name\": \"react-native-url-polyfill\",\n \"version\": \"2.0.0\",\n \"description\": \"A lightweight and trustworthy URL polyfill for React Native\",\n \"keywords\": [\n \"URL\",\n \"URLSearchParams\",\n \"polyfill\",\n \"react native\",\n \"whatwg-url\"\n ],\n \"bugs\": {\n \"url\": \"https://github.com/charpeni/react-native-url-polyfill/issues\"\n },\n \"homepage\": \"https://github.com/charpeni/react-native-url-polyfill\",\n \"readme\": \"https://github.com/charpeni/react-native-url-polyfill#readme\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/charpeni/react-native-url-polyfill.git\"\n },\n \"main\": \"index.js\",\n \"types\": \"index.d.ts\",\n \"scripts\": {\n \"test\": \"jest\",\n \"lint\": \"eslint .\",\n \"prepare\": \"husky install\",\n \"bundle-size\": \"node scripts/bundle-size\"\n },\n \"author\": \"Nicolas Charpentier \",\n \"license\": \"MIT\",\n \"dependencies\": {\n \"whatwg-url-without-unicode\": \"8.0.0-3\"\n },\n \"devDependencies\": {\n \"@react-native-community/eslint-config\": \"3.2.0\",\n \"detox\": \"20.9.1\",\n \"eslint\": \"8.44.0\",\n \"eslint-plugin-prettier\": \"4.2.1\",\n \"husky\": \"8.0.3\",\n \"jest\": \"29.5.0\",\n \"lint-staged\": \"13.2.3\",\n \"metro-react-native-babel-preset\": \"0.76.7\",\n \"nanoid\": \"3.3.6\",\n \"prettier\": \"2.8.8\",\n \"react\": \"18.2.0\",\n \"react-native\": \"0.72.1\",\n \"react-native-bundle-scale\": \"1.1.0\",\n \"typescript\": \"5.1.6\"\n },\n \"peerDependencies\": {\n \"react-native\": \"*\"\n },\n \"jest\": {\n \"preset\": \"react-native\",\n \"testPathIgnorePatterns\": [\n \"/node_modules/\",\n \"./platforms/\"\n ]\n },\n \"lint-staged\": {\n \"*.js\": [\n \"eslint --fix\"\n ]\n }\n}\n","import {NativeModules} from 'react-native';\nimport {URL as whatwgUrl} from 'whatwg-url-without-unicode';\n\nlet BLOB_URL_PREFIX = null;\n\nconst {BlobModule} = NativeModules;\n\nif (BlobModule && typeof BlobModule.BLOB_URI_SCHEME === 'string') {\n BLOB_URL_PREFIX = BlobModule.BLOB_URI_SCHEME + ':';\n if (typeof BlobModule.BLOB_URI_HOST === 'string') {\n BLOB_URL_PREFIX += `//${BlobModule.BLOB_URI_HOST}/`;\n }\n}\n\n/**\n * To allow Blobs be accessed via `content://` URIs,\n * you need to register `BlobProvider` as a ContentProvider in your app's `AndroidManifest.xml`:\n *\n * ```xml\n * \n * \n * \n * \n * \n * ```\n * And then define the `blob_provider_authority` string in `res/values/strings.xml`.\n * Use a dotted name that's entirely unique to your app:\n *\n * ```xml\n * \n * your.app.package.blobs\n * \n * ```\n */\n\nwhatwgUrl.createObjectURL = function createObjectURL(blob) {\n if (BLOB_URL_PREFIX === null) {\n throw new Error('Cannot create URL for blob!');\n }\n return `${BLOB_URL_PREFIX}${blob.data.blobId}?offset=${blob.data.offset}&size=${blob.size}`;\n};\n\nwhatwgUrl.revokeObjectURL = function revokeObjectURL(url) {\n // Do nothing.\n};\n\nexport const URL = whatwgUrl;\n","\"use strict\";\n\nconst { URL, URLSearchParams } = require(\"./webidl2js-wrapper\");\nconst urlStateMachine = require(\"./lib/url-state-machine\");\nconst urlEncoded = require(\"./lib/urlencoded\");\n\nconst sharedGlobalObject = {};\nURL.install(sharedGlobalObject);\nURLSearchParams.install(sharedGlobalObject);\n\nexports.URL = sharedGlobalObject.URL;\nexports.URLSearchParams = sharedGlobalObject.URLSearchParams;\n\nexports.parseURL = urlStateMachine.parseURL;\nexports.basicURLParse = urlStateMachine.basicURLParse;\nexports.serializeURL = urlStateMachine.serializeURL;\nexports.serializeHost = urlStateMachine.serializeHost;\nexports.serializeInteger = urlStateMachine.serializeInteger;\nexports.serializeURLOrigin = urlStateMachine.serializeURLOrigin;\nexports.setTheUsername = urlStateMachine.setTheUsername;\nexports.setThePassword = urlStateMachine.setThePassword;\nexports.cannotHaveAUsernamePasswordPort = urlStateMachine.cannotHaveAUsernamePasswordPort;\n\nexports.percentDecode = urlEncoded.percentDecode;\n","\"use strict\";\n\nconst URL = require(\"./lib/URL\");\nconst URLSearchParams = require(\"./lib/URLSearchParams\");\n\nexports.URL = URL;\nexports.URLSearchParams = URLSearchParams;\n","\"use strict\";\n\nconst conversions = require(\"webidl-conversions\");\nconst utils = require(\"./utils.js\");\n\nconst impl = utils.implSymbol;\nconst ctorRegistry = utils.ctorRegistrySymbol;\n\nconst iface = {\n // When an interface-module that implements this interface as a mixin is loaded, it will append its own `.is()`\n // method into this array. It allows objects that directly implements *those* interfaces to be recognized as\n // implementing this mixin interface.\n _mixedIntoPredicates: [],\n is(obj) {\n if (obj) {\n if (utils.hasOwn(obj, impl) && obj[impl] instanceof Impl.implementation) {\n return true;\n }\n for (const isMixedInto of module.exports._mixedIntoPredicates) {\n if (isMixedInto(obj)) {\n return true;\n }\n }\n }\n return false;\n },\n isImpl(obj) {\n if (obj) {\n if (obj instanceof Impl.implementation) {\n return true;\n }\n\n const wrapper = utils.wrapperForImpl(obj);\n for (const isMixedInto of module.exports._mixedIntoPredicates) {\n if (isMixedInto(wrapper)) {\n return true;\n }\n }\n }\n return false;\n },\n convert(obj, { context = \"The provided value\" } = {}) {\n if (module.exports.is(obj)) {\n return utils.implForWrapper(obj);\n }\n throw new TypeError(`${context} is not of type 'URL'.`);\n },\n\n create(globalObject, constructorArgs, privateData) {\n if (globalObject[ctorRegistry] === undefined) {\n throw new Error(\"Internal error: invalid global object\");\n }\n\n const ctor = globalObject[ctorRegistry][\"URL\"];\n if (ctor === undefined) {\n throw new Error(\"Internal error: constructor URL is not installed on the passed global object\");\n }\n\n let obj = Object.create(ctor.prototype);\n obj = iface.setup(obj, globalObject, constructorArgs, privateData);\n return obj;\n },\n createImpl(globalObject, constructorArgs, privateData) {\n const obj = iface.create(globalObject, constructorArgs, privateData);\n return utils.implForWrapper(obj);\n },\n _internalSetup(obj) {},\n setup(obj, globalObject, constructorArgs = [], privateData = {}) {\n privateData.wrapper = obj;\n\n iface._internalSetup(obj);\n Object.defineProperty(obj, impl, {\n value: new Impl.implementation(globalObject, constructorArgs, privateData),\n configurable: true });\n\n\n obj[impl][utils.wrapperSymbol] = obj;\n if (Impl.init) {\n Impl.init(obj[impl], privateData);\n }\n return obj;\n },\n\n install(globalObject) {\n class URL {\n constructor(url) {\n if (arguments.length < 1) {\n throw new TypeError(\n \"Failed to construct 'URL': 1 argument required, but only \" + arguments.length + \" present.\");\n\n }\n const args = [];\n {\n let curArg = arguments[0];\n curArg = conversions[\"USVString\"](curArg, { context: \"Failed to construct 'URL': parameter 1\" });\n args.push(curArg);\n }\n {\n let curArg = arguments[1];\n if (curArg !== undefined) {\n curArg = conversions[\"USVString\"](curArg, { context: \"Failed to construct 'URL': parameter 2\" });\n }\n args.push(curArg);\n }\n return iface.setup(Object.create(this.constructor.prototype), globalObject, args);\n }\n\n toJSON() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl].toJSON();\n }\n\n get href() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"href\"];\n }\n\n set href(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, { context: \"Failed to set the 'href' property on 'URL': The provided value\" });\n\n this[impl][\"href\"] = V;\n }\n\n toString() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n return this[impl][\"href\"];\n }\n\n get origin() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"origin\"];\n }\n\n get protocol() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"protocol\"];\n }\n\n set protocol(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, {\n context: \"Failed to set the 'protocol' property on 'URL': The provided value\" });\n\n\n this[impl][\"protocol\"] = V;\n }\n\n get username() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"username\"];\n }\n\n set username(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, {\n context: \"Failed to set the 'username' property on 'URL': The provided value\" });\n\n\n this[impl][\"username\"] = V;\n }\n\n get password() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"password\"];\n }\n\n set password(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, {\n context: \"Failed to set the 'password' property on 'URL': The provided value\" });\n\n\n this[impl][\"password\"] = V;\n }\n\n get host() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"host\"];\n }\n\n set host(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, { context: \"Failed to set the 'host' property on 'URL': The provided value\" });\n\n this[impl][\"host\"] = V;\n }\n\n get hostname() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"hostname\"];\n }\n\n set hostname(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, {\n context: \"Failed to set the 'hostname' property on 'URL': The provided value\" });\n\n\n this[impl][\"hostname\"] = V;\n }\n\n get port() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"port\"];\n }\n\n set port(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, { context: \"Failed to set the 'port' property on 'URL': The provided value\" });\n\n this[impl][\"port\"] = V;\n }\n\n get pathname() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"pathname\"];\n }\n\n set pathname(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, {\n context: \"Failed to set the 'pathname' property on 'URL': The provided value\" });\n\n\n this[impl][\"pathname\"] = V;\n }\n\n get search() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"search\"];\n }\n\n set search(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, {\n context: \"Failed to set the 'search' property on 'URL': The provided value\" });\n\n\n this[impl][\"search\"] = V;\n }\n\n get searchParams() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return utils.getSameObject(this, \"searchParams\", () => {\n return utils.tryWrapperForImpl(this[impl][\"searchParams\"]);\n });\n }\n\n get hash() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl][\"hash\"];\n }\n\n set hash(V) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n V = conversions[\"USVString\"](V, { context: \"Failed to set the 'hash' property on 'URL': The provided value\" });\n\n this[impl][\"hash\"] = V;\n }}\n\n Object.defineProperties(URL.prototype, {\n toJSON: { enumerable: true },\n href: { enumerable: true },\n toString: { enumerable: true },\n origin: { enumerable: true },\n protocol: { enumerable: true },\n username: { enumerable: true },\n password: { enumerable: true },\n host: { enumerable: true },\n hostname: { enumerable: true },\n port: { enumerable: true },\n pathname: { enumerable: true },\n search: { enumerable: true },\n searchParams: { enumerable: true },\n hash: { enumerable: true },\n [Symbol.toStringTag]: { value: \"URL\", configurable: true } });\n\n if (globalObject[ctorRegistry] === undefined) {\n globalObject[ctorRegistry] = Object.create(null);\n }\n globalObject[ctorRegistry][\"URL\"] = URL;\n\n Object.defineProperty(globalObject, \"URL\", {\n configurable: true,\n writable: true,\n value: URL });\n\n } };\n// iface\nmodule.exports = iface;\n\nconst Impl = require(\"./URL-impl.js\");","\"use strict\";\n\nfunction _(message, opts) {\n return `${opts && opts.context ? opts.context : \"Value\"} ${message}.`;\n}\n\nfunction type(V) {\n if (V === null) {\n return \"Null\";\n }\n switch (typeof V) {\n case \"undefined\":\n return \"Undefined\";\n case \"boolean\":\n return \"Boolean\";\n case \"number\":\n return \"Number\";\n case \"string\":\n return \"String\";\n case \"symbol\":\n return \"Symbol\";\n case \"object\":\n // Falls through\n case \"function\":\n // Falls through\n default:\n // Per ES spec, typeof returns an implemention-defined value that is not any of the existing ones for\n // uncallable non-standard exotic objects. Yet Type() which the Web IDL spec depends on returns Object for\n // such cases. So treat the default case as an object.\n return \"Object\";\n }\n}\n\n// Round x to the nearest integer, choosing the even integer if it lies halfway between two.\nfunction evenRound(x) {\n // There are four cases for numbers with fractional part being .5:\n //\n // case | x | floor(x) | round(x) | expected | x <> 0 | x % 1 | x & 1 | example\n // 1 | 2n + 0.5 | 2n | 2n + 1 | 2n | > | 0.5 | 0 | 0.5 -> 0\n // 2 | 2n + 1.5 | 2n + 1 | 2n + 2 | 2n + 2 | > | 0.5 | 1 | 1.5 -> 2\n // 3 | -2n - 0.5 | -2n - 1 | -2n | -2n | < | -0.5 | 0 | -0.5 -> 0\n // 4 | -2n - 1.5 | -2n - 2 | -2n - 1 | -2n - 2 | < | -0.5 | 1 | -1.5 -> -2\n // (where n is a non-negative integer)\n //\n // Branch here for cases 1 and 4\n if ((x > 0 && (x % 1) === +0.5 && (x & 1) === 0) ||\n (x < 0 && (x % 1) === -0.5 && (x & 1) === 1)) {\n return censorNegativeZero(Math.floor(x));\n }\n\n return censorNegativeZero(Math.round(x));\n}\n\nfunction integerPart(n) {\n return censorNegativeZero(Math.trunc(n));\n}\n\nfunction sign(x) {\n return x < 0 ? -1 : 1;\n}\n\nfunction modulo(x, y) {\n // https://tc39.github.io/ecma262/#eqn-modulo\n // Note that http://stackoverflow.com/a/4467559/3191 does NOT work for large modulos\n const signMightNotMatch = x % y;\n if (sign(y) !== sign(signMightNotMatch)) {\n return signMightNotMatch + y;\n }\n return signMightNotMatch;\n}\n\nfunction censorNegativeZero(x) {\n return x === 0 ? 0 : x;\n}\n\nfunction createIntegerConversion(bitLength, typeOpts) {\n const isSigned = !typeOpts.unsigned;\n\n let lowerBound;\n let upperBound;\n if (bitLength === 64) {\n upperBound = Math.pow(2, 53) - 1;\n lowerBound = !isSigned ? 0 : -Math.pow(2, 53) + 1;\n } else if (!isSigned) {\n lowerBound = 0;\n upperBound = Math.pow(2, bitLength) - 1;\n } else {\n lowerBound = -Math.pow(2, bitLength - 1);\n upperBound = Math.pow(2, bitLength - 1) - 1;\n }\n\n const twoToTheBitLength = Math.pow(2, bitLength);\n const twoToOneLessThanTheBitLength = Math.pow(2, bitLength - 1);\n\n return (V, opts) => {\n if (opts === undefined) {\n opts = {};\n }\n\n let x = +V;\n x = censorNegativeZero(x); // Spec discussion ongoing: https://github.com/heycam/webidl/issues/306\n\n if (opts.enforceRange) {\n if (!Number.isFinite(x)) {\n throw new TypeError(_(\"is not a finite number\", opts));\n }\n\n x = integerPart(x);\n\n if (x < lowerBound || x > upperBound) {\n throw new TypeError(_(\n `is outside the accepted range of ${lowerBound} to ${upperBound}, inclusive`, opts));\n }\n\n return x;\n }\n\n if (!Number.isNaN(x) && opts.clamp) {\n x = Math.min(Math.max(x, lowerBound), upperBound);\n x = evenRound(x);\n return x;\n }\n\n if (!Number.isFinite(x) || x === 0) {\n return 0;\n }\n x = integerPart(x);\n\n // Math.pow(2, 64) is not accurately representable in JavaScript, so try to avoid these per-spec operations if\n // possible. Hopefully it's an optimization for the non-64-bitLength cases too.\n if (x >= lowerBound && x <= upperBound) {\n return x;\n }\n\n // These will not work great for bitLength of 64, but oh well. See the README for more details.\n x = modulo(x, twoToTheBitLength);\n if (isSigned && x >= twoToOneLessThanTheBitLength) {\n return x - twoToTheBitLength;\n }\n return x;\n };\n}\n\nexports.any = V => {\n return V;\n};\n\nexports.void = function () {\n return undefined;\n};\n\nexports.boolean = function (val) {\n return !!val;\n};\n\nexports.byte = createIntegerConversion(8, { unsigned: false });\nexports.octet = createIntegerConversion(8, { unsigned: true });\n\nexports.short = createIntegerConversion(16, { unsigned: false });\nexports[\"unsigned short\"] = createIntegerConversion(16, { unsigned: true });\n\nexports.long = createIntegerConversion(32, { unsigned: false });\nexports[\"unsigned long\"] = createIntegerConversion(32, { unsigned: true });\n\nexports[\"long long\"] = createIntegerConversion(64, { unsigned: false });\nexports[\"unsigned long long\"] = createIntegerConversion(64, { unsigned: true });\n\nexports.double = (V, opts) => {\n const x = +V;\n\n if (!Number.isFinite(x)) {\n throw new TypeError(_(\"is not a finite floating-point value\", opts));\n }\n\n return x;\n};\n\nexports[\"unrestricted double\"] = V => {\n const x = +V;\n\n return x;\n};\n\nexports.float = (V, opts) => {\n const x = +V;\n\n if (!Number.isFinite(x)) {\n throw new TypeError(_(\"is not a finite floating-point value\", opts));\n }\n\n if (Object.is(x, -0)) {\n return x;\n }\n\n const y = Math.fround(x);\n\n if (!Number.isFinite(y)) {\n throw new TypeError(_(\"is outside the range of a single-precision floating-point value\", opts));\n }\n\n return y;\n};\n\nexports[\"unrestricted float\"] = V => {\n const x = +V;\n\n if (isNaN(x)) {\n return x;\n }\n\n if (Object.is(x, -0)) {\n return x;\n }\n\n return Math.fround(x);\n};\n\nexports.DOMString = function (V, opts) {\n if (opts === undefined) {\n opts = {};\n }\n\n if (opts.treatNullAsEmptyString && V === null) {\n return \"\";\n }\n\n if (typeof V === \"symbol\") {\n throw new TypeError(_(\"is a symbol, which cannot be converted to a string\", opts));\n }\n\n return String(V);\n};\n\nexports.ByteString = (V, opts) => {\n const x = exports.DOMString(V, opts);\n let c;\n for (let i = 0; (c = x.codePointAt(i)) !== undefined; ++i) {\n if (c > 255) {\n throw new TypeError(_(\"is not a valid ByteString\", opts));\n }\n }\n\n return x;\n};\n\nexports.USVString = (V, opts) => {\n const S = exports.DOMString(V, opts);\n const n = S.length;\n const U = [];\n for (let i = 0; i < n; ++i) {\n const c = S.charCodeAt(i);\n if (c < 0xD800 || c > 0xDFFF) {\n U.push(String.fromCodePoint(c));\n } else if (0xDC00 <= c && c <= 0xDFFF) {\n U.push(String.fromCodePoint(0xFFFD));\n } else if (i === n - 1) {\n U.push(String.fromCodePoint(0xFFFD));\n } else {\n const d = S.charCodeAt(i + 1);\n if (0xDC00 <= d && d <= 0xDFFF) {\n const a = c & 0x3FF;\n const b = d & 0x3FF;\n U.push(String.fromCodePoint((2 << 15) + ((2 << 9) * a) + b));\n ++i;\n } else {\n U.push(String.fromCodePoint(0xFFFD));\n }\n }\n }\n\n return U.join(\"\");\n};\n\nexports.object = (V, opts) => {\n if (type(V) !== \"Object\") {\n throw new TypeError(_(\"is not an object\", opts));\n }\n\n return V;\n};\n\n// Not exported, but used in Function and VoidFunction.\n\n// Neither Function nor VoidFunction is defined with [TreatNonObjectAsNull], so\n// handling for that is omitted.\nfunction convertCallbackFunction(V, opts) {\n if (typeof V !== \"function\") {\n throw new TypeError(_(\"is not a function\", opts));\n }\n return V;\n}\n\nconst abByteLengthGetter =\n Object.getOwnPropertyDescriptor(ArrayBuffer.prototype, \"byteLength\").get;\n\nfunction isArrayBuffer(V) {\n try {\n abByteLengthGetter.call(V);\n return true;\n } catch (e) {\n return false;\n }\n}\n\n// I don't think we can reliably detect detached ArrayBuffers.\nexports.ArrayBuffer = (V, opts) => {\n if (!isArrayBuffer(V)) {\n throw new TypeError(_(\"is not a view on an ArrayBuffer object\", opts));\n }\n return V;\n};\n\nconst dvByteLengthGetter =\n Object.getOwnPropertyDescriptor(DataView.prototype, \"byteLength\").get;\nexports.DataView = (V, opts) => {\n try {\n dvByteLengthGetter.call(V);\n return V;\n } catch (e) {\n throw new TypeError(_(\"is not a view on an DataView object\", opts));\n }\n};\n\n[\n Int8Array, Int16Array, Int32Array, Uint8Array,\n Uint16Array, Uint32Array, Uint8ClampedArray, Float32Array, Float64Array\n].forEach(func => {\n const name = func.name;\n const article = /^[AEIOU]/.test(name) ? \"an\" : \"a\";\n exports[name] = (V, opts) => {\n if (!ArrayBuffer.isView(V) || V.constructor.name !== name) {\n throw new TypeError(_(`is not ${article} ${name} object`, opts));\n }\n\n return V;\n };\n});\n\n// Common definitions\n\nexports.ArrayBufferView = (V, opts) => {\n if (!ArrayBuffer.isView(V)) {\n throw new TypeError(_(\"is not a view on an ArrayBuffer object\", opts));\n }\n\n return V;\n};\n\nexports.BufferSource = (V, opts) => {\n if (!ArrayBuffer.isView(V) && !isArrayBuffer(V)) {\n throw new TypeError(_(\"is not an ArrayBuffer object or a view on one\", opts));\n }\n\n return V;\n};\n\nexports.DOMTimeStamp = exports[\"unsigned long long\"];\n\nexports.Function = convertCallbackFunction;\n\nexports.VoidFunction = convertCallbackFunction;\n","\"use strict\";\n\n// Returns \"Type(value) is Object\" in ES terminology.\nfunction isObject(value) {\n return typeof value === \"object\" && value !== null || typeof value === \"function\";\n}\n\nfunction hasOwn(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nconst wrapperSymbol = Symbol(\"wrapper\");\nconst implSymbol = Symbol(\"impl\");\nconst sameObjectCaches = Symbol(\"SameObject caches\");\nconst ctorRegistrySymbol = Symbol.for(\"[webidl2js] constructor registry\");\n\nfunction getSameObject(wrapper, prop, creator) {\n if (!wrapper[sameObjectCaches]) {\n wrapper[sameObjectCaches] = Object.create(null);\n }\n\n if (prop in wrapper[sameObjectCaches]) {\n return wrapper[sameObjectCaches][prop];\n }\n\n wrapper[sameObjectCaches][prop] = creator();\n return wrapper[sameObjectCaches][prop];\n}\n\nfunction wrapperForImpl(impl) {\n return impl ? impl[wrapperSymbol] : null;\n}\n\nfunction implForWrapper(wrapper) {\n return wrapper ? wrapper[implSymbol] : null;\n}\n\nfunction tryWrapperForImpl(impl) {\n const wrapper = wrapperForImpl(impl);\n return wrapper ? wrapper : impl;\n}\n\nfunction tryImplForWrapper(wrapper) {\n const impl = implForWrapper(wrapper);\n return impl ? impl : wrapper;\n}\n\nconst iterInternalSymbol = Symbol(\"internal\");\nconst IteratorPrototype = Object.getPrototypeOf(Object.getPrototypeOf([][Symbol.iterator]()));\n\nfunction isArrayIndexPropName(P) {\n if (typeof P !== \"string\") {\n return false;\n }\n const i = P >>> 0;\n if (i === Math.pow(2, 32) - 1) {\n return false;\n }\n const s = `${i}`;\n if (P !== s) {\n return false;\n }\n return true;\n}\n\nconst byteLengthGetter =\n Object.getOwnPropertyDescriptor(ArrayBuffer.prototype, \"byteLength\").get;\nfunction isArrayBuffer(value) {\n try {\n byteLengthGetter.call(value);\n return true;\n } catch (e) {\n return false;\n }\n}\n\nconst supportsPropertyIndex = Symbol(\"supports property index\");\nconst supportedPropertyIndices = Symbol(\"supported property indices\");\nconst supportsPropertyName = Symbol(\"supports property name\");\nconst supportedPropertyNames = Symbol(\"supported property names\");\nconst indexedGet = Symbol(\"indexed property get\");\nconst indexedSetNew = Symbol(\"indexed property set new\");\nconst indexedSetExisting = Symbol(\"indexed property set existing\");\nconst namedGet = Symbol(\"named property get\");\nconst namedSetNew = Symbol(\"named property set new\");\nconst namedSetExisting = Symbol(\"named property set existing\");\nconst namedDelete = Symbol(\"named property delete\");\n\nmodule.exports = exports = {\n isObject,\n hasOwn,\n wrapperSymbol,\n implSymbol,\n getSameObject,\n ctorRegistrySymbol,\n wrapperForImpl,\n implForWrapper,\n tryWrapperForImpl,\n tryImplForWrapper,\n iterInternalSymbol,\n IteratorPrototype,\n isArrayBuffer,\n isArrayIndexPropName,\n supportsPropertyIndex,\n supportedPropertyIndices,\n supportsPropertyName,\n supportedPropertyNames,\n indexedGet,\n indexedSetNew,\n indexedSetExisting,\n namedGet,\n namedSetNew,\n namedSetExisting,\n namedDelete\n};\n","\"use strict\";\nconst usm = require(\"./url-state-machine\");\nconst urlencoded = require(\"./urlencoded\");\nconst URLSearchParams = require(\"./URLSearchParams\");\n\nexports.implementation = class URLImpl {\n constructor(globalObject, constructorArgs) {\n const url = constructorArgs[0];\n const base = constructorArgs[1];\n\n let parsedBase = null;\n if (base !== undefined) {\n parsedBase = usm.basicURLParse(base);\n if (parsedBase === null) {\n throw new TypeError(`Invalid base URL: ${base}`);\n }\n }\n\n const parsedURL = usm.basicURLParse(url, { baseURL: parsedBase });\n if (parsedURL === null) {\n throw new TypeError(`Invalid URL: ${url}`);\n }\n\n const query = parsedURL.query !== null ? parsedURL.query : \"\";\n\n this._url = parsedURL;\n\n // We cannot invoke the \"new URLSearchParams object\" algorithm without going through the constructor, which strips\n // question mark by default. Therefore the doNotStripQMark hack is used.\n this._query = URLSearchParams.createImpl(globalObject, [query], { doNotStripQMark: true });\n this._query._url = this;\n }\n\n get href() {\n return usm.serializeURL(this._url);\n }\n\n set href(v) {\n const parsedURL = usm.basicURLParse(v);\n if (parsedURL === null) {\n throw new TypeError(`Invalid URL: ${v}`);\n }\n\n this._url = parsedURL;\n\n this._query._list.splice(0);\n const { query } = parsedURL;\n if (query !== null) {\n this._query._list = urlencoded.parseUrlencoded(query);\n }\n }\n\n get origin() {\n return usm.serializeURLOrigin(this._url);\n }\n\n get protocol() {\n return this._url.scheme + \":\";\n }\n\n set protocol(v) {\n usm.basicURLParse(v + \":\", { url: this._url, stateOverride: \"scheme start\" });\n }\n\n get username() {\n return this._url.username;\n }\n\n set username(v) {\n if (usm.cannotHaveAUsernamePasswordPort(this._url)) {\n return;\n }\n\n usm.setTheUsername(this._url, v);\n }\n\n get password() {\n return this._url.password;\n }\n\n set password(v) {\n if (usm.cannotHaveAUsernamePasswordPort(this._url)) {\n return;\n }\n\n usm.setThePassword(this._url, v);\n }\n\n get host() {\n const url = this._url;\n\n if (url.host === null) {\n return \"\";\n }\n\n if (url.port === null) {\n return usm.serializeHost(url.host);\n }\n\n return usm.serializeHost(url.host) + \":\" + usm.serializeInteger(url.port);\n }\n\n set host(v) {\n if (this._url.cannotBeABaseURL) {\n return;\n }\n\n usm.basicURLParse(v, { url: this._url, stateOverride: \"host\" });\n }\n\n get hostname() {\n if (this._url.host === null) {\n return \"\";\n }\n\n return usm.serializeHost(this._url.host);\n }\n\n set hostname(v) {\n if (this._url.cannotBeABaseURL) {\n return;\n }\n\n usm.basicURLParse(v, { url: this._url, stateOverride: \"hostname\" });\n }\n\n get port() {\n if (this._url.port === null) {\n return \"\";\n }\n\n return usm.serializeInteger(this._url.port);\n }\n\n set port(v) {\n if (usm.cannotHaveAUsernamePasswordPort(this._url)) {\n return;\n }\n\n if (v === \"\") {\n this._url.port = null;\n } else {\n usm.basicURLParse(v, { url: this._url, stateOverride: \"port\" });\n }\n }\n\n get pathname() {\n if (this._url.cannotBeABaseURL) {\n return this._url.path[0];\n }\n\n if (this._url.path.length === 0) {\n return \"\";\n }\n\n return \"/\" + this._url.path.join(\"/\");\n }\n\n set pathname(v) {\n if (this._url.cannotBeABaseURL) {\n return;\n }\n\n this._url.path = [];\n usm.basicURLParse(v, { url: this._url, stateOverride: \"path start\" });\n }\n\n get search() {\n if (this._url.query === null || this._url.query === \"\") {\n return \"\";\n }\n\n return \"?\" + this._url.query;\n }\n\n set search(v) {\n const url = this._url;\n\n if (v === \"\") {\n url.query = null;\n this._query._list = [];\n return;\n }\n\n const input = v[0] === \"?\" ? v.substring(1) : v;\n url.query = \"\";\n usm.basicURLParse(input, { url, stateOverride: \"query\" });\n this._query._list = urlencoded.parseUrlencoded(input);\n }\n\n get searchParams() {\n return this._query;\n }\n\n get hash() {\n if (this._url.fragment === null || this._url.fragment === \"\") {\n return \"\";\n }\n\n return \"#\" + this._url.fragment;\n }\n\n set hash(v) {\n if (v === \"\") {\n this._url.fragment = null;\n return;\n }\n\n const input = v[0] === \"#\" ? v.substring(1) : v;\n this._url.fragment = \"\";\n usm.basicURLParse(input, { url: this._url, stateOverride: \"fragment\" });\n }\n\n toJSON() {\n return this.href;\n }\n};\n","\"use strict\";\nconst { Buffer } = require(\"buffer/\");\nconst punycode = require(\"punycode\");\n\nconst infra = require(\"./infra\");\nconst { percentEncode, percentDecode } = require(\"./urlencoded\");\n\nconst specialSchemes = {\n ftp: 21,\n file: null,\n http: 80,\n https: 443,\n ws: 80,\n wss: 443\n};\n\nconst failure = Symbol(\"failure\");\n\nfunction countSymbols(str) {\n return punycode.ucs2.decode(str).length;\n}\n\nfunction at(input, idx) {\n const c = input[idx];\n return isNaN(c) ? undefined : String.fromCodePoint(c);\n}\n\nfunction isSingleDot(buffer) {\n return buffer === \".\" || buffer.toLowerCase() === \"%2e\";\n}\n\nfunction isDoubleDot(buffer) {\n buffer = buffer.toLowerCase();\n return buffer === \"..\" || buffer === \"%2e.\" || buffer === \".%2e\" || buffer === \"%2e%2e\";\n}\n\nfunction isWindowsDriveLetterCodePoints(cp1, cp2) {\n return infra.isASCIIAlpha(cp1) && (cp2 === 58 || cp2 === 124);\n}\n\nfunction isWindowsDriveLetterString(string) {\n return string.length === 2 && infra.isASCIIAlpha(string.codePointAt(0)) && (string[1] === \":\" || string[1] === \"|\");\n}\n\nfunction isNormalizedWindowsDriveLetterString(string) {\n return string.length === 2 && infra.isASCIIAlpha(string.codePointAt(0)) && string[1] === \":\";\n}\n\nfunction containsForbiddenHostCodePoint(string) {\n return string.search(/\\u0000|\\u0009|\\u000A|\\u000D|\\u0020|#|%|\\/|:|\\?|@|\\[|\\\\|\\]/) !== -1;\n}\n\nfunction containsForbiddenHostCodePointExcludingPercent(string) {\n return string.search(/\\u0000|\\u0009|\\u000A|\\u000D|\\u0020|#|\\/|:|\\?|@|\\[|\\\\|\\]/) !== -1;\n}\n\nfunction isSpecialScheme(scheme) {\n return specialSchemes[scheme] !== undefined;\n}\n\nfunction isSpecial(url) {\n return isSpecialScheme(url.scheme);\n}\n\nfunction isNotSpecial(url) {\n return !isSpecialScheme(url.scheme);\n}\n\nfunction defaultPort(scheme) {\n return specialSchemes[scheme];\n}\n\nfunction utf8PercentEncode(c) {\n const buf = Buffer.from(c);\n\n let str = \"\";\n\n for (let i = 0; i < buf.length; ++i) {\n str += percentEncode(buf[i]);\n }\n\n return str;\n}\n\nfunction isC0ControlPercentEncode(c) {\n return c <= 0x1F || c > 0x7E;\n}\n\nconst extraUserinfoPercentEncodeSet =\n new Set([47, 58, 59, 61, 64, 91, 92, 93, 94, 124]);\nfunction isUserinfoPercentEncode(c) {\n return isPathPercentEncode(c) || extraUserinfoPercentEncodeSet.has(c);\n}\n\nconst extraFragmentPercentEncodeSet = new Set([32, 34, 60, 62, 96]);\nfunction isFragmentPercentEncode(c) {\n return isC0ControlPercentEncode(c) || extraFragmentPercentEncodeSet.has(c);\n}\n\nconst extraPathPercentEncodeSet = new Set([35, 63, 123, 125]);\nfunction isPathPercentEncode(c) {\n return isFragmentPercentEncode(c) || extraPathPercentEncodeSet.has(c);\n}\n\nfunction percentEncodeChar(c, encodeSetPredicate) {\n const cStr = String.fromCodePoint(c);\n\n if (encodeSetPredicate(c)) {\n return utf8PercentEncode(cStr);\n }\n\n return cStr;\n}\n\nfunction parseIPv4Number(input) {\n let R = 10;\n\n if (input.length >= 2 && input.charAt(0) === \"0\" && input.charAt(1).toLowerCase() === \"x\") {\n input = input.substring(2);\n R = 16;\n } else if (input.length >= 2 && input.charAt(0) === \"0\") {\n input = input.substring(1);\n R = 8;\n }\n\n if (input === \"\") {\n return 0;\n }\n\n let regex = /[^0-7]/;\n if (R === 10) {\n regex = /[^0-9]/;\n }\n if (R === 16) {\n regex = /[^0-9A-Fa-f]/;\n }\n\n if (regex.test(input)) {\n return failure;\n }\n\n return parseInt(input, R);\n}\n\nfunction parseIPv4(input) {\n const parts = input.split(\".\");\n if (parts[parts.length - 1] === \"\") {\n if (parts.length > 1) {\n parts.pop();\n }\n }\n\n if (parts.length > 4) {\n return input;\n }\n\n const numbers = [];\n for (const part of parts) {\n if (part === \"\") {\n return input;\n }\n const n = parseIPv4Number(part);\n if (n === failure) {\n return input;\n }\n\n numbers.push(n);\n }\n\n for (let i = 0; i < numbers.length - 1; ++i) {\n if (numbers[i] > 255) {\n return failure;\n }\n }\n if (numbers[numbers.length - 1] >= Math.pow(256, 5 - numbers.length)) {\n return failure;\n }\n\n let ipv4 = numbers.pop();\n let counter = 0;\n\n for (const n of numbers) {\n ipv4 += n * Math.pow(256, 3 - counter);\n ++counter;\n }\n\n return ipv4;\n}\n\nfunction serializeIPv4(address) {\n let output = \"\";\n let n = address;\n\n for (let i = 1; i <= 4; ++i) {\n output = String(n % 256) + output;\n if (i !== 4) {\n output = \".\" + output;\n }\n n = Math.floor(n / 256);\n }\n\n return output;\n}\n\nfunction parseIPv6(input) {\n const address = [0, 0, 0, 0, 0, 0, 0, 0];\n let pieceIndex = 0;\n let compress = null;\n let pointer = 0;\n\n input = punycode.ucs2.decode(input);\n\n if (input[pointer] === 58) {\n if (input[pointer + 1] !== 58) {\n return failure;\n }\n\n pointer += 2;\n ++pieceIndex;\n compress = pieceIndex;\n }\n\n while (pointer < input.length) {\n if (pieceIndex === 8) {\n return failure;\n }\n\n if (input[pointer] === 58) {\n if (compress !== null) {\n return failure;\n }\n ++pointer;\n ++pieceIndex;\n compress = pieceIndex;\n continue;\n }\n\n let value = 0;\n let length = 0;\n\n while (length < 4 && infra.isASCIIHex(input[pointer])) {\n value = value * 0x10 + parseInt(at(input, pointer), 16);\n ++pointer;\n ++length;\n }\n\n if (input[pointer] === 46) {\n if (length === 0) {\n return failure;\n }\n\n pointer -= length;\n\n if (pieceIndex > 6) {\n return failure;\n }\n\n let numbersSeen = 0;\n\n while (input[pointer] !== undefined) {\n let ipv4Piece = null;\n\n if (numbersSeen > 0) {\n if (input[pointer] === 46 && numbersSeen < 4) {\n ++pointer;\n } else {\n return failure;\n }\n }\n\n if (!infra.isASCIIDigit(input[pointer])) {\n return failure;\n }\n\n while (infra.isASCIIDigit(input[pointer])) {\n const number = parseInt(at(input, pointer));\n if (ipv4Piece === null) {\n ipv4Piece = number;\n } else if (ipv4Piece === 0) {\n return failure;\n } else {\n ipv4Piece = ipv4Piece * 10 + number;\n }\n if (ipv4Piece > 255) {\n return failure;\n }\n ++pointer;\n }\n\n address[pieceIndex] = address[pieceIndex] * 0x100 + ipv4Piece;\n\n ++numbersSeen;\n\n if (numbersSeen === 2 || numbersSeen === 4) {\n ++pieceIndex;\n }\n }\n\n if (numbersSeen !== 4) {\n return failure;\n }\n\n break;\n } else if (input[pointer] === 58) {\n ++pointer;\n if (input[pointer] === undefined) {\n return failure;\n }\n } else if (input[pointer] !== undefined) {\n return failure;\n }\n\n address[pieceIndex] = value;\n ++pieceIndex;\n }\n\n if (compress !== null) {\n let swaps = pieceIndex - compress;\n pieceIndex = 7;\n while (pieceIndex !== 0 && swaps > 0) {\n const temp = address[compress + swaps - 1];\n address[compress + swaps - 1] = address[pieceIndex];\n address[pieceIndex] = temp;\n --pieceIndex;\n --swaps;\n }\n } else if (compress === null && pieceIndex !== 8) {\n return failure;\n }\n\n return address;\n}\n\nfunction serializeIPv6(address) {\n let output = \"\";\n const seqResult = findLongestZeroSequence(address);\n const compress = seqResult.idx;\n let ignore0 = false;\n\n for (let pieceIndex = 0; pieceIndex <= 7; ++pieceIndex) {\n if (ignore0 && address[pieceIndex] === 0) {\n continue;\n } else if (ignore0) {\n ignore0 = false;\n }\n\n if (compress === pieceIndex) {\n const separator = pieceIndex === 0 ? \"::\" : \":\";\n output += separator;\n ignore0 = true;\n continue;\n }\n\n output += address[pieceIndex].toString(16);\n\n if (pieceIndex !== 7) {\n output += \":\";\n }\n }\n\n return output;\n}\n\nfunction parseHost(input, isNotSpecialArg = false) {\n if (input[0] === \"[\") {\n if (input[input.length - 1] !== \"]\") {\n return failure;\n }\n\n return parseIPv6(input.substring(1, input.length - 1));\n }\n\n if (isNotSpecialArg) {\n return parseOpaqueHost(input);\n }\n\n const domain = percentDecode(Buffer.from(input)).toString();\n const asciiDomain = domainToASCII(domain);\n if (asciiDomain === failure) {\n return failure;\n }\n\n if (containsForbiddenHostCodePoint(asciiDomain)) {\n return failure;\n }\n\n const ipv4Host = parseIPv4(asciiDomain);\n if (typeof ipv4Host === \"number\" || ipv4Host === failure) {\n return ipv4Host;\n }\n\n return asciiDomain;\n}\n\nfunction parseOpaqueHost(input) {\n if (containsForbiddenHostCodePointExcludingPercent(input)) {\n return failure;\n }\n\n let output = \"\";\n const decoded = punycode.ucs2.decode(input);\n for (let i = 0; i < decoded.length; ++i) {\n output += percentEncodeChar(decoded[i], isC0ControlPercentEncode);\n }\n return output;\n}\n\nfunction findLongestZeroSequence(arr) {\n let maxIdx = null;\n let maxLen = 1; // only find elements > 1\n let currStart = null;\n let currLen = 0;\n\n for (let i = 0; i < arr.length; ++i) {\n if (arr[i] !== 0) {\n if (currLen > maxLen) {\n maxIdx = currStart;\n maxLen = currLen;\n }\n\n currStart = null;\n currLen = 0;\n } else {\n if (currStart === null) {\n currStart = i;\n }\n ++currLen;\n }\n }\n\n // if trailing zeros\n if (currLen > maxLen) {\n maxIdx = currStart;\n maxLen = currLen;\n }\n\n return {\n idx: maxIdx,\n len: maxLen\n };\n}\n\nfunction serializeHost(host) {\n if (typeof host === \"number\") {\n return serializeIPv4(host);\n }\n\n // IPv6 serializer\n if (host instanceof Array) {\n return \"[\" + serializeIPv6(host) + \"]\";\n }\n\n return host;\n}\n\nfunction domainToASCII(domain) {\n const result = domain;\n\n if (result === null) {\n return failure;\n }\n return result;\n}\n\nfunction trimControlChars(url) {\n return url.replace(/^[\\u0000-\\u001F\\u0020]+|[\\u0000-\\u001F\\u0020]+$/g, \"\");\n}\n\nfunction trimTabAndNewline(url) {\n return url.replace(/\\u0009|\\u000A|\\u000D/g, \"\");\n}\n\nfunction shortenPath(url) {\n const { path } = url;\n if (path.length === 0) {\n return;\n }\n if (url.scheme === \"file\" && path.length === 1 && isNormalizedWindowsDriveLetter(path[0])) {\n return;\n }\n\n path.pop();\n}\n\nfunction includesCredentials(url) {\n return url.username !== \"\" || url.password !== \"\";\n}\n\nfunction cannotHaveAUsernamePasswordPort(url) {\n return url.host === null || url.host === \"\" || url.cannotBeABaseURL || url.scheme === \"file\";\n}\n\nfunction isNormalizedWindowsDriveLetter(string) {\n return /^[A-Za-z]:$/.test(string);\n}\n\nfunction URLStateMachine(input, base, encodingOverride, url, stateOverride) {\n this.pointer = 0;\n this.input = input;\n this.base = base || null;\n this.encodingOverride = encodingOverride || \"utf-8\";\n this.stateOverride = stateOverride;\n this.url = url;\n this.failure = false;\n this.parseError = false;\n\n if (!this.url) {\n this.url = {\n scheme: \"\",\n username: \"\",\n password: \"\",\n host: null,\n port: null,\n path: [],\n query: null,\n fragment: null,\n\n cannotBeABaseURL: false\n };\n\n const res = trimControlChars(this.input);\n if (res !== this.input) {\n this.parseError = true;\n }\n this.input = res;\n }\n\n const res = trimTabAndNewline(this.input);\n if (res !== this.input) {\n this.parseError = true;\n }\n this.input = res;\n\n this.state = stateOverride || \"scheme start\";\n\n this.buffer = \"\";\n this.atFlag = false;\n this.arrFlag = false;\n this.passwordTokenSeenFlag = false;\n\n this.input = punycode.ucs2.decode(this.input);\n\n for (; this.pointer <= this.input.length; ++this.pointer) {\n const c = this.input[this.pointer];\n const cStr = isNaN(c) ? undefined : String.fromCodePoint(c);\n\n // exec state machine\n const ret = this[\"parse \" + this.state](c, cStr);\n if (!ret) {\n break; // terminate algorithm\n } else if (ret === failure) {\n this.failure = true;\n break;\n }\n }\n}\n\nURLStateMachine.prototype[\"parse scheme start\"] = function parseSchemeStart(c, cStr) {\n if (infra.isASCIIAlpha(c)) {\n this.buffer += cStr.toLowerCase();\n this.state = \"scheme\";\n } else if (!this.stateOverride) {\n this.state = \"no scheme\";\n --this.pointer;\n } else {\n this.parseError = true;\n return failure;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse scheme\"] = function parseScheme(c, cStr) {\n if (infra.isASCIIAlphanumeric(c) || c === 43 || c === 45 || c === 46) {\n this.buffer += cStr.toLowerCase();\n } else if (c === 58) {\n if (this.stateOverride) {\n if (isSpecial(this.url) && !isSpecialScheme(this.buffer)) {\n return false;\n }\n\n if (!isSpecial(this.url) && isSpecialScheme(this.buffer)) {\n return false;\n }\n\n if ((includesCredentials(this.url) || this.url.port !== null) && this.buffer === \"file\") {\n return false;\n }\n\n if (this.url.scheme === \"file\" && (this.url.host === \"\" || this.url.host === null)) {\n return false;\n }\n }\n this.url.scheme = this.buffer;\n if (this.stateOverride) {\n if (this.url.port === defaultPort(this.url.scheme)) {\n this.url.port = null;\n }\n return false;\n }\n this.buffer = \"\";\n if (this.url.scheme === \"file\") {\n if (this.input[this.pointer + 1] !== 47 || this.input[this.pointer + 2] !== 47) {\n this.parseError = true;\n }\n this.state = \"file\";\n } else if (isSpecial(this.url) && this.base !== null && this.base.scheme === this.url.scheme) {\n this.state = \"special relative or authority\";\n } else if (isSpecial(this.url)) {\n this.state = \"special authority slashes\";\n } else if (this.input[this.pointer + 1] === 47) {\n this.state = \"path or authority\";\n ++this.pointer;\n } else {\n this.url.cannotBeABaseURL = true;\n this.url.path.push(\"\");\n this.state = \"cannot-be-a-base-URL path\";\n }\n } else if (!this.stateOverride) {\n this.buffer = \"\";\n this.state = \"no scheme\";\n this.pointer = -1;\n } else {\n this.parseError = true;\n return failure;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse no scheme\"] = function parseNoScheme(c) {\n if (this.base === null || (this.base.cannotBeABaseURL && c !== 35)) {\n return failure;\n } else if (this.base.cannotBeABaseURL && c === 35) {\n this.url.scheme = this.base.scheme;\n this.url.path = this.base.path.slice();\n this.url.query = this.base.query;\n this.url.fragment = \"\";\n this.url.cannotBeABaseURL = true;\n this.state = \"fragment\";\n } else if (this.base.scheme === \"file\") {\n this.state = \"file\";\n --this.pointer;\n } else {\n this.state = \"relative\";\n --this.pointer;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse special relative or authority\"] = function parseSpecialRelativeOrAuthority(c) {\n if (c === 47 && this.input[this.pointer + 1] === 47) {\n this.state = \"special authority ignore slashes\";\n ++this.pointer;\n } else {\n this.parseError = true;\n this.state = \"relative\";\n --this.pointer;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse path or authority\"] = function parsePathOrAuthority(c) {\n if (c === 47) {\n this.state = \"authority\";\n } else {\n this.state = \"path\";\n --this.pointer;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse relative\"] = function parseRelative(c) {\n this.url.scheme = this.base.scheme;\n if (isNaN(c)) {\n this.url.username = this.base.username;\n this.url.password = this.base.password;\n this.url.host = this.base.host;\n this.url.port = this.base.port;\n this.url.path = this.base.path.slice();\n this.url.query = this.base.query;\n } else if (c === 47) {\n this.state = \"relative slash\";\n } else if (c === 63) {\n this.url.username = this.base.username;\n this.url.password = this.base.password;\n this.url.host = this.base.host;\n this.url.port = this.base.port;\n this.url.path = this.base.path.slice();\n this.url.query = \"\";\n this.state = \"query\";\n } else if (c === 35) {\n this.url.username = this.base.username;\n this.url.password = this.base.password;\n this.url.host = this.base.host;\n this.url.port = this.base.port;\n this.url.path = this.base.path.slice();\n this.url.query = this.base.query;\n this.url.fragment = \"\";\n this.state = \"fragment\";\n } else if (isSpecial(this.url) && c === 92) {\n this.parseError = true;\n this.state = \"relative slash\";\n } else {\n this.url.username = this.base.username;\n this.url.password = this.base.password;\n this.url.host = this.base.host;\n this.url.port = this.base.port;\n this.url.path = this.base.path.slice(0, this.base.path.length - 1);\n\n this.state = \"path\";\n --this.pointer;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse relative slash\"] = function parseRelativeSlash(c) {\n if (isSpecial(this.url) && (c === 47 || c === 92)) {\n if (c === 92) {\n this.parseError = true;\n }\n this.state = \"special authority ignore slashes\";\n } else if (c === 47) {\n this.state = \"authority\";\n } else {\n this.url.username = this.base.username;\n this.url.password = this.base.password;\n this.url.host = this.base.host;\n this.url.port = this.base.port;\n this.state = \"path\";\n --this.pointer;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse special authority slashes\"] = function parseSpecialAuthoritySlashes(c) {\n if (c === 47 && this.input[this.pointer + 1] === 47) {\n this.state = \"special authority ignore slashes\";\n ++this.pointer;\n } else {\n this.parseError = true;\n this.state = \"special authority ignore slashes\";\n --this.pointer;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse special authority ignore slashes\"] = function parseSpecialAuthorityIgnoreSlashes(c) {\n if (c !== 47 && c !== 92) {\n this.state = \"authority\";\n --this.pointer;\n } else {\n this.parseError = true;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse authority\"] = function parseAuthority(c, cStr) {\n if (c === 64) {\n this.parseError = true;\n if (this.atFlag) {\n this.buffer = \"%40\" + this.buffer;\n }\n this.atFlag = true;\n\n // careful, this is based on buffer and has its own pointer (this.pointer != pointer) and inner chars\n const len = countSymbols(this.buffer);\n for (let pointer = 0; pointer < len; ++pointer) {\n const codePoint = this.buffer.codePointAt(pointer);\n\n if (codePoint === 58 && !this.passwordTokenSeenFlag) {\n this.passwordTokenSeenFlag = true;\n continue;\n }\n const encodedCodePoints = percentEncodeChar(codePoint, isUserinfoPercentEncode);\n if (this.passwordTokenSeenFlag) {\n this.url.password += encodedCodePoints;\n } else {\n this.url.username += encodedCodePoints;\n }\n }\n this.buffer = \"\";\n } else if (isNaN(c) || c === 47 || c === 63 || c === 35 ||\n (isSpecial(this.url) && c === 92)) {\n if (this.atFlag && this.buffer === \"\") {\n this.parseError = true;\n return failure;\n }\n this.pointer -= countSymbols(this.buffer) + 1;\n this.buffer = \"\";\n this.state = \"host\";\n } else {\n this.buffer += cStr;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse hostname\"] =\nURLStateMachine.prototype[\"parse host\"] = function parseHostName(c, cStr) {\n if (this.stateOverride && this.url.scheme === \"file\") {\n --this.pointer;\n this.state = \"file host\";\n } else if (c === 58 && !this.arrFlag) {\n if (this.buffer === \"\") {\n this.parseError = true;\n return failure;\n }\n\n const host = parseHost(this.buffer, isNotSpecial(this.url));\n if (host === failure) {\n return failure;\n }\n\n this.url.host = host;\n this.buffer = \"\";\n this.state = \"port\";\n if (this.stateOverride === \"hostname\") {\n return false;\n }\n } else if (isNaN(c) || c === 47 || c === 63 || c === 35 ||\n (isSpecial(this.url) && c === 92)) {\n --this.pointer;\n if (isSpecial(this.url) && this.buffer === \"\") {\n this.parseError = true;\n return failure;\n } else if (this.stateOverride && this.buffer === \"\" &&\n (includesCredentials(this.url) || this.url.port !== null)) {\n this.parseError = true;\n return false;\n }\n\n const host = parseHost(this.buffer, isNotSpecial(this.url));\n if (host === failure) {\n return failure;\n }\n\n this.url.host = host;\n this.buffer = \"\";\n this.state = \"path start\";\n if (this.stateOverride) {\n return false;\n }\n } else {\n if (c === 91) {\n this.arrFlag = true;\n } else if (c === 93) {\n this.arrFlag = false;\n }\n this.buffer += cStr;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse port\"] = function parsePort(c, cStr) {\n if (infra.isASCIIDigit(c)) {\n this.buffer += cStr;\n } else if (isNaN(c) || c === 47 || c === 63 || c === 35 ||\n (isSpecial(this.url) && c === 92) ||\n this.stateOverride) {\n if (this.buffer !== \"\") {\n const port = parseInt(this.buffer);\n if (port > Math.pow(2, 16) - 1) {\n this.parseError = true;\n return failure;\n }\n this.url.port = port === defaultPort(this.url.scheme) ? null : port;\n this.buffer = \"\";\n }\n if (this.stateOverride) {\n return false;\n }\n this.state = \"path start\";\n --this.pointer;\n } else {\n this.parseError = true;\n return failure;\n }\n\n return true;\n};\n\nconst fileOtherwiseCodePoints = new Set([47, 92, 63, 35]);\n\nfunction startsWithWindowsDriveLetter(input, pointer) {\n const length = input.length - pointer;\n return length >= 2 &&\n isWindowsDriveLetterCodePoints(input[pointer], input[pointer + 1]) &&\n (length === 2 || fileOtherwiseCodePoints.has(input[pointer + 2]));\n}\n\nURLStateMachine.prototype[\"parse file\"] = function parseFile(c) {\n this.url.scheme = \"file\";\n\n if (c === 47 || c === 92) {\n if (c === 92) {\n this.parseError = true;\n }\n this.state = \"file slash\";\n } else if (this.base !== null && this.base.scheme === \"file\") {\n if (isNaN(c)) {\n this.url.host = this.base.host;\n this.url.path = this.base.path.slice();\n this.url.query = this.base.query;\n } else if (c === 63) {\n this.url.host = this.base.host;\n this.url.path = this.base.path.slice();\n this.url.query = \"\";\n this.state = \"query\";\n } else if (c === 35) {\n this.url.host = this.base.host;\n this.url.path = this.base.path.slice();\n this.url.query = this.base.query;\n this.url.fragment = \"\";\n this.state = \"fragment\";\n } else {\n if (!startsWithWindowsDriveLetter(this.input, this.pointer)) {\n this.url.host = this.base.host;\n this.url.path = this.base.path.slice();\n shortenPath(this.url);\n } else {\n this.parseError = true;\n }\n\n this.state = \"path\";\n --this.pointer;\n }\n } else {\n this.state = \"path\";\n --this.pointer;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse file slash\"] = function parseFileSlash(c) {\n if (c === 47 || c === 92) {\n if (c === 92) {\n this.parseError = true;\n }\n this.state = \"file host\";\n } else {\n if (this.base !== null && this.base.scheme === \"file\" &&\n !startsWithWindowsDriveLetter(this.input, this.pointer)) {\n if (isNormalizedWindowsDriveLetterString(this.base.path[0])) {\n this.url.path.push(this.base.path[0]);\n } else {\n this.url.host = this.base.host;\n }\n }\n this.state = \"path\";\n --this.pointer;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse file host\"] = function parseFileHost(c, cStr) {\n if (isNaN(c) || c === 47 || c === 92 || c === 63 || c === 35) {\n --this.pointer;\n if (!this.stateOverride && isWindowsDriveLetterString(this.buffer)) {\n this.parseError = true;\n this.state = \"path\";\n } else if (this.buffer === \"\") {\n this.url.host = \"\";\n if (this.stateOverride) {\n return false;\n }\n this.state = \"path start\";\n } else {\n let host = parseHost(this.buffer, isNotSpecial(this.url));\n if (host === failure) {\n return failure;\n }\n if (host === \"localhost\") {\n host = \"\";\n }\n this.url.host = host;\n\n if (this.stateOverride) {\n return false;\n }\n\n this.buffer = \"\";\n this.state = \"path start\";\n }\n } else {\n this.buffer += cStr;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse path start\"] = function parsePathStart(c) {\n if (isSpecial(this.url)) {\n if (c === 92) {\n this.parseError = true;\n }\n this.state = \"path\";\n\n if (c !== 47 && c !== 92) {\n --this.pointer;\n }\n } else if (!this.stateOverride && c === 63) {\n this.url.query = \"\";\n this.state = \"query\";\n } else if (!this.stateOverride && c === 35) {\n this.url.fragment = \"\";\n this.state = \"fragment\";\n } else if (c !== undefined) {\n this.state = \"path\";\n if (c !== 47) {\n --this.pointer;\n }\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse path\"] = function parsePath(c) {\n if (isNaN(c) || c === 47 || (isSpecial(this.url) && c === 92) ||\n (!this.stateOverride && (c === 63 || c === 35))) {\n if (isSpecial(this.url) && c === 92) {\n this.parseError = true;\n }\n\n if (isDoubleDot(this.buffer)) {\n shortenPath(this.url);\n if (c !== 47 && !(isSpecial(this.url) && c === 92)) {\n this.url.path.push(\"\");\n }\n } else if (isSingleDot(this.buffer) && c !== 47 &&\n !(isSpecial(this.url) && c === 92)) {\n this.url.path.push(\"\");\n } else if (!isSingleDot(this.buffer)) {\n if (this.url.scheme === \"file\" && this.url.path.length === 0 && isWindowsDriveLetterString(this.buffer)) {\n if (this.url.host !== \"\" && this.url.host !== null) {\n this.parseError = true;\n this.url.host = \"\";\n }\n this.buffer = this.buffer[0] + \":\";\n }\n this.url.path.push(this.buffer);\n }\n this.buffer = \"\";\n if (this.url.scheme === \"file\" && (c === undefined || c === 63 || c === 35)) {\n while (this.url.path.length > 1 && this.url.path[0] === \"\") {\n this.parseError = true;\n this.url.path.shift();\n }\n }\n if (c === 63) {\n this.url.query = \"\";\n this.state = \"query\";\n }\n if (c === 35) {\n this.url.fragment = \"\";\n this.state = \"fragment\";\n }\n } else {\n // TODO: If c is not a URL code point and not \"%\", parse error.\n\n if (c === 37 &&\n (!infra.isASCIIHex(this.input[this.pointer + 1]) ||\n !infra.isASCIIHex(this.input[this.pointer + 2]))) {\n this.parseError = true;\n }\n\n this.buffer += percentEncodeChar(c, isPathPercentEncode);\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse cannot-be-a-base-URL path\"] = function parseCannotBeABaseURLPath(c) {\n if (c === 63) {\n this.url.query = \"\";\n this.state = \"query\";\n } else if (c === 35) {\n this.url.fragment = \"\";\n this.state = \"fragment\";\n } else {\n // TODO: Add: not a URL code point\n if (!isNaN(c) && c !== 37) {\n this.parseError = true;\n }\n\n if (c === 37 &&\n (!infra.isASCIIHex(this.input[this.pointer + 1]) ||\n !infra.isASCIIHex(this.input[this.pointer + 2]))) {\n this.parseError = true;\n }\n\n if (!isNaN(c)) {\n this.url.path[0] += percentEncodeChar(c, isC0ControlPercentEncode);\n }\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse query\"] = function parseQuery(c, cStr) {\n if (isNaN(c) || (!this.stateOverride && c === 35)) {\n if (!isSpecial(this.url) || this.url.scheme === \"ws\" || this.url.scheme === \"wss\") {\n this.encodingOverride = \"utf-8\";\n }\n\n const buffer = Buffer.from(this.buffer); // TODO: Use encoding override instead\n for (let i = 0; i < buffer.length; ++i) {\n if (buffer[i] < 0x21 ||\n buffer[i] > 0x7E ||\n buffer[i] === 0x22 || buffer[i] === 0x23 || buffer[i] === 0x3C || buffer[i] === 0x3E ||\n (buffer[i] === 0x27 && isSpecial(this.url))) {\n this.url.query += percentEncode(buffer[i]);\n } else {\n this.url.query += String.fromCodePoint(buffer[i]);\n }\n }\n\n this.buffer = \"\";\n if (c === 35) {\n this.url.fragment = \"\";\n this.state = \"fragment\";\n }\n } else {\n // TODO: If c is not a URL code point and not \"%\", parse error.\n if (c === 37 &&\n (!infra.isASCIIHex(this.input[this.pointer + 1]) ||\n !infra.isASCIIHex(this.input[this.pointer + 2]))) {\n this.parseError = true;\n }\n\n this.buffer += cStr;\n }\n\n return true;\n};\n\nURLStateMachine.prototype[\"parse fragment\"] = function parseFragment(c) {\n if (isNaN(c)) { // do nothing\n } else if (c === 0x0) {\n this.parseError = true;\n } else {\n // TODO: If c is not a URL code point and not \"%\", parse error.\n if (c === 37 &&\n (!infra.isASCIIHex(this.input[this.pointer + 1]) ||\n !infra.isASCIIHex(this.input[this.pointer + 2]))) {\n this.parseError = true;\n }\n\n this.url.fragment += percentEncodeChar(c, isFragmentPercentEncode);\n }\n\n return true;\n};\n\nfunction serializeURL(url, excludeFragment) {\n let output = url.scheme + \":\";\n if (url.host !== null) {\n output += \"//\";\n\n if (url.username !== \"\" || url.password !== \"\") {\n output += url.username;\n if (url.password !== \"\") {\n output += \":\" + url.password;\n }\n output += \"@\";\n }\n\n output += serializeHost(url.host);\n\n if (url.port !== null) {\n output += \":\" + url.port;\n }\n } else if (url.host === null && url.scheme === \"file\") {\n output += \"//\";\n }\n\n if (url.cannotBeABaseURL) {\n output += url.path[0];\n } else {\n for (const string of url.path) {\n output += \"/\" + string;\n }\n }\n\n if (url.query !== null) {\n output += \"?\" + url.query;\n }\n\n if (!excludeFragment && url.fragment !== null) {\n output += \"#\" + url.fragment;\n }\n\n return output;\n}\n\nfunction serializeOrigin(tuple) {\n let result = tuple.scheme + \"://\";\n result += serializeHost(tuple.host);\n\n if (tuple.port !== null) {\n result += \":\" + tuple.port;\n }\n\n return result;\n}\n\nmodule.exports.serializeURL = serializeURL;\n\nmodule.exports.serializeURLOrigin = function (url) {\n // https://url.spec.whatwg.org/#concept-url-origin\n switch (url.scheme) {\n case \"blob\":\n try {\n return module.exports.serializeURLOrigin(module.exports.parseURL(url.path[0]));\n } catch (e) {\n // serializing an opaque origin returns \"null\"\n return \"null\";\n }\n case \"ftp\":\n case \"http\":\n case \"https\":\n case \"ws\":\n case \"wss\":\n return serializeOrigin({\n scheme: url.scheme,\n host: url.host,\n port: url.port\n });\n case \"file\":\n // The spec says:\n // > Unfortunate as it is, this is left as an exercise to the reader. When in doubt, return a new opaque origin.\n // Browsers tested so far:\n // - Chrome says \"file://\", but treats file: URLs as cross-origin for most (all?) purposes; see e.g.\n // https://bugs.chromium.org/p/chromium/issues/detail?id=37586\n // - Firefox says \"null\", but treats file: URLs as same-origin sometimes based on directory stuff; see\n // https://developer.mozilla.org/en-US/docs/Archive/Misc_top_level/Same-origin_policy_for_file:_URIs\n return \"null\";\n default:\n // serializing an opaque origin returns \"null\"\n return \"null\";\n }\n};\n\nmodule.exports.basicURLParse = function (input, options) {\n if (options === undefined) {\n options = {};\n }\n\n const usm = new URLStateMachine(input, options.baseURL, options.encodingOverride, options.url, options.stateOverride);\n if (usm.failure) {\n return null;\n }\n\n return usm.url;\n};\n\nmodule.exports.setTheUsername = function (url, username) {\n url.username = \"\";\n const decoded = punycode.ucs2.decode(username);\n for (let i = 0; i < decoded.length; ++i) {\n url.username += percentEncodeChar(decoded[i], isUserinfoPercentEncode);\n }\n};\n\nmodule.exports.setThePassword = function (url, password) {\n url.password = \"\";\n const decoded = punycode.ucs2.decode(password);\n for (let i = 0; i < decoded.length; ++i) {\n url.password += percentEncodeChar(decoded[i], isUserinfoPercentEncode);\n }\n};\n\nmodule.exports.serializeHost = serializeHost;\n\nmodule.exports.cannotHaveAUsernamePasswordPort = cannotHaveAUsernamePasswordPort;\n\nmodule.exports.serializeInteger = function (integer) {\n return String(integer);\n};\n\nmodule.exports.parseURL = function (input, options) {\n if (options === undefined) {\n options = {};\n }\n\n // We don't handle blobs, so this just delegates:\n return module.exports.basicURLParse(input, { baseURL: options.baseURL, encodingOverride: options.encodingOverride });\n};\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar customInspectSymbol =\n (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n : null\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nvar K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n var arr = new Uint8Array(1)\n var proto = { foo: function () { return 42 } }\n Object.setPrototypeOf(proto, Uint8Array.prototype)\n Object.setPrototypeOf(arr, proto)\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n }\n // Return an augmented `Uint8Array` instance\n var buf = new Uint8Array(length)\n Object.setPrototypeOf(buf, Buffer.prototype)\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError(\n 'The \"string\" argument must be of type string. Received type number'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value)\n }\n\n if (value == null) {\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n }\n\n if (isInstance(value, ArrayBuffer) ||\n (value && isInstance(value.buffer, ArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof SharedArrayBuffer !== 'undefined' &&\n (isInstance(value, SharedArrayBuffer) ||\n (value && isInstance(value.buffer, SharedArrayBuffer)))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'number') {\n throw new TypeError(\n 'The \"value\" argument must not be of type number. Received type number'\n )\n }\n\n var valueOf = value.valueOf && value.valueOf()\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length)\n }\n\n var b = fromObject(value)\n if (b) return b\n\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(\n value[Symbol.toPrimitive]('string'), encodingOrOffset, length\n )\n }\n\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype)\nObject.setPrototypeOf(Buffer, Uint8Array)\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n var length = byteLength(string, encoding) | 0\n var buf = createBuffer(length)\n\n var actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n var buf = createBuffer(length)\n for (var i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayView (arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n var copy = new Uint8Array(arrayView)\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n }\n return fromArrayLike(arrayView)\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n var buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype)\n\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n var buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return b != null && b._isBuffer === true &&\n b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n}\n\nBuffer.compare = function compare (a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength)\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength)\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError(\n 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n )\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n Buffer.from(buf).copy(buffer, pos)\n } else {\n Uint8Array.prototype.set.call(\n buffer,\n buf,\n pos\n )\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n } else {\n buf.copy(buffer, pos)\n }\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n throw new TypeError(\n 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n 'Received type ' + typeof string\n )\n }\n\n var len = string.length\n var mustMatch = (arguments.length > 2 && arguments[2] === true)\n if (!mustMatch && len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n }\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.toLocaleString = Buffer.prototype.toString\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim()\n if (this.length > max) str += ' ... '\n return ''\n}\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength)\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError(\n 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n 'Received type ' + (typeof target)\n )\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n var strLen = string.length\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (numberIsNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF)\n ? 4\n : (firstByte > 0xDF)\n ? 3\n : (firstByte > 0xBF)\n ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]]\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (var i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype)\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUintLE =\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUintBE =\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUint8 =\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUint16LE =\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUint16BE =\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUint32LE =\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUint32BE =\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUintLE =\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUintBE =\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUint8 =\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUint16LE =\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUint16BE =\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUint32LE =\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUint32BE =\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n var limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n } else if (typeof val === 'boolean') {\n val = Number(val)\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : Buffer.from(val, encoding)\n var len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance (obj, type) {\n return obj instanceof type ||\n (obj != null && obj.constructor != null && obj.constructor.name != null &&\n obj.constructor.name === type.name)\n}\nfunction numberIsNaN (obj) {\n // For IE11 support\n return obj !== obj // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nvar hexSliceLookupTable = (function () {\n var alphabet = '0123456789abcdef'\n var table = new Array(256)\n for (var i = 0; i < 16; ++i) {\n var i16 = i * 16\n for (var j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j]\n }\n }\n return table\n})()\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","'use strict';\n\n/** Highest positive signed 32-bit float value */\nconst maxInt = 2147483647; // aka. 0x7FFFFFFF or 2^31-1\n\n/** Bootstring parameters */\nconst base = 36;\nconst tMin = 1;\nconst tMax = 26;\nconst skew = 38;\nconst damp = 700;\nconst initialBias = 72;\nconst initialN = 128; // 0x80\nconst delimiter = '-'; // '\\x2D'\n\n/** Regular expressions */\nconst regexPunycode = /^xn--/;\nconst regexNonASCII = /[^\\0-\\x7F]/; // Note: U+007F DEL is excluded too.\nconst regexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g; // RFC 3490 separators\n\n/** Error messages */\nconst errors = {\n\t'overflow': 'Overflow: input needs wider integers to process',\n\t'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n\t'invalid-input': 'Invalid input'\n};\n\n/** Convenience shortcuts */\nconst baseMinusTMin = base - tMin;\nconst floor = Math.floor;\nconst stringFromCharCode = String.fromCharCode;\n\n/*--------------------------------------------------------------------------*/\n\n/**\n * A generic error utility function.\n * @private\n * @param {String} type The error type.\n * @returns {Error} Throws a `RangeError` with the applicable error message.\n */\nfunction error(type) {\n\tthrow new RangeError(errors[type]);\n}\n\n/**\n * A generic `Array#map` utility function.\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} callback The function that gets called for every array\n * item.\n * @returns {Array} A new array of values returned by the callback function.\n */\nfunction map(array, callback) {\n\tconst result = [];\n\tlet length = array.length;\n\twhile (length--) {\n\t\tresult[length] = callback(array[length]);\n\t}\n\treturn result;\n}\n\n/**\n * A simple `Array#map`-like wrapper to work with domain name strings or email\n * addresses.\n * @private\n * @param {String} domain The domain name or email address.\n * @param {Function} callback The function that gets called for every\n * character.\n * @returns {String} A new string of characters returned by the callback\n * function.\n */\nfunction mapDomain(domain, callback) {\n\tconst parts = domain.split('@');\n\tlet result = '';\n\tif (parts.length > 1) {\n\t\t// In email addresses, only the domain name should be punycoded. Leave\n\t\t// the local part (i.e. everything up to `@`) intact.\n\t\tresult = parts[0] + '@';\n\t\tdomain = parts[1];\n\t}\n\t// Avoid `split(regex)` for IE8 compatibility. See #17.\n\tdomain = domain.replace(regexSeparators, '\\x2E');\n\tconst labels = domain.split('.');\n\tconst encoded = map(labels, callback).join('.');\n\treturn result + encoded;\n}\n\n/**\n * Creates an array containing the numeric code points of each Unicode\n * character in the string. While JavaScript uses UCS-2 internally,\n * this function will convert a pair of surrogate halves (each of which\n * UCS-2 exposes as separate characters) into a single code point,\n * matching UTF-16.\n * @see `punycode.ucs2.encode`\n * @see \n * @memberOf punycode.ucs2\n * @name decode\n * @param {String} string The Unicode input string (UCS-2).\n * @returns {Array} The new array of code points.\n */\nfunction ucs2decode(string) {\n\tconst output = [];\n\tlet counter = 0;\n\tconst length = string.length;\n\twhile (counter < length) {\n\t\tconst value = string.charCodeAt(counter++);\n\t\tif (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n\t\t\t// It's a high surrogate, and there is a next character.\n\t\t\tconst extra = string.charCodeAt(counter++);\n\t\t\tif ((extra & 0xFC00) == 0xDC00) { // Low surrogate.\n\t\t\t\toutput.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n\t\t\t} else {\n\t\t\t\t// It's an unmatched surrogate; only append this code unit, in case the\n\t\t\t\t// next code unit is the high surrogate of a surrogate pair.\n\t\t\t\toutput.push(value);\n\t\t\t\tcounter--;\n\t\t\t}\n\t\t} else {\n\t\t\toutput.push(value);\n\t\t}\n\t}\n\treturn output;\n}\n\n/**\n * Creates a string based on an array of numeric code points.\n * @see `punycode.ucs2.decode`\n * @memberOf punycode.ucs2\n * @name encode\n * @param {Array} codePoints The array of numeric code points.\n * @returns {String} The new Unicode string (UCS-2).\n */\nconst ucs2encode = codePoints => String.fromCodePoint(...codePoints);\n\n/**\n * Converts a basic code point into a digit/integer.\n * @see `digitToBasic()`\n * @private\n * @param {Number} codePoint The basic numeric code point value.\n * @returns {Number} The numeric value of a basic code point (for use in\n * representing integers) in the range `0` to `base - 1`, or `base` if\n * the code point does not represent a value.\n */\nconst basicToDigit = function(codePoint) {\n\tif (codePoint >= 0x30 && codePoint < 0x3A) {\n\t\treturn 26 + (codePoint - 0x30);\n\t}\n\tif (codePoint >= 0x41 && codePoint < 0x5B) {\n\t\treturn codePoint - 0x41;\n\t}\n\tif (codePoint >= 0x61 && codePoint < 0x7B) {\n\t\treturn codePoint - 0x61;\n\t}\n\treturn base;\n};\n\n/**\n * Converts a digit/integer into a basic code point.\n * @see `basicToDigit()`\n * @private\n * @param {Number} digit The numeric value of a basic code point.\n * @returns {Number} The basic code point whose value (when used for\n * representing integers) is `digit`, which needs to be in the range\n * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n * used; else, the lowercase form is used. The behavior is undefined\n * if `flag` is non-zero and `digit` has no uppercase form.\n */\nconst digitToBasic = function(digit, flag) {\n\t// 0..25 map to ASCII a..z or A..Z\n\t// 26..35 map to ASCII 0..9\n\treturn digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n};\n\n/**\n * Bias adaptation function as per section 3.4 of RFC 3492.\n * https://tools.ietf.org/html/rfc3492#section-3.4\n * @private\n */\nconst adapt = function(delta, numPoints, firstTime) {\n\tlet k = 0;\n\tdelta = firstTime ? floor(delta / damp) : delta >> 1;\n\tdelta += floor(delta / numPoints);\n\tfor (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) {\n\t\tdelta = floor(delta / baseMinusTMin);\n\t}\n\treturn floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n};\n\n/**\n * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n * symbols.\n * @memberOf punycode\n * @param {String} input The Punycode string of ASCII-only symbols.\n * @returns {String} The resulting string of Unicode symbols.\n */\nconst decode = function(input) {\n\t// Don't use UCS-2.\n\tconst output = [];\n\tconst inputLength = input.length;\n\tlet i = 0;\n\tlet n = initialN;\n\tlet bias = initialBias;\n\n\t// Handle the basic code points: let `basic` be the number of input code\n\t// points before the last delimiter, or `0` if there is none, then copy\n\t// the first basic code points to the output.\n\n\tlet basic = input.lastIndexOf(delimiter);\n\tif (basic < 0) {\n\t\tbasic = 0;\n\t}\n\n\tfor (let j = 0; j < basic; ++j) {\n\t\t// if it's not a basic code point\n\t\tif (input.charCodeAt(j) >= 0x80) {\n\t\t\terror('not-basic');\n\t\t}\n\t\toutput.push(input.charCodeAt(j));\n\t}\n\n\t// Main decoding loop: start just after the last delimiter if any basic code\n\t// points were copied; start at the beginning otherwise.\n\n\tfor (let index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) {\n\n\t\t// `index` is the index of the next character to be consumed.\n\t\t// Decode a generalized variable-length integer into `delta`,\n\t\t// which gets added to `i`. The overflow checking is easier\n\t\t// if we increase `i` as we go, then subtract off its starting\n\t\t// value at the end to obtain `delta`.\n\t\tconst oldi = i;\n\t\tfor (let w = 1, k = base; /* no condition */; k += base) {\n\n\t\t\tif (index >= inputLength) {\n\t\t\t\terror('invalid-input');\n\t\t\t}\n\n\t\t\tconst digit = basicToDigit(input.charCodeAt(index++));\n\n\t\t\tif (digit >= base) {\n\t\t\t\terror('invalid-input');\n\t\t\t}\n\t\t\tif (digit > floor((maxInt - i) / w)) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\ti += digit * w;\n\t\t\tconst t = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\n\t\t\tif (digit < t) {\n\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tconst baseMinusT = base - t;\n\t\t\tif (w > floor(maxInt / baseMinusT)) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tw *= baseMinusT;\n\n\t\t}\n\n\t\tconst out = output.length + 1;\n\t\tbias = adapt(i - oldi, out, oldi == 0);\n\n\t\t// `i` was supposed to wrap around from `out` to `0`,\n\t\t// incrementing `n` each time, so we'll fix that now:\n\t\tif (floor(i / out) > maxInt - n) {\n\t\t\terror('overflow');\n\t\t}\n\n\t\tn += floor(i / out);\n\t\ti %= out;\n\n\t\t// Insert `n` at position `i` of the output.\n\t\toutput.splice(i++, 0, n);\n\n\t}\n\n\treturn String.fromCodePoint(...output);\n};\n\n/**\n * Converts a string of Unicode symbols (e.g. a domain name label) to a\n * Punycode string of ASCII-only symbols.\n * @memberOf punycode\n * @param {String} input The string of Unicode symbols.\n * @returns {String} The resulting Punycode string of ASCII-only symbols.\n */\nconst encode = function(input) {\n\tconst output = [];\n\n\t// Convert the input in UCS-2 to an array of Unicode code points.\n\tinput = ucs2decode(input);\n\n\t// Cache the length.\n\tconst inputLength = input.length;\n\n\t// Initialize the state.\n\tlet n = initialN;\n\tlet delta = 0;\n\tlet bias = initialBias;\n\n\t// Handle the basic code points.\n\tfor (const currentValue of input) {\n\t\tif (currentValue < 0x80) {\n\t\t\toutput.push(stringFromCharCode(currentValue));\n\t\t}\n\t}\n\n\tconst basicLength = output.length;\n\tlet handledCPCount = basicLength;\n\n\t// `handledCPCount` is the number of code points that have been handled;\n\t// `basicLength` is the number of basic code points.\n\n\t// Finish the basic string with a delimiter unless it's empty.\n\tif (basicLength) {\n\t\toutput.push(delimiter);\n\t}\n\n\t// Main encoding loop:\n\twhile (handledCPCount < inputLength) {\n\n\t\t// All non-basic code points < n have been handled already. Find the next\n\t\t// larger one:\n\t\tlet m = maxInt;\n\t\tfor (const currentValue of input) {\n\t\t\tif (currentValue >= n && currentValue < m) {\n\t\t\t\tm = currentValue;\n\t\t\t}\n\t\t}\n\n\t\t// Increase `delta` enough to advance the decoder's state to ,\n\t\t// but guard against overflow.\n\t\tconst handledCPCountPlusOne = handledCPCount + 1;\n\t\tif (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n\t\t\terror('overflow');\n\t\t}\n\n\t\tdelta += (m - n) * handledCPCountPlusOne;\n\t\tn = m;\n\n\t\tfor (const currentValue of input) {\n\t\t\tif (currentValue < n && ++delta > maxInt) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\t\t\tif (currentValue === n) {\n\t\t\t\t// Represent delta as a generalized variable-length integer.\n\t\t\t\tlet q = delta;\n\t\t\t\tfor (let k = base; /* no condition */; k += base) {\n\t\t\t\t\tconst t = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\t\t\t\t\tif (q < t) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tconst qMinusT = q - t;\n\t\t\t\t\tconst baseMinusT = base - t;\n\t\t\t\t\toutput.push(\n\t\t\t\t\t\tstringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0))\n\t\t\t\t\t);\n\t\t\t\t\tq = floor(qMinusT / baseMinusT);\n\t\t\t\t}\n\n\t\t\t\toutput.push(stringFromCharCode(digitToBasic(q, 0)));\n\t\t\t\tbias = adapt(delta, handledCPCountPlusOne, handledCPCount === basicLength);\n\t\t\t\tdelta = 0;\n\t\t\t\t++handledCPCount;\n\t\t\t}\n\t\t}\n\n\t\t++delta;\n\t\t++n;\n\n\t}\n\treturn output.join('');\n};\n\n/**\n * Converts a Punycode string representing a domain name or an email address\n * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n * it doesn't matter if you call it on a string that has already been\n * converted to Unicode.\n * @memberOf punycode\n * @param {String} input The Punycoded domain name or email address to\n * convert to Unicode.\n * @returns {String} The Unicode representation of the given Punycode\n * string.\n */\nconst toUnicode = function(input) {\n\treturn mapDomain(input, function(string) {\n\t\treturn regexPunycode.test(string)\n\t\t\t? decode(string.slice(4).toLowerCase())\n\t\t\t: string;\n\t});\n};\n\n/**\n * Converts a Unicode string representing a domain name or an email address to\n * Punycode. Only the non-ASCII parts of the domain name will be converted,\n * i.e. it doesn't matter if you call it with a domain that's already in\n * ASCII.\n * @memberOf punycode\n * @param {String} input The domain name or email address to convert, as a\n * Unicode string.\n * @returns {String} The Punycode representation of the given domain name or\n * email address.\n */\nconst toASCII = function(input) {\n\treturn mapDomain(input, function(string) {\n\t\treturn regexNonASCII.test(string)\n\t\t\t? 'xn--' + encode(string)\n\t\t\t: string;\n\t});\n};\n\n/*--------------------------------------------------------------------------*/\n\n/** Define the public API */\nconst punycode = {\n\t/**\n\t * A string representing the current Punycode.js version number.\n\t * @memberOf punycode\n\t * @type String\n\t */\n\t'version': '2.1.0',\n\t/**\n\t * An object of methods to convert from JavaScript's internal character\n\t * representation (UCS-2) to Unicode code points, and back.\n\t * @see \n\t * @memberOf punycode\n\t * @type Object\n\t */\n\t'ucs2': {\n\t\t'decode': ucs2decode,\n\t\t'encode': ucs2encode\n\t},\n\t'decode': decode,\n\t'encode': encode,\n\t'toASCII': toASCII,\n\t'toUnicode': toUnicode\n};\n\nmodule.exports = punycode;\n","\"use strict\";\n\nfunction isASCIIDigit(c) {\n return c >= 0x30 && c <= 0x39;\n}\n\nfunction isASCIIAlpha(c) {\n return (c >= 0x41 && c <= 0x5A) || (c >= 0x61 && c <= 0x7A);\n}\n\nfunction isASCIIAlphanumeric(c) {\n return isASCIIAlpha(c) || isASCIIDigit(c);\n}\n\nfunction isASCIIHex(c) {\n return isASCIIDigit(c) || (c >= 0x41 && c <= 0x46) || (c >= 0x61 && c <= 0x66);\n}\n\nmodule.exports = {\n isASCIIDigit,\n isASCIIAlpha,\n isASCIIAlphanumeric,\n isASCIIHex\n};\n","\"use strict\";\nconst { Buffer } = require(\"buffer/\");\n\nconst { isASCIIHex } = require(\"./infra\");\n\nfunction strictlySplitByteSequence(buf, cp) {\n const list = [];\n let last = 0;\n let i = buf.indexOf(cp);\n while (i >= 0) {\n list.push(buf.slice(last, i));\n last = i + 1;\n i = buf.indexOf(cp, last);\n }\n if (last !== buf.length) {\n list.push(buf.slice(last));\n }\n return list;\n}\n\nfunction replaceByteInByteSequence(buf, from, to) {\n let i = buf.indexOf(from);\n while (i >= 0) {\n buf[i] = to;\n i = buf.indexOf(from, i + 1);\n }\n return buf;\n}\n\nfunction percentEncode(c) {\n let hex = c.toString(16).toUpperCase();\n if (hex.length === 1) {\n hex = \"0\" + hex;\n }\n\n return \"%\" + hex;\n}\n\nfunction percentDecode(input) {\n const output = Buffer.alloc(input.byteLength);\n let ptr = 0;\n for (let i = 0; i < input.length; ++i) {\n if (input[i] !== 37 || !isASCIIHex(input[i + 1]) || !isASCIIHex(input[i + 2])) {\n output[ptr++] = input[i];\n } else {\n output[ptr++] = parseInt(input.slice(i + 1, i + 3).toString(), 16);\n i += 2;\n }\n }\n return output.slice(0, ptr);\n}\n\nfunction parseUrlencoded(input) {\n const sequences = strictlySplitByteSequence(input, 38);\n const output = [];\n for (const bytes of sequences) {\n if (bytes.length === 0) {\n continue;\n }\n\n let name;\n let value;\n const indexOfEqual = bytes.indexOf(61);\n\n if (indexOfEqual >= 0) {\n name = bytes.slice(0, indexOfEqual);\n value = bytes.slice(indexOfEqual + 1);\n } else {\n name = bytes;\n value = Buffer.alloc(0);\n }\n\n name = replaceByteInByteSequence(Buffer.from(name), 43, 32);\n value = replaceByteInByteSequence(Buffer.from(value), 43, 32);\n\n output.push([percentDecode(name).toString(), percentDecode(value).toString()]);\n }\n return output;\n}\n\nfunction serializeUrlencodedByte(input) {\n let output = \"\";\n for (const byte of input) {\n if (byte === 32) {\n output += \"+\";\n } else if (byte === 42 ||\n byte === 45 ||\n byte === 46 ||\n (byte >= 48 && byte <= 57) ||\n (byte >= 65 && byte <= 90) ||\n byte === 95 ||\n (byte >= 97 && byte <= 122)) {\n output += String.fromCodePoint(byte);\n } else {\n output += percentEncode(byte);\n }\n }\n return output;\n}\n\nfunction serializeUrlencoded(tuples, encodingOverride = undefined) {\n let encoding = \"utf-8\";\n if (encodingOverride !== undefined) {\n encoding = encodingOverride;\n }\n\n let output = \"\";\n for (const [i, tuple] of tuples.entries()) {\n // TODO: handle encoding override\n const name = serializeUrlencodedByte(Buffer.from(tuple[0]));\n let value = tuple[1];\n if (tuple.length > 2 && tuple[2] !== undefined) {\n if (tuple[2] === \"hidden\" && name === \"_charset_\") {\n value = encoding;\n } else if (tuple[2] === \"file\") {\n // value is a File object\n value = value.name;\n }\n }\n value = serializeUrlencodedByte(Buffer.from(value));\n if (i !== 0) {\n output += \"&\";\n }\n output += `${name}=${value}`;\n }\n return output;\n}\n\nmodule.exports = {\n percentEncode,\n percentDecode,\n\n // application/x-www-form-urlencoded string parser\n parseUrlencoded(input) {\n return parseUrlencoded(Buffer.from(input));\n },\n\n // application/x-www-form-urlencoded serializer\n serializeUrlencoded\n};\n","\"use strict\";\n\nconst conversions = require(\"webidl-conversions\");\nconst utils = require(\"./utils.js\");\n\nconst impl = utils.implSymbol;\nconst ctorRegistry = utils.ctorRegistrySymbol;\n\nconst IteratorPrototype = Object.create(utils.IteratorPrototype, {\n next: {\n value: function next() {\n const internal = this[utils.iterInternalSymbol];\n const { target, kind, index } = internal;\n const values = Array.from(target[impl]);\n const len = values.length;\n if (index >= len) {\n return { value: undefined, done: true };\n }\n\n const pair = values[index];\n internal.index = index + 1;\n const [key, value] = pair.map(utils.tryWrapperForImpl);\n\n let result;\n switch (kind) {\n case \"key\":\n result = key;\n break;\n case \"value\":\n result = value;\n break;\n case \"key+value\":\n result = [key, value];\n break;}\n\n return { value: result, done: false };\n },\n writable: true,\n enumerable: true,\n configurable: true },\n\n [Symbol.toStringTag]: {\n value: \"URLSearchParams Iterator\",\n configurable: true } });\n\n\n\nconst iface = {\n // When an interface-module that implements this interface as a mixin is loaded, it will append its own `.is()`\n // method into this array. It allows objects that directly implements *those* interfaces to be recognized as\n // implementing this mixin interface.\n _mixedIntoPredicates: [],\n is(obj) {\n if (obj) {\n if (utils.hasOwn(obj, impl) && obj[impl] instanceof Impl.implementation) {\n return true;\n }\n for (const isMixedInto of module.exports._mixedIntoPredicates) {\n if (isMixedInto(obj)) {\n return true;\n }\n }\n }\n return false;\n },\n isImpl(obj) {\n if (obj) {\n if (obj instanceof Impl.implementation) {\n return true;\n }\n\n const wrapper = utils.wrapperForImpl(obj);\n for (const isMixedInto of module.exports._mixedIntoPredicates) {\n if (isMixedInto(wrapper)) {\n return true;\n }\n }\n }\n return false;\n },\n convert(obj, { context = \"The provided value\" } = {}) {\n if (module.exports.is(obj)) {\n return utils.implForWrapper(obj);\n }\n throw new TypeError(`${context} is not of type 'URLSearchParams'.`);\n },\n\n createDefaultIterator(target, kind) {\n const iterator = Object.create(IteratorPrototype);\n Object.defineProperty(iterator, utils.iterInternalSymbol, {\n value: { target, kind, index: 0 },\n configurable: true });\n\n return iterator;\n },\n\n create(globalObject, constructorArgs, privateData) {\n if (globalObject[ctorRegistry] === undefined) {\n throw new Error(\"Internal error: invalid global object\");\n }\n\n const ctor = globalObject[ctorRegistry][\"URLSearchParams\"];\n if (ctor === undefined) {\n throw new Error(\"Internal error: constructor URLSearchParams is not installed on the passed global object\");\n }\n\n let obj = Object.create(ctor.prototype);\n obj = iface.setup(obj, globalObject, constructorArgs, privateData);\n return obj;\n },\n createImpl(globalObject, constructorArgs, privateData) {\n const obj = iface.create(globalObject, constructorArgs, privateData);\n return utils.implForWrapper(obj);\n },\n _internalSetup(obj) {},\n setup(obj, globalObject, constructorArgs = [], privateData = {}) {\n privateData.wrapper = obj;\n\n iface._internalSetup(obj);\n Object.defineProperty(obj, impl, {\n value: new Impl.implementation(globalObject, constructorArgs, privateData),\n configurable: true });\n\n\n obj[impl][utils.wrapperSymbol] = obj;\n if (Impl.init) {\n Impl.init(obj[impl], privateData);\n }\n return obj;\n },\n\n install(globalObject) {\n class URLSearchParams {\n constructor() {\n const args = [];\n {\n let curArg = arguments[0];\n if (curArg !== undefined) {\n if (utils.isObject(curArg)) {\n if (curArg[Symbol.iterator] !== undefined) {\n if (!utils.isObject(curArg)) {\n throw new TypeError(\n \"Failed to construct 'URLSearchParams': parameter 1\" + \" sequence\" + \" is not an iterable object.\");\n\n } else {\n const V = [];\n const tmp = curArg;\n for (let nextItem of tmp) {\n if (!utils.isObject(nextItem)) {\n throw new TypeError(\n \"Failed to construct 'URLSearchParams': parameter 1\" +\n \" sequence\" +\n \"'s element\" +\n \" is not an iterable object.\");\n\n } else {\n const V = [];\n const tmp = nextItem;\n for (let nextItem of tmp) {\n nextItem = conversions[\"USVString\"](nextItem, {\n context:\n \"Failed to construct 'URLSearchParams': parameter 1\" +\n \" sequence\" +\n \"'s element\" +\n \"'s element\" });\n\n\n V.push(nextItem);\n }\n nextItem = V;\n }\n\n V.push(nextItem);\n }\n curArg = V;\n }\n } else {\n if (!utils.isObject(curArg)) {\n throw new TypeError(\n \"Failed to construct 'URLSearchParams': parameter 1\" + \" record\" + \" is not an object.\");\n\n } else {\n const result = Object.create(null);\n for (const key of Reflect.ownKeys(curArg)) {\n const desc = Object.getOwnPropertyDescriptor(curArg, key);\n if (desc && desc.enumerable) {\n let typedKey = key;\n\n typedKey = conversions[\"USVString\"](typedKey, {\n context: \"Failed to construct 'URLSearchParams': parameter 1\" + \" record\" + \"'s key\" });\n\n\n let typedValue = curArg[key];\n\n typedValue = conversions[\"USVString\"](typedValue, {\n context: \"Failed to construct 'URLSearchParams': parameter 1\" + \" record\" + \"'s value\" });\n\n\n result[typedKey] = typedValue;\n }\n }\n curArg = result;\n }\n }\n } else {\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to construct 'URLSearchParams': parameter 1\" });\n\n }\n } else {\n curArg = \"\";\n }\n args.push(curArg);\n }\n return iface.setup(Object.create(this.constructor.prototype), globalObject, args);\n }\n\n append(name, value) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n if (arguments.length < 2) {\n throw new TypeError(\n \"Failed to execute 'append' on 'URLSearchParams': 2 arguments required, but only \" +\n arguments.length +\n \" present.\");\n\n }\n const args = [];\n {\n let curArg = arguments[0];\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to execute 'append' on 'URLSearchParams': parameter 1\" });\n\n args.push(curArg);\n }\n {\n let curArg = arguments[1];\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to execute 'append' on 'URLSearchParams': parameter 2\" });\n\n args.push(curArg);\n }\n return this[impl].append(...args);\n }\n\n delete(name) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n if (arguments.length < 1) {\n throw new TypeError(\n \"Failed to execute 'delete' on 'URLSearchParams': 1 argument required, but only \" +\n arguments.length +\n \" present.\");\n\n }\n const args = [];\n {\n let curArg = arguments[0];\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to execute 'delete' on 'URLSearchParams': parameter 1\" });\n\n args.push(curArg);\n }\n return this[impl].delete(...args);\n }\n\n get(name) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n if (arguments.length < 1) {\n throw new TypeError(\n \"Failed to execute 'get' on 'URLSearchParams': 1 argument required, but only \" +\n arguments.length +\n \" present.\");\n\n }\n const args = [];\n {\n let curArg = arguments[0];\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to execute 'get' on 'URLSearchParams': parameter 1\" });\n\n args.push(curArg);\n }\n return this[impl].get(...args);\n }\n\n getAll(name) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n if (arguments.length < 1) {\n throw new TypeError(\n \"Failed to execute 'getAll' on 'URLSearchParams': 1 argument required, but only \" +\n arguments.length +\n \" present.\");\n\n }\n const args = [];\n {\n let curArg = arguments[0];\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to execute 'getAll' on 'URLSearchParams': parameter 1\" });\n\n args.push(curArg);\n }\n return utils.tryWrapperForImpl(this[impl].getAll(...args));\n }\n\n has(name) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n if (arguments.length < 1) {\n throw new TypeError(\n \"Failed to execute 'has' on 'URLSearchParams': 1 argument required, but only \" +\n arguments.length +\n \" present.\");\n\n }\n const args = [];\n {\n let curArg = arguments[0];\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to execute 'has' on 'URLSearchParams': parameter 1\" });\n\n args.push(curArg);\n }\n return this[impl].has(...args);\n }\n\n set(name, value) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n if (arguments.length < 2) {\n throw new TypeError(\n \"Failed to execute 'set' on 'URLSearchParams': 2 arguments required, but only \" +\n arguments.length +\n \" present.\");\n\n }\n const args = [];\n {\n let curArg = arguments[0];\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to execute 'set' on 'URLSearchParams': parameter 1\" });\n\n args.push(curArg);\n }\n {\n let curArg = arguments[1];\n curArg = conversions[\"USVString\"](curArg, {\n context: \"Failed to execute 'set' on 'URLSearchParams': parameter 2\" });\n\n args.push(curArg);\n }\n return this[impl].set(...args);\n }\n\n sort() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl].sort();\n }\n\n toString() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n\n return this[impl].toString();\n }\n\n keys() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n return module.exports.createDefaultIterator(this, \"key\");\n }\n\n values() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n return module.exports.createDefaultIterator(this, \"value\");\n }\n\n entries() {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n return module.exports.createDefaultIterator(this, \"key+value\");\n }\n\n forEach(callback) {\n if (!this || !module.exports.is(this)) {\n throw new TypeError(\"Illegal invocation\");\n }\n if (arguments.length < 1) {\n throw new TypeError(\n \"Failed to execute 'forEach' on 'iterable': 1 argument required, \" + \"but only 0 present.\");\n\n }\n if (typeof callback !== \"function\") {\n throw new TypeError(\n \"Failed to execute 'forEach' on 'iterable': The callback provided \" + \"as parameter 1 is not a function.\");\n\n }\n const thisArg = arguments[1];\n let pairs = Array.from(this[impl]);\n let i = 0;\n while (i < pairs.length) {\n const [key, value] = pairs[i].map(utils.tryWrapperForImpl);\n callback.call(thisArg, value, key, this);\n pairs = Array.from(this[impl]);\n i++;\n }\n }}\n\n Object.defineProperties(URLSearchParams.prototype, {\n append: { enumerable: true },\n delete: { enumerable: true },\n get: { enumerable: true },\n getAll: { enumerable: true },\n has: { enumerable: true },\n set: { enumerable: true },\n sort: { enumerable: true },\n toString: { enumerable: true },\n keys: { enumerable: true },\n values: { enumerable: true },\n entries: { enumerable: true },\n forEach: { enumerable: true },\n [Symbol.toStringTag]: { value: \"URLSearchParams\", configurable: true },\n [Symbol.iterator]: { value: URLSearchParams.prototype.entries, configurable: true, writable: true } });\n\n if (globalObject[ctorRegistry] === undefined) {\n globalObject[ctorRegistry] = Object.create(null);\n }\n globalObject[ctorRegistry][\"URLSearchParams\"] = URLSearchParams;\n\n Object.defineProperty(globalObject, \"URLSearchParams\", {\n configurable: true,\n writable: true,\n value: URLSearchParams });\n\n } };\n// iface\nmodule.exports = iface;\n\nconst Impl = require(\"./URLSearchParams-impl.js\");","\"use strict\";\nconst urlencoded = require(\"./urlencoded\");\n\nfunction stableSortBy(arr, compare) {\n return arr\n .map((item, index) => ({ item, index }))\n .sort((a, b) => compare(a.item, b.item) || a.index - b.index)\n .map(({ item }) => item);\n}\n\nexports.implementation = class URLSearchParamsImpl {\n constructor(globalObject, constructorArgs, { doNotStripQMark = false }) {\n let init = constructorArgs[0];\n this._list = [];\n this._url = null;\n\n if (!doNotStripQMark && typeof init === \"string\" && init[0] === \"?\") {\n init = init.slice(1);\n }\n\n if (Array.isArray(init)) {\n for (const pair of init) {\n if (pair.length !== 2) {\n throw new TypeError(\"Failed to construct 'URLSearchParams': parameter 1 sequence's element does not \" +\n \"contain exactly two elements.\");\n }\n this._list.push([pair[0], pair[1]]);\n }\n } else if (typeof init === \"object\" && Object.getPrototypeOf(init) === null) {\n for (const name of Object.keys(init)) {\n const value = init[name];\n this._list.push([name, value]);\n }\n } else {\n this._list = urlencoded.parseUrlencoded(init);\n }\n }\n\n _updateSteps() {\n if (this._url !== null) {\n let query = urlencoded.serializeUrlencoded(this._list);\n if (query === \"\") {\n query = null;\n }\n this._url._url.query = query;\n }\n }\n\n append(name, value) {\n this._list.push([name, value]);\n this._updateSteps();\n }\n\n delete(name) {\n let i = 0;\n while (i < this._list.length) {\n if (this._list[i][0] === name) {\n this._list.splice(i, 1);\n } else {\n i++;\n }\n }\n this._updateSteps();\n }\n\n get(name) {\n for (const tuple of this._list) {\n if (tuple[0] === name) {\n return tuple[1];\n }\n }\n return null;\n }\n\n getAll(name) {\n const output = [];\n for (const tuple of this._list) {\n if (tuple[0] === name) {\n output.push(tuple[1]);\n }\n }\n return output;\n }\n\n has(name) {\n for (const tuple of this._list) {\n if (tuple[0] === name) {\n return true;\n }\n }\n return false;\n }\n\n set(name, value) {\n let found = false;\n let i = 0;\n while (i < this._list.length) {\n if (this._list[i][0] === name) {\n if (found) {\n this._list.splice(i, 1);\n } else {\n found = true;\n this._list[i][1] = value;\n i++;\n }\n } else {\n i++;\n }\n }\n if (!found) {\n this._list.push([name, value]);\n }\n this._updateSteps();\n }\n\n sort() {\n this._list = stableSortBy(this._list, (a, b) => a[0] > b[0]);\n this._updateSteps();\n }\n\n [Symbol.iterator]() {\n return this._list[Symbol.iterator]();\n }\n\n toString() {\n return urlencoded.serializeUrlencoded(this._list);\n }\n};\n","export {URLSearchParams} from 'whatwg-url-without-unicode';\n","","import React, {useContext, useEffect, useState} from 'react';\nimport {Dimensions, Image, ScrollView, View} from \"react-native\";\nimport TextM from \"@common/components/text/TextM\";\nimport {theme} from \"@common/theme/theme\";\nimport {apiIdle, apiRequest, apiRequestWithPrerequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {StatusBar} from \"expo-status-bar\";\nimport {ActivityIndicator} from \"react-native-paper\";\nimport logo from \"../../assets/logo-blue.png\";\nimport {subscriptionService} from \"@data/services/subscriptionService\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport {useApiStatus} from \"@common/hooks/useApiStatus\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport base64 from \"@common/utils/base64\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {useSafeAreaInsets} from \"react-native-safe-area-context\";\nimport {PricingTableM} from \"./PricingTableM\";\nimport AvatarM from \"@common/components/avatar/AvatarM\";\nimport {isSubscribed, isSubscriptionPaused} from \"@data/utility/dataUtils\";\n\nimport MySubscriptionInfos from \"../student/account/subscription/MySubscriptionInfos\";\nimport {ToggleButtonM} from \"@common/components/button/ToggleButtonM\";\nimport {useController} from \"react-hook-form\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\nimport * as amplitude from \"@amplitude/analytics-react-native\";\nimport NextLiveSessionBanner from \"../student/activity/todo/NextLiveSessionBanner\";\nimport {TouchableOpacity} from \"@gorhom/bottom-sheet\";\nimport TitleM from \"@common/components/text/TitleM\";\nimport {setBugsnagUser} from \"@common/utils/initBugsnag\";\nimport FAQComponent from \"@common/components/FAQ/FAQComponent\";\nimport moment from \"moment\";\nimport ReferralActionCard from \"@common/account/ReferralActionCard\";\n\n\nfunction PricingComponent(props) {\n const {\n control,\n goToNextStep,\n register,\n errors,\n serverError,\n setFormValues = () => {},\n field,\n userEmail,\n pricingTableData,\n startNextMonth,\n pricingTableDataNextMode,\n subscribedProductPriceId,\n forceBigSize = false\n } = props\n\n const {field: productNameField} = control ? useController({\n control,\n name: \"product_name\"\n }) : {};\n\n const {field: withCommitmentField} = control ? useController({\n control,\n name: \"with_commitment\"\n }) : {};\n\n const [withCommitment, setWithCommitment] = useState(withCommitmentField?.value ?? 1)\n\n const advantage = !withCommitment ? pricingTableData?.[0]?.advantage : pricingTableData?.[0]?.prices?.monthly?.commitment_discount_data?.advantage_in_months\n\n return <>\n \n Engagement mensuel\n Paiement mensuel\n ,\n \n Engagement annuel*\n Paiement mensuel\n ]}\n buttonsStyle={{width: 180}}\n initialIndex={withCommitment}\n onSelectIndex={setWithCommitment}\n onPressAdditional={() => {\n withCommitmentField?.onChange(!withCommitment ? 1 : 0)\n setFormValues({\n ...control?._formValues,\n with_commitment: !withCommitment ? 1 : 0\n })\n }}/>\n {advantage}\n {withCommitment ? *Vous hésitez ? Résiliation possible sans condition pendant le 1er mois ! : null}\n\n {\n productNameField.onChange(productName)\n withCommitmentField.onChange(withCommitment)\n setFormValues({\n ...control._formValues,\n product_name: productName,\n with_commitment: withCommitment\n })\n goToNextStep()\n } : null}\n userEmail={userEmail}\n pricingTableData={pricingTableData}\n pricingTableDataNextMode={pricingTableDataNextMode}\n subscribedProductPriceId={subscribedProductPriceId}\n forceBigSize={forceBigSize}\n />\n \n}\n\nexport function ChooseSubscriptionOffer(props) {\n const { forceBigSize = false } = props;\n const dimensions = useContext(DimensionsContext)\n\n return forceBigSize ?\n \n \n : \n \n ;\n}\n\nconst SubscribeScreen = (props) => {\n\n\n const userEmailb64 = props.route?.params?.user ?? \"\"\n const userEmail = base64.decode(userEmailb64.replace(/-/g, \"\"))\n\n // if we are less than 2,5 days before the first of next month, then we start next month\n const startNextMonth = props.route?.params?.start_next_month ?? moment().startOf(\"month\").add(1, \"month\").startOf(\"month\").diff(moment(), \"hours\") < 60\n\n const initialShowDetails = !!props.route?.params?.show_details ?? false\n const status = props.route?.params?.status ?? null\n //remove any \"-\" in the base64 email and replace it by \"\"\n const navigation = useNavigation()\n\n const pricingTableData = props.pricingTableData\n const pricingTableDataNextMode = props.pricingTableDataNextMode\n const billingPortalUrl = props.billingPortalUrl\n const user = props.user\n\n const dimensions = useContext(DimensionsContext)\n\n const insets = useSafeAreaInsets()\n\n //hasRole(props.currentUser, \"admin\") ? {} : ( props.currentUser?.email == props.user?.email ? {} : navigation.push(\"menu\"));\n\n useEffect(() => {\n\n if (!props.currentUser || props.currentUser?.email === userEmail) {\n amplitude.setUserId(userEmail)\n setBugsnagUser({id: \"-\", email: userEmail, display_name: \"-\"})\n }\n\n // get infos from back\n props.apiRequest(subscriptionService.getSubscribePricing, {}, {}, {\n email: userEmail\n })\n\n if (status === \"success\") {\n DialogM.show({\n text1: \"Félicitations ! 🎉\",\n text2: \"Votre abonnement a bien été activé. Un mail de confirmation vous a été envoyé.\"\n })\n navigation.setParams({\n ...props.route.params,\n status: null\n })\n }\n }\n ,\n []\n )\n\n useApiStatus(\n subscriptionService.getSubscribePricing, // api service\n null, // success message on toast (string or null)\n false, // error message on toast (true) or keep it in redux state (false)\n (data) => {\n\n }, // success callback\n (error) => {\n console.log(error)\n }, // error callback\n true\n )\n\n return (\n \n {(props.request) ? <>\n \n {\"Chargement...\"}\n : props.error ? <>\n \n {props.error.message}\n \n {\n navigation.goBack()\n }}\n label={\"Retour à l'accueil\"}\n />\n : props.success ? \n \n \n \n \n \n\n \n {`${user?.firstname} ${user?.lastname}`}\n {`${user?.email}`}\n \n \n \n \n\n {!isSubscribed(user) && !isSubscriptionPaused(user) ? <>\n {\"S'abonner\"}\n Choisissez votre formule\n \n {props.faq?.length > 0 && }\n \n : <>\n {\"Mon portail parent\"}\n {!props.user?.subscription_state?.is_manual_sub && }\n \n {props.user?.current_study_programs?.length > 0 && \n Mes programmes de révision\n\n {props.user?.current_study_programs?.map(studyProgram => {\n return {\n navigation.push(\"study-program\", {id: studyProgram?.id})\n }}\n style={{\n width: dimensions?.width - 40,\n borderWidth: 1,\n borderRadius: 15,\n borderColor: theme.colors.lightMore,\n backgroundColor: theme.colors.white,\n marginBottom: 10\n }}>\n \n {{studyProgram?.title}}\n {{studyProgram?.school_subject?.name} | {studyProgram?.class}}\n \n \n })}\n }\n \n \n \n }\n \n \n : null}\n\n \n \n );\n}\nconst mapStateToProps = state => {\n return {\n request: state.api.getSubscribePricing?.request,\n success: state.api.getSubscribePricing?.success,\n error: state.api.getSubscribePricing?.error,\n currentUser: state.data.currentUser?.object,\n user: state.data.formData?.user,\n billingPortalUrl: state.data.formData?.billingPortalUrl,\n pricingTableData: state.data.formData?.pricingTableData,\n pricingTableDataNextMode: state.data.formData?.pricingTableDataNextMode,\n faq: state.data.formData?.faq,\n }\n}\n\nconst mapDispatchToProps = {\n apiRequestWithPrerequest,\n apiRequest,\n apiIdle\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps)(SubscribeScreen)","export function setStatusBarBackgroundColor() { }\nexport function setStatusBarNetworkActivityIndicatorVisible() { }\nexport function setStatusBarHidden() { }\nexport function setStatusBarStyle() { }\nexport function setStatusBarTranslucent() { }\nexport function StatusBar() {\n return null;\n}\n//# sourceMappingURL=StatusBar.web.js.map","","import React, {useContext} from \"react\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport {View} from \"react-native\";\nimport PricingColumnM from \"./PricingColumnM\";\n\nexport const PricingTableM = (props) => {\n const {withCommitment, pricingTableData, pricingTableDataNextMode, userEmail, startNextMonth = false, onPress = null, subscribedProductPriceId, forceBigSize = false} = props\n const dimensions = useContext(DimensionsContext)\n\n return \n {pricingTableData?.map((pricingColumn, index) => {\n return \n })}\n ;\n}","import React, {useContext, useState} from \"react\";\nimport {AbilityContext} from \"@data/utility/Can\";\nimport {getPrivilegedRole} from \"@data/utility/ability\";\nimport {ActivityIndicator, View} from 'react-native';\nimport {SubscriptionProductChip} from \"../SubscriptionPrivilegeChip\";\nimport TextM from \"@common/components/text/TextM\";\nimport {isSubscriptionPaused, isSubscriptionRecurring, isSubscriptionTrialing} from \"@data/utility/dataUtils\";\nimport moment from \"moment\";\nimport {ProductIcon, subscriptionStatusNames} from \"./MySubscriptionScreen\";\nimport {ProfileSection} from \"../ProfileSection\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport * as WebBrowser from \"expo-web-browser\";\nimport {theme} from \"@common/theme/theme\";\nimport TitleM from \"@common/components/text/TitleM\";\nimport {LinearGradient} from \"expo-linear-gradient\";\nimport {PremiumPlus} from \"@common/components/icons/IconsM\";\nimport {capitalize, formatDate} from \"@data/utility/Utils\";\nimport LinkTextM from \"@common/components/text/LinkTextM\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport base64 from \"@common/utils/base64\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {PrioritizedSchoolSubjects, SchoolSubjectBadge} from \"../../../tutor/students/ProfilDetails\";\nimport {apiIdle, apiRequest, apiRequestWithPrerequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {AvailabilitySlotsM} from \"../../../admin/AvailabilitySlotsM\";\nimport {PrivilegesChecklistM} from \"../../../auth/PricingColumnM\";\nimport ChangePaymentCollectionDayModal from \"./ChangePaymentCollectionDayModal\";\nimport {useApiStatus} from \"../../../common/hooks/useApiStatus\";\nimport {studentsService} from \"../../../data/services/studentsService\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\n\nfunction SubscriptionContinuityCTA(props) {\n\n const {user} = props\n const dimensions = useContext(DimensionsContext)\n\n const navigation = useNavigation()\n\n return \n \n \n La suite...\n {user?.firstname} semble avoir bien profité de l'accompagnement Masteur jusqu'ici. Ne vous\n arrêtez pas là, et\n profitez de notre offre de continuité* !\n *Offre promotionnelle valable\n jusqu'au {moment(user?.subscription_state?.end_date).add(-1, \"day\")?.format(\"DD MMMM YYYY\")}\n \n \n \n {\n const userEmail = base64.encode(user?.email)\n navigation.push(\"subscription-continuity\", {\n user: userEmail\n })\n }}\n label={\"En savoir plus\"}/>\n\n ;\n}\n\n\nfunction MySubscriptionInfos(props) {\n\n const {billingPortalUrl, user, plannedTableData, currentTableData, initialShowDetails = false} = props\n\n const ability = useContext(AbilityContext)\n const product = getPrivilegedRole(user)\n const productName = user?.subscription_state?.plan\n\n const commitmentEndsAt = user?.commitment_ends_at ? moment(user?.commitment_ends_at) : null\n const commitmentEndsAtFormatted = commitmentEndsAt?.isAfter(moment()) ? commitmentEndsAt.format(\"DD MMMM YYYY\") : null\n\n const nextPaymentAmount = user?.upcoming_invoice_data?.amount_due > 0 ? user?.upcoming_invoice_data?.amount_due : null //(user?.planned_subscription?.amount + user?.stripe_balance)\n\n const [nextPaymentAttempt, setNextPaymentAttempt] = useState(user?.upcoming_invoice_data?.next_payment_attempt ?? user?.planned_subscription?.start_date);\n\n const [showDetails, setShowDetails] = useState(initialShowDetails)\n\n const noSchoolSubject = !!user?.profile?.subject_priority && user?.prioritized_school_subjects?.length === 0\n\n const navigation = useNavigation()\n\n const [openPaymentCollectionDayModal, setOpenPaymentCollectionDayModal] = useState(false);\n const handleOpenPaymentCollectionDayModal = () => setOpenPaymentCollectionDayModal(!openPaymentCollectionDayModal);\n\n const [payment_collection_day, setpayment_collection_day] = useState(\"Ma date de prélèvement (le \" + user.payment_collection_day + \")\");\n\n const [loading, setLoading] = useState(false);\n\n\n useApiStatus(\n studentsService.studentChangePaymentCollectionDay, // api service\n null, // success message on toast (string or null)\n true, // error message on toast (true) or keep it in redux state (false)\n (successData) => {\n setpayment_collection_day(\"Ma date de prélèvement (le \" + successData.payment_collection_day + \")\")\n setLoading(false);\n const text2 = 'Votre prélèvement mensuel est désormais fixé au ' + successData.payment_collection_day + ' du mois';\n DialogM.show({\n text1: 'Opération réussie',\n text2: text2,\n onPress: () => {\n }\n });\n }// success callback\n )\n const handleUpdatePaymentCollectionDay = (newDay) => {\n\n setLoading(true);\n if (!user?.upcoming_invoice_data?.next_invoice_attempt)\n return;\n\n\n setpayment_collection_day(`Ma date de prélèvement (le ${newDay})`);\n\n const [year, month, day] = user?.upcoming_invoice_data?.next_invoice_attempt.split('-').map(Number);\n const date = new Date(year, month - 1, day); // Les mois sont indexés à partir de 0 en JavaScript\n\n // Ajouter les jours\n date.setDate(date.getDate() + newDay);\n\n // Formater la nouvelle date\n const newDate = date.toISOString().split('T')[0];\n setNextPaymentAttempt(newDate);\n };\n return <>\n {user?.current_holiday_courses?.length > 0 && \n {user?.current_holiday_courses?.map((course) => {\n\n return \n {/* name, start_date, end_date, class, first_school_subject_id, second_school_subject_id*/}\n \n {course?.name}\n {moment(course?.start_date).format(\"DD MMMM\")} - {moment(course?.end_date).format(\"DD MMMM\")}\n \n \n {course?.class}\n subject?.id === course?.first_school_subject_id)}/>\n {course?.second_school_subject_id && subject?.id === course?.second_school_subject_id)}/>}\n \n \n })}\n }\n \n \n\n \n \n \n\n \n\n \n {subscriptionStatusNames?.[user?.subscription_state?.status] ?? \"Pas d'abonnement actif\"}\n {\n setShowDetails(!showDetails)\n }}\n style={{\n fontSize: 10,\n marginTop: 8\n }}>Afficher les détails\n \n\n {showDetails &&\n \n {currentTableData &&\n }\n {isSubscriptionPaused(user) && user?.subscription_state?.end_date && user?.subscription_state?.end_date !== \"-\" &&\n \n \n Date de suspension :\n le {moment(user?.subscription_state?.end_date)?.format(\"DD MMMM YYYY\")}\n\n }\n\n {/* If no planned subscription */}\n {!isSubscriptionPaused(user) && !isSubscriptionRecurring(user) && !isSubscriptionTrialing(user) && user?.subscription_state?.end_date !== \"-\" &&\n \n \n Date de fin de l'abonnement :\n le {moment(user?.subscription_state?.end_date)?.format(\"DD MMMM YYYY\")}\n }\n\n {nextPaymentAmount > 0 &&\n \n \n Prochain paiement : {nextPaymentAmount}€\n le {moment(nextPaymentAttempt)?.format(\"DD MMMM YYYY\")} \n }\n\n {/* Only show this if planned subscription + (commited or after march) */}\n {user?.subscription_state?.planned_start_date && (Math.abs(moment().diff(moment(user?.subscription_state?.planned_start_date), \"months\")) <= 2) && <>\n \n \n {isSubscriptionPaused(user) ?\n \n Reprise en {user?.subscription_state?.planned_plan} prévue\n le {formatDate(moment(user?.subscription_state?.planned_start_date))}\n : \n Passage en {user?.subscription_state?.planned_plan} prévu\n le {formatDate(moment(user?.subscription_state?.planned_start_date))}\n }\n \n {!currentTableData && plannedTableData &&\n }\n {currentTableData && plannedTableData && = {plannedTableData?.product_slots}}\n }\n\n {commitmentEndsAtFormatted &&\n \n \n Date de fin de l'engagement :\n le {commitmentEndsAtFormatted}\n }\n\n }\n\n {!isSubscriptionPaused(user)\n && !isSubscriptionRecurring(user)\n && !isSubscriptionTrialing(user)\n && Math.abs(moment(user?.subscription_state?.end_date)?.diff(moment(), \"days\")) < 30\n && }\n \n \n {(isSubscriptionPaused(user) || isSubscriptionRecurring(user) || isSubscriptionTrialing(user)) && <>\n \n \n\n {/* 0}*/}\n {/* // textColor={theme.colors.white}*/}\n {/* onPress={() => {*/}\n {/* navigation.push(\"prioritized-school-subjects\", {user: base64.encode(user?.email)})*/}\n {/* }}*/}\n {/* labelStyle={{fontSize: 12, height: 16}}*/}\n {/* contentStyle={{height: 30}}*/}\n {/* label={!noSchoolSubject ? \"Je souhaite changer de matière\" : \"Choisir mes matières\"}/>*/}\n \n \n {user?.slots_possible?.length > 0\n ? \n : Pas de créneaux renseignés}\n {/* 0}*/}\n {/* onPress={() => {*/}\n {/* navigation.push(\"availability-slots\", {user: base64.encode(user?.email)})*/}\n {/* }}*/}\n {/* style={{*/}\n {/* marginTop: 7,*/}\n {/* alignSelf: \"center\"*/}\n {/* }}*/}\n {/* labelStyle={{fontSize: 12, height: 16}}*/}\n {/* contentStyle={{height: 30}}*/}\n {/* label={user?.slots_possible?.length > 0 ? \"Je souhaite changer d'horaires\" : \"Indiquer mes disponibilités\"}/>*/}\n \n }\n \n\n {!user?.subscription_state?.is_manual_sub && <>\n {\n handleOpenPaymentCollectionDayModal();\n }}\n labelStyle={{fontSize: 12, height: 16}}\n contentStyle={{height: 30}}\n label={\n \n {payment_collection_day?.toUpperCase()}\n {loading && (\n \n )}\n \n }\n disabled={loading}/>\n\n {(\n \n )}\n\n {\n if (IS_WEB) {\n window.open(billingPortalUrl + \"/payment-methods\");\n } else {\n WebBrowser.openBrowserAsync(billingPortalUrl + \"/payment-methods\");\n }\n }}\n labelStyle={{fontSize: 12, height: 16}}\n contentStyle={{height: 30}}\n label={\"Mon moyen de paiement\"}/>\n {\n if (IS_WEB) {\n window.open(billingPortalUrl);\n } else {\n WebBrowser.openBrowserAsync(billingPortalUrl);\n }\n }}\n labelStyle={{fontSize: 12, height: 16}}\n contentStyle={{height: 30}}\n label={\"Mes factures\"}/>\n }\n\n {\n const url = \"https://wa.me/message/FCOBQ6PCPMBJC1\"\n if (IS_WEB) {\n window.open(url);\n } else {\n WebBrowser.openBrowserAsync(url);\n }\n }}\n labelStyle={{fontSize: 12, height: 16}}\n contentStyle={{height: 30}}\n label={\"Contacter le support\"}/>\n {/*{!commitmentEndsAtFormatted && {*/}\n {/* }}*/}\n {/* disabled*/}\n {/* style={{}}*/}\n {/* labelStyle={{fontSize: 12}}*/}\n {/* contentStyle={{height: 30}}*/}\n {/* label={\"Suspendre mon abonnement\"}/>}*/}\n \n \n}\n\nconst mapStateToProps = state => {\n return {\n request: state.api.getSubscribePricing?.request,\n success: state.api.getSubscribePricing?.success,\n error: state.api.getSubscribePricing?.error,\n user: state.data.formData?.user,\n billingPortalUrl: state.data.formData?.billingPortalUrl,\n pricingTableData: state.data.formData?.pricingTableData,\n schoolSubjects: state.data.formData?.schoolSubjects,\n pricingTableDataNextMode: state.data.formData?.pricingTableDataNextMode\n }\n}\n\nconst mapDispatchToProps = {\n apiRequestWithPrerequest,\n apiRequest,\n apiIdle\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps)(MySubscriptionInfos)","// ** Imports createContext function\nimport {createContext} from 'react'\n\n// ** Imports createContextualCan function\nimport {createContextualCan} from '@casl/react'\n\n// ** CreateM Context\nexport const AbilityContext = createContext()\n\n// ** Init Can Context\nexport const Can = createContextualCan(AbilityContext.Consumer)\n","import t,{Fragment as n,createElement as r,Children as i,PureComponent as u}from\"react\";function e(t,n){for(var r=0;r1?r.apply(void 0,[n,null].concat(t)):i.only(t)}:i.only;var l=function(t){c(n,t);function n(){var n;for(var r=arguments.length,i=new Array(r),u=0;u= 16.8 in order to use useAbility()\");var r=t.useContext(n);var i=t.useState(),u=i[0],e=i[1];t.useEffect((function(){return r.on(\"updated\",(function(t){if(t.rules!==u)e(t.rules)}))}),[]);return r}export{l as Can,v as createCanBoundTo,b as createContextualCan,useAbility};\n//# sourceMappingURL=index.js.map\n","import _extends from \"@babel/runtime/helpers/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nvar _excluded = [\"animating\", \"color\", \"hidesWhenStopped\", \"size\", \"style\"];\n/**\n * Copyright (c) Nicolas Gallagher.\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport * as React from 'react';\nimport StyleSheet from '../StyleSheet';\nimport View from '../View';\nvar createSvgCircle = style => /*#__PURE__*/React.createElement(\"circle\", {\n cx: \"16\",\n cy: \"16\",\n fill: \"none\",\n r: \"14\",\n strokeWidth: \"4\",\n style: style\n});\nvar ActivityIndicator = /*#__PURE__*/React.forwardRef((props, forwardedRef) => {\n var _props$animating = props.animating,\n animating = _props$animating === void 0 ? true : _props$animating,\n _props$color = props.color,\n color = _props$color === void 0 ? '#1976D2' : _props$color,\n _props$hidesWhenStopp = props.hidesWhenStopped,\n hidesWhenStopped = _props$hidesWhenStopp === void 0 ? true : _props$hidesWhenStopp,\n _props$size = props.size,\n size = _props$size === void 0 ? 'small' : _props$size,\n style = props.style,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n var svg = /*#__PURE__*/React.createElement(\"svg\", {\n height: \"100%\",\n viewBox: \"0 0 32 32\",\n width: \"100%\"\n }, createSvgCircle({\n stroke: color,\n opacity: 0.2\n }), createSvgCircle({\n stroke: color,\n strokeDasharray: 80,\n strokeDashoffset: 60\n }));\n return /*#__PURE__*/React.createElement(View, _extends({}, other, {\n \"aria-valuemax\": 1,\n \"aria-valuemin\": 0,\n ref: forwardedRef,\n role: \"progressbar\",\n style: [styles.container, style]\n }), /*#__PURE__*/React.createElement(View, {\n children: svg,\n style: [typeof size === 'number' ? {\n height: size,\n width: size\n } : indicatorSizes[size], styles.animation, !animating && styles.animationPause, !animating && hidesWhenStopped && styles.hidesWhenStopped]\n }));\n});\nActivityIndicator.displayName = 'ActivityIndicator';\nvar styles = StyleSheet.create({\n container: {\n alignItems: 'center',\n justifyContent: 'center'\n },\n hidesWhenStopped: {\n visibility: 'hidden'\n },\n animation: {\n animationDuration: '0.75s',\n animationKeyframes: [{\n '0%': {\n transform: 'rotate(0deg)'\n },\n '100%': {\n transform: 'rotate(360deg)'\n }\n }],\n animationTimingFunction: 'linear',\n animationIterationCount: 'infinite'\n },\n animationPause: {\n animationPlayState: 'paused'\n }\n});\nvar indicatorSizes = StyleSheet.create({\n small: {\n width: 20,\n height: 20\n },\n large: {\n width: 36,\n height: 36\n }\n});\nexport default ActivityIndicator;","import {View} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport {Text} from \"react-native-paper\";\nimport React from \"react\";\nimport {offersNames} from \"@data/utility/ability\";\n\nexport const productsColors = {\n basic: theme.colors.light,\n plus: theme.colors.material.secondary[\"200\"],\n premium: theme.colors.accentDark,\n initial: theme.colors.material.secondary[\"300\"],\n essential: theme.colors.material.secondary[\"500\"],\n integral: theme.colors.material.secondary[\"700\"],\n holidaycourse: theme.colors.material.secondary[\"200\"],\n}\n\nexport const productsLightColors = {\n basic: theme.colors.lighter,\n plus: theme.colors.material.secondary[\"50\"],\n premium: theme.colors.material.secondary[\"100\"],\n initial: theme.colors.material.secondary[\"50\"],\n essential: theme.colors.material.secondary[\"100\"],\n integral: theme.colors.material.secondary[\"200\"],\n holidaycourse: theme.colors.material.secondary[\"100\"],\n}\n\nexport function SubscriptionPrivilegeChip({product = \"basic\", withRotation = false, style, large = false}) {\n return \n \n {offersNames?.[product]}\n \n ;\n}\n\nexport function SubscriptionProductChip({product = \"basic\", withRotation = false, style, large = false}) {\n return \n \n {product}\n \n ;\n}","import React, {useContext} from 'react';\nimport {Platform, RefreshControl, ScrollView, StatusBar, View} from \"react-native\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {theme} from \"@common/theme/theme\";\nimport {connect, useSelector} from \"react-redux\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport {useSafeAreaInsets} from \"react-native-safe-area-context\";\nimport TextM from \"@common/components/text/TextM\";\nimport {getPrivilegedRole, isOnTrial} from \"@data/utility/ability\";\nimport {authService} from \"@data/services/authService\";\nimport {isSubscribed, isSubscriptionPaused} from \"@data/utility/dataUtils\";\nimport {URL} from 'react-native-url-polyfill';\nimport {offersImages} from \"../../../auth/PricingColumnM\";\nimport {canSubscribeToTrialEssential} from \"./BecomePremiumCard\";\nimport {SubscriptionStateCard} from \"./SubscriptionStateCard\";\n\n\nexport const subscriptionStatusNames = {\n recurring: \"Abonnement actif\",\n past_due: \"Abonnement actif - en retard de paiement\",\n on_grace_period: \"Abonnement actif jusqu'à échéance\",\n on_trial: \"Essai gratuit en cours\",\n on_generic_trial: \"Essai gratuit en cours\",\n on_grace_period_before_pause: \"Mise en pause planifiée\",\n paused: \"Abonnement mis en pause\",\n planned: \"Activation planifiée\",\n expired_trial: \"Essai gratuit expiré\",\n ended: \"Abonnement expiré\"\n}\n\n\nexport const ProductIcon = ({size = 24, style, user = null}) => {\n\n const thisUser = user ?? useSelector(state => state.data.currentUser?.object)\n\n return getPrivilegedRole(thisUser) !== \"basic\" && \n}\n\nconst MySubscriptionScreen = (props) => {\n\n // ** Component props\n const {navigation} = props\n\n const insets = useSafeAreaInsets();\n\n const product = getPrivilegedRole(props.user)\n\n const dimensions = useContext(DimensionsContext)\n return (\n \n\n props.apiRequest(authService.getUser)}\n />}\n contentContainerStyle={{\n alignItems: \"center\"\n }}\n >\n {/**/}\n\n \n\n {((product === \"basic\"))\n && {\n if (canSubscribeToTrialEssential(props.user))\n navigation.push(\"start-trial\")\n else\n navigation.push(\"offer-essential\")\n }}\n textColor={theme.colors.white}\n style={{\n width: Platform.OS !== 'web' ? dimensions?.width - 20 : dimensions?.width / 2.5,\n marginTop: 30\n }}\n label={canSubscribeToTrialEssential(props.user) ? \"ESSAI GRATUIT\" : \"Voir les offres\"}/>}\n\n {(isOnTrial(props.user))\n && !isSubscriptionPaused(props.user)\n && (Platform.OS !== \"ios\" ? {\n // navigation.replace(\"choose-trial\", {product: \"product\"})\n const url = new URL(props.user?.subscribe_url)\n navigation.push(url.pathname.slice(1), {\n user: url.searchParams.get(\"user\")\n })\n // WebBrowser.openBrowserAsync(props.user?.subscribe_url)\n }}\n // labelStyle={{color: theme.colors.white}}\n style={{\n // width: dimensions?.width - 20,\n marginTop: 30\n }}\n label={(isSubscribed(props.user)) ? \"Mon abonnement\" : \"S'abonner\"}/> : (!isOnTrial(props.user))\n ? null\n : \n On ne peut pas s'abonner dans l'appli. Ce n'est pas idéal, nous le savons.\n )}\n\n {(product !== \"basic\"\n && !isOnTrial(props.user))\n && (Platform.OS !== \"ios\" ? {\n const url = new URL(props.user?.subscribe_url)\n navigation.push(url.pathname.slice(1), {\n user: url.searchParams.get(\"user\")\n })\n }}\n // labelStyle={{color: theme.colors.white}}\n style={{\n width: dimensions?.width - 20,\n marginTop: 30\n }}\n label=\"Gérer l'abonnement\"/> : null)}\n\n {IS_WEB && {\n if (navigation.canGoBack())\n navigation.goBack()\n else\n navigation.replace(\"account\")\n }}\n label={\"Retour\"}/>}\n\n \n \n\n \n \n );\n}\nconst mapStateToProps = state => {\n return {\n user: state.data.currentUser?.object,\n getUserRequest: state.api.getUser?.request\n\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(MySubscriptionScreen)","import {Linking, View} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport TextM from \"@common/components/text/TextM\";\nimport {PremiumCoach, PremiumPlus} from \"@common/components/icons/IconsM\";\nimport React, {useContext} from \"react\";\nimport {Text} from \"react-native-paper\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {getPrivilegedRole, hasRole} from \"@data/utility/ability\";\nimport {AbilityContext} from \"@data/utility/Can\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {isSubscribed, isSubscriptionPaused, subscriptionPausePeriod} from \"@data/utility/dataUtils\";\n\n// export const minSwitchToPremiumRemainingDays = 3\n\nexport const canSubscribeToTrialEssential = (user) => getPrivilegedRole(user) === \"basic\"\nexport const canSubscribeToEssential = (user) => getPrivilegedRole(user) === \"basic\" && !user?.tutor\n\n\nconst BecomePremiumCard = (props) => {\n\n // ** Component props\n const {style, index = 0} = props\n\n const navigation = useNavigation()\n\n const ability = useContext(AbilityContext)\n\n // function getRandomInt(max) {\n // return Math.floor(Math.random() * max);\n // }\n\n // const diffDays = moment(props.user?.trial_ends_at).diff(moment().add(minSwitchToPremiumRemainingDays, \"days\"), \"days\")\n\n // const index = getRandomInt(2) === 1 ? 0 : 1\n // const canSwitchToEssentialTrial = canSwitchToEssential(props.user)\n\n // console.log(product)\n\n // const canSubscribeToPlus = product === \"basic\"\n const initialCondition = hasRole(props.user, 'student') && !isSubscribed(props.user) && ability.cannot(\"read\", \"holiday_course_views\")\n\n const premiumAdsContent = [\n {\n title: \"Offre Essentielle\",\n description: \"Bénéficie d'un suivi sur mesure par un tuteur\",\n // descriptionTrial: (diffDays === 0 ? \"Dernier jour\" : (\"Plus que \" + diffDays + \" jour\" + (diffDays > 1 ? \"s\" : \"\"))) + \" pour profiter d'un entretien gratuit !\",\n premium_icon: false\n }\n // {\n // title: \"Masteur Plus\",\n // description: \"Bénéficie de conseils et d'un score sur toutes tes activités\",\n // premium_icon: false\n // },\n\n ]\n\n\n function onPress() {\n if (canSubscribeToTrialEssential(props.user))\n navigation.push(\"start-trial\")\n else\n navigation.push(\"offer-essential\")\n }\n\n const dimensions = useContext(DimensionsContext)\n\n return (initialCondition && (\n (index === 0 && (canSubscribeToTrialEssential(props.user) || canSubscribeToEssential(props.user)))\n )\n ) ? \n \n\n \n \n {isSubscriptionPaused(props.user) ? \"Abonnement en pause\" : premiumAdsContent[index]?.title}\n \n {\n {isSubscriptionPaused(props.user) ? \"Ton abonnement est en pause \" + subscriptionPausePeriod(props.user) : premiumAdsContent[index]?.description}\n {/*{(index === 0 || (index === 1 && !canSwitchToPremiumTrial)) ? premiumAdsContent[index]?.description : premiumAdsContent[index]?.descriptionTrial}*/}\n }\n \n\n\n {premiumAdsContent[index]?.premium_icon ? : }\n\n \n {isSubscriptionPaused(props.user) ?\n {\n if (IS_WEB)\n location.href = \"mailto:support@masteur.com\"\n else\n Linking.openURL(\"mailto:support@masteur.com\").catch(err => console.error(\"Couldn't load page\", err))\n }}\n label={\"Une question ?\"}/>\n : }\n \n : null\n}\n\nconst mapStateToProps = state => {\n return {\n\n user: state.data.currentUser?.object\n\n\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(BecomePremiumCard)","import {theme} from \"@common/theme/theme\";\nimport TextM from \"@common/components/text/TextM\";\nimport React, {useContext} from \"react\";\nimport {AbilityContext} from \"@data/utility/Can\";\nimport moment from \"moment\";\nimport {getPrivilegedRole, hasRole} from \"@data/utility/ability\";\nimport TouchableRippleM from \"@common/components/button/TouchableRippleM\";\nimport { productsLightColors, SubscriptionPrivilegeChip, SubscriptionProductChip } from \"../SubscriptionPrivilegeChip\"\nimport {useNavigation} from \"@react-navigation/native\";\nimport {View} from \"react-native\";\nimport {formatDate} from \"@data/utility/Utils\";\n\nexport function SubscriptionStateCard({user, style, disabled}) {\n\n const ability = useContext(AbilityContext)\n const navigation = useNavigation()\n const onPress = () => {\n navigation.push(\"my-privileges\")\n }\n\n const productName = user?.subscription_state?.plan\n\n return hasRole(user, \"student\") ? <>\n {/*Mes privilèges*/}\n \n <>\n \n \n\n {ability.can(\"read\", \"holiday_course_views\") && }\n \n \n {moment(user?.trial_ends_at).isAfter(moment()) ?\n Fin de l'essai gratuit :\n le {moment(user?.trial_ends_at).format(\"DD MMMM YYYY\")} :\n Voir\n les détails\n }\n \n \n \n \n : null\n\n}","import withPreventDoubleClick from \"../../utils/withPreventDoubleClick\";\nimport {TouchableRipple} from \"react-native-paper\";\n\n\nfunction TouchableRippleM(props) {\n return {props.children};\n}\n\nexport default withPreventDoubleClick(TouchableRippleM)","import {View} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport TitleM from \"@common/components/text/TitleM\";\nimport React, {useContext} from \"react\";\n\nexport const ProfileSection = ({title, children, style, noBorder = false, tiny = false}) => {\n const dimensions = useContext(DimensionsContext)\n\n return \n {title && {title} }\n\n {children}\n \n}","// Copyright © 2024 650 Industries.\n'use client';\nimport * as React from 'react';\nimport { Platform, processColor } from 'react-native';\nimport NativeLinearGradient from './NativeLinearGradient';\n/**\n * Renders a native view that transitions between multiple colors in a linear direction.\n */\nexport class LinearGradient extends React.Component {\n render() {\n const { colors, locations, start, end, dither, ...props } = this.props;\n let resolvedLocations = locations;\n if (locations && colors.length !== locations.length) {\n console.warn('LinearGradient colors and locations props should be arrays of the same length');\n resolvedLocations = locations.slice(0, colors.length);\n }\n return ();\n }\n}\nfunction _normalizePoint(point) {\n if (!point) {\n return undefined;\n }\n if (Array.isArray(point) && point.length !== 2) {\n console.warn('start and end props for LinearGradient must be of the format [x,y] or {x, y}');\n return undefined;\n }\n return Array.isArray(point) ? point : [point.x, point.y];\n}\n//# sourceMappingURL=LinearGradient.js.map","import * as React from 'react';\nimport { View } from 'react-native';\nimport { normalizeColor } from './normalizeColor';\nexport default function NativeLinearGradient({ colors, locations, startPoint, endPoint, ...props }) {\n const [{ height, width }, setLayout] = React.useState({\n height: 1,\n width: 1,\n });\n // TODO(Bacon): In the future we could consider adding `backgroundRepeat: \"no-repeat\"`. For more\n // browser support.\n const linearGradientBackgroundImage = React.useMemo(() => {\n return getLinearGradientBackgroundImage(colors, locations, startPoint, endPoint, width, height);\n }, [colors, locations, startPoint, endPoint, width, height]);\n return ( {\n const { width, height } = event.nativeEvent.layout;\n setLayout((oldLayout) => {\n // don't set new layout state unless the layout has actually changed\n if (width !== oldLayout.width || height !== oldLayout.height) {\n return { height, width };\n }\n return oldLayout;\n });\n if (props.onLayout) {\n props.onLayout(event);\n }\n }}/>);\n}\n/**\n * Extracted to a separate function in order to be able to test logic independently.\n */\nexport function getLinearGradientBackgroundImage(colors, locations, startPoint, endPoint, width = 1, height = 1) {\n const gradientColors = calculateGradientColors(colors, locations);\n const angle = calculatePseudoAngle(width, height, startPoint, endPoint);\n return `linear-gradient(${angle}deg, ${gradientColors.join(', ')})`;\n}\nfunction calculatePseudoAngle(width, height, startPoint, endPoint) {\n const getControlPoints = () => {\n let correctedStartPoint = [0, 0];\n if (Array.isArray(startPoint)) {\n correctedStartPoint = [\n startPoint[0] != null ? startPoint[0] : 0.0,\n startPoint[1] != null ? startPoint[1] : 0.0,\n ];\n }\n let correctedEndPoint = [0.0, 1.0];\n if (Array.isArray(endPoint)) {\n correctedEndPoint = [\n endPoint[0] != null ? endPoint[0] : 0.0,\n endPoint[1] != null ? endPoint[1] : 1.0,\n ];\n }\n return [correctedStartPoint, correctedEndPoint];\n };\n const [start, end] = getControlPoints();\n start[0] *= width;\n end[0] *= width;\n start[1] *= height;\n end[1] *= height;\n const py = end[1] - start[1];\n const px = end[0] - start[0];\n return 90 + (Math.atan2(py, px) * 180) / Math.PI;\n}\nfunction calculateGradientColors(colors, locations) {\n return colors.map((color, index) => {\n const output = normalizeColor(color);\n if (locations && locations[index]) {\n const location = Math.max(0, Math.min(1, locations[index]));\n // Convert 0...1 to 0...100\n const percentage = location * 100;\n return `${output} ${percentage}%`;\n }\n return output;\n });\n}\n//# sourceMappingURL=NativeLinearGradient.web.js.map","/**\n * Copyright (c) Expo.\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport { processColor } from 'react-native';\nconst isWebColor = (color) => color === 'currentcolor' ||\n color === 'currentColor' ||\n color === 'inherit' ||\n color.indexOf('var(') === 0;\nexport function normalizeColor(color, opacity = 1) {\n if (color == null)\n return;\n if (typeof color === 'string' && isWebColor(color)) {\n return color;\n }\n const colorInt = processColor(color);\n if (colorInt != null) {\n const r = (colorInt >> 16) & 255;\n const g = (colorInt >> 8) & 255;\n const b = colorInt & 255;\n const a = ((colorInt >> 24) & 255) / 255;\n const alpha = (a * opacity).toFixed(2);\n return `rgba(${r},${g},${b},${alpha})`;\n }\n}\n//# sourceMappingURL=normalizeColor.js.map","import React, {useContext} from 'react';\nimport {View} from \"react-native\";\nimport TextM from \"@common/components/text/TextM\";\nimport {subjectPriorities} from \"@data/constants/formConstants\";\nimport {theme} from \"@common/theme/theme\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport {whatIsIt} from \"@data/utility/Utils\";\nimport {AbilityContext} from \"@data/utility/Can\";\n\n\nexport const PrioritizedSchoolSubjects = ({\n student,\n warningMode = false,\n iconWidth = 24,\n fontSize = 14,\n style,\n subjectStyle = {maxWidth: 180},\n ellipsize = false,\n }) => \n {student?.prioritized_school_subjects?.length > 0\n ?\n (student?.prioritized_school_subjects?.map((item) => {\n\n return \n }))\n : student?.profile?.desired_support === \"Aide aux devoirs\"\n ? \n : {warningMode ? \"Pas de matière choisie\" : \"-\"}\n }\n\n\nexport const SchoolSubjectBadge = ({schoolSubject, iconWidth, fontSize, style, ellipsize = false}) => {\n return \n {schoolSubject?.icon && }\n {\n {!ellipsize\n ? schoolSubject?.name\n : (schoolSubject?.name === \"Aide aux devoirs\"\n ? \"Aide aux devoirs\"\n : schoolSubject?.name.length > 1\n ? schoolSubject?.name?.substring(0, 1) + \".\"\n : schoolSubject?.name)}\n\n }\n \n}\n\nexport const profilItem = (text, content, borderBottom) => {\n\n const displayArrayContent = whatIsIt(content) === \"Array\" ? content?.length > 0 ? content : null : null\n const dimensions = useContext(DimensionsContext)\n return 800 ? 'row' : null,\n justifyContent: 'space-between'\n }}>\n \n {text}:\n \n {displayArrayContent ? \n {displayArrayContent}\n : content ? \n {content}\n \n : \n (non renseigné)\n }\n \n}\n\nfunction ProfileDetails(props) {\n const {student} = props\n\n const ability = useContext(AbilityContext)\n\n return (\n <>\n \n {(ability.can(\"read\", \"backOffice\") || ability.can(\"read\", \"review_activities\")) && <>\n {profilItem(\"E-mail\", `Elève : ${student?.email ?? \"-\"} | Parent : ${student?.parent_email ?? \"-\"}`)}\n {profilItem(\"Numéro de téléphone\", `Elève : ${student?.mobile ?? \"-\"} | Parent : ${student?.parent_mobile ?? \"-\"}`)}\n }\n {profilItem(\"Fuseau horaire\", student?.timezone)}\n {profilItem(\"Comment j'ai connu Masteur\", student?.channel)}\n {profilItem(\"Classe\", student?.profile?.class)}\n {profilItem(\"Accompagnement souhaité\", student?.profile?.desired_support)}\n {profilItem(\"Matière(s) choisie(s)\", )}\n {profilItem(\"Masteur peut m'être utile pour\", student?.reason)}\n {profilItem(\"Matières où j'ai le plus besoin de m'améliorer\", student?.profile?.subject_priority ? subjectPriorities?.find(x => x?.value === student?.profile?.subject_priority)?.label : null)}\n {profilItem(\"J'ai une préférence pour les matières\", student?.profile?.subject_preference ? subjectPriorities?.find(x => x?.value === student?.profile?.subject_preference)?.label : null)}\n {profilItem(\"Ville\", student?.profile?.city)}\n {profilItem(\"Etablissement scolaire\", student?.profile?.school_name, true)}\n\n\n {(student?.profile?.class === \"1ère\" || student?.profile?.class === \"Tle\") &&\n profilItem(\"Mes matières de spécialité\", student?.school_subjects?.filter(item => item?.specialty)?.map((item, index) => {\n return \n }))}\n\n\n {profilItem(\"Mes principales qualités\", student?.profile?.qualities?.map((item) => {\n return \n \n {item}\n \n \n }))}\n {profilItem(\"Les matières que j'apprécie le plus\", student?.appreciated_school_subjects?.map((item) => {\n return \n }), true) ?? null}\n\n {profilItem(\"Le(s) métier(s) où je m'imagine plus tard\", student?.profile?.future_job)}\n {profilItem(\"L'orientation que je souhaiterais\", student?.profile?.future_orientation, true)}\n\n {profilItem(props.personalWorkForm?.duration?.title, student?.profile?.personal_work?.duration)}\n {profilItem(props.personalWorkForm?.frequency?.title, student?.profile?.personal_work?.frequency)}\n\n \n \n )\n}\n\nconst mapStateToProps = state => {\n return {\n personalWorkForm: state.data.staticData?.personal_work_form\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ProfileDetails)","import {View} from \"react-native\";\nimport {daysOptions} from \"@data/constants/formConstants\";\nimport {BadgeM} from \"@common/components/badge/BadgeM\";\nimport {theme} from \"@common/theme/theme\";\nimport React from \"react\";\n\nexport function AvailabilitySlotsM({slots}) {\n return \n {slots?.map((slot, key) => {\n const day = slot.split(\" \")[0]\n const hour = slot.split(\" \")[1]\n const dayFr = daysOptions?.find(d => d.value === day)?.label\n return \n })}\n\n ;\n}","import React, { useContext, useState } from \"react\";\nimport { DimensionsContext, IS_WEB } from \"@common/utils/mobileUtils\";\nimport { ModalM } from \"@common/components/modal/ModalM\";\nimport TitleM from \"@common/components/text/TitleM\";\nimport { theme } from \"@common/theme/theme\";\nimport { useController, useForm } from \"react-hook-form\";\nimport TextInputM from \"../../../common/components/input/TextInputM\";\nimport { yupResolver } from \"@hookform/resolvers/yup\";\nimport yup from \"../../../data/utility/validation\";\nimport FilledButtonM from \"../../../common/components/button/FilledButtonM\";\nimport { backOfficeService } from \"../../../data/services/backOfficeService\";\nimport { useApiStatus } from \"../../../common/hooks/useApiStatus\";\nimport { ListItemM } from \"../../../common/components/list/ListItemM\";\nimport { ListGroupM } from \"../../../common/components/list/ListGroupM\";\nimport { View } from \"react-native\";\nimport { studentsService } from \"../../../data/services/studentsService\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\n\nconst formSchema = yup.object().shape({\n transfer_amount: yup.number().required(),\n tutoring_credit_amount: yup.number().required(),\n application_fee_amount: yup.number().required(),\n application_compensation_amount: yup.number().required(),\n});\n\nexport default function ChangePaymentCollectionDayModal(props) {\n const { isOpen, handleShowModal, data , onUpdatePaymentCollectionDay , isLoading, apiRequest } = props;\n const dimensions = useContext(DimensionsContext);\n const resolver = yupResolver(formSchema);\n \n const [payment_collection_day, setpayment_collection_day] = useState(data.payment_collection_day);\n\n const items = [\n {\n value: 1,\n description: \"Le 1 du mois\",\n },\n {\n value: 3,\n description: \"Le 3 du mois\",\n },\n {\n value: 5,\n description: \"Le 5 du mois\",\n },\n {\n value: 7,\n description: \"Le 7 du mois\",\n },\n {\n value: 9,\n description: \"Le 9 du mois\",\n },\n ];\n\n const {\n control,\n handleSubmit,\n formState: { errors, dirtyFields },\n } = useForm({\n resolver,\n defaultValues: {\n payment_collection_day: payment_collection_day,\n },\n });\n\n const { field } = useController({\n control,\n name: \"payment_collection_day\",\n });\n\n const onSubmit = (payment_collection_day) => {\n onUpdatePaymentCollectionDay(payment_collection_day.payment_collection_day);\n props.apiRequest(studentsService.studentChangePaymentCollectionDay, {}, {\n day: payment_collection_day.payment_collection_day,\n email: data?.email\n })\n };\n\n useApiStatus(\n studentsService.studentChangePaymentCollectionDay, // api service\n null, // success message on toast (string or null)\n true, // error message on toast (true) or keep it in redux state (false)\n (successData) => {\n setpayment_collection_day(successData.payment_collection_day)\n }// success callback\n)\n // useApiStatus(\n // backOfficeService.editBilling, // api service\n // null, // success message on toast (string or null)\n // true, // error message from server in toast (true) or keep it in redux state (false)\n // (successData) => {\n // }\n // );\n return (\n 800 ? \"50%\" : \"90%\",\n maxHeight: \"80%\",\n padding: 20,\n alignItems: \"center\",\n }}\n >\n Ma date de prélèvement\n \n {\n return (\n {\n field.onChange(item.item?.value);\n const text2 = 'Nouvelle date : le '+item.item?.value+' du mois';\n DialogM.show({\n text1: 'Voulez-vous changer votre date de prélèvement ?',\n text2: text2,\n buttonText1: 'Confirmer',\n buttonColor1: theme.colors.primary,\n onPress: () => { onSubmit({ payment_collection_day : item.item?.value }) },\n buttonText2: 'Annuler',\n onPressBack: () => {}\n });\n handleShowModal();\n }}\n itemHeight={70}\n selected={item.item?.value === payment_collection_day}\n option={item.item}\n />\n );\n }}\n />\n \n \n );\n}\n","import{validateFieldsNatively as e,toNestError as t}from\"@hookform/resolvers\";import{appendErrors as r}from\"react-hook-form\";var o=function(o,n,a){return void 0===n&&(n={}),void 0===a&&(a={}),function(s,i,c){try{return Promise.resolve(function(t,r){try{var u=(n.context&&\"development\"===process.env.NODE_ENV&&console.warn(\"You should not used the yup options context. Please, use the 'useForm' context object instead\"),Promise.resolve(o[\"sync\"===a.mode?\"validateSync\":\"validate\"](s,Object.assign({abortEarly:!1},n,{context:i}))).then(function(t){return c.shouldUseNativeValidation&&e({},c),{values:a.rawValues?s:t,errors:{}}}))}catch(e){return r(e)}return u&&u.then?u.then(void 0,r):u}(0,function(e){if(!e.inner)throw e;return{values:{},errors:t((o=e,n=!c.shouldUseNativeValidation&&\"all\"===c.criteriaMode,(o.inner||[]).reduce(function(e,t){if(e[t.path]||(e[t.path]={message:t.message,type:t.type}),n){var o=e[t.path].types,a=o&&o[t.type];e[t.path]=r(t.path,n,e,t.type,a?[].concat(a,t.message):t.message)}return e},{})),c)};var o,n}))}catch(e){return Promise.reject(e)}}};export{o as yupResolver};\n//# sourceMappingURL=yup.module.js.map\n","import{get as r,set as i}from\"react-hook-form\";var e=function(i,e,t){if(i&&\"reportValidity\"in i){var f=r(t,e);i.setCustomValidity(f&&f.message||\"\"),i.reportValidity()}},t=function(r,i){var t=function(t){var f=i.fields[t];f&&f.ref&&\"reportValidity\"in f.ref?e(f.ref,t,r):f.refs&&f.refs.forEach(function(i){return e(i,t,r)})};for(var f in i.fields)t(f)},f=function(e,f){f.shouldUseNativeValidation&&t(e,f);var o={};for(var a in e){var n=r(f.fields,a);i(o,a,Object.assign(e[a],{ref:n&&n.ref}))}return o};export{f as toNestError,t as validateFieldsNatively};\n//# sourceMappingURL=resolvers.module.js.map\n","import React, {useContext, useState} from \"react\";\nimport FilledButtonM from \"./FilledButtonM\";\nimport {View} from \"react-native\";\nimport {theme} from \"../../theme/theme\";\nimport {DimensionsContext} from \"../../utils/mobileUtils\";\n\nexport const ToggleButtonM = props => {\n\n const {\n color = theme.colors.white,\n labels = [],\n subLabels = [],\n trackingIds = null,\n initialIndex = 0,\n onSelectIndex = (index) => {\n },\n style={},\n buttonsStyle={},\n labelStyle={},\n contentStyle={},\n disabled = false,\n onPressAdditional = () => {\n }\n } = props\n const [selectedIndex, setSelectedIndex] = useState(initialIndex)\n const dimensions = useContext(DimensionsContext)\n\n return \n {labels?.map((label, index) => {\n\n const isSelected = index === selectedIndex\n const isFirst = index === 0\n const isLast = index === labels?.length - 1\n\n\n return {\n setSelectedIndex(index)\n onSelectIndex(index)\n onPressAdditional()\n }}\n />\n\n })}\n \n\n}","import moment from \"moment\"\nimport { hasRole } from \"@data/utility/ability\"\nimport { Dimensions, View } from \"react-native\"\nimport { theme } from \"@common/theme/theme\"\nimport { IconImageM } from \"@common/components/icons/IconsM\"\nimport live from \"../../../../assets/icons/generic/live.png\"\nimport TextM from \"@common/components/text/TextM\"\nimport { capitalize } from \"@data/utility/Utils\"\nimport FilledButtonM from \"@common/components/button/FilledButtonM\"\nimport React, { useContext, useEffect, useState } from \"react\"\nimport { DimensionsContext } from \"@common/utils/mobileUtils\"\nimport { apiIdle, apiRequest } from \"@data/redux/actions/api\"\nimport { setTodoActivities } from \"@data/redux/actions/data\"\nimport { setIsLiveModeEnabled } from \"@data/redux/actions/liveMode\"\nimport { connect, useSelector } from \"react-redux\"\nimport { TabActions, useNavigation, useRoute } from \"@react-navigation/native\"\nimport { findClosestNextOccurrence } from \"../../account/onboarding/LiveRoomCard\"\nimport RescheduleTrialLiveSessionModal from \"../../tutoring/RescheduleTrialLiveSessionModal\"\nimport { DialogM } from \"@common/components/alert/dialog/Dialog\"\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\"\nimport TouchableRippleM from \"@common/components/button/TouchableRippleM\"\nimport StudentLiveSessionsListModal from \"../../tutoring/StudentLiveSessionsListModal\"\nimport SendTutorMessageModal from \"../../tutoring/SendTutorMessageModal\"\n\nconst NextLiveSessionBanner = (props) => {\n\n const { noButton = false, subscriptionUser = null, forceAllLivesButton = false, tutorIds = 0 } = props\n\n const route = useRoute()\n const showLivesModal = route?.params?.show_lives === true || route?.params?.show_lives === \"true\"\n\n const user = subscriptionUser ?? props.user\n\n if (!hasRole(user, \"student\"))\n return null\n\n\n const dimensions = useContext(DimensionsContext)\n\n const navigation = useNavigation()\n\n const closestNextLiveSessionOccurrence = findClosestNextOccurrence(user?.live_sessions)\n // console.log(\"closestNextLiveSessionOccurrence?.live_session_id\", closestNextLiveSessionOccurrence?.live_session_id)\n const closestNextLiveSession = user?.live_sessions?.find(x => x?.id === closestNextLiveSessionOccurrence?.live_session_id)\n const liveMoment = moment(closestNextLiveSessionOccurrence?.date)\n const isToday = liveMoment?.isSame(moment(), \"day\")\n\n const [selectLiveSessionModalVisible, setSelectLiveSessionModalVisible] = useState(false)\n const [bModel, setBModel] = useState(false)\n\n const attendanceCountsForOccurrence = [closestNextLiveSession]?.reduce((counts, session) => {\n session?.attendance_flags?.forEach(flag => {\n if (flag.type === \"late\" && user?.id === flag?.user_id && flag?.date === closestNextLiveSessionOccurrence?.date) {\n counts.late += 1\n } else if (flag.type === \"absent\" && user?.id === flag?.user_id && flag?.date === closestNextLiveSessionOccurrence?.date) {\n counts.absence += 1\n }\n })\n return counts\n }, { late: 0, absence: 0 })\n\n // console.log(\"closestNextLiveSession\", closestNextLiveSession)\n // console.log(\"attendanceCountsForOccurrence\", attendanceCountsForOccurrence)\n\n // const isTooEarly = moment()?.isBefore(liveMoment?.clone()?.subtract(15, \"minutes\"))\n\n // const isAlert = moment()?.isBetween(liveMoment?.clone()?.subtract(15, \"minutes\"), liveMoment?.clone()?.add(45, \"minutes\"))\n // useEffect(() => {\n // if (props.isLiveMode && isToday) {\n // if (isTooEarly) {\n // navigation.push(\"intro\", {\n // name: \"zoe\",\n // introSuffix: `_live_launch_intro_too_early`,\n // isTracked: false,\n // goBack: true,\n // liveModeOnly: true\n // })\n // } else {\n // navigation.push(\"intro\", {\n // name: \"zoe\",\n // introSuffix: `_live_launch_intro`,\n // isTracked: false,\n // goBack: true,\n // liveModeOnly: true\n // })\n // }\n // }\n //\n //\n // }, [])\n\n if (props.isLiveMode) {\n return null\n }\n\n\n const isTrial = props.user?.subscription_state?.status === \"on_generic_trial\" && Math.abs(moment().diff(moment(props.user?.trial_ends_at), \"days\")) <= 7\n\n const [openLiveSessionsListModal, setOpenLiveSessionsListModal] = useState(false)\n const handleShowModal = () => {\n // console.log(\"handle show modal\")\n setOpenLiveSessionsListModal(!openLiveSessionsListModal)\n }\n\n const [openSendTutorMessageModal, setOpenSendTutorMessageModal] = useState(false)\n const handleShowSendTutorMessageModal = () => setOpenSendTutorMessageModal(!openSendTutorMessageModal)\n\n const [sendTutorMessageTutor, setSendTutorMessageTutor] = useState(0)\n\n const liveSessions = useSelector(state => state.data.liveSessions?.full_list)\n\n const tutorIdsArray = tutorIds !== 0 ? tutorIds.split(\",\") : []\n\n useEffect(() => {\n // console.log(\"tutorIds : \",tutorIds)\n // console.log(\"tutorIdsArray : \",tutorIdsArray)\n // console.log(subscriptionUser)\n if (tutorIdsArray.length > 0) {\n if (subscriptionUser && !bModel) {\n if (tutorIdsArray.length > 1) {\n handleShowModal()\n setBModel(true)\n } else {\n\n // console.log(\"liveSessions\" , liveSessions)\n // console.log(\"tutorIds\" , tutorIds)\n // console.log(\"tutor\" , liveSessions?.find(session => session?.tutor?.id == tutorIds)?.tutor)\n setSendTutorMessageTutor(liveSessions?.find(session => session?.tutor?.id === parseInt(tutorIds))?.tutor)\n handleShowSendTutorMessageModal()\n setBModel(true)\n }\n }\n }\n }, [subscriptionUser])\n\n useEffect(() => {\n if (subscriptionUser && showLivesModal) {\n setOpenLiveSessionsListModal(true)\n }\n }, [])\n useEffect(() => {\n\n if (props.lastPhoto !== null) handleShowSendTutorMessageModal()\n\n }, [props.lastPhoto, props.lastPhotos])\n\n return (closestNextLiveSessionOccurrence || forceAllLivesButton) && \n {!!closestNextLiveSessionOccurrence && \n \n \n \n {\"Prochaine session LIVE\"}\n {capitalize(isToday\n ? liveMoment.format(\"[Aujourd'hui à] HH[h]mm\")\n : liveMoment.format(\"dddd DD MMMM [à] HH[h]mm\"))}\n {attendanceCountsForOccurrence?.late > 0 && Retard\n de {user?.firstname} signalé}\n {attendanceCountsForOccurrence?.absence > 0 && Absence\n de {user?.firstname} signalée}\n \n {!noButton && {\n if (isToday) {\n navigation.push(\"pre-call\", {\n liveSessionId: closestNextLiveSessionOccurrence?.live_session_id,\n })\n } else {\n DialogM.show({\n champion: \"zoe\",\n variant: \"main\",\n text1: \"Le live n'est accessible que le jour-même\",\n text2: `Reviens ${liveMoment.format(\"dddd\")} pour te connecter !`,\n })\n }\n }}\n color={isToday ? theme.colors.success : theme.colors.lightMore}\n style={{\n width: 80,\n alignSelf: \"flex-start\",\n marginBottom: 0,\n height: 40,\n }}\n contentStyle={{\n height: 40,\n }}\n label={\"GO !\"} />}\n \n \n }\n {(closestNextLiveSessionOccurrence || forceAllLivesButton) && \n {\n if (isTrial) {\n setSelectLiveSessionModalVisible(true)\n } else {\n\n if (subscriptionUser) {\n handleShowModal()\n } else {\n const jumpToAction = TabActions.jumpTo(\"tutor\", {\n // scroll_to_end: true\n })\n navigation.dispatch(jumpToAction)\n }\n }\n }}\n >\n \n \n \n {isTrial\n ? \"PAS DISPONIBLE ? REPLANIFIER\"\n : \"VOIR TOUS MES LIVES\"}\n \n \n \n {subscriptionUser && openLiveSessionsListModal && }\n\n\n {subscriptionUser && openSendTutorMessageModal && }\n\n }\n \n}\n\nconst mapStateToProps = state => {\n return {\n activityTodoIndexesAsStudentRequest: state.api.activityTodoIndexesAsStudent?.request,\n activityTemplates: state.data.staticData?.activity_templates,\n user: state.data.currentUser?.object,\n schoolSubjects: state.data.staticData?.school_subjects,\n getUserRequest: state.api.getUser?.request,\n getStudentRequest: state.api.getStudent?.request,\n liveSessionId: state.liveMode?.liveSessionId,\n isLiveMode: state.liveMode.isLiveModeEnabled,\n lastPhoto: state.camera?.lastPhoto,\n }\n}\n\nconst mapDispatchToProps = {\n apiRequest, apiIdle, setTodoActivities, setIsLiveModeEnabled,\n\n}\n\nexport default connect(mapStateToProps, mapDispatchToProps)(NextLiveSessionBanner)","import {\n RESET_ACTIVITIES_HISTORY,\n SET_ACTIVITIES_REVIEW_FILTER,\n SET_TODO_ACTIVITIES\n} from \"@data/constants/activitiesConstants\";\nimport {messengerConstants} from \"@data/constants/messengerConstants\";\n\nexport function resetActivitiesHistory(studentId) {\n return {type: RESET_ACTIVITIES_HISTORY, studentId: studentId}\n}\n\nexport function incrementTutorMessengerNotReadCount() {\n return {type: messengerConstants.INCREMENT_TUTOR_MESSENGER_NOT_READ_COUNT}\n}\n\nexport function incrementStudentMessengerNotReadCount(studentId) {\n return {type: messengerConstants.INCREMENT_STUDENT_MESSENGER_NOT_READ_COUNT, studentId: studentId}\n}\n\nexport function setActivitiesReviewFilter(filter) {\n return {type: SET_ACTIVITIES_REVIEW_FILTER, filter: filter}\n}\n\nexport function setTodoActivities(todoActivities) {\n return {type: SET_TODO_ACTIVITIES, todoActivities: todoActivities}\n}","import {liveKitRoomConstants, liveModeConstants} from \"../../../constants/liveModeConstants\";\nimport {messengerConstants} from \"../../../constants/messengerConstants\";\n\nexport function setIsLiveModeEnabled(newState, liveSessionId) {\n if (newState)\n return {type: liveModeConstants.IS_LIVE_MODE_CHANGE, newState, liveSessionId}\n else\n return {type: liveModeConstants.RESET_LIVE_MODE}\n}\n\nexport function setIsTyping(newState) {\n return {type: liveModeConstants.IS_TYPING, newState}\n}\n\nexport function setTypingUser(newState) {\n return {type: liveModeConstants.TYPING_USER, newState}\n}\n\nexport function setLiveParticipants(newState) {\n return {type: liveModeConstants.LIVE_PARTICIPANTS, newState}\n}\n\nexport function addParticipant(newState) {\n return {type: liveModeConstants.ADD_PARTICIPANT, newState}\n}\n\nexport function removeParticipant(newState) {\n return {type: liveModeConstants.REMOVE_PARTICIPANT, newState}\n}\n\n// export function removeTutor(newState) {\n// return {type: liveModeConstants.REMOVE_TUTOR, newState}\n// }\n\nexport function clearMembers() {\n return {type: liveModeConstants.CLEAR_MEMBERS}\n}\n\nexport function showIncomingCall() {\n return {type: liveModeConstants.SHOW_INCOMING_CALL}\n}\n\nexport function hideIncomingCall() {\n return {type: liveModeConstants.HIDE_INCOMING_CALL}\n}\n\nexport function setInCallUsers(newState) {\n return {type: liveModeConstants.IN_CALL_USERS, newState}\n}\n\nexport function addInCallUser(newState) {\n return {type: liveModeConstants.ADD_IN_CALL_USER, newState}\n}\n\nexport function removeInCallUsers(newState) {\n return {type: liveModeConstants.REMOVE_IN_CALL_USERS, newState}\n}\n\nexport function newLiveSessionLog(newState) {\n return {type: liveModeConstants.NEW_LIVE_SESSION_LOG, newState}\n}\n\nexport function setTimesSinceLastCall(newState) {\n return {type: liveModeConstants.SET_TIMES_SINCE_LAST_CALL, newState}\n}\n\nexport function setActiveTime(newState) {\n return {type: liveModeConstants.SET_ACTIVE_TIME, newState}\n}\n\nexport function setRaisedHands(newState) {\n return {type: liveModeConstants.RAISED_HANDS, newState}\n}\n\nexport function addRaisedHand(newState) {\n return {type: liveModeConstants.ADD_RAISED_HAND, newState}\n}\n\nexport function removeRaisedHand(newState) {\n return {type: liveModeConstants.REMOVE_RAISED_HAND, newState}\n}\n\nexport function setPhoneRinging(newState) {\n return {type: liveModeConstants.PHONE_RINGING, newState}\n}\n\nexport function resetPhoneRinging() {\n return {type: liveModeConstants.RESET_PHONE_RINGING}\n}\n\nexport function addPhoneRinging(newState) {\n return {type: liveModeConstants.ADD_PHONE_RINGING, newState}\n}\n\nexport function removePhoneRinging(newState) {\n return {type: liveModeConstants.REMOVE_PHONE_RINGING, newState}\n}\n\nexport function setCallPortal(newState, mode) {\n return {type: liveModeConstants.SET_CALL_PORTAL, newState, mode}\n}\n\nexport function addMessage(newState) {\n return {type: liveModeConstants.SET_MESSAGES, newState}\n}\n\nexport function resetLiveMessagesCount(threadId) {\n return {type: messengerConstants.RESET_LIVE_MESSAGES_COUNT, threadId}\n}\n\nexport function playASound(sound) {\n return {type: liveModeConstants.PLAY_SOUND, sound}\n}\n\nexport function setActivityFinalizedCount(sessionId, studentId) {\n return {type: liveModeConstants.ACTIVITY_FINALIZED, sessionId, studentId}\n}\n\nexport function setIssoundMode(newState, userId) {\n return {type: liveModeConstants.SOUND_MODE, newState, userId}\n}\n\nexport function setIsOutOfApp(newState, userId) {\n return {type: liveModeConstants.OUT_OF_APP, newState, userId}\n}\n\nexport function setActivityCameraOn(newState, userId) {\n return {type: liveModeConstants.ACTIVITY_CAMERA_ON, newState, userId}\n}\n\nexport function setVoiceRecordingIds(newState, userId) {\n return {type: liveModeConstants.VOICE_RECORDING_ACTIVITY, newState, userId}\n}\n\nexport function setCallKeepUUID(uuid) {\n return {type: liveModeConstants.SET_CALL_KEEP_UUID, uuid}\n}\n\nexport function setCallKeepOn(newStatus) {\n return { type: liveModeConstants.SET_CALLKEEP_ON, newStatus }\n}\n\nexport function setHasPhonePermission(newStatus) {\n return { type: liveModeConstants.SET_HAS_PHONE_PERMISSION, newStatus }\n}","import FormStepperModal from \"@common/components/stepper/FormStepperModal\"\nimport { validation } from \"@data/utility/validation\"\nimport { authService } from \"@data/services/authService\"\nimport React from \"react\"\nimport { apiIdle, apiRequest } from \"@data/redux/actions/api\"\nimport { connect } from \"react-redux\"\nimport { DialogM } from \"@common/components/alert/dialog/Dialog\"\nimport { backOfficeService } from \"@data/services/backOfficeService\"\n\nfunction RescheduleTrialLiveSessionModal(props) {\n\n const { visible, navigation, setVisible, notify = false, student = null, reschedule = true } = props\n\n const apiService = student ? backOfficeService.postNewTrialLiveSessionChoiceBackoffice : authService.postNewTrialLiveSessionChoice\n const routeParams = student ? { id: student?.id } : {}\n\n return {\n DialogM.show({\n text1: \"Erreur\", text2: errorData?.message,\n })\n setVisible(false)\n props.apiIdle(apiService)\n }}\n formData={[\n {\n label: reschedule ? \"Replanifiez votre session d'essai\" : \"Choisissez votre session d'essai\",\n description: \"Une session Live d'essai dure environ 30 minutes, et permet de réellement tester l'expérience Masteur en tant qu'élève. C'est gratuit et sans engagement !\",\n type: \"select.single\",\n name: \"new_choice\",\n options: props.trialOptions,\n defaultValue: props.user?.live_sessions?.[0]?.day_time,\n validationRules: { ...validation.required() },\n },\n ]}\n initialGetService={authService.getAvailableTrialLiveSessions}\n submitService={apiService}\n submitRouteParams={routeParams}\n submitAdditionalData={{\n notify: notify,\n }}\n submitSuccessMessage={\"Votre séance d'essai a bien été \" + (reschedule ? \"re\" : \"\") + \"planifiée ✅. Un SMS de confirmation vous a été envoyé.\"}\n submitButtonText={\"Confirmer\"}\n\n />\n}\n\nconst mapStateToProps = state => {\n return {\n challengeTemplates: state.data.staticData?.challenge_templates,\n activityTemplates: state.data.staticData?.activity_templates,\n user: state.data.currentUser?.object,\n trialOptions: state.data.formData?.trialOptions,\n postConfirmTrialRequest: state.api?.[authService.postConfirmTrial?.name]?.request,\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle,\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(RescheduleTrialLiveSessionModal)","import React, { useContext, useEffect } from \"react\"\nimport { View } from \"react-native\"\nimport { ModalM } from \"@common/components/modal/ModalM\"\nimport { FormStepper } from \"@common/components/stepper/FormStepper\"\nimport { connect, useSelector } from \"react-redux\"\nimport { useApiStatus } from \"@common/hooks/useApiStatus\"\nimport { apiIdle, apiRequest } from \"@data/redux/actions/api\"\nimport { theme } from \"@common/theme/theme\"\nimport { DimensionsContext } from \"@common/utils/mobileUtils\"\nimport { ActivityIndicator } from \"react-native-paper\"\n\n\nconst FormStepperModal = ((props) => {\n\n const { visible,\n navigation,\n setVisible,\n formData,\n track = true,\n setFormValues = () => {\n },\n formValues,\n initialGetService = null,\n submitService,\n submitRouteParams = null,\n submitSuccessMessage = null,\n submitButtonText = \"Terminer\",\n submitButtonColor = theme.colors.success,\n submitAdditionalData = {},\n submitErrorCalback = () => {\n },\n defaultValues = {},\n transformSubmitData = (data) => data,\n } = props\n\n const submitted = useSelector(state => state.api?.[submitService?.name]?.request)\n const error = useSelector((state) => state.api[submitService?.name]?.error)\n\n const dimensions = useContext(DimensionsContext)\n\n useApiStatus(\n submitService, // api service\n submitSuccessMessage ?? \"\", // success message on toast (string or null)\n false, // error message on toast (true) or keep it in redux state (false)\n (successData) => {\n setVisible(false)\n },\n submitErrorCalback,\n )\n\n useApiStatus(\n initialGetService, // api service\n null, // success message on toast (string or null)\n true, // error message on toast (true) or keep it in redux state (false)\n (successData) => {\n },\n (error) => {\n setVisible(false)\n },\n )\n\n const initialGetRequest = useSelector(state => state.api?.[initialGetService?.name]?.request)\n\n useEffect(() => {\n if (initialGetService && visible) {\n props.apiRequest(initialGetService)\n }\n return () => {\n }\n }, [visible])\n\n\n return setVisible(false)}\n style={{ height: \"90%\", width: dimensions?.width }}>\n \n {initialGetRequest\n ? \n : !x.is_masked)}\n champion={null}\n setFormValues={setFormValues}\n formValues={formValues}\n defaultValues={defaultValues}\n onSubmit={(data) => {\n props.apiRequest(submitService, submitRouteParams ?? {}, {\n ...submitAdditionalData,\n ...transformSubmitData(data),\n })\n }}\n submitted={submitted}\n previousRouteName={\"\"}\n submittedMessage={\"\"}\n serverError={error}\n submitButtonText={submitButtonText}\n submitButtonColor={submitButtonColor}\n exitHandler={() => setVisible(false)}\n />}\n \n \n})\n\nconst mapStateToProps = state => {\n return {}\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle,\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(FormStepperModal)","import React, {useContext, useState} from \"react\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport {ModalM} from \"@common/components/modal/ModalM\";\nimport {ScrollView} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport StudentLiveSessionsList from \"./StudentLiveSessionsList\";\n\nfunction StudentLiveSessionsListModal(props) {\n const {\n isOpen,\n handleShowModal,\n handleShowSendTutorMessageModal,\n subscriptionUser,\n navigation,\n sendTutorMessageTutor,\n setSendTutorMessageTutor\n } = props\n const dimensions = useContext(DimensionsContext)\n\n return 800 ? \"50%\" : \"90%\",\n maxHeight: \"80%\",\n }}>\n \n \n \n \n \n\n}\n\nconst mapStateToProps = state => {\n return {\n exports: state.data.staticData?.exports,\n exportRequest: state.api?.exportData?.request\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(StudentLiveSessionsListModal)","import {Dimensions, View} from \"react-native\";\nimport TextM from \"@common/components/text/TextM\";\nimport {theme} from \"@common/theme/theme\";\nimport {ActivityIndicator, IconButton} from \"react-native-paper\";\nimport {liveService} from \"@data/services/liveService\";\nimport {findClosestNextOccurrence} from \"../account/onboarding/LiveRoomCard\";\nimport moment from \"moment/moment\";\nimport {findItemInListWithId, groupBy, sortLiveSessionsCallback} from \"@data/utility/dataUtils\";\nimport StudentLiveCardComponent from \"./StudentLiveCardComponent\";\nimport React, {useContext, useEffect} from \"react\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {setIsLiveModeEnabled} from \"@data/redux/actions/liveMode\";\nimport {connect, useSelector} from \"react-redux\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {useApiStatus} from \"@common/hooks/useApiStatus\";\nimport {useSafeAreaInsets} from \"react-native-safe-area-context\";\nimport TouchableRippleM from \"@common/components/button/TouchableRippleM\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport {BadgeM} from \"@common/components/badge/BadgeM\";\nimport {whatIsIt} from \"@data/utility/Utils\";\n\nconst StudentLiveSessionsList = (props) => {\n\n const {\n style = {},\n noButton = false,\n sendTutorMessageTutor,\n setSendTutorMessageTutor,\n student,\n withFillerView = false,\n navigation = null,\n handleShowModal = () => {},\n handleShowSendTutorMessageModal = () => {},\n } = props\n\n const dimensions = useContext(DimensionsContext)\n\n const nav = navigation ?? useNavigation()\n\n const liveSessions = useSelector(state => state.data.liveSessions?.full_list)\n const attendanceFlagsToBeRecovered = useSelector(state => state.data.liveSessions?.attendance_flags_to_be_recovered)\n const attendanceFlagsRecoverable = attendanceFlagsToBeRecovered?.filter(flag => flag?.is_recoverable_now)\n\n const absenceRecoveryColor = attendanceFlagsRecoverable?.length > 0 ? theme.colors.error : theme.colors.primary\n const absenceRecoveryBgColor = attendanceFlagsRecoverable?.length > 0 ? theme.colors.errorLight : theme.colors.primaryLighter\n\n const user = student ?? props.user\n\n const getRequest = !student ? liveService.getAllMyNextLiveSessions : liveService.getAllMyNextLiveSessionsAsParent\n const params = !student ? {} : {student_email: student?.email}\n\n useEffect(() => {\n props.apiRequest(getRequest, {}, {}, params)\n }, []);\n\n useApiStatus(\n getRequest,\n null,\n true,\n (successData) => {\n },\n (errorData) => {\n handleShowModal()\n }\n )\n\n const liveSessionsByLiveRoom = whatIsIt(liveSessions) === \"Array\" ? Object.values(groupBy(liveSessions ?? null, \"live_room_id\") ?? {})?.sort((a, b) => {\n const firstA = a?.sort(sortLiveSessionsCallback)?.[0]\n const firstB = b?.sort(sortLiveSessionsCallback)?.[0]\n\n return sortLiveSessionsCallback(firstA, firstB)\n }) : []\n const insets = useSafeAreaInsets()\n\n\n return \n \n Tous mes Lives\n {props.getAllMyNextLiveSessionsRequest || props.getAllMyNextLiveSessionsAsParentRequest ? (\n \n ) : (\n {\n props.apiRequest(getRequest, {}, {}, params)\n }}\n iconColor={theme.colors.primary}\n containerColor={theme.colors.transparent}\n disabled={props.getAllMyNextLiveSessionsRequest || props.getAllMyNextLiveSessionsAsParentRequest}\n icon={\"sync-alt\"}\n size={20}\n />\n )}\n \n {attendanceFlagsToBeRecovered?.length > 0 && \n {\n nav.push(\"recover-absence\", {\n withStudent: !!student\n })\n handleShowModal()\n }}\n >\n \n \n PLANIFIER UN RATTRAPAGE\n \n {attendanceFlagsRecoverable?.length > 0 && }\n \n \n }\n {/**/}\n {liveSessionsByLiveRoom?.map((liveSessionsForOneRoom, index) => {\n const closestNextOccurrence = findClosestNextOccurrence(liveSessionsForOneRoom)\n const closestNextOccurrenceDate = moment(closestNextOccurrence?.date)\n // console.log(\"closestNextOccurrence?.live_session_id\", closestNextOccurrence?.live_session_id)\n const liveSession = findItemInListWithId(closestNextOccurrence?.live_session_id, liveSessionsForOneRoom)\n const isToday = closestNextOccurrenceDate?.isSame(moment(), \"day\")\n\n return \n\n })}\n {withFillerView && }\n ;\n}\n\nconst mapStateToProps = state => {\n return {\n getAllMyNextLiveSessionsRequest: state.api.getAllMyNextLiveSessions?.request,\n getAllMyNextLiveSessionsAsParentRequest: state.api.getAllMyNextLiveSessionsAsParent?.request,\n getUserSuccess: state.api.getUser?.success,\n getUserError: state.api.getUser?.error,\n activityTemplates: state.data.staticData?.activity_templates,\n user: state.data.currentUser?.object,\n maxPrioritizedSchoolSubjects: state.data.staticData?.max_prioritized_school_subjects,\n isLive: state.liveMode.isLiveModeEnabled,\n getLiveSessionRequest: state.api.getLiveSession?.request\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle,\n setIsLiveModeEnabled\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(StudentLiveSessionsList)","import React from \"react\";\nimport {View} from \"react-native\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport AvatarM from \"../../common/components/avatar/AvatarM\";\nimport {Divider} from \"react-native-paper\";\nimport FilledButtonM from \"../../common/components/button/FilledButtonM\";\nimport {theme} from \"@common/theme/theme\";\nimport moment from \"moment\";\nimport {findClosestNextOccurrence} from \"../../student/account/onboarding/LiveRoomCard\";\nimport {capitalize, formatMinutes, plr, readableDayTime} from \"@data/utility/Utils\";\nimport live from \"../../../assets/icons/generic/live.png\";\nimport TextM from \"../../common/components/text/TextM\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect, useDispatch} from \"react-redux\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport LinkTextM from \"@common/components/text/LinkTextM\";\nimport {IS_WEB} from \"@common/utils/mobileUtils\";\nimport * as WebBrowser from \"expo-web-browser\";\n\nexport const renderAttendanceActions = (flagType, label, color, count, studentId, navigation, handleShowModal = () => {\n}, withStudent = null, liveRoomId) => {\n const icon = flagType === 'late' ? \"clock\" : \"exclamation-circle\"\n\n const dispatch = useDispatch()\n\n return (\n count > 0 && (\n \n \n {\n navigation.push(\"cancel-absence\", {\n id: studentId,\n liveRoomId,\n type: flagType,\n withStudent\n })\n handleShowModal()\n\n }\n\n // DialogM.show({\n // text1: `Veux-tu vraiment annuler ${label.toLowerCase()} ?`,\n // buttonText1: 'Annuler',\n // buttonColor1: theme.colors.error,\n // onPress: () => dispatch(apiRequest(attendanceFlagsService.cancelAbsenceAsStudent, {id: flag.id})),\n // buttonText2: 'Quitter'\n // })\n }\n >\n {flagType === 'late' ? `${plr(\"Retard\", count)} ${plr(\"signalé\", count)}` : `${plr(\"Absence\", count)} ${plr(\"signalée\", count)}`}\n \n \n )\n );\n};\n\nconst StudentLiveCardComponent = (props) => {\n const {\n liveSession,\n liveSessionsForOneRoom,\n dateTime = null,\n noButtons = false,\n customTitle = null,\n noAvatar = false,\n style = {},\n oneOccurrence = true,\n navigation = null,\n additionalOnPress = () => {\n },\n subscriptionUser = null,\n noButton = false,\n handleShowModal = () => {\n },\n handleShowSendTutorMessageModal = () => {\n },\n sendTutorMessageTutor,\n setSendTutorMessageTutor,\n } = props;\n\n const nav = navigation ?? useNavigation();\n const closestNextOccurrence = findClosestNextOccurrence([liveSession]);\n\n const user = subscriptionUser ?? props.user\n\n const closestNextLiveSession = liveSessionsForOneRoom?.find(x => x?.id === closestNextOccurrence?.live_session_id)\n\n const liveMoment = closestNextOccurrence?.date\n ? moment(closestNextOccurrence?.date)\n : null;\n\n const isToday = dateTime\n ? moment(dateTime).isSame(moment(), \"day\")\n : liveMoment?.isSame(moment(), \"day\");\n const formattedLiveMoment = dateTime\n ? capitalize(\n moment(dateTime)?.format(\n (isToday ? \"[aujourd'hui]\" : \"dddd\") + \" DD MMMM [à] HH:mm\"\n )\n )\n : capitalize(\n liveMoment?.format(\n (isToday && !noButtons ? \"[aujourd'hui]\" : \"dddd\") + \" [à] HH:mm\"\n )\n );\n\n const isIndividual = liveSession?.live_room?.type === \"individual\";\n\n const color = isToday ? theme.colors.success : theme.colors.transparent;\n const textColor = isToday ? theme.colors.white : theme.colors.grey;\n\n const delayToday = liveSession?.delay_today\n const isReplacement = dateTime ? liveSession?.next_occurrences?.find((occ) => occ.date === dateTime)?.substitution_id\n : closestNextOccurrence?.substitution_id\n const isRescheduled = dateTime ? liveSession?.next_occurrences?.find((occ) => occ.date === dateTime)?.rescheduling_id\n : closestNextOccurrence?.rescheduling_id\n const isAccepted = dateTime ? liveSession?.next_occurrences?.find((occ) => occ.date === dateTime)?.substitute_id\n : closestNextOccurrence?.substitute_id\n\n const liveRoom = {\n ...liveSession?.live_room,\n live_sessions: liveSessionsForOneRoom\n }\n\n const attendanceCounts = liveSessionsForOneRoom?.reduce((counts, session) => {\n // console.log(\"session?.attendance_flags\", session?.attendance_flags)\n session?.attendance_flags?.forEach(flag => {\n if (flag.type === \"late\" && user?.id === flag?.user_id) {\n counts.late += 1;\n } else if (flag.type === \"absent\" && user?.id === flag?.user_id) {\n counts.absence += 1;\n }\n });\n return counts;\n }, {late: 0, absence: 0});\n\n const attendanceCountsForLiveSession = [closestNextLiveSession]?.reduce((counts, session) => {\n session?.attendance_flags?.forEach(flag => {\n if (flag.type === \"late\" && user?.id === flag?.user_id) {\n counts.late += 1;\n } else if (flag.type === \"absent\" && user?.id === flag?.user_id) {\n counts.absence += 1;\n }\n });\n return counts;\n }, {late: 0, absence: 0});\n\n // for a permanent member, there are 5 next_occurrences, 4 when I am not within current one\n const isRecovery = [\"biweekly\", \"study_group\"]?.includes(liveRoom?.type) && attendanceCountsForLiveSession?.absence < (4-liveSession?.next_occurrences?.length)\n\n\n const renderButton = () => {\n\n // console.log(\"attendanceCounts\", attendanceCounts)\n\n return \n { {\n if ([\"biweekly\", \"study_group\", \"holiday_course\", \"holiday_workbook\"].includes(closestNextLiveSession?.live_room?.type)) {\n navigation.push(\"absence-form\", {\n id: user.id,\n liveSessionId: closestNextLiveSession?.id,\n liveRoomId: closestNextLiveSession?.live_room_id,\n withStudent: !!subscriptionUser\n })\n handleShowModal()\n } else {\n DialogM.show({\n text1: `Une question concernant cette session Live ?`,\n text2: `${readableDayTime(liveSession?.day_time, liveSession?.duration)}`,\n buttonText1: subscriptionUser ? `Contacter le support` : `Contacter le tuteur`,\n onPress: () => {\n if (subscriptionUser) {\n const url = \"https://wa.me/message/FCOBQ6PCPMBJC1\"\n if (IS_WEB) {\n window.open(url);\n } else {\n WebBrowser.openBrowserAsync(url);\n }\n } else {\n // open\n navigation.navigate(\"messenger\", {\n tutorId: liveSession?.tutor?.id\n })\n }\n },\n buttonText2: 'Retour',\n onPressBack: () => {\n }\n })\n handleShowModal()\n }\n }}\n fontWeight={\"Bold\"}\n labelStyle={{fontSize: 10, marginHorizontal: 10, marginVertical: 5}}\n contentStyle={{height: 40}}\n label={\"Gérer les rdv\"}\n icon={() => }\n />}\n {!!subscriptionUser && {\n handleShowModal()\n setSendTutorMessageTutor(liveSession?.tutor)\n handleShowSendTutorMessageModal()\n \n }}\n fontWeight={\"Bold\"}\n labelStyle={{fontSize: 10, marginHorizontal: 10, marginVertical: 5}}\n contentStyle={{height: 40}}\n label={\"message au tuteur\"}\n icon={() => }\n />}\n {renderAttendanceActions(\"absent\", \"l'absence\", theme.colors.error, attendanceCounts?.absence, user?.id, navigation, handleShowModal, !!subscriptionUser, closestNextLiveSession?.live_room_id)}\n {renderAttendanceActions(\"late\", \"le retard\", theme.colors.warning, attendanceCounts?.late, user?.id, navigation, handleShowModal, !!subscriptionUser, closestNextLiveSession?.live_room_id)}\n \n }\n\n return (\n \n \n \n \n {customTitle\n ? customTitle\n : capitalize(oneOccurrence ? moment(dateTime ?? liveMoment).format(\n \"dddd DD MMM [à] HH:mm\"\n ) + (isRescheduled ? \" *\" : \"\") + (isRecovery || isReplacement ? \" **\" : \"\") +\n \" - \" +\n formatMinutes(liveSession?.duration)\n : readableDayTime(liveSession?.day_time, liveSession?.duration))}\n \n \n \n {!customTitle && (isRescheduled || isReplacement || isRecovery) &&\n {isRescheduled ? \"*Replanifié \" : \"\"}{isRecovery ? \"**Rattrapage \" : isReplacement ? \"**Tuteur remplaçant \" : \"\"}}\n\n \n Mes RDV\n : {liveRoom?.live_sessions?.map((ls) => readableDayTime(ls?.day_time, ls?.duration, ls?.live_room?.type))?.join(\", \")}\n \n {isIndividual && Individuel}\n \n \n {!noAvatar && }\n {liveSession?.tutor?.display_name}\n \n \n {!noButtons && }\n {!noButtons && (\n \n {renderButton()}\n {!noButton && x?.id === user?.id) ? \"contained\" : \"text\"}\n contentStyle={{height: 32}}\n labelStyle={{fontSize: 10}}\n label=\"GO !\"\n onPress={() => {\n additionalOnPress()\n\n if (isToday) {\n // if liveSession doesnt contain me as user, then I should not be able to join the live\n if (!liveSession?.students?.find(x => x?.id === user?.id)) {\n DialogM.show({\n champion: \"zoe\",\n variant: \"main\",\n text1: \"Tu n'es pas inscrit à cette session live\",\n text2: \"Tu ne peux pas y accéder\"\n });\n return\n }\n\n nav.push(\"pre-call\", {\n liveSessionId: liveSession?.id\n })\n } else {\n DialogM.show({\n champion: \"zoe\",\n variant: \"main\",\n text1: \"Le live n'est accessible que le jour-même\",\n text2: `Reviens ${liveMoment?.format(\"dddd\")} pour te connecter !`\n });\n }\n }}\n // disabled={!isToday}\n color={isToday && liveSession?.students?.find(x => x?.id === user?.id) ? theme.colors.success : theme.colors?.grey}\n />}\n \n )}\n \n );\n};\nconst mapStateToProps = (state) => {\n return {\n user: state.data.currentUser?.object,\n getUserRequest: state.api.getUser?.request,\n schoolSubjects: state.data.staticData?.school_subjects,\n cancelSubstitutionRequest: state.api.cancelSubstitution?.request,\n cancelSubstitutionId: state.api.cancelSubstitution?.routeParams?.id,\n cancelTutorDelayRequest: state.api.cancelTutorDelayRequest?.request,\n cancelTutorDelayId: state.api.cancelTutorDelayRequest?.routeParams?.id\n };\n};\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(StudentLiveCardComponent);\n","import React, { useContext, useState } from \"react\"\nimport { DimensionsContext, IS_WEB } from \"@common/utils/mobileUtils\"\nimport { ModalM } from \"@common/components/modal/ModalM\"\nimport { ScrollView } from \"react-native\"\nimport { theme } from \"@common/theme/theme\"\nimport { apiIdle, apiRequest } from \"@data/redux/actions/api\"\nimport { connect } from \"react-redux\"\nimport TextM from \"@common/components/text/TextM\"\nimport { useForm } from \"react-hook-form\"\nimport TextInputM from \"@common/components/input/TextInputM\"\nimport { formIds } from \"@data/constants/formConstants\"\nimport CameraImagesM from \"@common/camera/CameraImagesM\"\nimport { useRequestsBatch } from \"@common/hooks/useRequestsBatch\"\nimport { authService } from \"@data/services/authService\"\nimport { clearLastPhoto, clearPhotos } from \"@data/redux/actions/camera\"\nimport moment from \"moment\"\nimport FilledButtonM from \"@common/components/button/FilledButtonM\"\nimport { SnackBarM } from \"@common/components/alert/snackbar/SnackBar\"\nimport { DialogM } from \"@common/components/alert/dialog/Dialog\"\nimport { IconButton } from \"react-native-paper\"\nimport UncontrolledTextInputM from \"@common/components/input/UncontrolledTextInputM\"\nimport IconButtonM from \"@common/components/button/IconButtonM\"\n\nfunction SendTutorMessageModal(props) {\n const {\n subscriptionUser,\n isOpen,\n handleShowSendTutorMessageModal,\n handleShowModal,\n sendTutorMessageTutor,\n tutorIds,\n } = props\n const dimensions = useContext(DimensionsContext)\n\n const [message, setMessage] = useState(\"\")\n const [images, setImages] = useState([])\n\n const { control, handleSubmit, formState: { errors, dirtyFields }, trigger, setValue } = useForm({\n message: \"\",\n status: \"validated\",\n })\n\n\n const filesToUpload = images?.filter(img => !img.id).map(img => {\n return {\n uri: img?.uri,\n name: `message_attachments_${subscriptionUser?.display_name}_${moment().format(\"YYYY-MM-DD\")}.jpg`, //Tutor_id to add\n type: \"image/jpg\",\n }\n })\n const submitMessages = () => {\n startRequests()\n }\n // console.log(\"sendTutorMessageTutor : \",sendTutorMessageTutor?.display_name);\n\n // console.log(\"subscriptionUser: \",subscriptionUser);\n\n const [globalProgress, submitted, startRequests] = useRequestsBatch(\n [],\n filesToUpload,\n formIds.SEND_TUTOR_MESSAGE,\n {\n service: authService.sendMessageToTutor, // à traiter\n data: {\n subscriptionUserID: subscriptionUser?.id,\n tutorId: sendTutorMessageTutor?.id,\n message: message,\n },\n tmpFilesKey: \"message_attachments\",\n tmpFilesFormatter: (attachmentTmp, index) => {\n return attachmentTmp\n },\n additionalData: [],\n //params: {subscriptionUser: subscriptionUser}, // à traiter\n onSuccessBeforeNext: (successData) => {\n // console.log(\"onSuccessBeforeNext\");\n setImages([])\n setMessage(\"\")\n handleShowSendTutorMessageModal()\n // handleShowModal()\n DialogM.show({\n text1: \"Message envoyé ✅\",\n text2: \"Votre message a bien été transmis.\",\n onPress: () => {\n },\n })\n },\n onError: () => {\n\n DialogM.show({\n text1: \"Erreur lors de l'envoi du message ❌\",\n text2: \"Veuillez réessayer.\",\n })\n },\n },\n [],\n true,\n )\n\n return 800 ? \"80%\" : \"90%\",\n height: \"90%\",\n overflow: \"hidden\"\n }}>\n \n\n Transmettre un message au tuteur {sendTutorMessageTutor?.display_name}\n\n {\n setMessage(value)\n }}\n />\n \n \n \n {\n handleShowSendTutorMessageModal()\n }}\n />\n \n\n}\n\nconst mapStateToProps = state => {\n return {\n exports: state.data.staticData?.exports,\n exportRequest: state.api?.exportData?.request,\n }\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle,\n clearLastPhoto,\n clearPhotos,\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(SendTutorMessageModal)","import { DialogM } from \"@common/components/alert/dialog/Dialog\";\nimport { useInterval } from \"@common/utils/useInterval\";\nimport {\n apiIdle,\n apiRequest,\n vaporFileUpload,\n vaporFileUploadIdle\n} from \"@data/redux/actions/api\";\nimport { useEffect, useState } from \"react\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport { apiRequestWithPrerequest } from \"../../data/redux/actions/api\";\n\nexport const fetchResourceFromURI = async (uri) => {\n const response = await fetch(uri);\n return await response.blob();\n};\n\nexport function useRequestsBatch(\n requestsBeforeFilesUpload = [],\n filesToUpload = [],\n formId,\n requestToSendFiles,\n requestsAfterFilesUpload = [],\n noIdle = false,\n withPrerequest = false\n) {\n const vaporFileUploadService = useSelector(\n (state) => state.api?.vaporFileUpload\n );\n const dispatch = useDispatch();\n const nbReqsBefore = requestsBeforeFilesUpload?.length;\n const nbReqsAfter = requestsAfterFilesUpload?.length;\n const requestsNumber = nbReqsBefore + nbReqsAfter + filesToUpload?.length + 1;\n\n const apiRequestHandler = withPrerequest? apiRequestWithPrerequest : apiRequest;\n\n const [requestProgress, setRequestProgress] = useState(0);\n const [percentRequestCompleted, setPercentRequestCompleted] = useState(0);\n const [submitted, setSubmitted] = useState(false);\n const [currentRequest, setCurrentRequest] = useState(null);\n const [attachments, setAttachments] = useState([]);\n const percentLimitForUpload = 0;\n const globalProgress = Math.max(\n 0,\n Math.round(\n ((requestProgress - 1 + percentRequestCompleted / 100) / requestsNumber) *\n 100\n )\n );\n\n const currentRequestSuccess =\n useSelector((state) => state.api?.[currentRequest?.service?.name])\n ?.success ?? false;\n const currentRequestError =\n useSelector((state) => state.api?.[currentRequest?.service?.name])?.error ??\n false;\n const currentRequestSuccessData = useSelector(\n (state) => state.api?.[currentRequest?.service?.name]\n )?.data;\n\n // console.log(\"current Request Name: \", currentRequest?.service?.name)\n\n // console.log(\"files to upload: \", filesToUpload)\n\n // console.log(\"current request success : \", currentRequestSuccess)\n\n // console.log(\"your uploaded files : \", attachments)\n\n // console.log(requestsNumber)\n\n const setNewRequestStarted = () => {\n // console.log(\"progressBeforeIncrement = \", requestProgress)\n setSubmitted(true);\n setRequestProgress((x) => Math.min(x + 1, requestsNumber));\n setPercentRequestCompleted(0);\n };\n const setRequestsReset = () => {\n setSubmitted(false);\n setAttachments(null);\n setRequestProgress(0);\n setPercentRequestCompleted(0);\n };\n\n const onUploadProgress = (progressEvent) => {\n // console.log(\"request\", requestProgress, \"progress\", Math.round((progressEvent.loaded * percentLimitForUpload) / progressEvent.total))\n setPercentRequestCompleted(\n Math.round(\n (progressEvent.loaded * percentLimitForUpload) / progressEvent.total\n )\n );\n };\n\n useInterval(\n () => {\n setPercentRequestCompleted((p) => p + 1);\n },\n submitted &&\n percentRequestCompleted >= percentLimitForUpload\n && percentRequestCompleted < 98\n ? 500\n : null\n );\n\n const startRequests = () => {\n // console.log(\"start all requests from here\")\n if (requestsNumber >= 1) nextRequest();\n };\n\n useEffect(() => {\n if (currentRequestSuccess) {\n dispatch(apiIdle(currentRequest?.service));\n\n if (\n currentRequest?.onSuccessBeforeNext(currentRequestSuccessData) &&\n requestProgress < requestsNumber\n ) {\n // console.log(\"progressAfterIncrement = \", requestProgress)\n nextRequest();\n } else {\n setRequestsReset();\n }\n }\n }, [currentRequestSuccess]);\n\n useEffect(() => {\n // if POST file to AWS S3 SUCCESS then save AWS S3 key in logs and IDLE, then switch to next request\n if (\n vaporFileUploadService?.success &&\n vaporFileUploadService?.formId === formId &&\n requestProgress > 0\n ) {\n const responseKey = vaporFileUploadService?.response?.key;\n dispatch(vaporFileUploadIdle);\n // console.log(\"progressAfterIncrement = \", requestProgress)\n nextRequest([...attachments, responseKey]);\n }\n }, [vaporFileUploadService?.success]);\n\n const nextRequest = async (tmpData = []) => {\n // console.log(\"next request\")\n // console.log(\"filesToUpload\", filesToUpload)\n // save the updated data list to be sent after all files\n if (tmpData) {\n setAttachments(tmpData);\n }\n // if request progress < nbRequestsBefore continue handling requests before upload\n if (requestProgress < nbReqsBefore) {\n const nextApiRequest = requestsBeforeFilesUpload[requestProgress];\n dispatch(\n apiRequestHandler(\n nextApiRequest?.service,\n nextApiRequest?.params,\n nextApiRequest?.data,\n {},\n onUploadProgress\n )\n );\n setCurrentRequest(nextApiRequest);\n setNewRequestStarted();\n }\n // if requests progress < requests number - nbReqsAfter, increment progress and message, and POST file number (requests progress - nbReqsBefore) to AWS S3\n // else handle RequestsAfterUpload\n else if (requestProgress < requestsNumber - nbReqsAfter - 1) {\n const attachment = filesToUpload[requestProgress - nbReqsBefore];\n // console.log(`attachment num ${requestProgress - nbReqsBefore}: `, attachment)\n const file = await fetchResourceFromURI(attachment?.uri);\n // console.log(\"attachment: \", attachment)\n\n dispatch(\n vaporFileUpload(\n file,\n { onUploadProgress, contentType: file?.type },\n formId\n )\n );\n setNewRequestStarted();\n } else if (requestProgress === requestsNumber - nbReqsAfter - 1) {\n // console.log({\n // ...requestToSendFiles?.data,\n // [requestToSendFiles?.tmpFilesKey]: [...tmpData?.map(requestToSendFiles?.tmpFilesFormatter), ...requestToSendFiles?.additionalData]\n // })\n const requestToSendFilesData = {\n ...requestToSendFiles?.data,\n [requestToSendFiles?.tmpFilesKey]: [\n ...tmpData.map(requestToSendFiles?.tmpFilesFormatter),\n ...requestToSendFiles.additionalData,\n ],\n };\n // console.log(\"requestToSendFilesData: \", requestToSendFilesData)\n dispatch(\n apiRequestHandler(\n requestToSendFiles?.service,\n requestToSendFiles?.params,\n requestToSendFilesData,\n {},\n onUploadProgress\n )\n );\n setCurrentRequest(requestToSendFiles);\n setNewRequestStarted();\n } else {\n const nextApiRequest =\n requestsAfterFilesUpload[\n requestProgress - (nbReqsBefore + filesToUpload?.length + 1)\n ];\n // console.log(nextApiRequest?.params)\n dispatch(\n apiRequestHandler(\n nextApiRequest?.service,\n nextApiRequest?.params,\n nextApiRequest?.data,\n {},\n onUploadProgress\n )\n );\n setCurrentRequest(nextApiRequest);\n setNewRequestStarted();\n }\n };\n\n useEffect(() => {\n let errorMessage = null;\n\n // if any error then alert with the error and IDLE reset request state\n\n //if an error occurred before or after files upload\n if (currentRequestError) {\n if (!noIdle) {\n errorMessage = `${currentRequestError?.message}`;\n dispatch(apiIdle(currentRequest?.service));\n }\n setRequestsReset();\n }\n\n //if an error occurred while uploading a file\n else if (vaporFileUploadService?.error) {\n if (!noIdle) {\n dispatch(vaporFileUploadIdle());\n errorMessage = `${vaporFileUploadService?.error?.message}`;\n }\n setRequestsReset();\n }\n\n if (errorMessage)\n DialogM.show({\n text1: \"Erreur\",\n text2: errorMessage,\n });\n //alertPolyfill(\"Erreur\", errorMessage)\n }, [currentRequestError, vaporFileUploadService?.error]);\n\n return [globalProgress, submitted, startRequests];\n}\n","import React, {useEffect, useRef} from 'react';\n\nexport function useInterval(callback, delay) {\n const savedCallback = useRef();\n\n // Remember the latest callback.\n useEffect(() => {\n savedCallback.current = callback;\n }, [callback]);\n\n // Set up the interval.\n useEffect(() => {\n function tick() {\n savedCallback.current();\n }\n\n if (delay !== null) {\n let id = setInterval(tick, delay);\n return () => clearInterval(id);\n }\n }, [delay]);\n}","import React from 'react';\nimport {Text, TextInput} from \"react-native-paper\";\nimport {theme} from \"../../theme/theme\";\nimport {View} from \"react-native\";\nimport * as amplitude from \"@amplitude/analytics-react-native\"\nimport * as Clipboard from \"expo-clipboard\"\nimport { SnackBarM } from \"@common/components/alert/snackbar/SnackBar\"\nimport IconButtonM from \"@common/components/button/IconButtonM\"\n\nconst UncontrolledTextInputM = React.forwardRef((props, ref) => {\n\n const {password, name, errors, onChangeText, value, style = {}, contentContainerStyle = {}, copyPaste = false, disabled = false} = props\n\n const [secure, setSecure] = React.useState(true);\n\n\n return <>\n \n\n {\n setSecure(!secure)\n }}/>}\n error={errors && errors[name]}\n />\n {errors && errors[name] && {errors[name].message}}\n {copyPaste && {\n amplitude.track(\"button.clicked.copy-input\")\n Clipboard.setStringAsync(value).then(() => {\n SnackBarM.show({\n text1: `📋 Copié dans le presse-papier`,\n duration: 6000\n })\n });\n }}\n />}\n \n\n \n})\n\nexport default UncontrolledTextInputM","// bottom sheet\nexport { default } from './components/bottomSheet'; // bottom sheet modal\n\nexport { default as BottomSheetModal } from './components/bottomSheetModal';\nexport { default as BottomSheetModalProvider } from './components/bottomSheetModalProvider'; //#region hooks\n\nexport { useBottomSheet } from './hooks/useBottomSheet';\nexport { useBottomSheetModal } from './hooks/useBottomSheetModal';\nexport { useBottomSheetSpringConfigs } from './hooks/useBottomSheetSpringConfigs';\nexport { useBottomSheetTimingConfigs } from './hooks/useBottomSheetTimingConfigs';\nexport { useBottomSheetInternal } from './hooks/useBottomSheetInternal';\nexport { useBottomSheetModalInternal } from './hooks/useBottomSheetModalInternal';\nexport { useBottomSheetDynamicSnapPoints } from './hooks/useBottomSheetDynamicSnapPoints';\nexport { useScrollEventsHandlersDefault } from './hooks/useScrollEventsHandlersDefault';\nexport { useGestureEventsHandlersDefault } from './hooks/useGestureEventsHandlersDefault';\nexport { useBottomSheetGestureHandlers } from './hooks/useBottomSheetGestureHandlers';\nexport { useScrollHandler } from './hooks/useScrollHandler';\nexport { useScrollableSetter } from './hooks/useScrollableSetter'; //#endregion\n//#region components\n\nexport { BottomSheetScrollView, BottomSheetSectionList, BottomSheetFlatList, BottomSheetVirtualizedList } from './components/bottomSheetScrollable';\nexport { default as BottomSheetHandle } from './components/bottomSheetHandle';\nexport { default as BottomSheetDraggableView } from './components/bottomSheetDraggableView';\nexport { default as BottomSheetView } from './components/bottomSheetView';\nexport { default as BottomSheetTextInput } from './components/bottomSheetTextInput';\nexport { default as BottomSheetBackdrop } from './components/bottomSheetBackdrop';\nexport { default as BottomSheetFooter } from './components/bottomSheetFooter';\nexport { default as BottomSheetFooterContainer } from './components/bottomSheetFooterContainer/BottomSheetFooterContainer'; // touchables\n\nimport BottomSheetTouchable from './components/touchables';\nexport const {\n TouchableHighlight,\n TouchableOpacity,\n TouchableWithoutFeedback\n} = BottomSheetTouchable; // utils\n\nexport { createBottomSheetScrollableComponent } from './components/bottomSheetScrollable'; //#endregion\n//#region types\n\n//#endregion\n//#region utilities\nexport * from './constants';\nexport { enableLogging } from './utilities/logger'; //#endregion\n//# sourceMappingURL=index.js.map","export { default } from './BottomSheet';\n//# sourceMappingURL=index.js.map","import React, { useMemo, useCallback, forwardRef, useImperativeHandle, memo, useEffect } from 'react';\nimport { Platform } from 'react-native';\nimport invariant from 'invariant';\nimport Animated, { useAnimatedReaction, useSharedValue, useAnimatedStyle, useDerivedValue, runOnJS, interpolate, Extrapolate, runOnUI, cancelAnimation, useWorkletCallback } from 'react-native-reanimated';\nimport { State } from 'react-native-gesture-handler';\nimport { useScrollable, usePropsValidator, useReactiveSharedValue, useNormalizedSnapPoints, useKeyboard } from '../../hooks';\nimport { BottomSheetInternalProvider, BottomSheetProvider } from '../../contexts';\nimport BottomSheetContainer from '../bottomSheetContainer';\nimport BottomSheetGestureHandlersProvider from '../bottomSheetGestureHandlersProvider';\nimport BottomSheetBackdropContainer from '../bottomSheetBackdropContainer';\nimport BottomSheetHandleContainer from '../bottomSheetHandleContainer';\nimport BottomSheetBackgroundContainer from '../bottomSheetBackgroundContainer';\nimport BottomSheetFooterContainer from '../bottomSheetFooterContainer/BottomSheetFooterContainer';\nimport BottomSheetDraggableView from '../bottomSheetDraggableView'; // import BottomSheetDebugView from '../bottomSheetDebugView';\n\nimport { ANIMATION_STATE, KEYBOARD_STATE, KEYBOARD_BEHAVIOR, SHEET_STATE, SCROLLABLE_STATE, KEYBOARD_BLUR_BEHAVIOR, KEYBOARD_INPUT_MODE, ANIMATION_SOURCE } from '../../constants';\nimport { animate, getKeyboardAnimationConfigs, normalizeSnapPoint, print } from '../../utilities';\nimport { DEFAULT_OVER_DRAG_RESISTANCE_FACTOR, DEFAULT_ENABLE_CONTENT_PANNING_GESTURE, DEFAULT_ENABLE_HANDLE_PANNING_GESTURE, DEFAULT_ENABLE_OVER_DRAG, DEFAULT_ANIMATE_ON_MOUNT, DEFAULT_KEYBOARD_BEHAVIOR, DEFAULT_KEYBOARD_BLUR_BEHAVIOR, DEFAULT_KEYBOARD_INPUT_MODE, INITIAL_CONTAINER_HEIGHT, INITIAL_HANDLE_HEIGHT, INITIAL_POSITION, INITIAL_SNAP_POINT, DEFAULT_ENABLE_PAN_DOWN_TO_CLOSE, INITIAL_CONTAINER_OFFSET, INITIAL_VALUE, DEFAULT_DYNAMIC_SIZING } from './constants';\nimport { styles } from './styles';\nAnimated.addWhitelistedUIProps({\n decelerationRate: true\n});\nconst BottomSheetComponent = /*#__PURE__*/forwardRef(function BottomSheet(props, ref) {\n //#region validate props\n usePropsValidator(props); //#endregion\n //#region extract props\n\n const {\n // animations configurations\n animationConfigs: _providedAnimationConfigs,\n // configurations\n index: _providedIndex = 0,\n snapPoints: _providedSnapPoints,\n animateOnMount = DEFAULT_ANIMATE_ON_MOUNT,\n enableContentPanningGesture = DEFAULT_ENABLE_CONTENT_PANNING_GESTURE,\n enableHandlePanningGesture = DEFAULT_ENABLE_HANDLE_PANNING_GESTURE,\n enableOverDrag = DEFAULT_ENABLE_OVER_DRAG,\n enablePanDownToClose = DEFAULT_ENABLE_PAN_DOWN_TO_CLOSE,\n enableDynamicSizing = DEFAULT_DYNAMIC_SIZING,\n overDragResistanceFactor = DEFAULT_OVER_DRAG_RESISTANCE_FACTOR,\n // styles\n style: _providedStyle,\n containerStyle: _providedContainerStyle,\n backgroundStyle: _providedBackgroundStyle,\n handleStyle: _providedHandleStyle,\n handleIndicatorStyle: _providedHandleIndicatorStyle,\n // hooks\n gestureEventsHandlersHook,\n // keyboard\n keyboardBehavior = DEFAULT_KEYBOARD_BEHAVIOR,\n keyboardBlurBehavior = DEFAULT_KEYBOARD_BLUR_BEHAVIOR,\n android_keyboardInputMode = DEFAULT_KEYBOARD_INPUT_MODE,\n // layout\n handleHeight: _providedHandleHeight,\n containerHeight: _providedContainerHeight,\n contentHeight: _providedContentHeight,\n containerOffset: _providedContainerOffset,\n topInset = 0,\n bottomInset = 0,\n maxDynamicContentSize,\n // animated callback shared values\n animatedPosition: _providedAnimatedPosition,\n animatedIndex: _providedAnimatedIndex,\n // gestures\n simultaneousHandlers: _providedSimultaneousHandlers,\n waitFor: _providedWaitFor,\n activeOffsetX: _providedActiveOffsetX,\n activeOffsetY: _providedActiveOffsetY,\n failOffsetX: _providedFailOffsetX,\n failOffsetY: _providedFailOffsetY,\n // callbacks\n onChange: _providedOnChange,\n onClose: _providedOnClose,\n onAnimate: _providedOnAnimate,\n // private\n $modal = false,\n detached = false,\n // components\n handleComponent,\n backdropComponent,\n backgroundComponent,\n footerComponent,\n children: Content\n } = props; //#endregion\n //#region layout variables\n\n /**\n * This variable is consider an internal variable,\n * that will be used conditionally in `animatedContainerHeight`\n */\n\n const _animatedContainerHeight = useReactiveSharedValue(_providedContainerHeight !== null && _providedContainerHeight !== void 0 ? _providedContainerHeight : INITIAL_CONTAINER_HEIGHT);\n /**\n * This is a conditional variable, where if the `BottomSheet` is used\n * in a modal, then it will subset vertical insets (top+bottom) from\n * provided container height.\n */\n\n\n const animatedContainerHeight = useDerivedValue(() => {\n const verticalInset = topInset + bottomInset;\n return $modal ? _animatedContainerHeight.value - verticalInset : _animatedContainerHeight.value;\n }, [$modal, topInset, bottomInset]);\n const animatedContainerOffset = useReactiveSharedValue(_providedContainerOffset !== null && _providedContainerOffset !== void 0 ? _providedContainerOffset : INITIAL_CONTAINER_OFFSET);\n const animatedHandleHeight = useReactiveSharedValue(_providedHandleHeight !== null && _providedHandleHeight !== void 0 ? _providedHandleHeight : INITIAL_HANDLE_HEIGHT);\n const animatedFooterHeight = useSharedValue(0);\n const animatedContentHeight = useSharedValue(INITIAL_CONTAINER_HEIGHT);\n const animatedSnapPoints = useNormalizedSnapPoints(_providedSnapPoints, animatedContainerHeight, animatedContentHeight, animatedHandleHeight, enableDynamicSizing, maxDynamicContentSize);\n const animatedHighestSnapPoint = useDerivedValue(() => animatedSnapPoints.value[animatedSnapPoints.value.length - 1]);\n const animatedClosedPosition = useDerivedValue(() => {\n let closedPosition = animatedContainerHeight.value;\n\n if ($modal || detached) {\n closedPosition = animatedContainerHeight.value + bottomInset;\n }\n\n return closedPosition;\n }, [$modal, detached, bottomInset]);\n const animatedSheetHeight = useDerivedValue(() => animatedContainerHeight.value - animatedHighestSnapPoint.value);\n const animatedCurrentIndex = useReactiveSharedValue(animateOnMount ? -1 : _providedIndex);\n const animatedPosition = useSharedValue(INITIAL_POSITION);\n const animatedNextPosition = useSharedValue(INITIAL_VALUE);\n const animatedNextPositionIndex = useSharedValue(0); // conditional\n\n const isAnimatedOnMount = useSharedValue(false);\n const isContentHeightFixed = useSharedValue(false);\n const isLayoutCalculated = useDerivedValue(() => {\n let isContainerHeightCalculated = false; //container height was provided.\n\n if (_providedContainerHeight !== null || _providedContainerHeight !== undefined) {\n isContainerHeightCalculated = true;\n } // container height did set.\n\n\n if (animatedContainerHeight.value !== INITIAL_CONTAINER_HEIGHT) {\n isContainerHeightCalculated = true;\n }\n\n let isHandleHeightCalculated = false; // handle height is provided.\n\n if (_providedHandleHeight !== null && _providedHandleHeight !== undefined && typeof _providedHandleHeight === 'number') {\n isHandleHeightCalculated = true;\n } // handle component is null.\n\n\n if (handleComponent === null) {\n animatedHandleHeight.value = 0;\n isHandleHeightCalculated = true;\n } // handle height did set.\n\n\n if (animatedHandleHeight.value !== INITIAL_HANDLE_HEIGHT) {\n isHandleHeightCalculated = true;\n }\n\n let isSnapPointsNormalized = false; // the first snap point did normalized\n\n if (animatedSnapPoints.value[0] !== INITIAL_SNAP_POINT) {\n isSnapPointsNormalized = true;\n }\n\n return isContainerHeightCalculated && isHandleHeightCalculated && isSnapPointsNormalized;\n });\n const isInTemporaryPosition = useSharedValue(false);\n const isForcedClosing = useSharedValue(false); // gesture\n\n const animatedContentGestureState = useSharedValue(State.UNDETERMINED);\n const animatedHandleGestureState = useSharedValue(State.UNDETERMINED); //#endregion\n //#region hooks variables\n // scrollable variables\n\n const {\n animatedScrollableType,\n animatedScrollableContentOffsetY,\n animatedScrollableOverrideState,\n isScrollableRefreshable,\n setScrollableRef,\n removeScrollableRef\n } = useScrollable(); // keyboard\n\n const {\n state: animatedKeyboardState,\n height: animatedKeyboardHeight,\n animationDuration: keyboardAnimationDuration,\n animationEasing: keyboardAnimationEasing,\n shouldHandleKeyboardEvents\n } = useKeyboard();\n const animatedKeyboardHeightInContainer = useSharedValue(0); //#endregion\n //#region state/dynamic variables\n // states\n\n const animatedAnimationState = useSharedValue(ANIMATION_STATE.UNDETERMINED);\n const animatedAnimationSource = useSharedValue(ANIMATION_SOURCE.MOUNT);\n const animatedSheetState = useDerivedValue(() => {\n // closed position = position >= container height\n if (animatedPosition.value >= animatedClosedPosition.value) return SHEET_STATE.CLOSED; // extended position = container height - sheet height\n\n const extendedPosition = animatedContainerHeight.value - animatedSheetHeight.value;\n if (animatedPosition.value === extendedPosition) return SHEET_STATE.EXTENDED; // extended position with keyboard =\n // container height - (sheet height + keyboard height in root container)\n\n const keyboardHeightInContainer = animatedKeyboardHeightInContainer.value;\n const extendedPositionWithKeyboard = Math.max(0, animatedContainerHeight.value - (animatedSheetHeight.value + keyboardHeightInContainer)); // detect if keyboard is open and the sheet is in temporary position\n\n if (keyboardBehavior === KEYBOARD_BEHAVIOR.interactive && isInTemporaryPosition.value && animatedPosition.value === extendedPositionWithKeyboard) {\n return SHEET_STATE.EXTENDED;\n } // fill parent = 0\n\n\n if (animatedPosition.value === 0) {\n return SHEET_STATE.FILL_PARENT;\n } // detect if position is below extended point\n\n\n if (animatedPosition.value < extendedPosition) {\n return SHEET_STATE.OVER_EXTENDED;\n }\n\n return SHEET_STATE.OPENED;\n }, [animatedClosedPosition, animatedContainerHeight, animatedKeyboardHeightInContainer, animatedPosition, animatedSheetHeight, isInTemporaryPosition, keyboardBehavior]);\n const animatedScrollableState = useDerivedValue(() => {\n /**\n * if scrollable override state is set, then we just return its value.\n */\n if (animatedScrollableOverrideState.value !== SCROLLABLE_STATE.UNDETERMINED) {\n return animatedScrollableOverrideState.value;\n }\n /**\n * if sheet state is fill parent, then unlock scrolling\n */\n\n\n if (animatedSheetState.value === SHEET_STATE.FILL_PARENT) {\n return SCROLLABLE_STATE.UNLOCKED;\n }\n /**\n * if sheet state is extended, then unlock scrolling\n */\n\n\n if (animatedSheetState.value === SHEET_STATE.EXTENDED) {\n return SCROLLABLE_STATE.UNLOCKED;\n }\n /**\n * if keyboard is shown and sheet is animating\n * then we do not lock the scrolling to not lose\n * current scrollable scroll position.\n */\n\n\n if (animatedKeyboardState.value === KEYBOARD_STATE.SHOWN && animatedAnimationState.value === ANIMATION_STATE.RUNNING) {\n return SCROLLABLE_STATE.UNLOCKED;\n }\n\n return SCROLLABLE_STATE.LOCKED;\n }); // dynamic\n\n const animatedContentHeightMax = useDerivedValue(() => {\n const keyboardHeightInContainer = animatedKeyboardHeightInContainer.value;\n const handleHeight = Math.max(0, animatedHandleHeight.value);\n let contentHeight = animatedSheetHeight.value - handleHeight;\n\n if (keyboardBehavior === KEYBOARD_BEHAVIOR.extend && animatedKeyboardState.value === KEYBOARD_STATE.SHOWN) {\n contentHeight = contentHeight - keyboardHeightInContainer;\n } else if (keyboardBehavior === KEYBOARD_BEHAVIOR.fillParent && isInTemporaryPosition.value) {\n if (animatedKeyboardState.value === KEYBOARD_STATE.SHOWN) {\n contentHeight = animatedContainerHeight.value - handleHeight - keyboardHeightInContainer;\n } else {\n contentHeight = animatedContainerHeight.value - handleHeight;\n }\n } else if (keyboardBehavior === KEYBOARD_BEHAVIOR.interactive && isInTemporaryPosition.value) {\n const contentWithKeyboardHeight = contentHeight + keyboardHeightInContainer;\n\n if (animatedKeyboardState.value === KEYBOARD_STATE.SHOWN) {\n if (keyboardHeightInContainer + animatedSheetHeight.value > animatedContainerHeight.value) {\n contentHeight = animatedContainerHeight.value - keyboardHeightInContainer - handleHeight;\n }\n } else if (contentWithKeyboardHeight + handleHeight > animatedContainerHeight.value) {\n contentHeight = animatedContainerHeight.value - handleHeight;\n } else {\n contentHeight = contentWithKeyboardHeight;\n }\n }\n /**\n * before the container is measured, `contentHeight` value will be below zero,\n * which will lead to freeze the scrollable.\n *\n * @link (https://github.com/gorhom/react-native-bottom-sheet/issues/470)\n */\n\n\n return Math.max(contentHeight, 0);\n }, [animatedContainerHeight, animatedHandleHeight, animatedKeyboardHeightInContainer, animatedKeyboardState, animatedSheetHeight, isInTemporaryPosition, keyboardBehavior]);\n const animatedIndex = useDerivedValue(() => {\n const adjustedSnapPoints = animatedSnapPoints.value.slice().reverse();\n const adjustedSnapPointsIndexes = animatedSnapPoints.value.slice().map((_, index) => index).reverse();\n /**\n * we add the close state index `-1`\n */\n\n adjustedSnapPoints.push(animatedContainerHeight.value);\n adjustedSnapPointsIndexes.push(-1);\n const currentIndex = isLayoutCalculated.value ? interpolate(animatedPosition.value, adjustedSnapPoints, adjustedSnapPointsIndexes, Extrapolate.CLAMP) : -1;\n /**\n * if the sheet is currently running an animation by the keyboard opening,\n * then we clamp the index on android with resize keyboard mode.\n */\n\n if (android_keyboardInputMode === KEYBOARD_INPUT_MODE.adjustResize && animatedAnimationSource.value === ANIMATION_SOURCE.KEYBOARD && animatedAnimationState.value === ANIMATION_STATE.RUNNING && isInTemporaryPosition.value) {\n return Math.max(animatedCurrentIndex.value, currentIndex);\n }\n /**\n * if the sheet is currently running an animation by snap point change - usually caused\n * by dynamic content height -, then we return the next position index.\n */\n\n\n if (animatedAnimationSource.value === ANIMATION_SOURCE.SNAP_POINT_CHANGE && animatedAnimationState.value === ANIMATION_STATE.RUNNING) {\n return animatedNextPositionIndex.value;\n }\n\n return currentIndex;\n }, [android_keyboardInputMode]); //#endregion\n //#region private methods\n\n /**\n * Calculate the next position based on keyboard state.\n */\n\n const getNextPosition = useWorkletCallback(function getNextPosition() {\n 'worklet';\n\n const currentIndex = animatedCurrentIndex.value;\n const snapPoints = animatedSnapPoints.value;\n const keyboardState = animatedKeyboardState.value;\n const highestSnapPoint = animatedHighestSnapPoint.value;\n /**\n * Handle restore sheet position on blur\n */\n\n if (keyboardBlurBehavior === KEYBOARD_BLUR_BEHAVIOR.restore && keyboardState === KEYBOARD_STATE.HIDDEN && animatedContentGestureState.value !== State.ACTIVE && animatedHandleGestureState.value !== State.ACTIVE) {\n isInTemporaryPosition.value = false;\n const nextPosition = snapPoints[currentIndex];\n return nextPosition;\n }\n /**\n * Handle extend behavior\n */\n\n\n if (keyboardBehavior === KEYBOARD_BEHAVIOR.extend && keyboardState === KEYBOARD_STATE.SHOWN) {\n return highestSnapPoint;\n }\n /**\n * Handle full screen behavior\n */\n\n\n if (keyboardBehavior === KEYBOARD_BEHAVIOR.fillParent && keyboardState === KEYBOARD_STATE.SHOWN) {\n isInTemporaryPosition.value = true;\n return 0;\n }\n /**\n * handle interactive behavior\n */\n\n\n if (keyboardBehavior === KEYBOARD_BEHAVIOR.interactive && keyboardState === KEYBOARD_STATE.SHOWN) {\n isInTemporaryPosition.value = true;\n const keyboardHeightInContainer = animatedKeyboardHeightInContainer.value;\n return Math.max(0, highestSnapPoint - keyboardHeightInContainer);\n }\n\n if (isInTemporaryPosition.value) {\n return animatedPosition.value;\n }\n\n return snapPoints[currentIndex];\n }, [animatedContentGestureState, animatedCurrentIndex, animatedHandleGestureState, animatedHighestSnapPoint, animatedKeyboardHeightInContainer, animatedKeyboardState, animatedPosition, animatedSnapPoints, isInTemporaryPosition, keyboardBehavior, keyboardBlurBehavior]);\n const handleOnChange = useCallback(function handleOnChange(index) {\n print({\n component: BottomSheet.name,\n method: handleOnChange.name,\n params: {\n index,\n animatedCurrentIndex: animatedCurrentIndex.value\n }\n });\n\n if (_providedOnChange) {\n _providedOnChange(index);\n }\n }, [_providedOnChange, animatedCurrentIndex]);\n const handleOnAnimate = useCallback(function handleOnAnimate(toPoint) {\n const snapPoints = animatedSnapPoints.value;\n const toIndex = snapPoints.indexOf(toPoint);\n print({\n component: BottomSheet.name,\n method: handleOnAnimate.name,\n params: {\n toIndex,\n fromIndex: animatedCurrentIndex.value\n }\n });\n\n if (!_providedOnAnimate) {\n return;\n }\n\n if (toIndex !== animatedCurrentIndex.value) {\n _providedOnAnimate(animatedCurrentIndex.value, toIndex);\n }\n }, [_providedOnAnimate, animatedSnapPoints, animatedCurrentIndex]); //#endregion\n //#region animation\n\n const stopAnimation = useWorkletCallback(() => {\n cancelAnimation(animatedPosition);\n isForcedClosing.value = false;\n animatedAnimationSource.value = ANIMATION_SOURCE.NONE;\n animatedAnimationState.value = ANIMATION_STATE.STOPPED;\n }, [animatedPosition, animatedAnimationState, animatedAnimationSource]);\n const animateToPositionCompleted = useWorkletCallback(function animateToPositionCompleted(isFinished) {\n isForcedClosing.value = false;\n\n if (!isFinished) {\n return;\n }\n\n runOnJS(print)({\n component: BottomSheet.name,\n method: animateToPositionCompleted.name,\n params: {\n animatedCurrentIndex: animatedCurrentIndex.value,\n animatedNextPosition: animatedNextPosition.value,\n animatedNextPositionIndex: animatedNextPositionIndex.value\n }\n });\n animatedAnimationSource.value = ANIMATION_SOURCE.NONE;\n animatedAnimationState.value = ANIMATION_STATE.STOPPED;\n animatedNextPosition.value = INITIAL_VALUE;\n animatedNextPositionIndex.value = INITIAL_VALUE;\n });\n const animateToPosition = useWorkletCallback(function animateToPosition(position, source, velocity = 0, configs) {\n if (position === animatedPosition.value || position === undefined || animatedAnimationState.value === ANIMATION_STATE.RUNNING && position === animatedNextPosition.value) {\n return;\n }\n\n runOnJS(print)({\n component: BottomSheet.name,\n method: animateToPosition.name,\n params: {\n currentPosition: animatedPosition.value,\n position,\n velocity,\n animatedContainerHeight: animatedContainerHeight.value\n }\n });\n stopAnimation();\n /**\n * set animation state to running, and source\n */\n\n animatedAnimationState.value = ANIMATION_STATE.RUNNING;\n animatedAnimationSource.value = source;\n /**\n * store next position\n */\n\n animatedNextPosition.value = position;\n animatedNextPositionIndex.value = animatedSnapPoints.value.indexOf(position);\n /**\n * fire `onAnimate` callback\n */\n\n runOnJS(handleOnAnimate)(position);\n /**\n * force animation configs from parameters, if provided\n */\n\n if (configs !== undefined) {\n animatedPosition.value = animate({\n point: position,\n configs,\n velocity,\n onComplete: animateToPositionCompleted\n });\n } else {\n /**\n * use animationConfigs callback, if provided\n */\n animatedPosition.value = animate({\n point: position,\n velocity,\n configs: _providedAnimationConfigs,\n onComplete: animateToPositionCompleted\n });\n }\n }, [handleOnAnimate, _providedAnimationConfigs]); //#endregion\n //#region public methods\n\n const handleSnapToIndex = useCallback(function handleSnapToIndex(index, animationConfigs) {\n const snapPoints = animatedSnapPoints.value;\n invariant(index >= -1 && index <= snapPoints.length - 1, `'index' was provided but out of the provided snap points range! expected value to be between -1, ${snapPoints.length - 1}`);\n print({\n component: BottomSheet.name,\n method: handleSnapToIndex.name,\n params: {\n index\n }\n });\n const nextPosition = snapPoints[index];\n /**\n * exit method if :\n * - layout is not calculated.\n * - already animating to next position.\n * - sheet is forced closing.\n */\n\n if (!isLayoutCalculated.value || index === animatedNextPositionIndex.value || nextPosition === animatedNextPosition.value || isForcedClosing.value) {\n return;\n }\n /**\n * reset temporary position boolean.\n */\n\n\n isInTemporaryPosition.value = false;\n runOnUI(animateToPosition)(nextPosition, ANIMATION_SOURCE.USER, 0, animationConfigs);\n }, [animateToPosition, isLayoutCalculated, isInTemporaryPosition, isForcedClosing, animatedSnapPoints, animatedNextPosition, animatedNextPositionIndex]);\n const handleSnapToPosition = useWorkletCallback(function handleSnapToPosition(position, animationConfigs) {\n print({\n component: BottomSheet.name,\n method: handleSnapToPosition.name,\n params: {\n position\n }\n });\n /**\n * normalized provided position.\n */\n\n const nextPosition = normalizeSnapPoint(position, animatedContainerHeight.value);\n /**\n * exit method if :\n * - layout is not calculated.\n * - already animating to next position.\n * - sheet is forced closing.\n */\n\n if (!isLayoutCalculated || nextPosition === animatedNextPosition.value || isForcedClosing.value) {\n return;\n }\n /**\n * mark the new position as temporary.\n */\n\n\n isInTemporaryPosition.value = true;\n runOnUI(animateToPosition)(nextPosition, ANIMATION_SOURCE.USER, 0, animationConfigs);\n }, [animateToPosition, bottomInset, topInset, isLayoutCalculated, isForcedClosing, animatedContainerHeight, animatedPosition]);\n const handleClose = useCallback(function handleClose(animationConfigs) {\n print({\n component: BottomSheet.name,\n method: handleClose.name\n });\n const nextPosition = animatedClosedPosition.value;\n /**\n * exit method if :\n * - layout is not calculated.\n * - already animating to next position.\n * - sheet is forced closing.\n */\n\n if (!isLayoutCalculated.value || nextPosition === animatedNextPosition.value || isForcedClosing.value) {\n return;\n }\n /**\n * reset temporary position variable.\n */\n\n\n isInTemporaryPosition.value = false;\n runOnUI(animateToPosition)(nextPosition, ANIMATION_SOURCE.USER, 0, animationConfigs);\n }, [animateToPosition, isForcedClosing, isLayoutCalculated, isInTemporaryPosition, animatedNextPosition, animatedClosedPosition]);\n const handleForceClose = useCallback(function handleForceClose(animationConfigs) {\n print({\n component: BottomSheet.name,\n method: handleForceClose.name\n });\n const nextPosition = animatedClosedPosition.value;\n /**\n * exit method if :\n * - already animating to next position.\n * - sheet is forced closing.\n */\n\n if (nextPosition === animatedNextPosition.value || isForcedClosing.value) {\n return;\n }\n /**\n * reset temporary position variable.\n */\n\n\n isInTemporaryPosition.value = false;\n /**\n * set force closing variable.\n */\n\n isForcedClosing.value = true;\n runOnUI(animateToPosition)(nextPosition, ANIMATION_SOURCE.USER, 0, animationConfigs);\n }, [animateToPosition, isForcedClosing, isInTemporaryPosition, animatedNextPosition, animatedClosedPosition]);\n const handleExpand = useCallback(function handleExpand(animationConfigs) {\n print({\n component: BottomSheet.name,\n method: handleExpand.name\n });\n const snapPoints = animatedSnapPoints.value;\n const nextPosition = snapPoints[snapPoints.length - 1];\n /**\n * exit method if :\n * - layout is not calculated.\n * - already animating to next position.\n * - sheet is forced closing.\n */\n\n if (!isLayoutCalculated.value || snapPoints.length - 1 === animatedNextPositionIndex.value || nextPosition === animatedNextPosition.value || isForcedClosing.value) {\n return;\n }\n /**\n * reset temporary position boolean.\n */\n\n\n isInTemporaryPosition.value = false;\n runOnUI(animateToPosition)(nextPosition, ANIMATION_SOURCE.USER, 0, animationConfigs);\n }, [animateToPosition, isInTemporaryPosition, isLayoutCalculated, isForcedClosing, animatedSnapPoints, animatedNextPosition, animatedNextPositionIndex]);\n const handleCollapse = useCallback(function handleCollapse(animationConfigs) {\n print({\n component: BottomSheet.name,\n method: handleCollapse.name\n });\n const nextPosition = animatedSnapPoints.value[0];\n /**\n * exit method if :\n * - layout is not calculated.\n * - already animating to next position.\n * - sheet is forced closing.\n */\n\n if (!isLayoutCalculated || animatedNextPositionIndex.value === 0 || nextPosition === animatedNextPosition.value || isForcedClosing.value) {\n return;\n }\n /**\n * reset temporary position boolean.\n */\n\n\n isInTemporaryPosition.value = false;\n runOnUI(animateToPosition)(nextPosition, ANIMATION_SOURCE.USER, 0, animationConfigs);\n }, [animateToPosition, isForcedClosing, isLayoutCalculated, isInTemporaryPosition, animatedSnapPoints, animatedNextPosition, animatedNextPositionIndex]);\n useImperativeHandle(ref, () => ({\n snapToIndex: handleSnapToIndex,\n snapToPosition: handleSnapToPosition,\n expand: handleExpand,\n collapse: handleCollapse,\n close: handleClose,\n forceClose: handleForceClose\n })); //#endregion\n //#region contexts variables\n\n const internalContextVariables = useMemo(() => ({\n enableContentPanningGesture,\n enableDynamicSizing,\n overDragResistanceFactor,\n enableOverDrag,\n enablePanDownToClose,\n animatedAnimationState,\n animatedSheetState,\n animatedScrollableState,\n animatedScrollableOverrideState,\n animatedContentGestureState,\n animatedHandleGestureState,\n animatedKeyboardState,\n animatedScrollableType,\n animatedIndex,\n animatedPosition,\n animatedContentHeight,\n animatedClosedPosition,\n animatedHandleHeight,\n animatedFooterHeight,\n animatedKeyboardHeight,\n animatedKeyboardHeightInContainer,\n animatedContainerHeight,\n animatedSnapPoints,\n animatedHighestSnapPoint,\n animatedScrollableContentOffsetY,\n isInTemporaryPosition,\n isContentHeightFixed,\n isScrollableRefreshable,\n shouldHandleKeyboardEvents,\n simultaneousHandlers: _providedSimultaneousHandlers,\n waitFor: _providedWaitFor,\n activeOffsetX: _providedActiveOffsetX,\n activeOffsetY: _providedActiveOffsetY,\n failOffsetX: _providedFailOffsetX,\n failOffsetY: _providedFailOffsetY,\n animateToPosition,\n stopAnimation,\n setScrollableRef,\n removeScrollableRef\n }), [animatedIndex, animatedPosition, animatedContentHeight, animatedScrollableType, animatedContentGestureState, animatedHandleGestureState, animatedClosedPosition, animatedFooterHeight, animatedContainerHeight, animatedHandleHeight, animatedAnimationState, animatedKeyboardState, animatedKeyboardHeight, animatedKeyboardHeightInContainer, animatedSheetState, animatedHighestSnapPoint, animatedScrollableState, animatedScrollableOverrideState, animatedSnapPoints, shouldHandleKeyboardEvents, animatedScrollableContentOffsetY, isScrollableRefreshable, isContentHeightFixed, isInTemporaryPosition, enableContentPanningGesture, overDragResistanceFactor, enableOverDrag, enablePanDownToClose, enableDynamicSizing, _providedSimultaneousHandlers, _providedWaitFor, _providedActiveOffsetX, _providedActiveOffsetY, _providedFailOffsetX, _providedFailOffsetY, setScrollableRef, removeScrollableRef, animateToPosition, stopAnimation]);\n const externalContextVariables = useMemo(() => ({\n animatedIndex,\n animatedPosition,\n snapToIndex: handleSnapToIndex,\n snapToPosition: handleSnapToPosition,\n expand: handleExpand,\n collapse: handleCollapse,\n close: handleClose,\n forceClose: handleForceClose\n }), [animatedIndex, animatedPosition, handleSnapToIndex, handleSnapToPosition, handleExpand, handleCollapse, handleClose, handleForceClose]); //#endregion\n //#region styles\n\n const containerAnimatedStyle = useAnimatedStyle(() => ({\n opacity: Platform.OS === 'android' && animatedIndex.value === -1 ? 0 : 1,\n transform: [{\n translateY: animatedPosition.value\n }]\n }), [animatedPosition, animatedIndex]);\n const containerStyle = useMemo(() => [_providedStyle, styles.container, containerAnimatedStyle], [_providedStyle, containerAnimatedStyle]);\n const contentContainerAnimatedStyle = useAnimatedStyle(() => {\n /**\n * if content height was provided, then we skip setting\n * calculated height.\n */\n if (_providedContentHeight) {\n return {};\n }\n\n return {\n height: animate({\n point: animatedContentHeightMax.value,\n configs: _providedAnimationConfigs\n })\n };\n }, [animatedContentHeightMax, enableDynamicSizing, animatedContentHeight]);\n const contentContainerStyle = useMemo(() => [styles.contentContainer, contentContainerAnimatedStyle], [contentContainerAnimatedStyle]);\n /**\n * added safe area to prevent the sheet from floating above\n * the bottom of the screen, when sheet being over dragged or\n * when the sheet is resized.\n */\n\n const contentMaskContainerAnimatedStyle = useAnimatedStyle(() => {\n if (detached) {\n return {\n overflow: 'visible'\n };\n }\n\n return {\n paddingBottom: animatedContainerHeight.value\n };\n }, [detached]);\n const contentMaskContainerStyle = useMemo(() => [styles.contentMaskContainer, contentMaskContainerAnimatedStyle], [contentMaskContainerAnimatedStyle]); //#endregion\n //#region effects\n\n /**\n * React to `isLayoutCalculated` change, to insure that the sheet will\n * appears/mounts only when all layout is been calculated.\n *\n * @alias OnMount\n */\n\n useAnimatedReaction(() => isLayoutCalculated.value, _isLayoutCalculated => {\n /**\n * exit method if:\n * - layout is not calculated yet.\n * - already did animate on mount.\n */\n if (!_isLayoutCalculated || isAnimatedOnMount.value) {\n return;\n }\n\n let nextPosition;\n\n if (_providedIndex === -1) {\n nextPosition = animatedClosedPosition.value;\n animatedNextPositionIndex.value = -1;\n } else {\n nextPosition = animatedSnapPoints.value[_providedIndex];\n }\n\n runOnJS(print)({\n component: BottomSheet.name,\n method: 'useAnimatedReaction::OnMount',\n params: {\n isLayoutCalculated: _isLayoutCalculated,\n animatedSnapPoints: animatedSnapPoints.value,\n nextPosition\n }\n });\n /**\n * here we exit method early because the next position\n * is out of the screen, this happens when `snapPoints`\n * still being calculated.\n */\n\n if (nextPosition === INITIAL_POSITION || nextPosition === animatedClosedPosition.value) {\n isAnimatedOnMount.value = true;\n animatedCurrentIndex.value = _providedIndex;\n return;\n }\n\n if (animateOnMount) {\n animateToPosition(nextPosition, ANIMATION_SOURCE.MOUNT);\n } else {\n animatedPosition.value = nextPosition;\n }\n\n isAnimatedOnMount.value = true;\n }, [_providedIndex, animateOnMount]);\n /**\n * React to `snapPoints` change, to insure that the sheet position reflect\n * to the current point correctly.\n *\n * @alias OnSnapPointsChange\n */\n\n useAnimatedReaction(() => ({\n snapPoints: animatedSnapPoints.value,\n containerHeight: animatedContainerHeight.value\n }), (result, _previousResult) => {\n const {\n snapPoints,\n containerHeight\n } = result;\n\n const _previousSnapPoints = _previousResult === null || _previousResult === void 0 ? void 0 : _previousResult.snapPoints;\n\n const _previousContainerHeight = _previousResult === null || _previousResult === void 0 ? void 0 : _previousResult.containerHeight;\n\n let nextPosition;\n let animationConfig;\n let animationSource = ANIMATION_SOURCE.SNAP_POINT_CHANGE;\n /**\n * if the bottom sheet is closing and the container gets resized,\n * then we restart the closing animation to the new position.\n */\n\n if (animatedAnimationState.value === ANIMATION_STATE.RUNNING && animatedNextPositionIndex.value === -1 && _previousContainerHeight !== containerHeight) {\n animationSource = ANIMATION_SOURCE.CONTAINER_RESIZE;\n animationConfig = {\n duration: 0\n };\n animateToPosition(containerHeight, animationSource, 0, animationConfig);\n }\n\n if (JSON.stringify(snapPoints) === JSON.stringify(_previousSnapPoints) || !isLayoutCalculated.value || !isAnimatedOnMount.value || containerHeight <= 0) {\n return;\n }\n\n runOnJS(print)({\n component: BottomSheet.name,\n method: 'useAnimatedReaction::OnSnapPointChange',\n params: {\n snapPoints\n }\n });\n /**\n * if snap points changed while sheet is animating, then\n * we stop the animation and animate to the updated point.\n */\n\n if (animatedAnimationState.value === ANIMATION_STATE.RUNNING && animatedNextPositionIndex.value !== animatedCurrentIndex.value) {\n nextPosition = animatedNextPositionIndex.value !== -1 ? snapPoints[animatedNextPositionIndex.value] : animatedNextPosition.value;\n } else if (animatedCurrentIndex.value === -1) {\n nextPosition = animatedClosedPosition.value;\n } else if (isInTemporaryPosition.value) {\n nextPosition = getNextPosition();\n } else {\n nextPosition = snapPoints[animatedCurrentIndex.value];\n /**\n * if snap points changes because of the container height change,\n * then we skip the snap animation by setting the duration to 0.\n */\n\n if (containerHeight !== _previousContainerHeight) {\n animationSource = ANIMATION_SOURCE.CONTAINER_RESIZE;\n animationConfig = {\n duration: 0\n };\n }\n }\n\n animateToPosition(nextPosition, animationSource, 0, animationConfig);\n });\n /**\n * React to keyboard appearance state.\n *\n * @alias OnKeyboardStateChange\n */\n\n useAnimatedReaction(() => ({\n _keyboardState: animatedKeyboardState.value,\n _keyboardHeight: animatedKeyboardHeight.value\n }), (result, _previousResult) => {\n const {\n _keyboardState,\n _keyboardHeight\n } = result;\n\n const _previousKeyboardState = _previousResult === null || _previousResult === void 0 ? void 0 : _previousResult._keyboardState;\n\n const _previousKeyboardHeight = _previousResult === null || _previousResult === void 0 ? void 0 : _previousResult._keyboardHeight;\n /**\n * Calculate the keyboard height in the container.\n */\n\n\n animatedKeyboardHeightInContainer.value = $modal ? Math.abs(_keyboardHeight - Math.abs(bottomInset - animatedContainerOffset.value.bottom)) : Math.abs(_keyboardHeight - animatedContainerOffset.value.bottom);\n const hasActiveGesture = animatedContentGestureState.value === State.ACTIVE || animatedContentGestureState.value === State.BEGAN || animatedHandleGestureState.value === State.ACTIVE || animatedHandleGestureState.value === State.BEGAN;\n\n if (\n /**\n * if keyboard state is equal to the previous state, then exit the method\n */\n _keyboardState === _previousKeyboardState && _keyboardHeight === _previousKeyboardHeight ||\n /**\n * if user is interacting with sheet, then exit the method\n */\n hasActiveGesture ||\n /**\n * if sheet not animated on mount yet, then exit the method\n */\n !isAnimatedOnMount.value || _keyboardState === KEYBOARD_STATE.HIDDEN && keyboardBlurBehavior === KEYBOARD_BLUR_BEHAVIOR.none || Platform.OS === 'android' && keyboardBehavior === KEYBOARD_BEHAVIOR.interactive && android_keyboardInputMode === KEYBOARD_INPUT_MODE.adjustResize) {\n animatedKeyboardHeightInContainer.value = 0;\n return;\n }\n\n runOnJS(print)({\n component: BottomSheet.name,\n method: 'useAnimatedReaction::OnKeyboardStateChange',\n params: {\n keyboardState: _keyboardState,\n keyboardHeight: _keyboardHeight\n }\n });\n let animationConfigs = getKeyboardAnimationConfigs(keyboardAnimationEasing.value, keyboardAnimationDuration.value);\n const nextPosition = getNextPosition();\n animateToPosition(nextPosition, ANIMATION_SOURCE.KEYBOARD, 0, animationConfigs);\n }, [$modal, bottomInset, keyboardBehavior, keyboardBlurBehavior, android_keyboardInputMode, animatedContainerOffset, getNextPosition]);\n /**\n * sets provided animated position\n */\n\n useAnimatedReaction(() => animatedPosition.value, _animatedPosition => {\n if (_providedAnimatedPosition) {\n _providedAnimatedPosition.value = _animatedPosition + topInset;\n }\n });\n /**\n * sets provided animated index\n */\n\n useAnimatedReaction(() => animatedIndex.value, _animatedIndex => {\n if (_providedAnimatedIndex) {\n _providedAnimatedIndex.value = _animatedIndex;\n }\n });\n /**\n * React to internal variables to detect change in snap position.\n *\n * @alias OnChange\n */\n\n useAnimatedReaction(() => ({\n _animatedIndex: animatedIndex.value,\n _animatedPosition: animatedPosition.value,\n _animationState: animatedAnimationState.value,\n _contentGestureState: animatedContentGestureState.value,\n _handleGestureState: animatedHandleGestureState.value\n }), ({\n _animatedIndex,\n _animationState,\n _contentGestureState,\n _handleGestureState\n }) => {\n /**\n * exit the method if animation state is not stopped.\n */\n if (_animationState !== ANIMATION_STATE.STOPPED) {\n return;\n }\n /**\n * exit the method if animated index value\n * has fraction, e.g. 1.99, 0.52\n */\n\n\n if (_animatedIndex % 1 !== 0) {\n return;\n }\n /**\n * exit the method if there any active gesture.\n */\n\n\n const hasNoActiveGesture = (_contentGestureState === State.END || _contentGestureState === State.UNDETERMINED || _contentGestureState === State.CANCELLED) && (_handleGestureState === State.END || _handleGestureState === State.UNDETERMINED || _handleGestureState === State.CANCELLED);\n\n if (!hasNoActiveGesture) {\n return;\n }\n /**\n * if the index is not equal to the current index,\n * than the sheet position had changed and we trigger\n * the `onChange` callback.\n */\n\n\n if (_animatedIndex !== animatedCurrentIndex.value) {\n runOnJS(print)({\n component: BottomSheet.name,\n method: 'useAnimatedReaction::OnChange',\n params: {\n animatedCurrentIndex: animatedCurrentIndex.value,\n animatedIndex: _animatedIndex\n }\n });\n animatedCurrentIndex.value = _animatedIndex;\n runOnJS(handleOnChange)(_animatedIndex);\n }\n /**\n * if index is `-1` than we fire the `onClose` callback.\n */\n\n\n if (_animatedIndex === -1 && _providedOnClose) {\n runOnJS(print)({\n component: BottomSheet.name,\n method: 'useAnimatedReaction::onClose',\n params: {\n animatedCurrentIndex: animatedCurrentIndex.value,\n animatedIndex: _animatedIndex\n }\n });\n runOnJS(_providedOnClose)();\n }\n }, [handleOnChange, _providedOnClose]);\n /**\n * React to `index` prop to snap the sheet to the new position.\n *\n * @alias onIndexChange\n */\n\n useEffect(() => {\n if (isAnimatedOnMount.value) {\n handleSnapToIndex(_providedIndex);\n }\n }, [_providedIndex, animatedCurrentIndex, isAnimatedOnMount, handleSnapToIndex]); //#endregion\n // render\n\n print({\n component: BottomSheet.name,\n method: 'render',\n params: {\n animatedSnapPoints: animatedSnapPoints.value,\n animatedCurrentIndex: animatedCurrentIndex.value,\n providedIndex: _providedIndex\n }\n });\n return /*#__PURE__*/React.createElement(BottomSheetProvider, {\n value: externalContextVariables\n }, /*#__PURE__*/React.createElement(BottomSheetInternalProvider, {\n value: internalContextVariables\n }, /*#__PURE__*/React.createElement(BottomSheetGestureHandlersProvider, {\n gestureEventsHandlersHook: gestureEventsHandlersHook\n }, /*#__PURE__*/React.createElement(BottomSheetBackdropContainer, {\n key: \"BottomSheetBackdropContainer\",\n animatedIndex: animatedIndex,\n animatedPosition: animatedPosition,\n backdropComponent: backdropComponent\n }), /*#__PURE__*/React.createElement(BottomSheetContainer, {\n key: \"BottomSheetContainer\",\n shouldCalculateHeight: !$modal,\n containerHeight: _animatedContainerHeight,\n containerOffset: animatedContainerOffset,\n topInset: topInset,\n bottomInset: bottomInset,\n detached: detached,\n style: _providedContainerStyle\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: containerStyle\n }, /*#__PURE__*/React.createElement(BottomSheetBackgroundContainer, {\n key: \"BottomSheetBackgroundContainer\",\n animatedIndex: animatedIndex,\n animatedPosition: animatedPosition,\n backgroundComponent: backgroundComponent,\n backgroundStyle: _providedBackgroundStyle\n }), /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: \"box-none\",\n style: contentMaskContainerStyle\n }, /*#__PURE__*/React.createElement(BottomSheetDraggableView, {\n key: \"BottomSheetRootDraggableView\",\n style: contentContainerStyle\n }, typeof Content === 'function' ? /*#__PURE__*/React.createElement(Content, null) : Content, footerComponent && /*#__PURE__*/React.createElement(BottomSheetFooterContainer, {\n footerComponent: footerComponent\n }))), /*#__PURE__*/React.createElement(BottomSheetHandleContainer, {\n key: \"BottomSheetHandleContainer\",\n animatedIndex: animatedIndex,\n animatedPosition: animatedPosition,\n handleHeight: animatedHandleHeight,\n enableHandlePanningGesture: enableHandlePanningGesture,\n enableOverDrag: enableOverDrag,\n enablePanDownToClose: enablePanDownToClose,\n overDragResistanceFactor: overDragResistanceFactor,\n keyboardBehavior: keyboardBehavior,\n handleComponent: handleComponent,\n handleStyle: _providedHandleStyle,\n handleIndicatorStyle: _providedHandleIndicatorStyle\n }))))));\n});\nconst BottomSheet = /*#__PURE__*/memo(BottomSheetComponent);\nBottomSheet.displayName = 'BottomSheet';\nexport default BottomSheet;\n//# sourceMappingURL=BottomSheet.js.map","export { useBottomSheet } from './useBottomSheet';\nexport { useBottomSheetInternal } from './useBottomSheetInternal'; // modal\n\nexport { useBottomSheetModal } from './useBottomSheetModal';\nexport { useBottomSheetModalInternal } from './useBottomSheetModalInternal'; // scrollable\n\nexport { useScrollable } from './useScrollable';\nexport { useScrollableSetter } from './useScrollableSetter';\nexport { useScrollHandler } from './useScrollHandler'; // gestures\n\nexport { useGestureHandler } from './useGestureHandler';\nexport { useGestureEventsHandlersDefault } from './useGestureEventsHandlersDefault'; // utilities\n\nexport { useKeyboard } from './useKeyboard';\nexport { useStableCallback } from './useStableCallback';\nexport { usePropsValidator } from './usePropsValidator';\nexport { useNormalizedSnapPoints } from './useNormalizedSnapPoints';\nexport { useReactiveSharedValue } from './useReactiveSharedValue';\nexport { useBottomSheetDynamicSnapPoints } from './useBottomSheetDynamicSnapPoints';\nexport { useBottomSheetGestureHandlers } from './useBottomSheetGestureHandlers';\n//# sourceMappingURL=index.js.map","import { useContext } from 'react';\nimport { BottomSheetContext } from '../contexts/external';\nexport const useBottomSheet = () => {\n const context = useContext(BottomSheetContext);\n\n if (context === null) {\n throw \"'useBottomSheet' cannot be used out of the BottomSheet!\";\n }\n\n return context;\n};\n//# sourceMappingURL=useBottomSheet.js.map","import { createContext } from 'react';\nexport const BottomSheetContext = /*#__PURE__*/createContext(null);\nexport const BottomSheetProvider = BottomSheetContext.Provider;\n//# sourceMappingURL=external.js.map","import { useContext } from 'react';\nimport { BottomSheetInternalContext } from '../contexts/internal';\nexport function useBottomSheetInternal(unsafe) {\n const context = useContext(BottomSheetInternalContext);\n\n if (unsafe !== true && context === null) {\n throw \"'useBottomSheetInternal' cannot be used out of the BottomSheet!\";\n }\n\n return context;\n}\n//# sourceMappingURL=useBottomSheetInternal.js.map","import { createContext } from 'react';\nexport const BottomSheetInternalContext = /*#__PURE__*/createContext(null);\nexport const BottomSheetInternalProvider = BottomSheetInternalContext.Provider;\n//# sourceMappingURL=internal.js.map","import { useContext } from 'react';\nimport { BottomSheetModalContext } from '../contexts';\nexport const useBottomSheetModal = () => {\n const context = useContext(BottomSheetModalContext);\n\n if (context === null) {\n throw \"'BottomSheetModalContext' cannot be null!\";\n }\n\n return context;\n};\n//# sourceMappingURL=useBottomSheetModal.js.map","export { BottomSheetContext, BottomSheetProvider } from './external';\nexport { BottomSheetInternalContext, BottomSheetInternalProvider } from './internal';\nexport { BottomSheetGestureHandlersContext } from './gesture';\nexport { BottomSheetModalContext, BottomSheetModalProvider } from './modal/external';\nexport { BottomSheetModalInternalContext, BottomSheetModalInternalProvider } from './modal/internal';\n//# sourceMappingURL=index.js.map","import { createContext } from 'react';\nexport const BottomSheetGestureHandlersContext = /*#__PURE__*/createContext(null);\n//# sourceMappingURL=gesture.js.map","import { createContext } from 'react';\nexport const BottomSheetModalContext = /*#__PURE__*/createContext(null);\nexport const BottomSheetModalProvider = BottomSheetModalContext.Provider;\n//# sourceMappingURL=external.js.map","import { createContext } from 'react';\nexport const BottomSheetModalInternalContext = /*#__PURE__*/createContext(null);\nexport const BottomSheetModalInternalProvider = BottomSheetModalInternalContext.Provider;\n//# sourceMappingURL=internal.js.map","import { useContext } from 'react';\nimport { BottomSheetModalInternalContext } from '../contexts';\nexport function useBottomSheetModalInternal(unsafe) {\n const context = useContext(BottomSheetModalInternalContext);\n\n if (unsafe !== true && context === null) {\n throw \"'BottomSheetModalInternalContext' cannot be null!\";\n }\n\n return context;\n}\n//# sourceMappingURL=useBottomSheetModalInternal.js.map","import { useCallback, useRef } from 'react';\nimport { useSharedValue } from 'react-native-reanimated';\nimport { getRefNativeTag } from '../utilities/getRefNativeTag';\nimport { SCROLLABLE_STATE, SCROLLABLE_TYPE } from '../constants';\nexport const useScrollable = () => {\n // refs\n const scrollableRef = useRef(null);\n const previousScrollableRef = useRef(null); // variables\n\n const animatedScrollableType = useSharedValue(SCROLLABLE_TYPE.UNDETERMINED);\n const animatedScrollableContentOffsetY = useSharedValue(0);\n const animatedScrollableOverrideState = useSharedValue(SCROLLABLE_STATE.UNDETERMINED);\n const isScrollableRefreshable = useSharedValue(false); // callbacks\n\n const setScrollableRef = useCallback(ref => {\n var _scrollableRef$curren, _scrollableRef$curren2;\n\n // get current node handle id\n let currentRefId = (_scrollableRef$curren = (_scrollableRef$curren2 = scrollableRef.current) === null || _scrollableRef$curren2 === void 0 ? void 0 : _scrollableRef$curren2.id) !== null && _scrollableRef$curren !== void 0 ? _scrollableRef$curren : null;\n\n if (currentRefId !== ref.id) {\n if (scrollableRef.current) {\n // @ts-ignore\n previousScrollableRef.current = scrollableRef.current;\n } // @ts-ignore\n\n\n scrollableRef.current = ref;\n }\n }, []);\n const removeScrollableRef = useCallback(ref => {\n var _scrollableRef$curren3, _scrollableRef$curren4;\n\n // find node handle id\n let id;\n\n try {\n id = getRefNativeTag(ref);\n } catch {\n return;\n } // get current node handle id\n\n\n let currentRefId = (_scrollableRef$curren3 = (_scrollableRef$curren4 = scrollableRef.current) === null || _scrollableRef$curren4 === void 0 ? void 0 : _scrollableRef$curren4.id) !== null && _scrollableRef$curren3 !== void 0 ? _scrollableRef$curren3 : null;\n /**\n * @DEV\n * when the incoming node is actually the current node, we reset\n * the current scrollable ref to the previous one.\n */\n\n if (id === currentRefId) {\n // @ts-ignore\n scrollableRef.current = previousScrollableRef.current;\n }\n }, []);\n return {\n scrollableRef,\n animatedScrollableType,\n animatedScrollableContentOffsetY,\n animatedScrollableOverrideState,\n isScrollableRefreshable,\n setScrollableRef,\n removeScrollableRef\n };\n};\n//# sourceMappingURL=useScrollable.js.map","const isFunction = ref => typeof ref === 'function';\n\nconst hasNativeTag = ref => !!ref && typeof ref === 'object' && 'current' in (ref || {}) && '_nativeTag' in ((ref === null || ref === void 0 ? void 0 : ref.current) || {});\n/*\n * getRefNativeTag is an internal utility used by createBottomSheetScrollableComponent\n * to grab the native tag from the native host component. It only works when the ref\n * is pointing to a native Host component.\n *\n * Internally in the bottom-sheet library ref can be a function that returns a native tag\n * this seems to happen due to the usage of Reanimated's animated scroll components.\n *\n * This should be Fabric compatible as long as the ref is a native host component.\n * */\n\n\nexport function getRefNativeTag(ref) {\n const refType = typeof ref;\n let nativeTag;\n\n if (isFunction(ref)) {\n nativeTag = ref();\n } else if (hasNativeTag(ref)) {\n nativeTag = ref.current._nativeTag;\n }\n\n if (!nativeTag || typeof nativeTag !== 'number') {\n throw new Error(`Unexpected nativeTag: ${refType}; nativeTag=${nativeTag} \n\n\t\t\tcreateBottomSheetScrollableComponent's ScrollableComponent needs to return \n\t\t\ta reference that contains a nativeTag to a Native HostComponent.\n\n\t\t\tref=${ref}\n\t\t\t`);\n }\n\n return nativeTag;\n}\n//# sourceMappingURL=getRefNativeTag.js.map","import { Dimensions, Platform } from 'react-native';\nimport { Easing } from 'react-native-reanimated';\nconst {\n height: WINDOW_HEIGHT,\n width: WINDOW_WIDTH\n} = Dimensions.get('window');\nconst {\n height: SCREEN_HEIGHT,\n width: SCREEN_WIDTH\n} = Dimensions.get('screen');\nvar GESTURE_SOURCE;\n\n(function (GESTURE_SOURCE) {\n GESTURE_SOURCE[GESTURE_SOURCE[\"UNDETERMINED\"] = 0] = \"UNDETERMINED\";\n GESTURE_SOURCE[GESTURE_SOURCE[\"SCROLLABLE\"] = 1] = \"SCROLLABLE\";\n GESTURE_SOURCE[GESTURE_SOURCE[\"HANDLE\"] = 2] = \"HANDLE\";\n GESTURE_SOURCE[GESTURE_SOURCE[\"CONTENT\"] = 3] = \"CONTENT\";\n})(GESTURE_SOURCE || (GESTURE_SOURCE = {}));\n\nvar SHEET_STATE;\n\n(function (SHEET_STATE) {\n SHEET_STATE[SHEET_STATE[\"CLOSED\"] = 0] = \"CLOSED\";\n SHEET_STATE[SHEET_STATE[\"OPENED\"] = 1] = \"OPENED\";\n SHEET_STATE[SHEET_STATE[\"EXTENDED\"] = 2] = \"EXTENDED\";\n SHEET_STATE[SHEET_STATE[\"OVER_EXTENDED\"] = 3] = \"OVER_EXTENDED\";\n SHEET_STATE[SHEET_STATE[\"FILL_PARENT\"] = 4] = \"FILL_PARENT\";\n})(SHEET_STATE || (SHEET_STATE = {}));\n\nvar SCROLLABLE_STATE;\n\n(function (SCROLLABLE_STATE) {\n SCROLLABLE_STATE[SCROLLABLE_STATE[\"LOCKED\"] = 0] = \"LOCKED\";\n SCROLLABLE_STATE[SCROLLABLE_STATE[\"UNLOCKED\"] = 1] = \"UNLOCKED\";\n SCROLLABLE_STATE[SCROLLABLE_STATE[\"UNDETERMINED\"] = 2] = \"UNDETERMINED\";\n})(SCROLLABLE_STATE || (SCROLLABLE_STATE = {}));\n\nvar SCROLLABLE_TYPE;\n\n(function (SCROLLABLE_TYPE) {\n SCROLLABLE_TYPE[SCROLLABLE_TYPE[\"UNDETERMINED\"] = 0] = \"UNDETERMINED\";\n SCROLLABLE_TYPE[SCROLLABLE_TYPE[\"VIEW\"] = 1] = \"VIEW\";\n SCROLLABLE_TYPE[SCROLLABLE_TYPE[\"FLATLIST\"] = 2] = \"FLATLIST\";\n SCROLLABLE_TYPE[SCROLLABLE_TYPE[\"SCROLLVIEW\"] = 3] = \"SCROLLVIEW\";\n SCROLLABLE_TYPE[SCROLLABLE_TYPE[\"SECTIONLIST\"] = 4] = \"SECTIONLIST\";\n SCROLLABLE_TYPE[SCROLLABLE_TYPE[\"VIRTUALIZEDLIST\"] = 5] = \"VIRTUALIZEDLIST\";\n})(SCROLLABLE_TYPE || (SCROLLABLE_TYPE = {}));\n\nvar ANIMATION_STATE;\n\n(function (ANIMATION_STATE) {\n ANIMATION_STATE[ANIMATION_STATE[\"UNDETERMINED\"] = 0] = \"UNDETERMINED\";\n ANIMATION_STATE[ANIMATION_STATE[\"RUNNING\"] = 1] = \"RUNNING\";\n ANIMATION_STATE[ANIMATION_STATE[\"STOPPED\"] = 2] = \"STOPPED\";\n ANIMATION_STATE[ANIMATION_STATE[\"INTERRUPTED\"] = 3] = \"INTERRUPTED\";\n})(ANIMATION_STATE || (ANIMATION_STATE = {}));\n\nvar ANIMATION_SOURCE;\n\n(function (ANIMATION_SOURCE) {\n ANIMATION_SOURCE[ANIMATION_SOURCE[\"NONE\"] = 0] = \"NONE\";\n ANIMATION_SOURCE[ANIMATION_SOURCE[\"MOUNT\"] = 1] = \"MOUNT\";\n ANIMATION_SOURCE[ANIMATION_SOURCE[\"GESTURE\"] = 2] = \"GESTURE\";\n ANIMATION_SOURCE[ANIMATION_SOURCE[\"USER\"] = 3] = \"USER\";\n ANIMATION_SOURCE[ANIMATION_SOURCE[\"CONTAINER_RESIZE\"] = 4] = \"CONTAINER_RESIZE\";\n ANIMATION_SOURCE[ANIMATION_SOURCE[\"SNAP_POINT_CHANGE\"] = 5] = \"SNAP_POINT_CHANGE\";\n ANIMATION_SOURCE[ANIMATION_SOURCE[\"KEYBOARD\"] = 6] = \"KEYBOARD\";\n})(ANIMATION_SOURCE || (ANIMATION_SOURCE = {}));\n\nvar ANIMATION_METHOD;\n\n(function (ANIMATION_METHOD) {\n ANIMATION_METHOD[ANIMATION_METHOD[\"TIMING\"] = 0] = \"TIMING\";\n ANIMATION_METHOD[ANIMATION_METHOD[\"SPRING\"] = 1] = \"SPRING\";\n})(ANIMATION_METHOD || (ANIMATION_METHOD = {}));\n\nvar KEYBOARD_STATE;\n\n(function (KEYBOARD_STATE) {\n KEYBOARD_STATE[KEYBOARD_STATE[\"UNDETERMINED\"] = 0] = \"UNDETERMINED\";\n KEYBOARD_STATE[KEYBOARD_STATE[\"SHOWN\"] = 1] = \"SHOWN\";\n KEYBOARD_STATE[KEYBOARD_STATE[\"HIDDEN\"] = 2] = \"HIDDEN\";\n})(KEYBOARD_STATE || (KEYBOARD_STATE = {}));\n\nconst ANIMATION_EASING = Easing.out(Easing.exp);\nconst ANIMATION_DURATION = 250;\nconst ANIMATION_CONFIGS_IOS = {\n damping: 500,\n stiffness: 1000,\n mass: 3,\n overshootClamping: true,\n restDisplacementThreshold: 10,\n restSpeedThreshold: 10\n};\nconst ANIMATION_CONFIGS_ANDROID = {\n duration: ANIMATION_DURATION,\n easing: ANIMATION_EASING\n};\nconst ANIMATION_CONFIGS = Platform.OS === 'ios' ? ANIMATION_CONFIGS_IOS : ANIMATION_CONFIGS_ANDROID;\nconst SCROLLABLE_DECELERATION_RATE_MAPPER = {\n [SCROLLABLE_STATE.UNDETERMINED]: 0,\n [SCROLLABLE_STATE.LOCKED]: 0,\n [SCROLLABLE_STATE.UNLOCKED]: Platform.select({\n ios: 0.998,\n android: 0.985,\n default: 1\n })\n};\nconst MODAL_STACK_BEHAVIOR = {\n replace: 'replace',\n push: 'push'\n};\nconst KEYBOARD_BEHAVIOR = {\n interactive: 'interactive',\n extend: 'extend',\n fillParent: 'fillParent'\n};\nconst KEYBOARD_BLUR_BEHAVIOR = {\n none: 'none',\n restore: 'restore'\n};\nconst KEYBOARD_INPUT_MODE = {\n adjustPan: 'adjustPan',\n adjustResize: 'adjustResize'\n};\nconst KEYBOARD_DISMISS_THRESHOLD = 12.5;\nexport { GESTURE_SOURCE, SHEET_STATE, ANIMATION_STATE, ANIMATION_METHOD, ANIMATION_SOURCE, SCROLLABLE_TYPE, SCROLLABLE_STATE, KEYBOARD_STATE, WINDOW_HEIGHT, WINDOW_WIDTH, SCREEN_HEIGHT, SCREEN_WIDTH, SCROLLABLE_DECELERATION_RATE_MAPPER, MODAL_STACK_BEHAVIOR, KEYBOARD_BEHAVIOR, KEYBOARD_BLUR_BEHAVIOR, KEYBOARD_INPUT_MODE, KEYBOARD_DISMISS_THRESHOLD, ANIMATION_CONFIGS, ANIMATION_EASING, ANIMATION_DURATION };\n//# sourceMappingURL=constants.js.map","import { useCallback, useEffect } from 'react';\nimport { useBottomSheetInternal } from './useBottomSheetInternal';\nimport { getRefNativeTag } from '../utilities/getRefNativeTag';\nexport const useScrollableSetter = (ref, type, contentOffsetY, refreshable, useFocusHook = useEffect) => {\n // hooks\n const {\n animatedScrollableType,\n animatedScrollableContentOffsetY: rootScrollableContentOffsetY,\n isContentHeightFixed,\n isScrollableRefreshable,\n setScrollableRef,\n removeScrollableRef\n } = useBottomSheetInternal(); // callbacks\n\n const handleSettingScrollable = useCallback(() => {\n // set current content offset\n rootScrollableContentOffsetY.value = contentOffsetY.value;\n animatedScrollableType.value = type;\n isScrollableRefreshable.value = refreshable;\n isContentHeightFixed.value = false; // set current scrollable ref\n\n const id = getRefNativeTag(ref);\n\n if (id) {\n setScrollableRef({\n id: id,\n node: ref\n });\n } else {\n console.warn(`Couldn't find the scrollable node handle id!`);\n }\n\n return () => {\n removeScrollableRef(ref);\n };\n }, [ref, type, refreshable, animatedScrollableType, rootScrollableContentOffsetY, contentOffsetY, isScrollableRefreshable, isContentHeightFixed, setScrollableRef, removeScrollableRef]); // effects\n\n useFocusHook(handleSettingScrollable);\n};\n//# sourceMappingURL=useScrollableSetter.js.map","import { runOnJS, useAnimatedRef, useAnimatedScrollHandler, useSharedValue } from 'react-native-reanimated';\nimport { useScrollEventsHandlersDefault } from './useScrollEventsHandlersDefault';\nimport { workletNoop as noop } from '../utilities';\nexport const useScrollHandler = (useScrollEventsHandlers = useScrollEventsHandlersDefault, onScroll, onScrollBeginDrag, onScrollEndDrag) => {\n // refs\n const scrollableRef = useAnimatedRef(); // variables\n\n const scrollableContentOffsetY = useSharedValue(0); // hooks\n\n const {\n handleOnScroll = noop,\n handleOnBeginDrag = noop,\n handleOnEndDrag = noop,\n handleOnMomentumEnd = noop,\n handleOnMomentumBegin = noop\n } = useScrollEventsHandlers(scrollableRef, scrollableContentOffsetY); // callbacks\n\n const scrollHandler = useAnimatedScrollHandler({\n onScroll: (event, context) => {\n handleOnScroll(event, context);\n\n if (onScroll) {\n runOnJS(onScroll)({\n nativeEvent: event\n });\n }\n },\n onBeginDrag: (event, context) => {\n handleOnBeginDrag(event, context);\n\n if (onScrollBeginDrag) {\n runOnJS(onScrollBeginDrag)({\n nativeEvent: event\n });\n }\n },\n onEndDrag: (event, context) => {\n handleOnEndDrag(event, context);\n\n if (onScrollEndDrag) {\n runOnJS(onScrollEndDrag)({\n nativeEvent: event\n });\n }\n },\n onMomentumBegin: handleOnMomentumBegin,\n onMomentumEnd: handleOnMomentumEnd\n }, [handleOnScroll, handleOnBeginDrag, handleOnEndDrag, handleOnMomentumBegin, handleOnMomentumEnd, onScroll, onScrollBeginDrag, onScrollEndDrag]);\n return {\n scrollHandler,\n scrollableRef,\n scrollableContentOffsetY\n };\n};\n//# sourceMappingURL=useScrollHandler.js.map","import { scrollTo, useWorkletCallback } from 'react-native-reanimated';\nimport { useBottomSheetInternal } from './useBottomSheetInternal';\nimport { ANIMATION_STATE, SCROLLABLE_STATE, SHEET_STATE } from '../constants';\nexport const useScrollEventsHandlersDefault = (scrollableRef, scrollableContentOffsetY) => {\n // hooks\n const {\n animatedSheetState,\n animatedScrollableState,\n animatedAnimationState,\n animatedScrollableContentOffsetY: rootScrollableContentOffsetY\n } = useBottomSheetInternal(); //#region callbacks\n\n const handleOnScroll = useWorkletCallback((_, context) => {\n /**\n * if sheet position is extended or fill parent, then we reset\n * `shouldLockInitialPosition` value to false.\n */\n if (animatedSheetState.value === SHEET_STATE.EXTENDED || animatedSheetState.value === SHEET_STATE.FILL_PARENT) {\n context.shouldLockInitialPosition = false;\n }\n\n if (animatedScrollableState.value === SCROLLABLE_STATE.LOCKED) {\n var _context$initialConte;\n\n const lockPosition = context.shouldLockInitialPosition ? (_context$initialConte = context.initialContentOffsetY) !== null && _context$initialConte !== void 0 ? _context$initialConte : 0 : 0; // @ts-ignore\n\n scrollTo(scrollableRef, 0, lockPosition, false);\n scrollableContentOffsetY.value = lockPosition;\n return;\n }\n }, [scrollableRef, scrollableContentOffsetY, animatedScrollableState, animatedSheetState]);\n const handleOnBeginDrag = useWorkletCallback(({\n contentOffset: {\n y\n }\n }, context) => {\n scrollableContentOffsetY.value = y;\n rootScrollableContentOffsetY.value = y;\n context.initialContentOffsetY = y;\n /**\n * if sheet position not extended or fill parent and the scrollable position\n * not at the top, then we should lock the initial scrollable position.\n */\n\n if (animatedSheetState.value !== SHEET_STATE.EXTENDED && animatedSheetState.value !== SHEET_STATE.FILL_PARENT && y > 0) {\n context.shouldLockInitialPosition = true;\n } else {\n context.shouldLockInitialPosition = false;\n }\n }, [scrollableContentOffsetY, animatedSheetState, rootScrollableContentOffsetY]);\n const handleOnEndDrag = useWorkletCallback(({\n contentOffset: {\n y\n }\n }, context) => {\n if (animatedScrollableState.value === SCROLLABLE_STATE.LOCKED) {\n var _context$initialConte2;\n\n const lockPosition = context.shouldLockInitialPosition ? (_context$initialConte2 = context.initialContentOffsetY) !== null && _context$initialConte2 !== void 0 ? _context$initialConte2 : 0 : 0; // @ts-ignore\n\n scrollTo(scrollableRef, 0, lockPosition, false);\n scrollableContentOffsetY.value = lockPosition;\n return;\n }\n\n if (animatedAnimationState.value !== ANIMATION_STATE.RUNNING) {\n scrollableContentOffsetY.value = y;\n rootScrollableContentOffsetY.value = y;\n }\n }, [scrollableRef, scrollableContentOffsetY, animatedAnimationState, animatedScrollableState, rootScrollableContentOffsetY]);\n const handleOnMomentumEnd = useWorkletCallback(({\n contentOffset: {\n y\n }\n }, context) => {\n if (animatedScrollableState.value === SCROLLABLE_STATE.LOCKED) {\n var _context$initialConte3;\n\n const lockPosition = context.shouldLockInitialPosition ? (_context$initialConte3 = context.initialContentOffsetY) !== null && _context$initialConte3 !== void 0 ? _context$initialConte3 : 0 : 0; // @ts-ignore\n\n scrollTo(scrollableRef, 0, lockPosition, false);\n scrollableContentOffsetY.value = 0;\n return;\n }\n\n if (animatedAnimationState.value !== ANIMATION_STATE.RUNNING) {\n scrollableContentOffsetY.value = y;\n rootScrollableContentOffsetY.value = y;\n }\n }, [scrollableContentOffsetY, scrollableRef, animatedAnimationState, animatedScrollableState, rootScrollableContentOffsetY]); //#endregion\n\n return {\n handleOnScroll,\n handleOnBeginDrag,\n handleOnEndDrag,\n handleOnMomentumEnd\n };\n};\n//# sourceMappingURL=useScrollEventsHandlersDefault.js.map","export { normalizeSnapPoint } from './normalizeSnapPoint';\nexport { animate } from './animate';\nexport { getKeyboardAnimationConfigs } from './getKeyboardAnimationConfigs';\nexport { print } from './logger';\nexport { noop, workletNoop } from './noop';\n//# sourceMappingURL=index.js.map","/**\n * Converts a snap point to fixed numbers.\n */\nexport const normalizeSnapPoint = (snapPoint, containerHeight) => {\n 'worklet';\n\n let normalizedSnapPoint = snapPoint; // percentage snap point\n\n if (typeof normalizedSnapPoint === 'string') {\n normalizedSnapPoint = Number(normalizedSnapPoint.split('%')[0]) * containerHeight / 100;\n }\n\n return Math.max(0, containerHeight - normalizedSnapPoint);\n};\n//# sourceMappingURL=normalizeSnapPoint.js.map","import { withTiming, withSpring } from 'react-native-reanimated';\nimport { ANIMATION_CONFIGS, ANIMATION_METHOD } from '../constants';\nexport const animate = ({\n point,\n configs = undefined,\n velocity = 0,\n onComplete\n}) => {\n 'worklet';\n\n if (!configs) {\n configs = ANIMATION_CONFIGS;\n } // detect animation type\n\n\n const type = 'duration' in configs || 'easing' in configs ? ANIMATION_METHOD.TIMING : ANIMATION_METHOD.SPRING;\n\n if (type === ANIMATION_METHOD.TIMING) {\n return withTiming(point, configs, onComplete);\n } else {\n return withSpring(point, Object.assign({\n velocity\n }, configs), onComplete);\n }\n};\n//# sourceMappingURL=animate.js.map","import { Easing } from 'react-native-reanimated';\nexport const getKeyboardAnimationConfigs = (easing, duration) => {\n 'worklet';\n\n switch (easing) {\n case 'easeIn':\n return {\n easing: Easing.in(Easing.ease),\n duration\n };\n\n case 'easeOut':\n return {\n easing: Easing.out(Easing.ease),\n duration\n };\n\n case 'easeInEaseOut':\n return {\n easing: Easing.inOut(Easing.ease),\n duration\n };\n\n case 'linear':\n return {\n easing: Easing.linear,\n duration\n };\n\n case 'keyboard':\n return {\n damping: 500,\n stiffness: 1000,\n mass: 3,\n overshootClamping: true,\n restDisplacementThreshold: 10,\n restSpeedThreshold: 10\n };\n }\n};\n//# sourceMappingURL=getKeyboardAnimationConfigs.js.map","let isLoggingEnabled = false;\n\nconst enableLogging = () => {\n if (!__DEV__) {\n console.warn('[BottomSheet] could not enable logging on production!');\n return;\n }\n\n isLoggingEnabled = true;\n};\n\nlet print = () => {};\n\nif (__DEV__) {\n print = ({\n component,\n method,\n params\n }) => {\n if (!isLoggingEnabled) {\n return;\n }\n\n let message = '';\n\n if (typeof params === 'object') {\n message = Object.keys(params).map(key => `${key}:${params[key]}`).join(' ');\n } else {\n message = `${params !== null && params !== void 0 ? params : ''}`;\n } // eslint-disable-next-line no-console\n\n\n console.log(`[${[component, method].filter(Boolean).join('::')}]`, message);\n };\n}\n\nObject.freeze(print);\nexport { print, enableLogging };\n//# sourceMappingURL=logger.js.map","const workletNoop = () => {\n 'worklet';\n};\n\nconst noop = () => {};\n\nexport { noop, workletNoop };\n//# sourceMappingURL=noop.js.map","import { useAnimatedGestureHandler } from 'react-native-reanimated';\nimport { State } from 'react-native-gesture-handler';\nimport { GESTURE_SOURCE } from '../constants';\n\nconst resetContext = context => {\n 'worklet';\n\n Object.keys(context).map(key => {\n context[key] = undefined;\n });\n};\n\nexport const useGestureHandler = (type, state, gestureSource, handleOnStart, handleOnActive, handleOnEnd) => {\n const gestureHandler = useAnimatedGestureHandler({\n onActive: (payload, context) => {\n if (!context.didStart) {\n context.didStart = true;\n state.value = State.BEGAN;\n gestureSource.value = type;\n handleOnStart(type, payload, context);\n return;\n }\n\n if (gestureSource.value !== type) {\n return;\n }\n\n state.value = payload.state;\n handleOnActive(type, payload, context);\n },\n onEnd: (payload, context) => {\n if (gestureSource.value !== type) {\n return;\n }\n\n state.value = payload.state;\n gestureSource.value = GESTURE_SOURCE.UNDETERMINED;\n handleOnEnd(type, payload, context);\n resetContext(context);\n },\n onCancel: (payload, context) => {\n if (gestureSource.value !== type) {\n return;\n }\n\n state.value = payload.state;\n gestureSource.value = GESTURE_SOURCE.UNDETERMINED;\n resetContext(context);\n },\n onFail: (payload, context) => {\n if (gestureSource.value !== type) {\n return;\n }\n\n state.value = payload.state;\n gestureSource.value = GESTURE_SOURCE.UNDETERMINED;\n resetContext(context);\n },\n onFinish: (payload, context) => {\n if (gestureSource.value !== type) {\n return;\n }\n\n state.value = payload.state;\n gestureSource.value = GESTURE_SOURCE.UNDETERMINED;\n resetContext(context);\n }\n }, [type, state, handleOnStart, handleOnActive, handleOnEnd]);\n return gestureHandler;\n};\n//# sourceMappingURL=useGestureHandler.js.map","import { Keyboard, Platform } from 'react-native';\nimport { runOnJS, useWorkletCallback } from 'react-native-reanimated';\nimport { useBottomSheetInternal } from './useBottomSheetInternal';\nimport { ANIMATION_SOURCE, GESTURE_SOURCE, KEYBOARD_STATE, SCROLLABLE_TYPE, WINDOW_HEIGHT } from '../constants';\nimport { clamp } from '../utilities/clamp';\nimport { snapPoint } from '../utilities/snapPoint';\nconst dismissKeyboard = Keyboard.dismiss;\nexport const useGestureEventsHandlersDefault = () => {\n //#region variables\n const {\n animatedPosition,\n animatedSnapPoints,\n animatedKeyboardState,\n animatedKeyboardHeight,\n animatedContainerHeight,\n animatedScrollableType,\n animatedHighestSnapPoint,\n animatedClosedPosition,\n animatedScrollableContentOffsetY,\n enableOverDrag,\n enablePanDownToClose,\n overDragResistanceFactor,\n isInTemporaryPosition,\n isScrollableRefreshable,\n animateToPosition,\n stopAnimation\n } = useBottomSheetInternal(); //#endregion\n //#region gesture methods\n\n const handleOnStart = useWorkletCallback(function handleOnStart(__, _, context) {\n // cancel current animation\n stopAnimation(); // store current animated position\n\n context.initialPosition = animatedPosition.value;\n context.initialKeyboardState = animatedKeyboardState.value;\n /**\n * if the scrollable content is scrolled, then\n * we lock the position.\n */\n\n if (animatedScrollableContentOffsetY.value > 0) {\n context.isScrollablePositionLocked = true;\n }\n }, [stopAnimation, animatedPosition, animatedKeyboardState, animatedScrollableContentOffsetY]);\n const handleOnActive = useWorkletCallback(function handleOnActive(source, {\n translationY\n }, context) {\n let highestSnapPoint = animatedHighestSnapPoint.value;\n /**\n * if keyboard is shown, then we set the highest point to the current\n * position which includes the keyboard height.\n */\n\n if (isInTemporaryPosition.value && context.initialKeyboardState === KEYBOARD_STATE.SHOWN) {\n highestSnapPoint = context.initialPosition;\n }\n /**\n * if current position is out of provided `snapPoints` and smaller then\n * highest snap pont, then we set the highest point to the current position.\n */\n\n\n if (isInTemporaryPosition.value && context.initialPosition < highestSnapPoint) {\n highestSnapPoint = context.initialPosition;\n }\n\n const lowestSnapPoint = enablePanDownToClose ? animatedContainerHeight.value : animatedSnapPoints.value[0];\n /**\n * if scrollable is refreshable and sheet position at the highest\n * point, then do not interact with current gesture.\n */\n\n if (source === GESTURE_SOURCE.SCROLLABLE && isScrollableRefreshable.value && animatedPosition.value === highestSnapPoint) {\n return;\n }\n /**\n * a negative scrollable content offset to be subtracted from accumulated\n * current position and gesture translation Y to allow user to drag the sheet,\n * when scrollable position at the top.\n * a negative scrollable content offset when the scrollable is not locked.\n */\n\n\n const negativeScrollableContentOffset = context.initialPosition === highestSnapPoint && source === GESTURE_SOURCE.SCROLLABLE || !context.isScrollablePositionLocked ? animatedScrollableContentOffsetY.value * -1 : 0;\n /**\n * an accumulated value of starting position with gesture translation y.\n */\n\n const draggedPosition = context.initialPosition + translationY;\n /**\n * an accumulated value of dragged position and negative scrollable content offset,\n * this will insure locking sheet position when user is scrolling the scrollable until,\n * they reach to the top of the scrollable.\n */\n\n const accumulatedDraggedPosition = draggedPosition + negativeScrollableContentOffset;\n /**\n * a clamped value of the accumulated dragged position, to insure keeping the dragged\n * position between the highest and lowest snap points.\n */\n\n const clampedPosition = clamp(accumulatedDraggedPosition, highestSnapPoint, lowestSnapPoint);\n /**\n * if scrollable position is locked and the animated position\n * reaches the highest point, then we unlock the scrollable position.\n */\n\n if (context.isScrollablePositionLocked && source === GESTURE_SOURCE.SCROLLABLE && animatedPosition.value === highestSnapPoint) {\n context.isScrollablePositionLocked = false;\n }\n /**\n * over-drag implementation.\n */\n\n\n if (enableOverDrag) {\n if ((source === GESTURE_SOURCE.HANDLE || animatedScrollableType.value === SCROLLABLE_TYPE.VIEW) && draggedPosition < highestSnapPoint) {\n const resistedPosition = highestSnapPoint - Math.sqrt(1 + (highestSnapPoint - draggedPosition)) * overDragResistanceFactor;\n animatedPosition.value = resistedPosition;\n return;\n }\n\n if (source === GESTURE_SOURCE.HANDLE && draggedPosition > lowestSnapPoint) {\n const resistedPosition = lowestSnapPoint + Math.sqrt(1 + (draggedPosition - lowestSnapPoint)) * overDragResistanceFactor;\n animatedPosition.value = resistedPosition;\n return;\n }\n\n if (source === GESTURE_SOURCE.SCROLLABLE && draggedPosition + negativeScrollableContentOffset > lowestSnapPoint) {\n const resistedPosition = lowestSnapPoint + Math.sqrt(1 + (draggedPosition + negativeScrollableContentOffset - lowestSnapPoint)) * overDragResistanceFactor;\n animatedPosition.value = resistedPosition;\n return;\n }\n }\n\n animatedPosition.value = clampedPosition;\n }, [enableOverDrag, enablePanDownToClose, overDragResistanceFactor, isInTemporaryPosition, isScrollableRefreshable, animatedHighestSnapPoint, animatedContainerHeight, animatedSnapPoints, animatedPosition, animatedScrollableType, animatedScrollableContentOffsetY]);\n const handleOnEnd = useWorkletCallback(function handleOnEnd(source, {\n translationY,\n absoluteY,\n velocityY\n }, context) {\n const highestSnapPoint = animatedHighestSnapPoint.value;\n const isSheetAtHighestSnapPoint = animatedPosition.value === highestSnapPoint;\n /**\n * if scrollable is refreshable and sheet position at the highest\n * point, then do not interact with current gesture.\n */\n\n if (source === GESTURE_SOURCE.SCROLLABLE && isScrollableRefreshable.value && isSheetAtHighestSnapPoint) {\n return;\n }\n /**\n * if the sheet is in a temporary position and the gesture ended above\n * the current position, then we snap back to the temporary position.\n */\n\n\n if (isInTemporaryPosition.value && context.initialPosition >= animatedPosition.value) {\n if (context.initialPosition > animatedPosition.value) {\n animateToPosition(context.initialPosition, ANIMATION_SOURCE.GESTURE, velocityY / 2);\n }\n\n return;\n }\n /**\n * close keyboard if current position is below the recorded\n * start position and keyboard still shown.\n */\n\n\n const isScrollable = animatedScrollableType.value !== SCROLLABLE_TYPE.UNDETERMINED && animatedScrollableType.value !== SCROLLABLE_TYPE.VIEW;\n /**\n * if keyboard is shown and the sheet is dragged down,\n * then we dismiss the keyboard.\n */\n\n if (context.initialKeyboardState === KEYBOARD_STATE.SHOWN && animatedPosition.value > context.initialPosition) {\n /**\n * if the platform is ios, current content is scrollable and\n * the end touch point is below the keyboard position then\n * we exit the method.\n *\n * because the the keyboard dismiss is interactive in iOS.\n */\n if (!(Platform.OS === 'ios' && isScrollable && absoluteY > WINDOW_HEIGHT - animatedKeyboardHeight.value)) {\n runOnJS(dismissKeyboard)();\n }\n }\n /**\n * reset isInTemporaryPosition value\n */\n\n\n if (isInTemporaryPosition.value) {\n isInTemporaryPosition.value = false;\n }\n /**\n * clone snap points array, and insert the container height\n * if pan down to close is enabled.\n */\n\n\n const snapPoints = animatedSnapPoints.value.slice();\n\n if (enablePanDownToClose) {\n snapPoints.unshift(animatedClosedPosition.value);\n }\n /**\n * calculate the destination point, using redash.\n */\n\n\n const destinationPoint = snapPoint(translationY + context.initialPosition, velocityY, snapPoints);\n /**\n * if destination point is the same as the current position,\n * then no need to perform animation.\n */\n\n if (destinationPoint === animatedPosition.value) {\n return;\n }\n\n const wasGestureHandledByScrollView = source === GESTURE_SOURCE.SCROLLABLE && animatedScrollableContentOffsetY.value > 0;\n /**\n * prevents snapping from top to middle / bottom with repeated interrupted scrolls\n */\n\n if (wasGestureHandledByScrollView && isSheetAtHighestSnapPoint) {\n return;\n }\n\n animateToPosition(destinationPoint, ANIMATION_SOURCE.GESTURE, velocityY / 2);\n }, [enablePanDownToClose, isInTemporaryPosition, isScrollableRefreshable, animatedClosedPosition, animatedHighestSnapPoint, animatedKeyboardHeight, animatedPosition, animatedScrollableType, animatedSnapPoints, animatedScrollableContentOffsetY, animateToPosition]); //#endregion\n\n return {\n handleOnStart,\n handleOnActive,\n handleOnEnd\n };\n};\n//# sourceMappingURL=useGestureEventsHandlersDefault.js.map","export const clamp = (value, lowerBound, upperBound) => {\n 'worklet';\n\n return Math.min(Math.max(lowerBound, value), upperBound);\n};\n//# sourceMappingURL=clamp.js.map","export const snapPoint = (value, velocity, points) => {\n 'worklet';\n\n const point = value + 0.2 * velocity;\n const deltas = points.map(p => Math.abs(point - p));\n const minDelta = Math.min.apply(null, deltas);\n return points.filter(p => Math.abs(point - p) === minDelta)[0];\n};\n//# sourceMappingURL=snapPoint.js.map","import { useEffect } from 'react';\nimport { Keyboard, Platform } from 'react-native';\nimport { runOnUI, useAnimatedReaction, useSharedValue, useWorkletCallback } from 'react-native-reanimated';\nimport { KEYBOARD_STATE } from '../constants';\nconst KEYBOARD_EVENT_MAPPER = {\n KEYBOARD_SHOW: Platform.select({\n ios: 'keyboardWillShow',\n android: 'keyboardDidShow',\n default: ''\n }),\n KEYBOARD_HIDE: Platform.select({\n ios: 'keyboardWillHide',\n android: 'keyboardDidHide',\n default: ''\n })\n};\nexport const useKeyboard = () => {\n //#region variables\n const shouldHandleKeyboardEvents = useSharedValue(false);\n const keyboardState = useSharedValue(KEYBOARD_STATE.UNDETERMINED);\n const keyboardHeight = useSharedValue(0);\n const keyboardAnimationEasing = useSharedValue('keyboard');\n const keyboardAnimationDuration = useSharedValue(500);\n const temporaryCachedKeyboardEvent = useSharedValue([]); //#endregion\n //#region worklets\n\n const handleKeyboardEvent = useWorkletCallback((state, height, duration, easing) => {\n if (state === KEYBOARD_STATE.SHOWN && !shouldHandleKeyboardEvents.value) {\n /**\n * if the keyboard event was fired before the `onFocus` on TextInput,\n * then we cache the input, and wait till the `shouldHandleKeyboardEvents`\n * to be updated then fire this function again.\n */\n temporaryCachedKeyboardEvent.value = [state, height, duration, easing];\n return;\n }\n\n keyboardHeight.value = state === KEYBOARD_STATE.SHOWN ? height : height === 0 ? keyboardHeight.value : height;\n keyboardAnimationDuration.value = duration;\n keyboardAnimationEasing.value = easing;\n keyboardState.value = state;\n temporaryCachedKeyboardEvent.value = [];\n }, []); //#endregion\n //#region effects\n\n useEffect(() => {\n const handleOnKeyboardShow = event => {\n runOnUI(handleKeyboardEvent)(KEYBOARD_STATE.SHOWN, event.endCoordinates.height, event.duration, event.easing);\n };\n\n const handleOnKeyboardHide = event => {\n runOnUI(handleKeyboardEvent)(KEYBOARD_STATE.HIDDEN, event.endCoordinates.height, event.duration, event.easing);\n };\n\n const showSubscription = Keyboard.addListener(KEYBOARD_EVENT_MAPPER.KEYBOARD_SHOW, handleOnKeyboardShow);\n const hideSubscription = Keyboard.addListener(KEYBOARD_EVENT_MAPPER.KEYBOARD_HIDE, handleOnKeyboardHide);\n return () => {\n showSubscription.remove();\n hideSubscription.remove();\n };\n }, [handleKeyboardEvent]);\n /**\n * This reaction is needed to handle the issue with multiline text input.\n *\n * @link https://github.com/gorhom/react-native-bottom-sheet/issues/411\n */\n\n useAnimatedReaction(() => shouldHandleKeyboardEvents.value, result => {\n const params = temporaryCachedKeyboardEvent.value;\n\n if (result && params.length > 0) {\n handleKeyboardEvent(params[0], params[1], params[2], params[3]);\n }\n }); //#endregion\n\n return {\n state: keyboardState,\n height: keyboardHeight,\n animationEasing: keyboardAnimationEasing,\n animationDuration: keyboardAnimationDuration,\n shouldHandleKeyboardEvents\n };\n};\n//# sourceMappingURL=useKeyboard.js.map","import { useRef, useCallback, useEffect } from 'react';\n\n/**\n * Provide a stable version of useCallback\n * https://gist.github.com/JakeCoxon/c7ebf6e6496f8468226fd36b596e1985\n */\nexport const useStableCallback = callback => {\n const callbackRef = useRef();\n const memoCallback = useCallback((...args) => callbackRef.current && callbackRef.current(...args), []);\n useEffect(() => {\n callbackRef.current = callback;\n return () => callbackRef.current = undefined;\n });\n return memoCallback;\n};\n//# sourceMappingURL=useStableCallback.js.map","import { useMemo } from 'react';\nimport invariant from 'invariant';\nimport { INITIAL_SNAP_POINT } from '../components/bottomSheet/constants';\n\n/**\n * @todo\n * replace this with `prop-types`.\n */\nexport const usePropsValidator = ({\n index,\n snapPoints,\n enableDynamicSizing,\n topInset,\n bottomInset\n}) => {\n useMemo(() => {\n //#region snap points\n const _snapPoints = snapPoints ? 'value' in snapPoints ? snapPoints.value : snapPoints : [];\n\n invariant(_snapPoints || enableDynamicSizing, `'snapPoints' was not provided! please provide at least one snap point.`);\n\n _snapPoints.map(snapPoint => {\n const _snapPoint = typeof snapPoint === 'number' ? snapPoint : parseInt(snapPoint.replace('%', ''), 10);\n\n invariant(_snapPoint > 0 || _snapPoint === INITIAL_SNAP_POINT, `Snap point '${snapPoint}' is invalid. if you want to allow user to close the sheet, Please use 'enablePanDownToClose' prop.`);\n });\n\n invariant('value' in _snapPoints || _snapPoints.length > 0 || enableDynamicSizing, `'snapPoints' was provided with no points! please provide at least one snap point.`); //#endregion\n //#region index\n\n invariant(typeof index === 'number' || typeof index === 'undefined', `'index' was provided but with wrong type ! expected type is a number.`);\n invariant(enableDynamicSizing || (typeof index === 'number' ? index >= -1 && index <= _snapPoints.length - 1 : true), `'index' was provided but out of the provided snap points range! expected value to be between -1, ${_snapPoints.length - 1}`); //#endregion\n //#region insets\n\n invariant(typeof topInset === 'number' || typeof topInset === 'undefined', `'topInset' was provided but with wrong type ! expected type is a number.`);\n invariant(typeof bottomInset === 'number' || typeof bottomInset === 'undefined', `'bottomInset' was provided but with wrong type ! expected type is a number.`); //#endregion\n // animations\n }, [index, snapPoints, topInset, bottomInset, enableDynamicSizing]);\n};\n//# sourceMappingURL=usePropsValidator.js.map","import { KEYBOARD_BEHAVIOR, KEYBOARD_BLUR_BEHAVIOR, KEYBOARD_INPUT_MODE, SCREEN_HEIGHT } from '../../constants'; // default values\n\nconst DEFAULT_HANDLE_HEIGHT = 24;\nconst DEFAULT_OVER_DRAG_RESISTANCE_FACTOR = 2.5;\nconst DEFAULT_ENABLE_CONTENT_PANNING_GESTURE = true;\nconst DEFAULT_ENABLE_HANDLE_PANNING_GESTURE = true;\nconst DEFAULT_ENABLE_OVER_DRAG = true;\nconst DEFAULT_ENABLE_PAN_DOWN_TO_CLOSE = false;\nconst DEFAULT_ANIMATE_ON_MOUNT = true;\nconst DEFAULT_DYNAMIC_SIZING = false; // keyboard\n\nconst DEFAULT_KEYBOARD_BEHAVIOR = KEYBOARD_BEHAVIOR.interactive;\nconst DEFAULT_KEYBOARD_BLUR_BEHAVIOR = KEYBOARD_BLUR_BEHAVIOR.none;\nconst DEFAULT_KEYBOARD_INPUT_MODE = KEYBOARD_INPUT_MODE.adjustPan; // initial values\n\nconst INITIAL_VALUE = Number.NEGATIVE_INFINITY;\nconst INITIAL_SNAP_POINT = -999;\nconst INITIAL_CONTAINER_HEIGHT = -999;\nconst INITIAL_CONTAINER_OFFSET = {\n top: 0,\n bottom: 0,\n left: 0,\n right: 0\n};\nconst INITIAL_HANDLE_HEIGHT = -999;\nconst INITIAL_POSITION = SCREEN_HEIGHT;\nexport { DEFAULT_HANDLE_HEIGHT, DEFAULT_OVER_DRAG_RESISTANCE_FACTOR, DEFAULT_ENABLE_CONTENT_PANNING_GESTURE, DEFAULT_ENABLE_HANDLE_PANNING_GESTURE, DEFAULT_ENABLE_OVER_DRAG, DEFAULT_ENABLE_PAN_DOWN_TO_CLOSE, DEFAULT_DYNAMIC_SIZING, DEFAULT_ANIMATE_ON_MOUNT, // keyboard\nDEFAULT_KEYBOARD_BEHAVIOR, DEFAULT_KEYBOARD_BLUR_BEHAVIOR, DEFAULT_KEYBOARD_INPUT_MODE, // layout\nINITIAL_POSITION, INITIAL_CONTAINER_HEIGHT, INITIAL_CONTAINER_OFFSET, INITIAL_HANDLE_HEIGHT, INITIAL_SNAP_POINT, INITIAL_VALUE };\n//# sourceMappingURL=constants.js.map","import { useDerivedValue } from 'react-native-reanimated';\nimport { normalizeSnapPoint } from '../utilities';\nimport { INITIAL_CONTAINER_HEIGHT, INITIAL_HANDLE_HEIGHT, INITIAL_SNAP_POINT } from '../components/bottomSheet/constants';\n/**\n * Convert percentage snap points to pixels in screen and calculate\n * the accurate snap points positions.\n * @param snapPoints provided snap points.\n * @param containerHeight BottomSheetContainer height.\n * @param contentHeight content size.\n * @param handleHeight handle size.\n * @param enableDynamicSizing\n * @param maxDynamicContentSize\n * @returns {Animated.SharedValue}\n */\n\nexport const useNormalizedSnapPoints = (snapPoints, containerHeight, contentHeight, handleHeight, enableDynamicSizing, maxDynamicContentSize) => {\n const normalizedSnapPoints = useDerivedValue(() => {\n // early exit, if container layout is not ready\n const isContainerLayoutReady = containerHeight.value !== INITIAL_CONTAINER_HEIGHT;\n\n if (!isContainerLayoutReady) {\n return [INITIAL_SNAP_POINT];\n }\n\n const _snapPoints = snapPoints ? 'value' in snapPoints ? snapPoints.value : snapPoints : [];\n\n let _normalizedSnapPoints = _snapPoints.map(snapPoint => normalizeSnapPoint(snapPoint, containerHeight.value));\n\n if (enableDynamicSizing) {\n if (handleHeight.value === INITIAL_HANDLE_HEIGHT) {\n return [INITIAL_SNAP_POINT];\n }\n\n if (contentHeight.value === INITIAL_CONTAINER_HEIGHT) {\n return [INITIAL_SNAP_POINT];\n }\n\n _normalizedSnapPoints.push(containerHeight.value - Math.min(contentHeight.value + handleHeight.value, maxDynamicContentSize !== undefined ? maxDynamicContentSize : containerHeight.value));\n\n _normalizedSnapPoints = _normalizedSnapPoints.sort((a, b) => b - a);\n }\n\n return _normalizedSnapPoints;\n }, [snapPoints, enableDynamicSizing, maxDynamicContentSize]);\n return normalizedSnapPoints;\n};\n//# sourceMappingURL=useNormalizedSnapPoints.js.map","import { useEffect, useRef } from 'react';\nimport { cancelAnimation, makeMutable } from 'react-native-reanimated';\nexport const useReactiveSharedValue = value => {\n var _valueRef$current;\n\n const initialValueRef = useRef(null);\n const valueRef = useRef(null);\n\n if (value && typeof value === 'object' && 'value' in value) {\n /**\n * if provided value is a shared value,\n * then we do not initialize another one.\n */\n } else if (valueRef.current === null) {\n // @ts-ignore\n initialValueRef.current = value;\n /**\n * if value is an object, then we need to\n * pass a clone.\n */\n\n if (typeof value === 'object') {\n // @ts-ignore\n valueRef.current = makeMutable({ ...value\n });\n } else {\n // @ts-ignore\n valueRef.current = makeMutable(value);\n }\n } else if (initialValueRef.current !== value) {\n valueRef.current.value = value;\n }\n\n useEffect(() => {\n return () => {\n if (valueRef.current) {\n cancelAnimation(valueRef.current);\n }\n };\n }, []); // @ts-ignore\n\n return (_valueRef$current = valueRef.current) !== null && _valueRef$current !== void 0 ? _valueRef$current : value;\n};\n//# sourceMappingURL=useReactiveSharedValue.js.map","import { useCallback, useEffect } from 'react';\nimport { useDerivedValue, useSharedValue } from 'react-native-reanimated';\nimport { INITIAL_HANDLE_HEIGHT, INITIAL_SNAP_POINT } from '../components/bottomSheet/constants';\n/**\n * Provides dynamic content height calculating functionalities, by\n * replacing the placeholder `CONTENT_HEIGHT` with calculated layout.\n * @example\n * [0, 'CONTENT_HEIGHT', '100%']\n * @param initialSnapPoints your snap point with content height placeholder.\n * @returns {\n * - animatedSnapPoints: an animated snap points to be set on `BottomSheet` or `BottomSheetModal`.\n * - animatedHandleHeight: an animated handle height callback node to be set on `BottomSheet` or `BottomSheetModal`.\n * - animatedContentHeight: an animated content height callback node to be set on `BottomSheet` or `BottomSheetModal`.\n * - handleContentLayout: a `onLayout` callback method to be set on `BottomSheetView` component.\n * }\n * @deprecated will be deprecated in the next major release! please use the new introduce prop `enableDynamicSizing`.\n */\n\nexport const useBottomSheetDynamicSnapPoints = initialSnapPoints => {\n // variables\n const animatedContentHeight = useSharedValue(0);\n const animatedHandleHeight = useSharedValue(INITIAL_HANDLE_HEIGHT);\n const animatedSnapPoints = useDerivedValue(() => {\n if (animatedHandleHeight.value === INITIAL_HANDLE_HEIGHT || animatedContentHeight.value === 0) {\n return initialSnapPoints.map(() => INITIAL_SNAP_POINT);\n }\n\n const contentWithHandleHeight = animatedContentHeight.value + animatedHandleHeight.value;\n return initialSnapPoints.map(snapPoint => snapPoint === 'CONTENT_HEIGHT' ? contentWithHandleHeight : snapPoint);\n }, []);\n // callbacks\n const handleContentLayout = useCallback(({\n nativeEvent: {\n layout: {\n height\n }\n }\n }) => {\n animatedContentHeight.value = height;\n }, [animatedContentHeight]); //#region effects\n\n useEffect(() => {\n console.warn('`useBottomSheetDynamicSnapPoints` will be deprecated in the next major release! please use the new introduce prop `enableDynamicSizing`.');\n }, []); //#endregion\n\n return {\n animatedSnapPoints,\n animatedHandleHeight,\n animatedContentHeight,\n handleContentLayout\n };\n};\n//# sourceMappingURL=useBottomSheetDynamicSnapPoints.js.map","import { useContext } from 'react';\nimport { BottomSheetGestureHandlersContext } from '../contexts/gesture';\nexport const useBottomSheetGestureHandlers = () => {\n const context = useContext(BottomSheetGestureHandlersContext);\n\n if (context === null) {\n throw \"'useBottomSheetGestureHandlers' cannot be used out of the BottomSheet!\";\n }\n\n return context;\n};\n//# sourceMappingURL=useBottomSheetGestureHandlers.js.map","export { default } from './BottomSheetContainer';\n//# sourceMappingURL=index.js.map","import React, { memo, useCallback, useMemo, useRef } from 'react';\nimport { StatusBar, View } from 'react-native';\nimport { WINDOW_HEIGHT } from '../../constants';\nimport { print } from '../../utilities';\nimport { styles } from './styles';\n\nfunction BottomSheetContainerComponent({\n containerHeight,\n containerOffset,\n topInset = 0,\n bottomInset = 0,\n shouldCalculateHeight = true,\n detached,\n style,\n children\n}) {\n const containerRef = useRef(null); //#region styles\n\n const containerStyle = useMemo(() => [style, styles.container, {\n top: topInset,\n bottom: bottomInset,\n overflow: detached ? 'visible' : 'hidden'\n }], [style, detached, topInset, bottomInset]); //#endregion\n //#region callbacks\n\n const handleContainerLayout = useCallback(function handleContainerLayout({\n nativeEvent: {\n layout: {\n height\n }\n }\n }) {\n var _containerRef$current;\n\n containerHeight.value = height;\n (_containerRef$current = containerRef.current) === null || _containerRef$current === void 0 ? void 0 : _containerRef$current.measure((_x, _y, _width, _height, _pageX, pageY) => {\n var _StatusBar$currentHei;\n\n containerOffset.value = {\n top: pageY !== null && pageY !== void 0 ? pageY : 0,\n left: 0,\n right: 0,\n bottom: Math.max(0, WINDOW_HEIGHT - ((pageY !== null && pageY !== void 0 ? pageY : 0) + height + ((_StatusBar$currentHei = StatusBar.currentHeight) !== null && _StatusBar$currentHei !== void 0 ? _StatusBar$currentHei : 0)))\n };\n });\n print({\n component: BottomSheetContainer.displayName,\n method: 'handleContainerLayout',\n params: {\n height\n }\n });\n }, [containerHeight, containerOffset, containerRef]); //#endregion\n //#region render\n\n return /*#__PURE__*/React.createElement(View, {\n ref: containerRef,\n pointerEvents: \"box-none\",\n onLayout: shouldCalculateHeight ? handleContainerLayout : undefined,\n style: containerStyle,\n children: children\n }); //#endregion\n}\n\nconst BottomSheetContainer = /*#__PURE__*/memo(BottomSheetContainerComponent);\nBottomSheetContainer.displayName = 'BottomSheetContainer';\nexport default BottomSheetContainer;\n//# sourceMappingURL=BottomSheetContainer.js.map","import { StyleSheet } from 'react-native';\nexport const styles = StyleSheet.create({\n container: {\n // @ts-ignore\n position: 'fixed',\n left: 0,\n right: 0,\n bottom: 0,\n top: 0\n }\n});\n//# sourceMappingURL=styles.web.js.map","export { default } from './BottomSheetGestureHandlersProvider';\n//# sourceMappingURL=index.js.map","import React, { useMemo } from 'react';\nimport { GESTURE_SOURCE } from '../../constants';\nimport { useGestureHandler, useBottomSheetInternal, useGestureEventsHandlersDefault } from '../../hooks';\nimport { BottomSheetGestureHandlersContext } from '../../contexts';\nimport { useSharedValue } from 'react-native-reanimated';\n\nconst BottomSheetGestureHandlersProvider = ({\n gestureEventsHandlersHook: useGestureEventsHandlers = useGestureEventsHandlersDefault,\n children\n}) => {\n //#region variables\n const animatedGestureSource = useSharedValue(GESTURE_SOURCE.UNDETERMINED); //#endregion\n //#region hooks\n\n const {\n animatedContentGestureState,\n animatedHandleGestureState\n } = useBottomSheetInternal();\n const {\n handleOnStart,\n handleOnActive,\n handleOnEnd\n } = useGestureEventsHandlers(); //#endregion\n //#region gestures\n\n const contentPanGestureHandler = useGestureHandler(GESTURE_SOURCE.CONTENT, animatedContentGestureState, animatedGestureSource, handleOnStart, handleOnActive, handleOnEnd);\n const scrollablePanGestureHandler = useGestureHandler(GESTURE_SOURCE.SCROLLABLE, animatedContentGestureState, animatedGestureSource, handleOnStart, handleOnActive, handleOnEnd);\n const handlePanGestureHandler = useGestureHandler(GESTURE_SOURCE.HANDLE, animatedHandleGestureState, animatedGestureSource, handleOnStart, handleOnActive, handleOnEnd); //#endregion\n //#region context\n\n const contextValue = useMemo(() => ({\n contentPanGestureHandler,\n handlePanGestureHandler,\n scrollablePanGestureHandler,\n animatedGestureSource\n }), [contentPanGestureHandler, handlePanGestureHandler, scrollablePanGestureHandler, animatedGestureSource]); //#endregion\n\n return /*#__PURE__*/React.createElement(BottomSheetGestureHandlersContext.Provider, {\n value: contextValue\n }, children);\n};\n\nexport default BottomSheetGestureHandlersProvider;\n//# sourceMappingURL=BottomSheetGestureHandlersProvider.js.map","export { default } from './BottomSheetBackdropContainer';\n//# sourceMappingURL=index.js.map","import React, { memo } from 'react';\nimport { styles } from './styles';\n\nconst BottomSheetBackdropContainerComponent = ({\n animatedIndex,\n animatedPosition,\n backdropComponent: BackdropComponent\n}) => {\n return BackdropComponent ? /*#__PURE__*/React.createElement(BackdropComponent, {\n animatedIndex: animatedIndex,\n animatedPosition: animatedPosition,\n style: styles.container\n }) : null;\n};\n\nconst BottomSheetBackdropContainer = /*#__PURE__*/memo(BottomSheetBackdropContainerComponent);\nBottomSheetBackdropContainer.displayName = 'BottomSheetBackdropContainer';\nexport default BottomSheetBackdropContainer;\n//# sourceMappingURL=BottomSheetBackdropContainer.js.map","import { StyleSheet } from 'react-native';\nexport const styles = StyleSheet.create({\n container: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0\n }\n});\n//# sourceMappingURL=styles.js.map","export { default } from './BottomSheetHandleContainer';\n//# sourceMappingURL=index.js.map","import React, { memo, useCallback, useMemo } from 'react';\nimport { PanGestureHandler } from 'react-native-gesture-handler';\nimport Animated from 'react-native-reanimated';\nimport BottomSheetHandle from '../bottomSheetHandle';\nimport { useBottomSheetGestureHandlers, useBottomSheetInternal } from '../../hooks';\nimport { print } from '../../utilities';\n\nfunction BottomSheetHandleContainerComponent({\n animatedIndex,\n animatedPosition,\n simultaneousHandlers: _internalSimultaneousHandlers,\n enableHandlePanningGesture,\n handleHeight,\n handleComponent: _providedHandleComponent,\n handleStyle: _providedHandleStyle,\n handleIndicatorStyle: _providedIndicatorStyle\n}) {\n //#region hooks\n const {\n activeOffsetX,\n activeOffsetY,\n failOffsetX,\n failOffsetY,\n waitFor,\n simultaneousHandlers: _providedSimultaneousHandlers\n } = useBottomSheetInternal();\n const {\n handlePanGestureHandler\n } = useBottomSheetGestureHandlers(); //#endregion\n //#region variables\n\n const simultaneousHandlers = useMemo(() => {\n const refs = [];\n\n if (_internalSimultaneousHandlers) {\n refs.push(_internalSimultaneousHandlers);\n }\n\n if (_providedSimultaneousHandlers) {\n if (Array.isArray(_providedSimultaneousHandlers)) {\n refs.push(..._providedSimultaneousHandlers);\n } else {\n refs.push(_providedSimultaneousHandlers);\n }\n }\n\n return refs;\n }, [_providedSimultaneousHandlers, _internalSimultaneousHandlers]); //#endregion\n //#region callbacks\n\n const handleContainerLayout = useCallback(function handleContainerLayout({\n nativeEvent: {\n layout: {\n height\n }\n }\n }) {\n handleHeight.value = height;\n print({\n component: BottomSheetHandleContainer.displayName,\n method: 'handleContainerLayout',\n params: {\n height\n }\n });\n }, [handleHeight]); //#endregion\n //#region renders\n\n const HandleComponent = _providedHandleComponent === undefined ? BottomSheetHandle : _providedHandleComponent;\n return HandleComponent !== null ? /*#__PURE__*/React.createElement(PanGestureHandler, {\n enabled: enableHandlePanningGesture,\n waitFor: waitFor,\n simultaneousHandlers: simultaneousHandlers,\n shouldCancelWhenOutside: false,\n activeOffsetX: activeOffsetX,\n activeOffsetY: activeOffsetY,\n failOffsetX: failOffsetX,\n failOffsetY: failOffsetY,\n onGestureEvent: handlePanGestureHandler\n }, /*#__PURE__*/React.createElement(Animated.View, {\n key: \"BottomSheetHandleContainer\",\n accessible: true,\n accessibilityRole: \"adjustable\",\n accessibilityLabel: \"Bottom Sheet handle\",\n accessibilityHint: \"Drag up or down to extend or minimize the Bottom Sheet\",\n onLayout: handleContainerLayout\n }, /*#__PURE__*/React.createElement(HandleComponent, {\n animatedIndex: animatedIndex,\n animatedPosition: animatedPosition,\n style: _providedHandleStyle,\n indicatorStyle: _providedIndicatorStyle\n }))) : null; //#endregion\n}\n\nconst BottomSheetHandleContainer = /*#__PURE__*/memo(BottomSheetHandleContainerComponent);\nBottomSheetHandleContainer.displayName = 'BottomSheetHandleContainer';\nexport default BottomSheetHandleContainer;\n//# sourceMappingURL=BottomSheetHandleContainer.js.map","export { default } from './BottomSheetHandle';\n//# sourceMappingURL=index.js.map","import React, { memo, useMemo } from 'react';\nimport Animated from 'react-native-reanimated';\nimport { styles } from './styles';\n\nconst BottomSheetHandleComponent = ({\n style,\n indicatorStyle: _indicatorStyle,\n children\n}) => {\n // styles\n const containerStyle = useMemo(() => [styles.container, ...[Array.isArray(style) ? style : [style]]], [style]);\n const indicatorStyle = useMemo(() => [styles.indicator, ...[Array.isArray(_indicatorStyle) ? _indicatorStyle : [_indicatorStyle]]], [_indicatorStyle]); // render\n\n return /*#__PURE__*/React.createElement(Animated.View, {\n style: containerStyle\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: indicatorStyle\n }), children);\n};\n\nconst BottomSheetHandle = /*#__PURE__*/memo(BottomSheetHandleComponent);\nBottomSheetHandle.displayName = 'BottomSheetHandle';\nexport default BottomSheetHandle;\n//# sourceMappingURL=BottomSheetHandle.js.map","import { StyleSheet } from 'react-native';\nimport { WINDOW_WIDTH } from '../../constants';\nexport const styles = StyleSheet.create({\n container: {\n padding: 10\n },\n indicator: {\n alignSelf: 'center',\n width: 7.5 * WINDOW_WIDTH / 100,\n height: 4,\n borderRadius: 4,\n backgroundColor: 'rgba(0, 0, 0, 0.75)'\n }\n});\n//# sourceMappingURL=styles.js.map","export { default } from './BottomSheetBackgroundContainer';\n//# sourceMappingURL=index.js.map","import React, { memo, useMemo } from 'react';\nimport BottomSheetBackground from '../bottomSheetBackground';\nimport { styles } from './styles';\nimport { StyleSheet } from 'react-native';\n\nconst BottomSheetBackgroundContainerComponent = ({\n animatedIndex,\n animatedPosition,\n backgroundComponent: _providedBackgroundComponent,\n backgroundStyle: _providedBackgroundStyle\n}) => {\n const BackgroundComponent = _providedBackgroundComponent || BottomSheetBackground;\n const backgroundStyle = useMemo(() => StyleSheet.flatten([styles.container, _providedBackgroundStyle]), [_providedBackgroundStyle]);\n return _providedBackgroundComponent === null ? null : /*#__PURE__*/React.createElement(BackgroundComponent, {\n pointerEvents: \"none\",\n animatedIndex: animatedIndex,\n animatedPosition: animatedPosition,\n style: backgroundStyle\n });\n};\n\nconst BottomSheetBackgroundContainer = /*#__PURE__*/memo(BottomSheetBackgroundContainerComponent);\nBottomSheetBackgroundContainer.displayName = 'BottomSheetBackgroundContainer';\nexport default BottomSheetBackgroundContainer;\n//# sourceMappingURL=BottomSheetBackgroundContainer.js.map","export { default } from './BottomSheetBackground';\n//# sourceMappingURL=index.js.map","import React, { memo } from 'react';\nimport { View } from 'react-native';\nimport { styles } from './styles';\n\nconst BottomSheetBackgroundComponent = ({\n pointerEvents,\n style\n}) => /*#__PURE__*/React.createElement(View, {\n pointerEvents: pointerEvents,\n accessible: true,\n accessibilityRole: \"adjustable\",\n accessibilityLabel: \"Bottom Sheet\",\n style: [styles.container, style]\n});\n\nconst BottomSheetBackground = /*#__PURE__*/memo(BottomSheetBackgroundComponent);\nBottomSheetBackground.displayName = 'BottomSheetBackground';\nexport default BottomSheetBackground;\n//# sourceMappingURL=BottomSheetBackground.js.map","import { StyleSheet } from 'react-native';\nexport const styles = StyleSheet.create({\n container: {\n backgroundColor: 'white',\n borderRadius: 15\n }\n});\n//# sourceMappingURL=styles.js.map","import { StyleSheet } from 'react-native';\nexport const styles = StyleSheet.create({\n container: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0\n }\n});\n//# sourceMappingURL=styles.js.map","import React, { memo } from 'react';\nimport { useDerivedValue } from 'react-native-reanimated';\nimport { useBottomSheetInternal } from '../../hooks';\nimport { KEYBOARD_STATE } from '../../constants';\n\nconst BottomSheetFooterContainerComponent = ({\n footerComponent: FooterComponent\n}) => {\n //#region hooks\n const {\n animatedContainerHeight,\n animatedHandleHeight,\n animatedFooterHeight,\n animatedPosition,\n animatedKeyboardState,\n animatedKeyboardHeightInContainer\n } = useBottomSheetInternal(); //#endregion\n //#region variables\n\n const animatedFooterPosition = useDerivedValue(() => {\n const keyboardHeight = animatedKeyboardHeightInContainer.value;\n let footerTranslateY = Math.max(0, animatedContainerHeight.value - animatedPosition.value);\n\n if (animatedKeyboardState.value === KEYBOARD_STATE.SHOWN) {\n footerTranslateY = footerTranslateY - keyboardHeight;\n }\n\n footerTranslateY = footerTranslateY - animatedFooterHeight.value - animatedHandleHeight.value;\n return footerTranslateY;\n }, [animatedKeyboardHeightInContainer, animatedContainerHeight, animatedPosition, animatedKeyboardState, animatedFooterHeight, animatedHandleHeight]); //#endregion\n\n return /*#__PURE__*/React.createElement(FooterComponent, {\n animatedFooterPosition: animatedFooterPosition\n });\n};\n\nconst BottomSheetFooterContainer = /*#__PURE__*/memo(BottomSheetFooterContainerComponent);\nBottomSheetFooterContainer.displayName = 'BottomSheetFooterContainer';\nexport default BottomSheetFooterContainer;\n//# sourceMappingURL=BottomSheetFooterContainer.js.map","export { default } from './BottomSheetDraggableView';\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport React, { useMemo, useRef, memo } from 'react';\nimport Animated from 'react-native-reanimated';\nimport { PanGestureHandler } from 'react-native-gesture-handler';\nimport { useBottomSheetGestureHandlers, useBottomSheetInternal } from '../../hooks';\nimport { GESTURE_SOURCE } from '../../constants';\n\nconst BottomSheetDraggableViewComponent = ({\n gestureType = GESTURE_SOURCE.CONTENT,\n nativeGestureRef,\n refreshControlGestureRef,\n style,\n children,\n ...rest\n}) => {\n //#region hooks\n const {\n enableContentPanningGesture,\n simultaneousHandlers: _providedSimultaneousHandlers,\n waitFor,\n activeOffsetX,\n activeOffsetY,\n failOffsetX,\n failOffsetY\n } = useBottomSheetInternal();\n const {\n contentPanGestureHandler,\n scrollablePanGestureHandler\n } = useBottomSheetGestureHandlers(); //#endregion\n //#region variables\n\n const panGestureRef = useRef(null);\n const gestureHandler = useMemo(() => gestureType === GESTURE_SOURCE.CONTENT ? contentPanGestureHandler : scrollablePanGestureHandler, [gestureType, contentPanGestureHandler, scrollablePanGestureHandler]);\n const simultaneousHandlers = useMemo(() => {\n const refs = [];\n\n if (nativeGestureRef) {\n refs.push(nativeGestureRef);\n }\n\n if (refreshControlGestureRef) {\n refs.push(refreshControlGestureRef);\n }\n\n if (_providedSimultaneousHandlers) {\n if (Array.isArray(_providedSimultaneousHandlers)) {\n refs.push(..._providedSimultaneousHandlers);\n } else {\n refs.push(_providedSimultaneousHandlers);\n }\n }\n\n return refs;\n }, [_providedSimultaneousHandlers, nativeGestureRef, refreshControlGestureRef]); //#endregion\n\n return /*#__PURE__*/React.createElement(PanGestureHandler, {\n ref: panGestureRef,\n enabled: enableContentPanningGesture,\n simultaneousHandlers: simultaneousHandlers,\n shouldCancelWhenOutside: false,\n waitFor: waitFor,\n onGestureEvent: gestureHandler,\n activeOffsetX: activeOffsetX,\n activeOffsetY: activeOffsetY,\n failOffsetX: failOffsetX,\n failOffsetY: failOffsetY\n }, /*#__PURE__*/React.createElement(Animated.View, _extends({\n style: style\n }, rest), children));\n};\n\nconst BottomSheetDraggableView = /*#__PURE__*/memo(BottomSheetDraggableViewComponent);\nBottomSheetDraggableView.displayName = 'BottomSheetDraggableView';\nexport default BottomSheetDraggableView;\n//# sourceMappingURL=BottomSheetDraggableView.js.map","import { StyleSheet } from 'react-native';\nexport const styles = StyleSheet.create({\n container: {\n flexDirection: 'column-reverse',\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0\n },\n contentContainer: {},\n contentMaskContainer: {\n overflow: 'hidden'\n }\n});\n//# sourceMappingURL=styles.js.map","export { default } from './BottomSheetModal';\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport React, { forwardRef, memo, useCallback, useImperativeHandle, useMemo, useRef, useState } from 'react';\nimport { Portal, usePortal } from '@gorhom/portal';\nimport BottomSheet from '../bottomSheet';\nimport { useBottomSheetModalInternal } from '../../hooks';\nimport { print } from '../../utilities';\nimport { DEFAULT_STACK_BEHAVIOR, DEFAULT_ENABLE_DISMISS_ON_CLOSE } from './constants';\nimport { id } from '../../utilities/id';\nconst INITIAL_STATE = {\n mount: false,\n data: undefined\n};\nconst BottomSheetModalComponent = /*#__PURE__*/forwardRef(function BottomSheetModal(props, ref) {\n const {\n // modal props\n name,\n stackBehavior = DEFAULT_STACK_BEHAVIOR,\n enableDismissOnClose = DEFAULT_ENABLE_DISMISS_ON_CLOSE,\n onDismiss: _providedOnDismiss,\n // bottom sheet props\n index = 0,\n snapPoints,\n enablePanDownToClose = true,\n animateOnMount = true,\n containerComponent: ContainerComponent = React.Fragment,\n // callbacks\n onChange: _providedOnChange,\n // components\n children: Content,\n ...bottomSheetProps\n } = props; //#region state\n\n const [{\n mount,\n data\n }, setState] = useState(INITIAL_STATE); //#endregion\n //#region hooks\n\n const {\n containerHeight,\n containerOffset,\n mountSheet,\n unmountSheet,\n willUnmountSheet\n } = useBottomSheetModalInternal();\n const {\n removePortal: unmountPortal\n } = usePortal(); //#endregion\n //#region refs\n\n const bottomSheetRef = useRef(null);\n const currentIndexRef = useRef(!animateOnMount ? index : -1);\n const restoreIndexRef = useRef(-1);\n const minimized = useRef(false);\n const forcedDismissed = useRef(false);\n const mounted = useRef(false);\n mounted.current = mount; //#endregion\n //#region variables\n\n const key = useMemo(() => name || `bottom-sheet-modal-${id()}`, [name]); //#endregion\n //#region private methods\n\n const resetVariables = useCallback(function resetVariables() {\n print({\n component: BottomSheetModal.name,\n method: resetVariables.name\n });\n currentIndexRef.current = -1;\n restoreIndexRef.current = -1;\n minimized.current = false;\n mounted.current = false;\n forcedDismissed.current = false;\n }, []);\n const unmount = useCallback(function unmount() {\n print({\n component: BottomSheetModal.name,\n method: unmount.name\n });\n const _mounted = mounted.current; // reset variables\n\n resetVariables(); // unmount sheet and portal\n\n unmountSheet(key);\n unmountPortal(key); // unmount the node, if sheet is still mounted\n\n if (_mounted) {\n setState(INITIAL_STATE);\n } // fire `onDismiss` callback\n\n\n if (_providedOnDismiss) {\n _providedOnDismiss();\n }\n }, [key, resetVariables, unmountSheet, unmountPortal, _providedOnDismiss]); //#endregion\n //#region bottom sheet methods\n\n const handleSnapToIndex = useCallback((...args) => {\n var _bottomSheetRef$curre;\n\n if (minimized.current) {\n return;\n }\n\n (_bottomSheetRef$curre = bottomSheetRef.current) === null || _bottomSheetRef$curre === void 0 ? void 0 : _bottomSheetRef$curre.snapToIndex(...args);\n }, []);\n const handleSnapToPosition = useCallback((...args) => {\n var _bottomSheetRef$curre2;\n\n if (minimized.current) {\n return;\n }\n\n (_bottomSheetRef$curre2 = bottomSheetRef.current) === null || _bottomSheetRef$curre2 === void 0 ? void 0 : _bottomSheetRef$curre2.snapToPosition(...args);\n }, []);\n const handleExpand = useCallback((...args) => {\n var _bottomSheetRef$curre3;\n\n if (minimized.current) {\n return;\n }\n\n (_bottomSheetRef$curre3 = bottomSheetRef.current) === null || _bottomSheetRef$curre3 === void 0 ? void 0 : _bottomSheetRef$curre3.expand(...args);\n }, []);\n const handleCollapse = useCallback((...args) => {\n var _bottomSheetRef$curre4;\n\n if (minimized.current) {\n return;\n }\n\n (_bottomSheetRef$curre4 = bottomSheetRef.current) === null || _bottomSheetRef$curre4 === void 0 ? void 0 : _bottomSheetRef$curre4.collapse(...args);\n }, []);\n const handleClose = useCallback((...args) => {\n var _bottomSheetRef$curre5;\n\n if (minimized.current) {\n return;\n }\n\n (_bottomSheetRef$curre5 = bottomSheetRef.current) === null || _bottomSheetRef$curre5 === void 0 ? void 0 : _bottomSheetRef$curre5.close(...args);\n }, []);\n const handleForceClose = useCallback((...args) => {\n var _bottomSheetRef$curre6;\n\n if (minimized.current) {\n return;\n }\n\n (_bottomSheetRef$curre6 = bottomSheetRef.current) === null || _bottomSheetRef$curre6 === void 0 ? void 0 : _bottomSheetRef$curre6.forceClose(...args);\n }, []); //#endregion\n //#region bottom sheet modal methods\n\n const handlePresent = useCallback(function handlePresent(_data) {\n requestAnimationFrame(() => {\n setState({\n mount: true,\n data: _data\n });\n mountSheet(key, ref, stackBehavior);\n print({\n component: BottomSheetModal.name,\n method: handlePresent.name\n });\n });\n }, // eslint-disable-next-line react-hooks/exhaustive-deps\n [key, stackBehavior, mountSheet]);\n const handleDismiss = useCallback(function handleDismiss(animationConfigs) {\n var _bottomSheetRef$curre7;\n\n print({\n component: BottomSheetModal.name,\n method: handleDismiss.name,\n params: {\n currentIndexRef: currentIndexRef.current,\n minimized: minimized.current\n }\n });\n /**\n * if modal is already been dismiss, we exit the method.\n */\n\n if (currentIndexRef.current === -1 && minimized.current === false) {\n return;\n }\n\n if (minimized.current || currentIndexRef.current === -1 && enablePanDownToClose) {\n unmount();\n return;\n }\n\n willUnmountSheet(key);\n forcedDismissed.current = true;\n (_bottomSheetRef$curre7 = bottomSheetRef.current) === null || _bottomSheetRef$curre7 === void 0 ? void 0 : _bottomSheetRef$curre7.forceClose(animationConfigs);\n }, [willUnmountSheet, unmount, key, enablePanDownToClose]);\n const handleMinimize = useCallback(function handleMinimize() {\n var _bottomSheetRef$curre8;\n\n print({\n component: BottomSheetModal.name,\n method: handleMinimize.name,\n params: {\n minimized: minimized.current\n }\n });\n\n if (minimized.current) {\n return;\n }\n\n minimized.current = true;\n /**\n * if modal got minimized before it finish its mounting\n * animation, we set the `restoreIndexRef` to the\n * provided index.\n */\n\n if (currentIndexRef.current === -1) {\n restoreIndexRef.current = index;\n } else {\n restoreIndexRef.current = currentIndexRef.current;\n }\n\n (_bottomSheetRef$curre8 = bottomSheetRef.current) === null || _bottomSheetRef$curre8 === void 0 ? void 0 : _bottomSheetRef$curre8.close();\n }, [index]);\n const handleRestore = useCallback(function handleRestore() {\n var _bottomSheetRef$curre9;\n\n print({\n component: BottomSheetModal.name,\n method: handleRestore.name,\n params: {\n minimized: minimized.current,\n forcedDismissed: forcedDismissed.current\n }\n });\n\n if (!minimized.current || forcedDismissed.current) {\n return;\n }\n\n minimized.current = false;\n (_bottomSheetRef$curre9 = bottomSheetRef.current) === null || _bottomSheetRef$curre9 === void 0 ? void 0 : _bottomSheetRef$curre9.snapToIndex(restoreIndexRef.current);\n }, []); //#endregion\n //#region callbacks\n\n const handlePortalOnUnmount = useCallback(function handlePortalOnUnmount() {\n var _bottomSheetRef$curre10;\n\n print({\n component: BottomSheetModal.name,\n method: handlePortalOnUnmount.name,\n params: {\n minimized: minimized.current,\n forcedDismissed: forcedDismissed.current\n }\n });\n /**\n * if modal is already been dismiss, we exit the method.\n */\n\n if (currentIndexRef.current === -1 && minimized.current === false) {\n return;\n }\n\n mounted.current = false;\n forcedDismissed.current = true;\n\n if (minimized.current) {\n unmount();\n return;\n }\n\n willUnmountSheet(key);\n (_bottomSheetRef$curre10 = bottomSheetRef.current) === null || _bottomSheetRef$curre10 === void 0 ? void 0 : _bottomSheetRef$curre10.close();\n }, [key, unmount, willUnmountSheet]);\n const handlePortalRender = useCallback(function handlePortalRender(render) {\n if (mounted.current) {\n render();\n }\n }, []);\n const handleBottomSheetOnChange = useCallback(function handleBottomSheetOnChange(_index) {\n print({\n component: BottomSheetModal.name,\n method: handleBottomSheetOnChange.name,\n params: {\n minimized: minimized.current,\n forcedDismissed: forcedDismissed.current\n }\n });\n currentIndexRef.current = _index;\n\n if (_providedOnChange) {\n _providedOnChange(_index);\n }\n }, [_providedOnChange]);\n const handleBottomSheetOnClose = useCallback(function handleBottomSheetOnClose() {\n print({\n component: BottomSheetModal.name,\n method: handleBottomSheetOnClose.name,\n params: {\n minimized: minimized.current,\n forcedDismissed: forcedDismissed.current\n }\n });\n\n if (minimized.current) {\n return;\n }\n\n if (enableDismissOnClose) {\n unmount();\n }\n }, [enableDismissOnClose, unmount]); //#endregion\n //#region expose methods\n\n useImperativeHandle(ref, () => ({\n // sheet\n snapToIndex: handleSnapToIndex,\n snapToPosition: handleSnapToPosition,\n expand: handleExpand,\n collapse: handleCollapse,\n close: handleClose,\n forceClose: handleForceClose,\n // modal methods\n dismiss: handleDismiss,\n present: handlePresent,\n // internal\n minimize: handleMinimize,\n restore: handleRestore\n })); //#endregion\n // render\n // console.log('BottomSheetModal', index, mount, data);\n\n return mount ? /*#__PURE__*/React.createElement(Portal, {\n key: key,\n name: key,\n handleOnMount: handlePortalRender,\n handleOnUpdate: handlePortalRender,\n handleOnUnmount: handlePortalOnUnmount\n }, /*#__PURE__*/React.createElement(ContainerComponent, {\n key: key\n }, /*#__PURE__*/React.createElement(BottomSheet, _extends({}, bottomSheetProps, {\n ref: bottomSheetRef,\n key: key,\n index: index,\n snapPoints: snapPoints,\n enablePanDownToClose: enablePanDownToClose,\n animateOnMount: animateOnMount,\n containerHeight: containerHeight,\n containerOffset: containerOffset,\n onChange: handleBottomSheetOnChange,\n onClose: handleBottomSheetOnClose,\n children: typeof Content === 'function' ? /*#__PURE__*/React.createElement(Content, {\n data: data\n }) : Content,\n $modal: true\n })))) : null;\n});\nconst BottomSheetModal = /*#__PURE__*/memo(BottomSheetModalComponent);\nBottomSheetModal.displayName = 'BottomSheetModal';\nexport default BottomSheetModal;\n//# sourceMappingURL=BottomSheetModal.js.map","export { Portal } from './components/portal/Portal';\nexport { PortalHost } from './components/portalHost/PortalHost';\nexport { PortalProvider } from './components/portalProvider/PortalProvider';\nexport { usePortal } from './hooks/usePortal';\nexport { enableLogging } from './utilities/logger';\n//# sourceMappingURL=index.js.map","import { memo, useCallback, useEffect, useMemo, useRef } from 'react';\nimport { nanoid } from 'nanoid/non-secure';\nimport { usePortal } from '../../hooks/usePortal';\n\nconst PortalComponent = ({\n name: _providedName,\n hostName,\n handleOnMount: _providedHandleOnMount,\n handleOnUnmount: _providedHandleOnUnmount,\n handleOnUpdate: _providedHandleOnUpdate,\n children\n}) => {\n //#region hooks\n const {\n addPortal: addUpdatePortal,\n removePortal\n } = usePortal(hostName); //#endregion\n //#region variables\n\n const name = useMemo(() => _providedName || nanoid(), [_providedName]); //#endregion\n //#region refs\n\n const handleOnMountRef = useRef();\n const handleOnUnmountRef = useRef();\n const handleOnUpdateRef = useRef(); //#endregion\n //#region callbacks\n\n const handleOnMount = useCallback(() => {\n if (_providedHandleOnMount) {\n _providedHandleOnMount(() => addUpdatePortal(name, children));\n } else {\n addUpdatePortal(name, children);\n } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n }, [_providedHandleOnMount, addUpdatePortal]);\n handleOnMountRef.current = handleOnMount;\n const handleOnUnmount = useCallback(() => {\n if (_providedHandleOnUnmount) {\n _providedHandleOnUnmount(() => removePortal(name));\n } else {\n removePortal(name);\n } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n }, [_providedHandleOnUnmount, removePortal]);\n handleOnUnmountRef.current = handleOnUnmount;\n const handleOnUpdate = useCallback(() => {\n if (_providedHandleOnUpdate) {\n _providedHandleOnUpdate(() => addUpdatePortal(name, children));\n } else {\n addUpdatePortal(name, children);\n } // eslint-disable-next-line react-hooks/exhaustive-deps\n\n }, [_providedHandleOnUpdate, addUpdatePortal, children]);\n handleOnUpdateRef.current = handleOnUpdate; //#endregion\n //#region effects\n\n useEffect(() => {\n var _handleOnMountRef$cur;\n\n (_handleOnMountRef$cur = handleOnMountRef.current) === null || _handleOnMountRef$cur === void 0 ? void 0 : _handleOnMountRef$cur.call(handleOnMountRef);\n return () => {\n var _handleOnUnmountRef$c;\n\n (_handleOnUnmountRef$c = handleOnUnmountRef.current) === null || _handleOnUnmountRef$c === void 0 ? void 0 : _handleOnUnmountRef$c.call(handleOnUnmountRef); // remove callbacks refs\n\n handleOnMountRef.current = undefined;\n handleOnUnmountRef.current = undefined;\n handleOnUpdateRef.current = undefined;\n };\n }, []);\n useEffect(() => {\n var _handleOnUpdateRef$cu;\n\n (_handleOnUpdateRef$cu = handleOnUpdateRef.current) === null || _handleOnUpdateRef$cu === void 0 ? void 0 : _handleOnUpdateRef$cu.call(handleOnUpdateRef);\n }, [children]); //#endregion\n\n return null;\n};\n\nexport const Portal = /*#__PURE__*/memo(PortalComponent);\nPortal.displayName = 'Portal';\n//# sourceMappingURL=Portal.js.map","import { useCallback, useContext } from 'react';\nimport { ACTIONS } from '../state/constants';\nimport { PortalDispatchContext } from '../contexts/portal';\nexport const usePortal = (hostName = 'root') => {\n const dispatch = useContext(PortalDispatchContext);\n\n if (dispatch === null) {\n throw new Error(\"'PortalDispatchContext' cannot be null, please add 'PortalProvider' to the root component.\");\n } //#region methods\n\n\n const registerHost = useCallback(() => {\n dispatch({\n type: ACTIONS.REGISTER_HOST,\n hostName: hostName\n }); // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n const deregisterHost = useCallback(() => {\n dispatch({\n type: ACTIONS.DEREGISTER_HOST,\n hostName: hostName\n }); // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n const addUpdatePortal = useCallback((name, node) => {\n dispatch({\n type: ACTIONS.ADD_UPDATE_PORTAL,\n hostName,\n portalName: name,\n node\n }); // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n const removePortal = useCallback(name => {\n dispatch({\n type: ACTIONS.REMOVE_PORTAL,\n hostName,\n portalName: name\n }); // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []); //#endregion\n\n return {\n registerHost,\n deregisterHost,\n addPortal: addUpdatePortal,\n updatePortal: addUpdatePortal,\n removePortal\n };\n};\n//# sourceMappingURL=usePortal.js.map","var ACTIONS;\n\n(function (ACTIONS) {\n ACTIONS[ACTIONS[\"REGISTER_HOST\"] = 0] = \"REGISTER_HOST\";\n ACTIONS[ACTIONS[\"DEREGISTER_HOST\"] = 1] = \"DEREGISTER_HOST\";\n ACTIONS[ACTIONS[\"ADD_UPDATE_PORTAL\"] = 2] = \"ADD_UPDATE_PORTAL\";\n ACTIONS[ACTIONS[\"REMOVE_PORTAL\"] = 3] = \"REMOVE_PORTAL\";\n})(ACTIONS || (ACTIONS = {}));\n\nconst INITIAL_STATE = {};\nexport { ACTIONS, INITIAL_STATE };\n//# sourceMappingURL=constants.js.map","import { createContext } from 'react';\nexport const PortalStateContext = /*#__PURE__*/createContext(null);\nexport const PortalDispatchContext = /*#__PURE__*/createContext(null);\n//# sourceMappingURL=portal.js.map","import React, { memo, useEffect } from 'react';\nimport { usePortalState } from '../../hooks/usePortalState';\nimport { usePortal } from '../../hooks/usePortal';\n\nconst PortalHostComponent = ({\n name\n}) => {\n //#region hooks\n const state = usePortalState(name);\n const {\n registerHost,\n deregisterHost\n } = usePortal(name); //#endregion\n //#region effects\n\n useEffect(() => {\n registerHost();\n return () => {\n deregisterHost();\n }; // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []); //#endregion\n //#region render\n\n return /*#__PURE__*/React.createElement(React.Fragment, null, state.map(item => item.node)); //#endregion\n};\n\nexport const PortalHost = /*#__PURE__*/memo(PortalHostComponent);\nPortalHost.displayName = 'PortalHost';\n//# sourceMappingURL=PortalHost.js.map","import { useContext } from 'react';\nimport { PortalStateContext } from '../contexts/portal';\nexport const usePortalState = hostName => {\n const state = useContext(PortalStateContext);\n\n if (state === null) {\n throw new Error(\"'PortalStateContext' cannot be null, please add 'PortalProvider' to the root component.\");\n }\n\n return state[hostName] || [];\n};\n//# sourceMappingURL=usePortalState.js.map","import React, { memo, useReducer } from 'react';\nimport { PortalHost } from '../portalHost/PortalHost';\nimport { PortalDispatchContext, PortalStateContext } from '../../contexts/portal';\nimport { INITIAL_STATE } from '../../state/constants';\nimport { reducer } from '../../state/reducer';\n\nconst PortalProviderComponent = ({\n rootHostName = 'root',\n shouldAddRootHost = true,\n children\n}) => {\n const [state, dispatch] = useReducer(reducer, INITIAL_STATE);\n return /*#__PURE__*/React.createElement(PortalDispatchContext.Provider, {\n value: dispatch\n }, /*#__PURE__*/React.createElement(PortalStateContext.Provider, {\n value: state\n }, children, shouldAddRootHost && /*#__PURE__*/React.createElement(PortalHost, {\n name: rootHostName\n })));\n};\n\nexport const PortalProvider = /*#__PURE__*/memo(PortalProviderComponent);\nPortalProvider.displayName = 'PortalProvider';\n//# sourceMappingURL=PortalProvider.js.map","import { ACTIONS } from './constants';\nimport { print } from '../utilities/logger';\n\nconst registerHost = (state, hostName) => {\n if (!(hostName in state)) {\n state[hostName] = [];\n }\n\n return state;\n};\n\nconst deregisterHost = (state, hostName) => {\n delete state[hostName];\n return state;\n};\n\nconst addUpdatePortal = (state, hostName, portalName, node) => {\n if (!(hostName in state)) {\n state = registerHost(state, hostName);\n }\n /**\n * updated portal, if it was already added.\n */\n\n\n const index = state[hostName].findIndex(item => item.name === portalName);\n\n if (index !== -1) {\n state[hostName][index].node = node;\n } else {\n state[hostName].push({\n name: portalName,\n node\n });\n }\n\n return state;\n};\n\nconst removePortal = (state, hostName, portalName) => {\n if (!(hostName in state)) {\n print({\n component: reducer.name,\n method: removePortal.name,\n params: \"Failed to remove portal '\".concat(portalName, \"', '\").concat(hostName, \"' was not registered!\")\n });\n return state;\n }\n\n const index = state[hostName].findIndex(item => item.name === portalName);\n if (index !== -1) state[hostName].splice(index, 1);\n return state;\n};\n\nexport const reducer = (state, action) => {\n const {\n type\n } = action;\n let clonedState = { ...state\n };\n\n switch (type) {\n case ACTIONS.REGISTER_HOST:\n return registerHost(clonedState, action.hostName);\n\n case ACTIONS.DEREGISTER_HOST:\n return deregisterHost(clonedState, action.hostName);\n\n case ACTIONS.ADD_UPDATE_PORTAL:\n return addUpdatePortal(clonedState, action.hostName, action.portalName, action.node);\n\n case ACTIONS.REMOVE_PORTAL:\n return removePortal(clonedState, action.hostName, action.portalName);\n\n default:\n return state;\n }\n};\n//# sourceMappingURL=reducer.js.map","let isLoggingEnabled = false; // __DEV__ global is by default not defined in React Native Web builds\n\nconst isDev = Boolean(typeof __DEV__ !== 'undefined' && __DEV__);\n\nconst enableLogging = () => {\n if (!isDev) {\n console.warn('[Portal] could not enable logging on production!');\n return;\n }\n\n isLoggingEnabled = true;\n};\n\nlet print = () => {};\n\nif (isDev) {\n print = ({\n component,\n method,\n params\n }) => {\n if (!isLoggingEnabled) {\n return;\n }\n\n let message = '';\n\n if (typeof params === 'object') {\n message = Object.keys(params).map(key => \"\".concat(key, \":\").concat(params[key])).join(' ');\n } else {\n message = \"\".concat(params !== null && params !== void 0 ? params : '');\n }\n\n console.log(\"[Portal::\".concat([component, method].filter(Boolean).join('::'), \"]\"), message);\n };\n}\n\nObject.freeze(print);\nexport { print, enableLogging };\n//# sourceMappingURL=logger.js.map","const DEFAULT_STACK_BEHAVIOR = 'replace';\nconst DEFAULT_ENABLE_DISMISS_ON_CLOSE = true;\nexport { DEFAULT_STACK_BEHAVIOR, DEFAULT_ENABLE_DISMISS_ON_CLOSE };\n//# sourceMappingURL=constants.js.map","let current = 0;\nexport const id = () => {\n current = (current + 1) % Number.MAX_SAFE_INTEGER;\n return current;\n};\n//# sourceMappingURL=id.js.map","export { default } from './BottomSheetModalProvider';\n//# sourceMappingURL=index.js.map","import React, { useCallback, useMemo, useRef } from 'react';\nimport { useSharedValue } from 'react-native-reanimated';\nimport { PortalProvider } from '@gorhom/portal';\nimport { BottomSheetModalProvider, BottomSheetModalInternalProvider } from '../../contexts';\nimport BottomSheetContainer from '../bottomSheetContainer';\nimport { MODAL_STACK_BEHAVIOR } from '../../constants';\nimport { INITIAL_CONTAINER_HEIGHT, INITIAL_CONTAINER_OFFSET } from '../bottomSheet/constants';\n\nconst BottomSheetModalProviderWrapper = ({\n children\n}) => {\n //#region layout variables\n const animatedContainerHeight = useSharedValue(INITIAL_CONTAINER_HEIGHT);\n const animatedContainerOffset = useSharedValue(INITIAL_CONTAINER_OFFSET); //#endregion\n //#region variables\n\n const sheetsQueueRef = useRef([]); //#endregion\n //#region private methods\n\n const handleMountSheet = useCallback((key, ref, stackBehavior) => {\n const _sheetsQueue = sheetsQueueRef.current.slice();\n\n const sheetIndex = _sheetsQueue.findIndex(item => item.key === key);\n\n const sheetOnTop = sheetIndex === _sheetsQueue.length - 1;\n /**\n * Exit the method, if sheet is already presented\n * and at the top.\n */\n\n if (sheetIndex !== -1 && sheetOnTop) {\n return;\n }\n /**\n * Minimize the current sheet if:\n * - it exists.\n * - it is not unmounting.\n * - stack behavior is 'replace'.\n */\n\n\n const currentMountedSheet = _sheetsQueue[_sheetsQueue.length - 1];\n\n if (currentMountedSheet && !currentMountedSheet.willUnmount && stackBehavior === MODAL_STACK_BEHAVIOR.replace) {\n var _currentMountedSheet$, _currentMountedSheet$2;\n\n (_currentMountedSheet$ = currentMountedSheet.ref) === null || _currentMountedSheet$ === void 0 ? void 0 : (_currentMountedSheet$2 = _currentMountedSheet$.current) === null || _currentMountedSheet$2 === void 0 ? void 0 : _currentMountedSheet$2.minimize();\n }\n /**\n * Restore and remove incoming sheet from the queue,\n * if it was registered.\n */\n\n\n if (sheetIndex !== -1) {\n var _ref$current;\n\n _sheetsQueue.splice(sheetIndex, 1);\n\n ref === null || ref === void 0 ? void 0 : (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.restore();\n }\n\n _sheetsQueue.push({\n key,\n ref,\n willUnmount: false\n });\n\n sheetsQueueRef.current = _sheetsQueue;\n }, []);\n const handleUnmountSheet = useCallback(key => {\n const _sheetsQueue = sheetsQueueRef.current.slice();\n\n const sheetIndex = _sheetsQueue.findIndex(item => item.key === key);\n\n const sheetOnTop = sheetIndex === _sheetsQueue.length - 1;\n /**\n * Here we remove the unmounted sheet and update\n * the sheets queue.\n */\n\n _sheetsQueue.splice(sheetIndex, 1);\n\n sheetsQueueRef.current = _sheetsQueue;\n /**\n * Here we try to restore previous sheet position if unmounted\n * sheet was on top. This is needed when user dismiss\n * the modal by panning down.\n */\n\n const hasMinimizedSheet = sheetsQueueRef.current.length > 0;\n const minimizedSheet = sheetsQueueRef.current[sheetsQueueRef.current.length - 1];\n\n if (sheetOnTop && hasMinimizedSheet && minimizedSheet && !minimizedSheet.willUnmount) {\n var _sheetsQueueRef$curre, _sheetsQueueRef$curre2;\n\n (_sheetsQueueRef$curre = sheetsQueueRef.current[sheetsQueueRef.current.length - 1].ref) === null || _sheetsQueueRef$curre === void 0 ? void 0 : (_sheetsQueueRef$curre2 = _sheetsQueueRef$curre.current) === null || _sheetsQueueRef$curre2 === void 0 ? void 0 : _sheetsQueueRef$curre2.restore();\n }\n }, []);\n const handleWillUnmountSheet = useCallback(key => {\n const _sheetsQueue = sheetsQueueRef.current.slice();\n\n const sheetIndex = _sheetsQueue.findIndex(item => item.key === key);\n\n const sheetOnTop = sheetIndex === _sheetsQueue.length - 1;\n /**\n * Here we mark the sheet that will unmount,\n * so it won't be restored.\n */\n\n if (sheetIndex !== -1) {\n _sheetsQueue[sheetIndex].willUnmount = true;\n }\n /**\n * Here we try to restore previous sheet position,\n * This is needed when user dismiss the modal by fire the dismiss action.\n */\n\n\n const hasMinimizedSheet = _sheetsQueue.length > 1;\n\n if (sheetOnTop && hasMinimizedSheet) {\n var _sheetsQueue$ref, _sheetsQueue$ref$curr;\n\n (_sheetsQueue$ref = _sheetsQueue[_sheetsQueue.length - 2].ref) === null || _sheetsQueue$ref === void 0 ? void 0 : (_sheetsQueue$ref$curr = _sheetsQueue$ref.current) === null || _sheetsQueue$ref$curr === void 0 ? void 0 : _sheetsQueue$ref$curr.restore();\n }\n\n sheetsQueueRef.current = _sheetsQueue;\n }, []); //#endregion\n //#region public methods\n\n const handleDismiss = useCallback(key => {\n const sheetToBeDismissed = key ? sheetsQueueRef.current.find(item => item.key === key) : sheetsQueueRef.current[sheetsQueueRef.current.length - 1];\n\n if (sheetToBeDismissed) {\n var _sheetToBeDismissed$r, _sheetToBeDismissed$r2;\n\n (_sheetToBeDismissed$r = sheetToBeDismissed.ref) === null || _sheetToBeDismissed$r === void 0 ? void 0 : (_sheetToBeDismissed$r2 = _sheetToBeDismissed$r.current) === null || _sheetToBeDismissed$r2 === void 0 ? void 0 : _sheetToBeDismissed$r2.dismiss();\n return true;\n }\n\n return false;\n }, []);\n const handleDismissAll = useCallback(() => {\n sheetsQueueRef.current.map(item => {\n var _item$ref, _item$ref$current;\n\n (_item$ref = item.ref) === null || _item$ref === void 0 ? void 0 : (_item$ref$current = _item$ref.current) === null || _item$ref$current === void 0 ? void 0 : _item$ref$current.dismiss();\n });\n }, []); //#endregion\n //#region context variables\n\n const externalContextVariables = useMemo(() => ({\n dismiss: handleDismiss,\n dismissAll: handleDismissAll\n }), [handleDismiss, handleDismissAll]);\n const internalContextVariables = useMemo(() => ({\n containerHeight: animatedContainerHeight,\n containerOffset: animatedContainerOffset,\n mountSheet: handleMountSheet,\n unmountSheet: handleUnmountSheet,\n willUnmountSheet: handleWillUnmountSheet\n }), [animatedContainerHeight, animatedContainerOffset, handleMountSheet, handleUnmountSheet, handleWillUnmountSheet]); //#endregion\n //#region renders\n\n return /*#__PURE__*/React.createElement(BottomSheetModalProvider, {\n value: externalContextVariables\n }, /*#__PURE__*/React.createElement(BottomSheetModalInternalProvider, {\n value: internalContextVariables\n }, /*#__PURE__*/React.createElement(BottomSheetContainer, {\n containerOffset: animatedContainerOffset,\n containerHeight: animatedContainerHeight,\n children: null\n }), /*#__PURE__*/React.createElement(PortalProvider, null, children))); //#endregion\n};\n\nexport default BottomSheetModalProviderWrapper;\n//# sourceMappingURL=BottomSheetModalProvider.js.map","import { useMemo } from 'react';\n\n/**\n * Generate spring animation configs.\n * @param configs overridable configs.\n */\nexport const useBottomSheetSpringConfigs = configs => {\n return useMemo(() => configs, [configs]);\n};\n//# sourceMappingURL=useBottomSheetSpringConfigs.js.map","import { useMemo } from 'react';\nimport { ANIMATION_DURATION, ANIMATION_EASING } from '../constants';\n/**\n * Generate timing animation configs.\n * @default\n * - easing: Easing.out(Easing.exp)\n * - duration 250\n * @param configs overridable configs.\n */\n\nexport const useBottomSheetTimingConfigs = configs => {\n return useMemo(() => {\n const _configs = {\n easing: configs.easing || ANIMATION_EASING,\n duration: configs.duration || ANIMATION_DURATION\n };\n return _configs;\n }, [configs.duration, configs.easing]);\n};\n//# sourceMappingURL=useBottomSheetTimingConfigs.js.map","export { createBottomSheetScrollableComponent } from './createBottomSheetScrollableComponent';\nexport { default as BottomSheetSectionList } from './BottomSheetSectionList';\nexport { default as BottomSheetFlatList } from './BottomSheetFlatList';\nexport { default as BottomSheetScrollView } from './BottomSheetScrollView';\nexport { default as BottomSheetVirtualizedList } from './BottomSheetVirtualizedList';\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport React, { forwardRef, useImperativeHandle, useMemo, useRef } from 'react';\nimport { Platform } from 'react-native';\nimport { useAnimatedProps, useAnimatedStyle } from 'react-native-reanimated';\nimport { NativeViewGestureHandler } from 'react-native-gesture-handler';\nimport BottomSheetDraggableView from '../bottomSheetDraggableView';\nimport BottomSheetRefreshControl from '../bottomSheetRefreshControl';\nimport { useScrollHandler, useScrollableSetter, useBottomSheetInternal, useStableCallback } from '../../hooks';\nimport { GESTURE_SOURCE, SCROLLABLE_DECELERATION_RATE_MAPPER, SCROLLABLE_STATE } from '../../constants';\nimport { styles } from './styles';\nexport function createBottomSheetScrollableComponent(type, ScrollableComponent) {\n return /*#__PURE__*/forwardRef((props, ref) => {\n // props\n const {\n // hooks\n focusHook,\n scrollEventsHandlersHook,\n // props\n enableFooterMarginAdjustment = false,\n overScrollMode = 'never',\n keyboardDismissMode = 'interactive',\n showsVerticalScrollIndicator = true,\n style,\n refreshing,\n onRefresh,\n progressViewOffset,\n refreshControl,\n // events\n onScroll,\n onScrollBeginDrag,\n onScrollEndDrag,\n onContentSizeChange,\n ...rest\n } = props; //#region refs\n\n const nativeGestureRef = useRef(null);\n const refreshControlGestureRef = useRef(null); //#endregion\n //#region hooks\n\n const {\n scrollableRef,\n scrollableContentOffsetY,\n scrollHandler\n } = useScrollHandler(scrollEventsHandlersHook, onScroll, onScrollBeginDrag, onScrollEndDrag);\n const {\n enableContentPanningGesture,\n animatedFooterHeight,\n animatedScrollableState,\n animatedContentHeight,\n enableDynamicSizing\n } = useBottomSheetInternal(); //#endregion\n //#region variables\n\n const scrollableAnimatedProps = useAnimatedProps(() => ({\n decelerationRate: SCROLLABLE_DECELERATION_RATE_MAPPER[animatedScrollableState.value],\n showsVerticalScrollIndicator: showsVerticalScrollIndicator ? animatedScrollableState.value === SCROLLABLE_STATE.UNLOCKED : showsVerticalScrollIndicator\n }), [showsVerticalScrollIndicator]); //#endregion\n //#region callbacks\n\n const handleContentSizeChange = useStableCallback((contentWidth, contentHeight) => {\n if (enableDynamicSizing) {\n animatedContentHeight.value = contentHeight;\n }\n\n if (onContentSizeChange) {\n onContentSizeChange(contentWidth, contentHeight);\n }\n }); //#endregion\n //#region styles\n\n const containerAnimatedStyle = useAnimatedStyle(() => ({\n marginBottom: enableFooterMarginAdjustment ? animatedFooterHeight.value : 0\n }), [enableFooterMarginAdjustment]);\n const containerStyle = useMemo(() => {\n return enableFooterMarginAdjustment ? [...(style ? 'length' in style ? style : [style] : []), containerAnimatedStyle] : style;\n }, [enableFooterMarginAdjustment, style, containerAnimatedStyle]); //#endregion\n //#region effects\n // @ts-ignore\n\n useImperativeHandle(ref, () => scrollableRef.current);\n useScrollableSetter(scrollableRef, type, scrollableContentOffsetY, onRefresh !== undefined, focusHook); //#endregion\n //#region render\n\n if (Platform.OS === 'android') {\n const scrollableContent = /*#__PURE__*/React.createElement(NativeViewGestureHandler, {\n ref: nativeGestureRef,\n enabled: enableContentPanningGesture,\n shouldCancelWhenOutside: false\n }, /*#__PURE__*/React.createElement(ScrollableComponent, _extends({\n animatedProps: scrollableAnimatedProps\n }, rest, {\n scrollEventThrottle: 16,\n ref: scrollableRef,\n overScrollMode: overScrollMode,\n keyboardDismissMode: keyboardDismissMode,\n onScroll: scrollHandler,\n onContentSizeChange: handleContentSizeChange,\n style: containerStyle\n })));\n return /*#__PURE__*/React.createElement(BottomSheetDraggableView, {\n nativeGestureRef: nativeGestureRef,\n refreshControlGestureRef: refreshControlGestureRef,\n gestureType: GESTURE_SOURCE.SCROLLABLE,\n style: styles.container\n }, onRefresh ? /*#__PURE__*/React.createElement(BottomSheetRefreshControl, {\n ref: refreshControlGestureRef,\n refreshing: refreshing,\n onRefresh: onRefresh,\n progressViewOffset: progressViewOffset,\n style: styles.container\n }, scrollableContent) : scrollableContent);\n }\n\n return /*#__PURE__*/React.createElement(BottomSheetDraggableView, {\n nativeGestureRef: nativeGestureRef,\n gestureType: GESTURE_SOURCE.SCROLLABLE,\n style: styles.container\n }, /*#__PURE__*/React.createElement(NativeViewGestureHandler, {\n ref: nativeGestureRef,\n enabled: enableContentPanningGesture,\n shouldCancelWhenOutside: false\n }, /*#__PURE__*/React.createElement(ScrollableComponent, _extends({\n animatedProps: scrollableAnimatedProps\n }, rest, {\n scrollEventThrottle: 16,\n ref: scrollableRef,\n overScrollMode: overScrollMode,\n keyboardDismissMode: keyboardDismissMode,\n refreshing: refreshing,\n onRefresh: onRefresh,\n progressViewOffset: progressViewOffset,\n refreshControl: refreshControl,\n onScroll: scrollHandler,\n onContentSizeChange: handleContentSizeChange,\n style: containerStyle\n })))); //#endregion\n });\n}\n//# sourceMappingURL=createBottomSheetScrollableComponent.js.map","import BottomSheetRefreshControl from './BottomSheetRefreshControl';\nexport default BottomSheetRefreshControl;\n//# sourceMappingURL=index.js.map","export default (() => null);\n//# sourceMappingURL=BottomSheetRefreshControl.js.map","import { StyleSheet } from 'react-native';\nexport const styles = StyleSheet.create({\n container: {\n flex: 1,\n overflow: 'visible'\n }\n});\n//# sourceMappingURL=styles.js.map","import { memo } from 'react';\nimport { SectionList as RNSectionList } from 'react-native';\nimport Animated from 'react-native-reanimated';\nimport { SCROLLABLE_TYPE } from '../../constants';\nimport { createBottomSheetScrollableComponent } from './createBottomSheetScrollableComponent';\nconst AnimatedSectionList = Animated.createAnimatedComponent(RNSectionList);\nconst BottomSheetSectionListComponent = createBottomSheetScrollableComponent(SCROLLABLE_TYPE.SECTIONLIST, AnimatedSectionList);\nconst BottomSheetSectionList = /*#__PURE__*/memo(BottomSheetSectionListComponent);\nBottomSheetSectionList.displayName = 'BottomSheetSectionList';\nexport default BottomSheetSectionList;\n//# sourceMappingURL=BottomSheetSectionList.js.map","import { memo } from 'react';\nimport { FlatList as RNFlatList } from 'react-native';\nimport Animated from 'react-native-reanimated';\nimport { SCROLLABLE_TYPE } from '../../constants';\nimport { createBottomSheetScrollableComponent } from './createBottomSheetScrollableComponent';\nconst AnimatedFlatList = Animated.createAnimatedComponent(RNFlatList);\nconst BottomSheetFlatListComponent = createBottomSheetScrollableComponent(SCROLLABLE_TYPE.FLATLIST, AnimatedFlatList);\nconst BottomSheetFlatList = /*#__PURE__*/memo(BottomSheetFlatListComponent);\nBottomSheetFlatList.displayName = 'BottomSheetFlatList';\nexport default BottomSheetFlatList;\n//# sourceMappingURL=BottomSheetFlatList.js.map","import { memo } from 'react';\nimport { ScrollView as RNScrollView } from 'react-native';\nimport Animated from 'react-native-reanimated';\nimport { SCROLLABLE_TYPE } from '../../constants';\nimport { createBottomSheetScrollableComponent } from './createBottomSheetScrollableComponent';\nconst AnimatedScrollView = Animated.createAnimatedComponent(RNScrollView);\nconst BottomSheetScrollViewComponent = createBottomSheetScrollableComponent(SCROLLABLE_TYPE.SCROLLVIEW, AnimatedScrollView);\nconst BottomSheetScrollView = /*#__PURE__*/memo(BottomSheetScrollViewComponent);\nBottomSheetScrollView.displayName = 'BottomSheetScrollView';\nexport default BottomSheetScrollView;\n//# sourceMappingURL=BottomSheetScrollView.js.map","import { memo } from 'react';\nimport { VirtualizedList as RNVirtualizedList } from 'react-native';\nimport Animated from 'react-native-reanimated';\nimport { SCROLLABLE_TYPE } from '../../constants';\nimport { createBottomSheetScrollableComponent } from './createBottomSheetScrollableComponent';\nconst AnimatedVirtualizedList = Animated.createAnimatedComponent(RNVirtualizedList);\nconst BottomSheetVirtualizedListComponent = createBottomSheetScrollableComponent(SCROLLABLE_TYPE.VIRTUALIZEDLIST, AnimatedVirtualizedList);\nconst BottomSheetVirtualizedList = /*#__PURE__*/memo(BottomSheetVirtualizedListComponent);\nBottomSheetVirtualizedList.displayName = 'BottomSheetVirtualizedList';\nexport default BottomSheetVirtualizedList;\n//# sourceMappingURL=BottomSheetVirtualizedList.js.map","/**\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nimport VirtualizedList from '../../vendor/react-native/VirtualizedList';\nexport default VirtualizedList;","export { default } from './BottomSheetView';\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport React, { memo, useEffect, useCallback, useMemo } from 'react';\nimport { StyleSheet } from 'react-native';\nimport Animated, { useAnimatedStyle } from 'react-native-reanimated';\nimport { SCROLLABLE_TYPE } from '../../constants';\nimport { useBottomSheetInternal } from '../../hooks';\nimport { print } from '../../utilities';\n\nfunction BottomSheetViewComponent({\n focusHook: useFocusHook = useEffect,\n enableFooterMarginAdjustment = false,\n onLayout,\n style,\n children,\n ...rest\n}) {\n //#region hooks\n const {\n animatedScrollableContentOffsetY,\n animatedScrollableType,\n animatedFooterHeight,\n enableDynamicSizing,\n animatedContentHeight\n } = useBottomSheetInternal(); //#endregion\n //#region styles\n\n const containerStylePaddingBottom = useMemo(() => {\n const flattenStyle = StyleSheet.flatten(style);\n const paddingBottom = flattenStyle && 'paddingBottom' in flattenStyle ? flattenStyle.paddingBottom : 0;\n return typeof paddingBottom === 'number' ? paddingBottom : 0;\n }, [style]);\n const containerAnimatedStyle = useAnimatedStyle(() => ({\n paddingBottom: enableFooterMarginAdjustment ? animatedFooterHeight.value + containerStylePaddingBottom : containerStylePaddingBottom\n }), [containerStylePaddingBottom, enableFooterMarginAdjustment]);\n const containerStyle = useMemo(() => [style, containerAnimatedStyle], [style, containerAnimatedStyle]); //#endregion\n //#region callbacks\n\n const handleSettingScrollable = useCallback(() => {\n animatedScrollableContentOffsetY.value = 0;\n animatedScrollableType.value = SCROLLABLE_TYPE.VIEW;\n }, [animatedScrollableContentOffsetY, animatedScrollableType]);\n const handleLayout = useCallback(event => {\n if (enableDynamicSizing) {\n animatedContentHeight.value = event.nativeEvent.layout.height;\n }\n\n if (onLayout) {\n onLayout(event);\n }\n\n print({\n component: BottomSheetView.displayName,\n method: 'handleLayout',\n params: {\n height: event.nativeEvent.layout.height\n }\n });\n }, [onLayout, animatedContentHeight, enableDynamicSizing]); //#endregion\n // effects\n\n useFocusHook(handleSettingScrollable); //render\n\n return /*#__PURE__*/React.createElement(Animated.View, _extends({\n onLayout: handleLayout,\n style: containerStyle\n }, rest), children);\n}\n\nconst BottomSheetView = /*#__PURE__*/memo(BottomSheetViewComponent);\nBottomSheetView.displayName = 'BottomSheetView';\nexport default BottomSheetView;\n//# sourceMappingURL=BottomSheetView.js.map","export { default } from './BottomSheetTextInput';\n//# sourceMappingURL=index.js.map","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport React, { memo, useCallback, forwardRef, useEffect } from 'react';\nimport { TextInput } from 'react-native-gesture-handler';\nimport { useBottomSheetInternal } from '../../hooks';\nconst BottomSheetTextInputComponent = /*#__PURE__*/forwardRef(({\n onFocus,\n onBlur,\n ...rest\n}, ref) => {\n //#region hooks\n const {\n shouldHandleKeyboardEvents\n } = useBottomSheetInternal();\n useEffect(() => {\n return () => {\n // Reset the flag on unmount\n shouldHandleKeyboardEvents.value = false;\n };\n }, [shouldHandleKeyboardEvents]); //#endregion\n //#region callbacks\n\n const handleOnFocus = useCallback(args => {\n shouldHandleKeyboardEvents.value = true;\n\n if (onFocus) {\n onFocus(args);\n }\n }, [onFocus, shouldHandleKeyboardEvents]);\n const handleOnBlur = useCallback(args => {\n shouldHandleKeyboardEvents.value = false;\n\n if (onBlur) {\n onBlur(args);\n }\n }, [onBlur, shouldHandleKeyboardEvents]); //#endregion\n\n return /*#__PURE__*/React.createElement(TextInput, _extends({\n ref: ref,\n onFocus: handleOnFocus,\n onBlur: handleOnBlur\n }, rest));\n});\nconst BottomSheetTextInput = /*#__PURE__*/memo(BottomSheetTextInputComponent);\nBottomSheetTextInput.displayName = 'BottomSheetTextInput';\nexport default BottomSheetTextInput;\n//# sourceMappingURL=BottomSheetTextInput.js.map","export { default } from './BottomSheetBackdrop';\n//# sourceMappingURL=index.js.map","import React, { memo, useCallback, useMemo, useState } from 'react';\nimport Animated, { interpolate, Extrapolate, useAnimatedStyle, useAnimatedReaction, useAnimatedGestureHandler, runOnJS } from 'react-native-reanimated';\nimport { TapGestureHandler } from 'react-native-gesture-handler';\nimport { useBottomSheet } from '../../hooks';\nimport { DEFAULT_OPACITY, DEFAULT_APPEARS_ON_INDEX, DEFAULT_DISAPPEARS_ON_INDEX, DEFAULT_ENABLE_TOUCH_THROUGH, DEFAULT_PRESS_BEHAVIOR } from './constants';\nimport { styles } from './styles';\n\nconst BottomSheetBackdropComponent = ({\n animatedIndex,\n opacity: _providedOpacity,\n appearsOnIndex: _providedAppearsOnIndex,\n disappearsOnIndex: _providedDisappearsOnIndex,\n enableTouchThrough: _providedEnableTouchThrough,\n pressBehavior = DEFAULT_PRESS_BEHAVIOR,\n onPress,\n style,\n children\n}) => {\n //#region hooks\n const {\n snapToIndex,\n close\n } = useBottomSheet(); //#endregion\n //#region defaults\n\n const opacity = _providedOpacity !== null && _providedOpacity !== void 0 ? _providedOpacity : DEFAULT_OPACITY;\n const appearsOnIndex = _providedAppearsOnIndex !== null && _providedAppearsOnIndex !== void 0 ? _providedAppearsOnIndex : DEFAULT_APPEARS_ON_INDEX;\n const disappearsOnIndex = _providedDisappearsOnIndex !== null && _providedDisappearsOnIndex !== void 0 ? _providedDisappearsOnIndex : DEFAULT_DISAPPEARS_ON_INDEX;\n const enableTouchThrough = _providedEnableTouchThrough !== null && _providedEnableTouchThrough !== void 0 ? _providedEnableTouchThrough : DEFAULT_ENABLE_TOUCH_THROUGH; //#endregion\n //#region variables\n\n const [pointerEvents, setPointerEvents] = useState(enableTouchThrough ? 'none' : 'auto'); //#endregion\n //#region callbacks\n\n const handleOnPress = useCallback(() => {\n onPress === null || onPress === void 0 ? void 0 : onPress();\n\n if (pressBehavior === 'close') {\n close();\n } else if (pressBehavior === 'collapse') {\n snapToIndex(disappearsOnIndex);\n } else if (typeof pressBehavior === 'number') {\n snapToIndex(pressBehavior);\n }\n }, [snapToIndex, close, disappearsOnIndex, pressBehavior, onPress]);\n const handleContainerTouchability = useCallback(shouldDisableTouchability => {\n setPointerEvents(shouldDisableTouchability ? 'none' : 'auto');\n }, []); //#endregion\n //#region tap gesture\n\n const gestureHandler = useAnimatedGestureHandler({\n onFinish: () => {\n runOnJS(handleOnPress)();\n }\n }, [handleOnPress]); //#endregion\n //#region styles\n\n const containerAnimatedStyle = useAnimatedStyle(() => ({\n opacity: interpolate(animatedIndex.value, [-1, disappearsOnIndex, appearsOnIndex], [0, 0, opacity], Extrapolate.CLAMP),\n flex: 1\n }));\n const containerStyle = useMemo(() => [styles.container, style, containerAnimatedStyle], [style, containerAnimatedStyle]); //#endregion\n //#region effects\n\n useAnimatedReaction(() => animatedIndex.value <= disappearsOnIndex, (shouldDisableTouchability, previous) => {\n if (shouldDisableTouchability === previous) {\n return;\n }\n\n runOnJS(handleContainerTouchability)(shouldDisableTouchability);\n }, [disappearsOnIndex]); //#endregion\n\n return pressBehavior !== 'none' ? /*#__PURE__*/React.createElement(TapGestureHandler, {\n onGestureEvent: gestureHandler\n }, /*#__PURE__*/React.createElement(Animated.View, {\n style: containerStyle,\n pointerEvents: pointerEvents,\n accessible: true,\n accessibilityRole: \"button\",\n accessibilityLabel: \"Bottom Sheet backdrop\",\n accessibilityHint: `Tap to ${typeof pressBehavior === 'string' ? pressBehavior : 'move'} the Bottom Sheet`\n }, children)) : /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: pointerEvents,\n style: containerStyle\n }, children);\n};\n\nconst BottomSheetBackdrop = /*#__PURE__*/memo(BottomSheetBackdropComponent);\nBottomSheetBackdrop.displayName = 'BottomSheetBackdrop';\nexport default BottomSheetBackdrop;\n//# sourceMappingURL=BottomSheetBackdrop.js.map","const DEFAULT_OPACITY = 0.5;\nconst DEFAULT_APPEARS_ON_INDEX = 1;\nconst DEFAULT_DISAPPEARS_ON_INDEX = 0;\nconst DEFAULT_ENABLE_TOUCH_THROUGH = false;\nconst DEFAULT_PRESS_BEHAVIOR = 'close';\nexport { DEFAULT_OPACITY, DEFAULT_APPEARS_ON_INDEX, DEFAULT_DISAPPEARS_ON_INDEX, DEFAULT_ENABLE_TOUCH_THROUGH, DEFAULT_PRESS_BEHAVIOR };\n//# sourceMappingURL=constants.js.map","import { StyleSheet } from 'react-native';\nexport const styles = StyleSheet.create({\n container: {\n backgroundColor: 'black'\n }\n});\n//# sourceMappingURL=styles.js.map","export { default } from './BottomSheetFooter';\n//# sourceMappingURL=index.js.map","import React, { memo, useCallback, useMemo } from 'react';\nimport Animated, { useAnimatedStyle } from 'react-native-reanimated';\nimport { KEYBOARD_STATE } from '../../constants';\nimport { useBottomSheetInternal } from '../../hooks';\nimport { styles } from './styles';\n\nfunction BottomSheetFooterComponent({\n animatedFooterPosition,\n bottomInset = 0,\n style,\n children\n}) {\n //#region hooks\n const {\n animatedFooterHeight,\n animatedKeyboardState\n } = useBottomSheetInternal(); //#endregion\n //#region styles\n\n const containerAnimatedStyle = useAnimatedStyle(() => {\n let footerTranslateY = animatedFooterPosition.value;\n /**\n * Offset the bottom inset only when keyboard is not shown\n */\n\n if (animatedKeyboardState.value !== KEYBOARD_STATE.SHOWN) {\n footerTranslateY = footerTranslateY - bottomInset;\n }\n\n return {\n transform: [{\n translateY: Math.max(0, footerTranslateY)\n }]\n };\n }, [bottomInset, animatedKeyboardState, animatedFooterPosition]);\n const containerStyle = useMemo(() => [styles.container, style, containerAnimatedStyle], [style, containerAnimatedStyle]); //#endregion\n //#region callbacks\n\n const handleContainerLayout = useCallback(({\n nativeEvent: {\n layout: {\n height\n }\n }\n }) => {\n animatedFooterHeight.value = height;\n }, [animatedFooterHeight]); //#endregion\n\n return children !== null ? /*#__PURE__*/React.createElement(Animated.View, {\n pointerEvents: \"box-none\",\n onLayout: handleContainerLayout,\n style: containerStyle\n }, typeof children === 'function' ? children() : children) : null;\n}\n\nconst BottomSheetFooter = /*#__PURE__*/memo(BottomSheetFooterComponent);\nBottomSheetFooter.displayName = 'BottomSheetFooter';\nexport default BottomSheetFooter;\n//# sourceMappingURL=BottomSheetFooter.js.map","import { StyleSheet } from 'react-native';\nexport const styles = StyleSheet.create({\n container: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n zIndex: 9999\n }\n});\n//# sourceMappingURL=styles.js.map","import { TouchableOpacity, TouchableHighlight, TouchableWithoutFeedback // @ts-ignore\n} from './Touchables';\nexport default {\n TouchableOpacity: TouchableOpacity,\n TouchableHighlight: TouchableHighlight,\n TouchableWithoutFeedback: TouchableWithoutFeedback\n};\n//# sourceMappingURL=index.js.map","export { TouchableOpacity, TouchableHighlight, TouchableWithoutFeedback } from 'react-native-gesture-handler';\n//# sourceMappingURL=Touchables.js.map","import React, {useContext} from 'react';\nimport {View} from 'react-native';\nimport {List} from 'react-native-paper';\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport TextM from \"@common/components/text/TextM\";\nimport {theme} from \"@common/theme/theme\";\n\nconst FAQComponent = ({faqs, withTitle = false}) => {\n\n const dimensions = useContext(DimensionsContext);\n\n return (\n \n {withTitle && \n Questions fréquentes\n }\n \n {faqs.map((faq, index) => (\n {faq.question}}\n title={\"\"}\n id={index.toString()}\n style={{borderWidth: 1, borderColor: theme.colors.lightMore, marginHorizontal: 5}}\n >\n \n {faq.answer}}/>\n\n \n \n ))}\n \n \n );\n};\n\nexport default FAQComponent;\n","import { theme } from '@common/theme/theme'\nimport { DimensionsContext, IS_WEB } from '@common/utils/mobileUtils'\nimport { View } from 'react-native'\nimport FontAwesome5 from 'react-native-vector-icons/FontAwesome5'\nimport TextM from '@common/components/text/TextM'\nimport { TouchableRipple } from 'react-native-paper'\nimport React, { useContext } from 'react'\nimport { apiIdle, apiRequest } from '@data/redux/actions/api'\nimport { connect } from 'react-redux'\nimport { useNavigation } from '@react-navigation/native'\nimport { LinearGradient } from 'expo-linear-gradient'\nimport * as WebBrowser from 'expo-web-browser'\nimport * as amplitude from '@amplitude/analytics-react-native'\n\nfunction ReferralActionCard(props) {\n\n const { style, user } = props\n const navigation = useNavigation()\n const dimensions = useContext(DimensionsContext)\n\n return {\n amplitude.track('banner.clicked.referral')\n const url = user?.referrer_dashboard_url\n if (IS_WEB) {\n window.open(url)\n } else {\n WebBrowser.openBrowserAsync(url)\n }\n }}\n style={{\n alignItems: 'center',\n justifyContent: 'center',\n alignSelf: 'center',\n backgroundColor: theme.colors.white,\n // borderTopWidth: 1,\n borderWidth: 1,\n borderColor: theme.colors.warning,\n borderRadius: 15,\n width: dimensions?.width - 20,\n marginTop: 20,\n // opacity: count > 0 ? 1 : 0.7,\n ...style,\n }}\n // disabled={count === 0}\n underlayColor={theme.colors.lightMore}\n >\n \n\n\n \n \n\n \n \n Économisez {(props.user?.referral_commission_amount ?? 50) * 2}€ pour 2 amis parrainés !\n \n \n Chaque parrainage vous rapporte {props.user?.referral_commission_amount ?? 50}€, alors\n n'attendez pas et partagez votre lien de parrainage !\n \n \n En savoir plus\n \n\n \n \n\n \n \n}\n\nconst mapStateToProps = state => {\n return {}\n}\n\nconst mapDispatchToProps =\n {\n apiRequest,\n apiIdle,\n }\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ReferralActionCard)","import React, {useState} from 'react';\nimport {View} from \"react-native\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {FormStepper} from \"@common/components/stepper/FormStepper\";\nimport {useApiStatus} from \"@common/hooks/useApiStatus\";\nimport FeelingQuiz from \"@common/chapters/feeling-quiz/FeelingQuiz\";\nimport {chaptersService} from \"@data/services/chaptersService\";\nimport useLaunchActivity from \"@common/hooks/useLaunchActivity\";\nimport {theme} from \"@common/theme/theme\";\n\nconst ChapterFeelingQuiz = (props) => {\n const {navigation, route} = props\n const {\n activityTemplateId,\n challengeId,\n activityId,\n againActivityId,\n schoolSubjectId,\n chapterName,\n chapterId,\n } = route.params\n const [formValues, setFormValues] = useState({\n // chapterName,\n });\n const defaultValues = {}\n const formData = [\n {\n label: `Avant de commencer dis-moi, comment tu te sens concernant le chapitre “${chapterName}” ?`,\n type: \"custom\", // select.single, select.multiple, text, date\n name: \"feeling_questions\",\n component: FeelingQuiz,\n componentProps: {chapterName}\n },\n ]\n const onSubmit = data => {\n if (props.feelingQuestionsRequest || props.feelingQuestionsError) return\n // console.log({...data?.feeling_questions})\n props.apiRequest(chaptersService.studentChapterFeelings, {id: chapterId}, {...data?.feeling_questions})\n }\n\n const launchActivity = useLaunchActivity()\n useApiStatus(\n chaptersService.studentChapterFeelings, // api service\n null, // success message on toast (string or null)\n true, // error message on toast (true) or keep it in redux state (false)\n (data) => {\n if (activityId)\n launchActivity({\n activity_template_id: activityTemplateId,\n id: activityId,\n school_subject_id: schoolSubjectId,\n challengeId: challengeId,\n againActivityId: againActivityId,\n }, \"replace\", true)\n else if (navigation.canGoBack())\n navigation.goBack()\n else\n navigation.replace(\"live\")\n }, // success callback,\n (error) => {\n if (navigation.canGoBack())\n navigation.goBack()\n else\n navigation.replace(\"live\")\n }\n )\n return (\n \n !x.is_masked)}\n hideProgressBar\n champion={{name: \"tina\", variant: \"main\"}}\n formValues={formValues}\n setFormValues={setFormValues}\n defaultValues={defaultValues}\n onSubmit={onSubmit}\n submitted={props.feelingQuestionsRequest}\n previousRouteName={\"menu\"}\n submittedMessage=\"\"\n serverError={props.feelingQuestionsError}\n />\n );\n}\nconst mapStateToProps = state => {\n return {\n user: state.data.currentUser?.object,\n feelingQuestions: state.data.staticData?.feeling_questions,\n feelingQuestionsRequest: state.api.feelingQuestionsRequest,\n feelingQuestionsError: state.api.feelingQuestionsError,\n }\n}\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle,\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(ChapterFeelingQuiz)","import React, {useContext, useRef, useState} from \"react\";\nimport {FlatList, View} from \"react-native\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport TextM from \"@common/components/text/TextM\";\nimport {theme} from \"@common/theme/theme\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport FeelingQuizItem from \"@common/chapters/feeling-quiz/FeelingQuizItem\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\n\nconst FeelingQuiz = (props) => {\n const {\n control,\n goToNextStep,\n register,\n errors,\n serverError,\n setFormValues,\n field,\n formValues,\n chapterName\n } = props;\n\n const flatListRef = useRef();\n const dimensions = useContext(DimensionsContext);\n const [selectedIndexes, setSelectedIndexes] = useState({\n understanding: null,\n pleasure: null,\n sense: null\n });\n const feelingQuestions = Object.values(props.feelingQuestions);\n const onSelectAnswer = (answer, type) => {\n setSelectedIndexes({\n ...selectedIndexes,\n [type]: answer\n });\n field?.onChange({\n ...selectedIndexes,\n [type]: answer\n });\n // console.log(selectedIndexes)\n };\n return (\n \n \n \n Ce n’est pas du tout vrai\n \n \n C’est totalement vrai\n \n \n \n \n \n \n \n \n selectedIndexes.understanding &&\n selectedIndexes.pleasure &&\n selectedIndexes.sense && (\n \n )\n }\n renderItem={(item) => {\n let type = null;\n for (const key in props.feelingQuestions) {\n if (props.feelingQuestions[key] === item.item) {\n type = key;\n }\n }\n return (\n \n );\n }}\n />\n \n );\n};\nconst mapStateToProps = (state) => {\n return {\n user: state.data.currentUser?.object,\n feelingQuestions: state.data.staticData?.feeling_questions,\n feelingQuestionsRequest: state.api.feelingQuestionsRequest,\n studentChapterFeelingsRequest: state.api.studentChapterFeelings?.request,\n feelingQuestionsError: state.api.feelingQuestionsError\n };\n};\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(FeelingQuiz);\n","import React, {useContext} from 'react';\nimport {TouchableOpacity, View} from \"react-native\";\nimport TextM from \"@common/components/text/TextM\";\nimport {theme} from \"@common/theme/theme\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\n\nconst FeelingQuizItem = (props) => {\n const {\n question,\n onSelectAnswer,\n type,\n selectedIndexes,\n numberOfItems = 8,\n answers = [],\n descriptions = [],\n labels\n } = props;\n\n const dimensions = useContext(DimensionsContext);\n\n const renderAnswers = () => {\n const items = answers.length ? answers : Array.from({length: numberOfItems - 1}, (_, i) => (i + 1));\n return items.map((answer, index) => {\n const isSelected = selectedIndexes[type] === index + 1;\n\n return (\n \n onSelectAnswer(index + 1, type)}\n >\n \n {answer}\n \n \n \n {isSelected ? labels[index] : \" \"}\n \n \n );\n });\n };\n\n const renderDescription = () => {\n const selectedIndex = selectedIndexes[type];\n if (selectedIndex && descriptions[selectedIndex - 1]) {\n return (\n \n \n {labels[selectedIndex - 1]}\n \n \n {descriptions[selectedIndex - 1]}\n \n \n );\n }\n return null;\n };\n\n return (\n \n \n {question}\n \n \n {renderAnswers()}\n \n {renderDescription()}\n \n );\n};\n\nexport default FeelingQuizItem;\n","import {useNavigation} from \"@react-navigation/native\";\nimport {useSelector} from \"react-redux\";\n\nconst useLaunchActivity = () => {\n\n const navigation = useNavigation();\n\n const user = useSelector(state => state.data?.currentUser?.object)\n\n const navigateToActivityScreen = (activityData, navigationType = \"push\", noFeeling = false) => {\n // console.log(activityData)\n const data = {\n chapterName: activityData?.student_chapter?.chapter?.name ?? activityData?.chapterName,\n chapterId: activityData?.student_chapter?.id ?? activityData?.chapterId,\n activityTemplateId: activityData?.activity_template_id ?? activityData?.activityTemplateId,\n activityId: activityData?.activityId ?? activityData?.id,\n schoolSubjectId: activityData?.school_subject_id ?? activityData?.schoolSubjectId,\n challengeId: activityData?.challengeId,\n againActivityId: activityData?.againActivityId\n }\n // const lastFeelingSentAt = activityData?.student_chapter?.last_feeling_sent_at ?? activityData?.lastFeelingSentAt\n\n // const with condition : all last_feeling_sent_at are either >= 7 days or null, for all ongoing_student_chapters of currentUser\n // const ongoingStudentChapters = user?.ongoing_student_chapters\n // const allLastFeelingSentAt = ongoingStudentChapters?.map(ongoingStudentChapter => ongoingStudentChapter?.last_feeling_sent_at)\n // const allLastFeelingSentAtAreNullOrOlderThan7Days = allLastFeelingSentAt?.reduce((prev, cur) => prev && (!cur || moment().diff(cur, 'days') >= 7), true)\n\n // if ((!lastFeelingSentAt || allLastFeelingSentAtAreNullOrOlderThan7Days) && !noFeeling && !!data?.chapterId && ongoingStudentChapters?.map(x => x?.id)?.includes(data?.chapterId) && user?.xp > 500) {\n // if (navigationType === \"push\")\n // navigation.push(\"feeling\", {\n // ...data,\n // })\n // else if (navigationType === \"replace\")\n // navigation.replace(\"feeling\", {\n // ...data,\n // })\n // } else\n\n // Feeling of progress deactivated because too overwhelming for the user\n if (navigationType === \"push\")\n navigation.push(\"activity\", {\n ...data\n })\n else if (navigationType === \"replace\")\n navigation.replace(\"activity\", {\n ...data\n })\n };\n\n return navigateToActivityScreen;\n};\n\nexport default useLaunchActivity;","import React, {useState} from 'react'\nimport {apiIdle, apiRequest} from \"../../data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {View} from \"react-native\";\nimport {FormStepper} from \"@common/components/stepper/FormStepper\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {liveService} from \"../../data/services/liveService\";\nimport LiveAvatarM from \"../../tutor/students/LiveAvatarM\";\nimport {addPhoneRinging, removePhoneRinging} from \"../../data/redux/actions/liveMode\";\nimport {liveServiceV2} from \"@data/services/liveServiceV2\";\n\nconst CallStudentsStepper = (props) => {\n\n const navigation = useNavigation()\n\n const liveSession = props.currentLiveSession\n const roomVersion = props.user.live_sessions.find((l) => l?.id === props.liveSessionId)?.live_room?.version\n\n const makeCallApiRequest = roomVersion === \"v3\" ? liveServiceV2.makeCallV2 : liveService.makeCall\n\n const defaultValues = {\n user_ids: liveSession?.users.filter(user => !user.is_tutor).map(i => i?.id)\n }\n const [formValues, setFormValues] = useState(defaultValues)\n\n const formData = [\n {\n label: \"Lancer un appel\",\n type: \"select.multiple\",\n name: \"user_ids\",\n height: 70,\n options: liveSession?.users?.filter(user => !user.is_tutor)?.map((s) => {\n return {\n leftComponent: ,\n value: s?.id,\n label: s?.display_name\n }\n }),\n defaultValue: defaultValues?.user_ids ?? []\n }\n ]\n\n const onSubmit = data => {\n if (props.makeCallRequest) return\n const formData = {...defaultValues, ...data}\n props.apiRequest(makeCallApiRequest, {id: props.liveSessionId}, formData)\n }\n\n return (\n \n\n\n !x.is_masked)}\n champion={null}\n setFormValues={setFormValues}\n formValues={formValues}\n onSubmit={onSubmit}\n submitted={props.makeCallRequest || props.makeCallV2Request}\n previousRouteName={\"live-students\"}\n submittedMessage=\"\"\n serverError={props.makeCallError || props.makeCallV2Error}\n submitButtonText=\"Appeler\"\n\n />\n \n )\n}\n\nconst mapStateToProps = state => {\n return {\n user: state.data.currentUser?.object,\n liveSessionId: state.liveMode?.liveSessionId,\n liveSessions: state.data.currentUser?.object?.live_sessions,\n currentLiveSession: state.data.currentUser?.object?.live_sessions?.find(x => x?.id === state.liveMode?.liveSessionId),\n getSessionsRequest: state.api.getLiveSession?.request,\n makeCallV2Request: state.api.makeCallV2?.request,\n makeCallRequest: state.api.makeCall?.request,\n makeCallError: state.api.makeCall?.error,\n makeCallV2Error: state.api.makeCallV2?.error,\n isLive: state.liveMode.isLiveModeEnabled\n }\n}\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle,\n addPhoneRinging,\n removePhoneRinging\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(CallStudentsStepper)","import {View} from \"react-native\";\nimport AvatarM from \"@common/components/avatar/AvatarM\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport {theme} from \"@common/theme/theme\";\nimport {Badge} from \"react-native-paper\";\nimport React from \"react\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport forbidden from \"@assets/icons/generic/forbidden.png\"\nimport photo from \"@assets/icons/activity-steps/photo.png\"\nimport { IconImageM } from \"@common/components/icons/IconsM\"\nimport TouchableRippleM from \"@common/components/button/TouchableRippleM\"\nimport { DialogM } from \"@common/components/alert/dialog/Dialog\"\n\nconst LiveAvatarM = props => {\n\n const {user, size = 50, style} = props\n const isOnline = !!props.participants?.find(x => x === user?.id)\n const isOutOfApp = props.outOfAppIds?.find((id) => id === user?.id)\n const isActivityCameraOn = props.activityCameraOnIds?.find((id) => id === user?.id)\n\n // if (!props.isLive) return null\n\n const isHandRaised = !!props.raisedHands?.find(x => x?.toString() === user?.id?.toString())\n // console.log(props.inCallUsers)\n // const participants = useParticipants();\n // const participant = participants?.find(x => user?.id === parseInt(x?.identity?.split(\".\")?.[0]))\n\n\n return \n \n {isHandRaised && }\n {user?.id !== 0 && }\n {user?.id !== 0 && isOnline && (isActivityCameraOn ? {\n DialogM.show({\n champion: \"abou\",\n text1: `📷 ${user?.display_name} est en train de prendre une photo sur son activité`,\n text2: ``,\n })\n }}\n >\n \n : isOutOfApp ? {\n DialogM.show({\n champion: \"abou\",\n text1: `🚫 ${user?.display_name} est sorti de son écran d'activité`,\n text2: `Il est sur une autre appli ou a verrouillé son appareil, c'est peut-être le moment de lui tirer les oreilles !`,\n })\n }}\n >\n \n : null)}\n {/*{participant && }*/}\n \n}\nconst mapStateToProps = state => {\n return {\n currentUser: state.data.currentUser?.object,\n liveSessions: state.data.currentUser?.object?.live_sessions,\n currentLiveSession: state.data.currentUser?.object?.live_sessions?.find(x => x?.id === state.liveMode?.liveSessionId),\n liveSessionId: state.liveMode?.liveSessionId,\n participants: state.liveMode?.liveParticipants,\n inCallUsers: state.liveMode?.inCallUsers,\n raisedHands: state.liveMode?.raisedHands,\n voiceActivityRecordingIds: state.liveMode?.voiceActivityRecordingIds,\n getSessionsRequest: state.api.getLiveSession?.request,\n isLive: state.liveMode.isLiveModeEnabled,\n outOfAppIds: state.liveMode?.outOfAppIds,\n activityCameraOnIds: state.liveMode?.activityCameraOnIds,\n }\n}\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(LiveAvatarM)","","","import React, {useContext, useEffect, useRef, useState} from \"react\";\nimport {FlatList, ScrollView, View} from \"react-native\";\nimport {ActivityIndicator} from \"react-native-paper\";\nimport {theme} from \"@common/theme/theme\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport TextM from \"@common/components/text/TextM\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {setIsLiveModeEnabled} from \"@data/redux/actions/liveMode\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport {liveService} from \"@data/services/liveService\";\nimport {useApiStatus} from \"@common/hooks/useApiStatus\";\nimport {useSafeAreaInsets} from \"react-native-safe-area-context\";\nimport {StatusBar} from \"expo-status-bar\";\nimport RNCallKeep from \"react-native-callkeep\";\nimport LiveReportComponent from \"@common/liveMode/live-report/LiveReportComponent\";\nimport SatisfactionComponent from \"@common/liveMode/SatisfactionComponent\";\nimport EndSessionStudentComment from \"./EndSessionStudentComment\";\nimport moment from \"moment\";\nimport AutoSaveTextInputM from \"../components/input/TextInputAutoSaveM\";\nimport {useNavigation} from \"@react-navigation/native\";\nimport {authService} from \"../../data/services/authService\";\nimport {plr} from \"@data/utility/Utils\";\n\nconst EndSessionScreen = (props) => {\n const occurrenceId = props.route?.params?.occurrence_id ?? null;\n\n const dimensions = useContext(DimensionsContext);\n const [message, setMessage] = useState(\"\");\n const insets = useSafeAreaInsets();\n const [liveReports, setLiveReports] = useState([]);\n const [qualityScore, setQualityScore] = useState(0);\n const [showReports, setShowReports] = useState(false);\n const [liveSessionDate, setLiveSessionDate] = useState(null);\n const [commentsSentCount, setCommentsSentCount] = useState(0);\n\n const navigation = useNavigation();\n\n // calculate average call_count, duration, activities_count and tutor_call_duration by number of students without digits after comma\n const avgStats = liveReports\n ?.filter((x) => !!x?.stats)\n ?.reduce(\n (acc, curr) => {\n return {\n call_count: acc.call_count + curr?.statistics?.call_count,\n duration: acc.duration + curr?.statistics?.duration,\n activities_count:\n acc.activities_count + curr?.statistics?.activities_count,\n tutor_call_duration:\n acc.tutor_call_duration + curr?.statistics?.tutor_call_duration,\n live_connection_duration:\n acc.live_connection_duration +\n curr?.statistics?.live_connection_duration\n };\n },\n {\n call_count: 0,\n duration: 0,\n activities_count: 0,\n tutor_call_duration: 0,\n live_connection_duration: 0\n }\n );\n\n avgStats.call_count =\n Math.round(avgStats.call_count / liveReports?.length) ?? 0;\n avgStats.duration = Math.round(avgStats.duration / liveReports?.length) ?? 0;\n avgStats.activities_count =\n Math.round(avgStats.activities_count / liveReports?.length) ?? 0;\n avgStats.tutor_call_duration =\n Math.round(avgStats.tutor_call_duration / liveReports?.length) ?? 0;\n avgStats.live_connection_duration =\n Math.round(avgStats.live_connection_duration / liveReports?.length) ?? 0;\n\n useEffect(() => {\n if (occurrenceId)\n props.apiRequest(liveService.getLiveOccurrence, {\n id: occurrenceId\n });\n }, []);\n\n useApiStatus(\n liveService.getLiveOccurrence, // api service\n null, // success message on toast (string or null)\n false, // error message on toast (true) or keep it in redux state (false)\n (successData) => {\n setLiveReports(successData?.live_reports);\n setQualityScore(successData?.tutor_live_quality_score);\n setMessage(successData?.tutor_comment);\n setCommentsSentCount(\n successData?.live_reports?.filter(\n (r) => r?.tutor_comment || r?.comment_record\n ).length\n );\n\n setLiveSessionDate(\n moment(successData?.date).format(\"dddd DD MMMM HH:mm\").toUpperCase()\n );\n },\n () => {\n }\n );\n\n const listRef = useRef(null);\n const studentCommentsListRef = useRef(null);\n const inputRef = useRef(null);\n\n const commentsNeededToBeSent = liveReports?.filter(\n (report) => !!report?.statistics\n )?.length;\n\n return (\n <>\n {props.getTodayLiveOccurrenceRequest || props.getLiveOccurrenceRequest ? (\n \n ) : (props.getLiveOccurrenceError || !occurrenceId) ? <>\n \n {props.getLiveOccurrenceError?.message || \"Une erreur est survenue\"}\n \n {\n navigation.goBack()\n }}\n label={\"Retour à l'accueil\"}\n />\n : (\n \n \n \n Live du {liveSessionDate}\n \n \n La session Live a bien été clôturée\n \n \n \n \n FAIS UN PETIT COMPTE-RENDU POUR LE SUIVI DE CHAQUE ÉLÈVE\n \n \n À destination de l'équipe pédagogique, ce compte-rendu est essentiel pour alimenter le dossier de chaque élève.\n \n \n = commentsNeededToBeSent ? theme.colors.success : theme.colors.error}\n >{commentsSentCount} /{commentsNeededToBeSent} {plr(\"effectué\", commentsSentCount)}\n \n \n \n {liveReports?.map((item, index) => {\n return \n })}\n \n \n \n \n Évalue la qualité de la plateforme sur cette session (visio, son, etc.)\n \n \n Ton retour régulier est précieux, pour nous aider à améliorer la plateforme Masteur\n \n \n \n {!!qualityScore && (\n <>\n \n {props.satisfactionSubtitles?.[qualityScore]}\n \n {\n setMessage(value);\n props.apiRequest(\n liveService.sendLiveQuality,\n {id: occurrenceId},\n {\n quality_score: qualityScore,\n comment: value\n }\n );\n }}\n />\n \n )}\n \n {\n setShowReports(!showReports);\n }}\n mode={\"outlined\"}\n label={`${showReports ? \"Masquer\" : \"Afficher\"} les rapports`}\n color={theme.colors.primary}\n style={{\n // width: \"100%\",\n alignSelf: \"center\",\n marginTop: 100\n }}\n />\n {showReports && (\n <>\n \n RAPPORTS DÉTAILLÉS\n \n\n {\n return (\n \n );\n }}\n contentContainerStyle={{\n alignSelf: \"center\",\n alignItems: \"flex-start\",\n paddingHorizontal: IS_WEB ? 0 : 10\n }}\n style={\n {\n // width: dimensions.width,\n }\n }\n />\n \n )}\n\n {\n if (navigation.canGoBack()) navigation.goBack();\n else navigation.replace(\"menu\");\n props.apiRequest(authService.getUser);\n }}\n label={\"Terminer\"}\n color={theme.colors.success}\n disabled={commentsSentCount < commentsNeededToBeSent}\n style={{\n // width: \"100%\",\n alignSelf: \"center\",\n marginTop: 10,\n marginBottom: 40\n }}\n />\n \n )}\n \n \n );\n};\nconst mapStateToProps = (state) => {\n return {\n user: state.data.currentUser?.object,\n currentLiveSession: state.data.currentUser?.object?.live_sessions?.find(\n (x) => x?.id === state.liveMode?.liveSessionId\n ),\n liveSessionId: state.liveMode?.liveSessionId,\n liveSessions: state.data.currentUser?.object?.live_sessions,\n participants: state.liveMode?.liveParticipants,\n getTodayLiveOccurrenceRequest: state.api.getTodayLiveOccurrence?.request,\n getTodayLiveOccurrenceError: state.api.getTodayLiveOccurrence?.error,\n getLiveOccurrenceRequest: state.api.getLiveOccurrence?.request,\n getLiveOccurrenceError: state.api.getLiveOccurrence?.error,\n satisfactionSubtitles: state.data.staticData?.satisfaction_subtitles\n };\n};\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle,\n setIsLiveModeEnabled\n};\n\nexport default connect(mapStateToProps, mapDispatchToProps)(EndSessionScreen);\n","import { NativeModules, Platform, Alert } from 'react-native';\n\nimport { listeners, emit } from './actions';\n\nconst RNCallKeepModule = NativeModules.RNCallKeep;\nconst isIOS = Platform.OS === 'ios';\nconst supportConnectionService = !isIOS && Platform.Version >= 23;\n\nconst AudioSessionCategoryOption = {\n mixWithOthers: 0x1,\n duckOthers: 0x2,\n interruptSpokenAudioAndMixWithOthers: 0x11,\n allowBluetooth: 0x4,\n allowBluetoothA2DP: 0x20,\n allowAirPlay: 0x40,\n defaultToSpeaker: 0x8,\n overrideMutedMicrophoneInterruption: 0x80,\n}\n\nconst AudioSessionMode = {\n default: 'AVAudioSessionModeDefault',\n gameChat: 'AVAudioSessionModeGameChat',\n measurement: 'AVAudioSessionModeMeasurement',\n moviePlayback: 'AVAudioSessionModeMoviePlayback',\n spokenAudio: 'AVAudioSessionModeSpokenAudio',\n videoChat: 'AVAudioSessionModeVideoChat',\n videoRecording: 'AVAudioSessionModeVideoRecording',\n voiceChat: 'AVAudioSessionModeVoiceChat',\n voicePrompt: 'AVAudioSessionModeVoicePrompt',\n}\n\nconst CONSTANTS = {\n END_CALL_REASONS: {\n FAILED: 1,\n REMOTE_ENDED: 2,\n UNANSWERED: 3,\n ANSWERED_ELSEWHERE: 4,\n DECLINED_ELSEWHERE: isIOS ? 5 : 2, // make declined elsewhere link to \"Remote ended\" on android because that's kinda true\n MISSED: isIOS ? 2 : 6,\n },\n};\n\nexport { emit, CONSTANTS, AudioSessionCategoryOption, AudioSessionMode };\n\nclass EventListener {\n constructor(type, listener, callkeep) {\n this._type = type;\n this._listener = listener;\n this._callkeep = callkeep;\n }\n\n remove = () => {\n this._callkeep.removeEventListener(this._type, this._listener);\n };\n}\n\nclass RNCallKeep {\n constructor() {\n this._callkeepEventHandlers = new Map();\n }\n\n addEventListener = (type, handler) => {\n const listener = listeners[type](handler);\n\n const listenerSet = this._callkeepEventHandlers.get(type) ?? new Set();\n listenerSet.add(listener);\n\n this._callkeepEventHandlers.set(type, listenerSet);\n\n return new EventListener(type, listener, this);\n };\n\n removeEventListener = (type, listener = undefined) => {\n const listenerSet = this._callkeepEventHandlers.get(type);\n if (!listenerSet) {\n return;\n }\n\n if (listener) {\n listenerSet.delete(listener);\n listener.remove();\n if (listenerSet.size <= 0) {\n this._callkeepEventHandlers.delete(type);\n }\n } else {\n listenerSet.forEach((listener) => {\n listener.remove();\n });\n this._callkeepEventHandlers.delete(type);\n }\n };\n\n setup = async (options) => {\n if (!isIOS) {\n return this._setupAndroid(options.android);\n }\n\n return this._setupIOS(options.ios);\n };\n\n setSettings = (settings) => RNCallKeepModule.setSettings(settings[isIOS ? 'ios' : 'android']);\n\n registerPhoneAccount = (options) => {\n if (isIOS) {\n return;\n }\n RNCallKeepModule.registerPhoneAccount(options.android);\n };\n\n registerAndroidEvents = () => {\n if (isIOS) {\n return;\n }\n RNCallKeepModule.registerEvents();\n };\n\n unregisterAndroidEvents = () => {\n if (isIOS) {\n return;\n }\n RNCallKeepModule.unregisterEvents();\n };\n\n hasDefaultPhoneAccount = async (options) => {\n if (!isIOS) {\n return this._hasDefaultPhoneAccount(options);\n }\n\n return;\n };\n\n displayIncomingCall = (\n uuid,\n handle,\n localizedCallerName = '',\n handleType = 'number',\n hasVideo = false,\n options = null\n ) => {\n if (!isIOS) {\n RNCallKeepModule.displayIncomingCall(uuid, handle, localizedCallerName, hasVideo);\n return;\n }\n\n // should be boolean type value\n let supportsHolding = !!(options?.ios?.supportsHolding ?? true);\n let supportsDTMF = !!(options?.ios?.supportsDTMF ?? true);\n let supportsGrouping = !!(options?.ios?.supportsGrouping ?? true);\n let supportsUngrouping = !!(options?.ios?.supportsUngrouping ?? true);\n\n RNCallKeepModule.displayIncomingCall(\n uuid,\n handle,\n handleType,\n hasVideo,\n localizedCallerName,\n supportsHolding,\n supportsDTMF,\n supportsGrouping,\n supportsUngrouping\n );\n };\n\n checkIsInManagedCall = async () => isIOS? false: RNCallKeepModule.checkIsInManagedCall();\n\n answerIncomingCall = (uuid) => {\n RNCallKeepModule.answerIncomingCall(uuid);\n };\n\n startCall = (uuid, handle, contactIdentifier, handleType = 'number', hasVideo = false) => {\n if (!isIOS) {\n RNCallKeepModule.startCall(uuid, handle, contactIdentifier, hasVideo);\n return;\n }\n\n RNCallKeepModule.startCall(uuid, handle, contactIdentifier, handleType, hasVideo);\n };\n\n checkPhoneAccountEnabled = async () => {\n if (isIOS) {\n return;\n }\n\n return RNCallKeepModule.checkPhoneAccountEnabled();\n };\n\n isConnectionServiceAvailable = async () => {\n if (isIOS) {\n return true;\n }\n\n return RNCallKeepModule.isConnectionServiceAvailable();\n };\n\n reportConnectingOutgoingCallWithUUID = (uuid) => {\n //only available on iOS\n if (isIOS) {\n RNCallKeepModule.reportConnectingOutgoingCallWithUUID(uuid);\n }\n };\n\n reportConnectedOutgoingCallWithUUID = (uuid) => {\n //only available on iOS\n if (isIOS) {\n RNCallKeepModule.reportConnectedOutgoingCallWithUUID(uuid);\n }\n };\n\n reportEndCallWithUUID = (uuid, reason) => RNCallKeepModule.reportEndCallWithUUID(uuid, reason);\n\n /*\n * Android explicitly states we reject a call\n * On iOS we just notify of an endCall\n */\n rejectCall = (uuid) => {\n if (!isIOS) {\n RNCallKeepModule.rejectCall(uuid);\n } else {\n RNCallKeepModule.endCall(uuid);\n }\n };\n\n isCallActive = async (uuid) => await RNCallKeepModule.isCallActive(uuid);\n\n getCalls = () => {\n if (isIOS) {\n return RNCallKeepModule.getCalls();\n }\n };\n\n endCall = (uuid) => RNCallKeepModule.endCall(uuid);\n\n endAllCalls = () => RNCallKeepModule.endAllCalls();\n\n supportConnectionService = () => supportConnectionService;\n\n hasPhoneAccount = async () => (isIOS ? true : await RNCallKeepModule.hasPhoneAccount());\n\n hasOutgoingCall = async () => (isIOS ? null : await RNCallKeepModule.hasOutgoingCall());\n\n setMutedCall = (uuid, shouldMute) => {\n RNCallKeepModule.setMutedCall(uuid, shouldMute);\n };\n\n sendDTMF = (uuid, key) => RNCallKeepModule.sendDTMF(uuid, key);\n /**\n * @description when Phone call is active, Android control the audio service via connection service. so this function help to toggle the audio to Speaker or wired/ear-piece or vice-versa\n * @param {*} uuid\n * @param {*} routeSpeaker\n * @returns Audio route state of audio service\n */\n toggleAudioRouteSpeaker = (uuid, routeSpeaker) => isIOS ? null : RNCallKeepModule.toggleAudioRouteSpeaker(uuid, routeSpeaker);\n\n getAudioRoutes = () => RNCallKeepModule.getAudioRoutes();\n\n setAudioRoute = (uuid, inputName) => RNCallKeepModule.setAudioRoute(uuid, inputName);\n\n checkIfBusy = () =>\n isIOS ? RNCallKeepModule.checkIfBusy() : Promise.reject('RNCallKeep.checkIfBusy was called from unsupported OS');\n\n checkSpeaker = () =>\n isIOS ? RNCallKeepModule.checkSpeaker() : Promise.reject('RNCallKeep.checkSpeaker was called from unsupported OS');\n\n setAvailable = (state) => {\n if (isIOS) {\n return;\n }\n\n // Tell android that we are able to make outgoing calls\n RNCallKeepModule.setAvailable(state);\n };\n\n setForegroundServiceSettings = (settings) => {\n if (isIOS) {\n return;\n }\n\n RNCallKeepModule.setForegroundServiceSettings(settings);\n };\n\n canMakeMultipleCalls = (state) => {\n if (isIOS) {\n return;\n }\n\n RNCallKeepModule.canMakeMultipleCalls(state);\n };\n\n setCurrentCallActive = (callUUID) => {\n if (isIOS) {\n return;\n }\n\n RNCallKeepModule.setCurrentCallActive(callUUID);\n };\n\n updateDisplay = (uuid, displayName, handle, options = null) => {\n if (!isIOS) {\n RNCallKeepModule.updateDisplay(uuid, displayName, handle);\n return;\n }\n\n let iosOptions = {};\n if (options && options.ios) {\n iosOptions = {\n ...options.ios,\n };\n }\n RNCallKeepModule.updateDisplay(uuid, displayName, handle, iosOptions);\n };\n\n setOnHold = (uuid, shouldHold) => RNCallKeepModule.setOnHold(uuid, shouldHold);\n\n setConnectionState = (uuid, state) => isIOS ? null : RNCallKeepModule.setConnectionState(uuid, state);\n\n setReachable = () => RNCallKeepModule.setReachable();\n\n // @deprecated\n reportUpdatedCall = (uuid, localizedCallerName) => {\n console.warn('RNCallKeep.reportUpdatedCall is deprecated, use RNCallKeep.updateDisplay instead');\n\n return isIOS\n ? RNCallKeepModule.reportUpdatedCall(uuid, localizedCallerName)\n : Promise.reject('RNCallKeep.reportUpdatedCall was called from unsupported OS');\n };\n\n _setupIOS = async (options) =>\n new Promise((resolve, reject) => {\n if (!options.appName) {\n reject('RNCallKeep.setup: option \"appName\" is required');\n }\n if (typeof options.appName !== 'string') {\n reject('RNCallKeep.setup: option \"appName\" should be of type \"string\"');\n }\n\n resolve(RNCallKeepModule.setup(options));\n });\n\n _setupAndroid = async (options) => {\n RNCallKeepModule.setup(options);\n\n if (options.selfManaged) {\n return false;\n }\n\n const showAccountAlert = await RNCallKeepModule.checkPhoneAccountPermission(options.additionalPermissions || []);\n const shouldOpenAccounts = await this._alert(options, showAccountAlert);\n\n if (shouldOpenAccounts) {\n RNCallKeepModule.openPhoneAccounts();\n return true;\n }\n\n return false;\n };\n\n _hasDefaultPhoneAccount = async (options) => {\n const hasDefault = await RNCallKeepModule.checkDefaultPhoneAccount();\n const shouldOpenAccounts = await this._alert(options, hasDefault);\n\n if (shouldOpenAccounts) {\n RNCallKeepModule.openPhoneAccountSettings();\n }\n };\n\n _alert = async (options, condition) =>\n new Promise((resolve, reject) => {\n if (!condition) {\n return resolve(false);\n }\n\n Alert.alert(\n options.alertTitle,\n options.alertDescription,\n [\n {\n text: options.cancelButton,\n onPress: reject,\n style: 'cancel',\n },\n { text: options.okButton, onPress: () => resolve(true) },\n ],\n { cancelable: true },\n );\n });\n\n backToForeground() {\n if (isIOS) {\n return;\n }\n\n NativeModules.RNCallKeep.backToForeground();\n }\n\n getInitialEvents() {\n return RNCallKeepModule.getInitialEvents();\n }\n\n clearInitialEvents() {\n return RNCallKeepModule.clearInitialEvents();\n }\n}\n\nexport default new RNCallKeep();\n","/**\n * Copyright (c) Nicolas Gallagher.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n *\n * \n */\n\nclass Alert {\n static alert() {}\n}\nexport default Alert;","import { NativeModules, NativeEventEmitter, Platform } from 'react-native';\n\nconst RNCallKeepModule = NativeModules.RNCallKeep;\nconst eventEmitter = new NativeEventEmitter(RNCallKeepModule);\n\nconst RNCallKeepDidReceiveStartCallAction = 'RNCallKeepDidReceiveStartCallAction';\nconst RNCallKeepPerformAnswerCallAction = 'RNCallKeepPerformAnswerCallAction';\nconst RNCallKeepPerformEndCallAction = 'RNCallKeepPerformEndCallAction';\nconst RNCallKeepDidActivateAudioSession = 'RNCallKeepDidActivateAudioSession';\nconst RNCallKeepDidDeactivateAudioSession = 'RNCallKeepDidDeactivateAudioSession';\nconst RNCallKeepDidDisplayIncomingCall = 'RNCallKeepDidDisplayIncomingCall';\nconst RNCallKeepDidPerformSetMutedCallAction = 'RNCallKeepDidPerformSetMutedCallAction';\nconst RNCallKeepDidToggleHoldAction = 'RNCallKeepDidToggleHoldAction';\nconst RNCallKeepDidPerformDTMFAction = 'RNCallKeepDidPerformDTMFAction';\nconst RNCallKeepProviderReset = 'RNCallKeepProviderReset';\nconst RNCallKeepCheckReachability = 'RNCallKeepCheckReachability';\nconst RNCallKeepDidLoadWithEvents = 'RNCallKeepDidLoadWithEvents';\nconst RNCallKeepShowIncomingCallUi = 'RNCallKeepShowIncomingCallUi';\nconst RNCallKeepOnSilenceIncomingCall = 'RNCallKeepOnSilenceIncomingCall';\nconst RNCallKeepOnIncomingConnectionFailed = 'RNCallKeepOnIncomingConnectionFailed';\nconst RNCallKeepDidChangeAudioRoute = 'RNCallKeepDidChangeAudioRoute';\nconst RNCallKeepHasActiveCall = 'RNCallKeepHasActiveCall';\nconst isIOS = Platform.OS === 'ios';\n\nconst didReceiveStartCallAction = handler => {\n if (isIOS) {\n // Tell CallKeep that we are ready to receive `RNCallKeepDidReceiveStartCallAction` event and prevent delay\n RNCallKeepModule._startCallActionEventListenerAdded();\n }\n\n return eventEmitter.addListener(RNCallKeepDidReceiveStartCallAction, (data) => handler(data));\n};\n\nconst answerCall = handler =>\n eventEmitter.addListener(RNCallKeepPerformAnswerCallAction, (data) => handler(data));\n\nconst endCall = handler =>\n eventEmitter.addListener(RNCallKeepPerformEndCallAction, (data) => handler(data));\n\nconst didChangeAudioRoute = handler =>\n eventEmitter.addListener(RNCallKeepDidChangeAudioRoute, handler);\n\nconst didActivateAudioSession = handler =>\n eventEmitter.addListener(RNCallKeepDidActivateAudioSession, handler);\n\nconst didDeactivateAudioSession = handler =>\n eventEmitter.addListener(RNCallKeepDidDeactivateAudioSession, handler);\n\nconst didDisplayIncomingCall = handler => eventEmitter.addListener(RNCallKeepDidDisplayIncomingCall, data => {\n // On Android the payload parameter is sent a String\n // As it requires too much code on Android to convert it to WritableMap, let's do it here.\n if (data.payload && typeof data.payload === 'string') {\n try {\n data.payload = JSON.parse(data.payload);\n } catch (_) {\n }\n }\n handler(data);\n});\n\nconst didPerformSetMutedCallAction = handler =>\n eventEmitter.addListener(RNCallKeepDidPerformSetMutedCallAction, (data) => handler(data));\n\nconst onHasActiveCall = handler =>\n eventEmitter.addListener(RNCallKeepHasActiveCall, handler);\n\nconst didToggleHoldCallAction = handler =>\n eventEmitter.addListener(RNCallKeepDidToggleHoldAction, handler);\n\nconst didPerformDTMFAction = handler =>\n eventEmitter.addListener(RNCallKeepDidPerformDTMFAction, (data) => handler(data));\n\nconst didResetProvider = handler =>\n eventEmitter.addListener(RNCallKeepProviderReset, handler);\n\nconst checkReachability = handler =>\n eventEmitter.addListener(RNCallKeepCheckReachability, handler);\n\nconst didLoadWithEvents = handler =>\n eventEmitter.addListener(RNCallKeepDidLoadWithEvents, handler);\n\nconst showIncomingCallUi = handler =>\n eventEmitter.addListener(RNCallKeepShowIncomingCallUi, (data) => handler(data));\n\nconst silenceIncomingCall = handler =>\n eventEmitter.addListener(RNCallKeepOnSilenceIncomingCall, (data) => handler(data));\n\nconst createIncomingConnectionFailed = handler =>\n eventEmitter.addListener(RNCallKeepOnIncomingConnectionFailed, (data) => handler(data));\n\nexport const emit = (eventName, payload) => eventEmitter.emit(eventName, payload);\n\nexport const listeners = {\n didReceiveStartCallAction,\n answerCall,\n endCall,\n didActivateAudioSession,\n didDeactivateAudioSession,\n didDisplayIncomingCall,\n didPerformSetMutedCallAction,\n didToggleHoldCallAction,\n didPerformDTMFAction,\n didResetProvider,\n checkReachability,\n didLoadWithEvents,\n showIncomingCallUi,\n silenceIncomingCall,\n createIncomingConnectionFailed,\n didChangeAudioRoute,\n onHasActiveCall\n};\n","import React, {useContext, useRef, useState} from \"react\";\nimport {Platform, TouchableOpacity, View} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport moment from \"moment\";\nimport TextM from \"@common/components/text/TextM\";\nimport {ChampionImageM} from \"../../../student/champions/ChampionImageM\";\nimport {DimensionsContext, IS_WEB} from \"@common/utils/mobileUtils\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport {capitalize, hoursMinutesAndSecondsFromSeconds} from \"@data/utility/Utils\";\nimport videoIcon from \"../../../../assets/icons/generic/video.png\";\nimport chronometer from \"../../../../assets/icons/generic/chronometer.png\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {setOngoingActivity} from \"@data/redux/actions/activity\";\nimport {setIsLiveModeEnabled} from \"@data/redux/actions/liveMode\";\nimport {connect} from \"react-redux\";\nimport FilledButtonM from \"@common/components/button/FilledButtonM\";\nimport * as WebBrowser from \"expo-web-browser\";\nimport liveIcon from \"../../../../assets/icons/generic/live.png\";\nimport ChapterItemComponent from \"@common/chapters/ChapterItemComponent\";\nimport {Divider} from \"react-native-paper\";\nimport SatisfactionComponent from \"@common/liveMode/SatisfactionComponent\";\n\nconst engagementScores = {\n assiduity: {\n color: theme.colors.success,\n name: \"Présence\",\n total: 40\n },\n interaction: {\n color: theme.colors.phone,\n name: \"Participation\",\n total: 30\n },\n productivity: {\n color: theme.colors.purple,\n name: \"Productivité\",\n total: 30\n }\n};\n\nconst engagementBarHeight = 30;\n\nfunction LiveReportActivityItem({data, report}) {\n const activityTemplate = report?.activity_templates?.find(\n (a) => a.id === data?.activity_template_id\n );\n\n return (\n \n \n {data?.digit}\n \n \n \n {data?.label}\n \n \n );\n}\n\nexport const formatHoursMinutesAndSeconds = (duration, fontSize = 20, noSeconds = false) => {\n const [hours, minutes, seconds] = hoursMinutesAndSecondsFromSeconds(duration);\n\n return (\n <>\n {hours > 0 && (\n <>\n {hours}{\" \"}\n \n h\n {\" \"}\n \n )}\n {minutes}{\" \"}\n \n min\n \n {!noSeconds && <>\n {\" \"}\n {seconds}{\" \"}\n \n s\n \n }\n\n \n );\n};\n\nfunction EngagementSubScoreBar({scoreDetails, scoreKey, width}) {\n const totalWidth = width;\n\n const elementWidth = scoreDetails?.score\n ? totalWidth * (scoreDetails?.score / 100)\n : 0;\n\n return (\n {\n }}\n />\n );\n}\n\nfunction EngagementSubScoreTitleComponent({\n scoreDetails,\n scoreKey,\n detailsVisible\n }) {\n return (\n \n \n {engagementScores?.[scoreKey]?.name?.toUpperCase()}{\" \"}\n {scoreDetails?.score ?? \"-\"}{\" \"}\n \n /{scoreDetails?.score_max}\n {\" \"}\n \n {detailsVisible && (\n \n {scoreDetails?.details?.map((item, index) => {\n return (\n \n \n {item?.name} {item?.score}{\" \"}\n \n /{item?.score_max}\n \n \n \n {item?.value} {item?.unity}\n \n \n );\n })}\n \n )}\n \n );\n}\n\nfunction EngagementSubScoreTitle({\n scoreDetails,\n scoreKey,\n detailsVisible,\n setDetailsVisible,\n disableScoreButton = false\n }) {\n return !disableScoreButton ? (\n {\n setDetailsVisible(!detailsVisible);\n }}\n >\n \n \n ) : (\n \n \n \n );\n}\n\nexport function EngagementScoreBar({\n scores,\n forceVerticalDetails = false,\n width,\n noProgressBar = false,\n disableScoreButton = false,\n style\n }) {\n const [detailsVisible, setDetailsVisible] = useState(false);\n const dimensions = useContext(DimensionsContext);\n\n return (\n <>\n \n {Object.keys(engagementScores).map((key) => {\n return (\n \n );\n })}\n \n {!noProgressBar && (\n \n {Object.keys(engagementScores).map((key) => {\n return (\n \n );\n })}\n \n )}\n \n );\n}\n\nconst LiveReportComponent = (props) => {\n const {\n liveReport,\n withTitle = false,\n style,\n forceVerticalDetails = false,\n noDate = false\n } = props;\n const report = liveReport;\n const schoolSubjects = report?.school_subjects;\n const sessionDate = capitalize(\n moment(report?.statistics?.live_date_time).format(\"dddd DD MMMM HH:mm\")\n );\n const validatedActivities = report?.statistics?.validated_activities;\n const todoActivities = report?.statistics?.todo_activities;\n const chapters = report?.statistics?.ongoing_student_chapters;\n\n const flatListRef = useRef();\n const inputRef = useRef();\n\n const dimensions = useContext(DimensionsContext);\n\n const isV1Report =\n report && !!report?.statistics\n ? !(\"ongoing_student_chapters\" in report.statistics)\n : false;\n\n const boxStyle = {\n borderWidth: 2,\n borderColor: theme.colors.lightMore,\n borderRadius: theme.roundness,\n padding: 20,\n backgroundColor: theme.colors.white,\n marginTop: 20,\n width: dimensions?.width - 60,\n justifyContent: \"center\",\n alignItems: \"center\"\n };\n\n return (\n <>\n \n {withTitle && (\n \n RAPPORT DE LIVE\n \n )}\n {!noDate && (\n \n {sessionDate}\n \n )}\n \n {report?.student?.display_name}\n \n \n \n {!report?.statistics\n ? \"Malheureusement, nous n’avons pas eu la chance de te voir aujourd’hui. Quel dommage...\"\n : report?.statistics?.CTAS?.zoe}\n \n {!!report?.statistics?.CTAS?.sam && (\n {\n const ctaUrl = \"https://calendly.com/nawfal-masteur/soutien_scolaire\" //report?.subscribe_url;\n if (IS_WEB) {\n window.open(ctaUrl);\n } else {\n WebBrowser.openBrowserAsync(ctaUrl);\n }\n }}\n />\n )}\n\n {!!report?.statistics?.CTAS?.sam &&\n report?.satisfaction &&\n report?.satisfaction >= 5 && (\n \n \n Qu'a pensé{\" \"}\n {report?.student?.display_name?.substring(\n 0,\n report?.student?.display_name?.length - 3\n )}{\" \"}\n de cette session LIVE ?\n \n \n \n )}\n\n {validatedActivities?.length + todoActivities?.length > 0 &&\n isV1Report &&\n !!report?.statistics && (\n \n \n NOTIONS ABORDÉES\n \n \n {report?.statistics?.concepts?.map((c, index) => {\n const schoolSubject = schoolSubjects?.find(\n (s) => s.id === c.school_subject_id\n );\n return (\n \n \n \n \n {schoolSubject?.name}\n \n \n {c?.concepts?.join(\", \")}\n \n \n \n );\n })}\n \n \n )}\n\n {!isV1Report && !!report?.statistics && (\n <>\n \n \n SCORE D'ENGAGEMENT SUR LA SESSION\n \n \n \n {report?.statistics?.scores?.total_score}{\" \"}\n \n /100\n \n \n \n\n \n \n \n )}\n\n {chapters?.length > 0 && !isV1Report && !!report?.statistics && (\n \n \n AVANCEMENT DES CHAPITRES\n \n <>\n {chapters?.map((item, index) => {\n const chapterInfos = {...item, ...item?.chapter};\n\n return \n })}\n \n \n )}\n {isV1Report && !!report?.statistics && <>\n \n \n TEMPS CONNECTÉ.E AU LIVE\n \n \n \n \n {formatHoursMinutesAndSeconds(\n report?.statistics?.live_connection_duration\n )}\n \n \n \n \n \n TEMPS D'EXPLICATION\n \n \n \n \n {formatHoursMinutesAndSeconds(\n report?.statistics?.tutor_call_duration\n )}\n \n \n \n \n \n TEMPS DE PRODUCTION CHRONOMÉTRÉ\n \n \n \n \n {formatHoursMinutesAndSeconds(report?.statistics?.duration)}\n \n \n \n }\n\n {validatedActivities?.length + todoActivities?.length > 0 &&\n !!report?.statistics && (\n \n {validatedActivities?.length > 0 && (\n <>\n \n TRAVAIL VALIDÉ ✅\n \n {validatedActivities?.map((v, index) => (\n \n ))}\n \n )}\n\n {validatedActivities?.length > 0 &&\n todoActivities?.length > 0 && (\n \n )}\n\n {todoActivities?.length > 0 && (\n <>\n \n TRAVAIL À FAIRE 📋\n \n {todoActivities?.map((todo, index) => (\n \n ))}\n \n )}\n \n )}\n\n {!!report?.statistics?.CTAS?.sam && (\n <>\n \n \n {report?.statistics?.CTAS?.sam}\n \n\n {\n const ctaUrl = \"https://calendly.com/nawfal-masteur/soutien_scolaire\" //report?.subscribe_url;\n if (IS_WEB) {\n window.open(ctaUrl);\n } else {\n WebBrowser.openBrowserAsync(ctaUrl);\n }\n }}\n />\n \n )}\n \n \n );\n};\nconst mapStateToProps = (state) => {\n return {\n getLiveReportRequest: state.api.getLiveReport?.request,\n getLiveReportError: state.api.getLiveReport?.error\n };\n};\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle,\n setOngoingActivity,\n setIsLiveModeEnabled\n};\n\nexport default connect(\n mapStateToProps,\n mapDispatchToProps\n)(LiveReportComponent);\n","","","import React, {useContext, useEffect, useState} from \"react\";\nimport {TouchableOpacity, View} from \"react-native\";\nimport {theme} from \"@common/theme/theme\";\nimport {DimensionsContext} from \"@common/utils/mobileUtils\";\nimport {apiIdle, apiRequest} from \"@data/redux/actions/api\";\nimport {connect} from \"react-redux\";\nimport {IconImageM} from \"@common/components/icons/IconsM\";\nimport TextM from \"@common/components/text/TextM\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\nimport {DialogM} from \"@common/components/alert/dialog/Dialog\";\nimport {chaptersService} from \"@data/services/chaptersService\";\nimport {hasRole} from \"@data/utility/ability\";\nimport {ActivityIndicator} from \"react-native-paper\";\nimport {useApiStatus} from \"@common/hooks/useApiStatus\";\nimport {formatRelativeDateTime} from \"@data/utility/Utils\";\nimport {ProgressBarM} from \"@common/components/progress/ProgressBarM\";\nimport {ActivityLevelBadge} from \"@common/chapters/ActivityLevelBadge\";\n\nconst ChapterItemComponent = (props) => {\n\n const {\n chapter,\n onPress = () => {\n },\n animated = false,\n isHighlighted = false,\n liveReportMode = false,\n validatedActivities = 0,\n todoActivities = 0,\n style,\n withParentChapter = false,\n renderChapterOnly = false,\n interviewReportMode = false,\n width = null\n } = props\n\n const dimensions = useContext(DimensionsContext);\n const schoolSubject = props.schoolSubjects?.find(\n (subject) =>\n subject.id?.toString() === chapter?.school_subject_id?.toString()\n );\n // const differenceInDays = moment().diff(moment(chapter?.last_set_ongoing_at), 'days');\n const differenceInDaysString = formatRelativeDateTime(\n chapter?.last_set_ongoing_at,\n true\n );\n const color = schoolSubject?.color ?? theme.colors.info;\n\n const xpTotal = chapter?.xp_total;\n\n const xpMax = Math.max(props.xpToValidateChapter ?? 350, xpTotal);\n const widthMax = width ? width : liveReportMode\n ? dimensions.width - 100\n : dimensions.width - 40;\n\n const xpTotalWidth = (xpTotal / xpMax) * widthMax;\n\n const level = chapter?.student_chapters?.[0]?.level ?? chapter?.level;\n\n //Animation setup\n const [triggerAnimation, setTriggerAnimation] = useState(false);\n\n useEffect(() => {\n if (animated) {\n setTimeout(() => {\n setTriggerAnimation(true);\n }, 500);\n }\n }, []);\n\n const chapterItemComponentContent = () => (\n \n \n \n {schoolSubject?.icon && (\n \n )}\n \n \n {chapter?.name}\n \n {withParentChapter && \n {chapter?.parent_chapter?.name\n ? chapter?.parent_chapter?.name + \" - \"\n : \"\"}\n {schoolSubject?.name} - {chapter?.class}\n }\n {level && chapter?.id && !renderChapterOnly && }\n \n \n \n {\n //liveReportMode && chapter?.ongoing === 0 ? <>\n // \n // \n // \n // {chapter.last_tutor_comment}\n // \n // \n // \n // \n // :\n liveReportMode && (\n \n {validatedActivities > 0 && (\n \n {\"+\" +\n validatedActivities +\n (validatedActivities > 1 ? \" travaux\" : \" travail\") +\n \" envoyé\" +\n (validatedActivities > 1 ? \"s\" : \"\")}\n \n )}\n {todoActivities > 0 ? (\n \n {\"+\" +\n todoActivities +\n (todoActivities > 1 ? \" travaux\" : \" travail\") +\n \" à faire\"}\n \n ) : validatedActivities > 0 && interviewReportMode ? (\n \n OBJECTIF ATTEINT ✅\n \n ) : null}\n \n )\n }\n {!renderChapterOnly && \n {!!xpTotal && (\n \n \n {chapter?.xp_gained ?? 0}\n {\" /\" + xpTotal} \n \n \n )}\n {!!xpTotalWidth && (\n \n {barsElements}\n \n )}\n {!!xpTotalWidth && (\n \n 0\n ? theme.colors.accent\n : theme.colors.success\n }\n style={{\n top: -17,\n position: \"absolute\",\n right: -14.5,\n // opacity: chapter?.id && (chapter?.ongoing === 0) ? 0.5 : 1,\n }}\n />\n 0\n ? theme.colors.accent\n : theme.colors.success,\n width: 2.4,\n height: \"100%\",\n // opacity: chapter?.id && (chapter?.ongoing === 0) ? 0.5 : 1,\n }}\n >\n \n )}\n }\n \n );\n\n const barsElements = chapter?.xp_gained_steps\n ?.map((stepXp, index) => {\n const firstNewIndex =\n chapter?.xp_gained_steps?.length - validatedActivities;\n const hasNew = validatedActivities > 0;\n\n const barColor = !hasNew\n ? liveReportMode\n ? theme.colors.successGray\n : theme.colors.success\n : index >= firstNewIndex\n ? theme.colors.success\n : theme.colors.successGray;\n const barWidth = (stepXp / xpMax) * widthMax - 2;\n\n const isLast =\n index === chapter?.xp_gained_steps?.length - 1 &&\n chapter?.xp_remaining_steps?.length === 0;\n const isTotalMax = xpTotal === xpMax;\n\n return (\n \n {animated && index === chapter?.xp_gained_steps?.length - 1 ? (\n \n ) : (\n \n )}\n {/**/}\n \n );\n })\n ?.concat(\n chapter?.xp_remaining_steps?.map((stepXp, index) => {\n const barColor = theme.colors.lightMore;\n const barWidth = (stepXp / xpMax) * widthMax - 2;\n\n const isLast = index === chapter?.xp_remaining_steps?.length - 1;\n const isTotalMax = xpTotal === xpMax;\n\n return (\n \n {/**/}\n \n );\n })\n );\n\n return props.forceDisabled ? (\n {chapterItemComponentContent()}\n ) : (\n \n {chapterItemComponentContent()}\n \n );\n};\nconst mapStateToProps = (state) => {\n return {\n user: state.data.currentUser?.object,\n schoolSubjects: state.data.staticData?.school_subjects,\n xpToValidateChapter: state.data.staticData?.xp_to_validate_chapter,\n liveSessions: state.data.currentUser?.object?.live_sessions,\n liveSessionId: state.liveMode?.liveSessionId,\n isLiveModeEnabled: state.liveMode?.isLiveModeEnabled,\n materialLevels: state.data?.staticData?.material_levels,\n };\n};\n\nconst mapDispatchToProps = {\n apiRequest,\n apiIdle,\n};\n\nexport default connect(\n mapStateToProps,\n mapDispatchToProps\n)(ChapterItemComponent);\n","import {DimensionsContext} from \"../../utils/mobileUtils\";\nimport {Platform, View} from \"react-native\";\nimport {ProgressBar} from \"react-native-paper\";\nimport {theme} from \"../../theme/theme\";\nimport TextM from \"../text/TextM\";\nimport React, {useContext, useEffect, useState} from \"react\";\nimport SuccessAnimation from \"../../animations/SuccessAnimation\";\nimport Animated, {useAnimatedStyle, useSharedValue, withTiming} from \"react-native-reanimated\";\nimport {PlaySoundM} from \"@common/components/playSound/PlaySoundM\";\n\nexport const ProgressBarM = (props) => {\n const dimensions = useContext(DimensionsContext)\n\n const {\n progressColor,\n count,\n previousCount,\n total,\n barWidth = Platform.OS !== 'web' ? dimensions?.width / 3 : dimensions?.width / 5,\n percent,\n style,\n barStyle,\n withAnimation = true,\n canStartAnimation,\n isBgColorWarning = false,\n noText = false\n } = props\n\n\n const [progressBarCount, setProgressBarCount] = useState(previousCount ?? count)\n const [triggerAnimation, setTriggerAnimation] = useState(false)\n const circle = useSharedValue(progressBarCount / total * (barWidth - 18));\n\n const reanimatedStyleCircle = useAnimatedStyle(() => {\n return {\n transform: [{translateX: circle.value}]\n }\n })\n // useEffect(() => {\n // if (canStartAnimation) {\n // console.log(\"TRIGGER ANIMATION\")\n //\n // }\n //\n // }, [progressBarCount])\n\n useEffect(() => {\n if (canStartAnimation && withAnimation && count > previousCount)\n setTimeout(() => {\n // setProgressBarCount(0)\n setTriggerAnimation(true)\n PlaySoundM.play(require('../../../../assets/sounds/progress.mp3'))\n setTimeout(() => {\n setProgressBarCount(count)\n circle.value = withTiming(count / total * (barWidth - 18), {duration: 200})\n }, 500)\n\n }, 100)\n\n }, [canStartAnimation])\n\n return \n \n \n {triggerAnimation && <>\n {/*\n \n*/}\n \n }\n\n \n\n {!noText && \n\n {count >= 0 && \n {`${withAnimation ? progressBarCount : count}${percent ? \"%\" : \"\"}`}\n }\n {!percent && \n {\" / \" + total}\n }\n }\n\n ;\n}","import React, {useEffect, useRef} from \"react\";\nimport {Animated, View} from \"react-native\";\nimport FontAwesome5 from \"react-native-vector-icons/FontAwesome5\";\n\nexport default function SuccessAnimation({\n size = 120,\n iconSize = 120 * .7,\n dotColor = \"#44c6b1\",\n iconColor = \"white\",\n dotSize = 20,\n duration = 2000,\n backgroundColor = \"#44c6b1\",\n animatedLayerColor = \"white\",\n style,\n icon = \"check\",\n onAnimationEnd = () => {\n }\n }) {\n let animation = useRef(new Animated.Value(0)).current;\n useEffect(() => {\n Animated.timing(animation, {\n toValue: 2,\n duration,\n useNativeDriver: false\n }).start(e => onAnimationEnd());\n }, []);\n\n const particalScale = animation.interpolate({\n inputRange: [0, 1.5],\n outputRange: [dotSize, 0],\n extrapolate: \"clamp\"\n });\n const particalRadius = animation.interpolate({\n inputRange: [0, 1.5],\n outputRange: [dotSize / 2, 0],\n extrapolate: \"clamp\"\n });\n const particalOpacity = animation.interpolate({\n inputRange: [0, 0.5, 0.65],\n outputRange: [0, 0.1, 1],\n extrapolateRight: \"clamp\"\n });\n\n const Icon = Animated.createAnimatedComponent(FontAwesome5);\n let SIZE = size\n return (\n \n\n \n\n \n\n \n\n \n {icon? : \"\"}\n\n \n\n \n\n \n\n \n\n \n\n \n\n \n\n \n\n \n\n \n\n \n );\n}","import React, {forwardRef, useCallback, useImperativeHandle, useRef} from \"react\";\nimport {usePlaySound} from \"@common/components/playSound/usePlaySound\";\nimport {PlaySound} from \"@common/sound/PlaySound\";\n\n\nlet currentRef = null\nexport const PlaySoundComponent = forwardRef((props, ref) => {\n\n const playSoundRef = useRef()\n\n useImperativeHandle(\n ref,\n useCallback(\n () => ({\n play: playSoundRef?.current?.play,\n stop: playSoundRef?.current?.stop,\n }),\n []\n )\n );\n return ;\n\n})\n\nexport function PlaySoundM(props) {\n const playSoundRef = useRef(null);\n\n const setRef = useCallback((ref) => {\n if (ref) {\n playSoundRef.current = ref;\n currentRef = ref;\n }\n }, []);\n\n return (\n \n );\n}\n\nPlaySoundM.play = (params) => {\n return currentRef?.play(params);\n};\n\n// logic to stop\nPlaySoundM.stop = () => {\n return currentRef?.stop();\n};","import React, {useCallback, useState} from 'react'\nimport {mergeIfDefined} from \"@common/components/alert/snackbar/useSnackBar\";\n\nconst DEFAULT_DATA = {\n soundFile: null,\n isLooping: false,\n repeat: null,\n ref: null\n};\nconst DEFAULT_OPTIONS = {};\n\nexport function usePlaySound({defaultOptions}) {\n // const [isVisible, setIsVisible] = useState(false);\n const [data, setData] = useState(DEFAULT_DATA);\n\n const initialOptions = mergeIfDefined(\n DEFAULT_OPTIONS,\n defaultOptions)\n\n const [options, setOptions] = useState(initialOptions);\n\n // const stop = useCallback(() => {\n // // setIsVisible(false);\n // //options.onHide();\n // }, [options]);\n\n const play = useCallback(\n (params) => {\n stop()\n const {\n soundFile = DEFAULT_DATA.soundFile,\n isLooping = DEFAULT_DATA.isLooping,\n repeat = DEFAULT_DATA.repeat,\n ref = DEFAULT_DATA.ref,\n } = params;\n setData({\n soundFile,\n isLooping,\n repeat,\n ref\n });\n setOptions(\n mergeIfDefined(initialOptions, {})\n );\n // setIsVisible(true);\n },\n [initialOptions]\n );\n\n\n return {\n // isVisible,\n data,\n options,\n play,\n stop\n };\n}","import React, {useCallback, useEffect, useImperativeHandle, useRef, useState} from \"react\";\nimport {Audio, InterruptionModeAndroid, InterruptionModeIOS} from \"expo-av\";\nimport {useSelector} from \"react-redux\";\nimport {Platform} from \"react-native\";\nimport { hasRole } from \"@data/utility/ability\"\n\nexport const PlaySound = React.forwardRef((props, ref) => {\n const { } = props;\n\n useImperativeHandle(ref, () => ({\n play: playSound,\n stop: stopSound,\n }));\n\n const isLiveModeEnabled = useSelector(state => state.liveMode?.isLiveModeEnabled);\n const liveSessionId = useSelector(state => state.liveMode?.liveSessionId);\n const liveSessions = useSelector(state => state.data.currentUser?.object?.live_sessions);\n const liveSession = liveSessions?.find((session) => session.id === liveSessionId);\n const isV2 = liveSession?.live_room?.version === 'v2';\n\n const soundModeIds = useSelector(state => state.liveMode?.soundModeIds);\n const isSoundMode = hasRole(props.user, \"student\") && soundModeIds?.includes(props.user?.id)\n\n const cannotPlaySound = isLiveModeEnabled && (Platform.OS === \"android\");\n const cannotPlaySoundRef = useRef(cannotPlaySound);\n const soundRef = useRef(null);\n\n useEffect(() => {\n cannotPlaySoundRef.current = cannotPlaySound;\n }, [cannotPlaySound]);\n\n const playSound = async (soundFile, delay = 0, isLooping = false) => {\n if (cannotPlaySoundRef.current) return;\n\n try {\n await Audio.setAudioModeAsync({\n allowsRecordingIOS: true,\n interruptionModeIOS: InterruptionModeIOS.DuckOthers,\n playsInSilentModeIOS: true,\n staysActiveInBackground: true,\n });\n\n const sound = new Audio.Sound();\n await sound.loadAsync(soundFile);\n\n if (isLooping) {\n await sound.setIsLoopingAsync(isLooping);\n }\n\n soundRef.current = sound;\n\n setTimeout(async () => {\n await sound.playAsync()\n .then(async (playbackStatus) => {\n if (!isLooping) {\n setTimeout(() => {\n sound.unloadAsync();\n soundRef.current = null;\n }, 6000);\n }\n });\n }, delay);\n\n return sound;\n\n } catch (e) {\n console.log(\"PLAY SOUND ERROR\", e?.toString());\n return null;\n }\n };\n\n const stopSound = async () => {\n if (soundRef.current) {\n await soundRef.current.stopAsync();\n await soundRef.current.unloadAsync();\n soundRef.current = null;\n }\n };\n\n});","import * as Audio from './Audio';\nexport { Audio };\nexport { default as Video } from './Video';\nexport * from './AV.types';\nexport * from './Audio.types';\nexport * from './Video.types';\n//# sourceMappingURL=index.js.map","import { InterruptionModeAndroid, InterruptionModeIOS } from './Audio.types';\nimport ExponentAV from './ExponentAV';\nexport * from './Audio/Recording';\nexport * from './Audio/Sound';\nexport { setIsEnabledAsync } from './Audio/AudioAvailability';\nexport { PitchCorrectionQuality } from './AV';\nconst _populateMissingKeys = (userAudioMode, defaultAudioMode) => {\n for (const key in defaultAudioMode) {\n if (!userAudioMode.hasOwnProperty(key)) {\n userAudioMode[key] = defaultAudioMode[key];\n }\n }\n return userAudioMode;\n};\nconst defaultMode = {\n allowsRecordingIOS: false,\n interruptionModeIOS: InterruptionModeIOS.MixWithOthers,\n playsInSilentModeIOS: false,\n staysActiveInBackground: false,\n interruptionModeAndroid: InterruptionModeAndroid.DuckOthers,\n shouldDuckAndroid: true,\n playThroughEarpieceAndroid: false,\n};\nlet currentAudioMode = null;\nfunction getCurrentAudioMode() {\n if (!currentAudioMode) {\n return defaultMode;\n }\n return currentAudioMode;\n}\n/**\n * We provide this API to customize the audio experience on iOS and Android.\n * @param partialMode\n * @return A `Promise` that will reject if the audio mode could not be enabled for the device.\n */\nexport async function setAudioModeAsync(partialMode) {\n const mode = _populateMissingKeys(partialMode, getCurrentAudioMode());\n if (!InterruptionModeIOS[mode.interruptionModeIOS]) {\n throw new Error(`\"interruptionModeIOS\" was set to an invalid value.`);\n }\n if (!InterruptionModeAndroid[mode.interruptionModeAndroid]) {\n throw new Error(`\"interruptionModeAndroid\" was set to an invalid value.`);\n }\n if (typeof mode.allowsRecordingIOS !== 'boolean' ||\n typeof mode.playsInSilentModeIOS !== 'boolean' ||\n typeof mode.staysActiveInBackground !== 'boolean' ||\n typeof mode.shouldDuckAndroid !== 'boolean' ||\n typeof mode.playThroughEarpieceAndroid !== 'boolean') {\n throw new Error('\"allowsRecordingIOS\", \"playsInSilentModeIOS\", \"playThroughEarpieceAndroid\", \"staysActiveInBackground\" and \"shouldDuckAndroid\" must be booleans.');\n }\n currentAudioMode = mode;\n return await ExponentAV.setAudioMode(mode);\n}\n//# sourceMappingURL=Audio.js.map","// @needsAudit\nexport var InterruptionModeIOS;\n(function (InterruptionModeIOS) {\n /**\n * **This is the default option.** If this option is set, your experience's audio is mixed with audio playing in background apps.\n */\n InterruptionModeIOS[InterruptionModeIOS[\"MixWithOthers\"] = 0] = \"MixWithOthers\";\n /**\n * If this option is set, your experience's audio interrupts audio from other apps.\n */\n InterruptionModeIOS[InterruptionModeIOS[\"DoNotMix\"] = 1] = \"DoNotMix\";\n /**\n * If this option is set, your experience's audio lowers the volume (\"ducks\") of audio from other apps while your audio plays.\n */\n InterruptionModeIOS[InterruptionModeIOS[\"DuckOthers\"] = 2] = \"DuckOthers\";\n})(InterruptionModeIOS || (InterruptionModeIOS = {}));\nexport var InterruptionModeAndroid;\n(function (InterruptionModeAndroid) {\n /**\n * If this option is set, your experience's audio interrupts audio from other apps.\n */\n InterruptionModeAndroid[InterruptionModeAndroid[\"DoNotMix\"] = 1] = \"DoNotMix\";\n /**\n * **This is the default option.** If this option is set, your experience's audio lowers the volume (\"ducks\") of audio from other apps while your audio plays.\n */\n InterruptionModeAndroid[InterruptionModeAndroid[\"DuckOthers\"] = 2] = \"DuckOthers\";\n})(InterruptionModeAndroid || (InterruptionModeAndroid = {}));\n//# sourceMappingURL=Audio.types.js.map","import { DeviceEventEmitter, PermissionStatus } from 'expo-modules-core';\nimport { RecordingOptionsPresets } from './Audio/RecordingConstants';\nasync function getPermissionWithQueryAsync(name) {\n if (!navigator || !navigator.permissions || !navigator.permissions.query)\n return null;\n try {\n const { state } = await navigator.permissions.query({ name });\n switch (state) {\n case 'granted':\n return PermissionStatus.GRANTED;\n case 'denied':\n return PermissionStatus.DENIED;\n default:\n return PermissionStatus.UNDETERMINED;\n }\n }\n catch {\n // Firefox - TypeError: 'microphone' (value of 'name' member of PermissionDescriptor) is not a valid value for enumeration PermissionName.\n return PermissionStatus.UNDETERMINED;\n }\n}\nfunction getUserMedia(constraints) {\n if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {\n return navigator.mediaDevices.getUserMedia(constraints);\n }\n // Some browsers partially implement mediaDevices. We can't just assign an object\n // with getUserMedia as it would overwrite existing properties.\n // Here, we will just add the getUserMedia property if it's missing.\n // First get ahold of the legacy getUserMedia, if present\n const getUserMedia = \n // TODO: this method is deprecated, migrate to https://developer.mozilla.org/en-US/docs/Web/API/MediaDevices/getUserMedia\n navigator.getUserMedia ||\n navigator.webkitGetUserMedia ||\n navigator.mozGetUserMedia ||\n function () {\n const error = new Error('Permission unimplemented');\n error.code = 0;\n error.name = 'NotAllowedError';\n throw error;\n };\n return new Promise((resolve, reject) => {\n getUserMedia.call(navigator, constraints, resolve, reject);\n });\n}\nfunction getStatusFromMedia(media) {\n if (!media) {\n return {\n isLoaded: false,\n error: undefined,\n };\n }\n const isPlaying = !!(media.currentTime > 0 &&\n !media.paused &&\n !media.ended &&\n media.readyState > 2);\n const status = {\n isLoaded: true,\n uri: media.src,\n progressUpdateIntervalMillis: 100,\n durationMillis: media.duration * 1000,\n positionMillis: media.currentTime * 1000,\n // playableDurationMillis: media.buffered * 1000,\n // seekMillisToleranceBefore?: number\n // seekMillisToleranceAfter?: number\n shouldPlay: media.autoplay,\n isPlaying,\n isBuffering: false,\n rate: media.playbackRate,\n // TODO: Bacon: This seems too complicated right now: https://webaudio.github.io/web-audio-api/#dom-biquadfilternode-frequency\n shouldCorrectPitch: false,\n volume: media.volume,\n audioPan: 0,\n isMuted: media.muted,\n isLooping: media.loop,\n didJustFinish: media.ended,\n };\n return status;\n}\nasync function setStatusForMedia(media, status) {\n if (status.positionMillis !== undefined) {\n media.currentTime = status.positionMillis / 1000;\n }\n // if (status.progressUpdateIntervalMillis !== undefined) {\n // media.progressUpdateIntervalMillis = status.progressUpdateIntervalMillis;\n // }\n // if (status.seekMillisToleranceBefore !== undefined) {\n // media.seekMillisToleranceBefore = status.seekMillisToleranceBefore;\n // }\n // if (status.seekMillisToleranceAfter !== undefined) {\n // media.seekMillisToleranceAfter = status.seekMillisToleranceAfter;\n // }\n // if (status.shouldCorrectPitch !== undefined) {\n // media.shouldCorrectPitch = status.shouldCorrectPitch;\n // }\n if (status.shouldPlay !== undefined) {\n if (status.shouldPlay) {\n await media.play();\n }\n else {\n await media.pause();\n }\n }\n if (status.rate !== undefined) {\n media.playbackRate = status.rate;\n }\n if (status.shouldCorrectPitch !== undefined) {\n media.preservesPitch = status.shouldCorrectPitch;\n }\n if (status.volume !== undefined) {\n media.volume = status.volume;\n }\n if (status.isMuted !== undefined) {\n media.muted = status.isMuted;\n }\n if (status.isLooping !== undefined) {\n media.loop = status.isLooping;\n }\n return getStatusFromMedia(media);\n}\nlet mediaRecorder /*MediaRecorder*/ = null;\nlet mediaRecorderUptimeOfLastStartResume = 0;\nlet mediaRecorderDurationAlreadyRecorded = 0;\nlet mediaRecorderIsRecording = false;\nfunction getAudioRecorderDurationMillis() {\n let duration = mediaRecorderDurationAlreadyRecorded;\n if (mediaRecorderIsRecording && mediaRecorderUptimeOfLastStartResume > 0) {\n duration += Date.now() - mediaRecorderUptimeOfLastStartResume;\n }\n return duration;\n}\nexport default {\n async getStatusForVideo(element) {\n return getStatusFromMedia(element);\n },\n async loadForVideo(element, nativeSource, fullInitialStatus) {\n return getStatusFromMedia(element);\n },\n async unloadForVideo(element) {\n return getStatusFromMedia(element);\n },\n async setStatusForVideo(element, status) {\n return setStatusForMedia(element, status);\n },\n async replayVideo(element, status) {\n return setStatusForMedia(element, status);\n },\n /* Audio */\n async setAudioMode() { },\n async setAudioIsEnabled() { },\n async getStatusForSound(element) {\n return getStatusFromMedia(element);\n },\n async loadForSound(nativeSource, fullInitialStatus) {\n const source = typeof nativeSource === 'string' ? nativeSource : nativeSource.uri;\n const media = new Audio(source);\n media.ontimeupdate = () => {\n DeviceEventEmitter.emit('didUpdatePlaybackStatus', {\n key: media,\n status: getStatusFromMedia(media),\n });\n };\n media.onerror = () => {\n DeviceEventEmitter.emit('ExponentAV.onError', {\n key: media,\n error: media.error.message,\n });\n };\n const status = await setStatusForMedia(media, fullInitialStatus);\n return [media, status];\n },\n async unloadForSound(element) {\n element.pause();\n element.removeAttribute('src');\n element.load();\n return getStatusFromMedia(element);\n },\n async setStatusForSound(element, status) {\n return setStatusForMedia(element, status);\n },\n async replaySound(element, status) {\n return setStatusForMedia(element, status);\n },\n /* Recording */\n // async setUnloadedCallbackForAndroidRecording() {},\n async getAudioRecordingStatus() {\n return {\n canRecord: mediaRecorder?.state === 'recording' || mediaRecorder?.state === 'inactive',\n isRecording: mediaRecorder?.state === 'recording',\n isDoneRecording: false,\n durationMillis: getAudioRecorderDurationMillis(),\n uri: null,\n };\n },\n async prepareAudioRecorder(options) {\n if (typeof navigator !== 'undefined' && !navigator.mediaDevices) {\n throw new Error('No media devices available');\n }\n mediaRecorderUptimeOfLastStartResume = 0;\n mediaRecorderDurationAlreadyRecorded = 0;\n const stream = await getUserMedia({ audio: true });\n mediaRecorder = new window.MediaRecorder(stream, options?.web || RecordingOptionsPresets.HIGH_QUALITY.web);\n mediaRecorder.addEventListener('pause', () => {\n mediaRecorderDurationAlreadyRecorded = getAudioRecorderDurationMillis();\n mediaRecorderIsRecording = false;\n });\n mediaRecorder.addEventListener('resume', () => {\n mediaRecorderUptimeOfLastStartResume = Date.now();\n mediaRecorderIsRecording = true;\n });\n mediaRecorder.addEventListener('start', () => {\n mediaRecorderUptimeOfLastStartResume = Date.now();\n mediaRecorderDurationAlreadyRecorded = 0;\n mediaRecorderIsRecording = true;\n });\n mediaRecorder.addEventListener('stop', () => {\n mediaRecorderDurationAlreadyRecorded = getAudioRecorderDurationMillis();\n mediaRecorderIsRecording = false;\n // Clears recording icon in Chrome tab\n stream.getTracks().forEach((track) => track.stop());\n });\n const { uri, ...status } = await this.getAudioRecordingStatus();\n return { uri: null, status };\n },\n async startAudioRecording() {\n if (mediaRecorder === null) {\n throw new Error('Cannot start an audio recording without initializing a MediaRecorder. Run prepareToRecordAsync() before attempting to start an audio recording.');\n }\n if (mediaRecorder.state === 'paused') {\n mediaRecorder.resume();\n }\n else {\n mediaRecorder.start();\n }\n return this.getAudioRecordingStatus();\n },\n async pauseAudioRecording() {\n if (mediaRecorder === null) {\n throw new Error('Cannot start an audio recording without initializing a MediaRecorder. Run prepareToRecordAsync() before attempting to start an audio recording.');\n }\n // Set status to paused\n mediaRecorder.pause();\n return this.getAudioRecordingStatus();\n },\n async stopAudioRecording() {\n if (mediaRecorder === null) {\n throw new Error('Cannot start an audio recording without initializing a MediaRecorder. Run prepareToRecordAsync() before attempting to start an audio recording.');\n }\n if (mediaRecorder.state === 'inactive') {\n return this.getAudioRecordingStatus();\n }\n const dataPromise = new Promise((resolve) => mediaRecorder.addEventListener('dataavailable', (e) => resolve(e.data)));\n mediaRecorder.stop();\n const data = await dataPromise;\n const url = URL.createObjectURL(data);\n return {\n ...(await this.getAudioRecordingStatus()),\n uri: url,\n };\n },\n async unloadAudioRecorder() {\n mediaRecorder = null;\n },\n async getPermissionsAsync() {\n const maybeStatus = await getPermissionWithQueryAsync('microphone');\n switch (maybeStatus) {\n case PermissionStatus.GRANTED:\n return {\n status: PermissionStatus.GRANTED,\n expires: 'never',\n canAskAgain: true,\n granted: true,\n };\n case PermissionStatus.DENIED:\n return {\n status: PermissionStatus.DENIED,\n expires: 'never',\n canAskAgain: true,\n granted: false,\n };\n default:\n return await this.requestPermissionsAsync();\n }\n },\n async requestPermissionsAsync() {\n try {\n const stream = await getUserMedia({ audio: true });\n stream.getTracks().forEach((track) => track.stop());\n return {\n status: PermissionStatus.GRANTED,\n expires: 'never',\n canAskAgain: true,\n granted: true,\n };\n }\n catch {\n return {\n status: PermissionStatus.DENIED,\n expires: 'never',\n canAskAgain: true,\n granted: false,\n };\n }\n },\n};\n//# sourceMappingURL=ExponentAV.web.js.map","// @docsMissing\nexport var AndroidOutputFormat;\n(function (AndroidOutputFormat) {\n AndroidOutputFormat[AndroidOutputFormat[\"DEFAULT\"] = 0] = \"DEFAULT\";\n AndroidOutputFormat[AndroidOutputFormat[\"THREE_GPP\"] = 1] = \"THREE_GPP\";\n AndroidOutputFormat[AndroidOutputFormat[\"MPEG_4\"] = 2] = \"MPEG_4\";\n AndroidOutputFormat[AndroidOutputFormat[\"AMR_NB\"] = 3] = \"AMR_NB\";\n AndroidOutputFormat[AndroidOutputFormat[\"AMR_WB\"] = 4] = \"AMR_WB\";\n AndroidOutputFormat[AndroidOutputFormat[\"AAC_ADIF\"] = 5] = \"AAC_ADIF\";\n AndroidOutputFormat[AndroidOutputFormat[\"AAC_ADTS\"] = 6] = \"AAC_ADTS\";\n AndroidOutputFormat[AndroidOutputFormat[\"RTP_AVP\"] = 7] = \"RTP_AVP\";\n AndroidOutputFormat[AndroidOutputFormat[\"MPEG2TS\"] = 8] = \"MPEG2TS\";\n AndroidOutputFormat[AndroidOutputFormat[\"WEBM\"] = 9] = \"WEBM\";\n})(AndroidOutputFormat || (AndroidOutputFormat = {}));\n// @docsMissing\nexport var AndroidAudioEncoder;\n(function (AndroidAudioEncoder) {\n AndroidAudioEncoder[AndroidAudioEncoder[\"DEFAULT\"] = 0] = \"DEFAULT\";\n AndroidAudioEncoder[AndroidAudioEncoder[\"AMR_NB\"] = 1] = \"AMR_NB\";\n AndroidAudioEncoder[AndroidAudioEncoder[\"AMR_WB\"] = 2] = \"AMR_WB\";\n AndroidAudioEncoder[AndroidAudioEncoder[\"AAC\"] = 3] = \"AAC\";\n AndroidAudioEncoder[AndroidAudioEncoder[\"HE_AAC\"] = 4] = \"HE_AAC\";\n AndroidAudioEncoder[AndroidAudioEncoder[\"AAC_ELD\"] = 5] = \"AAC_ELD\";\n})(AndroidAudioEncoder || (AndroidAudioEncoder = {}));\n// @docsMissing\n/**\n * > **Note** Not all of the iOS formats included in this list of constants are currently supported by iOS,\n * > in spite of appearing in the Apple source code. For an accurate list of formats supported by iOS, see\n * > [Core Audio Codecs](https://developer.apple.com/library/content/documentation/MusicAudio/Conceptual/CoreAudioOverview/CoreAudioEssentials/CoreAudioEssentials.html)\n * > and [iPhone Audio File Formats](https://developer.apple.com/library/content/documentation/MusicAudio/Conceptual/CoreAudioOverview/CoreAudioEssentials/CoreAudioEssentials.html).\n */\nexport var IOSOutputFormat;\n(function (IOSOutputFormat) {\n IOSOutputFormat[\"LINEARPCM\"] = \"lpcm\";\n IOSOutputFormat[\"AC3\"] = \"ac-3\";\n IOSOutputFormat[\"60958AC3\"] = \"cac3\";\n IOSOutputFormat[\"APPLEIMA4\"] = \"ima4\";\n IOSOutputFormat[\"MPEG4AAC\"] = \"aac \";\n IOSOutputFormat[\"MPEG4CELP\"] = \"celp\";\n IOSOutputFormat[\"MPEG4HVXC\"] = \"hvxc\";\n IOSOutputFormat[\"MPEG4TWINVQ\"] = \"twvq\";\n IOSOutputFormat[\"MACE3\"] = \"MAC3\";\n IOSOutputFormat[\"MACE6\"] = \"MAC6\";\n IOSOutputFormat[\"ULAW\"] = \"ulaw\";\n IOSOutputFormat[\"ALAW\"] = \"alaw\";\n IOSOutputFormat[\"QDESIGN\"] = \"QDMC\";\n IOSOutputFormat[\"QDESIGN2\"] = \"QDM2\";\n IOSOutputFormat[\"QUALCOMM\"] = \"Qclp\";\n IOSOutputFormat[\"MPEGLAYER1\"] = \".mp1\";\n IOSOutputFormat[\"MPEGLAYER2\"] = \".mp2\";\n IOSOutputFormat[\"MPEGLAYER3\"] = \".mp3\";\n IOSOutputFormat[\"APPLELOSSLESS\"] = \"alac\";\n IOSOutputFormat[\"MPEG4AAC_HE\"] = \"aach\";\n IOSOutputFormat[\"MPEG4AAC_LD\"] = \"aacl\";\n IOSOutputFormat[\"MPEG4AAC_ELD\"] = \"aace\";\n IOSOutputFormat[\"MPEG4AAC_ELD_SBR\"] = \"aacf\";\n IOSOutputFormat[\"MPEG4AAC_ELD_V2\"] = \"aacg\";\n IOSOutputFormat[\"MPEG4AAC_HE_V2\"] = \"aacp\";\n IOSOutputFormat[\"MPEG4AAC_SPATIAL\"] = \"aacs\";\n IOSOutputFormat[\"AMR\"] = \"samr\";\n IOSOutputFormat[\"AMR_WB\"] = \"sawb\";\n IOSOutputFormat[\"AUDIBLE\"] = \"AUDB\";\n IOSOutputFormat[\"ILBC\"] = \"ilbc\";\n IOSOutputFormat[IOSOutputFormat[\"DVIINTELIMA\"] = 1836253201] = \"DVIINTELIMA\";\n IOSOutputFormat[IOSOutputFormat[\"MICROSOFTGSM\"] = 1836253233] = \"MICROSOFTGSM\";\n IOSOutputFormat[\"AES3\"] = \"aes3\";\n IOSOutputFormat[\"ENHANCEDAC3\"] = \"ec-3\";\n})(IOSOutputFormat || (IOSOutputFormat = {}));\n// @docsMissing\nexport var IOSAudioQuality;\n(function (IOSAudioQuality) {\n IOSAudioQuality[IOSAudioQuality[\"MIN\"] = 0] = \"MIN\";\n IOSAudioQuality[IOSAudioQuality[\"LOW\"] = 32] = \"LOW\";\n IOSAudioQuality[IOSAudioQuality[\"MEDIUM\"] = 64] = \"MEDIUM\";\n IOSAudioQuality[IOSAudioQuality[\"HIGH\"] = 96] = \"HIGH\";\n IOSAudioQuality[IOSAudioQuality[\"MAX\"] = 127] = \"MAX\";\n})(IOSAudioQuality || (IOSAudioQuality = {}));\n// @docsMissing\nexport var IOSBitRateStrategy;\n(function (IOSBitRateStrategy) {\n IOSBitRateStrategy[IOSBitRateStrategy[\"CONSTANT\"] = 0] = \"CONSTANT\";\n IOSBitRateStrategy[IOSBitRateStrategy[\"LONG_TERM_AVERAGE\"] = 1] = \"LONG_TERM_AVERAGE\";\n IOSBitRateStrategy[IOSBitRateStrategy[\"VARIABLE_CONSTRAINED\"] = 2] = \"VARIABLE_CONSTRAINED\";\n IOSBitRateStrategy[IOSBitRateStrategy[\"VARIABLE\"] = 3] = \"VARIABLE\";\n})(IOSBitRateStrategy || (IOSBitRateStrategy = {}));\n// TODO : maybe make presets for music and speech, or lossy / lossless.\nconst HIGH_QUALITY = {\n isMeteringEnabled: true,\n android: {\n extension: '.m4a',\n outputFormat: AndroidOutputFormat.MPEG_4,\n audioEncoder: AndroidAudioEncoder.AAC,\n sampleRate: 44100,\n numberOfChannels: 2,\n bitRate: 128000,\n },\n ios: {\n extension: '.m4a',\n outputFormat: IOSOutputFormat.MPEG4AAC,\n audioQuality: IOSAudioQuality.MAX,\n sampleRate: 44100,\n numberOfChannels: 2,\n bitRate: 128000,\n linearPCMBitDepth: 16,\n linearPCMIsBigEndian: false,\n linearPCMIsFloat: false,\n },\n web: {\n mimeType: 'audio/webm',\n bitsPerSecond: 128000,\n },\n};\nconst LOW_QUALITY = {\n isMeteringEnabled: true,\n android: {\n extension: '.3gp',\n outputFormat: AndroidOutputFormat.THREE_GPP,\n audioEncoder: AndroidAudioEncoder.AMR_NB,\n sampleRate: 44100,\n numberOfChannels: 2,\n bitRate: 128000,\n },\n ios: {\n extension: '.m4a',\n audioQuality: IOSAudioQuality.MIN,\n outputFormat: IOSOutputFormat.MPEG4AAC,\n sampleRate: 44100,\n numberOfChannels: 2,\n bitRate: 64000,\n linearPCMBitDepth: 16,\n linearPCMIsBigEndian: false,\n linearPCMIsFloat: false,\n },\n web: {\n mimeType: 'audio/webm',\n bitsPerSecond: 128000,\n },\n};\n/**\n * Constant which contains definitions of the two preset examples of `RecordingOptions`, as implemented in the Audio SDK.\n *\n * # `HIGH_QUALITY`\n * ```ts\n * RecordingOptionsPresets.HIGH_QUALITY = {\n * isMeteringEnabled: true,\n * android: {\n * extension: '.m4a',\n * outputFormat: AndroidOutputFormat.MPEG_4,\n * audioEncoder: AndroidAudioEncoder.AAC,\n * sampleRate: 44100,\n * numberOfChannels: 2,\n * bitRate: 128000,\n * },\n * ios: {\n * extension: '.m4a',\n * outputFormat: IOSOutputFormat.MPEG4AAC,\n * audioQuality: IOSAudioQuality.MAX,\n * sampleRate: 44100,\n * numberOfChannels: 2,\n * bitRate: 128000,\n * linearPCMBitDepth: 16,\n * linearPCMIsBigEndian: false,\n * linearPCMIsFloat: false,\n * },\n * web: {\n * mimeType: 'audio/webm',\n * bitsPerSecond: 128000,\n * },\n * };\n * ```\n *\n * # `LOW_QUALITY`\n * ```ts\n * RecordingOptionsPresets.LOW_QUALITY = {\n * isMeteringEnabled: true,\n * android: {\n * extension: '.3gp',\n * outputFormat: AndroidOutputFormat.THREE_GPP,\n * audioEncoder: AndroidAudioEncoder.AMR_NB,\n * sampleRate: 44100,\n * numberOfChannels: 2,\n * bitRate: 128000,\n * },\n * ios: {\n * extension: '.caf',\n * audioQuality: IOSAudioQuality.MIN,\n * sampleRate: 44100,\n * numberOfChannels: 2,\n * bitRate: 128000,\n * linearPCMBitDepth: 16,\n * linearPCMIsBigEndian: false,\n * linearPCMIsFloat: false,\n * },\n * web: {\n * mimeType: 'audio/webm',\n * bitsPerSecond: 128000,\n * },\n * };\n * ```\n */\nexport const RecordingOptionsPresets = {\n HIGH_QUALITY,\n LOW_QUALITY,\n};\n//# sourceMappingURL=RecordingConstants.js.map","import { PermissionStatus, createPermissionHook, EventEmitter, Platform, } from 'expo-modules-core';\nimport { isAudioEnabled, throwIfAudioIsDisabled } from './AudioAvailability';\nimport { RecordingOptionsPresets } from './RecordingConstants';\nimport { Sound } from './Sound';\nimport { _DEFAULT_PROGRESS_UPDATE_INTERVAL_MILLIS, } from '../AV';\nimport ExponentAV from '../ExponentAV';\nlet _recorderExists = false;\nconst eventEmitter = Platform.OS === 'android' ? new EventEmitter(ExponentAV) : null;\n/**\n * Checks user's permissions for audio recording.\n * @return A promise that resolves to an object of type `PermissionResponse`.\n * @platform android\n * @platform ios\n */\nexport async function getPermissionsAsync() {\n return ExponentAV.getPermissionsAsync();\n}\n/**\n * Asks the user to grant permissions for audio recording.\n * @return A promise that resolves to an object of type `PermissionResponse`.\n * @platform android\n * @platform ios\n */\nexport async function requestPermissionsAsync() {\n return ExponentAV.requestPermissionsAsync();\n}\n/**\n * Check or request permissions to record audio.\n * This uses both `requestPermissionAsync` and `getPermissionsAsync` to interact with the permissions.\n *\n * @example\n * ```ts\n * const [permissionResponse, requestPermission] = Audio.usePermissions();\n * ```\n */\nexport const usePermissions = createPermissionHook({\n getMethod: getPermissionsAsync,\n requestMethod: requestPermissionsAsync,\n});\n// @needsAudit\n/**\n * > **warning** **Warning**: Experimental for web.\n *\n * This class represents an audio recording. After creating an instance of this class, `prepareToRecordAsync`\n * must be called in order to record audio. Once recording is finished, call `stopAndUnloadAsync`. Note that\n * only one recorder is allowed to exist in the state between `prepareToRecordAsync` and `stopAndUnloadAsync`\n * at any given time.\n *\n * Note that your experience must request audio recording permissions in order for recording to function.\n * See the [`Permissions` module](/guides/permissions) for more details.\n *\n * Additionally, audio recording is [not supported in the iOS Simulator](/workflow/ios-simulator/#limitations).\n *\n * @example\n * ```ts\n * const recording = new Audio.Recording();\n * try {\n * await recording.prepareToRecordAsync(Audio.RecordingOptionsPresets.HIGH_QUALITY);\n * await recording.startAsync();\n * // You are now recording!\n * } catch (error) {\n * // An error occurred!\n * }\n * ```\n *\n * @return A newly constructed instance of `Audio.Recording`.\n * @platform android\n * @platform ios\n */\nexport class Recording {\n _subscription = null;\n _canRecord = false;\n _isDoneRecording = false;\n _finalDurationMillis = 0;\n _uri = null;\n _onRecordingStatusUpdate = null;\n _progressUpdateTimeoutVariable = null;\n _progressUpdateIntervalMillis = _DEFAULT_PROGRESS_UPDATE_INTERVAL_MILLIS;\n _options = null;\n // Internal methods\n _cleanupForUnloadedRecorder = async (finalStatus) => {\n this._canRecord = false;\n this._isDoneRecording = true;\n this._finalDurationMillis = finalStatus?.durationMillis ?? 0;\n _recorderExists = false;\n if (this._subscription) {\n this._subscription.remove();\n this._subscription = null;\n }\n this._disablePolling();\n return await this.getStatusAsync(); // Automatically calls onRecordingStatusUpdate for the final state.\n };\n _pollingLoop = async () => {\n if (isAudioEnabled() && this._canRecord && this._onRecordingStatusUpdate != null) {\n this._progressUpdateTimeoutVariable = setTimeout(this._pollingLoop, this._progressUpdateIntervalMillis);\n try {\n await this.getStatusAsync();\n }\n catch {\n this._disablePolling();\n }\n }\n };\n _disablePolling() {\n if (this._progressUpdateTimeoutVariable != null) {\n clearTimeout(this._progressUpdateTimeoutVariable);\n this._progressUpdateTimeoutVariable = null;\n }\n }\n _enablePollingIfNecessaryAndPossible() {\n if (isAudioEnabled() && this._canRecord && this._onRecordingStatusUpdate != null) {\n this._disablePolling();\n this._pollingLoop();\n }\n }\n _callOnRecordingStatusUpdateForNewStatus(status) {\n if (this._onRecordingStatusUpdate != null) {\n this._onRecordingStatusUpdate(status);\n }\n }\n async _performOperationAndHandleStatusAsync(operation) {\n throwIfAudioIsDisabled();\n if (this._canRecord) {\n const status = await operation();\n this._callOnRecordingStatusUpdateForNewStatus(status);\n return status;\n }\n else {\n throw new Error('Cannot complete operation because this recorder is not ready to record.');\n }\n }\n /**\n * Creates and starts a recording using the given options, with optional `onRecordingStatusUpdate` and `progressUpdateIntervalMillis`.\n *\n * ```ts\n * const { recording, status } = await Audio.Recording.createAsync(\n * options,\n * onRecordingStatusUpdate,\n * progressUpdateIntervalMillis\n * );\n *\n * // Which is equivalent to the following:\n * const recording = new Audio.Recording();\n * await recording.prepareToRecordAsync(options);\n * recording.setOnRecordingStatusUpdate(onRecordingStatusUpdate);\n * await recording.startAsync();\n * ```\n *\n * @param options Options for the recording, including sample rate, bitrate, channels, format, encoder, and extension. If no options are passed to,\n * the recorder will be created with options `Audio.RecordingOptionsPresets.LOW_QUALITY`. See below for details on `RecordingOptions`.\n * @param onRecordingStatusUpdate A function taking a single parameter `status` (a dictionary, described in `getStatusAsync`).\n * @param progressUpdateIntervalMillis The interval between calls of `onRecordingStatusUpdate`. This value defaults to 500 milliseconds.\n *\n * @example\n * ```ts\n * try {\n * const { recording: recordingObject, status } = await Audio.Recording.createAsync(\n * Audio.RecordingOptionsPresets.HIGH_QUALITY\n * );\n * // You are now recording!\n * } catch (error) {\n * // An error occurred!\n * }\n * ```\n *\n * @return A `Promise` that is rejected if creation failed, or fulfilled with the following dictionary if creation succeeded.\n */\n static createAsync = async (options = RecordingOptionsPresets.LOW_QUALITY, onRecordingStatusUpdate = null, progressUpdateIntervalMillis = null) => {\n const recording = new Recording();\n if (progressUpdateIntervalMillis) {\n recording._progressUpdateIntervalMillis = progressUpdateIntervalMillis;\n }\n recording.setOnRecordingStatusUpdate(onRecordingStatusUpdate);\n await recording.prepareToRecordAsync({\n ...options,\n keepAudioActiveHint: true,\n });\n try {\n const status = await recording.startAsync();\n return { recording, status };\n }\n catch (err) {\n recording.stopAndUnloadAsync();\n throw err;\n }\n };\n // Get status API\n /**\n * Gets the `status` of the `Recording`.\n * @return A `Promise` that is resolved with the `RecordingStatus` object.\n */\n getStatusAsync = async () => {\n // Automatically calls onRecordingStatusUpdate.\n if (this._canRecord) {\n return this._performOperationAndHandleStatusAsync(() => ExponentAV.getAudioRecordingStatus());\n }\n const status = {\n canRecord: false,\n isRecording: false,\n isDoneRecording: this._isDoneRecording,\n durationMillis: this._finalDurationMillis,\n };\n this._callOnRecordingStatusUpdateForNewStatus(status);\n return status;\n };\n /**\n * Sets a function to be called regularly with the `RecordingStatus` of the `Recording`.\n *\n * `onRecordingStatusUpdate` will be called when another call to the API for this recording completes (such as `prepareToRecordAsync()`,\n * `startAsync()`, `getStatusAsync()`, or `stopAndUnloadAsync()`), and will also be called at regular intervals while the recording can record.\n * Call `setProgressUpdateInterval()` to modify the interval with which `onRecordingStatusUpdate` is called while the recording can record.\n *\n * @param onRecordingStatusUpdate A function taking a single parameter `RecordingStatus`.\n */\n setOnRecordingStatusUpdate(onRecordingStatusUpdate) {\n this._onRecordingStatusUpdate = onRecordingStatusUpdate;\n if (onRecordingStatusUpdate == null) {\n this._disablePolling();\n }\n else {\n this._enablePollingIfNecessaryAndPossible();\n }\n this.getStatusAsync();\n }\n /**\n * Sets the interval with which `onRecordingStatusUpdate` is called while the recording can record.\n * See `setOnRecordingStatusUpdate` for details. This value defaults to 500 milliseconds.\n * @param progressUpdateIntervalMillis The new interval between calls of `onRecordingStatusUpdate`.\n */\n setProgressUpdateInterval(progressUpdateIntervalMillis) {\n this._progressUpdateIntervalMillis = progressUpdateIntervalMillis;\n this.getStatusAsync();\n }\n // Record API\n /**\n * Loads the recorder into memory and prepares it for recording. This must be called before calling `startAsync()`.\n * This method can only be called if the `Recording` instance has never yet been prepared.\n *\n * @param options `RecordingOptions` for the recording, including sample rate, bitrate, channels, format, encoder, and extension.\n * If no options are passed to `prepareToRecordAsync()`, the recorder will be created with options `Audio.RecordingOptionsPresets.LOW_QUALITY`.\n *\n * @return A `Promise` that is fulfilled when the recorder is loaded and prepared, or rejects if this failed. If another `Recording` exists\n * in your experience that is currently prepared to record, the `Promise` will reject. If the `RecordingOptions` provided are invalid,\n * the `Promise` will also reject. The promise is resolved with the `RecordingStatus` of the recording.\n */\n async prepareToRecordAsync(options = RecordingOptionsPresets.LOW_QUALITY) {\n throwIfAudioIsDisabled();\n if (_recorderExists) {\n throw new Error('Only one Recording object can be prepared at a given time.');\n }\n if (this._isDoneRecording) {\n throw new Error('This Recording object is done recording; you must make a new one.');\n }\n if (!options || !options.android || !options.ios) {\n throw new Error('You must provide recording options for android and ios in order to prepare to record.');\n }\n const extensionRegex = /^\\.\\w+$/;\n if (!options.android.extension ||\n !options.ios.extension ||\n !extensionRegex.test(options.android.extension) ||\n !extensionRegex.test(options.ios.extension)) {\n throw new Error(`Your file extensions must match ${extensionRegex.toString()}.`);\n }\n if (!this._canRecord) {\n if (eventEmitter) {\n this._subscription = eventEmitter.addListener('Expo.Recording.recorderUnloaded', this._cleanupForUnloadedRecorder);\n }\n const { uri, status, } = await ExponentAV.prepareAudioRecorder(options);\n _recorderExists = true;\n this._uri = uri;\n this._options = options;\n this._canRecord = true;\n const currentStatus = { ...status, canRecord: true };\n this._callOnRecordingStatusUpdateForNewStatus(currentStatus);\n this._enablePollingIfNecessaryAndPossible();\n return currentStatus;\n }\n else {\n throw new Error('This Recording object is already prepared to record.');\n }\n }\n /**\n * Returns a list of available recording inputs. This method can only be called if the `Recording` has been prepared.\n * @return A `Promise` that is fulfilled with an array of `RecordingInput` objects.\n */\n async getAvailableInputs() {\n return ExponentAV.getAvailableInputs();\n }\n /**\n * Returns the currently-selected recording input. This method can only be called if the `Recording` has been prepared.\n * @return A `Promise` that is fulfilled with a `RecordingInput` object.\n */\n async getCurrentInput() {\n return ExponentAV.getCurrentInput();\n }\n /**\n * Sets the current recording input.\n * @param inputUid The uid of a `RecordingInput`.\n * @return A `Promise` that is resolved if successful or rejected if not.\n */\n async setInput(inputUid) {\n return ExponentAV.setInput(inputUid);\n }\n /**\n * Begins recording. This method can only be called if the `Recording` has been prepared.\n * @return A `Promise` that is fulfilled when recording has begun, or rejects if recording could not be started.\n * The promise is resolved with the `RecordingStatus` of the recording.\n */\n async startAsync() {\n return this._performOperationAndHandleStatusAsync(() => ExponentAV.startAudioRecording());\n }\n /**\n * Pauses recording. This method can only be called if the `Recording` has been prepared.\n *\n * > This is only available on Android API version 24 and later.\n *\n * @return A `Promise` that is fulfilled when recording has paused, or rejects if recording could not be paused.\n * If the Android API version is less than 24, the `Promise` will reject. The promise is resolved with the\n * `RecordingStatus` of the recording.\n */\n async pauseAsync() {\n return this._performOperationAndHandleStatusAsync(() => ExponentAV.pauseAudioRecording());\n }\n /**\n * Stops the recording and deallocates the recorder from memory. This reverts the `Recording` instance\n * to an unprepared state, and another `Recording` instance must be created in order to record again.\n * This method can only be called if the `Recording` has been prepared.\n *\n * > On Android this method may fail with `E_AUDIO_NODATA` when called too soon after `startAsync` and\n * > no audio data has been recorded yet. In that case the recorded file will be invalid and should be discarded.\n *\n * @return A `Promise` that is fulfilled when recording has stopped, or rejects if recording could not be stopped.\n * The promise is resolved with the `RecordingStatus` of the recording.\n */\n async stopAndUnloadAsync() {\n if (!this._canRecord) {\n if (this._isDoneRecording) {\n throw new Error('Cannot unload a Recording that has already been unloaded.');\n }\n else {\n throw new Error('Cannot unload a Recording that has not been prepared.');\n }\n }\n // We perform a separate native API call so that the state of the Recording can be updated with\n // the final duration of the recording. (We cast stopStatus as Object to appease Flow)\n let stopResult;\n let stopError;\n try {\n stopResult = await ExponentAV.stopAudioRecording();\n }\n catch (err) {\n stopError = err;\n }\n // Web has to return the URI at the end of recording, so needs a little destructuring\n if (Platform.OS === 'web' && stopResult?.uri !== undefined) {\n this._uri = stopResult.uri;\n }\n // Clean-up and return status\n await ExponentAV.unloadAudioRecorder();\n const status = await this._cleanupForUnloadedRecorder(stopResult);\n return stopError ? Promise.reject(stopError) : status;\n }\n // Read API\n /**\n * Gets the local URI of the `Recording`. Note that this will only succeed once the `Recording` is prepared\n * to record. On web, this will not return the URI until the recording is finished.\n * @return A `string` with the local URI of the `Recording`, or `null` if the `Recording` is not prepared\n * to record (or, on Web, if the recording has not finished).\n */\n getURI() {\n return this._uri;\n }\n /**\n * @deprecated Use `createNewLoadedSoundAsync()` instead.\n */\n async createNewLoadedSound(initialStatus = {}, onPlaybackStatusUpdate = null) {\n console.warn(`createNewLoadedSound is deprecated in favor of createNewLoadedSoundAsync, which has the same API aside from the method name`);\n return this.createNewLoadedSoundAsync(initialStatus, onPlaybackStatusUpdate);\n }\n /**\n * Creates and loads a new `Sound` object to play back the `Recording`. Note that this will only succeed once the `Recording`\n * is done recording and `stopAndUnloadAsync()` has been called.\n *\n * @param initialStatus The initial intended `PlaybackStatusToSet` of the sound, whose values will override the default initial playback status.\n * This value defaults to `{}` if no parameter is passed. See the [AV documentation](/versions/latest/sdk/av) for details on `PlaybackStatusToSet`\n * and the default initial playback status.\n * @param onPlaybackStatusUpdate A function taking a single parameter `PlaybackStatus`. This value defaults to `null` if no parameter is passed.\n * See the [AV documentation](/versions/latest/sdk/av) for details on the functionality provided by `onPlaybackStatusUpdate`\n *\n * @return A `Promise` that is rejected if creation failed, or fulfilled with the `SoundObject`.\n */\n async createNewLoadedSoundAsync(initialStatus = {}, onPlaybackStatusUpdate = null) {\n if (this._uri == null || !this._isDoneRecording) {\n throw new Error('Cannot create sound when the Recording has not finished!');\n }\n return Sound.createAsync(\n // $FlowFixMe: Flow can't distinguish between this literal and Asset\n { uri: this._uri }, initialStatus, onPlaybackStatusUpdate, false);\n }\n}\nexport { PermissionStatus };\nexport * from './RecordingConstants';\nexport * from './Recording.types';\n//# sourceMappingURL=Recording.js.map","import ExponentAV from '../ExponentAV';\nlet _enabled = true;\nexport function isAudioEnabled() {\n return _enabled;\n}\nexport function throwIfAudioIsDisabled() {\n if (!_enabled) {\n throw new Error('Cannot complete operation because audio is not enabled.');\n }\n}\n// @needsAudit\n/**\n * Audio is enabled by default, but if you want to write your own Audio API in a bare workflow app, you might want to disable the Audio API.\n * @param value `true` enables Audio, and `false` disables it.\n * @return A `Promise` that will reject if audio playback could not be enabled for the device.\n */\nexport async function setIsEnabledAsync(value) {\n _enabled = value;\n await ExponentAV.setAudioIsEnabled(value);\n // TODO : We immediately pause all players when disabled, but we do not resume all shouldPlay\n // players when enabled. Perhaps for completeness we should allow this; the design of the\n // enabling API is for people to enable / disable this audio library, but I think that it should\n // intuitively also double as a global pause/resume.\n}\n//# sourceMappingURL=AudioAvailability.js.map","import { EventEmitter, Platform, UnavailabilityError } from 'expo-modules-core';\nimport { throwIfAudioIsDisabled } from './AudioAvailability';\nimport { PlaybackMixin, assertStatusValuesInBounds, getNativeSourceAndFullInitialStatusForLoadAsync, getUnloadedStatus, } from '../AV';\nimport ExponentAV from '../ExponentAV';\n// @needsAudit\n/**\n * This class represents a sound corresponding to an Asset or URL.\n * @return A newly constructed instance of `Audio.Sound`.\n *\n * @example\n * ```ts\n * const sound = new Audio.Sound();\n * try {\n * await sound.loadAsync(require('./assets/sounds/hello.mp3'));\n * await sound.playAsync();\n * // Your sound is playing!\n *\n * // Don't forget to unload the sound from memory\n * // when you are done using the Sound object\n * await sound.unloadAsync();\n * } catch (error) {\n * // An error occurred!\n * }\n * ```\n *\n * > Method not described below and the rest of the API for `Audio.Sound` is the same as the imperative playback API for `Video`.\n * > See the [AV documentation](/versions/latest/sdk/av) for further information.\n */\nexport class Sound {\n _loaded = false;\n _loading = false;\n _key = null;\n _lastStatusUpdate = null;\n _lastStatusUpdateTime = null;\n _subscriptions = [];\n _eventEmitter = new EventEmitter(ExponentAV);\n _coalesceStatusUpdatesInMillis = 100;\n _onPlaybackStatusUpdate = null;\n _onMetadataUpdate = null;\n _onAudioSampleReceived = null;\n /** @deprecated Use `Sound.createAsync()` instead */\n static create = async (source, initialStatus = {}, onPlaybackStatusUpdate = null, downloadFirst = true) => {\n console.warn(`Sound.create is deprecated in favor of Sound.createAsync with the same API except for the new method name`);\n return Sound.createAsync(source, initialStatus, onPlaybackStatusUpdate, downloadFirst);\n };\n /**\n * Creates and loads a sound from source.\n *\n * ```ts\n * const { sound } = await Audio.Sound.createAsync(\n * source,\n * initialStatus,\n * onPlaybackStatusUpdate,\n * downloadFirst\n * );\n *\n * // Which is equivalent to the following:\n * const sound = new Audio.Sound();\n * sound.setOnPlaybackStatusUpdate(onPlaybackStatusUpdate);\n * await sound.loadAsync(source, initialStatus, downloadFirst);\n * ```\n *\n * @param source The source of the sound. See the [AV documentation](/versions/latest/sdk/av/#playback-api) for details on the possible `source` values.\n *\n * @param initialStatus The initial intended `PlaybackStatusToSet` of the sound, whose values will override the default initial playback status.\n * This value defaults to `{}` if no parameter is passed. See the [AV documentation](/versions/latest/sdk/av) for details on `PlaybackStatusToSet` and the default\n * initial playback status.\n *\n * @param onPlaybackStatusUpdate A function taking a single parameter `PlaybackStatus`. This value defaults to `null` if no parameter is passed.\n * See the [AV documentation](/versions/latest/sdk/av) for details on the functionality provided by `onPlaybackStatusUpdate`\n *\n * @param downloadFirst If set to true, the system will attempt to download the resource to the device before loading. This value defaults to `true`.\n * Note that at the moment, this will only work for `source`s of the form `require('path/to/file')` or `Asset` objects.\n *\n * @example\n * ```ts\n * try {\n * const { sound: soundObject, status } = await Audio.Sound.createAsync(\n * require('./assets/sounds/hello.mp3'),\n * { shouldPlay: true }\n * );\n * // Your sound is playing!\n * } catch (error) {\n * // An error occurred!\n * }\n * ```\n *\n * @return A `Promise` that is rejected if creation failed, or fulfilled with the `SoundObject` if creation succeeded.\n */\n static createAsync = async (source, initialStatus = {}, onPlaybackStatusUpdate = null, downloadFirst = true) => {\n const sound = new Sound();\n sound.setOnPlaybackStatusUpdate(onPlaybackStatusUpdate);\n const status = await sound.loadAsync(source, initialStatus, downloadFirst);\n return { sound, status };\n };\n // Internal methods\n _callOnPlaybackStatusUpdateForNewStatus(status) {\n const shouldDismissBasedOnCoalescing = this._lastStatusUpdateTime &&\n JSON.stringify(status) === this._lastStatusUpdate &&\n Date.now() - this._lastStatusUpdateTime.getTime() < this._coalesceStatusUpdatesInMillis;\n if (this._onPlaybackStatusUpdate != null && !shouldDismissBasedOnCoalescing) {\n this._onPlaybackStatusUpdate(status);\n this._lastStatusUpdateTime = new Date();\n this._lastStatusUpdate = JSON.stringify(status);\n }\n }\n async _performOperationAndHandleStatusAsync(operation) {\n throwIfAudioIsDisabled();\n if (this._loaded) {\n const status = await operation();\n this._callOnPlaybackStatusUpdateForNewStatus(status);\n return status;\n }\n else {\n throw new Error('Cannot complete operation because sound is not loaded.');\n }\n }\n _updateAudioSampleReceivedCallback() {\n if (globalThis.__EXAV_setOnAudioSampleReceivedCallback == null) {\n if (Platform.OS === 'ios' || Platform.OS === 'android') {\n console.warn('expo-av: Failed to set up Audio Sample Buffer callback. ' +\n \"Do you have 'Remote Debugging' enabled in your app's Developer Menu (https://docs.expo.dev/workflow/debugging)? \" +\n 'Audio Sample Buffer callbacks are not supported while using Remote Debugging, you will need to disable it to use them.');\n return;\n }\n else {\n throw new UnavailabilityError('expo-av', 'setOnAudioSampleReceived');\n }\n }\n if (this._key == null) {\n throw new Error('Cannot set Audio Sample Buffer callback when the Sound instance has not been successfully loaded/initialized!');\n }\n if (typeof this._key !== 'number') {\n throw new Error(`Cannot set Audio Sample Buffer callback when Sound instance key is of type ${typeof this\n ._key}! (expected: number)`);\n }\n globalThis.__EXAV_setOnAudioSampleReceivedCallback(this._key, this._onAudioSampleReceived);\n }\n _internalStatusUpdateCallback = ({ key, status, }) => {\n if (this._key === key) {\n this._callOnPlaybackStatusUpdateForNewStatus(status);\n }\n };\n _internalMetadataUpdateCallback = ({ key, metadata, }) => {\n if (this._key === key) {\n this._onMetadataUpdate?.(metadata);\n }\n };\n _internalErrorCallback = ({ key, error }) => {\n if (this._key === key) {\n this._errorCallback(error);\n }\n };\n // TODO: We can optimize by only using time observer on native if (this._onPlaybackStatusUpdate).\n _subscribeToNativeEvents() {\n if (this._loaded) {\n this._subscriptions.push(this._eventEmitter.addListener('didUpdatePlaybackStatus', this._internalStatusUpdateCallback), this._eventEmitter.addListener('didUpdateMetadata', this._internalMetadataUpdateCallback));\n this._subscriptions.push(this._eventEmitter.addListener('ExponentAV.onError', this._internalErrorCallback));\n }\n }\n _clearSubscriptions() {\n this._subscriptions.forEach((e) => e.remove());\n this._subscriptions = [];\n }\n _errorCallback = (error) => {\n this._clearSubscriptions();\n this._loaded = false;\n this._key = null;\n this._callOnPlaybackStatusUpdateForNewStatus(getUnloadedStatus(error));\n };\n // ### Unified playback API ### (consistent with Video.js)\n // All calls automatically call onPlaybackStatusUpdate as a side effect.\n // Get status API\n getStatusAsync = async () => {\n if (this._loaded) {\n return this._performOperationAndHandleStatusAsync(() => ExponentAV.getStatusForSound(this._key));\n }\n const status = getUnloadedStatus();\n this._callOnPlaybackStatusUpdateForNewStatus(status);\n return status;\n };\n /**\n * Sets a function to be called regularly with the `AVPlaybackStatus` of the playback object.\n *\n * `onPlaybackStatusUpdate` will be called whenever a call to the API for this playback object completes\n * (such as `setStatusAsync()`, `getStatusAsync()`, or `unloadAsync()`), nd will also be called at regular intervals\n * while the media is in the loaded state.\n *\n * Set `progressUpdateIntervalMillis` via `setStatusAsync()` or `setProgressUpdateIntervalAsync()` to modify\n * the interval with which `onPlaybackStatusUpdate` is called while loaded.\n *\n * @param onPlaybackStatusUpdate A function taking a single parameter `AVPlaybackStatus`.\n */\n setOnPlaybackStatusUpdate(onPlaybackStatusUpdate) {\n this._onPlaybackStatusUpdate = onPlaybackStatusUpdate;\n this.getStatusAsync();\n }\n /**\n * Sets a function to be called whenever the metadata of the sound object changes, if one is set.\n * @param onMetadataUpdate A function taking a single object of type `AVMetadata` as a parameter.\n * @platform ios\n */\n setOnMetadataUpdate(onMetadataUpdate) {\n this._onMetadataUpdate = onMetadataUpdate;\n }\n /**\n * Sets a function to be called during playback, receiving the audio sample as parameter.\n * @param callback A function taking the `AudioSampleCallback` as parameter.\n */\n setOnAudioSampleReceived(callback) {\n this._onAudioSampleReceived = callback;\n if (this._key != null) {\n this._updateAudioSampleReceivedCallback();\n }\n }\n // Loading / unloading API\n async loadAsync(source, initialStatus = {}, downloadFirst = true) {\n throwIfAudioIsDisabled();\n if (this._loading) {\n throw new Error('The Sound is already loading.');\n }\n if (!this._loaded) {\n this._loading = true;\n const { nativeSource, fullInitialStatus } = await getNativeSourceAndFullInitialStatusForLoadAsync(source, initialStatus, downloadFirst);\n // This is a workaround, since using load with resolve / reject seems to not work.\n return new Promise((resolve, reject) => {\n const loadSuccess = (result) => {\n const [key, status] = result;\n this._key = key;\n this._loaded = true;\n this._loading = false;\n this._subscribeToNativeEvents();\n this._callOnPlaybackStatusUpdateForNewStatus(status);\n resolve(status);\n };\n const loadError = (error) => {\n this._loading = false;\n reject(error);\n };\n ExponentAV.loadForSound(nativeSource, fullInitialStatus).then(loadSuccess).catch(loadError);\n });\n }\n else {\n throw new Error('The Sound is already loaded.');\n }\n }\n async unloadAsync() {\n if (this._loaded) {\n this._loaded = false;\n const key = this._key;\n this._key = null;\n const status = await ExponentAV.unloadForSound(key);\n this._callOnPlaybackStatusUpdateForNewStatus(status);\n this._clearSubscriptions();\n return status;\n }\n else {\n return this.getStatusAsync(); // Automatically calls onPlaybackStatusUpdate.\n }\n }\n // Set status API (only available while isLoaded = true)\n async setStatusAsync(status) {\n assertStatusValuesInBounds(status);\n return this._performOperationAndHandleStatusAsync(() => ExponentAV.setStatusForSound(this._key, status));\n }\n async replayAsync(status = {}) {\n if (status.positionMillis && status.positionMillis !== 0) {\n throw new Error('Requested position after replay has to be 0.');\n }\n return this._performOperationAndHandleStatusAsync(() => ExponentAV.replaySound(this._key, {\n ...status,\n positionMillis: 0,\n shouldPlay: true,\n }));\n }\n // Methods of the Playback interface that are set via PlaybackMixin\n playAsync;\n playFromPositionAsync;\n pauseAsync;\n stopAsync;\n setPositionAsync;\n setRateAsync;\n setVolumeAsync;\n setIsMutedAsync;\n setIsLoopingAsync;\n setProgressUpdateIntervalAsync;\n}\nObject.assign(Sound.prototype, PlaybackMixin);\n//# sourceMappingURL=Sound.js.map","import { Asset } from 'expo-asset';\nimport { Platform } from 'expo-modules-core';\nimport { PitchCorrectionQuality, } from './AV.types';\n// TODO add:\n// disableFocusOnAndroid\n// audio routes (at least did become noisy on android)\n// pan\n// pitch\n// API to explicitly request audio focus / session\n// API to select stream type on Android\n// subtitles API\n/**\n * @hidden\n */\nexport const _DEFAULT_PROGRESS_UPDATE_INTERVAL_MILLIS = 500;\n// @needsAudit\n/**\n * The default initial `AVPlaybackStatusToSet` of all `Audio.Sound` objects and `Video` components is as follows:\n *\n * ```javascript\n * {\n * progressUpdateIntervalMillis: 500,\n * positionMillis: 0,\n * shouldPlay: false,\n * rate: 1.0,\n * shouldCorrectPitch: false,\n * volume: 1.0,\n * isMuted: false,\n * isLooping: false,\n * }\n * ```\n *\n * This default initial status can be overwritten by setting the optional `initialStatus` in `loadAsync()` or `Audio.Sound.createAsync()`.\n */\nexport const _DEFAULT_INITIAL_PLAYBACK_STATUS = {\n positionMillis: 0,\n progressUpdateIntervalMillis: _DEFAULT_PROGRESS_UPDATE_INTERVAL_MILLIS,\n shouldPlay: false,\n rate: 1.0,\n shouldCorrectPitch: false,\n volume: 1.0,\n audioPan: 0,\n isMuted: false,\n isLooping: false,\n};\n// @needsAudit\n/**\n * @hidden\n */\nexport function getNativeSourceFromSource(source) {\n let uri = null;\n let overridingExtension = null;\n let headers;\n if (typeof source === 'string' && Platform.OS === 'web') {\n return {\n uri: source,\n overridingExtension,\n headers,\n };\n }\n const asset = _getAssetFromPlaybackSource(source);\n if (asset != null) {\n uri = asset.localUri || asset.uri;\n }\n else if (source != null &&\n typeof source !== 'number' &&\n 'uri' in source &&\n typeof source.uri === 'string') {\n uri = source.uri;\n }\n if (uri == null) {\n return null;\n }\n if (source != null &&\n typeof source !== 'number' &&\n 'overrideFileExtensionAndroid' in source &&\n typeof source.overrideFileExtensionAndroid === 'string') {\n overridingExtension = source.overrideFileExtensionAndroid;\n }\n if (source != null &&\n typeof source !== 'number' &&\n 'headers' in source &&\n typeof source.headers === 'object') {\n headers = source.headers;\n }\n return { uri, overridingExtension, headers };\n}\nfunction _getAssetFromPlaybackSource(source) {\n if (source == null) {\n return null;\n }\n let asset = null;\n if (typeof source === 'number') {\n asset = Asset.fromModule(source);\n }\n else if (source instanceof Asset) {\n asset = source;\n }\n return asset;\n}\n// @needsAudit\n/**\n * @hidden\n */\nexport function assertStatusValuesInBounds(status) {\n if (typeof status.rate === 'number' && (status.rate < 0 || status.rate > 32)) {\n throw new RangeError('Rate value must be between 0.0 and 32.0');\n }\n if (typeof status.volume === 'number' && (status.volume < 0 || status.volume > 1)) {\n throw new RangeError('Volume value must be between 0.0 and 1.0');\n }\n if (typeof status.audioPan === 'number' && (status.audioPan < -1 || status.audioPan > 1)) {\n throw new RangeError('Pan value must be between -1.0 and 1.0');\n }\n}\n// @needsAudit\n/**\n * @hidden\n */\nexport async function getNativeSourceAndFullInitialStatusForLoadAsync(source, initialStatus, downloadFirst) {\n // Get the full initial status\n const fullInitialStatus = initialStatus == null\n ? _DEFAULT_INITIAL_PLAYBACK_STATUS\n : {\n ..._DEFAULT_INITIAL_PLAYBACK_STATUS,\n ...initialStatus,\n };\n assertStatusValuesInBounds(fullInitialStatus);\n if (typeof source === 'string' && Platform.OS === 'web') {\n return {\n nativeSource: {\n uri: source,\n overridingExtension: null,\n },\n fullInitialStatus,\n };\n }\n // Download first if necessary.\n const asset = _getAssetFromPlaybackSource(source);\n if (downloadFirst && asset) {\n // TODO we can download remote uri too once @nikki93 has integrated this into Asset\n await asset.downloadAsync();\n }\n // Get the native source\n const nativeSource = getNativeSourceFromSource(source);\n if (nativeSource === null) {\n throw new Error(`Cannot load an AV asset from a null playback source`);\n }\n // If asset has been downloaded use the localUri\n if (asset && asset.localUri) {\n nativeSource.uri = asset.localUri;\n }\n return { nativeSource, fullInitialStatus };\n}\n// @needsAudit\n/**\n * @hidden\n */\nexport function getUnloadedStatus(error = null) {\n return {\n isLoaded: false,\n ...(error ? { error } : null),\n };\n}\n/**\n * @hidden\n * A mixin that defines common playback methods for A/V classes, so they implement the `Playback`\n * interface.\n */\nexport const PlaybackMixin = {\n async playAsync() {\n return this.setStatusAsync({ shouldPlay: true });\n },\n async playFromPositionAsync(positionMillis, tolerances = {}) {\n return this.setStatusAsync({\n positionMillis,\n shouldPlay: true,\n seekMillisToleranceAfter: tolerances.toleranceMillisAfter,\n seekMillisToleranceBefore: tolerances.toleranceMillisBefore,\n });\n },\n async pauseAsync() {\n return this.setStatusAsync({ shouldPlay: false });\n },\n async stopAsync() {\n return this.setStatusAsync({ positionMillis: 0, shouldPlay: false });\n },\n async setPositionAsync(positionMillis, tolerances = {}) {\n return this.setStatusAsync({\n positionMillis,\n seekMillisToleranceAfter: tolerances.toleranceMillisAfter,\n seekMillisToleranceBefore: tolerances.toleranceMillisBefore,\n });\n },\n async setRateAsync(rate, shouldCorrectPitch = false, pitchCorrectionQuality = PitchCorrectionQuality.Medium) {\n return this.setStatusAsync({\n rate,\n shouldCorrectPitch,\n pitchCorrectionQuality,\n });\n },\n async setVolumeAsync(volume, audioPan) {\n return this.setStatusAsync({ volume, audioPan });\n },\n async setIsMutedAsync(isMuted) {\n return this.setStatusAsync({ isMuted });\n },\n async setIsLoopingAsync(isLooping) {\n return this.setStatusAsync({ isLooping });\n },\n async setProgressUpdateIntervalAsync(progressUpdateIntervalMillis) {\n return this.setStatusAsync({ progressUpdateIntervalMillis });\n },\n};\nexport * from './AV.types';\n//# sourceMappingURL=AV.js.map","import ExponentAV from './ExponentAV';\n// @needsAudit\n/**\n * Check [official Apple documentation](https://developer.apple.com/documentation/avfoundation/audio_settings/time_pitch_algorithm_settings) for more information.\n */\nexport var PitchCorrectionQuality;\n(function (PitchCorrectionQuality) {\n /**\n * Equivalent to `AVAudioTimePitchAlgorithmLowQualityZeroLatency`.\n */\n PitchCorrectionQuality[PitchCorrectionQuality[\"Low\"] = ExponentAV && ExponentAV.Qualities && ExponentAV.Qualities.Low] = \"Low\";\n /**\n * Equivalent to `AVAudioTimePitchAlgorithmTimeDomain`.\n */\n PitchCorrectionQuality[PitchCorrectionQuality[\"Medium\"] = ExponentAV && ExponentAV.Qualities && ExponentAV.Qualities.Medium] = \"Medium\";\n /**\n * Equivalent to `AVAudioTimePitchAlgorithmSpectral`.\n */\n PitchCorrectionQuality[PitchCorrectionQuality[\"High\"] = ExponentAV && ExponentAV.Qualities && ExponentAV.Qualities.High] = \"High\";\n})(PitchCorrectionQuality || (PitchCorrectionQuality = {}));\n//# sourceMappingURL=AV.types.js.map","export {};\n//# sourceMappingURL=Recording.types.js.map","import * as React from 'react';\nimport { findNodeHandle, Image, StyleSheet, View } from 'react-native';\nimport { assertStatusValuesInBounds, getNativeSourceAndFullInitialStatusForLoadAsync, getNativeSourceFromSource, getUnloadedStatus, PlaybackMixin, } from './AV';\nimport ExpoVideoManager from './ExpoVideoManager';\nimport ExponentAV from './ExponentAV';\nimport ExponentVideo from './ExponentVideo';\nimport { ResizeMode, } from './Video.types';\nconst _STYLES = StyleSheet.create({\n base: {\n overflow: 'hidden',\n pointerEvents: 'box-none',\n },\n poster: {\n position: 'absolute',\n left: 0,\n top: 0,\n right: 0,\n bottom: 0,\n resizeMode: 'contain',\n },\n video: {\n position: 'absolute',\n left: 0,\n top: 0,\n right: 0,\n bottom: 0,\n },\n});\n// On a real device UIManager should be present, however when running offline tests with jest-expo\n// we have to use the provided native module mock to access constants\nconst ExpoVideoManagerConstants = ExpoVideoManager;\nconst ExpoVideoViewManager = ExpoVideoManager;\nclass Video extends React.Component {\n _nativeRef = React.createRef();\n _onPlaybackStatusUpdate = null;\n constructor(props) {\n super(props);\n this.state = {\n showPoster: !!props.usePoster,\n };\n }\n /**\n * @hidden\n */\n setNativeProps(nativeProps) {\n const nativeVideo = this._nativeRef.current;\n if (!nativeVideo)\n throw new Error(`native video reference is not defined.`);\n nativeVideo.setNativeProps(nativeProps);\n }\n // Internal methods\n _handleNewStatus = (status) => {\n if (this.state.showPoster &&\n status.isLoaded &&\n (status.isPlaying || status.positionMillis !== 0)) {\n this.setState({ showPoster: false });\n }\n if (this.props.onPlaybackStatusUpdate) {\n this.props.onPlaybackStatusUpdate(status);\n }\n if (this._onPlaybackStatusUpdate) {\n this._onPlaybackStatusUpdate(status);\n }\n };\n _performOperationAndHandleStatusAsync = async (operation) => {\n const video = this._nativeRef.current;\n if (!video) {\n throw new Error(`Cannot complete operation because the Video component has not yet loaded`);\n }\n const handle = findNodeHandle(this._nativeRef.current);\n const status = await operation(handle);\n this._handleNewStatus(status);\n return status;\n };\n // Fullscreening API\n _setFullscreen = async (value) => {\n return this._performOperationAndHandleStatusAsync((tag) => ExpoVideoViewManager.setFullscreen(tag, value));\n };\n /**\n * This presents a fullscreen view of your video component on top of your app's UI. Note that even if `useNativeControls` is set to `false`,\n * native controls will be visible in fullscreen mode.\n * @return A `Promise` that is fulfilled with the `AVPlaybackStatus` of the video once the fullscreen player has finished presenting,\n * or rejects if there was an error, or if this was called on an Android device.\n */\n presentFullscreenPlayer = async () => {\n return this._setFullscreen(true);\n };\n /**\n * This dismisses the fullscreen video view.\n * @return A `Promise` that is fulfilled with the `AVPlaybackStatus` of the video once the fullscreen player has finished dismissing,\n * or rejects if there was an error, or if this was called on an Android device.\n */\n dismissFullscreenPlayer = async () => {\n return this._setFullscreen(false);\n };\n // ### Unified playback API ### (consistent with Audio.js)\n // All calls automatically call onPlaybackStatusUpdate as a side effect.\n /**\n * @hidden\n */\n getStatusAsync = async () => {\n return this._performOperationAndHandleStatusAsync((tag) => ExponentAV.getStatusForVideo(tag));\n };\n /**\n * @hidden\n */\n loadAsync = async (source, initialStatus = {}, downloadFirst = true) => {\n const { nativeSource, fullInitialStatus } = await getNativeSourceAndFullInitialStatusForLoadAsync(source, initialStatus, downloadFirst);\n return this._performOperationAndHandleStatusAsync((tag) => ExponentAV.loadForVideo(tag, nativeSource, fullInitialStatus));\n };\n /**\n * Equivalent to setting URI to `null`.\n * @hidden\n */\n unloadAsync = async () => {\n return this._performOperationAndHandleStatusAsync((tag) => ExponentAV.unloadForVideo(tag));\n };\n componentWillUnmount() {\n // Auto unload video to perform necessary cleanup safely\n this.unloadAsync().catch(() => {\n // Ignored rejection. Sometimes the unloadAsync code is executed when video is already unloaded.\n // In such cases, it throws:\n // \"[Unhandled promise rejection: Error: Invalid view returned from registry,\n // expecting EXVideo, got: (null)]\"\n });\n }\n /**\n * Set status API, only available while `isLoaded = true`.\n * @hidden\n */\n setStatusAsync = async (status) => {\n assertStatusValuesInBounds(status);\n return this._performOperationAndHandleStatusAsync((tag) => ExponentAV.setStatusForVideo(tag, status));\n };\n /**\n * @hidden\n */\n replayAsync = async (status = {}) => {\n if (status.positionMillis && status.positionMillis !== 0) {\n throw new Error('Requested position after replay has to be 0.');\n }\n return this._performOperationAndHandleStatusAsync((tag) => ExponentAV.replayVideo(tag, {\n ...status,\n positionMillis: 0,\n shouldPlay: true,\n }));\n };\n /**\n * Sets a function to be called regularly with the `AVPlaybackStatus` of the playback object.\n *\n * `onPlaybackStatusUpdate` will be called whenever a call to the API for this playback object completes\n * (such as `setStatusAsync()`, `getStatusAsync()`, or `unloadAsync()`), nd will also be called at regular intervals\n * while the media is in the loaded state.\n *\n * Set `progressUpdateIntervalMillis` via `setStatusAsync()` or `setProgressUpdateIntervalAsync()` to modify\n * the interval with which `onPlaybackStatusUpdate` is called while loaded.\n *\n * @param onPlaybackStatusUpdate A function taking a single parameter `AVPlaybackStatus`.\n */\n setOnPlaybackStatusUpdate(onPlaybackStatusUpdate) {\n this._onPlaybackStatusUpdate = onPlaybackStatusUpdate;\n this.getStatusAsync();\n }\n // Methods of the Playback interface that are set via PlaybackMixin\n playAsync;\n playFromPositionAsync;\n pauseAsync;\n stopAsync;\n setPositionAsync;\n setRateAsync;\n setVolumeAsync;\n setIsMutedAsync;\n setIsLoopingAsync;\n setProgressUpdateIntervalAsync;\n // Callback wrappers\n _nativeOnPlaybackStatusUpdate = (event) => {\n this._handleNewStatus(event.nativeEvent);\n };\n // TODO make sure we are passing the right stuff\n _nativeOnLoadStart = () => {\n if (this.props.onLoadStart) {\n this.props.onLoadStart();\n }\n };\n _nativeOnLoad = (event) => {\n if (this.props.onLoad) {\n this.props.onLoad(event.nativeEvent);\n }\n this._handleNewStatus(event.nativeEvent);\n };\n _nativeOnError = (event) => {\n const error = event.nativeEvent.error;\n if (this.props.onError) {\n this.props.onError(error);\n }\n this._handleNewStatus(getUnloadedStatus(error));\n };\n _nativeOnReadyForDisplay = (event) => {\n if (this.props.onReadyForDisplay) {\n this.props.onReadyForDisplay(event.nativeEvent);\n }\n };\n _nativeOnFullscreenUpdate = (event) => {\n if (this.props.onFullscreenUpdate) {\n this.props.onFullscreenUpdate(event.nativeEvent);\n }\n };\n _renderPoster = () => {\n const PosterComponent = this.props.PosterComponent ?? Image;\n return this.props.usePoster && this.state.showPoster ? () : null;\n };\n render() {\n const source = getNativeSourceFromSource(this.props.source) || undefined;\n let nativeResizeMode = ExpoVideoManagerConstants.ScaleNone;\n if (this.props.resizeMode) {\n const resizeMode = this.props.resizeMode;\n if (resizeMode === ResizeMode.STRETCH) {\n nativeResizeMode = ExpoVideoManagerConstants.ScaleToFill;\n }\n else if (resizeMode === ResizeMode.CONTAIN) {\n nativeResizeMode = ExpoVideoManagerConstants.ScaleAspectFit;\n }\n else if (resizeMode === ResizeMode.COVER) {\n nativeResizeMode = ExpoVideoManagerConstants.ScaleAspectFill;\n }\n }\n // Set status via individual props\n const status = { ...this.props.status };\n [\n 'progressUpdateIntervalMillis',\n 'positionMillis',\n 'shouldPlay',\n 'rate',\n 'shouldCorrectPitch',\n 'volume',\n 'isMuted',\n 'isLooping',\n ].forEach((prop) => {\n if (prop in this.props) {\n status[prop] = this.props[prop];\n }\n });\n // Replace selected native props\n const nativeProps = {\n ...omit(this.props, [\n 'source',\n 'onPlaybackStatusUpdate',\n 'usePoster',\n 'posterSource',\n 'posterStyle',\n ...Object.keys(status),\n ]),\n style: [_STYLES.base, this.props.style],\n videoStyle: [_STYLES.video, this.props.videoStyle],\n source,\n resizeMode: nativeResizeMode,\n status,\n onStatusUpdate: this._nativeOnPlaybackStatusUpdate,\n onLoadStart: this._nativeOnLoadStart,\n onLoad: this._nativeOnLoad,\n onError: this._nativeOnError,\n onReadyForDisplay: this._nativeOnReadyForDisplay,\n onFullscreenUpdate: this._nativeOnFullscreenUpdate,\n };\n return (\n \n {this._renderPoster()}\n );\n }\n}\nfunction omit(props, propNames) {\n const copied = { ...props };\n for (const propName of propNames) {\n delete copied[propName];\n }\n return copied;\n}\nObject.assign(Video.prototype, PlaybackMixin);\n// note(simek): TypeDoc cannot resolve correctly name of inline and default exported class\nexport default Video;\n//# sourceMappingURL=Video.js.map","import ExponentAV from './ExponentAV';\nimport { requestFullscreen, exitFullscreen } from './FullscreenUtils.web';\nexport default {\n get ScaleNone() {\n return 'none';\n },\n get ScaleToFill() {\n return 'fill';\n },\n get ScaleAspectFit() {\n return 'contain';\n },\n get ScaleAspectFill() {\n return 'cover';\n },\n async setFullscreen(element, isFullScreenEnabled) {\n if (isFullScreenEnabled) {\n await requestFullscreen(element);\n }\n else {\n await exitFullscreen(element);\n }\n return ExponentAV.getStatusForVideo(element);\n },\n};\n//# sourceMappingURL=ExpoVideoManager.web.js.map","/**\n * Detect if the browser supports the standard fullscreen API on the given\n * element:\n * https://developer.mozilla.org/en-US/docs/Web/API/Fullscreen_API\n */\nconst supportsFullscreenAPI = (element) => 'requestFullscreen' in element;\n/**\n * Detect if the browser supports the non-standard webkit fullscreen API on the\n * given element (looking at you, Safari).\n */\nconst supportsWebkitFullscreenAPI = (element) => 'webkitEnterFullScreen' in element;\n/**\n * Detect if the browser supports the non-standard ms fullscreen API on the\n * given element (looking at you, IE11).\n */\nconst supportsMsFullscreenAPI = (element) => 'msRequestFullscreen' in element;\n/**\n * Detect if the browser supports the `webkitFullscreenChange` event. This is\n * a non-standard event added to Safari on macOS by Apple:\n * https://developer.apple.com/documentation/webkitjs/document/1631998-onwebkitfullscreenchange\n */\nconst supportsWebkitFullscreenChangeEvent = () => supportsEvent('video', 'webkitfullscreenchange');\n/**\n * A helper that adds an event listener to an element. The key value-add over\n * the native addEventListener is that it returns a function that will remove\n * the event listener. This allows the setup and teardown logic for a listener\n * to be easily colocated.\n */\nfunction addEventListener(element, eventName, listener) {\n element.addEventListener(eventName, listener);\n return () => element.removeEventListener(eventName, listener);\n}\n/**\n * Detect if the browser supports an event on a particular element type.\n */\nconst supportsEvent = (elementName, eventName) => {\n // Detect if the browser supports the event by attempting to add a handler\n // attribute for that event to the provided element. If the event is supported\n // then the browser will accept the attribute and report the type of the\n // attribute as \"function\". See: https://stackoverflow.com/a/4562426/2747759\n const element = document.createElement(elementName);\n element.setAttribute('on' + eventName, 'return;');\n return typeof element['on' + eventName] === 'function';\n};\n/**\n * Switches a video element into fullscreen.\n */\nexport async function requestFullscreen(element) {\n if (supportsFullscreenAPI(element)) {\n return element.requestFullscreen();\n }\n else if (supportsWebkitFullscreenAPI(element)) {\n // This API is synchronous so no need to return the result\n element['webkitEnterFullScreen']?.();\n }\n else if (supportsMsFullscreenAPI(element)) {\n // This API is synchronous so no need to return the result\n element['msRequestFullscreen']?.();\n }\n else {\n throw new Error('Fullscreen not supported');\n }\n}\n/**\n * Switches a video element out of fullscreen.\n */\nexport async function exitFullscreen(element) {\n if (supportsFullscreenAPI(element)) {\n return document.exitFullscreen();\n }\n else if (supportsWebkitFullscreenAPI(element)) {\n // This API is synchronous so no need to return the result\n element['webkitExitFullScreen']?.();\n }\n else if (supportsMsFullscreenAPI(element)) {\n // This API is synchronous so no need to return the result\n document['msExitFullscreen']?.();\n }\n else {\n throw new Error('Fullscreen not supported');\n }\n}\n/**\n * Listens for fullscreen change events on a video element. The provided\n * callback will be called with `true` when the video is switched into\n * fullscreen and `false` when the video is switched out of fullscreen.\n */\nexport function addFullscreenListener(element, callback) {\n if (supportsFullscreenAPI(element)) {\n // Used by browsers that support the official spec\n return addEventListener(element, 'fullscreenchange', (event) => callback(document.fullscreenElement === event.target));\n }\n else if (supportsWebkitFullscreenAPI(element) && supportsWebkitFullscreenChangeEvent()) {\n // Used by Safari on macOS\n return addEventListener(element, 'webkitfullscreenchange', (event) => callback(document['webkitFullscreenElement'] === event.target));\n }\n else if (supportsWebkitFullscreenAPI(element)) {\n // Used by Safari on iOS\n const removeBeginListener = addEventListener(element, 'webkitbeginfullscreen', () => callback(true));\n const removeEndListener = addEventListener(element, 'webkitendfullscreen', () => callback(false));\n return () => {\n removeBeginListener();\n removeEndListener();\n };\n }\n else if (supportsMsFullscreenAPI(element)) {\n // Used by IE11\n return addEventListener(document, 'MSFullscreenChange', (event) => callback(document['msFullscreenElement'] === event.target));\n }\n else {\n return () => { };\n }\n}\n//# sourceMappingURL=FullscreenUtils.web.js.map","import * as React from 'react';\nimport createElement from 'react-native-web/dist/exports/createElement';\nimport ExponentAV from './ExponentAV';\nimport { addFullscreenListener } from './FullscreenUtils.web';\nimport { VideoFullscreenUpdate, } from './Video.types';\nconst Video = React.forwardRef((props, ref) => createElement('video', { ...props, ref }));\nexport default class ExponentVideo extends React.Component {\n _video;\n _removeFullscreenListener;\n componentWillUnmount() {\n this._removeFullscreenListener?.();\n }\n onFullscreenChange = (isFullscreen) => {\n if (!this.props.onFullscreenUpdate)\n return;\n if (isFullscreen) {\n this.props.onFullscreenUpdate({\n nativeEvent: { fullscreenUpdate: VideoFullscreenUpdate.PLAYER_DID_PRESENT },\n });\n }\n else {\n this.props.onFullscreenUpdate({\n nativeEvent: { fullscreenUpdate: VideoFullscreenUpdate.PLAYER_DID_DISMISS },\n });\n }\n };\n onStatusUpdate = async () => {\n if (!this.props.onStatusUpdate) {\n return;\n }\n const nativeEvent = await ExponentAV.getStatusForVideo(this._video);\n this.props.onStatusUpdate({ nativeEvent });\n };\n onLoadStart = () => {\n if (!this.props.onLoadStart) {\n return;\n }\n this.props.onLoadStart();\n this.onStatusUpdate();\n };\n onLoadedData = (event) => {\n if (!this.props.onLoad) {\n return;\n }\n this.props.onLoad(event);\n this.onStatusUpdate();\n };\n onError = (event) => {\n if (!this.props.onError) {\n return;\n }\n this.props.onError(event);\n this.onStatusUpdate();\n };\n onProgress = () => {\n this.onStatusUpdate();\n };\n onSeeking = () => {\n this.onStatusUpdate();\n };\n onEnded = () => {\n this.onStatusUpdate();\n };\n onLoadedMetadata = () => {\n this.onStatusUpdate();\n };\n onCanPlay = (event) => {\n if (!this.props.onReadyForDisplay) {\n return;\n }\n this.props.onReadyForDisplay(event);\n this.onStatusUpdate();\n };\n onStalled = () => {\n this.onStatusUpdate();\n };\n onRef = (ref) => {\n this._removeFullscreenListener?.();\n if (ref) {\n this._video = ref;\n this._removeFullscreenListener = addFullscreenListener(this._video, this.onFullscreenChange);\n this.onStatusUpdate();\n }\n else {\n this._removeFullscreenListener = undefined;\n }\n };\n render() {\n const { source, status = {}, resizeMode: objectFit, useNativeControls, style } = this.props;\n const customStyle = {\n position: undefined,\n objectFit,\n overflow: 'hidden',\n };\n return (