@duffel/components 3.1.8 → 3.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../.yarn/berry/cache/classnames-npm-2.3.2-d2fdae468d-10c0.zip/node_modules/classnames/index.js", "../.yarn/__virtual__/@stripe-react-stripe-js-virtual-25ff75fca0/3/.yarn/berry/cache/@stripe-react-stripe-js-npm-2.1.0-2f15e96dd7-10c0.zip/node_modules/@stripe/react-stripe-js/dist/react-stripe.umd.js", "../src/custom-elements.ts", "../src/components/DuffelAncillaries/DuffelAncillariesCustomElement.tsx", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/is.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/string.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/aggregate-errors.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/worldwide.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/browser.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/logger.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/dsn.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/error.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/object.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/misc.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/stacktrace.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/supports.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/vendor/supportsHistory.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/instrument.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/env.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/node.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/memo.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/normalize.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/syncpromise.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/promisebuffer.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/url.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/severity.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/time.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/baggage.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/tracing.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/envelope.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/clientreport.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/ratelimit.ts", "../../../.yarn/berry/cache/@sentry-utils-npm-7.77.0-2a4acebef5-10c0.zip/node_modules/@sentry/src/eventbuilder.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/constants.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/eventProcessors.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/session.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/scope.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/hub.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/tracing/utils.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/tracing/errors.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/tracing/span.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/tracing/dynamicSamplingContext.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/tracing/transaction.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/tracing/idletransaction.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/utils/hasTracingEnabled.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/tracing/sampling.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/tracing/hubextensions.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/exports.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/api.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/envelope.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/integration.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/utils/prepareEvent.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/baseclient.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/sdk.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/transports/base.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/version.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/core/esm/integrations/index.js", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/integrations/functiontostring.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/integrations/inboundfilters.ts", "../../../.yarn/berry/cache/@sentry-core-npm-7.77.0-5a2669a07e-10c0.zip/node_modules/@sentry/src/integrations/linkederrors.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/helpers.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/eventbuilder.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/userfeedback.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/client.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/transports/utils.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/transports/fetch.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/transports/xhr.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/stack-parsers.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/integrations/globalhandlers.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/integrations/trycatch.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/integrations/breadcrumbs.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/integrations/linkederrors.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/integrations/httpcontext.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/integrations/dedupe.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/sdk.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/@sentry/browser/esm/integrations/index.js", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/types.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/backgroundtab.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/lib/bindReporter.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/lib/generateUniqueID.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/lib/getNavigationEntry.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/lib/getActivationStart.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/lib/initMetric.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/lib/observe.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/lib/onHidden.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/getCLS.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/lib/getVisibilityWatcher.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/getFID.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/web-vitals/getLCP.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/instrument.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/metrics/utils.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/metrics/index.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/request.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/router.ts", "../../../.yarn/berry/cache/@sentry-internal-tracing-npm-7.77.0-dd5d7f5a08-10c0.zip/node_modules/@sentry-internal/src/browser/browsertracing.ts", "../../../.yarn/berry/cache/@sentry-browser-npm-7.77.0-3002d70329-10c0.zip/node_modules/src/index.ts", "../../../.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js", "../src/lib/captureErrorInSentry.ts", "../src/components/shared/ErrorBoundary.tsx", "../src/lib/logging.ts", "../src/components/shared/Icon.tsx", "../src/components/shared/Button.tsx", "../src/components/shared/NonIdealState.tsx", "../src/components/shared/FetchOfferErrorState.tsx", "../src/lib/getServicePriceMapById.ts", "../src/lib/getTotalAmountForServices.ts", "../src/lib/compileCreateOrderPayload.ts", "../src/lib/createPriceFormatters.ts", "../src/lib/isBaggageService.ts", "../src/lib/isCancelForAnyReasonService.ts", "../src/lib/formatAvailableServices.ts", "../src/lib/isSeatElement.ts", "../src/lib/formatSeatMaps.ts", "../src/lib/hasHighLuminance.ts", "../src/lib/isPayloadComplete.ts", "../src/lib/offerIsExpired.ts", "../src/lib/fetchFromDuffelAPI.ts", "../src/lib/fetchFromFixtures.ts", "../src/lib/isFixtureOfferId.ts", "../src/lib/retrieveOfferFromDuffelAPI.ts", "../src/lib/retrieveOffer.ts", "../src/lib/retrieveSeatMapsFromDuffelAPI.ts", "../src/lib/retrieveSeatMaps.ts", "../src/lib/validateProps.ts", "../src/components/DuffelAncillaries/DuffelAncillaries.tsx", "../src/components/shared/AnimatedLoaderEllipsis.tsx", "../src/components/shared/Stamp.tsx", "../src/lib/getCurrencyForServices.ts", "../src/lib/getTotalQuantity.ts", "../src/lib/hasService.ts", "../src/lib/moneyStringFormatter.ts", "../src/lib/withPlural.ts", "../src/components/DuffelAncillaries/bags/BaggageSelectionCard.tsx", "../src/components/DuffelAncillaries/Card.tsx", "../src/lib/setBodyScrollability.ts", "../src/components/shared/Modal.tsx", "../src/components/shared/IconButton.tsx", "../src/lib/getPassengerMapById.ts", "../src/lib/getSegmentList.ts", "../src/components/DuffelAncillaries/bags/BaggageSelectionModal.tsx", "../src/lib/getPassengerName.ts", "../src/lib/getBaggageServiceDescription.ts", "../src/lib/hasServiceOfSameMetadataTypeAlreadyBeenSelected.ts", "../src/components/DuffelAncillaries/Counter.tsx", "../src/components/DuffelAncillaries/bags/BaggageSelectionController.tsx", "../src/components/DuffelAncillaries/bags/IncludedBaggageBanner.tsx", "../src/components/DuffelAncillaries/bags/BaggageSelectionModalBodyPassenger.tsx", "../src/components/DuffelAncillaries/bags/BaggageSelectionModalBody.tsx", "../src/components/DuffelAncillaries/bags/BaggageSelectionModalFooter.tsx", "../src/lib/formatDate.ts", "../src/components/DuffelAncillaries/bags/BaggageSelectionModalHeader.tsx", "../src/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionCard.tsx", "../src/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModalBodyListItem.tsx", "../src/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModalBody.tsx", "../src/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModalFooter.tsx", "../src/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModalHeader.tsx", "../src/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModal.tsx", "../src/lib/getFirstSeatElementMatchingCriteria.ts", "../src/lib/getCurrencyForSeatMaps.ts", "../src/components/DuffelAncillaries/seats/SeatSelectionCard.tsx", "../src/lib/getPassengerBySegmentList.ts", "../src/components/DuffelAncillaries/seats/SeatSelectionModal.tsx", "../src/lib/getCabinsForSegmentAndDeck.ts", "../src/lib/getSymbols.ts", "../src/lib/hasWings.ts", "../src/components/DuffelAncillaries/seats/SeatMap.tsx", "../src/components/shared/Tabs.tsx", "../src/components/DuffelAncillaries/seats/DeckSelect.tsx", "../src/components/DuffelAncillaries/seats/Legend.tsx", "../src/lib/getRowNumber.ts", "../src/components/DuffelAncillaries/seats/RowSection.tsx", "../src/components/DuffelAncillaries/seats/Amenity.tsx", "../src/components/DuffelAncillaries/seats/EmptyElement.tsx", "../src/components/DuffelAncillaries/seats/ExitElement.tsx", "../src/lib/getPassengerInitials.ts", "../src/components/DuffelAncillaries/seats/SeatElement.tsx", "../src/components/DuffelAncillaries/seats/SeatInfo.tsx", "../src/components/DuffelAncillaries/seats/SeatUnavailable.tsx", "../src/components/DuffelAncillaries/seats/Element.tsx", "../src/components/DuffelAncillaries/seats/Row.tsx", "../src/components/DuffelAncillaries/seats/SeatMapUnavailable.tsx", "../src/components/DuffelAncillaries/seats/SeatSelectionModalBody.tsx", "../src/components/DuffelAncillaries/seats/SeatSelectionModalFooter.tsx", "../src/components/DuffelAncillaries/seats/SeatSelectionModalHeader.tsx", "../src/components/DuffelPayments/DuffelPaymentsCustomElement.tsx", "../src/components/DuffelPayments/DuffelPayments.tsx", "../../../.yarn/berry/cache/@stripe-stripe-js-npm-1.54.0-af9040fe9b-10c0.zip/node_modules/@stripe/stripe-js/dist/stripe.esm.js"],
4
- "sourcesContent": ["/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\tvar nativeCodeString = '[native code]';\n\n\tfunction classNames() {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg)) {\n\t\t\t\tif (arg.length) {\n\t\t\t\t\tvar inner = classNames.apply(null, arg);\n\t\t\t\t\tif (inner) {\n\t\t\t\t\t\tclasses.push(inner);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\t\t\tclasses.push(arg.toString());\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tfor (var key in arg) {\n\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n", "(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react')) :\n typeof define === 'function' && define.amd ? define(['exports', 'react'], factory) :\n (global = global || self, factory(global.ReactStripe = {}, global.React));\n}(this, (function (exports, React) { 'use strict';\n\n React = React && Object.prototype.hasOwnProperty.call(React, 'default') ? React['default'] : React;\n\n function ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n\n if (enumerableOnly) {\n symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n }\n\n keys.push.apply(keys, symbols);\n }\n\n return keys;\n }\n\n function _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(Object(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(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n }\n\n return target;\n }\n\n function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n _typeof = function (obj) {\n return typeof obj;\n };\n } else {\n _typeof = function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n }\n\n function _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\n function _slicedToArray(arr, i) {\n return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();\n }\n\n function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n }\n\n function _iterableToArrayLimit(arr, i) {\n var _i = arr && (typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"]);\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n }\n\n function _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 }\n\n function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n\n return arr2;\n }\n\n function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n function createCommonjsModule(fn, module) {\n \treturn module = { exports: {} }, fn(module, module.exports), module.exports;\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\n var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n var ReactPropTypesSecret_1 = ReactPropTypesSecret;\n\n function emptyFunction() {}\n\n function emptyFunctionWithReset() {}\n\n emptyFunctionWithReset.resetWarningCache = emptyFunction;\n\n var factoryWithThrowingShims = function () {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret_1) {\n // It is still safe when called from React.\n return;\n }\n\n var err = new Error('Calling PropTypes validators directly is not supported by the `prop-types` package. ' + 'Use PropTypes.checkPropTypes() to call them. ' + 'Read more at http://fb.me/use-check-prop-types');\n err.name = 'Invariant Violation';\n throw err;\n }\n shim.isRequired = shim;\n\n function getShim() {\n return shim;\n }\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\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 checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n ReactPropTypes.PropTypes = ReactPropTypes;\n return ReactPropTypes;\n };\n\n var propTypes = createCommonjsModule(function (module) {\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 // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = factoryWithThrowingShims();\n }\n });\n\n var usePrevious = function usePrevious(value) {\n var ref = React.useRef(value);\n React.useEffect(function () {\n ref.current = value;\n }, [value]);\n return ref.current;\n };\n\n var isUnknownObject = function isUnknownObject(raw) {\n return raw !== null && _typeof(raw) === 'object';\n };\n var isPromise = function isPromise(raw) {\n return isUnknownObject(raw) && typeof raw.then === 'function';\n }; // We are using types to enforce the `stripe` prop in this lib,\n // but in an untyped integration `stripe` could be anything, so we need\n // to do some sanity validation to prevent type errors.\n\n var isStripe = function isStripe(raw) {\n return isUnknownObject(raw) && typeof raw.elements === 'function' && typeof raw.createToken === 'function' && typeof raw.createPaymentMethod === 'function' && typeof raw.confirmCardPayment === 'function';\n };\n\n var PLAIN_OBJECT_STR = '[object Object]';\n var isEqual = function isEqual(left, right) {\n if (!isUnknownObject(left) || !isUnknownObject(right)) {\n return left === right;\n }\n\n var leftArray = Array.isArray(left);\n var rightArray = Array.isArray(right);\n if (leftArray !== rightArray) return false;\n var leftPlainObject = Object.prototype.toString.call(left) === PLAIN_OBJECT_STR;\n var rightPlainObject = Object.prototype.toString.call(right) === PLAIN_OBJECT_STR;\n if (leftPlainObject !== rightPlainObject) return false; // not sure what sort of special object this is (regexp is one option), so\n // fallback to reference check.\n\n if (!leftPlainObject && !leftArray) return left === right;\n var leftKeys = Object.keys(left);\n var rightKeys = Object.keys(right);\n if (leftKeys.length !== rightKeys.length) return false;\n var keySet = {};\n\n for (var i = 0; i < leftKeys.length; i += 1) {\n keySet[leftKeys[i]] = true;\n }\n\n for (var _i = 0; _i < rightKeys.length; _i += 1) {\n keySet[rightKeys[_i]] = true;\n }\n\n var allKeys = Object.keys(keySet);\n\n if (allKeys.length !== leftKeys.length) {\n return false;\n }\n\n var l = left;\n var r = right;\n\n var pred = function pred(key) {\n return isEqual(l[key], r[key]);\n };\n\n return allKeys.every(pred);\n };\n\n var extractAllowedOptionsUpdates = function extractAllowedOptionsUpdates(options, prevOptions, immutableKeys) {\n if (!isUnknownObject(options)) {\n return null;\n }\n\n return Object.keys(options).reduce(function (newOptions, key) {\n var isUpdated = !isUnknownObject(prevOptions) || !isEqual(options[key], prevOptions[key]);\n\n if (immutableKeys.includes(key)) {\n if (isUpdated) {\n console.warn(\"Unsupported prop change: options.\".concat(key, \" is not a mutable property.\"));\n }\n\n return newOptions;\n }\n\n if (!isUpdated) {\n return newOptions;\n }\n\n return _objectSpread2(_objectSpread2({}, newOptions || {}), {}, _defineProperty({}, key, options[key]));\n }, null);\n };\n\n var INVALID_STRIPE_ERROR = 'Invalid prop `stripe` supplied to `Elements`. We recommend using the `loadStripe` utility from `@stripe/stripe-js`. See https://stripe.com/docs/stripe-js/react#elements-props-stripe for details.'; // We are using types to enforce the `stripe` prop in this lib, but in a real\n // integration `stripe` could be anything, so we need to do some sanity\n // validation to prevent type errors.\n\n var validateStripe = function validateStripe(maybeStripe) {\n if (maybeStripe === null || isStripe(maybeStripe)) {\n return maybeStripe;\n }\n\n throw new Error(INVALID_STRIPE_ERROR);\n };\n\n var parseStripeProp = function parseStripeProp(raw) {\n if (isPromise(raw)) {\n return {\n tag: 'async',\n stripePromise: Promise.resolve(raw).then(validateStripe)\n };\n }\n\n var stripe = validateStripe(raw);\n\n if (stripe === null) {\n return {\n tag: 'empty'\n };\n }\n\n return {\n tag: 'sync',\n stripe: stripe\n };\n };\n\n var ElementsContext = /*#__PURE__*/React.createContext(null);\n ElementsContext.displayName = 'ElementsContext';\n var parseElementsContext = function parseElementsContext(ctx, useCase) {\n if (!ctx) {\n throw new Error(\"Could not find Elements context; You need to wrap the part of your app that \".concat(useCase, \" in an <Elements> provider.\"));\n }\n\n return ctx;\n };\n var CartElementContext = /*#__PURE__*/React.createContext(null);\n CartElementContext.displayName = 'CartElementContext';\n var parseCartElementContext = function parseCartElementContext(ctx, useCase) {\n if (!ctx) {\n throw new Error(\"Could not find Elements context; You need to wrap the part of your app that \".concat(useCase, \" in an <Elements> provider.\"));\n }\n\n return ctx;\n };\n /**\n * The `Elements` provider allows you to use [Element components](https://stripe.com/docs/stripe-js/react#element-components) and access the [Stripe object](https://stripe.com/docs/js/initializing) in any nested component.\n * Render an `Elements` provider at the root of your React app so that it is available everywhere you need it.\n *\n * To use the `Elements` provider, call `loadStripe` from `@stripe/stripe-js` with your publishable key.\n * The `loadStripe` function will asynchronously load the Stripe.js script and initialize a `Stripe` object.\n * Pass the returned `Promise` to `Elements`.\n *\n * @docs https://stripe.com/docs/stripe-js/react#elements-provider\n */\n\n var Elements = function Elements(_ref) {\n var rawStripeProp = _ref.stripe,\n options = _ref.options,\n children = _ref.children;\n var parsed = React.useMemo(function () {\n return parseStripeProp(rawStripeProp);\n }, [rawStripeProp]);\n\n var _React$useState = React.useState(null),\n _React$useState2 = _slicedToArray(_React$useState, 2),\n cart = _React$useState2[0],\n setCart = _React$useState2[1];\n\n var _React$useState3 = React.useState(null),\n _React$useState4 = _slicedToArray(_React$useState3, 2),\n cartState = _React$useState4[0],\n setCartState = _React$useState4[1]; // For a sync stripe instance, initialize into context\n\n\n var _React$useState5 = React.useState(function () {\n return {\n stripe: parsed.tag === 'sync' ? parsed.stripe : null,\n elements: parsed.tag === 'sync' ? parsed.stripe.elements(options) : null\n };\n }),\n _React$useState6 = _slicedToArray(_React$useState5, 2),\n ctx = _React$useState6[0],\n setContext = _React$useState6[1];\n\n React.useEffect(function () {\n var isMounted = true;\n\n var safeSetContext = function safeSetContext(stripe) {\n setContext(function (ctx) {\n // no-op if we already have a stripe instance (https://github.com/stripe/react-stripe-js/issues/296)\n if (ctx.stripe) return ctx;\n return {\n stripe: stripe,\n elements: stripe.elements(options)\n };\n });\n }; // For an async stripePromise, store it in context once resolved\n\n\n if (parsed.tag === 'async' && !ctx.stripe) {\n parsed.stripePromise.then(function (stripe) {\n if (stripe && isMounted) {\n // Only update Elements context if the component is still mounted\n // and stripe is not null. We allow stripe to be null to make\n // handling SSR easier.\n safeSetContext(stripe);\n }\n });\n } else if (parsed.tag === 'sync' && !ctx.stripe) {\n // Or, handle a sync stripe instance going from null -> populated\n safeSetContext(parsed.stripe);\n }\n\n return function () {\n isMounted = false;\n };\n }, [parsed, ctx, options]); // Warn on changes to stripe prop\n\n var prevStripe = usePrevious(rawStripeProp);\n React.useEffect(function () {\n if (prevStripe !== null && prevStripe !== rawStripeProp) {\n console.warn('Unsupported prop change on Elements: You cannot change the `stripe` prop after setting it.');\n }\n }, [prevStripe, rawStripeProp]); // Apply updates to elements when options prop has relevant changes\n\n var prevOptions = usePrevious(options);\n React.useEffect(function () {\n if (!ctx.elements) {\n return;\n }\n\n var updates = extractAllowedOptionsUpdates(options, prevOptions, ['clientSecret', 'fonts']);\n\n if (updates) {\n ctx.elements.update(updates);\n }\n }, [options, prevOptions, ctx.elements]); // Attach react-stripe-js version to stripe.js instance\n\n React.useEffect(function () {\n var anyStripe = ctx.stripe;\n\n if (!anyStripe || !anyStripe._registerWrapper || !anyStripe.registerAppInfo) {\n return;\n }\n\n anyStripe._registerWrapper({\n name: 'react-stripe-js',\n version: \"2.1.0\"\n });\n\n anyStripe.registerAppInfo({\n name: 'react-stripe-js',\n version: \"2.1.0\",\n url: 'https://stripe.com/docs/stripe-js/react'\n });\n }, [ctx.stripe]);\n return /*#__PURE__*/React.createElement(ElementsContext.Provider, {\n value: ctx\n }, /*#__PURE__*/React.createElement(CartElementContext.Provider, {\n value: {\n cart: cart,\n setCart: setCart,\n cartState: cartState,\n setCartState: setCartState\n }\n }, children));\n };\n Elements.propTypes = {\n stripe: propTypes.any,\n options: propTypes.object\n };\n var useElementsContextWithUseCase = function useElementsContextWithUseCase(useCaseMessage) {\n var ctx = React.useContext(ElementsContext);\n return parseElementsContext(ctx, useCaseMessage);\n };\n var useCartElementContextWithUseCase = function useCartElementContextWithUseCase(useCaseMessage) {\n var ctx = React.useContext(CartElementContext);\n return parseCartElementContext(ctx, useCaseMessage);\n };\n /**\n * @docs https://stripe.com/docs/stripe-js/react#useelements-hook\n */\n\n var useElements = function useElements() {\n var _useElementsContextWi = useElementsContextWithUseCase('calls useElements()'),\n elements = _useElementsContextWi.elements;\n\n return elements;\n };\n /**\n * @docs https://stripe.com/docs/stripe-js/react#usestripe-hook\n */\n\n var useStripe = function useStripe() {\n var _useElementsContextWi2 = useElementsContextWithUseCase('calls useStripe()'),\n stripe = _useElementsContextWi2.stripe;\n\n return stripe;\n };\n /**\n * @docs https://stripe.com/docs/payments/checkout/cart-element\n */\n\n var useCartElement = function useCartElement() {\n var _useCartElementContex = useCartElementContextWithUseCase('calls useCartElement()'),\n cart = _useCartElementContex.cart;\n\n return cart;\n };\n /**\n * @docs https://stripe.com/docs/payments/checkout/cart-element\n */\n\n var useCartElementState = function useCartElementState() {\n var _useCartElementContex2 = useCartElementContextWithUseCase('calls useCartElementState()'),\n cartState = _useCartElementContex2.cartState;\n\n return cartState;\n };\n /**\n * @docs https://stripe.com/docs/stripe-js/react#elements-consumer\n */\n\n var ElementsConsumer = function ElementsConsumer(_ref2) {\n var children = _ref2.children;\n var ctx = useElementsContextWithUseCase('mounts <ElementsConsumer>'); // Assert to satisfy the busted React.FC return type (it should be ReactNode)\n\n return children(ctx);\n };\n ElementsConsumer.propTypes = {\n children: propTypes.func.isRequired\n };\n\n var useAttachEvent = function useAttachEvent(element, event, cb) {\n var cbDefined = !!cb;\n var cbRef = React.useRef(cb); // In many integrations the callback prop changes on each render.\n // Using a ref saves us from calling element.on/.off every render.\n\n React.useEffect(function () {\n cbRef.current = cb;\n }, [cb]);\n React.useEffect(function () {\n if (!cbDefined || !element) {\n return function () {};\n }\n\n var decoratedCb = function decoratedCb() {\n if (cbRef.current) {\n cbRef.current.apply(cbRef, arguments);\n }\n };\n\n element.on(event, decoratedCb);\n return function () {\n element.off(event, decoratedCb);\n };\n }, [cbDefined, event, element, cbRef]);\n };\n\n var capitalized = function capitalized(str) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n };\n\n var createElementComponent = function createElementComponent(type, isServer) {\n var displayName = \"\".concat(capitalized(type), \"Element\");\n\n var ClientElement = function ClientElement(_ref) {\n var id = _ref.id,\n className = _ref.className,\n _ref$options = _ref.options,\n options = _ref$options === void 0 ? {} : _ref$options,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus,\n onReady = _ref.onReady,\n onChange = _ref.onChange,\n onEscape = _ref.onEscape,\n onClick = _ref.onClick,\n onLoadError = _ref.onLoadError,\n onLoaderStart = _ref.onLoaderStart,\n onNetworksChange = _ref.onNetworksChange,\n onCheckout = _ref.onCheckout,\n onLineItemClick = _ref.onLineItemClick,\n onConfirm = _ref.onConfirm,\n onCancel = _ref.onCancel,\n onShippingAddressChange = _ref.onShippingAddressChange,\n onShippingRateChange = _ref.onShippingRateChange;\n\n var _useElementsContextWi = useElementsContextWithUseCase(\"mounts <\".concat(displayName, \">\")),\n elements = _useElementsContextWi.elements;\n\n var _React$useState = React.useState(null),\n _React$useState2 = _slicedToArray(_React$useState, 2),\n element = _React$useState2[0],\n setElement = _React$useState2[1];\n\n var elementRef = React.useRef(null);\n var domNode = React.useRef(null);\n\n var _useCartElementContex = useCartElementContextWithUseCase(\"mounts <\".concat(displayName, \">\")),\n setCart = _useCartElementContex.setCart,\n setCartState = _useCartElementContex.setCartState; // For every event where the merchant provides a callback, call element.on\n // with that callback. If the merchant ever changes the callback, removes\n // the old callback with element.off and then call element.on with the new one.\n\n\n useAttachEvent(element, 'blur', onBlur);\n useAttachEvent(element, 'focus', onFocus);\n useAttachEvent(element, 'escape', onEscape);\n useAttachEvent(element, 'click', onClick);\n useAttachEvent(element, 'loaderror', onLoadError);\n useAttachEvent(element, 'loaderstart', onLoaderStart);\n useAttachEvent(element, 'networkschange', onNetworksChange);\n useAttachEvent(element, 'lineitemclick', onLineItemClick);\n useAttachEvent(element, 'confirm', onConfirm);\n useAttachEvent(element, 'cancel', onCancel);\n useAttachEvent(element, 'shippingaddresschange', onShippingAddressChange);\n useAttachEvent(element, 'shippingratechange', onShippingRateChange);\n var readyCallback;\n\n if (type === 'cart') {\n readyCallback = function readyCallback(event) {\n setCartState(event);\n onReady && onReady(event);\n };\n } else if (onReady) {\n if (type === 'expressCheckout') {\n // Passes through the event, which includes visible PM types\n readyCallback = onReady;\n } else {\n // For other Elements, pass through the Element itself.\n readyCallback = function readyCallback() {\n onReady(element);\n };\n }\n }\n\n useAttachEvent(element, 'ready', readyCallback);\n var changeCallback = type === 'cart' ? function (event) {\n setCartState(event);\n onChange && onChange(event);\n } : onChange;\n useAttachEvent(element, 'change', changeCallback);\n var checkoutCallback = type === 'cart' ? function (event) {\n setCartState(event);\n onCheckout && onCheckout(event);\n } : onCheckout;\n useAttachEvent(element, 'checkout', checkoutCallback);\n React.useLayoutEffect(function () {\n if (elementRef.current === null && elements && domNode.current !== null) {\n var newElement = elements.create(type, options);\n\n if (type === 'cart' && setCart) {\n // we know that elements.create return value must be of type StripeCartElement if type is 'cart',\n // we need to cast because typescript is not able to infer which overloaded method is used based off param type\n setCart(newElement);\n } // Store element in a ref to ensure it's _immediately_ available in cleanup hooks in StrictMode\n\n\n elementRef.current = newElement; // Store element in state to facilitate event listener attachment\n\n setElement(newElement);\n newElement.mount(domNode.current);\n }\n }, [elements, options, setCart]);\n var prevOptions = usePrevious(options);\n React.useEffect(function () {\n if (!elementRef.current) {\n return;\n }\n\n var updates = extractAllowedOptionsUpdates(options, prevOptions, ['paymentRequest']);\n\n if (updates) {\n elementRef.current.update(updates);\n }\n }, [options, prevOptions]);\n React.useLayoutEffect(function () {\n return function () {\n if (elementRef.current) {\n elementRef.current.destroy();\n elementRef.current = null;\n }\n };\n }, []);\n return /*#__PURE__*/React.createElement(\"div\", {\n id: id,\n className: className,\n ref: domNode\n });\n }; // Only render the Element wrapper in a server environment.\n\n\n var ServerElement = function ServerElement(props) {\n // Validate that we are in the right context by calling useElementsContextWithUseCase.\n useElementsContextWithUseCase(\"mounts <\".concat(displayName, \">\"));\n useCartElementContextWithUseCase(\"mounts <\".concat(displayName, \">\"));\n var id = props.id,\n className = props.className;\n return /*#__PURE__*/React.createElement(\"div\", {\n id: id,\n className: className\n });\n };\n\n var Element = isServer ? ServerElement : ClientElement;\n Element.propTypes = {\n id: propTypes.string,\n className: propTypes.string,\n onChange: propTypes.func,\n onBlur: propTypes.func,\n onFocus: propTypes.func,\n onReady: propTypes.func,\n onEscape: propTypes.func,\n onClick: propTypes.func,\n onLoadError: propTypes.func,\n onLoaderStart: propTypes.func,\n onNetworksChange: propTypes.func,\n onCheckout: propTypes.func,\n onLineItemClick: propTypes.func,\n onConfirm: propTypes.func,\n onCancel: propTypes.func,\n onShippingAddressChange: propTypes.func,\n onShippingRateChange: propTypes.func,\n options: propTypes.object\n };\n Element.displayName = displayName;\n Element.__elementType = type;\n return Element;\n };\n\n var isServer = typeof window === 'undefined';\n /**\n * Requires beta access:\n * Contact [Stripe support](https://support.stripe.com/) for more information.\n *\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var AuBankAccountElement = createElementComponent('auBankAccount', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var CardElement = createElementComponent('card', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var CardNumberElement = createElementComponent('cardNumber', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var CardExpiryElement = createElementComponent('cardExpiry', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var CardCvcElement = createElementComponent('cardCvc', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var FpxBankElement = createElementComponent('fpxBank', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var IbanElement = createElementComponent('iban', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var IdealBankElement = createElementComponent('idealBank', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var P24BankElement = createElementComponent('p24Bank', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var EpsBankElement = createElementComponent('epsBank', isServer);\n var PaymentElement = createElementComponent('payment', isServer);\n /**\n * Requires beta access:\n * Contact [Stripe support](https://support.stripe.com/) for more information.\n *\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var ExpressCheckoutElement = createElementComponent('expressCheckout', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var PaymentRequestButtonElement = createElementComponent('paymentRequestButton', isServer);\n /**\n * Requires beta access:\n * Contact [Stripe support](https://support.stripe.com/) for more information.\n *\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var LinkAuthenticationElement = createElementComponent('linkAuthentication', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var AddressElement = createElementComponent('address', isServer);\n /**\n * @deprecated\n * Use `AddressElement` instead.\n *\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var ShippingAddressElement = createElementComponent('shippingAddress', isServer);\n /**\n * Requires beta access:\n * Contact [Stripe support](https://support.stripe.com/) for more information.\n *\n * @docs https://stripe.com/docs/elements/cart-element\n */\n\n var CartElement = createElementComponent('cart', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var PaymentMethodMessagingElement = createElementComponent('paymentMethodMessaging', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var AffirmMessageElement = createElementComponent('affirmMessage', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var AfterpayClearpayMessageElement = createElementComponent('afterpayClearpayMessage', isServer);\n\n exports.AddressElement = AddressElement;\n exports.AffirmMessageElement = AffirmMessageElement;\n exports.AfterpayClearpayMessageElement = AfterpayClearpayMessageElement;\n exports.AuBankAccountElement = AuBankAccountElement;\n exports.CardCvcElement = CardCvcElement;\n exports.CardElement = CardElement;\n exports.CardExpiryElement = CardExpiryElement;\n exports.CardNumberElement = CardNumberElement;\n exports.CartElement = CartElement;\n exports.Elements = Elements;\n exports.ElementsConsumer = ElementsConsumer;\n exports.EpsBankElement = EpsBankElement;\n exports.ExpressCheckoutElement = ExpressCheckoutElement;\n exports.FpxBankElement = FpxBankElement;\n exports.IbanElement = IbanElement;\n exports.IdealBankElement = IdealBankElement;\n exports.LinkAuthenticationElement = LinkAuthenticationElement;\n exports.P24BankElement = P24BankElement;\n exports.PaymentElement = PaymentElement;\n exports.PaymentMethodMessagingElement = PaymentMethodMessagingElement;\n exports.PaymentRequestButtonElement = PaymentRequestButtonElement;\n exports.ShippingAddressElement = ShippingAddressElement;\n exports.useCartElement = useCartElement;\n exports.useCartElementState = useCartElementState;\n exports.useElements = useElements;\n exports.useStripe = useStripe;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n})));\n", "/**\n * This file is one of the entry points for the library -- `@duffel/components/custom-elements`.\n * If you'd like to expose other custom element functions, please add them here.\n */\nexport {\n onDuffelAncillariesPayloadReady,\n renderDuffelAncillariesCustomElement,\n} from \"./components/DuffelAncillaries/DuffelAncillariesCustomElement\";\nexport {\n onDuffelPaymentsFailedPayment,\n onDuffelPaymentsSuccessfulPayment,\n renderDuffelPaymentsCustomElement,\n} from \"./components/DuffelPayments/DuffelPaymentsCustomElement\";\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { createRoot, Root } from \"react-dom/client\";\nimport {\n DuffelAncillariesPropsWithClientKeyAndOfferId,\n DuffelAncillariesPropsWithOfferIdForFixture,\n DuffelAncillariesPropsWithOffersAndSeatMaps,\n DuffelAncillariesPropWithOfferAndClientKey,\n OnPayloadReady,\n OnPayloadReadyMetadata,\n} from \"../../types/DuffelAncillariesProps\";\nimport { DuffelAncillaries } from \"./DuffelAncillaries\";\nimport { CreateOrder } from \"@duffel/api/types\";\n\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/no-namespace\n namespace JSX {\n interface IntrinsicElements {\n \"duffel-ancillaries\": React.DetailedHTMLProps<\n React.HTMLAttributes<HTMLElement>,\n HTMLElement\n >;\n }\n }\n}\n\nconst CUSTOM_ELEMENT_TAG = \"duffel-ancillaries\";\n\n// A bit reptitive but typescript is not clever enough\n// to infer the correct type if we just use\n// `Omit<DuffelAncillariesProps, 'onPayloadReady'>`\ntype DuffelAncillariesCustomElementRenderArguments =\n | Omit<DuffelAncillariesPropsWithOfferIdForFixture, \"onPayloadReady\">\n | Omit<DuffelAncillariesPropsWithClientKeyAndOfferId, \"onPayloadReady\">\n | Omit<DuffelAncillariesPropWithOfferAndClientKey, \"onPayloadReady\">\n | Omit<DuffelAncillariesPropsWithOffersAndSeatMaps, \"onPayloadReady\">;\n\nclass DuffelAncillariesCustomElement extends HTMLElement {\n /**\n * The React root for displaying content inside a browser DOM element.\n */\n private root!: Root;\n\n /**\n * `connectedCallback` is called to initialise the custom element\n */\n connectedCallback() {\n const container = document.createElement(\"div\");\n this.attachShadow({ mode: \"open\" }).appendChild(container);\n\n this.root = createRoot(container);\n }\n\n /**\n * When this function is called, it will render/re-render\n * the `DuffelAncillaries` component with the given props.\n */\n public render(withProps: DuffelAncillariesCustomElementRenderArguments) {\n if (!this.root) {\n throw \"It was not possible to render `duffel-ancillaries` because `this.root` is missing.\";\n }\n\n this.root.render(\n <DuffelAncillaries\n {...withProps}\n onPayloadReady={(data, metadata) => {\n this.dispatchEvent(\n new CustomEvent(\"onPayloadReady\", {\n detail: { data, metadata },\n composed: true,\n })\n );\n }}\n />\n );\n }\n}\n\nwindow.customElements.get(CUSTOM_ELEMENT_TAG) ||\n window.customElements.define(\n CUSTOM_ELEMENT_TAG,\n DuffelAncillariesCustomElement\n );\n\nfunction tryToGetDuffelAncillariesCustomElement(\n caller: string\n): DuffelAncillariesCustomElement {\n const element =\n document.querySelector<DuffelAncillariesCustomElement>(CUSTOM_ELEMENT_TAG);\n if (!element) {\n throw new Error(\n `Could not find duffel-ancillaries element in the DOM. Maybe you need to call ${caller} after 'window.onload'?`\n );\n }\n return element;\n}\n\nexport function renderDuffelAncillariesCustomElement(\n props: DuffelAncillariesCustomElementRenderArguments\n) {\n const element = tryToGetDuffelAncillariesCustomElement(\n \"renderDuffelAncillariesCustomElement\"\n );\n element.render(props);\n}\n\ntype OnPayloadReadyCustomEvent = CustomEvent<{\n data: CreateOrder;\n metadata: OnPayloadReadyMetadata;\n}>;\n\nexport function onDuffelAncillariesPayloadReady(\n onPayloadReady: OnPayloadReady\n) {\n const element = tryToGetDuffelAncillariesCustomElement(\n \"onDuffelAncillariesPayloadReady\"\n );\n const eventListener = (event: OnPayloadReadyCustomEvent) => {\n onPayloadReady(event.detail.data, event.detail.metadata);\n };\n\n // using `as EventListener` here because typescript doesn't know the event type for `onPayloadReady`\n // There's a few different suggestions to resolve this seemed good enough\n // You can learn more here: https://github.com/microsoft/TypeScript/issues/28357\n element.addEventListener(\"onPayloadReady\", eventListener as EventListener);\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n\nimport type { PolymorphicEvent, Primitive } from '@sentry/types';\n\n// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isError(wat: unknown): wat is Error {\n switch (objectToString.call(wat)) {\n case '[object Error]':\n case '[object Exception]':\n case '[object DOMException]':\n return true;\n default:\n return isInstanceOf(wat, Error);\n }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat: unknown, className: string): boolean {\n return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isErrorEvent(wat: unknown): boolean {\n return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isDOMError(wat: unknown): boolean {\n return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isDOMException(wat: unknown): boolean {\n return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isString(wat: unknown): wat is string {\n return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isPrimitive(wat: unknown): wat is Primitive {\n return wat === null || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isPlainObject(wat: unknown): wat is Record<string, unknown> {\n return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isEvent(wat: unknown): wat is PolymorphicEvent {\n return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isElement(wat: unknown): boolean {\n return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isRegExp(wat: unknown): wat is RegExp {\n return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nexport function isThenable(wat: any): wat is PromiseLike<any> {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return Boolean(wat && wat.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isSyntheticEvent(wat: unknown): boolean {\n return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value is NaN\n * {@link isNaN}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isNaN(wat: unknown): boolean {\n return typeof wat === 'number' && wat !== wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nexport function isInstanceOf(wat: any, base: any): boolean {\n try {\n return wat instanceof base;\n } catch (_e) {\n return false;\n }\n}\n\ninterface VueViewModel {\n // Vue3\n __isVue?: boolean;\n // Vue2\n _isVue?: boolean;\n}\n/**\n * Checks whether given value's type is a Vue ViewModel.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isVueViewModel(wat: unknown): boolean {\n // Not using Object.prototype.toString because in Vue 3 it would read the instance's Symbol(Symbol.toStringTag) property.\n return !!(typeof wat === 'object' && wat !== null && ((wat as VueViewModel).__isVue || (wat as VueViewModel)._isVue));\n}\n", "import { isRegExp, isString, isVueViewModel } from './is';\n\nexport { escapeStringForRegex } from './vendor/escapeStringForRegex';\n\n/**\n * Truncates given string to the maximum characters count\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string (0 = unlimited)\n * @returns string Encoded\n */\nexport function truncate(str: string, max: number = 0): string {\n if (typeof str !== 'string' || max === 0) {\n return str;\n }\n return str.length <= max ? str : `${str.slice(0, max)}...`;\n}\n\n/**\n * This is basically just `trim_line` from\n * https://github.com/getsentry/sentry/blob/master/src/sentry/lang/javascript/processor.py#L67\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string\n * @returns string Encoded\n */\nexport function snipLine(line: string, colno: number): string {\n let newLine = line;\n const lineLength = newLine.length;\n if (lineLength <= 150) {\n return newLine;\n }\n if (colno > lineLength) {\n // eslint-disable-next-line no-param-reassign\n colno = lineLength;\n }\n\n let start = Math.max(colno - 60, 0);\n if (start < 5) {\n start = 0;\n }\n\n let end = Math.min(start + 140, lineLength);\n if (end > lineLength - 5) {\n end = lineLength;\n }\n if (end === lineLength) {\n start = Math.max(end - 140, 0);\n }\n\n newLine = newLine.slice(start, end);\n if (start > 0) {\n newLine = `'{snip} ${newLine}`;\n }\n if (end < lineLength) {\n newLine += ' {snip}';\n }\n\n return newLine;\n}\n\n/**\n * Join values in array\n * @param input array of values to be joined together\n * @param delimiter string to be placed in-between values\n * @returns Joined values\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function safeJoin(input: any[], delimiter?: string): string {\n if (!Array.isArray(input)) {\n return '';\n }\n\n const output = [];\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < input.length; i++) {\n const value = input[i];\n try {\n // This is a hack to fix a Vue3-specific bug that causes an infinite loop of\n // console warnings. This happens when a Vue template is rendered with\n // an undeclared variable, which we try to stringify, ultimately causing\n // Vue to issue another warning which repeats indefinitely.\n // see: https://github.com/getsentry/sentry-javascript/pull/8981\n if (isVueViewModel(value)) {\n output.push('[VueViewModel]');\n } else {\n output.push(String(value));\n }\n } catch (e) {\n output.push('[value cannot be serialized]');\n }\n }\n\n return output.join(delimiter);\n}\n\n/**\n * Checks if the given value matches a regex or string\n *\n * @param value The string to test\n * @param pattern Either a regex or a string against which `value` will be matched\n * @param requireExactStringMatch If true, `value` must match `pattern` exactly. If false, `value` will match\n * `pattern` if it contains `pattern`. Only applies to string-type patterns.\n */\nexport function isMatchingPattern(\n value: string,\n pattern: RegExp | string,\n requireExactStringMatch: boolean = false,\n): boolean {\n if (!isString(value)) {\n return false;\n }\n\n if (isRegExp(pattern)) {\n return pattern.test(value);\n }\n if (isString(pattern)) {\n return requireExactStringMatch ? value === pattern : value.includes(pattern);\n }\n\n return false;\n}\n\n/**\n * Test the given string against an array of strings and regexes. By default, string matching is done on a\n * substring-inclusion basis rather than a strict equality basis\n *\n * @param testString The string to test\n * @param patterns The patterns against which to test the string\n * @param requireExactStringMatch If true, `testString` must match one of the given string patterns exactly in order to\n * count. If false, `testString` will match a string pattern if it contains that pattern.\n * @returns\n */\nexport function stringMatchesSomePattern(\n testString: string,\n patterns: Array<string | RegExp> = [],\n requireExactStringMatch: boolean = false,\n): boolean {\n return patterns.some(pattern => isMatchingPattern(testString, pattern, requireExactStringMatch));\n}\n", "import type { Event, EventHint, Exception, ExtendedError, StackParser } from '@sentry/types';\n\nimport { isInstanceOf } from './is';\nimport { truncate } from './string';\n\n/**\n * Creates exceptions inside `event.exception.values` for errors that are nested on properties based on the `key` parameter.\n */\nexport function applyAggregateErrorsToEvent(\n exceptionFromErrorImplementation: (stackParser: StackParser, ex: Error) => Exception,\n parser: StackParser,\n maxValueLimit: number = 250,\n key: string,\n limit: number,\n event: Event,\n hint?: EventHint,\n): void {\n if (!event.exception || !event.exception.values || !hint || !isInstanceOf(hint.originalException, Error)) {\n return;\n }\n\n // Generally speaking the last item in `event.exception.values` is the exception originating from the original Error\n const originalException: Exception | undefined =\n event.exception.values.length > 0 ? event.exception.values[event.exception.values.length - 1] : undefined;\n\n // We only create exception grouping if there is an exception in the event.\n if (originalException) {\n event.exception.values = truncateAggregateExceptions(\n aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n hint.originalException as ExtendedError,\n key,\n event.exception.values,\n originalException,\n 0,\n ),\n maxValueLimit,\n );\n }\n}\n\nfunction aggregateExceptionsFromError(\n exceptionFromErrorImplementation: (stackParser: StackParser, ex: Error) => Exception,\n parser: StackParser,\n limit: number,\n error: ExtendedError,\n key: string,\n prevExceptions: Exception[],\n exception: Exception,\n exceptionId: number,\n): Exception[] {\n if (prevExceptions.length >= limit + 1) {\n return prevExceptions;\n }\n\n let newExceptions = [...prevExceptions];\n\n if (isInstanceOf(error[key], Error)) {\n applyExceptionGroupFieldsForParentException(exception, exceptionId);\n const newException = exceptionFromErrorImplementation(parser, error[key]);\n const newExceptionId = newExceptions.length;\n applyExceptionGroupFieldsForChildException(newException, key, newExceptionId, exceptionId);\n newExceptions = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n error[key],\n key,\n [newException, ...newExceptions],\n newException,\n newExceptionId,\n );\n }\n\n // This will create exception grouping for AggregateErrors\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AggregateError\n if (Array.isArray(error.errors)) {\n error.errors.forEach((childError, i) => {\n if (isInstanceOf(childError, Error)) {\n applyExceptionGroupFieldsForParentException(exception, exceptionId);\n const newException = exceptionFromErrorImplementation(parser, childError);\n const newExceptionId = newExceptions.length;\n applyExceptionGroupFieldsForChildException(newException, `errors[${i}]`, newExceptionId, exceptionId);\n newExceptions = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n childError,\n key,\n [newException, ...newExceptions],\n newException,\n newExceptionId,\n );\n }\n });\n }\n\n return newExceptions;\n}\n\nfunction applyExceptionGroupFieldsForParentException(exception: Exception, exceptionId: number): void {\n // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n exception.mechanism = {\n ...exception.mechanism,\n is_exception_group: true,\n exception_id: exceptionId,\n };\n}\n\nfunction applyExceptionGroupFieldsForChildException(\n exception: Exception,\n source: string,\n exceptionId: number,\n parentId: number | undefined,\n): void {\n // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n exception.mechanism = {\n ...exception.mechanism,\n type: 'chained',\n source,\n exception_id: exceptionId,\n parent_id: parentId,\n };\n}\n\n/**\n * Truncate the message (exception.value) of all exceptions in the event.\n * Because this event processor is ran after `applyClientOptions`,\n * we need to truncate the message of the added exceptions here.\n */\nfunction truncateAggregateExceptions(exceptions: Exception[], maxValueLength: number): Exception[] {\n return exceptions.map(exception => {\n if (exception.value) {\n exception.value = truncate(exception.value, maxValueLength);\n }\n return exception;\n });\n}\n", "/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the logger, or b) put your function elsewhere.\n *\n * Note: This file was originally called `global.ts`, but was changed to unblock users which might be doing\n * string replaces with bundlers like Vite for `global` (would break imports that rely on importing from utils/src/global).\n *\n * Why worldwide?\n *\n * Why not?\n */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport type { Integration } from '@sentry/types';\n\nimport type { SdkSource } from './env';\n\n/** Internal global with common properties and Sentry extensions */\nexport interface InternalGlobal {\n navigator?: { userAgent?: string };\n console: Console;\n Sentry?: {\n Integrations?: Integration[];\n };\n onerror?: {\n (msg: unknown, url: unknown, line: unknown, column: unknown, error: unknown): boolean;\n __SENTRY_INSTRUMENTED__?: true;\n __SENTRY_LOADER__?: true;\n };\n onunhandledrejection?: {\n (event: unknown): boolean;\n __SENTRY_INSTRUMENTED__?: true;\n __SENTRY_LOADER__?: true;\n };\n SENTRY_ENVIRONMENT?: string;\n SENTRY_DSN?: string;\n SENTRY_RELEASE?: {\n id?: string;\n };\n SENTRY_SDK_SOURCE?: SdkSource;\n /**\n * Debug IDs are indirectly injected by Sentry CLI or bundler plugins to directly reference a particular source map\n * for resolving of a source file. The injected code will place an entry into the record for each loaded bundle/JS\n * file.\n */\n _sentryDebugIds?: Record<string, string>;\n __SENTRY__: {\n globalEventProcessors: any;\n hub: any;\n logger: any;\n extensions?: {\n /** Extension methods for the hub, which are bound to the current Hub instance */\n // eslint-disable-next-line @typescript-eslint/ban-types\n [key: string]: Function;\n };\n };\n /**\n * Raw module metadata that is injected by bundler plugins.\n *\n * Keys are `error.stack` strings, values are the metadata.\n */\n _sentryModuleMetadata?: Record<string, any>;\n}\n\n// The code below for 'isGlobalObj' and 'GLOBAL_OBJ' was copied from core-js before modification\n// https://github.com/zloirock/core-js/blob/1b944df55282cdc99c90db5f49eb0b6eda2cc0a3/packages/core-js/internals/global.js\n// core-js has the following licence:\n//\n// Copyright (c) 2014-2022 Denis Pushkarev\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/** Returns 'obj' if it's the global object, otherwise returns undefined */\nfunction isGlobalObj(obj: { Math?: Math }): any | undefined {\n return obj && obj.Math == Math ? obj : undefined;\n}\n\n/** Get's the global object for the current JavaScript runtime */\nexport const GLOBAL_OBJ: InternalGlobal =\n (typeof globalThis == 'object' && isGlobalObj(globalThis)) ||\n // eslint-disable-next-line no-restricted-globals\n (typeof window == 'object' && isGlobalObj(window)) ||\n (typeof self == 'object' && isGlobalObj(self)) ||\n (typeof global == 'object' && isGlobalObj(global)) ||\n (function (this: any) {\n return this;\n })() ||\n {};\n\n/**\n * @deprecated Use GLOBAL_OBJ instead or WINDOW from @sentry/browser. This will be removed in v8\n */\nexport function getGlobalObject<T>(): T & InternalGlobal {\n return GLOBAL_OBJ as T & InternalGlobal;\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nexport function getGlobalSingleton<T>(name: keyof InternalGlobal['__SENTRY__'], creator: () => T, obj?: unknown): T {\n const gbl = (obj || GLOBAL_OBJ) as InternalGlobal;\n const __SENTRY__ = (gbl.__SENTRY__ = gbl.__SENTRY__ || {});\n const singleton = __SENTRY__[name] || (__SENTRY__[name] = creator());\n return singleton;\n}\n", "import { isString } from './is';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nconst DEFAULT_MAX_STRING_LENGTH = 80;\n\n/**\n * Given a child DOM element, returns a query-selector statement describing that\n * and its ancestors\n * e.g. [HTMLElement] => body > div > input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nexport function htmlTreeAsString(\n elem: unknown,\n options: string[] | { keyAttrs?: string[]; maxStringLength?: number } = {},\n): string {\n type SimpleNode = {\n parentNode: SimpleNode;\n } | null;\n\n if (!elem) {\n return '<unknown>';\n }\n\n // try/catch both:\n // - accessing event.target (see getsentry/raven-js#838, #768)\n // - `htmlTreeAsString` because it's complex, and just accessing the DOM incorrectly\n // - can throw an exception in some circumstances.\n try {\n let currentElem = elem as SimpleNode;\n const MAX_TRAVERSE_HEIGHT = 5;\n const out = [];\n let height = 0;\n let len = 0;\n const separator = ' > ';\n const sepLength = separator.length;\n let nextStr;\n const keyAttrs = Array.isArray(options) ? options : options.keyAttrs;\n const maxStringLength = (!Array.isArray(options) && options.maxStringLength) || DEFAULT_MAX_STRING_LENGTH;\n\n while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) {\n nextStr = _htmlElementAsString(currentElem, keyAttrs);\n // bail out if\n // - nextStr is the 'html' element\n // - the length of the string that would be created exceeds maxStringLength\n // (ignore this limit if we are on the first iteration)\n if (nextStr === 'html' || (height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength)) {\n break;\n }\n\n out.push(nextStr);\n\n len += nextStr.length;\n currentElem = currentElem.parentNode;\n }\n\n return out.reverse().join(separator);\n } catch (_oO) {\n return '<unknown>';\n }\n}\n\n/**\n * Returns a simple, query-selector representation of a DOM element\n * e.g. [HTMLElement] => input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction _htmlElementAsString(el: unknown, keyAttrs?: string[]): string {\n const elem = el as {\n tagName?: string;\n id?: string;\n className?: string;\n getAttribute(key: string): string;\n };\n\n const out = [];\n let className;\n let classes;\n let key;\n let attr;\n let i;\n\n if (!elem || !elem.tagName) {\n return '';\n }\n\n out.push(elem.tagName.toLowerCase());\n\n // Pairs of attribute keys defined in `serializeAttribute` and their values on element.\n const keyAttrPairs =\n keyAttrs && keyAttrs.length\n ? keyAttrs.filter(keyAttr => elem.getAttribute(keyAttr)).map(keyAttr => [keyAttr, elem.getAttribute(keyAttr)])\n : null;\n\n if (keyAttrPairs && keyAttrPairs.length) {\n keyAttrPairs.forEach(keyAttrPair => {\n out.push(`[${keyAttrPair[0]}=\"${keyAttrPair[1]}\"]`);\n });\n } else {\n if (elem.id) {\n out.push(`#${elem.id}`);\n }\n\n // eslint-disable-next-line prefer-const\n className = elem.className;\n if (className && isString(className)) {\n classes = className.split(/\\s+/);\n for (i = 0; i < classes.length; i++) {\n out.push(`.${classes[i]}`);\n }\n }\n }\n const allowedAttrs = ['aria-label', 'type', 'name', 'title', 'alt'];\n for (i = 0; i < allowedAttrs.length; i++) {\n key = allowedAttrs[i];\n attr = elem.getAttribute(key);\n if (attr) {\n out.push(`[${key}=\"${attr}\"]`);\n }\n }\n return out.join('');\n}\n\n/**\n * A safe form of location.href\n */\nexport function getLocationHref(): string {\n try {\n return WINDOW.document.location.href;\n } catch (oO) {\n return '';\n }\n}\n\n/**\n * Gets a DOM element by using document.querySelector.\n *\n * This wrapper will first check for the existance of the function before\n * actually calling it so that we don't have to take care of this check,\n * every time we want to access the DOM.\n *\n * Reason: DOM/querySelector is not available in all environments.\n *\n * We have to cast to any because utils can be consumed by a variety of environments,\n * and we don't want to break TS users. If you know what element will be selected by\n * `document.querySelector`, specify it as part of the generic call. For example,\n * `const element = getDomElement<Element>('selector');`\n *\n * @param selector the selector string passed on to document.querySelector\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getDomElement<E = any>(selector: string): E | null {\n if (WINDOW.document && WINDOW.document.querySelector) {\n return WINDOW.document.querySelector(selector) as unknown as E;\n }\n return null;\n}\n", "import { GLOBAL_OBJ } from './worldwide';\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\nexport const CONSOLE_LEVELS = ['debug', 'info', 'warn', 'error', 'log', 'assert', 'trace'] as const;\nexport type ConsoleLevel = (typeof CONSOLE_LEVELS)[number];\n\ntype LoggerMethod = (...args: unknown[]) => void;\ntype LoggerConsoleMethods = Record<ConsoleLevel, LoggerMethod>;\n\n/** This may be mutated by the console instrumentation. */\nexport const originalConsoleMethods: {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key in ConsoleLevel]?: (...args: any[]) => void;\n} = {};\n\n/** JSDoc */\ninterface Logger extends LoggerConsoleMethods {\n disable(): void;\n enable(): void;\n isEnabled(): boolean;\n}\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nexport function consoleSandbox<T>(callback: () => T): T {\n if (!('console' in GLOBAL_OBJ)) {\n return callback();\n }\n\n const console = GLOBAL_OBJ.console as Console;\n const wrappedFuncs: Partial<LoggerConsoleMethods> = {};\n\n const wrappedLevels = Object.keys(originalConsoleMethods) as ConsoleLevel[];\n\n // Restore all wrapped console methods\n wrappedLevels.forEach(level => {\n const originalConsoleMethod = originalConsoleMethods[level] as LoggerMethod;\n wrappedFuncs[level] = console[level] as LoggerMethod | undefined;\n console[level] = originalConsoleMethod;\n });\n\n try {\n return callback();\n } finally {\n // Revert restoration to wrapped state\n wrappedLevels.forEach(level => {\n console[level] = wrappedFuncs[level] as LoggerMethod;\n });\n }\n}\n\nfunction makeLogger(): Logger {\n let enabled = false;\n const logger: Partial<Logger> = {\n enable: () => {\n enabled = true;\n },\n disable: () => {\n enabled = false;\n },\n isEnabled: () => enabled,\n };\n\n if (__DEBUG_BUILD__) {\n CONSOLE_LEVELS.forEach(name => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n logger[name] = (...args: any[]) => {\n if (enabled) {\n consoleSandbox(() => {\n GLOBAL_OBJ.console[name](`${PREFIX}[${name}]:`, ...args);\n });\n }\n };\n });\n } else {\n CONSOLE_LEVELS.forEach(name => {\n logger[name] = () => undefined;\n });\n }\n\n return logger as Logger;\n}\n\nexport const logger = makeLogger();\n", "import type { DsnComponents, DsnLike, DsnProtocol } from '@sentry/types';\n\nimport { logger } from './logger';\n\n/** Regular expression used to parse a Dsn. */\nconst DSN_REGEX = /^(?:(\\w+):)\\/\\/(?:(\\w+)(?::(\\w+)?)?@)([\\w.-]+)(?::(\\d+))?\\/(.+)/;\n\nfunction isValidProtocol(protocol?: string): protocol is DsnProtocol {\n return protocol === 'http' || protocol === 'https';\n}\n\n/**\n * Renders the string representation of this Dsn.\n *\n * By default, this will render the public representation without the password\n * component. To get the deprecated private representation, set `withPassword`\n * to true.\n *\n * @param withPassword When set to true, the password will be included.\n */\nexport function dsnToString(dsn: DsnComponents, withPassword: boolean = false): string {\n const { host, path, pass, port, projectId, protocol, publicKey } = dsn;\n return (\n `${protocol}://${publicKey}${withPassword && pass ? `:${pass}` : ''}` +\n `@${host}${port ? `:${port}` : ''}/${path ? `${path}/` : path}${projectId}`\n );\n}\n\n/**\n * Parses a Dsn from a given string.\n *\n * @param str A Dsn as string\n * @returns Dsn as DsnComponents or undefined if @param str is not a valid DSN string\n */\nexport function dsnFromString(str: string): DsnComponents | undefined {\n const match = DSN_REGEX.exec(str);\n\n if (!match) {\n // This should be logged to the console\n // eslint-disable-next-line no-console\n console.error(`Invalid Sentry Dsn: ${str}`);\n return undefined;\n }\n\n const [protocol, publicKey, pass = '', host, port = '', lastPath] = match.slice(1);\n let path = '';\n let projectId = lastPath;\n\n const split = projectId.split('/');\n if (split.length > 1) {\n path = split.slice(0, -1).join('/');\n projectId = split.pop() as string;\n }\n\n if (projectId) {\n const projectMatch = projectId.match(/^\\d+/);\n if (projectMatch) {\n projectId = projectMatch[0];\n }\n }\n\n return dsnFromComponents({ host, pass, path, projectId, port, protocol: protocol as DsnProtocol, publicKey });\n}\n\nfunction dsnFromComponents(components: DsnComponents): DsnComponents {\n return {\n protocol: components.protocol,\n publicKey: components.publicKey || '',\n pass: components.pass || '',\n host: components.host,\n port: components.port || '',\n path: components.path || '',\n projectId: components.projectId,\n };\n}\n\nfunction validateDsn(dsn: DsnComponents): boolean {\n if (!__DEBUG_BUILD__) {\n return true;\n }\n\n const { port, projectId, protocol } = dsn;\n\n const requiredComponents: ReadonlyArray<keyof DsnComponents> = ['protocol', 'publicKey', 'host', 'projectId'];\n const hasMissingRequiredComponent = requiredComponents.find(component => {\n if (!dsn[component]) {\n logger.error(`Invalid Sentry Dsn: ${component} missing`);\n return true;\n }\n return false;\n });\n\n if (hasMissingRequiredComponent) {\n return false;\n }\n\n if (!projectId.match(/^\\d+$/)) {\n logger.error(`Invalid Sentry Dsn: Invalid projectId ${projectId}`);\n return false;\n }\n\n if (!isValidProtocol(protocol)) {\n logger.error(`Invalid Sentry Dsn: Invalid protocol ${protocol}`);\n return false;\n }\n\n if (port && isNaN(parseInt(port, 10))) {\n logger.error(`Invalid Sentry Dsn: Invalid port ${port}`);\n return false;\n }\n\n return true;\n}\n\n/**\n * Creates a valid Sentry Dsn object, identifying a Sentry instance and project.\n * @returns a valid DsnComponents object or `undefined` if @param from is an invalid DSN source\n */\nexport function makeDsn(from: DsnLike): DsnComponents | undefined {\n const components = typeof from === 'string' ? dsnFromString(from) : dsnFromComponents(from);\n if (!components || !validateDsn(components)) {\n return undefined;\n }\n return components;\n}\n", "import type { ConsoleLevel } from './logger';\n\n/** An error emitted by Sentry SDKs and related utilities. */\nexport class SentryError extends Error {\n /** Display name of this error instance. */\n public name: string;\n\n public logLevel: ConsoleLevel;\n\n public constructor(public message: string, logLevel: ConsoleLevel = 'warn') {\n super(message);\n\n this.name = new.target.prototype.constructor.name;\n // This sets the prototype to be `Error`, not `SentryError`. It's unclear why we do this, but commenting this line\n // out causes various (seemingly totally unrelated) playwright tests consistently time out. FYI, this makes\n // instances of `SentryError` fail `obj instanceof SentryError` checks.\n Object.setPrototypeOf(this, new.target.prototype);\n this.logLevel = logLevel;\n }\n}\n", "/* eslint-disable max-lines */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { WrappedFunction } from '@sentry/types';\n\nimport { htmlTreeAsString } from './browser';\nimport { isElement, isError, isEvent, isInstanceOf, isPlainObject, isPrimitive } from './is';\nimport { logger } from './logger';\nimport { truncate } from './string';\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, <other\n * args>)` or `origMethod.apply(this, [<other args>])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nexport function fill(source: { [key: string]: any }, name: string, replacementFactory: (...args: any[]) => any): void {\n if (!(name in source)) {\n return;\n }\n\n const original = source[name] as () => any;\n const wrapped = replacementFactory(original) as WrappedFunction;\n\n // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n if (typeof wrapped === 'function') {\n markFunctionWrapped(wrapped, original);\n }\n\n source[name] = wrapped;\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nexport function addNonEnumerableProperty(obj: object, name: string, value: unknown): void {\n try {\n Object.defineProperty(obj, name, {\n // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n value: value,\n writable: true,\n configurable: true,\n });\n } catch (o_O) {\n __DEBUG_BUILD__ && logger.log(`Failed to add non-enumerable property \"${name}\" to object`, obj);\n }\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nexport function markFunctionWrapped(wrapped: WrappedFunction, original: WrappedFunction): void {\n try {\n const proto = original.prototype || {};\n wrapped.prototype = original.prototype = proto;\n addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n } catch (o_O) {} // eslint-disable-line no-empty\n}\n\n/**\n * This extracts the original function if available. See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\nexport function getOriginalFunction(func: WrappedFunction): WrappedFunction | undefined {\n return func.__sentry_original__;\n}\n\n/**\n * Encodes given object into url-friendly format\n *\n * @param object An object that contains serializable values\n * @returns string Encoded\n */\nexport function urlEncode(object: { [key: string]: any }): string {\n return Object.keys(object)\n .map(key => `${encodeURIComponent(key)}=${encodeURIComponent(object[key])}`)\n .join('&');\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argurment itself, when value is neither an Event nor\n * an Error.\n */\nexport function convertToPlainObject<V>(value: V):\n | {\n [ownProps: string]: unknown;\n type: string;\n target: string;\n currentTarget: string;\n detail?: unknown;\n }\n | {\n [ownProps: string]: unknown;\n message: string;\n name: string;\n stack?: string;\n }\n | V {\n if (isError(value)) {\n return {\n message: value.message,\n name: value.name,\n stack: value.stack,\n ...getOwnProperties(value),\n };\n } else if (isEvent(value)) {\n const newObj: {\n [ownProps: string]: unknown;\n type: string;\n target: string;\n currentTarget: string;\n detail?: unknown;\n } = {\n type: value.type,\n target: serializeEventTarget(value.target),\n currentTarget: serializeEventTarget(value.currentTarget),\n ...getOwnProperties(value),\n };\n\n if (typeof CustomEvent !== 'undefined' && isInstanceOf(value, CustomEvent)) {\n newObj.detail = value.detail;\n }\n\n return newObj;\n } else {\n return value;\n }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target: unknown): string {\n try {\n return isElement(target) ? htmlTreeAsString(target) : Object.prototype.toString.call(target);\n } catch (_oO) {\n return '<unknown>';\n }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj: unknown): { [key: string]: unknown } {\n if (typeof obj === 'object' && obj !== null) {\n const extractedProps: { [key: string]: unknown } = {};\n for (const property in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, property)) {\n extractedProps[property] = (obj as Record<string, unknown>)[property];\n }\n }\n return extractedProps;\n } else {\n return {};\n }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nexport function extractExceptionKeysForMessage(exception: Record<string, unknown>, maxLength: number = 40): string {\n const keys = Object.keys(convertToPlainObject(exception));\n keys.sort();\n\n if (!keys.length) {\n return '[object has no keys]';\n }\n\n if (keys[0].length >= maxLength) {\n return truncate(keys[0], maxLength);\n }\n\n for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n const serialized = keys.slice(0, includedKeys).join(', ');\n if (serialized.length > maxLength) {\n continue;\n }\n if (includedKeys === keys.length) {\n return serialized;\n }\n return truncate(serialized, maxLength);\n }\n\n return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n */\nexport function dropUndefinedKeys<T>(inputValue: T): T {\n // This map keeps track of what already visited nodes map to.\n // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n // references as the input object.\n const memoizationMap = new Map<unknown, unknown>();\n\n // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys<T>(inputValue: T, memoizationMap: Map<unknown, unknown>): T {\n if (isPlainObject(inputValue)) {\n // If this node has already been visited due to a circular reference, return the object it was mapped to in the new object\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal as T;\n }\n\n const returnValue: { [key: string]: any } = {};\n // Store the mapping of this value in case we visit it again, in case of circular data\n memoizationMap.set(inputValue, returnValue);\n\n for (const key of Object.keys(inputValue)) {\n if (typeof inputValue[key] !== 'undefined') {\n returnValue[key] = _dropUndefinedKeys(inputValue[key], memoizationMap);\n }\n }\n\n return returnValue as T;\n }\n\n if (Array.isArray(inputValue)) {\n // If this node has already been visited due to a circular reference, return the array it was mapped to in the new object\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal as T;\n }\n\n const returnValue: unknown[] = [];\n // Store the mapping of this value in case we visit it again, in case of circular data\n memoizationMap.set(inputValue, returnValue);\n\n inputValue.forEach((item: unknown) => {\n returnValue.push(_dropUndefinedKeys(item, memoizationMap));\n });\n\n return returnValue as unknown as T;\n }\n\n return inputValue;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nexport function objectify(wat: unknown): typeof Object {\n let objectified;\n switch (true) {\n case wat === undefined || wat === null:\n objectified = new String(wat);\n break;\n\n // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n // an object in order to wrap it.\n case typeof wat === 'symbol' || typeof wat === 'bigint':\n objectified = Object(wat);\n break;\n\n // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n case isPrimitive(wat):\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n objectified = new (wat as any).constructor(wat);\n break;\n\n // by process of elimination, at this point we know that `wat` must already be an object\n default:\n objectified = wat;\n break;\n }\n return objectified;\n}\n", "/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { Event, Exception, Mechanism, StackFrame } from '@sentry/types';\n\nimport { addNonEnumerableProperty } from './object';\nimport { snipLine } from './string';\nimport { GLOBAL_OBJ } from './worldwide';\n\ninterface CryptoInternal {\n getRandomValues(array: Uint8Array): Uint8Array;\n randomUUID?(): string;\n}\n\n/** An interface for common properties on global */\ninterface CryptoGlobal {\n msCrypto?: CryptoInternal;\n crypto?: CryptoInternal;\n}\n\n/**\n * UUID4 generator\n *\n * @returns string Generated UUID4.\n */\nexport function uuid4(): string {\n const gbl = GLOBAL_OBJ as typeof GLOBAL_OBJ & CryptoGlobal;\n const crypto = gbl.crypto || gbl.msCrypto;\n\n let getRandomByte = (): number => Math.random() * 16;\n try {\n if (crypto && crypto.randomUUID) {\n return crypto.randomUUID().replace(/-/g, '');\n }\n if (crypto && crypto.getRandomValues) {\n getRandomByte = () => crypto.getRandomValues(new Uint8Array(1))[0];\n }\n } catch (_) {\n // some runtimes can crash invoking crypto\n // https://github.com/getsentry/sentry-javascript/issues/8935\n }\n\n // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#2117523\n // Concatenating the following numbers as strings results in '10000000100040008000100000000000'\n return (([1e7] as unknown as string) + 1e3 + 4e3 + 8e3 + 1e11).replace(/[018]/g, c =>\n // eslint-disable-next-line no-bitwise\n ((c as unknown as number) ^ ((getRandomByte() & 15) >> ((c as unknown as number) / 4))).toString(16),\n );\n}\n\nfunction getFirstException(event: Event): Exception | undefined {\n return event.exception && event.exception.values ? event.exception.values[0] : undefined;\n}\n\n/**\n * Extracts either message or type+value from an event that can be used for user-facing logs\n * @returns event's description\n */\nexport function getEventDescription(event: Event): string {\n const { message, event_id: eventId } = event;\n if (message) {\n return message;\n }\n\n const firstException = getFirstException(event);\n if (firstException) {\n if (firstException.type && firstException.value) {\n return `${firstException.type}: ${firstException.value}`;\n }\n return firstException.type || firstException.value || eventId || '<unknown>';\n }\n return eventId || '<unknown>';\n}\n\n/**\n * Adds exception values, type and value to an synthetic Exception.\n * @param event The event to modify.\n * @param value Value of the exception.\n * @param type Type of the exception.\n * @hidden\n */\nexport function addExceptionTypeValue(event: Event, value?: string, type?: string): void {\n const exception = (event.exception = event.exception || {});\n const values = (exception.values = exception.values || []);\n const firstException = (values[0] = values[0] || {});\n if (!firstException.value) {\n firstException.value = value || '';\n }\n if (!firstException.type) {\n firstException.type = type || 'Error';\n }\n}\n\n/**\n * Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed.\n *\n * @param event The event to modify.\n * @param newMechanism Mechanism data to add to the event.\n * @hidden\n */\nexport function addExceptionMechanism(event: Event, newMechanism?: Partial<Mechanism>): void {\n const firstException = getFirstException(event);\n if (!firstException) {\n return;\n }\n\n const defaultMechanism = { type: 'generic', handled: true };\n const currentMechanism = firstException.mechanism;\n firstException.mechanism = { ...defaultMechanism, ...currentMechanism, ...newMechanism };\n\n if (newMechanism && 'data' in newMechanism) {\n const mergedData = { ...(currentMechanism && currentMechanism.data), ...newMechanism.data };\n firstException.mechanism.data = mergedData;\n }\n}\n\n// https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string\nconst SEMVER_REGEXP =\n /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/;\n\n/**\n * Represents Semantic Versioning object\n */\ninterface SemVer {\n major?: number;\n minor?: number;\n patch?: number;\n prerelease?: string;\n buildmetadata?: string;\n}\n\n/**\n * Parses input into a SemVer interface\n * @param input string representation of a semver version\n */\nexport function parseSemver(input: string): SemVer {\n const match = input.match(SEMVER_REGEXP) || [];\n const major = parseInt(match[1], 10);\n const minor = parseInt(match[2], 10);\n const patch = parseInt(match[3], 10);\n return {\n buildmetadata: match[5],\n major: isNaN(major) ? undefined : major,\n minor: isNaN(minor) ? undefined : minor,\n patch: isNaN(patch) ? undefined : patch,\n prerelease: match[4],\n };\n}\n\n/**\n * This function adds context (pre/post/line) lines to the provided frame\n *\n * @param lines string[] containing all lines\n * @param frame StackFrame that will be mutated\n * @param linesOfContext number of context lines we want to add pre/post\n */\nexport function addContextToFrame(lines: string[], frame: StackFrame, linesOfContext: number = 5): void {\n // When there is no line number in the frame, attaching context is nonsensical and will even break grouping\n if (frame.lineno === undefined) {\n return;\n }\n\n const maxLines = lines.length;\n const sourceLine = Math.max(Math.min(maxLines - 1, frame.lineno - 1), 0);\n\n frame.pre_context = lines\n .slice(Math.max(0, sourceLine - linesOfContext), sourceLine)\n .map((line: string) => snipLine(line, 0));\n\n frame.context_line = snipLine(lines[Math.min(maxLines - 1, sourceLine)], frame.colno || 0);\n\n frame.post_context = lines\n .slice(Math.min(sourceLine + 1, maxLines), sourceLine + 1 + linesOfContext)\n .map((line: string) => snipLine(line, 0));\n}\n\n/**\n * Checks whether or not we've already captured the given exception (note: not an identical exception - the very object\n * in question), and marks it captured if not.\n *\n * This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and\n * record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so\n * that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because\n * the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not\n * caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This\n * function helps us ensure that even if we encounter the same error more than once, we only record it the first time we\n * see it.\n *\n * Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on\n * them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent\n * object wrapper forms so that this check will always work. However, because we need to flag the exact object which\n * will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification\n * must be done before the exception captured.\n *\n * @param A thrown exception to check or flag as having been seen\n * @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen)\n */\nexport function checkOrSetAlreadyCaught(exception: unknown): boolean {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (exception && (exception as any).__sentry_captured__) {\n return true;\n }\n\n try {\n // set it this way rather than by assignment so that it's not ennumerable and therefore isn't recorded by the\n // `ExtraErrorData` integration\n addNonEnumerableProperty(exception as { [key: string]: unknown }, '__sentry_captured__', true);\n } catch (err) {\n // `exception` is a primitive, so we can't mark it seen\n }\n\n return false;\n}\n\n/**\n * Checks whether the given input is already an array, and if it isn't, wraps it in one.\n *\n * @param maybeArray Input to turn into an array, if necessary\n * @returns The input, if already an array, or an array with the input as the only element, if not\n */\nexport function arrayify<T = unknown>(maybeArray: T | T[]): T[] {\n return Array.isArray(maybeArray) ? maybeArray : [maybeArray];\n}\n", "import type { StackFrame, StackLineParser, StackParser } from '@sentry/types';\n\nimport type { GetModuleFn } from './node-stack-trace';\nimport { filenameIsInApp, node } from './node-stack-trace';\n\nexport { filenameIsInApp };\n\nconst STACKTRACE_FRAME_LIMIT = 50;\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nexport function createStackParser(...parsers: StackLineParser[]): StackParser {\n const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n return (stack: string, skipFirst: number = 0): StackFrame[] => {\n const frames: StackFrame[] = [];\n const lines = stack.split('\\n');\n\n for (let i = skipFirst; i < lines.length; i++) {\n const line = lines[i];\n // Ignore lines over 1kb as they are unlikely to be stack frames.\n // Many of the regular expressions use backtracking which results in run time that increases exponentially with\n // input size. Huge strings can result in hangs/Denial of Service:\n // https://github.com/getsentry/sentry-javascript/issues/2286\n if (line.length > 1024) {\n continue;\n }\n\n // https://github.com/getsentry/sentry-javascript/issues/5459\n // Remove webpack (error: *) wrappers\n const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n // https://github.com/getsentry/sentry-javascript/issues/7813\n // Skip Error: lines\n if (cleanedLine.match(/\\S*Error: /)) {\n continue;\n }\n\n for (const parser of sortedParsers) {\n const frame = parser(cleanedLine);\n\n if (frame) {\n frames.push(frame);\n break;\n }\n }\n\n if (frames.length >= STACKTRACE_FRAME_LIMIT) {\n break;\n }\n }\n\n return stripSentryFramesAndReverse(frames);\n };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nexport function stackParserFromStackParserOptions(stackParser: StackParser | StackLineParser[]): StackParser {\n if (Array.isArray(stackParser)) {\n return createStackParser(...stackParser);\n }\n return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nexport function stripSentryFramesAndReverse(stack: ReadonlyArray<StackFrame>): StackFrame[] {\n if (!stack.length) {\n return [];\n }\n\n const localStack = Array.from(stack);\n\n // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n if (/sentryWrapped/.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n }\n\n // Reversing in the middle of the procedure allows us to just pop the values off the stack\n localStack.reverse();\n\n // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n if (STRIP_FRAME_REGEXP.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n\n // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n // is produced within the hub itself, making it:\n //\n // Sentry.captureException()\n // getCurrentHub().captureException()\n //\n // instead of just the top `Sentry` call itself.\n // This forces us to possibly strip an additional frame in the exact same was as above.\n if (STRIP_FRAME_REGEXP.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n }\n }\n\n return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n ...frame,\n filename: frame.filename || localStack[localStack.length - 1].filename,\n function: frame.function || '?',\n }));\n}\n\nconst defaultFunctionName = '<anonymous>';\n\n/**\n * Safely extract function name from itself\n */\nexport function getFunctionName(fn: unknown): string {\n try {\n if (!fn || typeof fn !== 'function') {\n return defaultFunctionName;\n }\n return fn.name || defaultFunctionName;\n } catch (e) {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n return defaultFunctionName;\n }\n}\n\n/**\n * Node.js stack line parser\n *\n * This is in @sentry/utils so it can be used from the Electron SDK in the browser for when `nodeIntegration == true`.\n * This allows it to be used without referencing or importing any node specific code which causes bundlers to complain\n */\nexport function nodeStackLineParser(getModule?: GetModuleFn): StackLineParser {\n return [90, node(getModule)];\n}\n", "import { logger } from './logger';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nexport { supportsHistory } from './vendor/supportsHistory';\n\n/**\n * Tells whether current environment supports ErrorEvent objects\n * {@link supportsErrorEvent}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsErrorEvent(): boolean {\n try {\n new ErrorEvent('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMError objects\n * {@link supportsDOMError}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsDOMError(): boolean {\n try {\n // Chrome: VM89:1 Uncaught TypeError: Failed to construct 'DOMError':\n // 1 argument required, but only 0 present.\n // @ts-expect-error It really needs 1 argument, not 0.\n new DOMError('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMException objects\n * {@link supportsDOMException}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsDOMException(): boolean {\n try {\n new DOMException('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports Fetch API\n * {@link supportsFetch}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsFetch(): boolean {\n if (!('fetch' in WINDOW)) {\n return false;\n }\n\n try {\n new Headers();\n new Request('http://www.example.com');\n new Response();\n return true;\n } catch (e) {\n return false;\n }\n}\n/**\n * isNativeFetch checks if the given function is a native implementation of fetch()\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function isNativeFetch(func: Function): boolean {\n return func && /^function fetch\\(\\)\\s+\\{\\s+\\[native code\\]\\s+\\}$/.test(func.toString());\n}\n\n/**\n * Tells whether current environment supports Fetch API natively\n * {@link supportsNativeFetch}.\n *\n * @returns true if `window.fetch` is natively implemented, false otherwise\n */\nexport function supportsNativeFetch(): boolean {\n if (!supportsFetch()) {\n return false;\n }\n\n // Fast path to avoid DOM I/O\n // eslint-disable-next-line @typescript-eslint/unbound-method\n if (isNativeFetch(WINDOW.fetch)) {\n return true;\n }\n\n // window.fetch is implemented, but is polyfilled or already wrapped (e.g: by a chrome extension)\n // so create a \"pure\" iframe to see if that has native fetch\n let result = false;\n const doc = WINDOW.document;\n // eslint-disable-next-line deprecation/deprecation\n if (doc && typeof (doc.createElement as unknown) === 'function') {\n try {\n const sandbox = doc.createElement('iframe');\n sandbox.hidden = true;\n doc.head.appendChild(sandbox);\n if (sandbox.contentWindow && sandbox.contentWindow.fetch) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n result = isNativeFetch(sandbox.contentWindow.fetch);\n }\n doc.head.removeChild(sandbox);\n } catch (err) {\n __DEBUG_BUILD__ &&\n logger.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', err);\n }\n }\n\n return result;\n}\n\n/**\n * Tells whether current environment supports ReportingObserver API\n * {@link supportsReportingObserver}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsReportingObserver(): boolean {\n return 'ReportingObserver' in WINDOW;\n}\n\n/**\n * Tells whether current environment supports Referrer Policy API\n * {@link supportsReferrerPolicy}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsReferrerPolicy(): boolean {\n // Despite all stars in the sky saying that Edge supports old draft syntax, aka 'never', 'always', 'origin' and 'default'\n // (see https://caniuse.com/#feat=referrer-policy),\n // it doesn't. And it throws an exception instead of ignoring this parameter...\n // REF: https://github.com/getsentry/raven-js/issues/1233\n\n if (!supportsFetch()) {\n return false;\n }\n\n try {\n new Request('_', {\n referrerPolicy: 'origin' as ReferrerPolicy,\n });\n return true;\n } catch (e) {\n return false;\n }\n}\n", "// Based on https://github.com/angular/angular.js/pull/13945/files\n// The MIT License\n\n// Copyright (c) 2010-2016 Google, Inc. http://angularjs.org\n\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport { getGlobalObject } from '../worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\n/**\n * Tells whether current environment supports History API\n * {@link supportsHistory}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsHistory(): boolean {\n // NOTE: in Chrome App environment, touching history.pushState, *even inside\n // a try/catch block*, will cause Chrome to output an error to console.error\n // borrowed from: https://github.com/angular/angular.js/pull/13945/files\n /* eslint-disable @typescript-eslint/no-unsafe-member-access */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const chrome = (WINDOW as any).chrome;\n const isChromePackagedApp = chrome && chrome.app && chrome.app.runtime;\n /* eslint-enable @typescript-eslint/no-unsafe-member-access */\n const hasHistoryApi = 'history' in WINDOW && !!WINDOW.history.pushState && !!WINDOW.history.replaceState;\n\n return !isChromePackagedApp && hasHistoryApi;\n}\n", "/* eslint-disable max-lines */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/ban-types */\nimport type {\n HandlerDataFetch,\n HandlerDataXhr,\n SentryWrappedXMLHttpRequest,\n SentryXhrData,\n WrappedFunction,\n} from '@sentry/types';\n\nimport { isString } from './is';\nimport type { ConsoleLevel } from './logger';\nimport { CONSOLE_LEVELS, logger, originalConsoleMethods } from './logger';\nimport { uuid4 } from './misc';\nimport { addNonEnumerableProperty, fill } from './object';\nimport { getFunctionName } from './stacktrace';\nimport { supportsHistory, supportsNativeFetch } from './supports';\nimport { getGlobalObject, GLOBAL_OBJ } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nexport const SENTRY_XHR_DATA_KEY = '__sentry_xhr_v2__';\n\nexport type InstrumentHandlerType =\n | 'console'\n | 'dom'\n | 'fetch'\n | 'history'\n | 'sentry'\n | 'xhr'\n | 'error'\n | 'unhandledrejection';\nexport type InstrumentHandlerCallback = (data: any) => void;\n\n/**\n * Instrument native APIs to call handlers that can be used to create breadcrumbs, APM spans etc.\n * - Console API\n * - Fetch API\n * - XHR API\n * - History API\n * - DOM API (click/typing)\n * - Error API\n * - UnhandledRejection API\n */\n\nconst handlers: { [key in InstrumentHandlerType]?: InstrumentHandlerCallback[] } = {};\nconst instrumented: { [key in InstrumentHandlerType]?: boolean } = {};\n\n/** Instruments given API */\nfunction instrument(type: InstrumentHandlerType): void {\n if (instrumented[type]) {\n return;\n }\n\n instrumented[type] = true;\n\n switch (type) {\n case 'console':\n instrumentConsole();\n break;\n case 'dom':\n instrumentDOM();\n break;\n case 'xhr':\n instrumentXHR();\n break;\n case 'fetch':\n instrumentFetch();\n break;\n case 'history':\n instrumentHistory();\n break;\n case 'error':\n instrumentError();\n break;\n case 'unhandledrejection':\n instrumentUnhandledRejection();\n break;\n default:\n __DEBUG_BUILD__ && logger.warn('unknown instrumentation type:', type);\n return;\n }\n}\n\n/**\n * Add handler that will be called when given type of instrumentation triggers.\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nexport function addInstrumentationHandler(type: InstrumentHandlerType, callback: InstrumentHandlerCallback): void {\n handlers[type] = handlers[type] || [];\n (handlers[type] as InstrumentHandlerCallback[]).push(callback);\n instrument(type);\n}\n\n/**\n * Reset all instrumentation handlers.\n * This can be used by tests to ensure we have a clean slate of instrumentation handlers.\n */\nexport function resetInstrumentationHandlers(): void {\n Object.keys(handlers).forEach(key => {\n handlers[key as InstrumentHandlerType] = undefined;\n });\n}\n\n/** JSDoc */\nfunction triggerHandlers(type: InstrumentHandlerType, data: any): void {\n if (!type || !handlers[type]) {\n return;\n }\n\n for (const handler of handlers[type] || []) {\n try {\n handler(data);\n } catch (e) {\n __DEBUG_BUILD__ &&\n logger.error(\n `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${getFunctionName(handler)}\\nError:`,\n e,\n );\n }\n }\n}\n\n/** JSDoc */\nfunction instrumentConsole(): void {\n if (!('console' in GLOBAL_OBJ)) {\n return;\n }\n\n CONSOLE_LEVELS.forEach(function (level: ConsoleLevel): void {\n if (!(level in GLOBAL_OBJ.console)) {\n return;\n }\n\n fill(GLOBAL_OBJ.console, level, function (originalConsoleMethod: () => any): Function {\n originalConsoleMethods[level] = originalConsoleMethod;\n\n return function (...args: any[]): void {\n triggerHandlers('console', { args, level });\n\n const log = originalConsoleMethods[level];\n log && log.apply(GLOBAL_OBJ.console, args);\n };\n });\n });\n}\n\n/** JSDoc */\nfunction instrumentFetch(): void {\n if (!supportsNativeFetch()) {\n return;\n }\n\n fill(GLOBAL_OBJ, 'fetch', function (originalFetch: () => void): () => void {\n return function (...args: any[]): void {\n const { method, url } = parseFetchArgs(args);\n\n const handlerData: HandlerDataFetch = {\n args,\n fetchData: {\n method,\n url,\n },\n startTimestamp: Date.now(),\n };\n\n triggerHandlers('fetch', {\n ...handlerData,\n });\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return originalFetch.apply(GLOBAL_OBJ, args).then(\n (response: Response) => {\n triggerHandlers('fetch', {\n ...handlerData,\n endTimestamp: Date.now(),\n response,\n });\n return response;\n },\n (error: Error) => {\n triggerHandlers('fetch', {\n ...handlerData,\n endTimestamp: Date.now(),\n error,\n });\n // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n // it means the sentry.javascript SDK caught an error invoking your application code.\n // This is expected behavior and NOT indicative of a bug with sentry.javascript.\n throw error;\n },\n );\n };\n });\n}\n\nfunction hasProp<T extends string>(obj: unknown, prop: T): obj is Record<string, string> {\n return !!obj && typeof obj === 'object' && !!(obj as Record<string, string>)[prop];\n}\n\ntype FetchResource = string | { toString(): string } | { url: string };\n\nfunction getUrlFromResource(resource: FetchResource): string {\n if (typeof resource === 'string') {\n return resource;\n }\n\n if (!resource) {\n return '';\n }\n\n if (hasProp(resource, 'url')) {\n return resource.url;\n }\n\n if (resource.toString) {\n return resource.toString();\n }\n\n return '';\n}\n\n/**\n * Parses the fetch arguments to find the used Http method and the url of the request\n */\nexport function parseFetchArgs(fetchArgs: unknown[]): { method: string; url: string } {\n if (fetchArgs.length === 0) {\n return { method: 'GET', url: '' };\n }\n\n if (fetchArgs.length === 2) {\n const [url, options] = fetchArgs as [FetchResource, object];\n\n return {\n url: getUrlFromResource(url),\n method: hasProp(options, 'method') ? String(options.method).toUpperCase() : 'GET',\n };\n }\n\n const arg = fetchArgs[0];\n return {\n url: getUrlFromResource(arg as FetchResource),\n method: hasProp(arg, 'method') ? String(arg.method).toUpperCase() : 'GET',\n };\n}\n\n/** JSDoc */\nexport function instrumentXHR(): void {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (!(WINDOW as any).XMLHttpRequest) {\n return;\n }\n\n const xhrproto = XMLHttpRequest.prototype;\n\n fill(xhrproto, 'open', function (originalOpen: () => void): () => void {\n return function (this: XMLHttpRequest & SentryWrappedXMLHttpRequest, ...args: any[]): void {\n const startTimestamp = Date.now();\n\n const url = args[1];\n const xhrInfo: SentryXhrData = (this[SENTRY_XHR_DATA_KEY] = {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n method: isString(args[0]) ? args[0].toUpperCase() : args[0],\n url: args[1],\n request_headers: {},\n });\n\n // if Sentry key appears in URL, don't capture it as a request\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (isString(url) && xhrInfo.method === 'POST' && url.match(/sentry_key/)) {\n this.__sentry_own_request__ = true;\n }\n\n const onreadystatechangeHandler: () => void = () => {\n // For whatever reason, this is not the same instance here as from the outer method\n const xhrInfo = this[SENTRY_XHR_DATA_KEY];\n\n if (!xhrInfo) {\n return;\n }\n\n if (this.readyState === 4) {\n try {\n // touching statusCode in some platforms throws\n // an exception\n xhrInfo.status_code = this.status;\n } catch (e) {\n /* do nothing */\n }\n\n triggerHandlers('xhr', {\n args: args as [string, string],\n endTimestamp: Date.now(),\n startTimestamp,\n xhr: this,\n } as HandlerDataXhr);\n }\n };\n\n if ('onreadystatechange' in this && typeof this.onreadystatechange === 'function') {\n fill(this, 'onreadystatechange', function (original: WrappedFunction): Function {\n return function (this: SentryWrappedXMLHttpRequest, ...readyStateArgs: any[]): void {\n onreadystatechangeHandler();\n return original.apply(this, readyStateArgs);\n };\n });\n } else {\n this.addEventListener('readystatechange', onreadystatechangeHandler);\n }\n\n // Intercepting `setRequestHeader` to access the request headers of XHR instance.\n // This will only work for user/library defined headers, not for the default/browser-assigned headers.\n // Request cookies are also unavailable for XHR, as `Cookie` header can't be defined by `setRequestHeader`.\n fill(this, 'setRequestHeader', function (original: WrappedFunction): Function {\n return function (this: SentryWrappedXMLHttpRequest, ...setRequestHeaderArgs: unknown[]): void {\n const [header, value] = setRequestHeaderArgs as [string, string];\n\n const xhrInfo = this[SENTRY_XHR_DATA_KEY];\n\n if (xhrInfo) {\n xhrInfo.request_headers[header.toLowerCase()] = value;\n }\n\n return original.apply(this, setRequestHeaderArgs);\n };\n });\n\n return originalOpen.apply(this, args);\n };\n });\n\n fill(xhrproto, 'send', function (originalSend: () => void): () => void {\n return function (this: XMLHttpRequest & SentryWrappedXMLHttpRequest, ...args: any[]): void {\n const sentryXhrData = this[SENTRY_XHR_DATA_KEY];\n if (sentryXhrData && args[0] !== undefined) {\n sentryXhrData.body = args[0];\n }\n\n triggerHandlers('xhr', {\n args,\n startTimestamp: Date.now(),\n xhr: this,\n });\n\n return originalSend.apply(this, args);\n };\n });\n}\n\nlet lastHref: string;\n\n/** JSDoc */\nfunction instrumentHistory(): void {\n if (!supportsHistory()) {\n return;\n }\n\n const oldOnPopState = WINDOW.onpopstate;\n WINDOW.onpopstate = function (this: WindowEventHandlers, ...args: any[]): any {\n const to = WINDOW.location.href;\n // keep track of the current URL state, as we always receive only the updated state\n const from = lastHref;\n lastHref = to;\n triggerHandlers('history', {\n from,\n to,\n });\n if (oldOnPopState) {\n // Apparently this can throw in Firefox when incorrectly implemented plugin is installed.\n // https://github.com/getsentry/sentry-javascript/issues/3344\n // https://github.com/bugsnag/bugsnag-js/issues/469\n try {\n return oldOnPopState.apply(this, args);\n } catch (_oO) {\n // no-empty\n }\n }\n };\n\n /** @hidden */\n function historyReplacementFunction(originalHistoryFunction: () => void): () => void {\n return function (this: History, ...args: any[]): void {\n const url = args.length > 2 ? args[2] : undefined;\n if (url) {\n // coerce to string (this is what pushState does)\n const from = lastHref;\n const to = String(url);\n // keep track of the current URL state, as we always receive only the updated state\n lastHref = to;\n triggerHandlers('history', {\n from,\n to,\n });\n }\n return originalHistoryFunction.apply(this, args);\n };\n }\n\n fill(WINDOW.history, 'pushState', historyReplacementFunction);\n fill(WINDOW.history, 'replaceState', historyReplacementFunction);\n}\n\nconst DEBOUNCE_DURATION = 1000;\nlet debounceTimerID: number | undefined;\nlet lastCapturedEventType: string | undefined;\nlet lastCapturedEventTargetId: string | undefined;\n\ntype SentryWrappedTarget = HTMLElement & { _sentryId?: string };\n\n/**\n * Check whether the event is similar to the last captured one. For example, two click events on the same button.\n */\nfunction isSimilarToLastCapturedEvent(event: Event): boolean {\n // If both events have different type, then user definitely performed two separate actions. e.g. click + keypress.\n if (event.type !== lastCapturedEventType) {\n return false;\n }\n\n try {\n // If both events have the same type, it's still possible that actions were performed on different targets.\n // e.g. 2 clicks on different buttons.\n if (!event.target || (event.target as SentryWrappedTarget)._sentryId !== lastCapturedEventTargetId) {\n return false;\n }\n } catch (e) {\n // just accessing `target` property can throw an exception in some rare circumstances\n // see: https://github.com/getsentry/sentry-javascript/issues/838\n }\n\n // If both events have the same type _and_ same `target` (an element which triggered an event, _not necessarily_\n // to which an event listener was attached), we treat them as the same action, as we want to capture\n // only one breadcrumb. e.g. multiple clicks on the same button, or typing inside a user input box.\n return true;\n}\n\n/**\n * Decide whether an event should be captured.\n * @param event event to be captured\n */\nfunction shouldSkipDOMEvent(eventType: string, target: SentryWrappedTarget | null): boolean {\n // We are only interested in filtering `keypress` events for now.\n if (eventType !== 'keypress') {\n return false;\n }\n\n if (!target || !target.tagName) {\n return true;\n }\n\n // Only consider keypress events on actual input elements. This will disregard keypresses targeting body\n // e.g.tabbing through elements, hotkeys, etc.\n if (target.tagName === 'INPUT' || target.tagName === 'TEXTAREA' || target.isContentEditable) {\n return false;\n }\n\n return true;\n}\n\nfunction getEventTarget(event: Event): SentryWrappedTarget | null {\n try {\n return event.target as SentryWrappedTarget | null;\n } catch (e) {\n // just accessing `target` property can throw an exception in some rare circumstances\n // see: https://github.com/getsentry/sentry-javascript/issues/838\n return null;\n }\n}\n\n/**\n * Wraps addEventListener to capture UI breadcrumbs\n * @param handler function that will be triggered\n * @param globalListener indicates whether event was captured by the global event listener\n * @returns wrapped breadcrumb events handler\n * @hidden\n */\nfunction makeDOMEventHandler(handler: Function, globalListener: boolean = false): (event: Event) => void {\n return (event: Event & { _sentryCaptured?: true }): void => {\n // It's possible this handler might trigger multiple times for the same\n // event (e.g. event propagation through node ancestors).\n // Ignore if we've already captured that event.\n if (!event || event['_sentryCaptured']) {\n return;\n }\n\n const target = getEventTarget(event);\n\n // We always want to skip _some_ events.\n if (shouldSkipDOMEvent(event.type, target)) {\n return;\n }\n\n // Mark event as \"seen\"\n addNonEnumerableProperty(event, '_sentryCaptured', true);\n\n if (target && !target._sentryId) {\n // Add UUID to event target so we can identify if\n addNonEnumerableProperty(target, '_sentryId', uuid4());\n }\n\n const name = event.type === 'keypress' ? 'input' : event.type;\n\n // If there is no last captured event, it means that we can safely capture the new event and store it for future comparisons.\n // If there is a last captured event, see if the new event is different enough to treat it as a unique one.\n // If that's the case, emit the previous event and store locally the newly-captured DOM event.\n if (!isSimilarToLastCapturedEvent(event)) {\n handler({\n event: event,\n name,\n global: globalListener,\n });\n lastCapturedEventType = event.type;\n lastCapturedEventTargetId = target ? target._sentryId : undefined;\n }\n\n // Start a new debounce timer that will prevent us from capturing multiple events that should be grouped together.\n clearTimeout(debounceTimerID);\n debounceTimerID = WINDOW.setTimeout(() => {\n lastCapturedEventTargetId = undefined;\n lastCapturedEventType = undefined;\n }, DEBOUNCE_DURATION);\n };\n}\n\ntype AddEventListener = (\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | AddEventListenerOptions,\n) => void;\ntype RemoveEventListener = (\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | EventListenerOptions,\n) => void;\n\ntype InstrumentedElement = Element & {\n __sentry_instrumentation_handlers__?: {\n [key in 'click' | 'keypress']?: {\n handler?: Function;\n /** The number of custom listeners attached to this element */\n refCount: number;\n };\n };\n};\n\n/** JSDoc */\nexport function instrumentDOM(): void {\n if (!WINDOW.document) {\n return;\n }\n\n // Make it so that any click or keypress that is unhandled / bubbled up all the way to the document triggers our dom\n // handlers. (Normally we have only one, which captures a breadcrumb for each click or keypress.) Do this before\n // we instrument `addEventListener` so that we don't end up attaching this handler twice.\n const triggerDOMHandler = triggerHandlers.bind(null, 'dom');\n const globalDOMEventHandler = makeDOMEventHandler(triggerDOMHandler, true);\n WINDOW.document.addEventListener('click', globalDOMEventHandler, false);\n WINDOW.document.addEventListener('keypress', globalDOMEventHandler, false);\n\n // After hooking into click and keypress events bubbled up to `document`, we also hook into user-handled\n // clicks & keypresses, by adding an event listener of our own to any element to which they add a listener. That\n // way, whenever one of their handlers is triggered, ours will be, too. (This is needed because their handler\n // could potentially prevent the event from bubbling up to our global listeners. This way, our handler are still\n // guaranteed to fire at least once.)\n ['EventTarget', 'Node'].forEach((target: string) => {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const proto = (WINDOW as any)[target] && (WINDOW as any)[target].prototype;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, no-prototype-builtins\n if (!proto || !proto.hasOwnProperty || !proto.hasOwnProperty('addEventListener')) {\n return;\n }\n\n fill(proto, 'addEventListener', function (originalAddEventListener: AddEventListener): AddEventListener {\n return function (\n this: Element,\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ): AddEventListener {\n if (type === 'click' || type == 'keypress') {\n try {\n const el = this as InstrumentedElement;\n const handlers = (el.__sentry_instrumentation_handlers__ = el.__sentry_instrumentation_handlers__ || {});\n const handlerForType = (handlers[type] = handlers[type] || { refCount: 0 });\n\n if (!handlerForType.handler) {\n const handler = makeDOMEventHandler(triggerDOMHandler);\n handlerForType.handler = handler;\n originalAddEventListener.call(this, type, handler, options);\n }\n\n handlerForType.refCount++;\n } catch (e) {\n // Accessing dom properties is always fragile.\n // Also allows us to skip `addEventListenrs` calls with no proper `this` context.\n }\n }\n\n return originalAddEventListener.call(this, type, listener, options);\n };\n });\n\n fill(\n proto,\n 'removeEventListener',\n function (originalRemoveEventListener: RemoveEventListener): RemoveEventListener {\n return function (\n this: Element,\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | EventListenerOptions,\n ): () => void {\n if (type === 'click' || type == 'keypress') {\n try {\n const el = this as InstrumentedElement;\n const handlers = el.__sentry_instrumentation_handlers__ || {};\n const handlerForType = handlers[type];\n\n if (handlerForType) {\n handlerForType.refCount--;\n // If there are no longer any custom handlers of the current type on this element, we can remove ours, too.\n if (handlerForType.refCount <= 0) {\n originalRemoveEventListener.call(this, type, handlerForType.handler, options);\n handlerForType.handler = undefined;\n delete handlers[type]; // eslint-disable-line @typescript-eslint/no-dynamic-delete\n }\n\n // If there are no longer any custom handlers of any type on this element, cleanup everything.\n if (Object.keys(handlers).length === 0) {\n delete el.__sentry_instrumentation_handlers__;\n }\n }\n } catch (e) {\n // Accessing dom properties is always fragile.\n // Also allows us to skip `addEventListenrs` calls with no proper `this` context.\n }\n }\n\n return originalRemoveEventListener.call(this, type, listener, options);\n };\n },\n );\n });\n}\n\nlet _oldOnErrorHandler: (typeof WINDOW)['onerror'] | null = null;\n/** JSDoc */\nfunction instrumentError(): void {\n _oldOnErrorHandler = WINDOW.onerror;\n\n WINDOW.onerror = function (msg: unknown, url: unknown, line: unknown, column: unknown, error: unknown): boolean {\n triggerHandlers('error', {\n column,\n error,\n line,\n msg,\n url,\n });\n\n if (_oldOnErrorHandler && !_oldOnErrorHandler.__SENTRY_LOADER__) {\n // eslint-disable-next-line prefer-rest-params\n return _oldOnErrorHandler.apply(this, arguments);\n }\n\n return false;\n };\n\n WINDOW.onerror.__SENTRY_INSTRUMENTED__ = true;\n}\n\nlet _oldOnUnhandledRejectionHandler: (typeof WINDOW)['onunhandledrejection'] | null = null;\n/** JSDoc */\nfunction instrumentUnhandledRejection(): void {\n _oldOnUnhandledRejectionHandler = WINDOW.onunhandledrejection;\n\n WINDOW.onunhandledrejection = function (e: any): boolean {\n triggerHandlers('unhandledrejection', e);\n\n if (_oldOnUnhandledRejectionHandler && !_oldOnUnhandledRejectionHandler.__SENTRY_LOADER__) {\n // eslint-disable-next-line prefer-rest-params\n return _oldOnUnhandledRejectionHandler.apply(this, arguments);\n }\n\n return true;\n };\n\n WINDOW.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true;\n}\n", "/*\n * This module exists for optimizations in the build process through rollup and terser. We define some global\n * constants, which can be overridden during build. By guarding certain pieces of code with functions that return these\n * constants, we can control whether or not they appear in the final bundle. (Any code guarded by a false condition will\n * never run, and will hence be dropped during treeshaking.) The two primary uses for this are stripping out calls to\n * `logger` and preventing node-related code from appearing in browser bundles.\n *\n * Attention:\n * This file should not be used to define constants/flags that are intended to be used for tree-shaking conducted by\n * users. These flags should live in their respective packages, as we identified user tooling (specifically webpack)\n * having issues tree-shaking these constants across package boundaries.\n * An example for this is the __SENTRY_DEBUG__ constant. It is declared in each package individually because we want\n * users to be able to shake away expressions that it guards.\n */\n\ndeclare const __SENTRY_BROWSER_BUNDLE__: boolean | undefined;\n\nexport type SdkSource = 'npm' | 'cdn' | 'loader';\n\n/**\n * Figures out if we're building a browser bundle.\n *\n * @returns true if this is a browser bundle build.\n */\nexport function isBrowserBundle(): boolean {\n return typeof __SENTRY_BROWSER_BUNDLE__ !== 'undefined' && !!__SENTRY_BROWSER_BUNDLE__;\n}\n\n/**\n * Get source of SDK.\n */\nexport function getSDKSource(): SdkSource {\n // @ts-expect-error __SENTRY_SDK_SOURCE__ is injected by rollup during build process\n return __SENTRY_SDK_SOURCE__;\n}\n", "/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the logger, or b) put your function elsewhere.\n */\n\nimport { isBrowserBundle } from './env';\n\n/**\n * Checks whether we're in the Node.js or Browser environment\n *\n * @returns Answer to given question\n */\nexport function isNodeEnv(): boolean {\n // explicitly check for browser bundles as those can be optimized statically\n // by terser/rollup.\n return (\n !isBrowserBundle() &&\n Object.prototype.toString.call(typeof process !== 'undefined' ? process : 0) === '[object process]'\n );\n}\n\n/**\n * Requires a module which is protected against bundler minification.\n *\n * @param request The module path to resolve\n */\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types, @typescript-eslint/no-explicit-any\nexport function dynamicRequire(mod: any, request: string): any {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return mod.require(request);\n}\n\n/**\n * Helper for dynamically loading module that should work with linked dependencies.\n * The problem is that we _should_ be using `require(require.resolve(moduleName, { paths: [cwd()] }))`\n * However it's _not possible_ to do that with Webpack, as it has to know all the dependencies during\n * build time. `require.resolve` is also not available in any other way, so we cannot create,\n * a fake helper like we do with `dynamicRequire`.\n *\n * We always prefer to use local package, thus the value is not returned early from each `try/catch` block.\n * That is to mimic the behavior of `require.resolve` exactly.\n *\n * @param moduleName module name to require\n * @returns possibly required module\n */\nexport function loadModule<T>(moduleName: string): T | undefined {\n let mod: T | undefined;\n\n try {\n mod = dynamicRequire(module, moduleName);\n } catch (e) {\n // no-empty\n }\n\n try {\n const { cwd } = dynamicRequire(module, 'process');\n mod = dynamicRequire(module, `${cwd()}/node_modules/${moduleName}`) as T;\n } catch (e) {\n // no-empty\n }\n\n return mod;\n}\n", "/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport type MemoFunc = [\n // memoize\n (obj: any) => boolean,\n // unmemoize\n (obj: any) => void,\n];\n\n/**\n * Helper to decycle json objects\n */\nexport function memoBuilder(): MemoFunc {\n const hasWeakSet = typeof WeakSet === 'function';\n const inner: any = hasWeakSet ? new WeakSet() : [];\n function memoize(obj: any): boolean {\n if (hasWeakSet) {\n if (inner.has(obj)) {\n return true;\n }\n inner.add(obj);\n return false;\n }\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < inner.length; i++) {\n const value = inner[i];\n if (value === obj) {\n return true;\n }\n }\n inner.push(obj);\n return false;\n }\n\n function unmemoize(obj: any): void {\n if (hasWeakSet) {\n inner.delete(obj);\n } else {\n for (let i = 0; i < inner.length; i++) {\n if (inner[i] === obj) {\n inner.splice(i, 1);\n break;\n }\n }\n }\n }\n return [memoize, unmemoize];\n}\n", "import type { Primitive } from '@sentry/types';\n\nimport { isNaN, isSyntheticEvent, isVueViewModel } from './is';\nimport type { MemoFunc } from './memo';\nimport { memoBuilder } from './memo';\nimport { convertToPlainObject } from './object';\nimport { getFunctionName } from './stacktrace';\n\ntype Prototype = { constructor: (...args: unknown[]) => unknown };\n// This is a hack to placate TS, relying on the fact that technically, arrays are objects with integer keys. Normally we\n// think of those keys as actual numbers, but `arr['0']` turns out to work just as well as `arr[0]`, and doing it this\n// way lets us use a single type in the places where behave as if we are only dealing with objects, even if some of them\n// might be arrays.\ntype ObjOrArray<T> = { [key: string]: T };\n\n/**\n * Recursively normalizes the given object.\n *\n * - Creates a copy to prevent original input mutation\n * - Skips non-enumerable properties\n * - When stringifying, calls `toJSON` if implemented\n * - Removes circular references\n * - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format\n * - Translates known global objects/classes to a string representations\n * - Takes care of `Error` object serialization\n * - Optionally limits depth of final output\n * - Optionally limits number of properties/elements included in any single object/array\n *\n * @param input The object to be normalized.\n * @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.)\n * @param maxProperties The max number of elements or properties to be included in any single array or\n * object in the normallized output.\n * @returns A normalized version of the object, or `\"**non-serializable**\"` if any errors are thrown during normalization.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function normalize(input: unknown, depth: number = 100, maxProperties: number = +Infinity): any {\n try {\n // since we're at the outermost level, we don't provide a key\n return visit('', input, depth, maxProperties);\n } catch (err) {\n return { ERROR: `**non-serializable** (${err})` };\n }\n}\n\n/** JSDoc */\nexport function normalizeToSize<T>(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n object: { [key: string]: any },\n // Default Node.js REPL depth\n depth: number = 3,\n // 100kB, as 200kB is max payload size, so half sounds reasonable\n maxSize: number = 100 * 1024,\n): T {\n const normalized = normalize(object, depth);\n\n if (jsonSize(normalized) > maxSize) {\n return normalizeToSize(object, depth - 1, maxSize);\n }\n\n return normalized as T;\n}\n\n/**\n * Visits a node to perform normalization on it\n *\n * @param key The key corresponding to the given node\n * @param value The node to be visited\n * @param depth Optional number indicating the maximum recursion depth\n * @param maxProperties Optional maximum number of properties/elements included in any single object/array\n * @param memo Optional Memo class handling decycling\n */\nfunction visit(\n key: string,\n value: unknown,\n depth: number = +Infinity,\n maxProperties: number = +Infinity,\n memo: MemoFunc = memoBuilder(),\n): Primitive | ObjOrArray<unknown> {\n const [memoize, unmemoize] = memo;\n\n // Get the simple cases out of the way first\n if (\n value == null || // this matches null and undefined -> eqeq not eqeqeq\n (['number', 'boolean', 'string'].includes(typeof value) && !isNaN(value))\n ) {\n return value as Primitive;\n }\n\n const stringified = stringifyValue(key, value);\n\n // Anything we could potentially dig into more (objects or arrays) will have come back as `\"[object XXXX]\"`.\n // Everything else will have already been serialized, so if we don't see that pattern, we're done.\n if (!stringified.startsWith('[object ')) {\n return stringified;\n }\n\n // From here on, we can assert that `value` is either an object or an array.\n\n // Do not normalize objects that we know have already been normalized. As a general rule, the\n // \"__sentry_skip_normalization__\" property should only be used sparingly and only should only be set on objects that\n // have already been normalized.\n if ((value as ObjOrArray<unknown>)['__sentry_skip_normalization__']) {\n return value as ObjOrArray<unknown>;\n }\n\n // We can set `__sentry_override_normalization_depth__` on an object to ensure that from there\n // We keep a certain amount of depth.\n // This should be used sparingly, e.g. we use it for the redux integration to ensure we get a certain amount of state.\n const remainingDepth =\n typeof (value as ObjOrArray<unknown>)['__sentry_override_normalization_depth__'] === 'number'\n ? ((value as ObjOrArray<unknown>)['__sentry_override_normalization_depth__'] as number)\n : depth;\n\n // We're also done if we've reached the max depth\n if (remainingDepth === 0) {\n // At this point we know `serialized` is a string of the form `\"[object XXXX]\"`. Clean it up so it's just `\"[XXXX]\"`.\n return stringified.replace('object ', '');\n }\n\n // If we've already visited this branch, bail out, as it's circular reference. If not, note that we're seeing it now.\n if (memoize(value)) {\n return '[Circular ~]';\n }\n\n // If the value has a `toJSON` method, we call it to extract more information\n const valueWithToJSON = value as unknown & { toJSON?: () => unknown };\n if (valueWithToJSON && typeof valueWithToJSON.toJSON === 'function') {\n try {\n const jsonValue = valueWithToJSON.toJSON();\n // We need to normalize the return value of `.toJSON()` in case it has circular references\n return visit('', jsonValue, remainingDepth - 1, maxProperties, memo);\n } catch (err) {\n // pass (The built-in `toJSON` failed, but we can still try to do it ourselves)\n }\n }\n\n // At this point we know we either have an object or an array, we haven't seen it before, and we're going to recurse\n // because we haven't yet reached the max depth. Create an accumulator to hold the results of visiting each\n // property/entry, and keep track of the number of items we add to it.\n const normalized = (Array.isArray(value) ? [] : {}) as ObjOrArray<unknown>;\n let numAdded = 0;\n\n // Before we begin, convert`Error` and`Event` instances into plain objects, since some of each of their relevant\n // properties are non-enumerable and otherwise would get missed.\n const visitable = convertToPlainObject(value as ObjOrArray<unknown>);\n\n for (const visitKey in visitable) {\n // Avoid iterating over fields in the prototype if they've somehow been exposed to enumeration.\n if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) {\n continue;\n }\n\n if (numAdded >= maxProperties) {\n normalized[visitKey] = '[MaxProperties ~]';\n break;\n }\n\n // Recursively visit all the child nodes\n const visitValue = visitable[visitKey];\n normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo);\n\n numAdded++;\n }\n\n // Once we've visited all the branches, remove the parent from memo storage\n unmemoize(value);\n\n // Return accumulated values\n return normalized;\n}\n\n/**\n * @deprecated This export will be removed in v8.\n */\nexport { visit as walk };\n\n/* eslint-disable complexity */\n/**\n * Stringify the given value. Handles various known special values and types.\n *\n * Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn\n * the number 1231 into \"[Object Number]\", nor on `null`, as it will throw.\n *\n * @param value The value to stringify\n * @returns A stringified representation of the given value\n */\nfunction stringifyValue(\n key: unknown,\n // this type is a tiny bit of a cheat, since this function does handle NaN (which is technically a number), but for\n // our internal use, it'll do\n value: Exclude<unknown, string | number | boolean | null>,\n): string {\n try {\n if (key === 'domain' && value && typeof value === 'object' && (value as { _events: unknown })._events) {\n return '[Domain]';\n }\n\n if (key === 'domainEmitter') {\n return '[DomainEmitter]';\n }\n\n // It's safe to use `global`, `window`, and `document` here in this manner, as we are asserting using `typeof` first\n // which won't throw if they are not present.\n\n if (typeof global !== 'undefined' && value === global) {\n return '[Global]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof window !== 'undefined' && value === window) {\n return '[Window]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof document !== 'undefined' && value === document) {\n return '[Document]';\n }\n\n if (isVueViewModel(value)) {\n return '[VueViewModel]';\n }\n\n // React's SyntheticEvent thingy\n if (isSyntheticEvent(value)) {\n return '[SyntheticEvent]';\n }\n\n if (typeof value === 'number' && value !== value) {\n return '[NaN]';\n }\n\n if (typeof value === 'function') {\n return `[Function: ${getFunctionName(value)}]`;\n }\n\n if (typeof value === 'symbol') {\n return `[${String(value)}]`;\n }\n\n // stringified BigInts are indistinguishable from regular numbers, so we need to label them to avoid confusion\n if (typeof value === 'bigint') {\n return `[BigInt: ${String(value)}]`;\n }\n\n // Now that we've knocked out all the special cases and the primitives, all we have left are objects. Simply casting\n // them to strings means that instances of classes which haven't defined their `toStringTag` will just come out as\n // `\"[object Object]\"`. If we instead look at the constructor's name (which is the same as the name of the class),\n // we can make sure that only plain objects come out that way.\n const objName = getConstructorName(value);\n\n // Handle HTML Elements\n if (/^HTML(\\w*)Element$/.test(objName)) {\n return `[HTMLElement: ${objName}]`;\n }\n\n return `[object ${objName}]`;\n } catch (err) {\n return `**non-serializable** (${err})`;\n }\n}\n/* eslint-enable complexity */\n\nfunction getConstructorName(value: unknown): string {\n const prototype: Prototype | null = Object.getPrototypeOf(value);\n\n return prototype ? prototype.constructor.name : 'null prototype';\n}\n\n/** Calculates bytes size of input string */\nfunction utf8Length(value: string): number {\n // eslint-disable-next-line no-bitwise\n return ~-encodeURI(value).split(/%..|./).length;\n}\n\n/** Calculates bytes size of input object */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction jsonSize(value: any): number {\n return utf8Length(JSON.stringify(value));\n}\n", "/* eslint-disable @typescript-eslint/explicit-function-return-type */\n/* eslint-disable @typescript-eslint/typedef */\n/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { isThenable } from './is';\n\n/** SyncPromise internal states */\nconst enum States {\n /** Pending */\n PENDING = 0,\n /** Resolved / OK */\n RESOLVED = 1,\n /** Rejected / Error */\n REJECTED = 2,\n}\n\n// Overloads so we can call resolvedSyncPromise without arguments and generic argument\nexport function resolvedSyncPromise(): PromiseLike<void>;\nexport function resolvedSyncPromise<T>(value: T | PromiseLike<T>): PromiseLike<T>;\n\n/**\n * Creates a resolved sync promise.\n *\n * @param value the value to resolve the promise with\n * @returns the resolved sync promise\n */\nexport function resolvedSyncPromise<T>(value?: T | PromiseLike<T>): PromiseLike<T> {\n return new SyncPromise(resolve => {\n resolve(value);\n });\n}\n\n/**\n * Creates a rejected sync promise.\n *\n * @param value the value to reject the promise with\n * @returns the rejected sync promise\n */\nexport function rejectedSyncPromise<T = never>(reason?: any): PromiseLike<T> {\n return new SyncPromise((_, reject) => {\n reject(reason);\n });\n}\n\n/**\n * Thenable class that behaves like a Promise and follows it's interface\n * but is not async internally\n */\nclass SyncPromise<T> implements PromiseLike<T> {\n private _state: States;\n private _handlers: Array<[boolean, (value: T) => void, (reason: any) => any]>;\n private _value: any;\n\n public constructor(\n executor: (resolve: (value?: T | PromiseLike<T> | null) => void, reject: (reason?: any) => void) => void,\n ) {\n this._state = States.PENDING;\n this._handlers = [];\n\n try {\n executor(this._resolve, this._reject);\n } catch (e) {\n this._reject(e);\n }\n }\n\n /** JSDoc */\n public then<TResult1 = T, TResult2 = never>(\n onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | null,\n onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null,\n ): PromiseLike<TResult1 | TResult2> {\n return new SyncPromise((resolve, reject) => {\n this._handlers.push([\n false,\n result => {\n if (!onfulfilled) {\n // TODO: ¯\\_(ツ)_/¯\n // TODO: FIXME\n resolve(result as any);\n } else {\n try {\n resolve(onfulfilled(result));\n } catch (e) {\n reject(e);\n }\n }\n },\n reason => {\n if (!onrejected) {\n reject(reason);\n } else {\n try {\n resolve(onrejected(reason));\n } catch (e) {\n reject(e);\n }\n }\n },\n ]);\n this._executeHandlers();\n });\n }\n\n /** JSDoc */\n public catch<TResult = never>(\n onrejected?: ((reason: any) => TResult | PromiseLike<TResult>) | null,\n ): PromiseLike<T | TResult> {\n return this.then(val => val, onrejected);\n }\n\n /** JSDoc */\n public finally<TResult>(onfinally?: (() => void) | null): PromiseLike<TResult> {\n return new SyncPromise<TResult>((resolve, reject) => {\n let val: TResult | any;\n let isRejected: boolean;\n\n return this.then(\n value => {\n isRejected = false;\n val = value;\n if (onfinally) {\n onfinally();\n }\n },\n reason => {\n isRejected = true;\n val = reason;\n if (onfinally) {\n onfinally();\n }\n },\n ).then(() => {\n if (isRejected) {\n reject(val);\n return;\n }\n\n resolve(val as unknown as any);\n });\n });\n }\n\n /** JSDoc */\n private readonly _resolve = (value?: T | PromiseLike<T> | null) => {\n this._setResult(States.RESOLVED, value);\n };\n\n /** JSDoc */\n private readonly _reject = (reason?: any) => {\n this._setResult(States.REJECTED, reason);\n };\n\n /** JSDoc */\n private readonly _setResult = (state: States, value?: T | PromiseLike<T> | any) => {\n if (this._state !== States.PENDING) {\n return;\n }\n\n if (isThenable(value)) {\n void (value as PromiseLike<T>).then(this._resolve, this._reject);\n return;\n }\n\n this._state = state;\n this._value = value;\n\n this._executeHandlers();\n };\n\n /** JSDoc */\n private readonly _executeHandlers = () => {\n if (this._state === States.PENDING) {\n return;\n }\n\n const cachedHandlers = this._handlers.slice();\n this._handlers = [];\n\n cachedHandlers.forEach(handler => {\n if (handler[0]) {\n return;\n }\n\n if (this._state === States.RESOLVED) {\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n handler[1](this._value as unknown as any);\n }\n\n if (this._state === States.REJECTED) {\n handler[2](this._value);\n }\n\n handler[0] = true;\n });\n };\n}\n\nexport { SyncPromise };\n", "import { SentryError } from './error';\nimport { rejectedSyncPromise, resolvedSyncPromise, SyncPromise } from './syncpromise';\n\nexport interface PromiseBuffer<T> {\n // exposes the internal array so tests can assert on the state of it.\n // XXX: this really should not be public api.\n $: Array<PromiseLike<T>>;\n add(taskProducer: () => PromiseLike<T>): PromiseLike<T>;\n drain(timeout?: number): PromiseLike<boolean>;\n}\n\n/**\n * Creates an new PromiseBuffer object with the specified limit\n * @param limit max number of promises that can be stored in the buffer\n */\nexport function makePromiseBuffer<T>(limit?: number): PromiseBuffer<T> {\n const buffer: Array<PromiseLike<T>> = [];\n\n function isReady(): boolean {\n return limit === undefined || buffer.length < limit;\n }\n\n /**\n * Remove a promise from the queue.\n *\n * @param task Can be any PromiseLike<T>\n * @returns Removed promise.\n */\n function remove(task: PromiseLike<T>): PromiseLike<T> {\n return buffer.splice(buffer.indexOf(task), 1)[0];\n }\n\n /**\n * Add a promise (representing an in-flight action) to the queue, and set it to remove itself on fulfillment.\n *\n * @param taskProducer A function producing any PromiseLike<T>; In previous versions this used to be `task:\n * PromiseLike<T>`, but under that model, Promises were instantly created on the call-site and their executor\n * functions therefore ran immediately. Thus, even if the buffer was full, the action still happened. By\n * requiring the promise to be wrapped in a function, we can defer promise creation until after the buffer\n * limit check.\n * @returns The original promise.\n */\n function add(taskProducer: () => PromiseLike<T>): PromiseLike<T> {\n if (!isReady()) {\n return rejectedSyncPromise(new SentryError('Not adding Promise because buffer limit was reached.'));\n }\n\n // start the task and add its promise to the queue\n const task = taskProducer();\n if (buffer.indexOf(task) === -1) {\n buffer.push(task);\n }\n void task\n .then(() => remove(task))\n // Use `then(null, rejectionHandler)` rather than `catch(rejectionHandler)` so that we can use `PromiseLike`\n // rather than `Promise`. `PromiseLike` doesn't have a `.catch` method, making its polyfill smaller. (ES5 didn't\n // have promises, so TS has to polyfill when down-compiling.)\n .then(null, () =>\n remove(task).then(null, () => {\n // We have to add another catch here because `remove()` starts a new promise chain.\n }),\n );\n return task;\n }\n\n /**\n * Wait for all promises in the queue to resolve or for timeout to expire, whichever comes first.\n *\n * @param timeout The time, in ms, after which to resolve to `false` if the queue is still non-empty. Passing `0` (or\n * not passing anything) will make the promise wait as long as it takes for the queue to drain before resolving to\n * `true`.\n * @returns A promise which will resolve to `true` if the queue is already empty or drains before the timeout, and\n * `false` otherwise\n */\n function drain(timeout?: number): PromiseLike<boolean> {\n return new SyncPromise<boolean>((resolve, reject) => {\n let counter = buffer.length;\n\n if (!counter) {\n return resolve(true);\n }\n\n // wait for `timeout` ms and then resolve to `false` (if not cancelled first)\n const capturedSetTimeout = setTimeout(() => {\n if (timeout && timeout > 0) {\n resolve(false);\n }\n }, timeout);\n\n // if all promises resolve in time, cancel the timer and resolve to `true`\n buffer.forEach(item => {\n void resolvedSyncPromise(item).then(() => {\n if (!--counter) {\n clearTimeout(capturedSetTimeout);\n resolve(true);\n }\n }, reject);\n });\n });\n }\n\n return {\n $: buffer,\n add,\n drain,\n };\n}\n", "type PartialURL = {\n host?: string;\n path?: string;\n protocol?: string;\n relative?: string;\n search?: string;\n hash?: string;\n};\n\n/**\n * Parses string form of URL into an object\n * // borrowed from https://tools.ietf.org/html/rfc3986#appendix-B\n * // intentionally using regex and not <a/> href parsing trick because React Native and other\n * // environments where DOM might not be available\n * @returns parsed URL object\n */\nexport function parseUrl(url: string): PartialURL {\n if (!url) {\n return {};\n }\n\n const match = url.match(/^(([^:/?#]+):)?(\\/\\/([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?$/);\n\n if (!match) {\n return {};\n }\n\n // coerce to undefined values to empty string so we don't get 'undefined'\n const query = match[6] || '';\n const fragment = match[8] || '';\n return {\n host: match[4],\n path: match[5],\n protocol: match[2],\n search: query,\n hash: fragment,\n relative: match[5] + query + fragment, // everything minus origin\n };\n}\n\n/**\n * Strip the query string and fragment off of a given URL or path (if present)\n *\n * @param urlPath Full URL or path, including possible query string and/or fragment\n * @returns URL or path without query string or fragment\n */\nexport function stripUrlQueryAndFragment(urlPath: string): string {\n // eslint-disable-next-line no-useless-escape\n return urlPath.split(/[\\?#]/, 1)[0];\n}\n\n/**\n * Returns number of URL segments of a passed string URL.\n */\nexport function getNumberOfUrlSegments(url: string): number {\n // split at '/' or at '\\/' to split regex urls correctly\n return url.split(/\\\\?\\//).filter(s => s.length > 0 && s !== ',').length;\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span description\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nexport function getSanitizedUrlString(url: PartialURL): string {\n const { protocol, host, path } = url;\n\n const filteredHost =\n (host &&\n host\n // Always filter out authority\n .replace(/^.*@/, '[filtered]:[filtered]@')\n // Don't show standard :80 (http) and :443 (https) ports to reduce the noise\n .replace(':80', '')\n .replace(':443', '')) ||\n '';\n\n return `${protocol ? `${protocol}://` : ''}${filteredHost}${path}`;\n}\n", "/* eslint-disable deprecation/deprecation */\nimport type { Severity, SeverityLevel } from '@sentry/types';\n\n// Note: Ideally the `SeverityLevel` type would be derived from `validSeverityLevels`, but that would mean either\n//\n// a) moving `validSeverityLevels` to `@sentry/types`,\n// b) moving the`SeverityLevel` type here, or\n// c) importing `validSeverityLevels` from here into `@sentry/types`.\n//\n// Option A would make `@sentry/types` a runtime dependency of `@sentry/utils` (not good), and options B and C would\n// create a circular dependency between `@sentry/types` and `@sentry/utils` (also not good). So a TODO accompanying the\n// type, reminding anyone who changes it to change this list also, will have to do.\n\nexport const validSeverityLevels = ['fatal', 'error', 'warning', 'log', 'info', 'debug'];\n\n/**\n * Converts a string-based level into a member of the deprecated {@link Severity} enum.\n *\n * @deprecated `severityFromString` is deprecated. Please use `severityLevelFromString` instead.\n *\n * @param level String representation of Severity\n * @returns Severity\n */\nexport function severityFromString(level: Severity | SeverityLevel | string): Severity {\n return severityLevelFromString(level) as Severity;\n}\n\n/**\n * Converts a string-based level into a `SeverityLevel`, normalizing it along the way.\n *\n * @param level String representation of desired `SeverityLevel`.\n * @returns The `SeverityLevel` corresponding to the given string, or 'log' if the string isn't a valid level.\n */\nexport function severityLevelFromString(level: SeverityLevel | string): SeverityLevel {\n return (level === 'warn' ? 'warning' : validSeverityLevels.includes(level) ? level : 'log') as SeverityLevel;\n}\n", "import { dynamicRequire, isNodeEnv } from './node';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\n/**\n * An object that can return the current timestamp in seconds since the UNIX epoch.\n */\ninterface TimestampSource {\n nowSeconds(): number;\n}\n\n/**\n * A TimestampSource implementation for environments that do not support the Performance Web API natively.\n *\n * Note that this TimestampSource does not use a monotonic clock. A call to `nowSeconds` may return a timestamp earlier\n * than a previously returned value. We do not try to emulate a monotonic behavior in order to facilitate debugging. It\n * is more obvious to explain \"why does my span have negative duration\" than \"why my spans have zero duration\".\n */\nconst dateTimestampSource: TimestampSource = {\n nowSeconds: () => Date.now() / 1000,\n};\n\n/**\n * A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance}\n * for accessing a high-resolution monotonic clock.\n */\ninterface Performance {\n /**\n * The millisecond timestamp at which measurement began, measured in Unix time.\n */\n timeOrigin: number;\n /**\n * Returns the current millisecond timestamp, where 0 represents the start of measurement.\n */\n now(): number;\n}\n\n/**\n * Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not\n * support the API.\n *\n * Wrapping the native API works around differences in behavior from different browsers.\n */\nfunction getBrowserPerformance(): Performance | undefined {\n const { performance } = WINDOW;\n if (!performance || !performance.now) {\n return undefined;\n }\n\n // Replace performance.timeOrigin with our own timeOrigin based on Date.now().\n //\n // This is a partial workaround for browsers reporting performance.timeOrigin such that performance.timeOrigin +\n // performance.now() gives a date arbitrarily in the past.\n //\n // Additionally, computing timeOrigin in this way fills the gap for browsers where performance.timeOrigin is\n // undefined.\n //\n // The assumption that performance.timeOrigin + performance.now() ~= Date.now() is flawed, but we depend on it to\n // interact with data coming out of performance entries.\n //\n // Note that despite recommendations against it in the spec, browsers implement the Performance API with a clock that\n // might stop when the computer is asleep (and perhaps under other circumstances). Such behavior causes\n // performance.timeOrigin + performance.now() to have an arbitrary skew over Date.now(). In laptop computers, we have\n // observed skews that can be as long as days, weeks or months.\n //\n // See https://github.com/getsentry/sentry-javascript/issues/2590.\n //\n // BUG: despite our best intentions, this workaround has its limitations. It mostly addresses timings of pageload\n // transactions, but ignores the skew built up over time that can aversely affect timestamps of navigation\n // transactions of long-lived web pages.\n const timeOrigin = Date.now() - performance.now();\n\n return {\n now: () => performance.now(),\n timeOrigin,\n };\n}\n\n/**\n * Returns the native Performance API implementation from Node.js. Returns undefined in old Node.js versions that don't\n * implement the API.\n */\nfunction getNodePerformance(): Performance | undefined {\n try {\n const perfHooks = dynamicRequire(module, 'perf_hooks') as { performance: Performance };\n return perfHooks.performance;\n } catch (_) {\n return undefined;\n }\n}\n\n/**\n * The Performance API implementation for the current platform, if available.\n */\nconst platformPerformance: Performance | undefined = isNodeEnv() ? getNodePerformance() : getBrowserPerformance();\n\nconst timestampSource: TimestampSource =\n platformPerformance === undefined\n ? dateTimestampSource\n : {\n nowSeconds: () => (platformPerformance.timeOrigin + platformPerformance.now()) / 1000,\n };\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using the Date API.\n */\nexport const dateTimestampInSeconds: () => number = dateTimestampSource.nowSeconds.bind(dateTimestampSource);\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the\n * availability of the Performance API.\n *\n * See `usingPerformanceAPI` to test whether the Performance API is used.\n *\n * BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is\n * asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The\n * skew can grow to arbitrary amounts like days, weeks or months.\n * See https://github.com/getsentry/sentry-javascript/issues/2590.\n */\nexport const timestampInSeconds: () => number = timestampSource.nowSeconds.bind(timestampSource);\n\n/**\n * Re-exported with an old name for backwards-compatibility.\n * TODO (v8): Remove this\n *\n * @deprecated Use `timestampInSeconds` instead.\n */\nexport const timestampWithMs = timestampInSeconds;\n\n/**\n * A boolean that is true when timestampInSeconds uses the Performance API to produce monotonic timestamps.\n */\nexport const usingPerformanceAPI = platformPerformance !== undefined;\n\n/**\n * Internal helper to store what is the source of browserPerformanceTimeOrigin below. For debugging only.\n */\nexport let _browserPerformanceTimeOriginMode: string;\n\n/**\n * The number of milliseconds since the UNIX epoch. This value is only usable in a browser, and only when the\n * performance API is available.\n */\nexport const browserPerformanceTimeOrigin = ((): number | undefined => {\n // Unfortunately browsers may report an inaccurate time origin data, through either performance.timeOrigin or\n // performance.timing.navigationStart, which results in poor results in performance data. We only treat time origin\n // data as reliable if they are within a reasonable threshold of the current time.\n\n const { performance } = WINDOW;\n if (!performance || !performance.now) {\n _browserPerformanceTimeOriginMode = 'none';\n return undefined;\n }\n\n const threshold = 3600 * 1000;\n const performanceNow = performance.now();\n const dateNow = Date.now();\n\n // if timeOrigin isn't available set delta to threshold so it isn't used\n const timeOriginDelta = performance.timeOrigin\n ? Math.abs(performance.timeOrigin + performanceNow - dateNow)\n : threshold;\n const timeOriginIsReliable = timeOriginDelta < threshold;\n\n // While performance.timing.navigationStart is deprecated in favor of performance.timeOrigin, performance.timeOrigin\n // is not as widely supported. Namely, performance.timeOrigin is undefined in Safari as of writing.\n // Also as of writing, performance.timing is not available in Web Workers in mainstream browsers, so it is not always\n // a valid fallback. In the absence of an initial time provided by the browser, fallback to the current time from the\n // Date API.\n // eslint-disable-next-line deprecation/deprecation\n const navigationStart = performance.timing && performance.timing.navigationStart;\n const hasNavigationStart = typeof navigationStart === 'number';\n // if navigationStart isn't available set delta to threshold so it isn't used\n const navigationStartDelta = hasNavigationStart ? Math.abs(navigationStart + performanceNow - dateNow) : threshold;\n const navigationStartIsReliable = navigationStartDelta < threshold;\n\n if (timeOriginIsReliable || navigationStartIsReliable) {\n // Use the more reliable time origin\n if (timeOriginDelta <= navigationStartDelta) {\n _browserPerformanceTimeOriginMode = 'timeOrigin';\n return performance.timeOrigin;\n } else {\n _browserPerformanceTimeOriginMode = 'navigationStart';\n return navigationStart;\n }\n }\n\n // Either both timeOrigin and navigationStart are skewed or neither is available, fallback to Date.\n _browserPerformanceTimeOriginMode = 'dateNow';\n return dateNow;\n})();\n", "import type { DynamicSamplingContext } from '@sentry/types';\n\nimport { isString } from './is';\nimport { logger } from './logger';\n\nexport const BAGGAGE_HEADER_NAME = 'baggage';\n\nexport const SENTRY_BAGGAGE_KEY_PREFIX = 'sentry-';\n\nexport const SENTRY_BAGGAGE_KEY_PREFIX_REGEX = /^sentry-/;\n\n/**\n * Max length of a serialized baggage string\n *\n * https://www.w3.org/TR/baggage/#limits\n */\nexport const MAX_BAGGAGE_STRING_LENGTH = 8192;\n\n/**\n * Takes a baggage header and turns it into Dynamic Sampling Context, by extracting all the \"sentry-\" prefixed values\n * from it.\n *\n * @param baggageHeader A very bread definition of a baggage header as it might appear in various frameworks.\n * @returns The Dynamic Sampling Context that was found on `baggageHeader`, if there was any, `undefined` otherwise.\n */\nexport function baggageHeaderToDynamicSamplingContext(\n // Very liberal definition of what any incoming header might look like\n baggageHeader: string | string[] | number | null | undefined | boolean,\n): Partial<DynamicSamplingContext> | undefined {\n if (!isString(baggageHeader) && !Array.isArray(baggageHeader)) {\n return undefined;\n }\n\n // Intermediary object to store baggage key value pairs of incoming baggage headers on.\n // It is later used to read Sentry-DSC-values from.\n let baggageObject: Readonly<Record<string, string>> = {};\n\n if (Array.isArray(baggageHeader)) {\n // Combine all baggage headers into one object containing the baggage values so we can later read the Sentry-DSC-values from it\n baggageObject = baggageHeader.reduce<Record<string, string>>((acc, curr) => {\n const currBaggageObject = baggageHeaderToObject(curr);\n return {\n ...acc,\n ...currBaggageObject,\n };\n }, {});\n } else {\n // Return undefined if baggage header is an empty string (technically an empty baggage header is not spec conform but\n // this is how we choose to handle it)\n if (!baggageHeader) {\n return undefined;\n }\n\n baggageObject = baggageHeaderToObject(baggageHeader);\n }\n\n // Read all \"sentry-\" prefixed values out of the baggage object and put it onto a dynamic sampling context object.\n const dynamicSamplingContext = Object.entries(baggageObject).reduce<Record<string, string>>((acc, [key, value]) => {\n if (key.match(SENTRY_BAGGAGE_KEY_PREFIX_REGEX)) {\n const nonPrefixedKey = key.slice(SENTRY_BAGGAGE_KEY_PREFIX.length);\n acc[nonPrefixedKey] = value;\n }\n return acc;\n }, {});\n\n // Only return a dynamic sampling context object if there are keys in it.\n // A keyless object means there were no sentry values on the header, which means that there is no DSC.\n if (Object.keys(dynamicSamplingContext).length > 0) {\n return dynamicSamplingContext as Partial<DynamicSamplingContext>;\n } else {\n return undefined;\n }\n}\n\n/**\n * Turns a Dynamic Sampling Object into a baggage header by prefixing all the keys on the object with \"sentry-\".\n *\n * @param dynamicSamplingContext The Dynamic Sampling Context to turn into a header. For convenience and compatibility\n * with the `getDynamicSamplingContext` method on the Transaction class ,this argument can also be `undefined`. If it is\n * `undefined` the function will return `undefined`.\n * @returns a baggage header, created from `dynamicSamplingContext`, or `undefined` either if `dynamicSamplingContext`\n * was `undefined`, or if `dynamicSamplingContext` didn't contain any values.\n */\nexport function dynamicSamplingContextToSentryBaggageHeader(\n // this also takes undefined for convenience and bundle size in other places\n dynamicSamplingContext?: Partial<DynamicSamplingContext>,\n): string | undefined {\n if (!dynamicSamplingContext) {\n return undefined;\n }\n\n // Prefix all DSC keys with \"sentry-\" and put them into a new object\n const sentryPrefixedDSC = Object.entries(dynamicSamplingContext).reduce<Record<string, string>>(\n (acc, [dscKey, dscValue]) => {\n if (dscValue) {\n acc[`${SENTRY_BAGGAGE_KEY_PREFIX}${dscKey}`] = dscValue;\n }\n return acc;\n },\n {},\n );\n\n return objectToBaggageHeader(sentryPrefixedDSC);\n}\n\n/**\n * Will parse a baggage header, which is a simple key-value map, into a flat object.\n *\n * @param baggageHeader The baggage header to parse.\n * @returns a flat object containing all the key-value pairs from `baggageHeader`.\n */\nfunction baggageHeaderToObject(baggageHeader: string): Record<string, string> {\n return baggageHeader\n .split(',')\n .map(baggageEntry => baggageEntry.split('=').map(keyOrValue => decodeURIComponent(keyOrValue.trim())))\n .reduce<Record<string, string>>((acc, [key, value]) => {\n acc[key] = value;\n return acc;\n }, {});\n}\n\n/**\n * Turns a flat object (key-value pairs) into a baggage header, which is also just key-value pairs.\n *\n * @param object The object to turn into a baggage header.\n * @returns a baggage header string, or `undefined` if the object didn't have any values, since an empty baggage header\n * is not spec compliant.\n */\nfunction objectToBaggageHeader(object: Record<string, string>): string | undefined {\n if (Object.keys(object).length === 0) {\n // An empty baggage header is not spec compliant: We return undefined.\n return undefined;\n }\n\n return Object.entries(object).reduce((baggageHeader, [objectKey, objectValue], currentIndex) => {\n const baggageEntry = `${encodeURIComponent(objectKey)}=${encodeURIComponent(objectValue)}`;\n const newBaggageHeader = currentIndex === 0 ? baggageEntry : `${baggageHeader},${baggageEntry}`;\n if (newBaggageHeader.length > MAX_BAGGAGE_STRING_LENGTH) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Not adding key: ${objectKey} with val: ${objectValue} to baggage header due to exceeding baggage size limits.`,\n );\n return baggageHeader;\n } else {\n return newBaggageHeader;\n }\n }, '');\n}\n", "import type { DynamicSamplingContext, PropagationContext, TraceparentData } from '@sentry/types';\n\nimport { baggageHeaderToDynamicSamplingContext } from './baggage';\nimport { uuid4 } from './misc';\n\nexport const TRACEPARENT_REGEXP = new RegExp(\n '^[ \\\\t]*' + // whitespace\n '([0-9a-f]{32})?' + // trace_id\n '-?([0-9a-f]{16})?' + // span_id\n '-?([01])?' + // sampled\n '[ \\\\t]*$', // whitespace\n);\n\n/**\n * Extract transaction context data from a `sentry-trace` header.\n *\n * @param traceparent Traceparent string\n *\n * @returns Object containing data from the header, or undefined if traceparent string is malformed\n */\nexport function extractTraceparentData(traceparent?: string): TraceparentData | undefined {\n if (!traceparent) {\n return undefined;\n }\n\n const matches = traceparent.match(TRACEPARENT_REGEXP);\n if (!matches) {\n return undefined;\n }\n\n let parentSampled: boolean | undefined;\n if (matches[3] === '1') {\n parentSampled = true;\n } else if (matches[3] === '0') {\n parentSampled = false;\n }\n\n return {\n traceId: matches[1],\n parentSampled,\n parentSpanId: matches[2],\n };\n}\n\n/**\n * Create tracing context from incoming headers.\n */\nexport function tracingContextFromHeaders(\n sentryTrace: Parameters<typeof extractTraceparentData>[0],\n baggage: Parameters<typeof baggageHeaderToDynamicSamplingContext>[0],\n): {\n traceparentData: ReturnType<typeof extractTraceparentData>;\n dynamicSamplingContext: ReturnType<typeof baggageHeaderToDynamicSamplingContext>;\n propagationContext: PropagationContext;\n} {\n const traceparentData = extractTraceparentData(sentryTrace);\n const dynamicSamplingContext = baggageHeaderToDynamicSamplingContext(baggage);\n\n const { traceId, parentSpanId, parentSampled } = traceparentData || {};\n\n const propagationContext: PropagationContext = {\n traceId: traceId || uuid4(),\n spanId: uuid4().substring(16),\n sampled: parentSampled,\n };\n\n if (parentSpanId) {\n propagationContext.parentSpanId = parentSpanId;\n }\n\n if (dynamicSamplingContext) {\n propagationContext.dsc = dynamicSamplingContext as DynamicSamplingContext;\n }\n\n return {\n traceparentData,\n dynamicSamplingContext,\n propagationContext,\n };\n}\n\n/**\n * Create sentry-trace header from span context values.\n */\nexport function generateSentryTraceHeader(\n traceId: string = uuid4(),\n spanId: string = uuid4().substring(16),\n sampled?: boolean,\n): string {\n let sampledString = '';\n if (sampled !== undefined) {\n sampledString = sampled ? '-1' : '-0';\n }\n return `${traceId}-${spanId}${sampledString}`;\n}\n", "import type {\n Attachment,\n AttachmentItem,\n BaseEnvelopeHeaders,\n BaseEnvelopeItemHeaders,\n DataCategory,\n DsnComponents,\n Envelope,\n EnvelopeItemType,\n Event,\n EventEnvelopeHeaders,\n SdkInfo,\n SdkMetadata,\n TextEncoderInternal,\n} from '@sentry/types';\n\nimport { dsnToString } from './dsn';\nimport { normalize } from './normalize';\nimport { dropUndefinedKeys } from './object';\n\n/**\n * Creates an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nexport function createEnvelope<E extends Envelope>(headers: E[0], items: E[1] = []): E {\n return [headers, items] as E;\n}\n\n/**\n * Add an item to an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nexport function addItemToEnvelope<E extends Envelope>(envelope: E, newItem: E[1][number]): E {\n const [headers, items] = envelope;\n return [headers, [...items, newItem]] as unknown as E;\n}\n\n/**\n * Convenience function to loop through the items and item types of an envelope.\n * (This function was mostly created because working with envelope types is painful at the moment)\n *\n * If the callback returns true, the rest of the items will be skipped.\n */\nexport function forEachEnvelopeItem<E extends Envelope>(\n envelope: Envelope,\n callback: (envelopeItem: E[1][number], envelopeItemType: E[1][number][0]['type']) => boolean | void,\n): boolean {\n const envelopeItems = envelope[1];\n\n for (const envelopeItem of envelopeItems) {\n const envelopeItemType = envelopeItem[0].type;\n const result = callback(envelopeItem, envelopeItemType);\n\n if (result) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Returns true if the envelope contains any of the given envelope item types\n */\nexport function envelopeContainsItemType(envelope: Envelope, types: EnvelopeItemType[]): boolean {\n return forEachEnvelopeItem(envelope, (_, type) => types.includes(type));\n}\n\n/**\n * Encode a string to UTF8.\n */\nfunction encodeUTF8(input: string, textEncoder?: TextEncoderInternal): Uint8Array {\n const utf8 = textEncoder || new TextEncoder();\n return utf8.encode(input);\n}\n\n/**\n * Serializes an envelope.\n */\nexport function serializeEnvelope(envelope: Envelope, textEncoder?: TextEncoderInternal): string | Uint8Array {\n const [envHeaders, items] = envelope;\n\n // Initially we construct our envelope as a string and only convert to binary chunks if we encounter binary data\n let parts: string | Uint8Array[] = JSON.stringify(envHeaders);\n\n function append(next: string | Uint8Array): void {\n if (typeof parts === 'string') {\n parts = typeof next === 'string' ? parts + next : [encodeUTF8(parts, textEncoder), next];\n } else {\n parts.push(typeof next === 'string' ? encodeUTF8(next, textEncoder) : next);\n }\n }\n\n for (const item of items) {\n const [itemHeaders, payload] = item;\n\n append(`\\n${JSON.stringify(itemHeaders)}\\n`);\n\n if (typeof payload === 'string' || payload instanceof Uint8Array) {\n append(payload);\n } else {\n let stringifiedPayload: string;\n try {\n stringifiedPayload = JSON.stringify(payload);\n } catch (e) {\n // In case, despite all our efforts to keep `payload` circular-dependency-free, `JSON.strinify()` still\n // fails, we try again after normalizing it again with infinite normalization depth. This of course has a\n // performance impact but in this case a performance hit is better than throwing.\n stringifiedPayload = JSON.stringify(normalize(payload));\n }\n append(stringifiedPayload);\n }\n }\n\n return typeof parts === 'string' ? parts : concatBuffers(parts);\n}\n\nfunction concatBuffers(buffers: Uint8Array[]): Uint8Array {\n const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0);\n\n const merged = new Uint8Array(totalLength);\n let offset = 0;\n for (const buffer of buffers) {\n merged.set(buffer, offset);\n offset += buffer.length;\n }\n\n return merged;\n}\n\nexport interface TextDecoderInternal {\n decode(input?: Uint8Array): string;\n}\n\n/**\n * Parses an envelope\n */\nexport function parseEnvelope(\n env: string | Uint8Array,\n textEncoder: TextEncoderInternal,\n textDecoder: TextDecoderInternal,\n): Envelope {\n let buffer = typeof env === 'string' ? textEncoder.encode(env) : env;\n\n function readBinary(length: number): Uint8Array {\n const bin = buffer.subarray(0, length);\n // Replace the buffer with the remaining data excluding trailing newline\n buffer = buffer.subarray(length + 1);\n return bin;\n }\n\n function readJson<T>(): T {\n let i = buffer.indexOf(0xa);\n // If we couldn't find a newline, we must have found the end of the buffer\n if (i < 0) {\n i = buffer.length;\n }\n\n return JSON.parse(textDecoder.decode(readBinary(i))) as T;\n }\n\n const envelopeHeader = readJson<BaseEnvelopeHeaders>();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const items: [any, any][] = [];\n\n while (buffer.length) {\n const itemHeader = readJson<BaseEnvelopeItemHeaders>();\n const binaryLength = typeof itemHeader.length === 'number' ? itemHeader.length : undefined;\n\n items.push([itemHeader, binaryLength ? readBinary(binaryLength) : readJson()]);\n }\n\n return [envelopeHeader, items];\n}\n\n/**\n * Creates attachment envelope items\n */\nexport function createAttachmentEnvelopeItem(\n attachment: Attachment,\n textEncoder?: TextEncoderInternal,\n): AttachmentItem {\n const buffer = typeof attachment.data === 'string' ? encodeUTF8(attachment.data, textEncoder) : attachment.data;\n\n return [\n dropUndefinedKeys({\n type: 'attachment',\n length: buffer.length,\n filename: attachment.filename,\n content_type: attachment.contentType,\n attachment_type: attachment.attachmentType,\n }),\n buffer,\n ];\n}\n\nconst ITEM_TYPE_TO_DATA_CATEGORY_MAP: Record<EnvelopeItemType, DataCategory> = {\n session: 'session',\n sessions: 'session',\n attachment: 'attachment',\n transaction: 'transaction',\n event: 'error',\n client_report: 'internal',\n user_report: 'default',\n profile: 'profile',\n replay_event: 'replay',\n replay_recording: 'replay',\n check_in: 'monitor',\n // TODO: This is a temporary workaround until we have a proper data category for metrics\n statsd: 'unknown',\n};\n\n/**\n * Maps the type of an envelope item to a data category.\n */\nexport function envelopeItemTypeToDataCategory(type: EnvelopeItemType): DataCategory {\n return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type];\n}\n\n/** Extracts the minimal SDK info from from the metadata or an events */\nexport function getSdkMetadataForEnvelopeHeader(metadataOrEvent?: SdkMetadata | Event): SdkInfo | undefined {\n if (!metadataOrEvent || !metadataOrEvent.sdk) {\n return;\n }\n const { name, version } = metadataOrEvent.sdk;\n return { name, version };\n}\n\n/**\n * Creates event envelope headers, based on event, sdk info and tunnel\n * Note: This function was extracted from the core package to make it available in Replay\n */\nexport function createEventEnvelopeHeaders(\n event: Event,\n sdkInfo: SdkInfo | undefined,\n tunnel: string | undefined,\n dsn?: DsnComponents,\n): EventEnvelopeHeaders {\n const dynamicSamplingContext = event.sdkProcessingMetadata && event.sdkProcessingMetadata.dynamicSamplingContext;\n return {\n event_id: event.event_id as string,\n sent_at: new Date().toISOString(),\n ...(sdkInfo && { sdk: sdkInfo }),\n ...(!!tunnel && dsn && { dsn: dsnToString(dsn) }),\n ...(dynamicSamplingContext && {\n trace: dropUndefinedKeys({ ...dynamicSamplingContext }),\n }),\n };\n}\n", "import type { ClientReport, ClientReportEnvelope, ClientReportItem } from '@sentry/types';\n\nimport { createEnvelope } from './envelope';\nimport { dateTimestampInSeconds } from './time';\n\n/**\n * Creates client report envelope\n * @param discarded_events An array of discard events\n * @param dsn A DSN that can be set on the header. Optional.\n */\nexport function createClientReportEnvelope(\n discarded_events: ClientReport['discarded_events'],\n dsn?: string,\n timestamp?: number,\n): ClientReportEnvelope {\n const clientReportItem: ClientReportItem = [\n { type: 'client_report' },\n {\n timestamp: timestamp || dateTimestampInSeconds(),\n discarded_events,\n },\n ];\n return createEnvelope<ClientReportEnvelope>(dsn ? { dsn } : {}, [clientReportItem]);\n}\n", "import type { TransportMakeRequestResponse } from '@sentry/types';\n\n// Intentionally keeping the key broad, as we don't know for sure what rate limit headers get returned from backend\nexport type RateLimits = Record<string, number>;\n\nexport const DEFAULT_RETRY_AFTER = 60 * 1000; // 60 seconds\n\n/**\n * Extracts Retry-After value from the request header or returns default value\n * @param header string representation of 'Retry-After' header\n * @param now current unix timestamp\n *\n */\nexport function parseRetryAfterHeader(header: string, now: number = Date.now()): number {\n const headerDelay = parseInt(`${header}`, 10);\n if (!isNaN(headerDelay)) {\n return headerDelay * 1000;\n }\n\n const headerDate = Date.parse(`${header}`);\n if (!isNaN(headerDate)) {\n return headerDate - now;\n }\n\n return DEFAULT_RETRY_AFTER;\n}\n\n/**\n * Gets the time that the given category is disabled until for rate limiting.\n * In case no category-specific limit is set but a general rate limit across all categories is active,\n * that time is returned.\n *\n * @return the time in ms that the category is disabled until or 0 if there's no active rate limit.\n */\nexport function disabledUntil(limits: RateLimits, category: string): number {\n return limits[category] || limits.all || 0;\n}\n\n/**\n * Checks if a category is rate limited\n */\nexport function isRateLimited(limits: RateLimits, category: string, now: number = Date.now()): boolean {\n return disabledUntil(limits, category) > now;\n}\n\n/**\n * Update ratelimits from incoming headers.\n *\n * @return the updated RateLimits object.\n */\nexport function updateRateLimits(\n limits: RateLimits,\n { statusCode, headers }: TransportMakeRequestResponse,\n now: number = Date.now(),\n): RateLimits {\n const updatedRateLimits: RateLimits = {\n ...limits,\n };\n\n // \"The name is case-insensitive.\"\n // https://developer.mozilla.org/en-US/docs/Web/API/Headers/get\n const rateLimitHeader = headers && headers['x-sentry-rate-limits'];\n const retryAfterHeader = headers && headers['retry-after'];\n\n if (rateLimitHeader) {\n /**\n * rate limit headers are of the form\n * <header>,<header>,..\n * where each <header> is of the form\n * <retry_after>: <categories>: <scope>: <reason_code>\n * where\n * <retry_after> is a delay in seconds\n * <categories> is the event type(s) (error, transaction, etc) being rate limited and is of the form\n * <category>;<category>;...\n * <scope> is what's being limited (org, project, or key) - ignored by SDK\n * <reason_code> is an arbitrary string like \"org_quota\" - ignored by SDK\n */\n for (const limit of rateLimitHeader.trim().split(',')) {\n const [retryAfter, categories] = limit.split(':', 2);\n const headerDelay = parseInt(retryAfter, 10);\n const delay = (!isNaN(headerDelay) ? headerDelay : 60) * 1000; // 60sec default\n if (!categories) {\n updatedRateLimits.all = now + delay;\n } else {\n for (const category of categories.split(';')) {\n updatedRateLimits[category] = now + delay;\n }\n }\n }\n } else if (retryAfterHeader) {\n updatedRateLimits.all = now + parseRetryAfterHeader(retryAfterHeader, now);\n } else if (statusCode === 429) {\n updatedRateLimits.all = now + 60 * 1000;\n }\n\n return updatedRateLimits;\n}\n", "import type {\n Event,\n EventHint,\n Exception,\n Hub,\n Mechanism,\n Severity,\n SeverityLevel,\n StackFrame,\n StackParser,\n} from '@sentry/types';\n\nimport { isError, isPlainObject } from './is';\nimport { addExceptionMechanism, addExceptionTypeValue } from './misc';\nimport { normalizeToSize } from './normalize';\nimport { extractExceptionKeysForMessage } from './object';\n\n/**\n * Extracts stack frames from the error.stack string\n */\nexport function parseStackFrames(stackParser: StackParser, error: Error): StackFrame[] {\n return stackParser(error.stack || '', 1);\n}\n\n/**\n * Extracts stack frames from the error and builds a Sentry Exception\n */\nexport function exceptionFromError(stackParser: StackParser, error: Error): Exception {\n const exception: Exception = {\n type: error.name || error.constructor.name,\n value: error.message,\n };\n\n const frames = parseStackFrames(stackParser, error);\n if (frames.length) {\n exception.stacktrace = { frames };\n }\n\n return exception;\n}\n\nfunction getMessageForObject(exception: object): string {\n if ('name' in exception && typeof exception.name === 'string') {\n let message = `'${exception.name}' captured as exception`;\n\n if ('message' in exception && typeof exception.message === 'string') {\n message += ` with message '${exception.message}'`;\n }\n\n return message;\n } else if ('message' in exception && typeof exception.message === 'string') {\n return exception.message;\n } else {\n // This will allow us to group events based on top-level keys\n // which is much better than creating new group when any key/value change\n return `Object captured as exception with keys: ${extractExceptionKeysForMessage(\n exception as Record<string, unknown>,\n )}`;\n }\n}\n\n/**\n * Builds and Event from a Exception\n * @hidden\n */\nexport function eventFromUnknownInput(\n getCurrentHub: () => Hub,\n stackParser: StackParser,\n exception: unknown,\n hint?: EventHint,\n): Event {\n let ex: unknown = exception;\n const providedMechanism: Mechanism | undefined =\n hint && hint.data && (hint.data as { mechanism: Mechanism }).mechanism;\n const mechanism: Mechanism = providedMechanism || {\n handled: true,\n type: 'generic',\n };\n\n if (!isError(exception)) {\n if (isPlainObject(exception)) {\n const hub = getCurrentHub();\n const client = hub.getClient();\n const normalizeDepth = client && client.getOptions().normalizeDepth;\n hub.configureScope(scope => {\n scope.setExtra('__serialized__', normalizeToSize(exception, normalizeDepth));\n });\n\n const message = getMessageForObject(exception);\n ex = (hint && hint.syntheticException) || new Error(message);\n (ex as Error).message = message;\n } else {\n // This handles when someone does: `throw \"something awesome\";`\n // We use synthesized Error here so we can extract a (rough) stack trace.\n ex = (hint && hint.syntheticException) || new Error(exception as string);\n (ex as Error).message = exception as string;\n }\n mechanism.synthetic = true;\n }\n\n const event = {\n exception: {\n values: [exceptionFromError(stackParser, ex as Error)],\n },\n };\n\n addExceptionTypeValue(event, undefined, undefined);\n addExceptionMechanism(event, mechanism);\n\n return {\n ...event,\n event_id: hint && hint.event_id,\n };\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nexport function eventFromMessage(\n stackParser: StackParser,\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel = 'info',\n hint?: EventHint,\n attachStacktrace?: boolean,\n): Event {\n const event: Event = {\n event_id: hint && hint.event_id,\n level,\n message,\n };\n\n if (attachStacktrace && hint && hint.syntheticException) {\n const frames = parseStackFrames(stackParser, hint.syntheticException);\n if (frames.length) {\n event.exception = {\n values: [\n {\n value: message,\n stacktrace: { frames },\n },\n ],\n };\n }\n }\n\n return event;\n}\n", "export const DEFAULT_ENVIRONMENT = 'production';\n", "import type { Event, EventHint, EventProcessor } from '@sentry/types';\nimport { getGlobalSingleton, isThenable, logger, SyncPromise } from '@sentry/utils';\n\n/**\n * Returns the global event processors.\n */\nexport function getGlobalEventProcessors(): EventProcessor[] {\n return getGlobalSingleton<EventProcessor[]>('globalEventProcessors', () => []);\n}\n\n/**\n * Add a EventProcessor to be kept globally.\n * @param callback EventProcessor to add\n */\nexport function addGlobalEventProcessor(callback: EventProcessor): void {\n getGlobalEventProcessors().push(callback);\n}\n\n/**\n * Process an array of event processors, returning the processed event (or `null` if the event was dropped).\n */\nexport function notifyEventProcessors(\n processors: EventProcessor[],\n event: Event | null,\n hint: EventHint,\n index: number = 0,\n): PromiseLike<Event | null> {\n return new SyncPromise<Event | null>((resolve, reject) => {\n const processor = processors[index];\n if (event === null || typeof processor !== 'function') {\n resolve(event);\n } else {\n const result = processor({ ...event }, hint) as Event | null;\n\n __DEBUG_BUILD__ &&\n processor.id &&\n result === null &&\n logger.log(`Event processor \"${processor.id}\" dropped event`);\n\n if (isThenable(result)) {\n void result\n .then(final => notifyEventProcessors(processors, final, hint, index + 1).then(resolve))\n .then(null, reject);\n } else {\n void notifyEventProcessors(processors, result, hint, index + 1)\n .then(resolve)\n .then(null, reject);\n }\n }\n });\n}\n", "import type { SerializedSession, Session, SessionContext, SessionStatus } from '@sentry/types';\nimport { dropUndefinedKeys, timestampInSeconds, uuid4 } from '@sentry/utils';\n\n/**\n * Creates a new `Session` object by setting certain default parameters. If optional @param context\n * is passed, the passed properties are applied to the session object.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns a new `Session` object\n */\nexport function makeSession(context?: Omit<SessionContext, 'started' | 'status'>): Session {\n // Both timestamp and started are in seconds since the UNIX epoch.\n const startingTime = timestampInSeconds();\n\n const session: Session = {\n sid: uuid4(),\n init: true,\n timestamp: startingTime,\n started: startingTime,\n duration: 0,\n status: 'ok',\n errors: 0,\n ignoreDuration: false,\n toJSON: () => sessionToJSON(session),\n };\n\n if (context) {\n updateSession(session, context);\n }\n\n return session;\n}\n\n/**\n * Updates a session object with the properties passed in the context.\n *\n * Note that this function mutates the passed object and returns void.\n * (Had to do this instead of returning a new and updated session because closing and sending a session\n * makes an update to the session after it was passed to the sending logic.\n * @see BaseClient.captureSession )\n *\n * @param session the `Session` to update\n * @param context the `SessionContext` holding the properties that should be updated in @param session\n */\n// eslint-disable-next-line complexity\nexport function updateSession(session: Session, context: SessionContext = {}): void {\n if (context.user) {\n if (!session.ipAddress && context.user.ip_address) {\n session.ipAddress = context.user.ip_address;\n }\n\n if (!session.did && !context.did) {\n session.did = context.user.id || context.user.email || context.user.username;\n }\n }\n\n session.timestamp = context.timestamp || timestampInSeconds();\n\n if (context.abnormal_mechanism) {\n session.abnormal_mechanism = context.abnormal_mechanism;\n }\n\n if (context.ignoreDuration) {\n session.ignoreDuration = context.ignoreDuration;\n }\n if (context.sid) {\n // Good enough uuid validation. — Kamil\n session.sid = context.sid.length === 32 ? context.sid : uuid4();\n }\n if (context.init !== undefined) {\n session.init = context.init;\n }\n if (!session.did && context.did) {\n session.did = `${context.did}`;\n }\n if (typeof context.started === 'number') {\n session.started = context.started;\n }\n if (session.ignoreDuration) {\n session.duration = undefined;\n } else if (typeof context.duration === 'number') {\n session.duration = context.duration;\n } else {\n const duration = session.timestamp - session.started;\n session.duration = duration >= 0 ? duration : 0;\n }\n if (context.release) {\n session.release = context.release;\n }\n if (context.environment) {\n session.environment = context.environment;\n }\n if (!session.ipAddress && context.ipAddress) {\n session.ipAddress = context.ipAddress;\n }\n if (!session.userAgent && context.userAgent) {\n session.userAgent = context.userAgent;\n }\n if (typeof context.errors === 'number') {\n session.errors = context.errors;\n }\n if (context.status) {\n session.status = context.status;\n }\n}\n\n/**\n * Closes a session by setting its status and updating the session object with it.\n * Internally calls `updateSession` to update the passed session object.\n *\n * Note that this function mutates the passed session (@see updateSession for explanation).\n *\n * @param session the `Session` object to be closed\n * @param status the `SessionStatus` with which the session was closed. If you don't pass a status,\n * this function will keep the previously set status, unless it was `'ok'` in which case\n * it is changed to `'exited'`.\n */\nexport function closeSession(session: Session, status?: Exclude<SessionStatus, 'ok'>): void {\n let context = {};\n if (status) {\n context = { status };\n } else if (session.status === 'ok') {\n context = { status: 'exited' };\n }\n\n updateSession(session, context);\n}\n\n/**\n * Serializes a passed session object to a JSON object with a slightly different structure.\n * This is necessary because the Sentry backend requires a slightly different schema of a session\n * than the one the JS SDKs use internally.\n *\n * @param session the session to be converted\n *\n * @returns a JSON object of the passed session\n */\nfunction sessionToJSON(session: Session): SerializedSession {\n return dropUndefinedKeys({\n sid: `${session.sid}`,\n init: session.init,\n // Make sure that sec is converted to ms for date constructor\n started: new Date(session.started * 1000).toISOString(),\n timestamp: new Date(session.timestamp * 1000).toISOString(),\n status: session.status,\n errors: session.errors,\n did: typeof session.did === 'number' || typeof session.did === 'string' ? `${session.did}` : undefined,\n duration: session.duration,\n abnormal_mechanism: session.abnormal_mechanism,\n attrs: {\n release: session.release,\n environment: session.environment,\n ip_address: session.ipAddress,\n user_agent: session.userAgent,\n },\n });\n}\n", "/* eslint-disable max-lines */\nimport type {\n Attachment,\n Breadcrumb,\n CaptureContext,\n Context,\n Contexts,\n Event,\n EventHint,\n EventProcessor,\n Extra,\n Extras,\n Primitive,\n PropagationContext,\n RequestSession,\n Scope as ScopeInterface,\n ScopeContext,\n Session,\n Severity,\n SeverityLevel,\n Span,\n Transaction,\n User,\n} from '@sentry/types';\nimport { arrayify, dateTimestampInSeconds, isPlainObject, uuid4 } from '@sentry/utils';\n\nimport { getGlobalEventProcessors, notifyEventProcessors } from './eventProcessors';\nimport { updateSession } from './session';\n\n/**\n * Default value for maximum number of breadcrumbs added to an event.\n */\nconst DEFAULT_MAX_BREADCRUMBS = 100;\n\n/**\n * Holds additional event information. {@link Scope.applyToEvent} will be\n * called by the client before an event will be sent.\n */\nexport class Scope implements ScopeInterface {\n /** Flag if notifying is happening. */\n protected _notifyingListeners: boolean;\n\n /** Callback for client to receive scope changes. */\n protected _scopeListeners: Array<(scope: Scope) => void>;\n\n /** Callback list that will be called after {@link applyToEvent}. */\n protected _eventProcessors: EventProcessor[];\n\n /** Array of breadcrumbs. */\n protected _breadcrumbs: Breadcrumb[];\n\n /** User */\n protected _user: User;\n\n /** Tags */\n protected _tags: { [key: string]: Primitive };\n\n /** Extra */\n protected _extra: Extras;\n\n /** Contexts */\n protected _contexts: Contexts;\n\n /** Attachments */\n protected _attachments: Attachment[];\n\n /** Propagation Context for distributed tracing */\n protected _propagationContext: PropagationContext;\n\n /**\n * A place to stash data which is needed at some point in the SDK's event processing pipeline but which shouldn't get\n * sent to Sentry\n */\n protected _sdkProcessingMetadata: { [key: string]: unknown };\n\n /** Fingerprint */\n protected _fingerprint?: string[];\n\n /** Severity */\n // eslint-disable-next-line deprecation/deprecation\n protected _level?: Severity | SeverityLevel;\n\n /** Transaction Name */\n protected _transactionName?: string;\n\n /** Span */\n protected _span?: Span;\n\n /** Session */\n protected _session?: Session;\n\n /** Request Mode Session Status */\n protected _requestSession?: RequestSession;\n\n // NOTE: Any field which gets added here should get added not only to the constructor but also to the `clone` method.\n\n public constructor() {\n this._notifyingListeners = false;\n this._scopeListeners = [];\n this._eventProcessors = [];\n this._breadcrumbs = [];\n this._attachments = [];\n this._user = {};\n this._tags = {};\n this._extra = {};\n this._contexts = {};\n this._sdkProcessingMetadata = {};\n this._propagationContext = generatePropagationContext();\n }\n\n /**\n * Inherit values from the parent scope.\n * @param scope to clone.\n */\n public static clone(scope?: Scope): Scope {\n const newScope = new Scope();\n if (scope) {\n newScope._breadcrumbs = [...scope._breadcrumbs];\n newScope._tags = { ...scope._tags };\n newScope._extra = { ...scope._extra };\n newScope._contexts = { ...scope._contexts };\n newScope._user = scope._user;\n newScope._level = scope._level;\n newScope._span = scope._span;\n newScope._session = scope._session;\n newScope._transactionName = scope._transactionName;\n newScope._fingerprint = scope._fingerprint;\n newScope._eventProcessors = [...scope._eventProcessors];\n newScope._requestSession = scope._requestSession;\n newScope._attachments = [...scope._attachments];\n newScope._sdkProcessingMetadata = { ...scope._sdkProcessingMetadata };\n newScope._propagationContext = { ...scope._propagationContext };\n }\n return newScope;\n }\n\n /**\n * Add internal on change listener. Used for sub SDKs that need to store the scope.\n * @hidden\n */\n public addScopeListener(callback: (scope: Scope) => void): void {\n this._scopeListeners.push(callback);\n }\n\n /**\n * @inheritDoc\n */\n public addEventProcessor(callback: EventProcessor): this {\n this._eventProcessors.push(callback);\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setUser(user: User | null): this {\n this._user = user || {};\n if (this._session) {\n updateSession(this._session, { user });\n }\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getUser(): User | undefined {\n return this._user;\n }\n\n /**\n * @inheritDoc\n */\n public getRequestSession(): RequestSession | undefined {\n return this._requestSession;\n }\n\n /**\n * @inheritDoc\n */\n public setRequestSession(requestSession?: RequestSession): this {\n this._requestSession = requestSession;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTags(tags: { [key: string]: Primitive }): this {\n this._tags = {\n ...this._tags,\n ...tags,\n };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): this {\n this._tags = { ...this._tags, [key]: value };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setExtras(extras: Extras): this {\n this._extra = {\n ...this._extra,\n ...extras,\n };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setExtra(key: string, extra: Extra): this {\n this._extra = { ...this._extra, [key]: extra };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setFingerprint(fingerprint: string[]): this {\n this._fingerprint = fingerprint;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setLevel(\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel,\n ): this {\n this._level = level;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTransactionName(name?: string): this {\n this._transactionName = name;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setContext(key: string, context: Context | null): this {\n if (context === null) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this._contexts[key];\n } else {\n this._contexts[key] = context;\n }\n\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setSpan(span?: Span): this {\n this._span = span;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getSpan(): Span | undefined {\n return this._span;\n }\n\n /**\n * @inheritDoc\n */\n public getTransaction(): Transaction | undefined {\n // Often, this span (if it exists at all) will be a transaction, but it's not guaranteed to be. Regardless, it will\n // have a pointer to the currently-active transaction.\n const span = this.getSpan();\n return span && span.transaction;\n }\n\n /**\n * @inheritDoc\n */\n public setSession(session?: Session): this {\n if (!session) {\n delete this._session;\n } else {\n this._session = session;\n }\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getSession(): Session | undefined {\n return this._session;\n }\n\n /**\n * @inheritDoc\n */\n public update(captureContext?: CaptureContext): this {\n if (!captureContext) {\n return this;\n }\n\n if (typeof captureContext === 'function') {\n const updatedScope = (captureContext as <T>(scope: T) => T)(this);\n return updatedScope instanceof Scope ? updatedScope : this;\n }\n\n if (captureContext instanceof Scope) {\n this._tags = { ...this._tags, ...captureContext._tags };\n this._extra = { ...this._extra, ...captureContext._extra };\n this._contexts = { ...this._contexts, ...captureContext._contexts };\n if (captureContext._user && Object.keys(captureContext._user).length) {\n this._user = captureContext._user;\n }\n if (captureContext._level) {\n this._level = captureContext._level;\n }\n if (captureContext._fingerprint) {\n this._fingerprint = captureContext._fingerprint;\n }\n if (captureContext._requestSession) {\n this._requestSession = captureContext._requestSession;\n }\n if (captureContext._propagationContext) {\n this._propagationContext = captureContext._propagationContext;\n }\n } else if (isPlainObject(captureContext)) {\n // eslint-disable-next-line no-param-reassign\n captureContext = captureContext as ScopeContext;\n this._tags = { ...this._tags, ...captureContext.tags };\n this._extra = { ...this._extra, ...captureContext.extra };\n this._contexts = { ...this._contexts, ...captureContext.contexts };\n if (captureContext.user) {\n this._user = captureContext.user;\n }\n if (captureContext.level) {\n this._level = captureContext.level;\n }\n if (captureContext.fingerprint) {\n this._fingerprint = captureContext.fingerprint;\n }\n if (captureContext.requestSession) {\n this._requestSession = captureContext.requestSession;\n }\n if (captureContext.propagationContext) {\n this._propagationContext = captureContext.propagationContext;\n }\n }\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public clear(): this {\n this._breadcrumbs = [];\n this._tags = {};\n this._extra = {};\n this._user = {};\n this._contexts = {};\n this._level = undefined;\n this._transactionName = undefined;\n this._fingerprint = undefined;\n this._requestSession = undefined;\n this._span = undefined;\n this._session = undefined;\n this._notifyScopeListeners();\n this._attachments = [];\n this._propagationContext = generatePropagationContext();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public addBreadcrumb(breadcrumb: Breadcrumb, maxBreadcrumbs?: number): this {\n const maxCrumbs = typeof maxBreadcrumbs === 'number' ? maxBreadcrumbs : DEFAULT_MAX_BREADCRUMBS;\n\n // No data has been changed, so don't notify scope listeners\n if (maxCrumbs <= 0) {\n return this;\n }\n\n const mergedBreadcrumb = {\n timestamp: dateTimestampInSeconds(),\n ...breadcrumb,\n };\n\n const breadcrumbs = this._breadcrumbs;\n breadcrumbs.push(mergedBreadcrumb);\n this._breadcrumbs = breadcrumbs.length > maxCrumbs ? breadcrumbs.slice(-maxCrumbs) : breadcrumbs;\n\n this._notifyScopeListeners();\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getLastBreadcrumb(): Breadcrumb | undefined {\n return this._breadcrumbs[this._breadcrumbs.length - 1];\n }\n\n /**\n * @inheritDoc\n */\n public clearBreadcrumbs(): this {\n this._breadcrumbs = [];\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public addAttachment(attachment: Attachment): this {\n this._attachments.push(attachment);\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getAttachments(): Attachment[] {\n return this._attachments;\n }\n\n /**\n * @inheritDoc\n */\n public clearAttachments(): this {\n this._attachments = [];\n return this;\n }\n\n /**\n * Applies data from the scope to the event and runs all event processors on it.\n *\n * @param event Event\n * @param hint Object containing additional information about the original exception, for use by the event processors.\n * @hidden\n */\n public applyToEvent(\n event: Event,\n hint: EventHint = {},\n additionalEventProcessors?: EventProcessor[],\n ): PromiseLike<Event | null> {\n if (this._extra && Object.keys(this._extra).length) {\n event.extra = { ...this._extra, ...event.extra };\n }\n if (this._tags && Object.keys(this._tags).length) {\n event.tags = { ...this._tags, ...event.tags };\n }\n if (this._user && Object.keys(this._user).length) {\n event.user = { ...this._user, ...event.user };\n }\n if (this._contexts && Object.keys(this._contexts).length) {\n event.contexts = { ...this._contexts, ...event.contexts };\n }\n if (this._level) {\n event.level = this._level;\n }\n if (this._transactionName) {\n event.transaction = this._transactionName;\n }\n\n // We want to set the trace context for normal events only if there isn't already\n // a trace context on the event. There is a product feature in place where we link\n // errors with transaction and it relies on that.\n if (this._span) {\n event.contexts = { trace: this._span.getTraceContext(), ...event.contexts };\n const transaction = this._span.transaction;\n if (transaction) {\n event.sdkProcessingMetadata = {\n dynamicSamplingContext: transaction.getDynamicSamplingContext(),\n ...event.sdkProcessingMetadata,\n };\n const transactionName = transaction.name;\n if (transactionName) {\n event.tags = { transaction: transactionName, ...event.tags };\n }\n }\n }\n\n this._applyFingerprint(event);\n\n const scopeBreadcrumbs = this._getBreadcrumbs();\n const breadcrumbs = [...(event.breadcrumbs || []), ...scopeBreadcrumbs];\n event.breadcrumbs = breadcrumbs.length > 0 ? breadcrumbs : undefined;\n\n event.sdkProcessingMetadata = {\n ...event.sdkProcessingMetadata,\n ...this._sdkProcessingMetadata,\n propagationContext: this._propagationContext,\n };\n\n // TODO (v8): Update this order to be: Global > Client > Scope\n return notifyEventProcessors(\n [...(additionalEventProcessors || []), ...getGlobalEventProcessors(), ...this._eventProcessors],\n event,\n hint,\n );\n }\n\n /**\n * Add data which will be accessible during event processing but won't get sent to Sentry\n */\n public setSDKProcessingMetadata(newData: { [key: string]: unknown }): this {\n this._sdkProcessingMetadata = { ...this._sdkProcessingMetadata, ...newData };\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setPropagationContext(context: PropagationContext): this {\n this._propagationContext = context;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getPropagationContext(): PropagationContext {\n return this._propagationContext;\n }\n\n /**\n * Get the breadcrumbs for this scope.\n */\n protected _getBreadcrumbs(): Breadcrumb[] {\n return this._breadcrumbs;\n }\n\n /**\n * This will be called on every set call.\n */\n protected _notifyScopeListeners(): void {\n // We need this check for this._notifyingListeners to be able to work on scope during updates\n // If this check is not here we'll produce endless recursion when something is done with the scope\n // during the callback.\n if (!this._notifyingListeners) {\n this._notifyingListeners = true;\n this._scopeListeners.forEach(callback => {\n callback(this);\n });\n this._notifyingListeners = false;\n }\n }\n\n /**\n * Applies fingerprint from the scope to the event if there's one,\n * uses message if there's one instead or get rid of empty fingerprint\n */\n private _applyFingerprint(event: Event): void {\n // Make sure it's an array first and we actually have something in place\n event.fingerprint = event.fingerprint ? arrayify(event.fingerprint) : [];\n\n // If we have something on the scope, then merge it with event\n if (this._fingerprint) {\n event.fingerprint = event.fingerprint.concat(this._fingerprint);\n }\n\n // If we have no data at all, remove empty array default\n if (event.fingerprint && !event.fingerprint.length) {\n delete event.fingerprint;\n }\n }\n}\n\nfunction generatePropagationContext(): PropagationContext {\n return {\n traceId: uuid4(),\n spanId: uuid4().substring(16),\n };\n}\n", "/* eslint-disable max-lines */\nimport type {\n Breadcrumb,\n BreadcrumbHint,\n Client,\n CustomSamplingContext,\n Event,\n EventHint,\n Extra,\n Extras,\n Hub as HubInterface,\n Integration,\n IntegrationClass,\n Primitive,\n Session,\n SessionContext,\n Severity,\n SeverityLevel,\n Transaction,\n TransactionContext,\n User,\n} from '@sentry/types';\nimport { consoleSandbox, dateTimestampInSeconds, getGlobalSingleton, GLOBAL_OBJ, logger, uuid4 } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from './constants';\nimport { Scope } from './scope';\nimport { closeSession, makeSession, updateSession } from './session';\n\n/**\n * API compatibility version of this hub.\n *\n * WARNING: This number should only be increased when the global interface\n * changes and new methods are introduced.\n *\n * @hidden\n */\nexport const API_VERSION = 4;\n\n/**\n * Default maximum number of breadcrumbs added to an event. Can be overwritten\n * with {@link Options.maxBreadcrumbs}.\n */\nconst DEFAULT_BREADCRUMBS = 100;\n\nexport interface RunWithAsyncContextOptions {\n /** Whether to reuse an existing async context if one exists. Defaults to false. */\n reuseExisting?: boolean;\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Strategy used to track async context.\n */\nexport interface AsyncContextStrategy {\n /**\n * Gets the current async context. Returns undefined if there is no current async context.\n */\n getCurrentHub: () => Hub | undefined;\n /**\n * Runs the supplied callback in its own async context.\n */\n runWithAsyncContext<T>(callback: () => T, options: RunWithAsyncContextOptions): T;\n}\n\n/**\n * A layer in the process stack.\n * @hidden\n */\nexport interface Layer {\n client?: Client;\n scope: Scope;\n}\n\n/**\n * An object that contains a hub and maintains a scope stack.\n * @hidden\n */\nexport interface Carrier {\n __SENTRY__?: {\n hub?: Hub;\n acs?: AsyncContextStrategy;\n /**\n * Extra Hub properties injected by various SDKs\n */\n integrations?: Integration[];\n extensions?: {\n /** Extension methods for the hub, which are bound to the current Hub instance */\n // eslint-disable-next-line @typescript-eslint/ban-types\n [key: string]: Function;\n };\n };\n}\n\n/**\n * @inheritDoc\n */\nexport class Hub implements HubInterface {\n /** Is a {@link Layer}[] containing the client and scope */\n private readonly _stack: Layer[];\n\n /** Contains the last event id of a captured event. */\n private _lastEventId?: string;\n\n /**\n * Creates a new instance of the hub, will push one {@link Layer} into the\n * internal stack on creation.\n *\n * @param client bound to the hub.\n * @param scope bound to the hub.\n * @param version number, higher number means higher priority.\n */\n public constructor(client?: Client, scope: Scope = new Scope(), private readonly _version: number = API_VERSION) {\n this._stack = [{ scope }];\n if (client) {\n this.bindClient(client);\n }\n }\n\n /**\n * @inheritDoc\n */\n public isOlderThan(version: number): boolean {\n return this._version < version;\n }\n\n /**\n * @inheritDoc\n */\n public bindClient(client?: Client): void {\n const top = this.getStackTop();\n top.client = client;\n if (client && client.setupIntegrations) {\n client.setupIntegrations();\n }\n }\n\n /**\n * @inheritDoc\n */\n public pushScope(): Scope {\n // We want to clone the content of prev scope\n const scope = Scope.clone(this.getScope());\n this.getStack().push({\n client: this.getClient(),\n scope,\n });\n return scope;\n }\n\n /**\n * @inheritDoc\n */\n public popScope(): boolean {\n if (this.getStack().length <= 1) return false;\n return !!this.getStack().pop();\n }\n\n /**\n * @inheritDoc\n */\n public withScope(callback: (scope: Scope) => void): void {\n const scope = this.pushScope();\n try {\n callback(scope);\n } finally {\n this.popScope();\n }\n }\n\n /**\n * @inheritDoc\n */\n public getClient<C extends Client>(): C | undefined {\n return this.getStackTop().client as C;\n }\n\n /** Returns the scope of the top stack. */\n public getScope(): Scope {\n return this.getStackTop().scope;\n }\n\n /** Returns the scope stack for domains or the process. */\n public getStack(): Layer[] {\n return this._stack;\n }\n\n /** Returns the topmost scope layer in the order domain > local > process. */\n public getStackTop(): Layer {\n return this._stack[this._stack.length - 1];\n }\n\n /**\n * @inheritDoc\n */\n public captureException(exception: unknown, hint?: EventHint): string {\n const eventId = (this._lastEventId = hint && hint.event_id ? hint.event_id : uuid4());\n const syntheticException = new Error('Sentry syntheticException');\n this._withClient((client, scope) => {\n client.captureException(\n exception,\n {\n originalException: exception,\n syntheticException,\n ...hint,\n event_id: eventId,\n },\n scope,\n );\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level?: Severity | SeverityLevel,\n hint?: EventHint,\n ): string {\n const eventId = (this._lastEventId = hint && hint.event_id ? hint.event_id : uuid4());\n const syntheticException = new Error(message);\n this._withClient((client, scope) => {\n client.captureMessage(\n message,\n level,\n {\n originalException: message,\n syntheticException,\n ...hint,\n event_id: eventId,\n },\n scope,\n );\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureEvent(event: Event, hint?: EventHint): string {\n const eventId = hint && hint.event_id ? hint.event_id : uuid4();\n if (!event.type) {\n this._lastEventId = eventId;\n }\n\n this._withClient((client, scope) => {\n client.captureEvent(event, { ...hint, event_id: eventId }, scope);\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public lastEventId(): string | undefined {\n return this._lastEventId;\n }\n\n /**\n * @inheritDoc\n */\n public addBreadcrumb(breadcrumb: Breadcrumb, hint?: BreadcrumbHint): void {\n const { scope, client } = this.getStackTop();\n\n if (!client) return;\n\n const { beforeBreadcrumb = null, maxBreadcrumbs = DEFAULT_BREADCRUMBS } =\n (client.getOptions && client.getOptions()) || {};\n\n if (maxBreadcrumbs <= 0) return;\n\n const timestamp = dateTimestampInSeconds();\n const mergedBreadcrumb = { timestamp, ...breadcrumb };\n const finalBreadcrumb = beforeBreadcrumb\n ? (consoleSandbox(() => beforeBreadcrumb(mergedBreadcrumb, hint)) as Breadcrumb | null)\n : mergedBreadcrumb;\n\n if (finalBreadcrumb === null) return;\n\n if (client.emit) {\n client.emit('beforeAddBreadcrumb', finalBreadcrumb, hint);\n }\n\n scope.addBreadcrumb(finalBreadcrumb, maxBreadcrumbs);\n }\n\n /**\n * @inheritDoc\n */\n public setUser(user: User | null): void {\n this.getScope().setUser(user);\n }\n\n /**\n * @inheritDoc\n */\n public setTags(tags: { [key: string]: Primitive }): void {\n this.getScope().setTags(tags);\n }\n\n /**\n * @inheritDoc\n */\n public setExtras(extras: Extras): void {\n this.getScope().setExtras(extras);\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): void {\n this.getScope().setTag(key, value);\n }\n\n /**\n * @inheritDoc\n */\n public setExtra(key: string, extra: Extra): void {\n this.getScope().setExtra(key, extra);\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public setContext(name: string, context: { [key: string]: any } | null): void {\n this.getScope().setContext(name, context);\n }\n\n /**\n * @inheritDoc\n */\n public configureScope(callback: (scope: Scope) => void): void {\n const { scope, client } = this.getStackTop();\n if (client) {\n callback(scope);\n }\n }\n\n /**\n * @inheritDoc\n */\n public run(callback: (hub: Hub) => void): void {\n const oldHub = makeMain(this);\n try {\n callback(this);\n } finally {\n makeMain(oldHub);\n }\n }\n\n /**\n * @inheritDoc\n */\n public getIntegration<T extends Integration>(integration: IntegrationClass<T>): T | null {\n const client = this.getClient();\n if (!client) return null;\n try {\n return client.getIntegration(integration);\n } catch (_oO) {\n __DEBUG_BUILD__ && logger.warn(`Cannot retrieve integration ${integration.id} from the current Hub`);\n return null;\n }\n }\n\n /**\n * @inheritDoc\n */\n public startTransaction(context: TransactionContext, customSamplingContext?: CustomSamplingContext): Transaction {\n const result = this._callExtensionMethod<Transaction>('startTransaction', context, customSamplingContext);\n\n if (__DEBUG_BUILD__ && !result) {\n const client = this.getClient();\n if (!client) {\n // eslint-disable-next-line no-console\n console.warn(\n \"Tracing extension 'startTransaction' is missing. You should 'init' the SDK before calling 'startTransaction'\",\n );\n } else {\n // eslint-disable-next-line no-console\n console.warn(`Tracing extension 'startTransaction' has not been added. Call 'addTracingExtensions' before calling 'init':\nSentry.addTracingExtensions();\nSentry.init({...});\n`);\n }\n }\n\n return result;\n }\n\n /**\n * @inheritDoc\n */\n public traceHeaders(): { [key: string]: string } {\n return this._callExtensionMethod<{ [key: string]: string }>('traceHeaders');\n }\n\n /**\n * @inheritDoc\n */\n public captureSession(endSession: boolean = false): void {\n // both send the update and pull the session from the scope\n if (endSession) {\n return this.endSession();\n }\n\n // only send the update\n this._sendSessionUpdate();\n }\n\n /**\n * @inheritDoc\n */\n public endSession(): void {\n const layer = this.getStackTop();\n const scope = layer.scope;\n const session = scope.getSession();\n if (session) {\n closeSession(session);\n }\n this._sendSessionUpdate();\n\n // the session is over; take it off of the scope\n scope.setSession();\n }\n\n /**\n * @inheritDoc\n */\n public startSession(context?: SessionContext): Session {\n const { scope, client } = this.getStackTop();\n const { release, environment = DEFAULT_ENVIRONMENT } = (client && client.getOptions()) || {};\n\n // Will fetch userAgent if called from browser sdk\n const { userAgent } = GLOBAL_OBJ.navigator || {};\n\n const session = makeSession({\n release,\n environment,\n user: scope.getUser(),\n ...(userAgent && { userAgent }),\n ...context,\n });\n\n // End existing session if there's one\n const currentSession = scope.getSession && scope.getSession();\n if (currentSession && currentSession.status === 'ok') {\n updateSession(currentSession, { status: 'exited' });\n }\n this.endSession();\n\n // Afterwards we set the new session on the scope\n scope.setSession(session);\n\n return session;\n }\n\n /**\n * Returns if default PII should be sent to Sentry and propagated in ourgoing requests\n * when Tracing is used.\n */\n public shouldSendDefaultPii(): boolean {\n const client = this.getClient();\n const options = client && client.getOptions();\n return Boolean(options && options.sendDefaultPii);\n }\n\n /**\n * Sends the current Session on the scope\n */\n private _sendSessionUpdate(): void {\n const { scope, client } = this.getStackTop();\n\n const session = scope.getSession();\n if (session && client && client.captureSession) {\n client.captureSession(session);\n }\n }\n\n /**\n * Internal helper function to call a method on the top client if it exists.\n *\n * @param method The method to call on the client.\n * @param args Arguments to pass to the client function.\n */\n private _withClient(callback: (client: Client, scope: Scope) => void): void {\n const { scope, client } = this.getStackTop();\n if (client) {\n callback(client, scope);\n }\n }\n\n /**\n * Calls global extension method and binding current instance to the function call\n */\n // @ts-expect-error Function lacks ending return statement and return type does not include 'undefined'. ts(2366)\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private _callExtensionMethod<T>(method: string, ...args: any[]): T {\n const carrier = getMainCarrier();\n const sentry = carrier.__SENTRY__;\n if (sentry && sentry.extensions && typeof sentry.extensions[method] === 'function') {\n return sentry.extensions[method].apply(this, args);\n }\n __DEBUG_BUILD__ && logger.warn(`Extension method ${method} couldn't be found, doing nothing.`);\n }\n}\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nexport function getMainCarrier(): Carrier {\n GLOBAL_OBJ.__SENTRY__ = GLOBAL_OBJ.__SENTRY__ || {\n extensions: {},\n hub: undefined,\n };\n return GLOBAL_OBJ;\n}\n\n/**\n * Replaces the current main hub with the passed one on the global object\n *\n * @returns The old replaced hub\n */\nexport function makeMain(hub: Hub): Hub {\n const registry = getMainCarrier();\n const oldHub = getHubFromCarrier(registry);\n setHubOnCarrier(registry, hub);\n return oldHub;\n}\n\n/**\n * Returns the default hub instance.\n *\n * If a hub is already registered in the global carrier but this module\n * contains a more recent version, it replaces the registered version.\n * Otherwise, the currently registered hub will be returned.\n */\nexport function getCurrentHub(): Hub {\n // Get main carrier (global for every environment)\n const registry = getMainCarrier();\n\n if (registry.__SENTRY__ && registry.__SENTRY__.acs) {\n const hub = registry.__SENTRY__.acs.getCurrentHub();\n\n if (hub) {\n return hub;\n }\n }\n\n // Return hub that lives on a global object\n return getGlobalHub(registry);\n}\n\nfunction getGlobalHub(registry: Carrier = getMainCarrier()): Hub {\n // If there's no hub, or its an old API, assign a new one\n if (!hasHubOnCarrier(registry) || getHubFromCarrier(registry).isOlderThan(API_VERSION)) {\n setHubOnCarrier(registry, new Hub());\n }\n\n // Return hub that lives on a global object\n return getHubFromCarrier(registry);\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * If the carrier does not contain a hub, a new hub is created with the global hub client and scope.\n */\nexport function ensureHubOnCarrier(carrier: Carrier, parent: Hub = getGlobalHub()): void {\n // If there's no hub on current domain, or it's an old API, assign a new one\n if (!hasHubOnCarrier(carrier) || getHubFromCarrier(carrier).isOlderThan(API_VERSION)) {\n const globalHubTopStack = parent.getStackTop();\n setHubOnCarrier(carrier, new Hub(globalHubTopStack.client, Scope.clone(globalHubTopStack.scope)));\n }\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Sets the global async context strategy\n */\nexport function setAsyncContextStrategy(strategy: AsyncContextStrategy | undefined): void {\n // Get main carrier (global for every environment)\n const registry = getMainCarrier();\n registry.__SENTRY__ = registry.__SENTRY__ || {};\n registry.__SENTRY__.acs = strategy;\n}\n\n/**\n * Runs the supplied callback in its own async context. Async Context strategies are defined per SDK.\n *\n * @param callback The callback to run in its own async context\n * @param options Options to pass to the async context strategy\n * @returns The result of the callback\n */\nexport function runWithAsyncContext<T>(callback: () => T, options: RunWithAsyncContextOptions = {}): T {\n const registry = getMainCarrier();\n\n if (registry.__SENTRY__ && registry.__SENTRY__.acs) {\n return registry.__SENTRY__.acs.runWithAsyncContext(callback, options);\n }\n\n // if there was no strategy, fallback to just calling the callback\n return callback();\n}\n\n/**\n * This will tell whether a carrier has a hub on it or not\n * @param carrier object\n */\nfunction hasHubOnCarrier(carrier: Carrier): boolean {\n return !!(carrier && carrier.__SENTRY__ && carrier.__SENTRY__.hub);\n}\n\n/**\n * This will create a new {@link Hub} and add to the passed object on\n * __SENTRY__.hub.\n * @param carrier object\n * @hidden\n */\nexport function getHubFromCarrier(carrier: Carrier): Hub {\n return getGlobalSingleton<Hub>('hub', () => new Hub(), carrier);\n}\n\n/**\n * This will set passed {@link Hub} on the passed object's __SENTRY__.hub attribute\n * @param carrier object\n * @param hub Hub\n * @returns A boolean indicating success or failure\n */\nexport function setHubOnCarrier(carrier: Carrier, hub: Hub): boolean {\n if (!carrier) return false;\n const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n __SENTRY__.hub = hub;\n return true;\n}\n", "import type { Transaction } from '@sentry/types';\n\nimport type { Hub } from '../hub';\nimport { getCurrentHub } from '../hub';\n\n/**\n * The `extractTraceparentData` function and `TRACEPARENT_REGEXP` constant used\n * to be declared in this file. It was later moved into `@sentry/utils` as part of a\n * move to remove `@sentry/tracing` dependencies from `@sentry/node` (`extractTraceparentData`\n * is the only tracing function used by `@sentry/node`).\n *\n * These exports are kept here for backwards compatability's sake.\n *\n * TODO(v7): Reorganize these exports\n *\n * See https://github.com/getsentry/sentry-javascript/issues/4642 for more details.\n */\nexport { TRACEPARENT_REGEXP, extractTraceparentData } from '@sentry/utils';\n\n/** Grabs active transaction off scope, if any */\nexport function getActiveTransaction<T extends Transaction>(maybeHub?: Hub): T | undefined {\n const hub = maybeHub || getCurrentHub();\n const scope = hub.getScope();\n return scope.getTransaction() as T | undefined;\n}\n\n// so it can be used in manual instrumentation without necessitating a hard dependency on @sentry/utils\nexport { stripUrlQueryAndFragment } from '@sentry/utils';\n", "import { addInstrumentationHandler, logger } from '@sentry/utils';\n\nimport type { SpanStatusType } from './span';\nimport { getActiveTransaction } from './utils';\n\nlet errorsInstrumented = false;\n\n/**\n * Configures global error listeners\n */\nexport function registerErrorInstrumentation(): void {\n if (errorsInstrumented) {\n return;\n }\n\n errorsInstrumented = true;\n addInstrumentationHandler('error', errorCallback);\n addInstrumentationHandler('unhandledrejection', errorCallback);\n}\n\n/**\n * If an error or unhandled promise occurs, we mark the active transaction as failed\n */\nfunction errorCallback(): void {\n const activeTransaction = getActiveTransaction();\n if (activeTransaction) {\n const status: SpanStatusType = 'internal_error';\n __DEBUG_BUILD__ && logger.log(`[Tracing] Transaction: ${status} -> Global error occured`);\n activeTransaction.setStatus(status);\n }\n}\n\n// The function name will be lost when bundling but we need to be able to identify this listener later to maintain the\n// node.js default exit behaviour\nerrorCallback.tag = 'sentry_tracingErrorCallback';\n", "/* eslint-disable max-lines */\nimport type {\n Instrumenter,\n Primitive,\n Span as SpanInterface,\n SpanContext,\n SpanOrigin,\n TraceContext,\n Transaction,\n} from '@sentry/types';\nimport { dropUndefinedKeys, generateSentryTraceHeader, logger, timestampInSeconds, uuid4 } from '@sentry/utils';\n\n/**\n * Keeps track of finished spans for a given transaction\n * @internal\n * @hideconstructor\n * @hidden\n */\nexport class SpanRecorder {\n public spans: Span[];\n\n private readonly _maxlen: number;\n\n public constructor(maxlen: number = 1000) {\n this._maxlen = maxlen;\n this.spans = [];\n }\n\n /**\n * This is just so that we don't run out of memory while recording a lot\n * of spans. At some point we just stop and flush out the start of the\n * trace tree (i.e.the first n spans with the smallest\n * start_timestamp).\n */\n public add(span: Span): void {\n if (this.spans.length > this._maxlen) {\n span.spanRecorder = undefined;\n } else {\n this.spans.push(span);\n }\n }\n}\n\n/**\n * Span contains all data about a span\n */\nexport class Span implements SpanInterface {\n /**\n * @inheritDoc\n */\n public traceId: string;\n\n /**\n * @inheritDoc\n */\n public spanId: string;\n\n /**\n * @inheritDoc\n */\n public parentSpanId?: string;\n\n /**\n * Internal keeper of the status\n */\n public status?: SpanStatusType | string;\n\n /**\n * @inheritDoc\n */\n public sampled?: boolean;\n\n /**\n * Timestamp in seconds when the span was created.\n */\n public startTimestamp: number;\n\n /**\n * Timestamp in seconds when the span ended.\n */\n public endTimestamp?: number;\n\n /**\n * @inheritDoc\n */\n public op?: string;\n\n /**\n * @inheritDoc\n */\n public description?: string;\n\n /**\n * @inheritDoc\n */\n public tags: { [key: string]: Primitive };\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public data: { [key: string]: any };\n\n /**\n * List of spans that were finalized\n */\n public spanRecorder?: SpanRecorder;\n\n /**\n * @inheritDoc\n */\n public transaction?: Transaction;\n\n /**\n * The instrumenter that created this span.\n */\n public instrumenter: Instrumenter;\n\n /**\n * The origin of the span, giving context about what created the span.\n */\n public origin?: SpanOrigin;\n\n /**\n * You should never call the constructor manually, always use `Sentry.startTransaction()`\n * or call `startChild()` on an existing span.\n * @internal\n * @hideconstructor\n * @hidden\n */\n public constructor(spanContext: SpanContext = {}) {\n this.traceId = spanContext.traceId || uuid4();\n this.spanId = spanContext.spanId || uuid4().substring(16);\n this.startTimestamp = spanContext.startTimestamp || timestampInSeconds();\n this.tags = spanContext.tags || {};\n this.data = spanContext.data || {};\n this.instrumenter = spanContext.instrumenter || 'sentry';\n this.origin = spanContext.origin || 'manual';\n\n if (spanContext.parentSpanId) {\n this.parentSpanId = spanContext.parentSpanId;\n }\n // We want to include booleans as well here\n if ('sampled' in spanContext) {\n this.sampled = spanContext.sampled;\n }\n if (spanContext.op) {\n this.op = spanContext.op;\n }\n if (spanContext.description) {\n this.description = spanContext.description;\n }\n if (spanContext.name) {\n this.description = spanContext.name;\n }\n if (spanContext.status) {\n this.status = spanContext.status;\n }\n if (spanContext.endTimestamp) {\n this.endTimestamp = spanContext.endTimestamp;\n }\n }\n\n /** An alias for `description` of the Span. */\n public get name(): string {\n return this.description || '';\n }\n /** Update the name of the span. */\n public set name(name: string) {\n this.setName(name);\n }\n\n /**\n * @inheritDoc\n */\n public startChild(\n spanContext?: Pick<SpanContext, Exclude<keyof SpanContext, 'sampled' | 'traceId' | 'parentSpanId'>>,\n ): Span {\n const childSpan = new Span({\n ...spanContext,\n parentSpanId: this.spanId,\n sampled: this.sampled,\n traceId: this.traceId,\n });\n\n childSpan.spanRecorder = this.spanRecorder;\n if (childSpan.spanRecorder) {\n childSpan.spanRecorder.add(childSpan);\n }\n\n childSpan.transaction = this.transaction;\n\n if (__DEBUG_BUILD__ && childSpan.transaction) {\n const opStr = (spanContext && spanContext.op) || '< unknown op >';\n const nameStr = childSpan.transaction.name || '< unknown name >';\n const idStr = childSpan.transaction.spanId;\n\n const logMessage = `[Tracing] Starting '${opStr}' span on transaction '${nameStr}' (${idStr}).`;\n childSpan.transaction.metadata.spanMetadata[childSpan.spanId] = { logMessage };\n logger.log(logMessage);\n }\n\n return childSpan;\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): this {\n this.tags = { ...this.tags, [key]: value };\n return this;\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public setData(key: string, value: any): this {\n this.data = { ...this.data, [key]: value };\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setStatus(value: SpanStatusType): this {\n this.status = value;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setHttpStatus(httpStatus: number): this {\n this.setTag('http.status_code', String(httpStatus));\n this.setData('http.response.status_code', httpStatus);\n const spanStatus = spanStatusfromHttpCode(httpStatus);\n if (spanStatus !== 'unknown_error') {\n this.setStatus(spanStatus);\n }\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setName(name: string): void {\n this.description = name;\n }\n\n /**\n * @inheritDoc\n */\n public isSuccess(): boolean {\n return this.status === 'ok';\n }\n\n /**\n * @inheritDoc\n */\n public finish(endTimestamp?: number): void {\n if (\n __DEBUG_BUILD__ &&\n // Don't call this for transactions\n this.transaction &&\n this.transaction.spanId !== this.spanId\n ) {\n const { logMessage } = this.transaction.metadata.spanMetadata[this.spanId];\n if (logMessage) {\n logger.log((logMessage as string).replace('Starting', 'Finishing'));\n }\n }\n\n this.endTimestamp = typeof endTimestamp === 'number' ? endTimestamp : timestampInSeconds();\n }\n\n /**\n * @inheritDoc\n */\n public toTraceparent(): string {\n return generateSentryTraceHeader(this.traceId, this.spanId, this.sampled);\n }\n\n /**\n * @inheritDoc\n */\n public toContext(): SpanContext {\n return dropUndefinedKeys({\n data: this.data,\n description: this.description,\n endTimestamp: this.endTimestamp,\n op: this.op,\n parentSpanId: this.parentSpanId,\n sampled: this.sampled,\n spanId: this.spanId,\n startTimestamp: this.startTimestamp,\n status: this.status,\n tags: this.tags,\n traceId: this.traceId,\n });\n }\n\n /**\n * @inheritDoc\n */\n public updateWithContext(spanContext: SpanContext): this {\n this.data = spanContext.data || {};\n this.description = spanContext.description;\n this.endTimestamp = spanContext.endTimestamp;\n this.op = spanContext.op;\n this.parentSpanId = spanContext.parentSpanId;\n this.sampled = spanContext.sampled;\n this.spanId = spanContext.spanId || this.spanId;\n this.startTimestamp = spanContext.startTimestamp || this.startTimestamp;\n this.status = spanContext.status;\n this.tags = spanContext.tags || {};\n this.traceId = spanContext.traceId || this.traceId;\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getTraceContext(): TraceContext {\n return dropUndefinedKeys({\n data: Object.keys(this.data).length > 0 ? this.data : undefined,\n description: this.description,\n op: this.op,\n parent_span_id: this.parentSpanId,\n span_id: this.spanId,\n status: this.status,\n tags: Object.keys(this.tags).length > 0 ? this.tags : undefined,\n trace_id: this.traceId,\n });\n }\n\n /**\n * @inheritDoc\n */\n public toJSON(): {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data?: { [key: string]: any };\n description?: string;\n op?: string;\n parent_span_id?: string;\n span_id: string;\n start_timestamp: number;\n status?: string;\n tags?: { [key: string]: Primitive };\n timestamp?: number;\n trace_id: string;\n origin?: SpanOrigin;\n } {\n return dropUndefinedKeys({\n data: Object.keys(this.data).length > 0 ? this.data : undefined,\n description: this.description,\n op: this.op,\n parent_span_id: this.parentSpanId,\n span_id: this.spanId,\n start_timestamp: this.startTimestamp,\n status: this.status,\n tags: Object.keys(this.tags).length > 0 ? this.tags : undefined,\n timestamp: this.endTimestamp,\n trace_id: this.traceId,\n origin: this.origin,\n });\n }\n}\n\nexport type SpanStatusType =\n /** The operation completed successfully. */\n | 'ok'\n /** Deadline expired before operation could complete. */\n | 'deadline_exceeded'\n /** 401 Unauthorized (actually does mean unauthenticated according to RFC 7235) */\n | 'unauthenticated'\n /** 403 Forbidden */\n | 'permission_denied'\n /** 404 Not Found. Some requested entity (file or directory) was not found. */\n | 'not_found'\n /** 429 Too Many Requests */\n | 'resource_exhausted'\n /** Client specified an invalid argument. 4xx. */\n | 'invalid_argument'\n /** 501 Not Implemented */\n | 'unimplemented'\n /** 503 Service Unavailable */\n | 'unavailable'\n /** Other/generic 5xx. */\n | 'internal_error'\n /** Unknown. Any non-standard HTTP status code. */\n | 'unknown_error'\n /** The operation was cancelled (typically by the user). */\n | 'cancelled'\n /** Already exists (409) */\n | 'already_exists'\n /** Operation was rejected because the system is not in a state required for the operation's */\n | 'failed_precondition'\n /** The operation was aborted, typically due to a concurrency issue. */\n | 'aborted'\n /** Operation was attempted past the valid range. */\n | 'out_of_range'\n /** Unrecoverable data loss or corruption */\n | 'data_loss';\n\n/**\n * Converts a HTTP status code into a {@link SpanStatusType}.\n *\n * @param httpStatus The HTTP response status code.\n * @returns The span status or unknown_error.\n */\nexport function spanStatusfromHttpCode(httpStatus: number): SpanStatusType {\n if (httpStatus < 400 && httpStatus >= 100) {\n return 'ok';\n }\n\n if (httpStatus >= 400 && httpStatus < 500) {\n switch (httpStatus) {\n case 401:\n return 'unauthenticated';\n case 403:\n return 'permission_denied';\n case 404:\n return 'not_found';\n case 409:\n return 'already_exists';\n case 413:\n return 'failed_precondition';\n case 429:\n return 'resource_exhausted';\n default:\n return 'invalid_argument';\n }\n }\n\n if (httpStatus >= 500 && httpStatus < 600) {\n switch (httpStatus) {\n case 501:\n return 'unimplemented';\n case 503:\n return 'unavailable';\n case 504:\n return 'deadline_exceeded';\n default:\n return 'internal_error';\n }\n }\n\n return 'unknown_error';\n}\n", "import type { Client, DynamicSamplingContext, Scope } from '@sentry/types';\nimport { dropUndefinedKeys } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from '../constants';\n\n/**\n * Creates a dynamic sampling context from a client.\n *\n * Dispatchs the `createDsc` lifecycle hook as a side effect.\n */\nexport function getDynamicSamplingContextFromClient(\n trace_id: string,\n client: Client,\n scope?: Scope,\n): DynamicSamplingContext {\n const options = client.getOptions();\n\n const { publicKey: public_key } = client.getDsn() || {};\n const { segment: user_segment } = (scope && scope.getUser()) || {};\n\n const dsc = dropUndefinedKeys({\n environment: options.environment || DEFAULT_ENVIRONMENT,\n release: options.release,\n user_segment,\n public_key,\n trace_id,\n }) as DynamicSamplingContext;\n\n client.emit && client.emit('createDsc', dsc);\n\n return dsc;\n}\n", "import type {\n Context,\n Contexts,\n DynamicSamplingContext,\n Measurements,\n MeasurementUnit,\n Transaction as TransactionInterface,\n TransactionContext,\n TransactionEvent,\n TransactionMetadata,\n} from '@sentry/types';\nimport { dropUndefinedKeys, logger } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport { getCurrentHub } from '../hub';\nimport { getDynamicSamplingContextFromClient } from './dynamicSamplingContext';\nimport { Span as SpanClass, SpanRecorder } from './span';\n\n/** JSDoc */\nexport class Transaction extends SpanClass implements TransactionInterface {\n public metadata: TransactionMetadata;\n\n /**\n * The reference to the current hub.\n */\n public _hub: Hub;\n\n private _name: string;\n\n private _measurements: Measurements;\n\n private _contexts: Contexts;\n\n private _trimEnd?: boolean;\n\n private _frozenDynamicSamplingContext: Readonly<Partial<DynamicSamplingContext>> | undefined;\n\n /**\n * This constructor should never be called manually. Those instrumenting tracing should use\n * `Sentry.startTransaction()`, and internal methods should use `hub.startTransaction()`.\n * @internal\n * @hideconstructor\n * @hidden\n */\n public constructor(transactionContext: TransactionContext, hub?: Hub) {\n super(transactionContext);\n // We need to delete description since it's set by the Span class constructor\n // but not needed for transactions.\n delete this.description;\n\n this._measurements = {};\n this._contexts = {};\n\n this._hub = hub || getCurrentHub();\n\n this._name = transactionContext.name || '';\n\n this.metadata = {\n source: 'custom',\n ...transactionContext.metadata,\n spanMetadata: {},\n };\n\n this._trimEnd = transactionContext.trimEnd;\n\n // this is because transactions are also spans, and spans have a transaction pointer\n this.transaction = this;\n\n // If Dynamic Sampling Context is provided during the creation of the transaction, we freeze it as it usually means\n // there is incoming Dynamic Sampling Context. (Either through an incoming request, a baggage meta-tag, or other means)\n const incomingDynamicSamplingContext = this.metadata.dynamicSamplingContext;\n if (incomingDynamicSamplingContext) {\n // We shallow copy this in case anything writes to the original reference of the passed in `dynamicSamplingContext`\n this._frozenDynamicSamplingContext = { ...incomingDynamicSamplingContext };\n }\n }\n\n /** Getter for `name` property */\n public get name(): string {\n return this._name;\n }\n\n /** Setter for `name` property, which also sets `source` as custom */\n public set name(newName: string) {\n this.setName(newName);\n }\n\n /**\n * JSDoc\n */\n public setName(name: string, source: TransactionMetadata['source'] = 'custom'): void {\n this._name = name;\n this.metadata.source = source;\n }\n\n /**\n * Attaches SpanRecorder to the span itself\n * @param maxlen maximum number of spans that can be recorded\n */\n public initSpanRecorder(maxlen: number = 1000): void {\n if (!this.spanRecorder) {\n this.spanRecorder = new SpanRecorder(maxlen);\n }\n this.spanRecorder.add(this);\n }\n\n /**\n * @inheritDoc\n */\n public setContext(key: string, context: Context | null): void {\n if (context === null) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this._contexts[key];\n } else {\n this._contexts[key] = context;\n }\n }\n\n /**\n * @inheritDoc\n */\n public setMeasurement(name: string, value: number, unit: MeasurementUnit = ''): void {\n this._measurements[name] = { value, unit };\n }\n\n /**\n * @inheritDoc\n */\n public setMetadata(newMetadata: Partial<TransactionMetadata>): void {\n this.metadata = { ...this.metadata, ...newMetadata };\n }\n\n /**\n * @inheritDoc\n */\n public finish(endTimestamp?: number): string | undefined {\n const transaction = this._finishTransaction(endTimestamp);\n if (!transaction) {\n return undefined;\n }\n return this._hub.captureEvent(transaction);\n }\n\n /**\n * @inheritDoc\n */\n public toContext(): TransactionContext {\n const spanContext = super.toContext();\n\n return dropUndefinedKeys({\n ...spanContext,\n name: this.name,\n trimEnd: this._trimEnd,\n });\n }\n\n /**\n * @inheritDoc\n */\n public updateWithContext(transactionContext: TransactionContext): this {\n super.updateWithContext(transactionContext);\n\n this.name = transactionContext.name || '';\n\n this._trimEnd = transactionContext.trimEnd;\n\n return this;\n }\n\n /**\n * @inheritdoc\n *\n * @experimental\n */\n public getDynamicSamplingContext(): Readonly<Partial<DynamicSamplingContext>> {\n if (this._frozenDynamicSamplingContext) {\n return this._frozenDynamicSamplingContext;\n }\n\n const hub = this._hub || getCurrentHub();\n const client = hub.getClient();\n\n if (!client) return {};\n\n const scope = hub.getScope();\n const dsc = getDynamicSamplingContextFromClient(this.traceId, client, scope);\n\n const maybeSampleRate = this.metadata.sampleRate;\n if (maybeSampleRate !== undefined) {\n dsc.sample_rate = `${maybeSampleRate}`;\n }\n\n // We don't want to have a transaction name in the DSC if the source is \"url\" because URLs might contain PII\n const source = this.metadata.source;\n if (source && source !== 'url') {\n dsc.transaction = this.name;\n }\n\n if (this.sampled !== undefined) {\n dsc.sampled = String(this.sampled);\n }\n\n // Uncomment if we want to make DSC immutable\n // this._frozenDynamicSamplingContext = dsc;\n\n return dsc;\n }\n\n /**\n * Override the current hub with a new one.\n * Used if you want another hub to finish the transaction.\n *\n * @internal\n */\n public setHub(hub: Hub): void {\n this._hub = hub;\n }\n\n /**\n * Finish the transaction & prepare the event to send to Sentry.\n */\n protected _finishTransaction(endTimestamp?: number): TransactionEvent | undefined {\n // This transaction is already finished, so we should not flush it again.\n if (this.endTimestamp !== undefined) {\n return undefined;\n }\n\n if (!this.name) {\n __DEBUG_BUILD__ && logger.warn('Transaction has no name, falling back to `<unlabeled transaction>`.');\n this.name = '<unlabeled transaction>';\n }\n\n // just sets the end timestamp\n super.finish(endTimestamp);\n\n const client = this._hub.getClient();\n if (client && client.emit) {\n client.emit('finishTransaction', this);\n }\n\n if (this.sampled !== true) {\n // At this point if `sampled !== true` we want to discard the transaction.\n __DEBUG_BUILD__ && logger.log('[Tracing] Discarding transaction because its trace was not chosen to be sampled.');\n\n if (client) {\n client.recordDroppedEvent('sample_rate', 'transaction');\n }\n\n return undefined;\n }\n\n const finishedSpans = this.spanRecorder ? this.spanRecorder.spans.filter(s => s !== this && s.endTimestamp) : [];\n\n if (this._trimEnd && finishedSpans.length > 0) {\n this.endTimestamp = finishedSpans.reduce((prev: SpanClass, current: SpanClass) => {\n if (prev.endTimestamp && current.endTimestamp) {\n return prev.endTimestamp > current.endTimestamp ? prev : current;\n }\n return prev;\n }).endTimestamp;\n }\n\n const metadata = this.metadata;\n\n const transaction: TransactionEvent = {\n contexts: {\n ...this._contexts,\n // We don't want to override trace context\n trace: this.getTraceContext(),\n },\n spans: finishedSpans,\n start_timestamp: this.startTimestamp,\n tags: this.tags,\n timestamp: this.endTimestamp,\n transaction: this.name,\n type: 'transaction',\n sdkProcessingMetadata: {\n ...metadata,\n dynamicSamplingContext: this.getDynamicSamplingContext(),\n },\n ...(metadata.source && {\n transaction_info: {\n source: metadata.source,\n },\n }),\n };\n\n const hasMeasurements = Object.keys(this._measurements).length > 0;\n\n if (hasMeasurements) {\n __DEBUG_BUILD__ &&\n logger.log(\n '[Measurements] Adding measurements to transaction',\n JSON.stringify(this._measurements, undefined, 2),\n );\n transaction.measurements = this._measurements;\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] Finishing ${this.op} transaction: ${this.name}.`);\n\n return transaction;\n }\n}\n", "/* eslint-disable max-lines */\nimport type { TransactionContext } from '@sentry/types';\nimport { logger, timestampInSeconds } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport type { Span } from './span';\nimport { SpanRecorder } from './span';\nimport { Transaction } from './transaction';\n\nexport const TRACING_DEFAULTS = {\n idleTimeout: 1000,\n finalTimeout: 30000,\n heartbeatInterval: 5000,\n};\n\nconst FINISH_REASON_TAG = 'finishReason';\n\nconst IDLE_TRANSACTION_FINISH_REASONS = [\n 'heartbeatFailed',\n 'idleTimeout',\n 'documentHidden',\n 'finalTimeout',\n 'externalFinish',\n 'cancelled',\n];\n\n/**\n * @inheritDoc\n */\nexport class IdleTransactionSpanRecorder extends SpanRecorder {\n public constructor(\n private readonly _pushActivity: (id: string) => void,\n private readonly _popActivity: (id: string) => void,\n public transactionSpanId: string,\n maxlen?: number,\n ) {\n super(maxlen);\n }\n\n /**\n * @inheritDoc\n */\n public add(span: Span): void {\n // We should make sure we do not push and pop activities for\n // the transaction that this span recorder belongs to.\n if (span.spanId !== this.transactionSpanId) {\n // We patch span.finish() to pop an activity after setting an endTimestamp.\n span.finish = (endTimestamp?: number) => {\n span.endTimestamp = typeof endTimestamp === 'number' ? endTimestamp : timestampInSeconds();\n this._popActivity(span.spanId);\n };\n\n // We should only push new activities if the span does not have an end timestamp.\n if (span.endTimestamp === undefined) {\n this._pushActivity(span.spanId);\n }\n }\n\n super.add(span);\n }\n}\n\nexport type BeforeFinishCallback = (transactionSpan: IdleTransaction, endTimestamp: number) => void;\n\n/**\n * An IdleTransaction is a transaction that automatically finishes. It does this by tracking child spans as activities.\n * You can have multiple IdleTransactions active, but if the `onScope` option is specified, the idle transaction will\n * put itself on the scope on creation.\n */\nexport class IdleTransaction extends Transaction {\n // Activities store a list of active spans\n public activities: Record<string, boolean>;\n // Track state of activities in previous heartbeat\n private _prevHeartbeatString: string | undefined;\n\n // Amount of times heartbeat has counted. Will cause transaction to finish after 3 beats.\n private _heartbeatCounter: number;\n\n // We should not use heartbeat if we finished a transaction\n private _finished: boolean;\n\n // Idle timeout was canceled and we should finish the transaction with the last span end.\n private _idleTimeoutCanceledPermanently: boolean;\n\n private readonly _beforeFinishCallbacks: BeforeFinishCallback[];\n\n /**\n * Timer that tracks Transaction idleTimeout\n */\n private _idleTimeoutID: ReturnType<typeof setTimeout> | undefined;\n\n private _finishReason: (typeof IDLE_TRANSACTION_FINISH_REASONS)[number];\n\n public constructor(\n transactionContext: TransactionContext,\n private readonly _idleHub: Hub,\n /**\n * The time to wait in ms until the idle transaction will be finished. This timer is started each time\n * there are no active spans on this transaction.\n */\n private readonly _idleTimeout: number = TRACING_DEFAULTS.idleTimeout,\n /**\n * The final value in ms that a transaction cannot exceed\n */\n private readonly _finalTimeout: number = TRACING_DEFAULTS.finalTimeout,\n private readonly _heartbeatInterval: number = TRACING_DEFAULTS.heartbeatInterval,\n // Whether or not the transaction should put itself on the scope when it starts and pop itself off when it ends\n private readonly _onScope: boolean = false,\n ) {\n super(transactionContext, _idleHub);\n\n this.activities = {};\n this._heartbeatCounter = 0;\n this._finished = false;\n this._idleTimeoutCanceledPermanently = false;\n this._beforeFinishCallbacks = [];\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[4];\n\n if (_onScope) {\n // We set the transaction here on the scope so error events pick up the trace\n // context and attach it to the error.\n __DEBUG_BUILD__ && logger.log(`Setting idle transaction on scope. Span ID: ${this.spanId}`);\n _idleHub.configureScope(scope => scope.setSpan(this));\n }\n\n this._restartIdleTimeout();\n setTimeout(() => {\n if (!this._finished) {\n this.setStatus('deadline_exceeded');\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[3];\n this.finish();\n }\n }, this._finalTimeout);\n }\n\n /** {@inheritDoc} */\n public finish(endTimestamp: number = timestampInSeconds()): string | undefined {\n this._finished = true;\n this.activities = {};\n\n if (this.op === 'ui.action.click') {\n this.setTag(FINISH_REASON_TAG, this._finishReason);\n }\n\n if (this.spanRecorder) {\n __DEBUG_BUILD__ &&\n logger.log('[Tracing] finishing IdleTransaction', new Date(endTimestamp * 1000).toISOString(), this.op);\n\n for (const callback of this._beforeFinishCallbacks) {\n callback(this, endTimestamp);\n }\n\n this.spanRecorder.spans = this.spanRecorder.spans.filter((span: Span) => {\n // If we are dealing with the transaction itself, we just return it\n if (span.spanId === this.spanId) {\n return true;\n }\n\n // We cancel all pending spans with status \"cancelled\" to indicate the idle transaction was finished early\n if (!span.endTimestamp) {\n span.endTimestamp = endTimestamp;\n span.setStatus('cancelled');\n __DEBUG_BUILD__ &&\n logger.log('[Tracing] cancelling span since transaction ended early', JSON.stringify(span, undefined, 2));\n }\n\n const spanStartedBeforeTransactionFinish = span.startTimestamp < endTimestamp;\n\n // Add a delta with idle timeout so that we prevent false positives\n const timeoutWithMarginOfError = (this._finalTimeout + this._idleTimeout) / 1000;\n const spanEndedBeforeFinalTimeout = span.endTimestamp - this.startTimestamp < timeoutWithMarginOfError;\n\n if (__DEBUG_BUILD__) {\n const stringifiedSpan = JSON.stringify(span, undefined, 2);\n if (!spanStartedBeforeTransactionFinish) {\n logger.log('[Tracing] discarding Span since it happened after Transaction was finished', stringifiedSpan);\n } else if (!spanEndedBeforeFinalTimeout) {\n logger.log('[Tracing] discarding Span since it finished after Transaction final timeout', stringifiedSpan);\n }\n }\n\n return spanStartedBeforeTransactionFinish && spanEndedBeforeFinalTimeout;\n });\n\n __DEBUG_BUILD__ && logger.log('[Tracing] flushing IdleTransaction');\n } else {\n __DEBUG_BUILD__ && logger.log('[Tracing] No active IdleTransaction');\n }\n\n // if `this._onScope` is `true`, the transaction put itself on the scope when it started\n if (this._onScope) {\n const scope = this._idleHub.getScope();\n if (scope.getTransaction() === this) {\n scope.setSpan(undefined);\n }\n }\n\n return super.finish(endTimestamp);\n }\n\n /**\n * Register a callback function that gets excecuted before the transaction finishes.\n * Useful for cleanup or if you want to add any additional spans based on current context.\n *\n * This is exposed because users have no other way of running something before an idle transaction\n * finishes.\n */\n public registerBeforeFinishCallback(callback: BeforeFinishCallback): void {\n this._beforeFinishCallbacks.push(callback);\n }\n\n /**\n * @inheritDoc\n */\n public initSpanRecorder(maxlen?: number): void {\n if (!this.spanRecorder) {\n const pushActivity = (id: string): void => {\n if (this._finished) {\n return;\n }\n this._pushActivity(id);\n };\n const popActivity = (id: string): void => {\n if (this._finished) {\n return;\n }\n this._popActivity(id);\n };\n\n this.spanRecorder = new IdleTransactionSpanRecorder(pushActivity, popActivity, this.spanId, maxlen);\n\n // Start heartbeat so that transactions do not run forever.\n __DEBUG_BUILD__ && logger.log('Starting heartbeat');\n this._pingHeartbeat();\n }\n this.spanRecorder.add(this);\n }\n\n /**\n * Cancels the existing idle timeout, if there is one.\n * @param restartOnChildSpanChange Default is `true`.\n * If set to false the transaction will end\n * with the last child span.\n */\n public cancelIdleTimeout(\n endTimestamp?: Parameters<IdleTransaction['finish']>[0],\n {\n restartOnChildSpanChange,\n }: {\n restartOnChildSpanChange?: boolean;\n } = {\n restartOnChildSpanChange: true,\n },\n ): void {\n this._idleTimeoutCanceledPermanently = restartOnChildSpanChange === false;\n if (this._idleTimeoutID) {\n clearTimeout(this._idleTimeoutID);\n this._idleTimeoutID = undefined;\n\n if (Object.keys(this.activities).length === 0 && this._idleTimeoutCanceledPermanently) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[5];\n this.finish(endTimestamp);\n }\n }\n }\n\n /**\n * Temporary method used to externally set the transaction's `finishReason`\n *\n * ** WARNING**\n * This is for the purpose of experimentation only and will be removed in the near future, do not use!\n *\n * @internal\n *\n */\n public setFinishReason(reason: string): void {\n this._finishReason = reason;\n }\n\n /**\n * Restarts idle timeout, if there is no running idle timeout it will start one.\n */\n private _restartIdleTimeout(endTimestamp?: Parameters<IdleTransaction['finish']>[0]): void {\n this.cancelIdleTimeout();\n this._idleTimeoutID = setTimeout(() => {\n if (!this._finished && Object.keys(this.activities).length === 0) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[1];\n this.finish(endTimestamp);\n }\n }, this._idleTimeout);\n }\n\n /**\n * Start tracking a specific activity.\n * @param spanId The span id that represents the activity\n */\n private _pushActivity(spanId: string): void {\n this.cancelIdleTimeout(undefined, { restartOnChildSpanChange: !this._idleTimeoutCanceledPermanently });\n __DEBUG_BUILD__ && logger.log(`[Tracing] pushActivity: ${spanId}`);\n this.activities[spanId] = true;\n __DEBUG_BUILD__ && logger.log('[Tracing] new activities count', Object.keys(this.activities).length);\n }\n\n /**\n * Remove an activity from usage\n * @param spanId The span id that represents the activity\n */\n private _popActivity(spanId: string): void {\n if (this.activities[spanId]) {\n __DEBUG_BUILD__ && logger.log(`[Tracing] popActivity ${spanId}`);\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this.activities[spanId];\n __DEBUG_BUILD__ && logger.log('[Tracing] new activities count', Object.keys(this.activities).length);\n }\n\n if (Object.keys(this.activities).length === 0) {\n const endTimestamp = timestampInSeconds();\n if (this._idleTimeoutCanceledPermanently) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[5];\n this.finish(endTimestamp);\n } else {\n // We need to add the timeout here to have the real endtimestamp of the transaction\n // Remember timestampInSeconds is in seconds, timeout is in ms\n this._restartIdleTimeout(endTimestamp + this._idleTimeout / 1000);\n }\n }\n }\n\n /**\n * Checks when entries of this.activities are not changing for 3 beats.\n * If this occurs we finish the transaction.\n */\n private _beat(): void {\n // We should not be running heartbeat if the idle transaction is finished.\n if (this._finished) {\n return;\n }\n\n const heartbeatString = Object.keys(this.activities).join('');\n\n if (heartbeatString === this._prevHeartbeatString) {\n this._heartbeatCounter++;\n } else {\n this._heartbeatCounter = 1;\n }\n\n this._prevHeartbeatString = heartbeatString;\n\n if (this._heartbeatCounter >= 3) {\n __DEBUG_BUILD__ && logger.log('[Tracing] Transaction finished because of no change for 3 heart beats');\n this.setStatus('deadline_exceeded');\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[0];\n this.finish();\n } else {\n this._pingHeartbeat();\n }\n }\n\n /**\n * Pings the heartbeat\n */\n private _pingHeartbeat(): void {\n __DEBUG_BUILD__ && logger.log(`pinging Heartbeat -> current counter: ${this._heartbeatCounter}`);\n setTimeout(() => {\n this._beat();\n }, this._heartbeatInterval);\n }\n}\n", "import type { Options } from '@sentry/types';\n\nimport { getCurrentHub } from '../hub';\n\n// Treeshakable guard to remove all code related to tracing\ndeclare const __SENTRY_TRACING__: boolean | undefined;\n\n/**\n * Determines if tracing is currently enabled.\n *\n * Tracing is enabled when at least one of `tracesSampleRate` and `tracesSampler` is defined in the SDK config.\n */\nexport function hasTracingEnabled(\n maybeOptions?: Pick<Options, 'tracesSampleRate' | 'tracesSampler' | 'enableTracing'> | undefined,\n): boolean {\n if (typeof __SENTRY_TRACING__ === 'boolean' && !__SENTRY_TRACING__) {\n return false;\n }\n\n const client = getCurrentHub().getClient();\n const options = maybeOptions || (client && client.getOptions());\n return !!options && (options.enableTracing || 'tracesSampleRate' in options || 'tracesSampler' in options);\n}\n", "import type { Options, SamplingContext } from '@sentry/types';\nimport { isNaN, logger } from '@sentry/utils';\n\nimport { hasTracingEnabled } from '../utils/hasTracingEnabled';\nimport type { Transaction } from './transaction';\n\n/**\n * Makes a sampling decision for the given transaction and stores it on the transaction.\n *\n * Called every time a transaction is created. Only transactions which emerge with a `sampled` value of `true` will be\n * sent to Sentry.\n *\n * This method muttes the given `transaction` and will set the `sampled` value on it.\n * It returns the same transaction, for convenience.\n */\nexport function sampleTransaction<T extends Transaction>(\n transaction: T,\n options: Pick<Options, 'tracesSampleRate' | 'tracesSampler' | 'enableTracing'>,\n samplingContext: SamplingContext,\n): T {\n // nothing to do if tracing is not enabled\n if (!hasTracingEnabled(options)) {\n transaction.sampled = false;\n return transaction;\n }\n\n // if the user has forced a sampling decision by passing a `sampled` value in their transaction context, go with that\n if (transaction.sampled !== undefined) {\n transaction.setMetadata({\n sampleRate: Number(transaction.sampled),\n });\n return transaction;\n }\n\n // we would have bailed already if neither `tracesSampler` nor `tracesSampleRate` nor `enableTracing` were defined, so one of these should\n // work; prefer the hook if so\n let sampleRate;\n if (typeof options.tracesSampler === 'function') {\n sampleRate = options.tracesSampler(samplingContext);\n transaction.setMetadata({\n sampleRate: Number(sampleRate),\n });\n } else if (samplingContext.parentSampled !== undefined) {\n sampleRate = samplingContext.parentSampled;\n } else if (typeof options.tracesSampleRate !== 'undefined') {\n sampleRate = options.tracesSampleRate;\n transaction.setMetadata({\n sampleRate: Number(sampleRate),\n });\n } else {\n // When `enableTracing === true`, we use a sample rate of 100%\n sampleRate = 1;\n transaction.setMetadata({\n sampleRate,\n });\n }\n\n // Since this is coming from the user (or from a function provided by the user), who knows what we might get. (The\n // only valid values are booleans or numbers between 0 and 1.)\n if (!isValidSampleRate(sampleRate)) {\n __DEBUG_BUILD__ && logger.warn('[Tracing] Discarding transaction because of invalid sample rate.');\n transaction.sampled = false;\n return transaction;\n }\n\n // if the function returned 0 (or false), or if `tracesSampleRate` is 0, it's a sign the transaction should be dropped\n if (!sampleRate) {\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Discarding transaction because ${\n typeof options.tracesSampler === 'function'\n ? 'tracesSampler returned 0 or false'\n : 'a negative sampling decision was inherited or tracesSampleRate is set to 0'\n }`,\n );\n transaction.sampled = false;\n return transaction;\n }\n\n // Now we roll the dice. Math.random is inclusive of 0, but not of 1, so strict < is safe here. In case sampleRate is\n // a boolean, the < comparison will cause it to be automatically cast to 1 if it's true and 0 if it's false.\n transaction.sampled = Math.random() < (sampleRate as number | boolean);\n\n // if we're not going to keep it, we're done\n if (!transaction.sampled) {\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Discarding transaction because it's not included in the random sample (sampling rate = ${Number(\n sampleRate,\n )})`,\n );\n return transaction;\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] starting ${transaction.op} transaction - ${transaction.name}`);\n return transaction;\n}\n\n/**\n * Checks the given sample rate to make sure it is valid type and value (a boolean, or a number between 0 and 1).\n */\nfunction isValidSampleRate(rate: unknown): boolean {\n // we need to check NaN explicitly because it's of type 'number' and therefore wouldn't get caught by this typecheck\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (isNaN(rate) || !(typeof rate === 'number' || typeof rate === 'boolean')) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `[Tracing] Given sample rate is invalid. Sample rate must be a boolean or a number between 0 and 1. Got ${JSON.stringify(\n rate,\n )} of type ${JSON.stringify(typeof rate)}.`,\n );\n return false;\n }\n\n // in case sampleRate is a boolean, it will get automatically cast to 1 if it's true and 0 if it's false\n if (rate < 0 || rate > 1) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Given sample rate is invalid. Sample rate must be between 0 and 1. Got ${rate}.`);\n return false;\n }\n return true;\n}\n", "import type { ClientOptions, CustomSamplingContext, TransactionContext } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport { getMainCarrier } from '../hub';\nimport { registerErrorInstrumentation } from './errors';\nimport { IdleTransaction } from './idletransaction';\nimport { sampleTransaction } from './sampling';\nimport { Transaction } from './transaction';\n\n/** Returns all trace headers that are currently on the top scope. */\nfunction traceHeaders(this: Hub): { [key: string]: string } {\n const scope = this.getScope();\n const span = scope.getSpan();\n\n return span\n ? {\n 'sentry-trace': span.toTraceparent(),\n }\n : {};\n}\n\n/**\n * Creates a new transaction and adds a sampling decision if it doesn't yet have one.\n *\n * The Hub.startTransaction method delegates to this method to do its work, passing the Hub instance in as `this`, as if\n * it had been called on the hub directly. Exists as a separate function so that it can be injected into the class as an\n * \"extension method.\"\n *\n * @param this: The Hub starting the transaction\n * @param transactionContext: Data used to configure the transaction\n * @param CustomSamplingContext: Optional data to be provided to the `tracesSampler` function (if any)\n *\n * @returns The new transaction\n *\n * @see {@link Hub.startTransaction}\n */\nfunction _startTransaction(\n this: Hub,\n transactionContext: TransactionContext,\n customSamplingContext?: CustomSamplingContext,\n): Transaction {\n const client = this.getClient();\n const options: Partial<ClientOptions> = (client && client.getOptions()) || {};\n\n const configInstrumenter = options.instrumenter || 'sentry';\n const transactionInstrumenter = transactionContext.instrumenter || 'sentry';\n\n if (configInstrumenter !== transactionInstrumenter) {\n __DEBUG_BUILD__ &&\n logger.error(\n `A transaction was started with instrumenter=\\`${transactionInstrumenter}\\`, but the SDK is configured with the \\`${configInstrumenter}\\` instrumenter.\nThe transaction will not be sampled. Please use the ${configInstrumenter} instrumentation to start transactions.`,\n );\n\n transactionContext.sampled = false;\n }\n\n let transaction = new Transaction(transactionContext, this);\n transaction = sampleTransaction(transaction, options, {\n parentSampled: transactionContext.parentSampled,\n transactionContext,\n ...customSamplingContext,\n });\n if (transaction.sampled) {\n transaction.initSpanRecorder(options._experiments && (options._experiments.maxSpans as number));\n }\n if (client && client.emit) {\n client.emit('startTransaction', transaction);\n }\n return transaction;\n}\n\n/**\n * Create new idle transaction.\n */\nexport function startIdleTransaction(\n hub: Hub,\n transactionContext: TransactionContext,\n idleTimeout: number,\n finalTimeout: number,\n onScope?: boolean,\n customSamplingContext?: CustomSamplingContext,\n heartbeatInterval?: number,\n): IdleTransaction {\n const client = hub.getClient();\n const options: Partial<ClientOptions> = (client && client.getOptions()) || {};\n\n let transaction = new IdleTransaction(transactionContext, hub, idleTimeout, finalTimeout, heartbeatInterval, onScope);\n transaction = sampleTransaction(transaction, options, {\n parentSampled: transactionContext.parentSampled,\n transactionContext,\n ...customSamplingContext,\n });\n if (transaction.sampled) {\n transaction.initSpanRecorder(options._experiments && (options._experiments.maxSpans as number));\n }\n if (client && client.emit) {\n client.emit('startTransaction', transaction);\n }\n return transaction;\n}\n\n/**\n * Adds tracing extensions to the global hub.\n */\nexport function addTracingExtensions(): void {\n const carrier = getMainCarrier();\n if (!carrier.__SENTRY__) {\n return;\n }\n carrier.__SENTRY__.extensions = carrier.__SENTRY__.extensions || {};\n if (!carrier.__SENTRY__.extensions.startTransaction) {\n carrier.__SENTRY__.extensions.startTransaction = _startTransaction;\n }\n if (!carrier.__SENTRY__.extensions.traceHeaders) {\n carrier.__SENTRY__.extensions.traceHeaders = traceHeaders;\n }\n\n registerErrorInstrumentation();\n}\n", "import type {\n Breadcrumb,\n CaptureContext,\n CheckIn,\n CustomSamplingContext,\n Event,\n EventHint,\n Extra,\n Extras,\n FinishedCheckIn,\n MonitorConfig,\n Primitive,\n Severity,\n SeverityLevel,\n TransactionContext,\n User,\n} from '@sentry/types';\nimport { isThenable, logger, timestampInSeconds, uuid4 } from '@sentry/utils';\n\nimport type { Hub } from './hub';\nimport { getCurrentHub } from './hub';\nimport type { Scope } from './scope';\n\n// Note: All functions in this file are typed with a return value of `ReturnType<Hub[HUB_FUNCTION]>`,\n// where HUB_FUNCTION is some method on the Hub class.\n//\n// This is done to make sure the top level SDK methods stay in sync with the hub methods.\n// Although every method here has an explicit return type, some of them (that map to void returns) do not\n// contain `return` keywords. This is done to save on bundle size, as `return` is not minifiable.\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception An exception-like object.\n * @param captureContext Additional scope data to apply to exception event.\n * @returns The generated eventId.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\nexport function captureException(exception: any, captureContext?: CaptureContext): ReturnType<Hub['captureException']> {\n return getCurrentHub().captureException(exception, { captureContext });\n}\n\n/**\n * Captures a message event and sends it to Sentry.\n *\n * @param message The message to send to Sentry.\n * @param Severity Define the level of the message.\n * @returns The generated eventId.\n */\nexport function captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n captureContext?: CaptureContext | Severity | SeverityLevel,\n): ReturnType<Hub['captureMessage']> {\n // This is necessary to provide explicit scopes upgrade, without changing the original\n // arity of the `captureMessage(message, level)` method.\n const level = typeof captureContext === 'string' ? captureContext : undefined;\n const context = typeof captureContext !== 'string' ? { captureContext } : undefined;\n return getCurrentHub().captureMessage(message, level, context);\n}\n\n/**\n * Captures a manually created event and sends it to Sentry.\n *\n * @param event The event to send to Sentry.\n * @returns The generated eventId.\n */\nexport function captureEvent(event: Event, hint?: EventHint): ReturnType<Hub['captureEvent']> {\n return getCurrentHub().captureEvent(event, hint);\n}\n\n/**\n * Callback to set context information onto the scope.\n * @param callback Callback function that receives Scope.\n */\nexport function configureScope(callback: (scope: Scope) => void): ReturnType<Hub['configureScope']> {\n getCurrentHub().configureScope(callback);\n}\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on\n * user's actions prior to an error or crash.\n *\n * @param breadcrumb The breadcrumb to record.\n */\nexport function addBreadcrumb(breadcrumb: Breadcrumb): ReturnType<Hub['addBreadcrumb']> {\n getCurrentHub().addBreadcrumb(breadcrumb);\n}\n\n/**\n * Sets context data with the given name.\n * @param name of the context\n * @param context Any kind of data. This data will be normalized.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function setContext(name: string, context: { [key: string]: any } | null): ReturnType<Hub['setContext']> {\n getCurrentHub().setContext(name, context);\n}\n\n/**\n * Set an object that will be merged sent as extra data with the event.\n * @param extras Extras object to merge into current context.\n */\nexport function setExtras(extras: Extras): ReturnType<Hub['setExtras']> {\n getCurrentHub().setExtras(extras);\n}\n\n/**\n * Set key:value that will be sent as extra data with the event.\n * @param key String of extra\n * @param extra Any kind of data. This data will be normalized.\n */\nexport function setExtra(key: string, extra: Extra): ReturnType<Hub['setExtra']> {\n getCurrentHub().setExtra(key, extra);\n}\n\n/**\n * Set an object that will be merged sent as tags data with the event.\n * @param tags Tags context object to merge into current context.\n */\nexport function setTags(tags: { [key: string]: Primitive }): ReturnType<Hub['setTags']> {\n getCurrentHub().setTags(tags);\n}\n\n/**\n * Set key:value that will be sent as tags data with the event.\n *\n * Can also be used to unset a tag, by passing `undefined`.\n *\n * @param key String key of tag\n * @param value Value of tag\n */\nexport function setTag(key: string, value: Primitive): ReturnType<Hub['setTag']> {\n getCurrentHub().setTag(key, value);\n}\n\n/**\n * Updates user context information for future events.\n *\n * @param user User context object to be set in the current context. Pass `null` to unset the user.\n */\nexport function setUser(user: User | null): ReturnType<Hub['setUser']> {\n getCurrentHub().setUser(user);\n}\n\n/**\n * Creates a new scope with and executes the given operation within.\n * The scope is automatically removed once the operation\n * finishes or throws.\n *\n * This is essentially a convenience function for:\n *\n * pushScope();\n * callback();\n * popScope();\n *\n * @param callback that will be enclosed into push/popScope.\n */\nexport function withScope(callback: (scope: Scope) => void): ReturnType<Hub['withScope']> {\n getCurrentHub().withScope(callback);\n}\n\n/**\n * Starts a new `Transaction` and returns it. This is the entry point to manual tracing instrumentation.\n *\n * A tree structure can be built by adding child spans to the transaction, and child spans to other spans. To start a\n * new child span within the transaction or any span, call the respective `.startChild()` method.\n *\n * Every child span must be finished before the transaction is finished, otherwise the unfinished spans are discarded.\n *\n * The transaction must be finished with a call to its `.finish()` method, at which point the transaction with all its\n * finished child spans will be sent to Sentry.\n *\n * NOTE: This function should only be used for *manual* instrumentation. Auto-instrumentation should call\n * `startTransaction` directly on the hub.\n *\n * @param context Properties of the new `Transaction`.\n * @param customSamplingContext Information given to the transaction sampling function (along with context-dependent\n * default values). See {@link Options.tracesSampler}.\n *\n * @returns The transaction which was just started\n */\nexport function startTransaction(\n context: TransactionContext,\n customSamplingContext?: CustomSamplingContext,\n): ReturnType<Hub['startTransaction']> {\n return getCurrentHub().startTransaction({ ...context }, customSamplingContext);\n}\n\n/**\n * Create a cron monitor check in and send it to Sentry.\n *\n * @param checkIn An object that describes a check in.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nexport function captureCheckIn(checkIn: CheckIn, upsertMonitorConfig?: MonitorConfig): string {\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const client = hub.getClient();\n if (!client) {\n __DEBUG_BUILD__ && logger.warn('Cannot capture check-in. No client defined.');\n } else if (!client.captureCheckIn) {\n __DEBUG_BUILD__ && logger.warn('Cannot capture check-in. Client does not support sending check-ins.');\n } else {\n return client.captureCheckIn(checkIn, upsertMonitorConfig, scope);\n }\n\n return uuid4();\n}\n\n/**\n * Wraps a callback with a cron monitor check in. The check in will be sent to Sentry when the callback finishes.\n *\n * @param monitorSlug The distinct slug of the monitor.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nexport function withMonitor<T>(\n monitorSlug: CheckIn['monitorSlug'],\n callback: () => T,\n upsertMonitorConfig?: MonitorConfig,\n): T {\n const checkInId = captureCheckIn({ monitorSlug, status: 'in_progress' }, upsertMonitorConfig);\n const now = timestampInSeconds();\n\n function finishCheckIn(status: FinishedCheckIn['status']): void {\n captureCheckIn({ monitorSlug, status, checkInId, duration: timestampInSeconds() - now });\n }\n\n let maybePromiseResult: T;\n try {\n maybePromiseResult = callback();\n } catch (e) {\n finishCheckIn('error');\n throw e;\n }\n\n if (isThenable(maybePromiseResult)) {\n Promise.resolve(maybePromiseResult).then(\n () => {\n finishCheckIn('ok');\n },\n () => {\n finishCheckIn('error');\n },\n );\n } else {\n finishCheckIn('ok');\n }\n\n return maybePromiseResult;\n}\n\n/**\n * Call `flush()` on the current client, if there is one. See {@link Client.flush}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue. Omitting this parameter will cause\n * the client to wait until all events are sent before resolving the promise.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nexport async function flush(timeout?: number): Promise<boolean> {\n const client = getCurrentHub().getClient();\n if (client) {\n return client.flush(timeout);\n }\n __DEBUG_BUILD__ && logger.warn('Cannot flush events. No client defined.');\n return Promise.resolve(false);\n}\n\n/**\n * Call `close()` on the current client, if there is one. See {@link Client.close}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue before shutting down. Omitting this\n * parameter will cause the client to wait until all events are sent before disabling itself.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nexport async function close(timeout?: number): Promise<boolean> {\n const client = getCurrentHub().getClient();\n if (client) {\n return client.close(timeout);\n }\n __DEBUG_BUILD__ && logger.warn('Cannot flush events and disable SDK. No client defined.');\n return Promise.resolve(false);\n}\n\n/**\n * This is the getter for lastEventId.\n *\n * @returns The last event id of a captured event.\n */\nexport function lastEventId(): string | undefined {\n return getCurrentHub().lastEventId();\n}\n", "import type { ClientOptions, DsnComponents, DsnLike, SdkInfo } from '@sentry/types';\nimport { dsnToString, makeDsn, urlEncode } from '@sentry/utils';\n\nconst SENTRY_API_VERSION = '7';\n\n/** Returns the prefix to construct Sentry ingestion API endpoints. */\nfunction getBaseApiEndpoint(dsn: DsnComponents): string {\n const protocol = dsn.protocol ? `${dsn.protocol}:` : '';\n const port = dsn.port ? `:${dsn.port}` : '';\n return `${protocol}//${dsn.host}${port}${dsn.path ? `/${dsn.path}` : ''}/api/`;\n}\n\n/** Returns the ingest API endpoint for target. */\nfunction _getIngestEndpoint(dsn: DsnComponents): string {\n return `${getBaseApiEndpoint(dsn)}${dsn.projectId}/envelope/`;\n}\n\n/** Returns a URL-encoded string with auth config suitable for a query string. */\nfunction _encodedAuth(dsn: DsnComponents, sdkInfo: SdkInfo | undefined): string {\n return urlEncode({\n // We send only the minimum set of required information. See\n // https://github.com/getsentry/sentry-javascript/issues/2572.\n sentry_key: dsn.publicKey,\n sentry_version: SENTRY_API_VERSION,\n ...(sdkInfo && { sentry_client: `${sdkInfo.name}/${sdkInfo.version}` }),\n });\n}\n\n/**\n * Returns the envelope endpoint URL with auth in the query string.\n *\n * Sending auth as part of the query string and not as custom HTTP headers avoids CORS preflight requests.\n */\nexport function getEnvelopeEndpointWithUrlEncodedAuth(\n dsn: DsnComponents,\n // TODO (v8): Remove `tunnelOrOptions` in favor of `options`, and use the substitute code below\n // options: ClientOptions = {} as ClientOptions,\n tunnelOrOptions: string | ClientOptions = {} as ClientOptions,\n): string {\n // TODO (v8): Use this code instead\n // const { tunnel, _metadata = {} } = options;\n // return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, _metadata.sdk)}`;\n\n const tunnel = typeof tunnelOrOptions === 'string' ? tunnelOrOptions : tunnelOrOptions.tunnel;\n const sdkInfo =\n typeof tunnelOrOptions === 'string' || !tunnelOrOptions._metadata ? undefined : tunnelOrOptions._metadata.sdk;\n\n return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, sdkInfo)}`;\n}\n\n/** Returns the url to the report dialog endpoint. */\nexport function getReportDialogEndpoint(\n dsnLike: DsnLike,\n dialogOptions: {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n user?: { name?: string; email?: string };\n },\n): string {\n const dsn = makeDsn(dsnLike);\n if (!dsn) {\n return '';\n }\n\n const endpoint = `${getBaseApiEndpoint(dsn)}embed/error-page/`;\n\n let encodedOptions = `dsn=${dsnToString(dsn)}`;\n for (const key in dialogOptions) {\n if (key === 'dsn') {\n continue;\n }\n\n if (key === 'user') {\n const user = dialogOptions.user;\n if (!user) {\n continue;\n }\n if (user.name) {\n encodedOptions += `&name=${encodeURIComponent(user.name)}`;\n }\n if (user.email) {\n encodedOptions += `&email=${encodeURIComponent(user.email)}`;\n }\n } else {\n encodedOptions += `&${encodeURIComponent(key)}=${encodeURIComponent(dialogOptions[key] as string)}`;\n }\n }\n\n return `${endpoint}?${encodedOptions}`;\n}\n", "import type {\n DsnComponents,\n Event,\n EventEnvelope,\n EventItem,\n SdkInfo,\n SdkMetadata,\n Session,\n SessionAggregates,\n SessionEnvelope,\n SessionItem,\n} from '@sentry/types';\nimport {\n createEnvelope,\n createEventEnvelopeHeaders,\n dsnToString,\n getSdkMetadataForEnvelopeHeader,\n} from '@sentry/utils';\n\n/**\n * Apply SdkInfo (name, version, packages, integrations) to the corresponding event key.\n * Merge with existing data if any.\n **/\nfunction enhanceEventWithSdkInfo(event: Event, sdkInfo?: SdkInfo): Event {\n if (!sdkInfo) {\n return event;\n }\n event.sdk = event.sdk || {};\n event.sdk.name = event.sdk.name || sdkInfo.name;\n event.sdk.version = event.sdk.version || sdkInfo.version;\n event.sdk.integrations = [...(event.sdk.integrations || []), ...(sdkInfo.integrations || [])];\n event.sdk.packages = [...(event.sdk.packages || []), ...(sdkInfo.packages || [])];\n return event;\n}\n\n/** Creates an envelope from a Session */\nexport function createSessionEnvelope(\n session: Session | SessionAggregates,\n dsn?: DsnComponents,\n metadata?: SdkMetadata,\n tunnel?: string,\n): SessionEnvelope {\n const sdkInfo = getSdkMetadataForEnvelopeHeader(metadata);\n const envelopeHeaders = {\n sent_at: new Date().toISOString(),\n ...(sdkInfo && { sdk: sdkInfo }),\n ...(!!tunnel && dsn && { dsn: dsnToString(dsn) }),\n };\n\n const envelopeItem: SessionItem =\n 'aggregates' in session ? [{ type: 'sessions' }, session] : [{ type: 'session' }, session.toJSON()];\n\n return createEnvelope<SessionEnvelope>(envelopeHeaders, [envelopeItem]);\n}\n\n/**\n * Create an Envelope from an event.\n */\nexport function createEventEnvelope(\n event: Event,\n dsn?: DsnComponents,\n metadata?: SdkMetadata,\n tunnel?: string,\n): EventEnvelope {\n const sdkInfo = getSdkMetadataForEnvelopeHeader(metadata);\n\n /*\n Note: Due to TS, event.type may be `replay_event`, theoretically.\n In practice, we never call `createEventEnvelope` with `replay_event` type,\n and we'd have to adjut a looot of types to make this work properly.\n We want to avoid casting this around, as that could lead to bugs (e.g. when we add another type)\n So the safe choice is to really guard against the replay_event type here.\n */\n const eventType = event.type && event.type !== 'replay_event' ? event.type : 'event';\n\n enhanceEventWithSdkInfo(event, metadata && metadata.sdk);\n\n const envelopeHeaders = createEventEnvelopeHeaders(event, sdkInfo, tunnel, dsn);\n\n // Prevent this data (which, if it exists, was used in earlier steps in the processing pipeline) from being sent to\n // sentry. (Note: Our use of this property comes and goes with whatever we might be debugging, whatever hacks we may\n // have temporarily added, etc. Even if we don't happen to be using it at some point in the future, let's not get rid\n // of this `delete`, lest we miss putting it back in the next time the property is in use.)\n delete event.sdkProcessingMetadata;\n\n const eventItem: EventItem = [{ type: eventType }, event];\n return createEnvelope<EventEnvelope>(envelopeHeaders, [eventItem]);\n}\n", "import type { Client, Event, EventHint, Integration, Options } from '@sentry/types';\nimport { arrayify, logger } from '@sentry/utils';\n\nimport { addGlobalEventProcessor } from './eventProcessors';\nimport { getCurrentHub } from './hub';\n\ndeclare module '@sentry/types' {\n interface Integration {\n isDefaultInstance?: boolean;\n }\n}\n\nexport const installedIntegrations: string[] = [];\n\n/** Map of integrations assigned to a client */\nexport type IntegrationIndex = {\n [key: string]: Integration;\n};\n\n/**\n * Remove duplicates from the given array, preferring the last instance of any duplicate. Not guaranteed to\n * preseve the order of integrations in the array.\n *\n * @private\n */\nfunction filterDuplicates(integrations: Integration[]): Integration[] {\n const integrationsByName: { [key: string]: Integration } = {};\n\n integrations.forEach(currentInstance => {\n const { name } = currentInstance;\n\n const existingInstance = integrationsByName[name];\n\n // We want integrations later in the array to overwrite earlier ones of the same type, except that we never want a\n // default instance to overwrite an existing user instance\n if (existingInstance && !existingInstance.isDefaultInstance && currentInstance.isDefaultInstance) {\n return;\n }\n\n integrationsByName[name] = currentInstance;\n });\n\n return Object.keys(integrationsByName).map(k => integrationsByName[k]);\n}\n\n/** Gets integrations to install */\nexport function getIntegrationsToSetup(options: Options): Integration[] {\n const defaultIntegrations = options.defaultIntegrations || [];\n const userIntegrations = options.integrations;\n\n // We flag default instances, so that later we can tell them apart from any user-created instances of the same class\n defaultIntegrations.forEach(integration => {\n integration.isDefaultInstance = true;\n });\n\n let integrations: Integration[];\n\n if (Array.isArray(userIntegrations)) {\n integrations = [...defaultIntegrations, ...userIntegrations];\n } else if (typeof userIntegrations === 'function') {\n integrations = arrayify(userIntegrations(defaultIntegrations));\n } else {\n integrations = defaultIntegrations;\n }\n\n const finalIntegrations = filterDuplicates(integrations);\n\n // The `Debug` integration prints copies of the `event` and `hint` which will be passed to `beforeSend` or\n // `beforeSendTransaction`. It therefore has to run after all other integrations, so that the changes of all event\n // processors will be reflected in the printed values. For lack of a more elegant way to guarantee that, we therefore\n // locate it and, assuming it exists, pop it out of its current spot and shove it onto the end of the array.\n const debugIndex = findIndex(finalIntegrations, integration => integration.name === 'Debug');\n if (debugIndex !== -1) {\n const [debugInstance] = finalIntegrations.splice(debugIndex, 1);\n finalIntegrations.push(debugInstance);\n }\n\n return finalIntegrations;\n}\n\n/**\n * Given a list of integration instances this installs them all. When `withDefaults` is set to `true` then all default\n * integrations are added unless they were already provided before.\n * @param integrations array of integration instances\n * @param withDefault should enable default integrations\n */\nexport function setupIntegrations(client: Client, integrations: Integration[]): IntegrationIndex {\n const integrationIndex: IntegrationIndex = {};\n\n integrations.forEach(integration => {\n // guard against empty provided integrations\n if (integration) {\n setupIntegration(client, integration, integrationIndex);\n }\n });\n\n return integrationIndex;\n}\n\n/** Setup a single integration. */\nexport function setupIntegration(client: Client, integration: Integration, integrationIndex: IntegrationIndex): void {\n integrationIndex[integration.name] = integration;\n\n if (installedIntegrations.indexOf(integration.name) === -1) {\n integration.setupOnce(addGlobalEventProcessor, getCurrentHub);\n installedIntegrations.push(integration.name);\n }\n\n if (client.on && typeof integration.preprocessEvent === 'function') {\n const callback = integration.preprocessEvent.bind(integration) as typeof integration.preprocessEvent;\n client.on('preprocessEvent', (event, hint) => callback(event, hint, client));\n }\n\n if (client.addEventProcessor && typeof integration.processEvent === 'function') {\n const callback = integration.processEvent.bind(integration) as typeof integration.processEvent;\n\n const processor = Object.assign((event: Event, hint: EventHint) => callback(event, hint, client), {\n id: integration.name,\n });\n\n client.addEventProcessor(processor);\n }\n\n __DEBUG_BUILD__ && logger.log(`Integration installed: ${integration.name}`);\n}\n\n/** Add an integration to the current hub's client. */\nexport function addIntegration(integration: Integration): void {\n const client = getCurrentHub().getClient();\n\n if (!client || !client.addIntegration) {\n __DEBUG_BUILD__ && logger.warn(`Cannot add integration \"${integration.name}\" because no SDK Client is available.`);\n return;\n }\n\n client.addIntegration(integration);\n}\n\n// Polyfill for Array.findIndex(), which is not supported in ES5\nfunction findIndex<T>(arr: T[], callback: (item: T) => boolean): number {\n for (let i = 0; i < arr.length; i++) {\n if (callback(arr[i]) === true) {\n return i;\n }\n }\n\n return -1;\n}\n", "import type { Client, ClientOptions, Event, EventHint, StackFrame, StackParser } from '@sentry/types';\nimport { dateTimestampInSeconds, GLOBAL_OBJ, normalize, resolvedSyncPromise, truncate, uuid4 } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from '../constants';\nimport { getGlobalEventProcessors, notifyEventProcessors } from '../eventProcessors';\nimport { Scope } from '../scope';\n\n/**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * Note: This also triggers callbacks for `addGlobalEventProcessor`, but not `beforeSend`.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n * @hidden\n */\nexport function prepareEvent(\n options: ClientOptions,\n event: Event,\n hint: EventHint,\n scope?: Scope,\n client?: Client,\n): PromiseLike<Event | null> {\n const { normalizeDepth = 3, normalizeMaxBreadth = 1_000 } = options;\n const prepared: Event = {\n ...event,\n event_id: event.event_id || hint.event_id || uuid4(),\n timestamp: event.timestamp || dateTimestampInSeconds(),\n };\n const integrations = hint.integrations || options.integrations.map(i => i.name);\n\n applyClientOptions(prepared, options);\n applyIntegrationsMetadata(prepared, integrations);\n\n // Only put debug IDs onto frames for error events.\n if (event.type === undefined) {\n applyDebugIds(prepared, options.stackParser);\n }\n\n // If we have scope given to us, use it as the base for further modifications.\n // This allows us to prevent unnecessary copying of data if `captureContext` is not provided.\n let finalScope = scope;\n if (hint.captureContext) {\n finalScope = Scope.clone(finalScope).update(hint.captureContext);\n }\n\n // We prepare the result here with a resolved Event.\n let result = resolvedSyncPromise<Event | null>(prepared);\n\n const clientEventProcessors = client && client.getEventProcessors ? client.getEventProcessors() : [];\n\n // This should be the last thing called, since we want that\n // {@link Hub.addEventProcessor} gets the finished prepared event.\n //\n // We need to check for the existence of `finalScope.getAttachments`\n // because `getAttachments` can be undefined if users are using an older version\n // of `@sentry/core` that does not have the `getAttachments` method.\n // See: https://github.com/getsentry/sentry-javascript/issues/5229\n if (finalScope) {\n // Collect attachments from the hint and scope\n if (finalScope.getAttachments) {\n const attachments = [...(hint.attachments || []), ...finalScope.getAttachments()];\n\n if (attachments.length) {\n hint.attachments = attachments;\n }\n }\n\n // In case we have a hub we reassign it.\n result = finalScope.applyToEvent(prepared, hint, clientEventProcessors);\n } else {\n // Apply client & global event processors even if there is no scope\n // TODO (v8): Update the order to be Global > Client\n result = notifyEventProcessors([...clientEventProcessors, ...getGlobalEventProcessors()], prepared, hint);\n }\n\n return result.then(evt => {\n if (evt) {\n // We apply the debug_meta field only after all event processors have ran, so that if any event processors modified\n // file names (e.g.the RewriteFrames integration) the filename -> debug ID relationship isn't destroyed.\n // This should not cause any PII issues, since we're only moving data that is already on the event and not adding\n // any new data\n applyDebugMeta(evt);\n }\n\n if (typeof normalizeDepth === 'number' && normalizeDepth > 0) {\n return normalizeEvent(evt, normalizeDepth, normalizeMaxBreadth);\n }\n return evt;\n });\n}\n\n/**\n * Enhances event using the client configuration.\n * It takes care of all \"static\" values like environment, release and `dist`,\n * as well as truncating overly long values.\n * @param event event instance to be enhanced\n */\nfunction applyClientOptions(event: Event, options: ClientOptions): void {\n const { environment, release, dist, maxValueLength = 250 } = options;\n\n if (!('environment' in event)) {\n event.environment = 'environment' in options ? environment : DEFAULT_ENVIRONMENT;\n }\n\n if (event.release === undefined && release !== undefined) {\n event.release = release;\n }\n\n if (event.dist === undefined && dist !== undefined) {\n event.dist = dist;\n }\n\n if (event.message) {\n event.message = truncate(event.message, maxValueLength);\n }\n\n const exception = event.exception && event.exception.values && event.exception.values[0];\n if (exception && exception.value) {\n exception.value = truncate(exception.value, maxValueLength);\n }\n\n const request = event.request;\n if (request && request.url) {\n request.url = truncate(request.url, maxValueLength);\n }\n}\n\nconst debugIdStackParserCache = new WeakMap<StackParser, Map<string, StackFrame[]>>();\n\n/**\n * Puts debug IDs into the stack frames of an error event.\n */\nexport function applyDebugIds(event: Event, stackParser: StackParser): void {\n const debugIdMap = GLOBAL_OBJ._sentryDebugIds;\n\n if (!debugIdMap) {\n return;\n }\n\n let debugIdStackFramesCache: Map<string, StackFrame[]>;\n const cachedDebugIdStackFrameCache = debugIdStackParserCache.get(stackParser);\n if (cachedDebugIdStackFrameCache) {\n debugIdStackFramesCache = cachedDebugIdStackFrameCache;\n } else {\n debugIdStackFramesCache = new Map<string, StackFrame[]>();\n debugIdStackParserCache.set(stackParser, debugIdStackFramesCache);\n }\n\n // Build a map of filename -> debug_id\n const filenameDebugIdMap = Object.keys(debugIdMap).reduce<Record<string, string>>((acc, debugIdStackTrace) => {\n let parsedStack: StackFrame[];\n const cachedParsedStack = debugIdStackFramesCache.get(debugIdStackTrace);\n if (cachedParsedStack) {\n parsedStack = cachedParsedStack;\n } else {\n parsedStack = stackParser(debugIdStackTrace);\n debugIdStackFramesCache.set(debugIdStackTrace, parsedStack);\n }\n\n for (let i = parsedStack.length - 1; i >= 0; i--) {\n const stackFrame = parsedStack[i];\n if (stackFrame.filename) {\n acc[stackFrame.filename] = debugIdMap[debugIdStackTrace];\n break;\n }\n }\n return acc;\n }, {});\n\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n event!.exception!.values!.forEach(exception => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n exception.stacktrace!.frames!.forEach(frame => {\n if (frame.filename) {\n frame.debug_id = filenameDebugIdMap[frame.filename];\n }\n });\n });\n } catch (e) {\n // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n }\n}\n\n/**\n * Moves debug IDs from the stack frames of an error event into the debug_meta field.\n */\nexport function applyDebugMeta(event: Event): void {\n // Extract debug IDs and filenames from the stack frames on the event.\n const filenameDebugIdMap: Record<string, string> = {};\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n event.exception!.values!.forEach(exception => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n exception.stacktrace!.frames!.forEach(frame => {\n if (frame.debug_id) {\n if (frame.abs_path) {\n filenameDebugIdMap[frame.abs_path] = frame.debug_id;\n } else if (frame.filename) {\n filenameDebugIdMap[frame.filename] = frame.debug_id;\n }\n delete frame.debug_id;\n }\n });\n });\n } catch (e) {\n // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n }\n\n if (Object.keys(filenameDebugIdMap).length === 0) {\n return;\n }\n\n // Fill debug_meta information\n event.debug_meta = event.debug_meta || {};\n event.debug_meta.images = event.debug_meta.images || [];\n const images = event.debug_meta.images;\n Object.keys(filenameDebugIdMap).forEach(filename => {\n images.push({\n type: 'sourcemap',\n code_file: filename,\n debug_id: filenameDebugIdMap[filename],\n });\n });\n}\n\n/**\n * This function adds all used integrations to the SDK info in the event.\n * @param event The event that will be filled with all integrations.\n */\nfunction applyIntegrationsMetadata(event: Event, integrationNames: string[]): void {\n if (integrationNames.length > 0) {\n event.sdk = event.sdk || {};\n event.sdk.integrations = [...(event.sdk.integrations || []), ...integrationNames];\n }\n}\n\n/**\n * Applies `normalize` function on necessary `Event` attributes to make them safe for serialization.\n * Normalized keys:\n * - `breadcrumbs.data`\n * - `user`\n * - `contexts`\n * - `extra`\n * @param event Event\n * @returns Normalized event\n */\nfunction normalizeEvent(event: Event | null, depth: number, maxBreadth: number): Event | null {\n if (!event) {\n return null;\n }\n\n const normalized: Event = {\n ...event,\n ...(event.breadcrumbs && {\n breadcrumbs: event.breadcrumbs.map(b => ({\n ...b,\n ...(b.data && {\n data: normalize(b.data, depth, maxBreadth),\n }),\n })),\n }),\n ...(event.user && {\n user: normalize(event.user, depth, maxBreadth),\n }),\n ...(event.contexts && {\n contexts: normalize(event.contexts, depth, maxBreadth),\n }),\n ...(event.extra && {\n extra: normalize(event.extra, depth, maxBreadth),\n }),\n };\n\n // event.contexts.trace stores information about a Transaction. Similarly,\n // event.spans[] stores information about child Spans. Given that a\n // Transaction is conceptually a Span, normalization should apply to both\n // Transactions and Spans consistently.\n // For now the decision is to skip normalization of Transactions and Spans,\n // so this block overwrites the normalized event to add back the original\n // Transaction information prior to normalization.\n if (event.contexts && event.contexts.trace && normalized.contexts) {\n normalized.contexts.trace = event.contexts.trace;\n\n // event.contexts.trace.data may contain circular/dangerous data so we need to normalize it\n if (event.contexts.trace.data) {\n normalized.contexts.trace.data = normalize(event.contexts.trace.data, depth, maxBreadth);\n }\n }\n\n // event.spans[].data may contain circular/dangerous data so we need to normalize it\n if (event.spans) {\n normalized.spans = event.spans.map(span => {\n // We cannot use the spread operator here because `toJSON` on `span` is non-enumerable\n if (span.data) {\n span.data = normalize(span.data, depth, maxBreadth);\n }\n return span;\n });\n }\n\n return normalized;\n}\n", "/* eslint-disable max-lines */\nimport type {\n Breadcrumb,\n BreadcrumbHint,\n Client,\n ClientOptions,\n DataCategory,\n DsnComponents,\n DynamicSamplingContext,\n Envelope,\n ErrorEvent,\n Event,\n EventDropReason,\n EventHint,\n EventProcessor,\n Integration,\n IntegrationClass,\n Outcome,\n PropagationContext,\n SdkMetadata,\n Session,\n SessionAggregates,\n Severity,\n SeverityLevel,\n Transaction,\n TransactionEvent,\n Transport,\n TransportMakeRequestResponse,\n} from '@sentry/types';\nimport {\n addItemToEnvelope,\n checkOrSetAlreadyCaught,\n createAttachmentEnvelopeItem,\n isPlainObject,\n isPrimitive,\n isThenable,\n logger,\n makeDsn,\n rejectedSyncPromise,\n resolvedSyncPromise,\n SentryError,\n SyncPromise,\n} from '@sentry/utils';\n\nimport { getEnvelopeEndpointWithUrlEncodedAuth } from './api';\nimport { createEventEnvelope, createSessionEnvelope } from './envelope';\nimport type { IntegrationIndex } from './integration';\nimport { setupIntegration, setupIntegrations } from './integration';\nimport type { Scope } from './scope';\nimport { updateSession } from './session';\nimport { getDynamicSamplingContextFromClient } from './tracing/dynamicSamplingContext';\nimport { prepareEvent } from './utils/prepareEvent';\n\nconst ALREADY_SEEN_ERROR = \"Not capturing exception because it's already been captured.\";\n\n/**\n * Base implementation for all JavaScript SDK clients.\n *\n * Call the constructor with the corresponding options\n * specific to the client subclass. To access these options later, use\n * {@link Client.getOptions}.\n *\n * If a Dsn is specified in the options, it will be parsed and stored. Use\n * {@link Client.getDsn} to retrieve the Dsn at any moment. In case the Dsn is\n * invalid, the constructor will throw a {@link SentryException}. Note that\n * without a valid Dsn, the SDK will not send any events to Sentry.\n *\n * Before sending an event, it is passed through\n * {@link BaseClient._prepareEvent} to add SDK information and scope data\n * (breadcrumbs and context). To add more custom information, override this\n * method and extend the resulting prepared event.\n *\n * To issue automatically created events (e.g. via instrumentation), use\n * {@link Client.captureEvent}. It will prepare the event and pass it through\n * the callback lifecycle. To issue auto-breadcrumbs, use\n * {@link Client.addBreadcrumb}.\n *\n * @example\n * class NodeClient extends BaseClient<NodeOptions> {\n * public constructor(options: NodeOptions) {\n * super(options);\n * }\n *\n * // ...\n * }\n */\nexport abstract class BaseClient<O extends ClientOptions> implements Client<O> {\n /** Options passed to the SDK. */\n protected readonly _options: O;\n\n /** The client Dsn, if specified in options. Without this Dsn, the SDK will be disabled. */\n protected readonly _dsn?: DsnComponents;\n\n protected readonly _transport?: Transport;\n\n /** Array of set up integrations. */\n protected _integrations: IntegrationIndex;\n\n /** Indicates whether this client's integrations have been set up. */\n protected _integrationsInitialized: boolean;\n\n /** Number of calls being processed */\n protected _numProcessing: number;\n\n /** Holds flushable */\n private _outcomes: { [key: string]: number };\n\n // eslint-disable-next-line @typescript-eslint/ban-types\n private _hooks: Record<string, Function[]>;\n\n private _eventProcessors: EventProcessor[];\n\n /**\n * Initializes this client instance.\n *\n * @param options Options for the client.\n */\n protected constructor(options: O) {\n this._options = options;\n this._integrations = {};\n this._integrationsInitialized = false;\n this._numProcessing = 0;\n this._outcomes = {};\n this._hooks = {};\n this._eventProcessors = [];\n\n if (options.dsn) {\n this._dsn = makeDsn(options.dsn);\n } else {\n __DEBUG_BUILD__ && logger.warn('No DSN provided, client will not send events.');\n }\n\n if (this._dsn) {\n const url = getEnvelopeEndpointWithUrlEncodedAuth(this._dsn, options);\n this._transport = options.transport({\n recordDroppedEvent: this.recordDroppedEvent.bind(this),\n ...options.transportOptions,\n url,\n });\n }\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public captureException(exception: any, hint?: EventHint, scope?: Scope): string | undefined {\n // ensure we haven't captured this very object before\n if (checkOrSetAlreadyCaught(exception)) {\n __DEBUG_BUILD__ && logger.log(ALREADY_SEEN_ERROR);\n return;\n }\n\n let eventId: string | undefined = hint && hint.event_id;\n\n this._process(\n this.eventFromException(exception, hint)\n .then(event => this._captureEvent(event, hint, scope))\n .then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level?: Severity | SeverityLevel,\n hint?: EventHint,\n scope?: Scope,\n ): string | undefined {\n let eventId: string | undefined = hint && hint.event_id;\n\n const promisedEvent = isPrimitive(message)\n ? this.eventFromMessage(String(message), level, hint)\n : this.eventFromException(message, hint);\n\n this._process(\n promisedEvent\n .then(event => this._captureEvent(event, hint, scope))\n .then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureEvent(event: Event, hint?: EventHint, scope?: Scope): string | undefined {\n // ensure we haven't captured this very object before\n if (hint && hint.originalException && checkOrSetAlreadyCaught(hint.originalException)) {\n __DEBUG_BUILD__ && logger.log(ALREADY_SEEN_ERROR);\n return;\n }\n\n let eventId: string | undefined = hint && hint.event_id;\n\n this._process(\n this._captureEvent(event, hint, scope).then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureSession(session: Session): void {\n if (!(typeof session.release === 'string')) {\n __DEBUG_BUILD__ && logger.warn('Discarded session because of missing or non-string release');\n } else {\n this.sendSession(session);\n // After sending, we set init false to indicate it's not the first occurrence\n updateSession(session, { init: false });\n }\n }\n\n /**\n * @inheritDoc\n */\n public getDsn(): DsnComponents | undefined {\n return this._dsn;\n }\n\n /**\n * @inheritDoc\n */\n public getOptions(): O {\n return this._options;\n }\n\n /**\n * @see SdkMetadata in @sentry/types\n *\n * @return The metadata of the SDK\n */\n public getSdkMetadata(): SdkMetadata | undefined {\n return this._options._metadata;\n }\n\n /**\n * @inheritDoc\n */\n public getTransport(): Transport | undefined {\n return this._transport;\n }\n\n /**\n * @inheritDoc\n */\n public flush(timeout?: number): PromiseLike<boolean> {\n const transport = this._transport;\n if (transport) {\n return this._isClientDoneProcessing(timeout).then(clientFinished => {\n return transport.flush(timeout).then(transportFlushed => clientFinished && transportFlushed);\n });\n } else {\n return resolvedSyncPromise(true);\n }\n }\n\n /**\n * @inheritDoc\n */\n public close(timeout?: number): PromiseLike<boolean> {\n return this.flush(timeout).then(result => {\n this.getOptions().enabled = false;\n return result;\n });\n }\n\n /** Get all installed event processors. */\n public getEventProcessors(): EventProcessor[] {\n return this._eventProcessors;\n }\n\n /** @inheritDoc */\n public addEventProcessor(eventProcessor: EventProcessor): void {\n this._eventProcessors.push(eventProcessor);\n }\n\n /**\n * Sets up the integrations\n */\n public setupIntegrations(forceInitialize?: boolean): void {\n if ((forceInitialize && !this._integrationsInitialized) || (this._isEnabled() && !this._integrationsInitialized)) {\n this._integrations = setupIntegrations(this, this._options.integrations);\n this._integrationsInitialized = true;\n }\n }\n\n /**\n * Gets an installed integration by its `id`.\n *\n * @returns The installed integration or `undefined` if no integration with that `id` was installed.\n */\n public getIntegrationById(integrationId: string): Integration | undefined {\n return this._integrations[integrationId];\n }\n\n /**\n * @inheritDoc\n */\n public getIntegration<T extends Integration>(integration: IntegrationClass<T>): T | null {\n try {\n return (this._integrations[integration.id] as T) || null;\n } catch (_oO) {\n __DEBUG_BUILD__ && logger.warn(`Cannot retrieve integration ${integration.id} from the current Client`);\n return null;\n }\n }\n\n /**\n * @inheritDoc\n */\n public addIntegration(integration: Integration): void {\n setupIntegration(this, integration, this._integrations);\n }\n\n /**\n * @inheritDoc\n */\n public sendEvent(event: Event, hint: EventHint = {}): void {\n this.emit('beforeSendEvent', event, hint);\n\n let env = createEventEnvelope(event, this._dsn, this._options._metadata, this._options.tunnel);\n\n for (const attachment of hint.attachments || []) {\n env = addItemToEnvelope(\n env,\n createAttachmentEnvelopeItem(\n attachment,\n this._options.transportOptions && this._options.transportOptions.textEncoder,\n ),\n );\n }\n\n const promise = this._sendEnvelope(env);\n if (promise) {\n promise.then(sendResponse => this.emit('afterSendEvent', event, sendResponse), null);\n }\n }\n\n /**\n * @inheritDoc\n */\n public sendSession(session: Session | SessionAggregates): void {\n const env = createSessionEnvelope(session, this._dsn, this._options._metadata, this._options.tunnel);\n void this._sendEnvelope(env);\n }\n\n /**\n * @inheritDoc\n */\n public recordDroppedEvent(reason: EventDropReason, category: DataCategory, _event?: Event): void {\n // Note: we use `event` in replay, where we overwrite this hook.\n\n if (this._options.sendClientReports) {\n // We want to track each category (error, transaction, session, replay_event) separately\n // but still keep the distinction between different type of outcomes.\n // We could use nested maps, but it's much easier to read and type this way.\n // A correct type for map-based implementation if we want to go that route\n // would be `Partial<Record<SentryRequestType, Partial<Record<Outcome, number>>>>`\n // With typescript 4.1 we could even use template literal types\n const key = `${reason}:${category}`;\n __DEBUG_BUILD__ && logger.log(`Adding outcome: \"${key}\"`);\n\n // The following works because undefined + 1 === NaN and NaN is falsy\n this._outcomes[key] = this._outcomes[key] + 1 || 1;\n }\n }\n\n // Keep on() & emit() signatures in sync with types' client.ts interface\n /* eslint-disable @typescript-eslint/unified-signatures */\n\n /** @inheritdoc */\n public on(hook: 'startTransaction', callback: (transaction: Transaction) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'finishTransaction', callback: (transaction: Transaction) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'beforeEnvelope', callback: (envelope: Envelope) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'beforeSendEvent', callback: (event: Event, hint?: EventHint) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'preprocessEvent', callback: (event: Event, hint?: EventHint) => void): void;\n\n /** @inheritdoc */\n public on(\n hook: 'afterSendEvent',\n callback: (event: Event, sendResponse: TransportMakeRequestResponse | void) => void,\n ): void;\n\n /** @inheritdoc */\n public on(hook: 'beforeAddBreadcrumb', callback: (breadcrumb: Breadcrumb, hint?: BreadcrumbHint) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'createDsc', callback: (dsc: DynamicSamplingContext) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'otelSpanEnd', callback: (otelSpan: unknown, mutableOptions: { drop: boolean }) => void): void;\n\n /** @inheritdoc */\n public on(hook: string, callback: unknown): void {\n if (!this._hooks[hook]) {\n this._hooks[hook] = [];\n }\n\n // @ts-expect-error We assue the types are correct\n this._hooks[hook].push(callback);\n }\n\n /** @inheritdoc */\n public emit(hook: 'startTransaction', transaction: Transaction): void;\n\n /** @inheritdoc */\n public emit(hook: 'finishTransaction', transaction: Transaction): void;\n\n /** @inheritdoc */\n public emit(hook: 'beforeEnvelope', envelope: Envelope): void;\n\n /** @inheritdoc */\n public emit(hook: 'beforeSendEvent', event: Event, hint?: EventHint): void;\n\n /** @inheritdoc */\n public emit(hook: 'preprocessEvent', event: Event, hint?: EventHint): void;\n\n /** @inheritdoc */\n public emit(hook: 'afterSendEvent', event: Event, sendResponse: TransportMakeRequestResponse | void): void;\n\n /** @inheritdoc */\n public emit(hook: 'beforeAddBreadcrumb', breadcrumb: Breadcrumb, hint?: BreadcrumbHint): void;\n\n /** @inheritdoc */\n public emit(hook: 'createDsc', dsc: DynamicSamplingContext): void;\n\n /** @inheritdoc */\n public emit(hook: 'otelSpanEnd', otelSpan: unknown, mutableOptions: { drop: boolean }): void;\n\n /** @inheritdoc */\n public emit(hook: string, ...rest: unknown[]): void {\n if (this._hooks[hook]) {\n this._hooks[hook].forEach(callback => callback(...rest));\n }\n }\n\n /* eslint-enable @typescript-eslint/unified-signatures */\n\n /** Updates existing session based on the provided event */\n protected _updateSessionFromEvent(session: Session, event: Event): void {\n let crashed = false;\n let errored = false;\n const exceptions = event.exception && event.exception.values;\n\n if (exceptions) {\n errored = true;\n\n for (const ex of exceptions) {\n const mechanism = ex.mechanism;\n if (mechanism && mechanism.handled === false) {\n crashed = true;\n break;\n }\n }\n }\n\n // A session is updated and that session update is sent in only one of the two following scenarios:\n // 1. Session with non terminal status and 0 errors + an error occurred -> Will set error count to 1 and send update\n // 2. Session with non terminal status and 1 error + a crash occurred -> Will set status crashed and send update\n const sessionNonTerminal = session.status === 'ok';\n const shouldUpdateAndSend = (sessionNonTerminal && session.errors === 0) || (sessionNonTerminal && crashed);\n\n if (shouldUpdateAndSend) {\n updateSession(session, {\n ...(crashed && { status: 'crashed' }),\n errors: session.errors || Number(errored || crashed),\n });\n this.captureSession(session);\n }\n }\n\n /**\n * Determine if the client is finished processing. Returns a promise because it will wait `timeout` ms before saying\n * \"no\" (resolving to `false`) in order to give the client a chance to potentially finish first.\n *\n * @param timeout The time, in ms, after which to resolve to `false` if the client is still busy. Passing `0` (or not\n * passing anything) will make the promise wait as long as it takes for processing to finish before resolving to\n * `true`.\n * @returns A promise which will resolve to `true` if processing is already done or finishes before the timeout, and\n * `false` otherwise\n */\n protected _isClientDoneProcessing(timeout?: number): PromiseLike<boolean> {\n return new SyncPromise(resolve => {\n let ticked: number = 0;\n const tick: number = 1;\n\n const interval = setInterval(() => {\n if (this._numProcessing == 0) {\n clearInterval(interval);\n resolve(true);\n } else {\n ticked += tick;\n if (timeout && ticked >= timeout) {\n clearInterval(interval);\n resolve(false);\n }\n }\n }, tick);\n });\n }\n\n /** Determines whether this SDK is enabled and a transport is present. */\n protected _isEnabled(): boolean {\n return this.getOptions().enabled !== false && this._transport !== undefined;\n }\n\n /**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n */\n protected _prepareEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event | null> {\n const options = this.getOptions();\n const integrations = Object.keys(this._integrations);\n if (!hint.integrations && integrations.length > 0) {\n hint.integrations = integrations;\n }\n\n this.emit('preprocessEvent', event, hint);\n\n return prepareEvent(options, event, hint, scope, this).then(evt => {\n if (evt === null) {\n return evt;\n }\n\n // If a trace context is not set on the event, we use the propagationContext set on the event to\n // generate a trace context. If the propagationContext does not have a dynamic sampling context, we\n // also generate one for it.\n const { propagationContext } = evt.sdkProcessingMetadata || {};\n const trace = evt.contexts && evt.contexts.trace;\n if (!trace && propagationContext) {\n const { traceId: trace_id, spanId, parentSpanId, dsc } = propagationContext as PropagationContext;\n evt.contexts = {\n trace: {\n trace_id,\n span_id: spanId,\n parent_span_id: parentSpanId,\n },\n ...evt.contexts,\n };\n\n const dynamicSamplingContext = dsc ? dsc : getDynamicSamplingContextFromClient(trace_id, this, scope);\n\n evt.sdkProcessingMetadata = {\n dynamicSamplingContext,\n ...evt.sdkProcessingMetadata,\n };\n }\n return evt;\n });\n }\n\n /**\n * Processes the event and logs an error in case of rejection\n * @param event\n * @param hint\n * @param scope\n */\n protected _captureEvent(event: Event, hint: EventHint = {}, scope?: Scope): PromiseLike<string | undefined> {\n return this._processEvent(event, hint, scope).then(\n finalEvent => {\n return finalEvent.event_id;\n },\n reason => {\n if (__DEBUG_BUILD__) {\n // If something's gone wrong, log the error as a warning. If it's just us having used a `SentryError` for\n // control flow, log just the message (no stack) as a log-level log.\n const sentryError = reason as SentryError;\n if (sentryError.logLevel === 'log') {\n logger.log(sentryError.message);\n } else {\n logger.warn(sentryError);\n }\n }\n return undefined;\n },\n );\n }\n\n /**\n * Processes an event (either error or message) and sends it to Sentry.\n *\n * This also adds breadcrumbs and context information to the event. However,\n * platform specific meta data (such as the User's IP address) must be added\n * by the SDK implementor.\n *\n *\n * @param event The event to send to Sentry.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A SyncPromise that resolves with the event or rejects in case event was/will not be send.\n */\n protected _processEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event> {\n const options = this.getOptions();\n const { sampleRate } = options;\n\n const isTransaction = isTransactionEvent(event);\n const isError = isErrorEvent(event);\n const eventType = event.type || 'error';\n const beforeSendLabel = `before send for type \\`${eventType}\\``;\n\n // 1.0 === 100% events are sent\n // 0.0 === 0% events are sent\n // Sampling for transaction happens somewhere else\n if (isError && typeof sampleRate === 'number' && Math.random() > sampleRate) {\n this.recordDroppedEvent('sample_rate', 'error', event);\n return rejectedSyncPromise(\n new SentryError(\n `Discarding event because it's not included in the random sample (sampling rate = ${sampleRate})`,\n 'log',\n ),\n );\n }\n\n const dataCategory: DataCategory = eventType === 'replay_event' ? 'replay' : eventType;\n\n return this._prepareEvent(event, hint, scope)\n .then(prepared => {\n if (prepared === null) {\n this.recordDroppedEvent('event_processor', dataCategory, event);\n throw new SentryError('An event processor returned `null`, will not send event.', 'log');\n }\n\n const isInternalException = hint.data && (hint.data as { __sentry__: boolean }).__sentry__ === true;\n if (isInternalException) {\n return prepared;\n }\n\n const result = processBeforeSend(options, prepared, hint);\n return _validateBeforeSendResult(result, beforeSendLabel);\n })\n .then(processedEvent => {\n if (processedEvent === null) {\n this.recordDroppedEvent('before_send', dataCategory, event);\n throw new SentryError(`${beforeSendLabel} returned \\`null\\`, will not send event.`, 'log');\n }\n\n const session = scope && scope.getSession();\n if (!isTransaction && session) {\n this._updateSessionFromEvent(session, processedEvent);\n }\n\n // None of the Sentry built event processor will update transaction name,\n // so if the transaction name has been changed by an event processor, we know\n // it has to come from custom event processor added by a user\n const transactionInfo = processedEvent.transaction_info;\n if (isTransaction && transactionInfo && processedEvent.transaction !== event.transaction) {\n const source = 'custom';\n processedEvent.transaction_info = {\n ...transactionInfo,\n source,\n };\n }\n\n this.sendEvent(processedEvent, hint);\n return processedEvent;\n })\n .then(null, reason => {\n if (reason instanceof SentryError) {\n throw reason;\n }\n\n this.captureException(reason, {\n data: {\n __sentry__: true,\n },\n originalException: reason,\n });\n throw new SentryError(\n `Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\\nReason: ${reason}`,\n );\n });\n }\n\n /**\n * Occupies the client with processing and event\n */\n protected _process<T>(promise: PromiseLike<T>): void {\n this._numProcessing++;\n void promise.then(\n value => {\n this._numProcessing--;\n return value;\n },\n reason => {\n this._numProcessing--;\n return reason;\n },\n );\n }\n\n /**\n * @inheritdoc\n */\n protected _sendEnvelope(envelope: Envelope): PromiseLike<void | TransportMakeRequestResponse> | void {\n this.emit('beforeEnvelope', envelope);\n\n if (this._isEnabled() && this._transport) {\n return this._transport.send(envelope).then(null, reason => {\n __DEBUG_BUILD__ && logger.error('Error while sending event:', reason);\n });\n } else {\n __DEBUG_BUILD__ && logger.error('Transport disabled');\n }\n }\n\n /**\n * Clears outcomes on this client and returns them.\n */\n protected _clearOutcomes(): Outcome[] {\n const outcomes = this._outcomes;\n this._outcomes = {};\n return Object.keys(outcomes).map(key => {\n const [reason, category] = key.split(':') as [EventDropReason, DataCategory];\n return {\n reason,\n category,\n quantity: outcomes[key],\n };\n });\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public abstract eventFromException(_exception: any, _hint?: EventHint): PromiseLike<Event>;\n\n /**\n * @inheritDoc\n */\n public abstract eventFromMessage(\n _message: string,\n // eslint-disable-next-line deprecation/deprecation\n _level?: Severity | SeverityLevel,\n _hint?: EventHint,\n ): PromiseLike<Event>;\n}\n\n/**\n * Verifies that return value of configured `beforeSend` or `beforeSendTransaction` is of expected type, and returns the value if so.\n */\nfunction _validateBeforeSendResult(\n beforeSendResult: PromiseLike<Event | null> | Event | null,\n beforeSendLabel: string,\n): PromiseLike<Event | null> | Event | null {\n const invalidValueError = `${beforeSendLabel} must return \\`null\\` or a valid event.`;\n if (isThenable(beforeSendResult)) {\n return beforeSendResult.then(\n event => {\n if (!isPlainObject(event) && event !== null) {\n throw new SentryError(invalidValueError);\n }\n return event;\n },\n e => {\n throw new SentryError(`${beforeSendLabel} rejected with ${e}`);\n },\n );\n } else if (!isPlainObject(beforeSendResult) && beforeSendResult !== null) {\n throw new SentryError(invalidValueError);\n }\n return beforeSendResult;\n}\n\n/**\n * Process the matching `beforeSendXXX` callback.\n */\nfunction processBeforeSend(\n options: ClientOptions,\n event: Event,\n hint: EventHint,\n): PromiseLike<Event | null> | Event | null {\n const { beforeSend, beforeSendTransaction } = options;\n\n if (isErrorEvent(event) && beforeSend) {\n return beforeSend(event, hint);\n }\n\n if (isTransactionEvent(event) && beforeSendTransaction) {\n return beforeSendTransaction(event, hint);\n }\n\n return event;\n}\n\nfunction isErrorEvent(event: Event): event is ErrorEvent {\n return event.type === undefined;\n}\n\nfunction isTransactionEvent(event: Event): event is TransactionEvent {\n return event.type === 'transaction';\n}\n", "import type { Client, ClientOptions } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport { getCurrentHub } from './hub';\n\n/** A class object that can instantiate Client objects. */\nexport type ClientClass<F extends Client, O extends ClientOptions> = new (options: O) => F;\n\n/**\n * Internal function to create a new SDK client instance. The client is\n * installed and then bound to the current scope.\n *\n * @param clientClass The client class to instantiate.\n * @param options Options to pass to the client.\n */\nexport function initAndBind<F extends Client, O extends ClientOptions>(\n clientClass: ClientClass<F, O>,\n options: O,\n): void {\n if (options.debug === true) {\n if (__DEBUG_BUILD__) {\n logger.enable();\n } else {\n // use `console.warn` rather than `logger.warn` since by non-debug bundles have all `logger.x` statements stripped\n // eslint-disable-next-line no-console\n console.warn('[Sentry] Cannot initialize SDK with `debug` option using a non-debug bundle.');\n }\n }\n const hub = getCurrentHub();\n const scope = hub.getScope();\n scope.update(options.initialScope);\n\n const client = new clientClass(options);\n hub.bindClient(client);\n}\n", "import type {\n Envelope,\n EnvelopeItem,\n EnvelopeItemType,\n Event,\n EventDropReason,\n EventItem,\n InternalBaseTransportOptions,\n Transport,\n TransportMakeRequestResponse,\n TransportRequestExecutor,\n} from '@sentry/types';\nimport type { PromiseBuffer, RateLimits } from '@sentry/utils';\nimport {\n createEnvelope,\n envelopeItemTypeToDataCategory,\n forEachEnvelopeItem,\n isRateLimited,\n logger,\n makePromiseBuffer,\n resolvedSyncPromise,\n SentryError,\n serializeEnvelope,\n updateRateLimits,\n} from '@sentry/utils';\n\nexport const DEFAULT_TRANSPORT_BUFFER_SIZE = 30;\n\n/**\n * Creates an instance of a Sentry `Transport`\n *\n * @param options\n * @param makeRequest\n */\nexport function createTransport(\n options: InternalBaseTransportOptions,\n makeRequest: TransportRequestExecutor,\n buffer: PromiseBuffer<void | TransportMakeRequestResponse> = makePromiseBuffer(\n options.bufferSize || DEFAULT_TRANSPORT_BUFFER_SIZE,\n ),\n): Transport {\n let rateLimits: RateLimits = {};\n const flush = (timeout?: number): PromiseLike<boolean> => buffer.drain(timeout);\n\n function send(envelope: Envelope): PromiseLike<void | TransportMakeRequestResponse> {\n const filteredEnvelopeItems: EnvelopeItem[] = [];\n\n // Drop rate limited items from envelope\n forEachEnvelopeItem(envelope, (item, type) => {\n const envelopeItemDataCategory = envelopeItemTypeToDataCategory(type);\n if (isRateLimited(rateLimits, envelopeItemDataCategory)) {\n const event: Event | undefined = getEventForEnvelopeItem(item, type);\n options.recordDroppedEvent('ratelimit_backoff', envelopeItemDataCategory, event);\n } else {\n filteredEnvelopeItems.push(item);\n }\n });\n\n // Skip sending if envelope is empty after filtering out rate limited events\n if (filteredEnvelopeItems.length === 0) {\n return resolvedSyncPromise();\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const filteredEnvelope: Envelope = createEnvelope(envelope[0], filteredEnvelopeItems as any);\n\n // Creates client report for each item in an envelope\n const recordEnvelopeLoss = (reason: EventDropReason): void => {\n forEachEnvelopeItem(filteredEnvelope, (item, type) => {\n const event: Event | undefined = getEventForEnvelopeItem(item, type);\n options.recordDroppedEvent(reason, envelopeItemTypeToDataCategory(type), event);\n });\n };\n\n const requestTask = (): PromiseLike<void | TransportMakeRequestResponse> =>\n makeRequest({ body: serializeEnvelope(filteredEnvelope, options.textEncoder) }).then(\n response => {\n // We don't want to throw on NOK responses, but we want to at least log them\n if (response.statusCode !== undefined && (response.statusCode < 200 || response.statusCode >= 300)) {\n __DEBUG_BUILD__ && logger.warn(`Sentry responded with status code ${response.statusCode} to sent event.`);\n }\n\n rateLimits = updateRateLimits(rateLimits, response);\n return response;\n },\n error => {\n recordEnvelopeLoss('network_error');\n throw error;\n },\n );\n\n return buffer.add(requestTask).then(\n result => result,\n error => {\n if (error instanceof SentryError) {\n __DEBUG_BUILD__ && logger.error('Skipped sending event because buffer is full.');\n recordEnvelopeLoss('queue_overflow');\n return resolvedSyncPromise();\n } else {\n throw error;\n }\n },\n );\n }\n\n // We use this to identifify if the transport is the base transport\n // TODO (v8): Remove this again as we'll no longer need it\n send.__sentry__baseTransport__ = true;\n\n return {\n send,\n flush,\n };\n}\n\nfunction getEventForEnvelopeItem(item: Envelope[1][number], type: EnvelopeItemType): Event | undefined {\n if (type !== 'event' && type !== 'transaction') {\n return undefined;\n }\n\n return Array.isArray(item) ? (item as EventItem)[1] : undefined;\n}\n", "export const SDK_VERSION = '7.77.0';\n", "export { FunctionToString } from './functiontostring.js';\nexport { InboundFilters } from './inboundfilters.js';\nexport { LinkedErrors } from './linkederrors.js';\n//# sourceMappingURL=index.js.map\n", "import type { Integration, WrappedFunction } from '@sentry/types';\nimport { getOriginalFunction } from '@sentry/utils';\n\nlet originalFunctionToString: () => void;\n\n/** Patch toString calls to return proper name for wrapped functions */\nexport class FunctionToString implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'FunctionToString';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n public constructor() {\n this.name = FunctionToString.id;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n originalFunctionToString = Function.prototype.toString;\n\n // intrinsics (like Function.prototype) might be immutable in some environments\n // e.g. Node with --frozen-intrinsics, XS (an embedded JavaScript engine) or SES (a JavaScript proposal)\n try {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Function.prototype.toString = function (this: WrappedFunction, ...args: any[]): string {\n const context = getOriginalFunction(this) || this;\n return originalFunctionToString.apply(context, args);\n };\n } catch {\n // ignore errors here, just don't patch this\n }\n }\n}\n", "import type { Client, Event, EventHint, Integration, StackFrame } from '@sentry/types';\nimport { getEventDescription, logger, stringMatchesSomePattern } from '@sentry/utils';\n\n// \"Script error.\" is hard coded into browsers for errors that it can't read.\n// this is the result of a script being pulled in from an external domain and CORS.\nconst DEFAULT_IGNORE_ERRORS = [/^Script error\\.?$/, /^Javascript error: Script error\\.? on line 0$/];\n\nconst DEFAULT_IGNORE_TRANSACTIONS = [\n /^.*\\/healthcheck$/,\n /^.*\\/healthy$/,\n /^.*\\/live$/,\n /^.*\\/ready$/,\n /^.*\\/heartbeat$/,\n /^.*\\/health$/,\n /^.*\\/healthz$/,\n];\n\n/** Options for the InboundFilters integration */\nexport interface InboundFiltersOptions {\n allowUrls: Array<string | RegExp>;\n denyUrls: Array<string | RegExp>;\n ignoreErrors: Array<string | RegExp>;\n ignoreTransactions: Array<string | RegExp>;\n ignoreInternal: boolean;\n disableErrorDefaults: boolean;\n disableTransactionDefaults: boolean;\n}\n\n/** Inbound filters configurable by the user */\nexport class InboundFilters implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'InboundFilters';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n private readonly _options: Partial<InboundFiltersOptions>;\n\n public constructor(options: Partial<InboundFiltersOptions> = {}) {\n this.name = InboundFilters.id;\n this._options = options;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(_addGlobaleventProcessor: unknown, _getCurrentHub: unknown): void {\n // noop\n }\n\n /** @inheritDoc */\n public processEvent(event: Event, _eventHint: EventHint, client: Client): Event | null {\n const clientOptions = client.getOptions();\n const options = _mergeOptions(this._options, clientOptions);\n return _shouldDropEvent(event, options) ? null : event;\n }\n}\n\n/** JSDoc */\nexport function _mergeOptions(\n internalOptions: Partial<InboundFiltersOptions> = {},\n clientOptions: Partial<InboundFiltersOptions> = {},\n): Partial<InboundFiltersOptions> {\n return {\n allowUrls: [...(internalOptions.allowUrls || []), ...(clientOptions.allowUrls || [])],\n denyUrls: [...(internalOptions.denyUrls || []), ...(clientOptions.denyUrls || [])],\n ignoreErrors: [\n ...(internalOptions.ignoreErrors || []),\n ...(clientOptions.ignoreErrors || []),\n ...(internalOptions.disableErrorDefaults ? [] : DEFAULT_IGNORE_ERRORS),\n ],\n ignoreTransactions: [\n ...(internalOptions.ignoreTransactions || []),\n ...(clientOptions.ignoreTransactions || []),\n ...(internalOptions.disableTransactionDefaults ? [] : DEFAULT_IGNORE_TRANSACTIONS),\n ],\n ignoreInternal: internalOptions.ignoreInternal !== undefined ? internalOptions.ignoreInternal : true,\n };\n}\n\n/** JSDoc */\nexport function _shouldDropEvent(event: Event, options: Partial<InboundFiltersOptions>): boolean {\n if (options.ignoreInternal && _isSentryError(event)) {\n __DEBUG_BUILD__ &&\n logger.warn(`Event dropped due to being internal Sentry Error.\\nEvent: ${getEventDescription(event)}`);\n return true;\n }\n if (_isIgnoredError(event, options.ignoreErrors)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`ignoreErrors\\` option.\\nEvent: ${getEventDescription(event)}`,\n );\n return true;\n }\n if (_isIgnoredTransaction(event, options.ignoreTransactions)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`ignoreTransactions\\` option.\\nEvent: ${getEventDescription(event)}`,\n );\n return true;\n }\n if (_isDeniedUrl(event, options.denyUrls)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`denyUrls\\` option.\\nEvent: ${getEventDescription(\n event,\n )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n );\n return true;\n }\n if (!_isAllowedUrl(event, options.allowUrls)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to not being matched by \\`allowUrls\\` option.\\nEvent: ${getEventDescription(\n event,\n )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n );\n return true;\n }\n return false;\n}\n\nfunction _isIgnoredError(event: Event, ignoreErrors?: Array<string | RegExp>): boolean {\n // If event.type, this is not an error\n if (event.type || !ignoreErrors || !ignoreErrors.length) {\n return false;\n }\n\n return _getPossibleEventMessages(event).some(message => stringMatchesSomePattern(message, ignoreErrors));\n}\n\nfunction _isIgnoredTransaction(event: Event, ignoreTransactions?: Array<string | RegExp>): boolean {\n if (event.type !== 'transaction' || !ignoreTransactions || !ignoreTransactions.length) {\n return false;\n }\n\n const name = event.transaction;\n return name ? stringMatchesSomePattern(name, ignoreTransactions) : false;\n}\n\nfunction _isDeniedUrl(event: Event, denyUrls?: Array<string | RegExp>): boolean {\n // TODO: Use Glob instead?\n if (!denyUrls || !denyUrls.length) {\n return false;\n }\n const url = _getEventFilterUrl(event);\n return !url ? false : stringMatchesSomePattern(url, denyUrls);\n}\n\nfunction _isAllowedUrl(event: Event, allowUrls?: Array<string | RegExp>): boolean {\n // TODO: Use Glob instead?\n if (!allowUrls || !allowUrls.length) {\n return true;\n }\n const url = _getEventFilterUrl(event);\n return !url ? true : stringMatchesSomePattern(url, allowUrls);\n}\n\nfunction _getPossibleEventMessages(event: Event): string[] {\n const possibleMessages: string[] = [];\n\n if (event.message) {\n possibleMessages.push(event.message);\n }\n\n let lastException;\n try {\n // @ts-expect-error Try catching to save bundle size\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n lastException = event.exception.values[event.exception.values.length - 1];\n } catch (e) {\n // try catching to save bundle size checking existence of variables\n }\n\n if (lastException) {\n if (lastException.value) {\n possibleMessages.push(lastException.value);\n if (lastException.type) {\n possibleMessages.push(`${lastException.type}: ${lastException.value}`);\n }\n }\n }\n\n if (__DEBUG_BUILD__ && possibleMessages.length === 0) {\n logger.error(`Could not extract message for event ${getEventDescription(event)}`);\n }\n\n return possibleMessages;\n}\n\nfunction _isSentryError(event: Event): boolean {\n try {\n // @ts-expect-error can't be a sentry error if undefined\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return event.exception.values[0].type === 'SentryError';\n } catch (e) {\n // ignore\n }\n return false;\n}\n\nfunction _getLastValidUrl(frames: StackFrame[] = []): string | null {\n for (let i = frames.length - 1; i >= 0; i--) {\n const frame = frames[i];\n\n if (frame && frame.filename !== '<anonymous>' && frame.filename !== '[native code]') {\n return frame.filename || null;\n }\n }\n\n return null;\n}\n\nfunction _getEventFilterUrl(event: Event): string | null {\n try {\n let frames;\n try {\n // @ts-expect-error we only care about frames if the whole thing here is defined\n frames = event.exception.values[0].stacktrace.frames;\n } catch (e) {\n // ignore\n }\n return frames ? _getLastValidUrl(frames) : null;\n } catch (oO) {\n __DEBUG_BUILD__ && logger.error(`Cannot extract url for event ${getEventDescription(event)}`);\n return null;\n }\n}\n", "import type { Client, Event, EventHint, Integration } from '@sentry/types';\nimport { applyAggregateErrorsToEvent, exceptionFromError } from '@sentry/utils';\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\n/** Adds SDK info to an event. */\nexport class LinkedErrors implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'LinkedErrors';\n\n /**\n * @inheritDoc\n */\n public readonly name: string;\n\n /**\n * @inheritDoc\n */\n private readonly _key: string;\n\n /**\n * @inheritDoc\n */\n private readonly _limit: number;\n\n /**\n * @inheritDoc\n */\n public constructor(options: { key?: string; limit?: number } = {}) {\n this._key = options.key || DEFAULT_KEY;\n this._limit = options.limit || DEFAULT_LIMIT;\n this.name = LinkedErrors.id;\n }\n\n /** @inheritdoc */\n public setupOnce(): void {\n // noop\n }\n\n /**\n * @inheritDoc\n */\n public preprocessEvent(event: Event, hint: EventHint | undefined, client: Client): void {\n const options = client.getOptions();\n\n applyAggregateErrorsToEvent(\n exceptionFromError,\n options.stackParser,\n options.maxValueLength,\n this._key,\n this._limit,\n event,\n hint,\n );\n }\n}\n", "import { captureException, withScope } from '@sentry/core';\nimport type { DsnLike, Event as SentryEvent, Mechanism, Scope, WrappedFunction } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addExceptionTypeValue,\n addNonEnumerableProperty,\n getOriginalFunction,\n GLOBAL_OBJ,\n markFunctionWrapped,\n} from '@sentry/utils';\n\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ & Window;\n\nlet ignoreOnError: number = 0;\n\n/**\n * @hidden\n */\nexport function shouldIgnoreOnError(): boolean {\n return ignoreOnError > 0;\n}\n\n/**\n * @hidden\n */\nexport function ignoreNextOnError(): void {\n // onerror should trigger before setTimeout\n ignoreOnError++;\n setTimeout(() => {\n ignoreOnError--;\n });\n}\n\n/**\n * Instruments the given function and sends an event to Sentry every time the\n * function throws an exception.\n *\n * @param fn A function to wrap. It is generally safe to pass an unbound function, because the returned wrapper always\n * has a correct `this` context.\n * @returns The wrapped function.\n * @hidden\n */\nexport function wrap(\n fn: WrappedFunction,\n options: {\n mechanism?: Mechanism;\n } = {},\n before?: WrappedFunction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): any {\n // for future readers what this does is wrap a function and then create\n // a bi-directional wrapping between them.\n //\n // example: wrapped = wrap(original);\n // original.__sentry_wrapped__ -> wrapped\n // wrapped.__sentry_original__ -> original\n\n if (typeof fn !== 'function') {\n return fn;\n }\n\n try {\n // if we're dealing with a function that was previously wrapped, return\n // the original wrapper.\n const wrapper = fn.__sentry_wrapped__;\n if (wrapper) {\n return wrapper;\n }\n\n // We don't wanna wrap it twice\n if (getOriginalFunction(fn)) {\n return fn;\n }\n } catch (e) {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n // Bail on wrapping and return the function as-is (defers to window.onerror).\n return fn;\n }\n\n /* eslint-disable prefer-rest-params */\n // It is important that `sentryWrapped` is not an arrow function to preserve the context of `this`\n const sentryWrapped: WrappedFunction = function (this: unknown): void {\n const args = Array.prototype.slice.call(arguments);\n\n try {\n if (before && typeof before === 'function') {\n before.apply(this, arguments);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n const wrappedArguments = args.map((arg: any) => wrap(arg, options));\n\n // Attempt to invoke user-land function\n // NOTE: If you are a Sentry user, and you are seeing this stack frame, it\n // means the sentry.javascript SDK caught an error invoking your application code. This\n // is expected behavior and NOT indicative of a bug with sentry.javascript.\n return fn.apply(this, wrappedArguments);\n } catch (ex) {\n ignoreNextOnError();\n\n withScope((scope: Scope) => {\n scope.addEventProcessor((event: SentryEvent) => {\n if (options.mechanism) {\n addExceptionTypeValue(event, undefined, undefined);\n addExceptionMechanism(event, options.mechanism);\n }\n\n event.extra = {\n ...event.extra,\n arguments: args,\n };\n\n return event;\n });\n\n captureException(ex);\n });\n\n throw ex;\n }\n };\n /* eslint-enable prefer-rest-params */\n\n // Accessing some objects may throw\n // ref: https://github.com/getsentry/sentry-javascript/issues/1168\n try {\n for (const property in fn) {\n if (Object.prototype.hasOwnProperty.call(fn, property)) {\n sentryWrapped[property] = fn[property];\n }\n }\n } catch (_oO) {} // eslint-disable-line no-empty\n\n // Signal that this function has been wrapped/filled already\n // for both debugging and to prevent it to being wrapped/filled twice\n markFunctionWrapped(sentryWrapped, fn);\n\n addNonEnumerableProperty(fn, '__sentry_wrapped__', sentryWrapped);\n\n // Restore original function name (not all browsers allow that)\n try {\n const descriptor = Object.getOwnPropertyDescriptor(sentryWrapped, 'name') as PropertyDescriptor;\n if (descriptor.configurable) {\n Object.defineProperty(sentryWrapped, 'name', {\n get(): string {\n return fn.name;\n },\n });\n }\n // eslint-disable-next-line no-empty\n } catch (_oO) {}\n\n return sentryWrapped;\n}\n\n/**\n * All properties the report dialog supports\n */\nexport interface ReportDialogOptions {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n eventId?: string;\n dsn?: DsnLike;\n user?: {\n email?: string;\n name?: string;\n };\n lang?: string;\n title?: string;\n subtitle?: string;\n subtitle2?: string;\n labelName?: string;\n labelEmail?: string;\n labelComments?: string;\n labelClose?: string;\n labelSubmit?: string;\n errorGeneric?: string;\n errorFormEntry?: string;\n successMessage?: string;\n /** Callback after reportDialog showed up */\n onLoad?(this: void): void;\n}\n", "import { getCurrentHub } from '@sentry/core';\nimport type { Event, EventHint, Exception, Severity, SeverityLevel, StackFrame, StackParser } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addExceptionTypeValue,\n extractExceptionKeysForMessage,\n isDOMError,\n isDOMException,\n isError,\n isErrorEvent,\n isEvent,\n isPlainObject,\n normalizeToSize,\n resolvedSyncPromise,\n} from '@sentry/utils';\n\ntype Prototype = { constructor: (...args: unknown[]) => unknown };\n\n/**\n * This function creates an exception from a JavaScript Error\n */\nexport function exceptionFromError(stackParser: StackParser, ex: Error): Exception {\n // Get the frames first since Opera can lose the stack if we touch anything else first\n const frames = parseStackFrames(stackParser, ex);\n\n const exception: Exception = {\n type: ex && ex.name,\n value: extractMessage(ex),\n };\n\n if (frames.length) {\n exception.stacktrace = { frames };\n }\n\n if (exception.type === undefined && exception.value === '') {\n exception.value = 'Unrecoverable error caught';\n }\n\n return exception;\n}\n\n/**\n * @hidden\n */\nexport function eventFromPlainObject(\n stackParser: StackParser,\n exception: Record<string, unknown>,\n syntheticException?: Error,\n isUnhandledRejection?: boolean,\n): Event {\n const hub = getCurrentHub();\n const client = hub.getClient();\n const normalizeDepth = client && client.getOptions().normalizeDepth;\n\n const event: Event = {\n exception: {\n values: [\n {\n type: isEvent(exception) ? exception.constructor.name : isUnhandledRejection ? 'UnhandledRejection' : 'Error',\n value: getNonErrorObjectExceptionValue(exception, { isUnhandledRejection }),\n },\n ],\n },\n extra: {\n __serialized__: normalizeToSize(exception, normalizeDepth),\n },\n };\n\n if (syntheticException) {\n const frames = parseStackFrames(stackParser, syntheticException);\n if (frames.length) {\n // event.exception.values[0] has been set above\n (event.exception as { values: Exception[] }).values[0].stacktrace = { frames };\n }\n }\n\n return event;\n}\n\n/**\n * @hidden\n */\nexport function eventFromError(stackParser: StackParser, ex: Error): Event {\n return {\n exception: {\n values: [exceptionFromError(stackParser, ex)],\n },\n };\n}\n\n/** Parses stack frames from an error */\nexport function parseStackFrames(\n stackParser: StackParser,\n ex: Error & { framesToPop?: number; stacktrace?: string },\n): StackFrame[] {\n // Access and store the stacktrace property before doing ANYTHING\n // else to it because Opera is not very good at providing it\n // reliably in other circumstances.\n const stacktrace = ex.stacktrace || ex.stack || '';\n\n const popSize = getPopSize(ex);\n\n try {\n return stackParser(stacktrace, popSize);\n } catch (e) {\n // no-empty\n }\n\n return [];\n}\n\n// Based on our own mapping pattern - https://github.com/getsentry/sentry/blob/9f08305e09866c8bd6d0c24f5b0aabdd7dd6c59c/src/sentry/lang/javascript/errormapping.py#L83-L108\nconst reactMinifiedRegexp = /Minified React error #\\d+;/i;\n\nfunction getPopSize(ex: Error & { framesToPop?: number }): number {\n if (ex) {\n if (typeof ex.framesToPop === 'number') {\n return ex.framesToPop;\n }\n\n if (reactMinifiedRegexp.test(ex.message)) {\n return 1;\n }\n }\n\n return 0;\n}\n\n/**\n * There are cases where stacktrace.message is an Event object\n * https://github.com/getsentry/sentry-javascript/issues/1949\n * In this specific case we try to extract stacktrace.message.error.message\n */\nfunction extractMessage(ex: Error & { message: { error?: Error } }): string {\n const message = ex && ex.message;\n if (!message) {\n return 'No error message';\n }\n if (message.error && typeof message.error.message === 'string') {\n return message.error.message;\n }\n return message;\n}\n\n/**\n * Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`.\n * @hidden\n */\nexport function eventFromException(\n stackParser: StackParser,\n exception: unknown,\n hint?: EventHint,\n attachStacktrace?: boolean,\n): PromiseLike<Event> {\n const syntheticException = (hint && hint.syntheticException) || undefined;\n const event = eventFromUnknownInput(stackParser, exception, syntheticException, attachStacktrace);\n addExceptionMechanism(event); // defaults to { type: 'generic', handled: true }\n event.level = 'error';\n if (hint && hint.event_id) {\n event.event_id = hint.event_id;\n }\n return resolvedSyncPromise(event);\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nexport function eventFromMessage(\n stackParser: StackParser,\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel = 'info',\n hint?: EventHint,\n attachStacktrace?: boolean,\n): PromiseLike<Event> {\n const syntheticException = (hint && hint.syntheticException) || undefined;\n const event = eventFromString(stackParser, message, syntheticException, attachStacktrace);\n event.level = level;\n if (hint && hint.event_id) {\n event.event_id = hint.event_id;\n }\n return resolvedSyncPromise(event);\n}\n\n/**\n * @hidden\n */\nexport function eventFromUnknownInput(\n stackParser: StackParser,\n exception: unknown,\n syntheticException?: Error,\n attachStacktrace?: boolean,\n isUnhandledRejection?: boolean,\n): Event {\n let event: Event;\n\n if (isErrorEvent(exception as ErrorEvent) && (exception as ErrorEvent).error) {\n // If it is an ErrorEvent with `error` property, extract it to get actual Error\n const errorEvent = exception as ErrorEvent;\n return eventFromError(stackParser, errorEvent.error as Error);\n }\n\n // If it is a `DOMError` (which is a legacy API, but still supported in some browsers) then we just extract the name\n // and message, as it doesn't provide anything else. According to the spec, all `DOMExceptions` should also be\n // `Error`s, but that's not the case in IE11, so in that case we treat it the same as we do a `DOMError`.\n //\n // https://developer.mozilla.org/en-US/docs/Web/API/DOMError\n // https://developer.mozilla.org/en-US/docs/Web/API/DOMException\n // https://webidl.spec.whatwg.org/#es-DOMException-specialness\n if (isDOMError(exception) || isDOMException(exception as DOMException)) {\n const domException = exception as DOMException;\n\n if ('stack' in (exception as Error)) {\n event = eventFromError(stackParser, exception as Error);\n } else {\n const name = domException.name || (isDOMError(domException) ? 'DOMError' : 'DOMException');\n const message = domException.message ? `${name}: ${domException.message}` : name;\n event = eventFromString(stackParser, message, syntheticException, attachStacktrace);\n addExceptionTypeValue(event, message);\n }\n if ('code' in domException) {\n // eslint-disable-next-line deprecation/deprecation\n event.tags = { ...event.tags, 'DOMException.code': `${domException.code}` };\n }\n\n return event;\n }\n if (isError(exception)) {\n // we have a real Error object, do nothing\n return eventFromError(stackParser, exception);\n }\n if (isPlainObject(exception) || isEvent(exception)) {\n // If it's a plain object or an instance of `Event` (the built-in JS kind, not this SDK's `Event` type), serialize\n // it manually. This will allow us to group events based on top-level keys which is much better than creating a new\n // group on any key/value change.\n const objectException = exception as Record<string, unknown>;\n event = eventFromPlainObject(stackParser, objectException, syntheticException, isUnhandledRejection);\n addExceptionMechanism(event, {\n synthetic: true,\n });\n return event;\n }\n\n // If none of previous checks were valid, then it means that it's not:\n // - an instance of DOMError\n // - an instance of DOMException\n // - an instance of Event\n // - an instance of Error\n // - a valid ErrorEvent (one with an error property)\n // - a plain Object\n //\n // So bail out and capture it as a simple message:\n event = eventFromString(stackParser, exception as string, syntheticException, attachStacktrace);\n addExceptionTypeValue(event, `${exception}`, undefined);\n addExceptionMechanism(event, {\n synthetic: true,\n });\n\n return event;\n}\n\n/**\n * @hidden\n */\nexport function eventFromString(\n stackParser: StackParser,\n input: string,\n syntheticException?: Error,\n attachStacktrace?: boolean,\n): Event {\n const event: Event = {\n message: input,\n };\n\n if (attachStacktrace && syntheticException) {\n const frames = parseStackFrames(stackParser, syntheticException);\n if (frames.length) {\n event.exception = {\n values: [{ value: input, stacktrace: { frames } }],\n };\n }\n }\n\n return event;\n}\n\nfunction getNonErrorObjectExceptionValue(\n exception: Record<string, unknown>,\n { isUnhandledRejection }: { isUnhandledRejection?: boolean },\n): string {\n const keys = extractExceptionKeysForMessage(exception);\n const captureType = isUnhandledRejection ? 'promise rejection' : 'exception';\n\n // Some ErrorEvent instances do not have an `error` property, which is why they are not handled before\n // We still want to try to get a decent message for these cases\n if (isErrorEvent(exception)) {\n return `Event \\`ErrorEvent\\` captured as ${captureType} with message \\`${exception.message}\\``;\n }\n\n if (isEvent(exception)) {\n const className = getObjectClassName(exception);\n return `Event \\`${className}\\` (type=${exception.type}) captured as ${captureType}`;\n }\n\n return `Object captured as ${captureType} with keys: ${keys}`;\n}\n\nfunction getObjectClassName(obj: unknown): string | undefined | void {\n try {\n const prototype: Prototype | null = Object.getPrototypeOf(obj);\n return prototype ? prototype.constructor.name : undefined;\n } catch (e) {\n // ignore errors here\n }\n}\n", "import type { DsnComponents, EventEnvelope, SdkMetadata, UserFeedback, UserFeedbackItem } from '@sentry/types';\nimport { createEnvelope, dsnToString } from '@sentry/utils';\n\n/**\n * Creates an envelope from a user feedback.\n */\nexport function createUserFeedbackEnvelope(\n feedback: UserFeedback,\n {\n metadata,\n tunnel,\n dsn,\n }: {\n metadata: SdkMetadata | undefined;\n tunnel: string | undefined;\n dsn: DsnComponents | undefined;\n },\n): EventEnvelope {\n const headers: EventEnvelope[0] = {\n event_id: feedback.event_id,\n sent_at: new Date().toISOString(),\n ...(metadata &&\n metadata.sdk && {\n sdk: {\n name: metadata.sdk.name,\n version: metadata.sdk.version,\n },\n }),\n ...(!!tunnel && !!dsn && { dsn: dsnToString(dsn) }),\n };\n const item = createUserFeedbackEnvelopeItem(feedback);\n\n return createEnvelope(headers, [item]);\n}\n\nfunction createUserFeedbackEnvelopeItem(feedback: UserFeedback): UserFeedbackItem {\n const feedbackHeaders: UserFeedbackItem[0] = {\n type: 'user_report',\n };\n return [feedbackHeaders, feedback];\n}\n", "import type { Scope } from '@sentry/core';\nimport { BaseClient, SDK_VERSION } from '@sentry/core';\nimport type {\n BrowserClientProfilingOptions,\n BrowserClientReplayOptions,\n ClientOptions,\n Event,\n EventHint,\n Options,\n Severity,\n SeverityLevel,\n UserFeedback,\n} from '@sentry/types';\nimport { createClientReportEnvelope, dsnToString, getSDKSource, logger } from '@sentry/utils';\n\nimport { eventFromException, eventFromMessage } from './eventbuilder';\nimport { WINDOW } from './helpers';\nimport type { BrowserTransportOptions } from './transports/types';\nimport { createUserFeedbackEnvelope } from './userfeedback';\n\n/**\n * Configuration options for the Sentry Browser SDK.\n * @see @sentry/types Options for more information.\n */\nexport type BrowserOptions = Options<BrowserTransportOptions> &\n BrowserClientReplayOptions &\n BrowserClientProfilingOptions;\n\n/**\n * Configuration options for the Sentry Browser SDK Client class\n * @see BrowserClient for more information.\n */\nexport type BrowserClientOptions = ClientOptions<BrowserTransportOptions> &\n BrowserClientReplayOptions &\n BrowserClientProfilingOptions;\n\n/**\n * The Sentry Browser SDK Client.\n *\n * @see BrowserOptions for documentation on configuration options.\n * @see SentryClient for usage documentation.\n */\nexport class BrowserClient extends BaseClient<BrowserClientOptions> {\n /**\n * Creates a new Browser SDK instance.\n *\n * @param options Configuration options for this SDK.\n */\n public constructor(options: BrowserClientOptions) {\n const sdkSource = WINDOW.SENTRY_SDK_SOURCE || getSDKSource();\n\n options._metadata = options._metadata || {};\n options._metadata.sdk = options._metadata.sdk || {\n name: 'sentry.javascript.browser',\n packages: [\n {\n name: `${sdkSource}:@sentry/browser`,\n version: SDK_VERSION,\n },\n ],\n version: SDK_VERSION,\n };\n\n super(options);\n\n if (options.sendClientReports && WINDOW.document) {\n WINDOW.document.addEventListener('visibilitychange', () => {\n if (WINDOW.document.visibilityState === 'hidden') {\n this._flushOutcomes();\n }\n });\n }\n }\n\n /**\n * @inheritDoc\n */\n public eventFromException(exception: unknown, hint?: EventHint): PromiseLike<Event> {\n return eventFromException(this._options.stackParser, exception, hint, this._options.attachStacktrace);\n }\n\n /**\n * @inheritDoc\n */\n public eventFromMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel = 'info',\n hint?: EventHint,\n ): PromiseLike<Event> {\n return eventFromMessage(this._options.stackParser, message, level, hint, this._options.attachStacktrace);\n }\n\n /**\n * Sends user feedback to Sentry.\n */\n public captureUserFeedback(feedback: UserFeedback): void {\n if (!this._isEnabled()) {\n __DEBUG_BUILD__ && logger.warn('SDK not enabled, will not capture user feedback.');\n return;\n }\n\n const envelope = createUserFeedbackEnvelope(feedback, {\n metadata: this.getSdkMetadata(),\n dsn: this.getDsn(),\n tunnel: this.getOptions().tunnel,\n });\n void this._sendEnvelope(envelope);\n }\n\n /**\n * @inheritDoc\n */\n protected _prepareEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event | null> {\n event.platform = event.platform || 'javascript';\n return super._prepareEvent(event, hint, scope);\n }\n\n /**\n * Sends client reports as an envelope.\n */\n private _flushOutcomes(): void {\n const outcomes = this._clearOutcomes();\n\n if (outcomes.length === 0) {\n __DEBUG_BUILD__ && logger.log('No outcomes to send');\n return;\n }\n\n // This is really the only place where we want to check for a DSN and only send outcomes then\n if (!this._dsn) {\n __DEBUG_BUILD__ && logger.log('No dsn provided, will not send outcomes');\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('Sending outcomes:', outcomes);\n\n const envelope = createClientReportEnvelope(outcomes, this._options.tunnel && dsnToString(this._dsn));\n void this._sendEnvelope(envelope);\n }\n}\n", "import { isNativeFetch, logger } from '@sentry/utils';\n\nimport { WINDOW } from '../helpers';\n\nlet cachedFetchImpl: FetchImpl | undefined = undefined;\n\nexport type FetchImpl = typeof fetch;\n\n/**\n * A special usecase for incorrectly wrapped Fetch APIs in conjunction with ad-blockers.\n * Whenever someone wraps the Fetch API and returns the wrong promise chain,\n * this chain becomes orphaned and there is no possible way to capture it's rejections\n * other than allowing it bubble up to this very handler. eg.\n *\n * const f = window.fetch;\n * window.fetch = function () {\n * const p = f.apply(this, arguments);\n *\n * p.then(function() {\n * console.log('hi.');\n * });\n *\n * return p;\n * }\n *\n * `p.then(function () { ... })` is producing a completely separate promise chain,\n * however, what's returned is `p` - the result of original `fetch` call.\n *\n * This mean, that whenever we use the Fetch API to send our own requests, _and_\n * some ad-blocker blocks it, this orphaned chain will _always_ reject,\n * effectively causing another event to be captured.\n * This makes a whole process become an infinite loop, which we need to somehow\n * deal with, and break it in one way or another.\n *\n * To deal with this issue, we are making sure that we _always_ use the real\n * browser Fetch API, instead of relying on what `window.fetch` exposes.\n * The only downside to this would be missing our own requests as breadcrumbs,\n * but because we are already not doing this, it should be just fine.\n *\n * Possible failed fetch error messages per-browser:\n *\n * Chrome: Failed to fetch\n * Edge: Failed to Fetch\n * Firefox: NetworkError when attempting to fetch resource\n * Safari: resource blocked by content blocker\n */\nexport function getNativeFetchImplementation(): FetchImpl {\n if (cachedFetchImpl) {\n return cachedFetchImpl;\n }\n\n /* eslint-disable @typescript-eslint/unbound-method */\n\n // Fast path to avoid DOM I/O\n if (isNativeFetch(WINDOW.fetch)) {\n return (cachedFetchImpl = WINDOW.fetch.bind(WINDOW));\n }\n\n const document = WINDOW.document;\n let fetchImpl = WINDOW.fetch;\n // eslint-disable-next-line deprecation/deprecation\n if (document && typeof document.createElement === 'function') {\n try {\n const sandbox = document.createElement('iframe');\n sandbox.hidden = true;\n document.head.appendChild(sandbox);\n const contentWindow = sandbox.contentWindow;\n if (contentWindow && contentWindow.fetch) {\n fetchImpl = contentWindow.fetch;\n }\n document.head.removeChild(sandbox);\n } catch (e) {\n __DEBUG_BUILD__ &&\n logger.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', e);\n }\n }\n\n return (cachedFetchImpl = fetchImpl.bind(WINDOW));\n /* eslint-enable @typescript-eslint/unbound-method */\n}\n\n/** Clears cached fetch impl */\nexport function clearCachedFetchImplementation(): void {\n cachedFetchImpl = undefined;\n}\n", "import { createTransport } from '@sentry/core';\nimport type { Transport, TransportMakeRequestResponse, TransportRequest } from '@sentry/types';\nimport { rejectedSyncPromise } from '@sentry/utils';\n\nimport type { BrowserTransportOptions } from './types';\nimport type { FetchImpl } from './utils';\nimport { clearCachedFetchImplementation, getNativeFetchImplementation } from './utils';\n\n/**\n * Creates a Transport that uses the Fetch API to send events to Sentry.\n */\nexport function makeFetchTransport(\n options: BrowserTransportOptions,\n nativeFetch: FetchImpl = getNativeFetchImplementation(),\n): Transport {\n let pendingBodySize = 0;\n let pendingCount = 0;\n\n function makeRequest(request: TransportRequest): PromiseLike<TransportMakeRequestResponse> {\n const requestSize = request.body.length;\n pendingBodySize += requestSize;\n pendingCount++;\n\n const requestOptions: RequestInit = {\n body: request.body,\n method: 'POST',\n referrerPolicy: 'origin',\n headers: options.headers,\n // Outgoing requests are usually cancelled when navigating to a different page, causing a \"TypeError: Failed to\n // fetch\" error and sending a \"network_error\" client-outcome - in Chrome, the request status shows \"(cancelled)\".\n // The `keepalive` flag keeps outgoing requests alive, even when switching pages. We want this since we're\n // frequently sending events right before the user is switching pages (eg. whenfinishing navigation transactions).\n // Gotchas:\n // - `keepalive` isn't supported by Firefox\n // - As per spec (https://fetch.spec.whatwg.org/#http-network-or-cache-fetch):\n // If the sum of contentLength and inflightKeepaliveBytes is greater than 64 kibibytes, then return a network error.\n // We will therefore only activate the flag when we're below that limit.\n // There is also a limit of requests that can be open at the same time, so we also limit this to 15\n // See https://github.com/getsentry/sentry-javascript/pull/7553 for details\n keepalive: pendingBodySize <= 60_000 && pendingCount < 15,\n ...options.fetchOptions,\n };\n\n try {\n return nativeFetch(options.url, requestOptions).then(response => {\n pendingBodySize -= requestSize;\n pendingCount--;\n return {\n statusCode: response.status,\n headers: {\n 'x-sentry-rate-limits': response.headers.get('X-Sentry-Rate-Limits'),\n 'retry-after': response.headers.get('Retry-After'),\n },\n };\n });\n } catch (e) {\n clearCachedFetchImplementation();\n pendingBodySize -= requestSize;\n pendingCount--;\n return rejectedSyncPromise(e);\n }\n }\n\n return createTransport(options, makeRequest);\n}\n", "import { createTransport } from '@sentry/core';\nimport type { Transport, TransportMakeRequestResponse, TransportRequest } from '@sentry/types';\nimport { SyncPromise } from '@sentry/utils';\n\nimport type { BrowserTransportOptions } from './types';\n\n/**\n * The DONE ready state for XmlHttpRequest\n *\n * Defining it here as a constant b/c XMLHttpRequest.DONE is not always defined\n * (e.g. during testing, it is `undefined`)\n *\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/readyState}\n */\nconst XHR_READYSTATE_DONE = 4;\n\n/**\n * Creates a Transport that uses the XMLHttpRequest API to send events to Sentry.\n */\nexport function makeXHRTransport(options: BrowserTransportOptions): Transport {\n function makeRequest(request: TransportRequest): PromiseLike<TransportMakeRequestResponse> {\n return new SyncPromise((resolve, reject) => {\n const xhr = new XMLHttpRequest();\n\n xhr.onerror = reject;\n\n xhr.onreadystatechange = (): void => {\n if (xhr.readyState === XHR_READYSTATE_DONE) {\n resolve({\n statusCode: xhr.status,\n headers: {\n 'x-sentry-rate-limits': xhr.getResponseHeader('X-Sentry-Rate-Limits'),\n 'retry-after': xhr.getResponseHeader('Retry-After'),\n },\n });\n }\n };\n\n xhr.open('POST', options.url);\n\n for (const header in options.headers) {\n if (Object.prototype.hasOwnProperty.call(options.headers, header)) {\n xhr.setRequestHeader(header, options.headers[header]);\n }\n }\n\n xhr.send(request.body);\n });\n }\n\n return createTransport(options, makeRequest);\n}\n", "// This was originally forked from https://github.com/csnover/TraceKit, and was largely\n// re - written as part of raven - js.\n//\n// This code was later copied to the JavaScript mono - repo and further modified and\n// refactored over the years.\n\n// Copyright (c) 2013 Onur Can Cakmak onur.cakmak@gmail.com and all TraceKit contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of this\n// software and associated documentation files(the 'Software'), to deal in the Software\n// without restriction, including without limitation the rights to use, copy, modify,\n// merge, publish, distribute, sublicense, and / or sell copies of the Software, and to\n// permit persons to whom the Software is furnished to do so, subject to the following\n// conditions:\n//\n// The above copyright notice and this permission notice shall be included in all copies\n// or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,\n// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A\n// PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\n// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF\n// CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE\n// OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nimport type { StackFrame, StackLineParser, StackLineParserFn } from '@sentry/types';\nimport { createStackParser } from '@sentry/utils';\n\n// global reference to slice\nconst UNKNOWN_FUNCTION = '?';\n\nconst OPERA10_PRIORITY = 10;\nconst OPERA11_PRIORITY = 20;\nconst CHROME_PRIORITY = 30;\nconst WINJS_PRIORITY = 40;\nconst GECKO_PRIORITY = 50;\n\nfunction createFrame(filename: string, func: string, lineno?: number, colno?: number): StackFrame {\n const frame: StackFrame = {\n filename,\n function: func,\n in_app: true, // All browser frames are considered in_app\n };\n\n if (lineno !== undefined) {\n frame.lineno = lineno;\n }\n\n if (colno !== undefined) {\n frame.colno = colno;\n }\n\n return frame;\n}\n\n// Chromium based browsers: Chrome, Brave, new Opera, new Edge\nconst chromeRegex =\n /^\\s*at (?:(.+?\\)(?: \\[.+\\])?|.*?) ?\\((?:address at )?)?(?:async )?((?:<anonymous>|[-a-z]+:|.*bundle|\\/)?.*?)(?::(\\d+))?(?::(\\d+))?\\)?\\s*$/i;\nconst chromeEvalRegex = /\\((\\S*)(?::(\\d+))(?::(\\d+))\\)/;\n\nconst chrome: StackLineParserFn = line => {\n const parts = chromeRegex.exec(line);\n\n if (parts) {\n const isEval = parts[2] && parts[2].indexOf('eval') === 0; // start of line\n\n if (isEval) {\n const subMatch = chromeEvalRegex.exec(parts[2]);\n\n if (subMatch) {\n // throw out eval line/column and use top-most line/column number\n parts[2] = subMatch[1]; // url\n parts[3] = subMatch[2]; // line\n parts[4] = subMatch[3]; // column\n }\n }\n\n // Kamil: One more hack won't hurt us right? Understanding and adding more rules on top of these regexps right now\n // would be way too time consuming. (TODO: Rewrite whole RegExp to be more readable)\n const [func, filename] = extractSafariExtensionDetails(parts[1] || UNKNOWN_FUNCTION, parts[2]);\n\n return createFrame(filename, func, parts[3] ? +parts[3] : undefined, parts[4] ? +parts[4] : undefined);\n }\n\n return;\n};\n\nexport const chromeStackLineParser: StackLineParser = [CHROME_PRIORITY, chrome];\n\n// gecko regex: `(?:bundle|\\d+\\.js)`: `bundle` is for react native, `\\d+\\.js` also but specifically for ram bundles because it\n// generates filenames without a prefix like `file://` the filenames in the stacktrace are just 42.js\n// We need this specific case for now because we want no other regex to match.\nconst geckoREgex =\n /^\\s*(.*?)(?:\\((.*?)\\))?(?:^|@)?((?:[-a-z]+)?:\\/.*?|\\[native code\\]|[^@]*(?:bundle|\\d+\\.js)|\\/[\\w\\-. /=]+)(?::(\\d+))?(?::(\\d+))?\\s*$/i;\nconst geckoEvalRegex = /(\\S+) line (\\d+)(?: > eval line \\d+)* > eval/i;\n\nconst gecko: StackLineParserFn = line => {\n const parts = geckoREgex.exec(line);\n\n if (parts) {\n const isEval = parts[3] && parts[3].indexOf(' > eval') > -1;\n if (isEval) {\n const subMatch = geckoEvalRegex.exec(parts[3]);\n\n if (subMatch) {\n // throw out eval line/column and use top-most line number\n parts[1] = parts[1] || 'eval';\n parts[3] = subMatch[1];\n parts[4] = subMatch[2];\n parts[5] = ''; // no column when eval\n }\n }\n\n let filename = parts[3];\n let func = parts[1] || UNKNOWN_FUNCTION;\n [func, filename] = extractSafariExtensionDetails(func, filename);\n\n return createFrame(filename, func, parts[4] ? +parts[4] : undefined, parts[5] ? +parts[5] : undefined);\n }\n\n return;\n};\n\nexport const geckoStackLineParser: StackLineParser = [GECKO_PRIORITY, gecko];\n\nconst winjsRegex = /^\\s*at (?:((?:\\[object object\\])?.+) )?\\(?((?:[-a-z]+):.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nconst winjs: StackLineParserFn = line => {\n const parts = winjsRegex.exec(line);\n\n return parts\n ? createFrame(parts[2], parts[1] || UNKNOWN_FUNCTION, +parts[3], parts[4] ? +parts[4] : undefined)\n : undefined;\n};\n\nexport const winjsStackLineParser: StackLineParser = [WINJS_PRIORITY, winjs];\n\nconst opera10Regex = / line (\\d+).*script (?:in )?(\\S+)(?:: in function (\\S+))?$/i;\n\nconst opera10: StackLineParserFn = line => {\n const parts = opera10Regex.exec(line);\n return parts ? createFrame(parts[2], parts[3] || UNKNOWN_FUNCTION, +parts[1]) : undefined;\n};\n\nexport const opera10StackLineParser: StackLineParser = [OPERA10_PRIORITY, opera10];\n\nconst opera11Regex =\n / line (\\d+), column (\\d+)\\s*(?:in (?:<anonymous function: ([^>]+)>|([^)]+))\\(.*\\))? in (.*):\\s*$/i;\n\nconst opera11: StackLineParserFn = line => {\n const parts = opera11Regex.exec(line);\n return parts ? createFrame(parts[5], parts[3] || parts[4] || UNKNOWN_FUNCTION, +parts[1], +parts[2]) : undefined;\n};\n\nexport const opera11StackLineParser: StackLineParser = [OPERA11_PRIORITY, opera11];\n\nexport const defaultStackLineParsers = [chromeStackLineParser, geckoStackLineParser, winjsStackLineParser];\n\nexport const defaultStackParser = createStackParser(...defaultStackLineParsers);\n\n/**\n * Safari web extensions, starting version unknown, can produce \"frames-only\" stacktraces.\n * What it means, is that instead of format like:\n *\n * Error: wat\n * at function@url:row:col\n * at function@url:row:col\n * at function@url:row:col\n *\n * it produces something like:\n *\n * function@url:row:col\n * function@url:row:col\n * function@url:row:col\n *\n * Because of that, it won't be captured by `chrome` RegExp and will fall into `Gecko` branch.\n * This function is extracted so that we can use it in both places without duplicating the logic.\n * Unfortunately \"just\" changing RegExp is too complicated now and making it pass all tests\n * and fix this case seems like an impossible, or at least way too time-consuming task.\n */\nconst extractSafariExtensionDetails = (func: string, filename: string): [string, string] => {\n const isSafariExtension = func.indexOf('safari-extension') !== -1;\n const isSafariWebExtension = func.indexOf('safari-web-extension') !== -1;\n\n return isSafariExtension || isSafariWebExtension\n ? [\n func.indexOf('@') !== -1 ? func.split('@')[0] : UNKNOWN_FUNCTION,\n isSafariExtension ? `safari-extension:${filename}` : `safari-web-extension:${filename}`,\n ]\n : [func, filename];\n};\n", "/* eslint-disable @typescript-eslint/no-unsafe-member-access */\nimport { getCurrentHub } from '@sentry/core';\nimport type { Event, EventHint, Hub, Integration, Primitive, StackParser } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addInstrumentationHandler,\n getLocationHref,\n isErrorEvent,\n isPrimitive,\n isString,\n logger,\n} from '@sentry/utils';\n\nimport type { BrowserClient } from '../client';\nimport { eventFromUnknownInput } from '../eventbuilder';\nimport { shouldIgnoreOnError } from '../helpers';\n\ntype GlobalHandlersIntegrationsOptionKeys = 'onerror' | 'onunhandledrejection';\n\n/** JSDoc */\ntype GlobalHandlersIntegrations = Record<GlobalHandlersIntegrationsOptionKeys, boolean>;\n\n/** Global handlers */\nexport class GlobalHandlers implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'GlobalHandlers';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /** JSDoc */\n private readonly _options: GlobalHandlersIntegrations;\n\n /**\n * Stores references functions to installing handlers. Will set to undefined\n * after they have been run so that they are not used twice.\n */\n private _installFunc: Record<GlobalHandlersIntegrationsOptionKeys, (() => void) | undefined>;\n\n /** JSDoc */\n public constructor(options?: GlobalHandlersIntegrations) {\n this.name = GlobalHandlers.id;\n this._options = {\n onerror: true,\n onunhandledrejection: true,\n ...options,\n };\n\n this._installFunc = {\n onerror: _installGlobalOnErrorHandler,\n onunhandledrejection: _installGlobalOnUnhandledRejectionHandler,\n };\n }\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n Error.stackTraceLimit = 50;\n const options = this._options;\n\n // We can disable guard-for-in as we construct the options object above + do checks against\n // `this._installFunc` for the property.\n // eslint-disable-next-line guard-for-in\n for (const key in options) {\n const installFunc = this._installFunc[key as GlobalHandlersIntegrationsOptionKeys];\n if (installFunc && options[key as GlobalHandlersIntegrationsOptionKeys]) {\n globalHandlerLog(key);\n installFunc();\n this._installFunc[key as GlobalHandlersIntegrationsOptionKeys] = undefined;\n }\n }\n }\n}\n\n/** JSDoc */\nfunction _installGlobalOnErrorHandler(): void {\n addInstrumentationHandler(\n 'error',\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (data: { msg: any; url: any; line: any; column: any; error: any }) => {\n const [hub, stackParser, attachStacktrace] = getHubAndOptions();\n if (!hub.getIntegration(GlobalHandlers)) {\n return;\n }\n const { msg, url, line, column, error } = data;\n if (shouldIgnoreOnError() || (error && error.__sentry_own_request__)) {\n return;\n }\n\n const event =\n error === undefined && isString(msg)\n ? _eventFromIncompleteOnError(msg, url, line, column)\n : _enhanceEventWithInitialFrame(\n eventFromUnknownInput(stackParser, error || msg, undefined, attachStacktrace, false),\n url,\n line,\n column,\n );\n\n event.level = 'error';\n\n addMechanismAndCapture(hub, error, event, 'onerror');\n },\n );\n}\n\n/** JSDoc */\nfunction _installGlobalOnUnhandledRejectionHandler(): void {\n addInstrumentationHandler(\n 'unhandledrejection',\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (e: any) => {\n const [hub, stackParser, attachStacktrace] = getHubAndOptions();\n if (!hub.getIntegration(GlobalHandlers)) {\n return;\n }\n let error = e;\n\n // dig the object of the rejection out of known event types\n try {\n // PromiseRejectionEvents store the object of the rejection under 'reason'\n // see https://developer.mozilla.org/en-US/docs/Web/API/PromiseRejectionEvent\n if ('reason' in e) {\n error = e.reason;\n }\n // something, somewhere, (likely a browser extension) effectively casts PromiseRejectionEvents\n // to CustomEvents, moving the `promise` and `reason` attributes of the PRE into\n // the CustomEvent's `detail` attribute, since they're not part of CustomEvent's spec\n // see https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent and\n // https://github.com/getsentry/sentry-javascript/issues/2380\n else if ('detail' in e && 'reason' in e.detail) {\n error = e.detail.reason;\n }\n } catch (_oO) {\n // no-empty\n }\n\n if (shouldIgnoreOnError() || (error && error.__sentry_own_request__)) {\n return true;\n }\n\n const event = isPrimitive(error)\n ? _eventFromRejectionWithPrimitive(error)\n : eventFromUnknownInput(stackParser, error, undefined, attachStacktrace, true);\n\n event.level = 'error';\n\n addMechanismAndCapture(hub, error, event, 'onunhandledrejection');\n return;\n },\n );\n}\n\n/**\n * Create an event from a promise rejection where the `reason` is a primitive.\n *\n * @param reason: The `reason` property of the promise rejection\n * @returns An Event object with an appropriate `exception` value\n */\nfunction _eventFromRejectionWithPrimitive(reason: Primitive): Event {\n return {\n exception: {\n values: [\n {\n type: 'UnhandledRejection',\n // String() is needed because the Primitive type includes symbols (which can't be automatically stringified)\n value: `Non-Error promise rejection captured with value: ${String(reason)}`,\n },\n ],\n },\n };\n}\n\n/**\n * This function creates a stack from an old, error-less onerror handler.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _eventFromIncompleteOnError(msg: any, url: any, line: any, column: any): Event {\n const ERROR_TYPES_RE =\n /^(?:[Uu]ncaught (?:exception: )?)?(?:((?:Eval|Internal|Range|Reference|Syntax|Type|URI|)Error): )?(.*)$/i;\n\n // If 'message' is ErrorEvent, get real message from inside\n let message = isErrorEvent(msg) ? msg.message : msg;\n let name = 'Error';\n\n const groups = message.match(ERROR_TYPES_RE);\n if (groups) {\n name = groups[1];\n message = groups[2];\n }\n\n const event = {\n exception: {\n values: [\n {\n type: name,\n value: message,\n },\n ],\n },\n };\n\n return _enhanceEventWithInitialFrame(event, url, line, column);\n}\n\n/** JSDoc */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _enhanceEventWithInitialFrame(event: Event, url: any, line: any, column: any): Event {\n // event.exception\n const e = (event.exception = event.exception || {});\n // event.exception.values\n const ev = (e.values = e.values || []);\n // event.exception.values[0]\n const ev0 = (ev[0] = ev[0] || {});\n // event.exception.values[0].stacktrace\n const ev0s = (ev0.stacktrace = ev0.stacktrace || {});\n // event.exception.values[0].stacktrace.frames\n const ev0sf = (ev0s.frames = ev0s.frames || []);\n\n const colno = isNaN(parseInt(column, 10)) ? undefined : column;\n const lineno = isNaN(parseInt(line, 10)) ? undefined : line;\n const filename = isString(url) && url.length > 0 ? url : getLocationHref();\n\n // event.exception.values[0].stacktrace.frames\n if (ev0sf.length === 0) {\n ev0sf.push({\n colno,\n filename,\n function: '?',\n in_app: true,\n lineno,\n });\n }\n\n return event;\n}\n\nfunction globalHandlerLog(type: string): void {\n __DEBUG_BUILD__ && logger.log(`Global Handler attached: ${type}`);\n}\n\nfunction addMechanismAndCapture(hub: Hub, error: EventHint['originalException'], event: Event, type: string): void {\n addExceptionMechanism(event, {\n handled: false,\n type,\n });\n hub.captureEvent(event, {\n originalException: error,\n });\n}\n\nfunction getHubAndOptions(): [Hub, StackParser, boolean | undefined] {\n const hub = getCurrentHub();\n const client = hub.getClient<BrowserClient>();\n const options = (client && client.getOptions()) || {\n stackParser: () => [],\n attachStacktrace: false,\n };\n return [hub, options.stackParser, options.attachStacktrace];\n}\n", "import type { Integration, WrappedFunction } from '@sentry/types';\nimport { fill, getFunctionName, getOriginalFunction } from '@sentry/utils';\n\nimport { WINDOW, wrap } from '../helpers';\n\nconst DEFAULT_EVENT_TARGET = [\n 'EventTarget',\n 'Window',\n 'Node',\n 'ApplicationCache',\n 'AudioTrackList',\n 'BroadcastChannel',\n 'ChannelMergerNode',\n 'CryptoOperation',\n 'EventSource',\n 'FileReader',\n 'HTMLUnknownElement',\n 'IDBDatabase',\n 'IDBRequest',\n 'IDBTransaction',\n 'KeyOperation',\n 'MediaController',\n 'MessagePort',\n 'ModalWindow',\n 'Notification',\n 'SVGElementInstance',\n 'Screen',\n 'SharedWorker',\n 'TextTrack',\n 'TextTrackCue',\n 'TextTrackList',\n 'WebSocket',\n 'WebSocketWorker',\n 'Worker',\n 'XMLHttpRequest',\n 'XMLHttpRequestEventTarget',\n 'XMLHttpRequestUpload',\n];\n\ntype XMLHttpRequestProp = 'onload' | 'onerror' | 'onprogress' | 'onreadystatechange';\n\n/** JSDoc */\ninterface TryCatchOptions {\n setTimeout: boolean;\n setInterval: boolean;\n requestAnimationFrame: boolean;\n XMLHttpRequest: boolean;\n eventTarget: boolean | string[];\n}\n\n/** Wrap timer functions and event targets to catch errors and provide better meta data */\nexport class TryCatch implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'TryCatch';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /** JSDoc */\n private readonly _options: TryCatchOptions;\n\n /**\n * @inheritDoc\n */\n public constructor(options?: Partial<TryCatchOptions>) {\n this.name = TryCatch.id;\n this._options = {\n XMLHttpRequest: true,\n eventTarget: true,\n requestAnimationFrame: true,\n setInterval: true,\n setTimeout: true,\n ...options,\n };\n }\n\n /**\n * Wrap timer functions and event targets to catch errors\n * and provide better metadata.\n */\n public setupOnce(): void {\n if (this._options.setTimeout) {\n fill(WINDOW, 'setTimeout', _wrapTimeFunction);\n }\n\n if (this._options.setInterval) {\n fill(WINDOW, 'setInterval', _wrapTimeFunction);\n }\n\n if (this._options.requestAnimationFrame) {\n fill(WINDOW, 'requestAnimationFrame', _wrapRAF);\n }\n\n if (this._options.XMLHttpRequest && 'XMLHttpRequest' in WINDOW) {\n fill(XMLHttpRequest.prototype, 'send', _wrapXHR);\n }\n\n const eventTargetOption = this._options.eventTarget;\n if (eventTargetOption) {\n const eventTarget = Array.isArray(eventTargetOption) ? eventTargetOption : DEFAULT_EVENT_TARGET;\n eventTarget.forEach(_wrapEventTarget);\n }\n }\n}\n\n/** JSDoc */\nfunction _wrapTimeFunction(original: () => void): () => number {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: any, ...args: any[]): number {\n const originalCallback = args[0];\n args[0] = wrap(originalCallback, {\n mechanism: {\n data: { function: getFunctionName(original) },\n handled: false,\n type: 'instrument',\n },\n });\n return original.apply(this, args);\n };\n}\n\n/** JSDoc */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _wrapRAF(original: any): (callback: () => void) => any {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: any, callback: () => void): () => void {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return original.apply(this, [\n wrap(callback, {\n mechanism: {\n data: {\n function: 'requestAnimationFrame',\n handler: getFunctionName(original),\n },\n handled: false,\n type: 'instrument',\n },\n }),\n ]);\n };\n}\n\n/** JSDoc */\nfunction _wrapXHR(originalSend: () => void): () => void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: XMLHttpRequest, ...args: any[]): void {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const xhr = this;\n const xmlHttpRequestProps: XMLHttpRequestProp[] = ['onload', 'onerror', 'onprogress', 'onreadystatechange'];\n\n xmlHttpRequestProps.forEach(prop => {\n if (prop in xhr && typeof xhr[prop] === 'function') {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n fill(xhr, prop, function (original: WrappedFunction): () => any {\n const wrapOptions = {\n mechanism: {\n data: {\n function: prop,\n handler: getFunctionName(original),\n },\n handled: false,\n type: 'instrument',\n },\n };\n\n // If Instrument integration has been called before TryCatch, get the name of original function\n const originalFunction = getOriginalFunction(original);\n if (originalFunction) {\n wrapOptions.mechanism.data.handler = getFunctionName(originalFunction);\n }\n\n // Otherwise wrap directly\n return wrap(original, wrapOptions);\n });\n }\n });\n\n return originalSend.apply(this, args);\n };\n}\n\n/** JSDoc */\nfunction _wrapEventTarget(target: string): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const globalObject = WINDOW as { [key: string]: any };\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const proto = globalObject[target] && globalObject[target].prototype;\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, no-prototype-builtins\n if (!proto || !proto.hasOwnProperty || !proto.hasOwnProperty('addEventListener')) {\n return;\n }\n\n fill(proto, 'addEventListener', function (original: () => void): (\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ) => void {\n return function (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this: any,\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ): (eventName: string, fn: EventListenerObject, capture?: boolean, secure?: boolean) => void {\n try {\n if (typeof fn.handleEvent === 'function') {\n // ESlint disable explanation:\n // First, it is generally safe to call `wrap` with an unbound function. Furthermore, using `.bind()` would\n // introduce a bug here, because bind returns a new function that doesn't have our\n // flags(like __sentry_original__) attached. `wrap` checks for those flags to avoid unnecessary wrapping.\n // Without those flags, every call to addEventListener wraps the function again, causing a memory leak.\n // eslint-disable-next-line @typescript-eslint/unbound-method\n fn.handleEvent = wrap(fn.handleEvent, {\n mechanism: {\n data: {\n function: 'handleEvent',\n handler: getFunctionName(fn),\n target,\n },\n handled: false,\n type: 'instrument',\n },\n });\n }\n } catch (err) {\n // can sometimes get 'Permission denied to access property \"handle Event'\n }\n\n return original.apply(this, [\n eventName,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n wrap(fn as any as WrappedFunction, {\n mechanism: {\n data: {\n function: 'addEventListener',\n handler: getFunctionName(fn),\n target,\n },\n handled: false,\n type: 'instrument',\n },\n }),\n options,\n ]);\n };\n });\n\n fill(\n proto,\n 'removeEventListener',\n function (\n originalRemoveEventListener: () => void,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): (this: any, eventName: string, fn: EventListenerObject, options?: boolean | EventListenerOptions) => () => void {\n return function (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this: any,\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | EventListenerOptions,\n ): () => void {\n /**\n * There are 2 possible scenarios here:\n *\n * 1. Someone passes a callback, which was attached prior to Sentry initialization, or by using unmodified\n * method, eg. `document.addEventListener.call(el, name, handler). In this case, we treat this function\n * as a pass-through, and call original `removeEventListener` with it.\n *\n * 2. Someone passes a callback, which was attached after Sentry was initialized, which means that it was using\n * our wrapped version of `addEventListener`, which internally calls `wrap` helper.\n * This helper \"wraps\" whole callback inside a try/catch statement, and attached appropriate metadata to it,\n * in order for us to make a distinction between wrapped/non-wrapped functions possible.\n * If a function was wrapped, it has additional property of `__sentry_wrapped__`, holding the handler.\n *\n * When someone adds a handler prior to initialization, and then do it again, but after,\n * then we have to detach both of them. Otherwise, if we'd detach only wrapped one, it'd be impossible\n * to get rid of the initial handler and it'd stick there forever.\n */\n const wrappedEventHandler = fn as unknown as WrappedFunction;\n try {\n const originalEventHandler = wrappedEventHandler && wrappedEventHandler.__sentry_wrapped__;\n if (originalEventHandler) {\n originalRemoveEventListener.call(this, eventName, originalEventHandler, options);\n }\n } catch (e) {\n // ignore, accessing __sentry_wrapped__ will throw in some Selenium environments\n }\n return originalRemoveEventListener.call(this, eventName, wrappedEventHandler, options);\n };\n },\n );\n}\n", "/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable max-lines */\nimport { getCurrentHub } from '@sentry/core';\nimport type { Event as SentryEvent, HandlerDataFetch, HandlerDataXhr, Integration } from '@sentry/types';\nimport type {\n FetchBreadcrumbData,\n FetchBreadcrumbHint,\n XhrBreadcrumbData,\n XhrBreadcrumbHint,\n} from '@sentry/types/build/types/breadcrumb';\nimport {\n addInstrumentationHandler,\n getEventDescription,\n htmlTreeAsString,\n logger,\n parseUrl,\n safeJoin,\n SENTRY_XHR_DATA_KEY,\n severityLevelFromString,\n} from '@sentry/utils';\n\nimport { WINDOW } from '../helpers';\n\ntype HandlerData = Record<string, unknown>;\n\n/** JSDoc */\ninterface BreadcrumbsOptions {\n console: boolean;\n dom:\n | boolean\n | {\n serializeAttribute?: string | string[];\n maxStringLength?: number;\n };\n fetch: boolean;\n history: boolean;\n sentry: boolean;\n xhr: boolean;\n}\n\n/** maxStringLength gets capped to prevent 100 breadcrumbs exceeding 1MB event payload size */\nconst MAX_ALLOWED_STRING_LENGTH = 1024;\n\n/**\n * Default Breadcrumbs instrumentations\n * TODO: Deprecated - with v6, this will be renamed to `Instrument`\n */\nexport class Breadcrumbs implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'Breadcrumbs';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /**\n * Options of the breadcrumbs integration.\n */\n // This field is public, because we use it in the browser client to check if the `sentry` option is enabled.\n public readonly options: Readonly<BreadcrumbsOptions>;\n\n /**\n * @inheritDoc\n */\n public constructor(options?: Partial<BreadcrumbsOptions>) {\n this.name = Breadcrumbs.id;\n this.options = {\n console: true,\n dom: true,\n fetch: true,\n history: true,\n sentry: true,\n xhr: true,\n ...options,\n };\n }\n\n /**\n * Instrument browser built-ins w/ breadcrumb capturing\n * - Console API\n * - DOM API (click/typing)\n * - XMLHttpRequest API\n * - Fetch API\n * - History API\n */\n public setupOnce(): void {\n if (this.options.console) {\n addInstrumentationHandler('console', _consoleBreadcrumb);\n }\n if (this.options.dom) {\n addInstrumentationHandler('dom', _domBreadcrumb(this.options.dom));\n }\n if (this.options.xhr) {\n addInstrumentationHandler('xhr', _xhrBreadcrumb);\n }\n if (this.options.fetch) {\n addInstrumentationHandler('fetch', _fetchBreadcrumb);\n }\n if (this.options.history) {\n addInstrumentationHandler('history', _historyBreadcrumb);\n }\n if (this.options.sentry) {\n const client = getCurrentHub().getClient();\n client && client.on && client.on('beforeSendEvent', addSentryBreadcrumb);\n }\n }\n}\n\n/**\n * Adds a breadcrumb for Sentry events or transactions if this option is enabled.\n */\nfunction addSentryBreadcrumb(event: SentryEvent): void {\n getCurrentHub().addBreadcrumb(\n {\n category: `sentry.${event.type === 'transaction' ? 'transaction' : 'event'}`,\n event_id: event.event_id,\n level: event.level,\n message: getEventDescription(event),\n },\n {\n event,\n },\n );\n}\n\n/**\n * A HOC that creaes a function that creates breadcrumbs from DOM API calls.\n * This is a HOC so that we get access to dom options in the closure.\n */\nfunction _domBreadcrumb(dom: BreadcrumbsOptions['dom']): (handlerData: HandlerData) => void {\n function _innerDomBreadcrumb(handlerData: HandlerData): void {\n let target;\n let keyAttrs = typeof dom === 'object' ? dom.serializeAttribute : undefined;\n\n let maxStringLength =\n typeof dom === 'object' && typeof dom.maxStringLength === 'number' ? dom.maxStringLength : undefined;\n if (maxStringLength && maxStringLength > MAX_ALLOWED_STRING_LENGTH) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `\\`dom.maxStringLength\\` cannot exceed ${MAX_ALLOWED_STRING_LENGTH}, but a value of ${maxStringLength} was configured. Sentry will use ${MAX_ALLOWED_STRING_LENGTH} instead.`,\n );\n maxStringLength = MAX_ALLOWED_STRING_LENGTH;\n }\n\n if (typeof keyAttrs === 'string') {\n keyAttrs = [keyAttrs];\n }\n\n // Accessing event.target can throw (see getsentry/raven-js#838, #768)\n try {\n const event = handlerData.event as Event | Node;\n target = _isEvent(event)\n ? htmlTreeAsString(event.target, { keyAttrs, maxStringLength })\n : htmlTreeAsString(event, { keyAttrs, maxStringLength });\n } catch (e) {\n target = '<unknown>';\n }\n\n if (target.length === 0) {\n return;\n }\n\n getCurrentHub().addBreadcrumb(\n {\n category: `ui.${handlerData.name}`,\n message: target,\n },\n {\n event: handlerData.event,\n name: handlerData.name,\n global: handlerData.global,\n },\n );\n }\n\n return _innerDomBreadcrumb;\n}\n\n/**\n * Creates breadcrumbs from console API calls\n */\nfunction _consoleBreadcrumb(handlerData: HandlerData & { args: unknown[]; level: string }): void {\n const breadcrumb = {\n category: 'console',\n data: {\n arguments: handlerData.args,\n logger: 'console',\n },\n level: severityLevelFromString(handlerData.level),\n message: safeJoin(handlerData.args, ' '),\n };\n\n if (handlerData.level === 'assert') {\n if (handlerData.args[0] === false) {\n breadcrumb.message = `Assertion failed: ${safeJoin(handlerData.args.slice(1), ' ') || 'console.assert'}`;\n breadcrumb.data.arguments = handlerData.args.slice(1);\n } else {\n // Don't capture a breadcrumb for passed assertions\n return;\n }\n }\n\n getCurrentHub().addBreadcrumb(breadcrumb, {\n input: handlerData.args,\n level: handlerData.level,\n });\n}\n\n/**\n * Creates breadcrumbs from XHR API calls\n */\nfunction _xhrBreadcrumb(handlerData: HandlerData & HandlerDataXhr): void {\n const { startTimestamp, endTimestamp } = handlerData;\n\n const sentryXhrData = handlerData.xhr[SENTRY_XHR_DATA_KEY];\n\n // We only capture complete, non-sentry requests\n if (!startTimestamp || !endTimestamp || !sentryXhrData) {\n return;\n }\n\n const { method, url, status_code, body } = sentryXhrData;\n\n const data: XhrBreadcrumbData = {\n method,\n url,\n status_code,\n };\n\n const hint: XhrBreadcrumbHint = {\n xhr: handlerData.xhr,\n input: body,\n startTimestamp,\n endTimestamp,\n };\n\n getCurrentHub().addBreadcrumb(\n {\n category: 'xhr',\n data,\n type: 'http',\n },\n hint,\n );\n}\n\n/**\n * Creates breadcrumbs from fetch API calls\n */\nfunction _fetchBreadcrumb(handlerData: HandlerData & HandlerDataFetch & { response?: Response }): void {\n const { startTimestamp, endTimestamp } = handlerData;\n\n // We only capture complete fetch requests\n if (!endTimestamp) {\n return;\n }\n\n if (handlerData.fetchData.url.match(/sentry_key/) && handlerData.fetchData.method === 'POST') {\n // We will not create breadcrumbs for fetch requests that contain `sentry_key` (internal sentry requests)\n return;\n }\n\n if (handlerData.error) {\n const data: FetchBreadcrumbData = handlerData.fetchData;\n const hint: FetchBreadcrumbHint = {\n data: handlerData.error,\n input: handlerData.args,\n startTimestamp,\n endTimestamp,\n };\n\n getCurrentHub().addBreadcrumb(\n {\n category: 'fetch',\n data,\n level: 'error',\n type: 'http',\n },\n hint,\n );\n } else {\n const data: FetchBreadcrumbData = {\n ...handlerData.fetchData,\n status_code: handlerData.response && handlerData.response.status,\n };\n const hint: FetchBreadcrumbHint = {\n input: handlerData.args,\n response: handlerData.response,\n startTimestamp,\n endTimestamp,\n };\n getCurrentHub().addBreadcrumb(\n {\n category: 'fetch',\n data,\n type: 'http',\n },\n hint,\n );\n }\n}\n\n/**\n * Creates breadcrumbs from history API calls\n */\nfunction _historyBreadcrumb(handlerData: HandlerData & { from: string; to: string }): void {\n let from: string | undefined = handlerData.from;\n let to: string | undefined = handlerData.to;\n const parsedLoc = parseUrl(WINDOW.location.href);\n let parsedFrom = parseUrl(from);\n const parsedTo = parseUrl(to);\n\n // Initial pushState doesn't provide `from` information\n if (!parsedFrom.path) {\n parsedFrom = parsedLoc;\n }\n\n // Use only the path component of the URL if the URL matches the current\n // document (almost all the time when using pushState)\n if (parsedLoc.protocol === parsedTo.protocol && parsedLoc.host === parsedTo.host) {\n to = parsedTo.relative;\n }\n if (parsedLoc.protocol === parsedFrom.protocol && parsedLoc.host === parsedFrom.host) {\n from = parsedFrom.relative;\n }\n\n getCurrentHub().addBreadcrumb({\n category: 'navigation',\n data: {\n from,\n to,\n },\n });\n}\n\nfunction _isEvent(event: unknown): event is Event {\n return !!event && !!(event as Record<string, unknown>).target;\n}\n", "import type { Client, Event, EventHint, Integration } from '@sentry/types';\nimport { applyAggregateErrorsToEvent } from '@sentry/utils';\n\nimport { exceptionFromError } from '../eventbuilder';\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\ninterface LinkedErrorsOptions {\n key: string;\n limit: number;\n}\n\n/** Adds SDK info to an event. */\nexport class LinkedErrors implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'LinkedErrors';\n\n /**\n * @inheritDoc\n */\n public readonly name: string;\n\n /**\n * @inheritDoc\n */\n private readonly _key: LinkedErrorsOptions['key'];\n\n /**\n * @inheritDoc\n */\n private readonly _limit: LinkedErrorsOptions['limit'];\n\n /**\n * @inheritDoc\n */\n public constructor(options: Partial<LinkedErrorsOptions> = {}) {\n this.name = LinkedErrors.id;\n this._key = options.key || DEFAULT_KEY;\n this._limit = options.limit || DEFAULT_LIMIT;\n }\n\n /** @inheritdoc */\n public setupOnce(): void {\n // noop\n }\n\n /**\n * @inheritDoc\n */\n public preprocessEvent(event: Event, hint: EventHint | undefined, client: Client): void {\n const options = client.getOptions();\n\n applyAggregateErrorsToEvent(\n exceptionFromError,\n options.stackParser,\n options.maxValueLength,\n this._key,\n this._limit,\n event,\n hint,\n );\n }\n}\n", "import type { Event, Integration } from '@sentry/types';\n\nimport { WINDOW } from '../helpers';\n\n/** HttpContext integration collects information about HTTP request headers */\nexport class HttpContext implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'HttpContext';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n public constructor() {\n this.name = HttpContext.id;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n // noop\n }\n\n /** @inheritDoc */\n public preprocessEvent(event: Event): void {\n // if none of the information we want exists, don't bother\n if (!WINDOW.navigator && !WINDOW.location && !WINDOW.document) {\n return;\n }\n\n // grab as much info as exists and add it to the event\n const url = (event.request && event.request.url) || (WINDOW.location && WINDOW.location.href);\n const { referrer } = WINDOW.document || {};\n const { userAgent } = WINDOW.navigator || {};\n\n const headers = {\n ...(event.request && event.request.headers),\n ...(referrer && { Referer: referrer }),\n ...(userAgent && { 'User-Agent': userAgent }),\n };\n const request = { ...event.request, ...(url && { url }), headers };\n\n event.request = request;\n }\n}\n", "import type { Event, Exception, Integration, StackFrame } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\n/** Deduplication filter */\nexport class Dedupe implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'Dedupe';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /**\n * @inheritDoc\n */\n private _previousEvent?: Event;\n\n public constructor() {\n this.name = Dedupe.id;\n }\n\n /** @inheritDoc */\n public setupOnce(_addGlobaleventProcessor: unknown, _getCurrentHub: unknown): void {\n // noop\n }\n\n /**\n * @inheritDoc\n */\n public processEvent(currentEvent: Event): Event | null {\n // We want to ignore any non-error type events, e.g. transactions or replays\n // These should never be deduped, and also not be compared against as _previousEvent.\n if (currentEvent.type) {\n return currentEvent;\n }\n\n // Juuust in case something goes wrong\n try {\n if (_shouldDropEvent(currentEvent, this._previousEvent)) {\n __DEBUG_BUILD__ && logger.warn('Event dropped due to being a duplicate of previously captured event.');\n return null;\n }\n } catch (_oO) {} // eslint-disable-line no-empty\n\n return (this._previousEvent = currentEvent);\n }\n}\n\n/** JSDoc */\nfunction _shouldDropEvent(currentEvent: Event, previousEvent?: Event): boolean {\n if (!previousEvent) {\n return false;\n }\n\n if (_isSameMessageEvent(currentEvent, previousEvent)) {\n return true;\n }\n\n if (_isSameExceptionEvent(currentEvent, previousEvent)) {\n return true;\n }\n\n return false;\n}\n\n/** JSDoc */\nfunction _isSameMessageEvent(currentEvent: Event, previousEvent: Event): boolean {\n const currentMessage = currentEvent.message;\n const previousMessage = previousEvent.message;\n\n // If neither event has a message property, they were both exceptions, so bail out\n if (!currentMessage && !previousMessage) {\n return false;\n }\n\n // If only one event has a stacktrace, but not the other one, they are not the same\n if ((currentMessage && !previousMessage) || (!currentMessage && previousMessage)) {\n return false;\n }\n\n if (currentMessage !== previousMessage) {\n return false;\n }\n\n if (!_isSameFingerprint(currentEvent, previousEvent)) {\n return false;\n }\n\n if (!_isSameStacktrace(currentEvent, previousEvent)) {\n return false;\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameExceptionEvent(currentEvent: Event, previousEvent: Event): boolean {\n const previousException = _getExceptionFromEvent(previousEvent);\n const currentException = _getExceptionFromEvent(currentEvent);\n\n if (!previousException || !currentException) {\n return false;\n }\n\n if (previousException.type !== currentException.type || previousException.value !== currentException.value) {\n return false;\n }\n\n if (!_isSameFingerprint(currentEvent, previousEvent)) {\n return false;\n }\n\n if (!_isSameStacktrace(currentEvent, previousEvent)) {\n return false;\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameStacktrace(currentEvent: Event, previousEvent: Event): boolean {\n let currentFrames = _getFramesFromEvent(currentEvent);\n let previousFrames = _getFramesFromEvent(previousEvent);\n\n // If neither event has a stacktrace, they are assumed to be the same\n if (!currentFrames && !previousFrames) {\n return true;\n }\n\n // If only one event has a stacktrace, but not the other one, they are not the same\n if ((currentFrames && !previousFrames) || (!currentFrames && previousFrames)) {\n return false;\n }\n\n currentFrames = currentFrames as StackFrame[];\n previousFrames = previousFrames as StackFrame[];\n\n // If number of frames differ, they are not the same\n if (previousFrames.length !== currentFrames.length) {\n return false;\n }\n\n // Otherwise, compare the two\n for (let i = 0; i < previousFrames.length; i++) {\n const frameA = previousFrames[i];\n const frameB = currentFrames[i];\n\n if (\n frameA.filename !== frameB.filename ||\n frameA.lineno !== frameB.lineno ||\n frameA.colno !== frameB.colno ||\n frameA.function !== frameB.function\n ) {\n return false;\n }\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameFingerprint(currentEvent: Event, previousEvent: Event): boolean {\n let currentFingerprint = currentEvent.fingerprint;\n let previousFingerprint = previousEvent.fingerprint;\n\n // If neither event has a fingerprint, they are assumed to be the same\n if (!currentFingerprint && !previousFingerprint) {\n return true;\n }\n\n // If only one event has a fingerprint, but not the other one, they are not the same\n if ((currentFingerprint && !previousFingerprint) || (!currentFingerprint && previousFingerprint)) {\n return false;\n }\n\n currentFingerprint = currentFingerprint as string[];\n previousFingerprint = previousFingerprint as string[];\n\n // Otherwise, compare the two\n try {\n return !!(currentFingerprint.join('') === previousFingerprint.join(''));\n } catch (_oO) {\n return false;\n }\n}\n\n/** JSDoc */\nfunction _getExceptionFromEvent(event: Event): Exception | undefined {\n return event.exception && event.exception.values && event.exception.values[0];\n}\n\n/** JSDoc */\nfunction _getFramesFromEvent(event: Event): StackFrame[] | undefined {\n const exception = event.exception;\n\n if (exception) {\n try {\n // @ts-expect-error Object could be undefined\n return exception.values[0].stacktrace.frames;\n } catch (_oO) {\n return undefined;\n }\n }\n return undefined;\n}\n", "import type { Hub } from '@sentry/core';\nimport {\n getCurrentHub,\n getIntegrationsToSetup,\n getReportDialogEndpoint,\n initAndBind,\n Integrations as CoreIntegrations,\n} from '@sentry/core';\nimport type { UserFeedback } from '@sentry/types';\nimport { addInstrumentationHandler, logger, stackParserFromStackParserOptions, supportsFetch } from '@sentry/utils';\n\nimport type { BrowserClientOptions, BrowserOptions } from './client';\nimport { BrowserClient } from './client';\nimport type { ReportDialogOptions } from './helpers';\nimport { WINDOW, wrap as internalWrap } from './helpers';\nimport { Breadcrumbs, Dedupe, GlobalHandlers, HttpContext, LinkedErrors, TryCatch } from './integrations';\nimport { defaultStackParser } from './stack-parsers';\nimport { makeFetchTransport, makeXHRTransport } from './transports';\n\nexport const defaultIntegrations = [\n new CoreIntegrations.InboundFilters(),\n new CoreIntegrations.FunctionToString(),\n new TryCatch(),\n new Breadcrumbs(),\n new GlobalHandlers(),\n new LinkedErrors(),\n new Dedupe(),\n new HttpContext(),\n];\n\n/**\n * A magic string that build tooling can leverage in order to inject a release value into the SDK.\n */\ndeclare const __SENTRY_RELEASE__: string | undefined;\n\n/**\n * The Sentry Browser SDK Client.\n *\n * To use this SDK, call the {@link init} function as early as possible when\n * loading the web page. To set context information or send manual events, use\n * the provided methods.\n *\n * @example\n *\n * ```\n *\n * import { init } from '@sentry/browser';\n *\n * init({\n * dsn: '__DSN__',\n * // ...\n * });\n * ```\n *\n * @example\n * ```\n *\n * import { configureScope } from '@sentry/browser';\n * configureScope((scope: Scope) => {\n * scope.setExtra({ battery: 0.7 });\n * scope.setTag({ user_mode: 'admin' });\n * scope.setUser({ id: '4711' });\n * });\n * ```\n *\n * @example\n * ```\n *\n * import { addBreadcrumb } from '@sentry/browser';\n * addBreadcrumb({\n * message: 'My Breadcrumb',\n * // ...\n * });\n * ```\n *\n * @example\n *\n * ```\n *\n * import * as Sentry from '@sentry/browser';\n * Sentry.captureMessage('Hello, world!');\n * Sentry.captureException(new Error('Good bye'));\n * Sentry.captureEvent({\n * message: 'Manual',\n * stacktrace: [\n * // ...\n * ],\n * });\n * ```\n *\n * @see {@link BrowserOptions} for documentation on configuration options.\n */\nexport function init(options: BrowserOptions = {}): void {\n if (options.defaultIntegrations === undefined) {\n options.defaultIntegrations = defaultIntegrations;\n }\n if (options.release === undefined) {\n // This allows build tooling to find-and-replace __SENTRY_RELEASE__ to inject a release value\n if (typeof __SENTRY_RELEASE__ === 'string') {\n options.release = __SENTRY_RELEASE__;\n }\n\n // This supports the variable that sentry-webpack-plugin injects\n if (WINDOW.SENTRY_RELEASE && WINDOW.SENTRY_RELEASE.id) {\n options.release = WINDOW.SENTRY_RELEASE.id;\n }\n }\n if (options.autoSessionTracking === undefined) {\n options.autoSessionTracking = true;\n }\n if (options.sendClientReports === undefined) {\n options.sendClientReports = true;\n }\n\n const clientOptions: BrowserClientOptions = {\n ...options,\n stackParser: stackParserFromStackParserOptions(options.stackParser || defaultStackParser),\n integrations: getIntegrationsToSetup(options),\n transport: options.transport || (supportsFetch() ? makeFetchTransport : makeXHRTransport),\n };\n\n initAndBind(BrowserClient, clientOptions);\n\n if (options.autoSessionTracking) {\n startSessionTracking();\n }\n}\n\n/**\n * Present the user with a report dialog.\n *\n * @param options Everything is optional, we try to fetch all info need from the global scope.\n */\nexport function showReportDialog(options: ReportDialogOptions = {}, hub: Hub = getCurrentHub()): void {\n // doesn't work without a document (React Native)\n if (!WINDOW.document) {\n __DEBUG_BUILD__ && logger.error('Global document not defined in showReportDialog call');\n return;\n }\n\n const { client, scope } = hub.getStackTop();\n const dsn = options.dsn || (client && client.getDsn());\n if (!dsn) {\n __DEBUG_BUILD__ && logger.error('DSN not configured for showReportDialog call');\n return;\n }\n\n if (scope) {\n options.user = {\n ...scope.getUser(),\n ...options.user,\n };\n }\n\n if (!options.eventId) {\n options.eventId = hub.lastEventId();\n }\n\n const script = WINDOW.document.createElement('script');\n script.async = true;\n script.crossOrigin = 'anonymous';\n script.src = getReportDialogEndpoint(dsn, options);\n\n if (options.onLoad) {\n script.onload = options.onLoad;\n }\n\n const injectionPoint = WINDOW.document.head || WINDOW.document.body;\n if (injectionPoint) {\n injectionPoint.appendChild(script);\n } else {\n __DEBUG_BUILD__ && logger.error('Not injecting report dialog. No injection point found in HTML');\n }\n}\n\n/**\n * This function is here to be API compatible with the loader.\n * @hidden\n */\nexport function forceLoad(): void {\n // Noop\n}\n\n/**\n * This function is here to be API compatible with the loader.\n * @hidden\n */\nexport function onLoad(callback: () => void): void {\n callback();\n}\n\n/**\n * Wrap code within a try/catch block so the SDK is able to capture errors.\n *\n * @deprecated This function will be removed in v8.\n * It is not part of Sentry's official API and it's easily replaceable by using a try/catch block\n * and calling Sentry.captureException.\n *\n * @param fn A function to wrap.\n *\n * @returns The result of wrapped function call.\n */\n// TODO(v8): Remove this function\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function wrap(fn: (...args: any) => any): any {\n return internalWrap(fn)();\n}\n\nfunction startSessionOnHub(hub: Hub): void {\n hub.startSession({ ignoreDuration: true });\n hub.captureSession();\n}\n\n/**\n * Enable automatic Session Tracking for the initial page load.\n */\nfunction startSessionTracking(): void {\n if (typeof WINDOW.document === 'undefined') {\n __DEBUG_BUILD__ &&\n logger.warn('Session tracking in non-browser environment with @sentry/browser is not supported.');\n return;\n }\n\n const hub = getCurrentHub();\n\n // The only way for this to be false is for there to be a version mismatch between @sentry/browser (>= 6.0.0) and\n // @sentry/hub (< 5.27.0). In the simple case, there won't ever be such a mismatch, because the two packages are\n // pinned at the same version in package.json, but there are edge cases where it's possible. See\n // https://github.com/getsentry/sentry-javascript/issues/3207 and\n // https://github.com/getsentry/sentry-javascript/issues/3234 and\n // https://github.com/getsentry/sentry-javascript/issues/3278.\n if (!hub.captureSession) {\n return;\n }\n\n // The session duration for browser sessions does not track a meaningful\n // concept that can be used as a metric.\n // Automatically captured sessions are akin to page views, and thus we\n // discard their duration.\n startSessionOnHub(hub);\n\n // We want to create a session for every navigation as well\n addInstrumentationHandler('history', ({ from, to }) => {\n // Don't create an additional session for the initial route or if the location did not change\n if (!(from === undefined || from === to)) {\n startSessionOnHub(getCurrentHub());\n }\n });\n}\n\n/**\n * Captures user feedback and sends it to Sentry.\n */\nexport function captureUserFeedback(feedback: UserFeedback): void {\n const client = getCurrentHub().getClient<BrowserClient>();\n if (client) {\n client.captureUserFeedback(feedback);\n }\n}\n", "export { GlobalHandlers } from './globalhandlers.js';\nexport { TryCatch } from './trycatch.js';\nexport { Breadcrumbs } from './breadcrumbs.js';\nexport { LinkedErrors } from './linkederrors.js';\nexport { HttpContext } from './httpcontext.js';\nexport { Dedupe } from './dedupe.js';\n//# sourceMappingURL=index.js.map\n", "import { GLOBAL_OBJ } from '@sentry/utils';\n\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ & Window;\n", "import type { IdleTransaction, SpanStatusType } from '@sentry/core';\nimport { getActiveTransaction } from '@sentry/core';\nimport { logger } from '@sentry/utils';\n\nimport { WINDOW } from './types';\n\n/**\n * Add a listener that cancels and finishes a transaction when the global\n * document is hidden.\n */\nexport function registerBackgroundTabDetection(): void {\n if (WINDOW && WINDOW.document) {\n WINDOW.document.addEventListener('visibilitychange', () => {\n const activeTransaction = getActiveTransaction() as IdleTransaction;\n if (WINDOW.document.hidden && activeTransaction) {\n const statusType: SpanStatusType = 'cancelled';\n\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Transaction: ${statusType} -> since tab moved to the background, op: ${activeTransaction.op}`,\n );\n // We should not set status if it is already set, this prevent important statuses like\n // error or data loss from being overwritten on transaction.\n if (!activeTransaction.status) {\n activeTransaction.setStatus(statusType);\n }\n activeTransaction.setTag('visibilitychange', 'document.hidden');\n activeTransaction.finish();\n }\n });\n } else {\n __DEBUG_BUILD__ &&\n logger.warn('[Tracing] Could not set up background tab detection due to lack of global document');\n }\n}\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { Metric, ReportCallback } from '../types';\n\nexport const bindReporter = (\n callback: ReportCallback,\n metric: Metric,\n reportAllChanges?: boolean,\n): ((forceReport?: boolean) => void) => {\n let prevValue: number;\n let delta: number;\n return (forceReport?: boolean) => {\n if (metric.value >= 0) {\n if (forceReport || reportAllChanges) {\n delta = metric.value - (prevValue || 0);\n\n // Report the metric if there's a non-zero delta or if no previous\n // value exists (which can happen in the case of the document becoming\n // hidden when the metric value is 0).\n // See: https://github.com/GoogleChrome/web-vitals/issues/14\n if (delta || prevValue === undefined) {\n prevValue = metric.value;\n metric.delta = delta;\n callback(metric);\n }\n }\n }\n };\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Performantly generate a unique, 30-char string by combining a version\n * number, the current timestamp with a 13-digit number integer.\n * @return {string}\n */\nexport const generateUniqueID = (): string => {\n return `v3-${Date.now()}-${Math.floor(Math.random() * (9e12 - 1)) + 1e12}`;\n};\n", "/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport type { NavigationTimingPolyfillEntry } from '../types';\n\nconst getNavigationEntryFromPerformanceTiming = (): NavigationTimingPolyfillEntry => {\n // eslint-disable-next-line deprecation/deprecation\n const timing = WINDOW.performance.timing;\n // eslint-disable-next-line deprecation/deprecation\n const type = WINDOW.performance.navigation.type;\n\n const navigationEntry: { [key: string]: number | string } = {\n entryType: 'navigation',\n startTime: 0,\n type: type == 2 ? 'back_forward' : type === 1 ? 'reload' : 'navigate',\n };\n\n for (const key in timing) {\n if (key !== 'navigationStart' && key !== 'toJSON') {\n // eslint-disable-next-line deprecation/deprecation\n navigationEntry[key] = Math.max((timing[key as keyof PerformanceTiming] as number) - timing.navigationStart, 0);\n }\n }\n return navigationEntry as unknown as NavigationTimingPolyfillEntry;\n};\n\nexport const getNavigationEntry = (): PerformanceNavigationTiming | NavigationTimingPolyfillEntry | undefined => {\n if (WINDOW.__WEB_VITALS_POLYFILL__) {\n return (\n WINDOW.performance &&\n ((performance.getEntriesByType && performance.getEntriesByType('navigation')[0]) ||\n getNavigationEntryFromPerformanceTiming())\n );\n } else {\n return WINDOW.performance && performance.getEntriesByType && performance.getEntriesByType('navigation')[0];\n }\n};\n", "/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getNavigationEntry } from './getNavigationEntry';\n\nexport const getActivationStart = (): number => {\n const navEntry = getNavigationEntry();\n return (navEntry && navEntry.activationStart) || 0;\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport type { Metric } from '../types';\nimport { generateUniqueID } from './generateUniqueID';\nimport { getActivationStart } from './getActivationStart';\nimport { getNavigationEntry } from './getNavigationEntry';\n\nexport const initMetric = (name: Metric['name'], value?: number): Metric => {\n const navEntry = getNavigationEntry();\n let navigationType: Metric['navigationType'] = 'navigate';\n\n if (navEntry) {\n if (WINDOW.document.prerendering || getActivationStart() > 0) {\n navigationType = 'prerender';\n } else {\n navigationType = navEntry.type.replace(/_/g, '-') as Metric['navigationType'];\n }\n }\n\n return {\n name,\n value: typeof value === 'undefined' ? -1 : value,\n rating: 'good', // Will be updated if the value changes.\n delta: 0,\n entries: [],\n id: generateUniqueID(),\n navigationType,\n };\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { FirstInputPolyfillEntry, NavigationTimingPolyfillEntry, PerformancePaintTiming } from '../types';\n\nexport interface PerformanceEntryHandler {\n (entry: PerformanceEntry): void;\n}\n\ninterface PerformanceEntryMap {\n event: PerformanceEventTiming[];\n paint: PerformancePaintTiming[];\n 'layout-shift': LayoutShift[];\n 'largest-contentful-paint': LargestContentfulPaint[];\n 'first-input': PerformanceEventTiming[] | FirstInputPolyfillEntry[];\n navigation: PerformanceNavigationTiming[] | NavigationTimingPolyfillEntry[];\n resource: PerformanceResourceTiming[];\n longtask: PerformanceEntry[];\n}\n\n/**\n * Takes a performance entry type and a callback function, and creates a\n * `PerformanceObserver` instance that will observe the specified entry type\n * with buffering enabled and call the callback _for each entry_.\n *\n * This function also feature-detects entry support and wraps the logic in a\n * try/catch to avoid errors in unsupporting browsers.\n */\nexport const observe = <K extends keyof PerformanceEntryMap>(\n type: K,\n callback: (entries: PerformanceEntryMap[K]) => void,\n opts?: PerformanceObserverInit,\n): PerformanceObserver | undefined => {\n try {\n if (PerformanceObserver.supportedEntryTypes.includes(type)) {\n const po = new PerformanceObserver(list => {\n callback(list.getEntries() as PerformanceEntryMap[K]);\n });\n po.observe(\n Object.assign(\n {\n type,\n buffered: true,\n },\n opts || {},\n ) as PerformanceObserverInit,\n );\n return po;\n }\n } catch (e) {\n // Do nothing.\n }\n return;\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\n\nexport interface OnHiddenCallback {\n (event: Event): void;\n}\n\nexport const onHidden = (cb: OnHiddenCallback, once?: boolean): void => {\n const onHiddenOrPageHide = (event: Event): void => {\n if (event.type === 'pagehide' || WINDOW.document.visibilityState === 'hidden') {\n cb(event);\n if (once) {\n removeEventListener('visibilitychange', onHiddenOrPageHide, true);\n removeEventListener('pagehide', onHiddenOrPageHide, true);\n }\n }\n };\n addEventListener('visibilitychange', onHiddenOrPageHide, true);\n // Some browsers have buggy implementations of visibilitychange,\n // so we use pagehide in addition, just to be safe.\n addEventListener('pagehide', onHiddenOrPageHide, true);\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { CLSMetric, ReportCallback, StopListening } from './types';\n\n/**\n * Calculates the [CLS](https://web.dev/cls/) value for the current page and\n * calls the `callback` function once the value is ready to be reported, along\n * with all `layout-shift` performance entries that were used in the metric\n * value calculation. The reported value is a `double` (corresponding to a\n * [layout shift score](https://web.dev/cls/#layout-shift-score)).\n *\n * If the `reportAllChanges` configuration option is set to `true`, the\n * `callback` function will be called as soon as the value is initially\n * determined as well as any time the value changes throughout the page\n * lifespan.\n *\n * _**Important:** CLS should be continually monitored for changes throughout\n * the entire lifespan of a page—including if the user returns to the page after\n * it's been hidden/backgrounded. However, since browsers often [will not fire\n * additional callbacks once the user has backgrounded a\n * page](https://developer.chrome.com/blog/page-lifecycle-api/#advice-hidden),\n * `callback` is always called when the page's visibility state changes to\n * hidden. As a result, the `callback` function might be called multiple times\n * during the same page load._\n */\nexport const onCLS = (onReport: ReportCallback): StopListening | undefined => {\n const metric = initMetric('CLS', 0);\n let report: ReturnType<typeof bindReporter>;\n\n let sessionValue = 0;\n let sessionEntries: PerformanceEntry[] = [];\n\n // const handleEntries = (entries: Metric['entries']) => {\n const handleEntries = (entries: LayoutShift[]): void => {\n entries.forEach(entry => {\n // Only count layout shifts without recent user input.\n if (!entry.hadRecentInput) {\n const firstSessionEntry = sessionEntries[0];\n const lastSessionEntry = sessionEntries[sessionEntries.length - 1];\n\n // If the entry occurred less than 1 second after the previous entry and\n // less than 5 seconds after the first entry in the session, include the\n // entry in the current session. Otherwise, start a new session.\n if (\n sessionValue &&\n sessionEntries.length !== 0 &&\n entry.startTime - lastSessionEntry.startTime < 1000 &&\n entry.startTime - firstSessionEntry.startTime < 5000\n ) {\n sessionValue += entry.value;\n sessionEntries.push(entry);\n } else {\n sessionValue = entry.value;\n sessionEntries = [entry];\n }\n\n // If the current session value is larger than the current CLS value,\n // update CLS and the entries contributing to it.\n if (sessionValue > metric.value) {\n metric.value = sessionValue;\n metric.entries = sessionEntries;\n if (report) {\n report();\n }\n }\n }\n });\n };\n\n const po = observe('layout-shift', handleEntries);\n if (po) {\n report = bindReporter(onReport, metric);\n\n const stopListening = (): void => {\n handleEntries(po.takeRecords() as CLSMetric['entries']);\n report(true);\n };\n\n onHidden(stopListening);\n\n return stopListening;\n }\n\n return;\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport { onHidden } from './onHidden';\n\nlet firstHiddenTime = -1;\n\nconst initHiddenTime = (): number => {\n // If the document is hidden and not prerendering, assume it was always\n // hidden and the page was loaded in the background.\n return WINDOW.document.visibilityState === 'hidden' && !WINDOW.document.prerendering ? 0 : Infinity;\n};\n\nconst trackChanges = (): void => {\n // Update the time if/when the document becomes hidden.\n onHidden(({ timeStamp }) => {\n firstHiddenTime = timeStamp;\n }, true);\n};\n\nexport const getVisibilityWatcher = (): {\n readonly firstHiddenTime: number;\n} => {\n if (firstHiddenTime < 0) {\n // If the document is hidden when this code runs, assume it was hidden\n // since navigation start. This isn't a perfect heuristic, but it's the\n // best we can do until an API is available to support querying past\n // visibilityState.\n firstHiddenTime = initHiddenTime();\n trackChanges();\n }\n return {\n get firstHiddenTime() {\n return firstHiddenTime;\n },\n };\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { FIDMetric, PerformanceEventTiming, ReportCallback } from './types';\n\n/**\n * Calculates the [FID](https://web.dev/fid/) value for the current page and\n * calls the `callback` function once the value is ready, along with the\n * relevant `first-input` performance entry used to determine the value. The\n * reported value is a `DOMHighResTimeStamp`.\n *\n * _**Important:** since FID is only reported after the user interacts with the\n * page, it's possible that it will not be reported for some page loads._\n */\nexport const onFID = (onReport: ReportCallback): void => {\n const visibilityWatcher = getVisibilityWatcher();\n const metric = initMetric('FID');\n // eslint-disable-next-line prefer-const\n let report: ReturnType<typeof bindReporter>;\n\n const handleEntry = (entry: PerformanceEventTiming): void => {\n // Only report if the page wasn't hidden prior to the first input.\n if (entry.startTime < visibilityWatcher.firstHiddenTime) {\n metric.value = entry.processingStart - entry.startTime;\n metric.entries.push(entry);\n report(true);\n }\n };\n\n const handleEntries = (entries: FIDMetric['entries']): void => {\n (entries as PerformanceEventTiming[]).forEach(handleEntry);\n };\n\n const po = observe('first-input', handleEntries);\n report = bindReporter(onReport, metric);\n\n if (po) {\n onHidden(() => {\n handleEntries(po.takeRecords() as FIDMetric['entries']);\n po.disconnect();\n }, true);\n }\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { getActivationStart } from './lib/getActivationStart';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { LCPMetric, ReportCallback, StopListening } from './types';\n\nconst reportedMetricIDs: Record<string, boolean> = {};\n\n/**\n * Calculates the [LCP](https://web.dev/lcp/) value for the current page and\n * calls the `callback` function once the value is ready (along with the\n * relevant `largest-contentful-paint` performance entry used to determine the\n * value). The reported value is a `DOMHighResTimeStamp`.\n */\nexport const onLCP = (onReport: ReportCallback): StopListening | undefined => {\n const visibilityWatcher = getVisibilityWatcher();\n const metric = initMetric('LCP');\n let report: ReturnType<typeof bindReporter>;\n\n const handleEntries = (entries: LCPMetric['entries']): void => {\n const lastEntry = entries[entries.length - 1] as LargestContentfulPaint;\n if (lastEntry) {\n // The startTime attribute returns the value of the renderTime if it is\n // not 0, and the value of the loadTime otherwise. The activationStart\n // reference is used because LCP should be relative to page activation\n // rather than navigation start if the page was prerendered.\n const value = Math.max(lastEntry.startTime - getActivationStart(), 0);\n\n // Only report if the page wasn't hidden prior to LCP.\n if (value < visibilityWatcher.firstHiddenTime) {\n metric.value = value;\n metric.entries = [lastEntry];\n report();\n }\n }\n };\n\n const po = observe('largest-contentful-paint', handleEntries);\n\n if (po) {\n report = bindReporter(onReport, metric);\n\n const stopListening = (): void => {\n if (!reportedMetricIDs[metric.id]) {\n handleEntries(po.takeRecords() as LCPMetric['entries']);\n po.disconnect();\n reportedMetricIDs[metric.id] = true;\n report(true);\n }\n };\n\n // Stop listening after input. Note: while scrolling is an input that\n // stop LCP observation, it's unreliable since it can be programmatically\n // generated. See: https://github.com/GoogleChrome/web-vitals/issues/75\n ['keydown', 'click'].forEach(type => {\n addEventListener(type, stopListening, { once: true, capture: true });\n });\n\n onHidden(stopListening, true);\n\n return stopListening;\n }\n\n return;\n};\n", "import { getFunctionName, logger } from '@sentry/utils';\n\nimport { onCLS } from './web-vitals/getCLS';\nimport { onFID } from './web-vitals/getFID';\nimport { onLCP } from './web-vitals/getLCP';\nimport { observe } from './web-vitals/lib/observe';\n\ntype InstrumentHandlerTypePerformanceObserver = 'longtask' | 'event' | 'navigation' | 'paint' | 'resource';\n\ntype InstrumentHandlerTypeMetric = 'cls' | 'lcp' | 'fid';\n\n// We provide this here manually instead of relying on a global, as this is not available in non-browser environements\n// And we do not want to expose such types\ninterface PerformanceEntry {\n readonly duration: number;\n readonly entryType: string;\n readonly name: string;\n readonly startTime: number;\n toJSON(): Record<string, unknown>;\n}\n\ninterface Metric {\n /**\n * The name of the metric (in acronym form).\n */\n name: 'CLS' | 'FCP' | 'FID' | 'INP' | 'LCP' | 'TTFB';\n\n /**\n * The current value of the metric.\n */\n value: number;\n\n /**\n * The rating as to whether the metric value is within the \"good\",\n * \"needs improvement\", or \"poor\" thresholds of the metric.\n */\n rating: 'good' | 'needs-improvement' | 'poor';\n\n /**\n * The delta between the current value and the last-reported value.\n * On the first report, `delta` and `value` will always be the same.\n */\n delta: number;\n\n /**\n * A unique ID representing this particular metric instance. This ID can\n * be used by an analytics tool to dedupe multiple values sent for the same\n * metric instance, or to group multiple deltas together and calculate a\n * total. It can also be used to differentiate multiple different metric\n * instances sent from the same page, which can happen if the page is\n * restored from the back/forward cache (in that case new metrics object\n * get created).\n */\n id: string;\n\n /**\n * Any performance entries relevant to the metric value calculation.\n * The array may also be empty if the metric value was not based on any\n * entries (e.g. a CLS value of 0 given no layout shifts).\n */\n entries: PerformanceEntry[];\n\n /**\n * The type of navigation\n *\n * Navigation Timing API (or `undefined` if the browser doesn't\n * support that API). For pages that are restored from the bfcache, this\n * value will be 'back-forward-cache'.\n */\n navigationType: 'navigate' | 'reload' | 'back-forward' | 'back-forward-cache' | 'prerender';\n}\n\ntype InstrumentHandlerType = InstrumentHandlerTypeMetric | InstrumentHandlerTypePerformanceObserver;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype InstrumentHandlerCallback = (data: any) => void;\n\ntype CleanupHandlerCallback = () => void;\n\nconst handlers: { [key in InstrumentHandlerType]?: InstrumentHandlerCallback[] } = {};\nconst instrumented: { [key in InstrumentHandlerType]?: boolean } = {};\n\nlet _previousCls: Metric | undefined;\nlet _previousFid: Metric | undefined;\nlet _previousLcp: Metric | undefined;\n\n/**\n * Add a callback that will be triggered when a CLS metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addClsInstrumentationHandler(callback: (data: { metric: Metric }) => void): CleanupHandlerCallback {\n return addMetricObserver('cls', callback, instrumentCls, _previousCls);\n}\n\n/**\n * Add a callback that will be triggered when a LCP metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addLcpInstrumentationHandler(callback: (data: { metric: Metric }) => void): CleanupHandlerCallback {\n return addMetricObserver('lcp', callback, instrumentLcp, _previousLcp);\n}\n\n/**\n * Add a callback that will be triggered when a FID metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addFidInstrumentationHandler(callback: (data: { metric: Metric }) => void): CleanupHandlerCallback {\n return addMetricObserver('fid', callback, instrumentFid, _previousFid);\n}\n\nexport function addPerformanceInstrumentationHandler(\n type: 'event',\n callback: (data: { entries: (PerformanceEntry & { target?: unknown | null })[] }) => void,\n): CleanupHandlerCallback;\nexport function addPerformanceInstrumentationHandler(\n type: InstrumentHandlerTypePerformanceObserver,\n callback: (data: { entries: PerformanceEntry[] }) => void,\n): CleanupHandlerCallback;\n\n/**\n * Add a callback that will be triggered when a performance observer is triggered,\n * and receives the entries of the observer.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addPerformanceInstrumentationHandler(\n type: InstrumentHandlerTypePerformanceObserver,\n callback: (data: { entries: PerformanceEntry[] }) => void,\n): CleanupHandlerCallback {\n addHandler(type, callback);\n\n if (!instrumented[type]) {\n instrumentPerformanceObserver(type);\n instrumented[type] = true;\n }\n\n return getCleanupCallback(type, callback);\n}\n\n/** Trigger all handlers of a given type. */\nfunction triggerHandlers(type: InstrumentHandlerType, data: unknown): void {\n const typeHandlers = handlers[type];\n\n if (!typeHandlers || !typeHandlers.length) {\n return;\n }\n\n for (const handler of typeHandlers) {\n try {\n handler(data);\n } catch (e) {\n __DEBUG_BUILD__ &&\n logger.error(\n `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${getFunctionName(handler)}\\nError:`,\n e,\n );\n }\n }\n}\n\nfunction instrumentCls(): void {\n onCLS(metric => {\n triggerHandlers('cls', {\n metric,\n });\n _previousCls = metric;\n });\n}\n\nfunction instrumentFid(): void {\n onFID(metric => {\n triggerHandlers('fid', {\n metric,\n });\n _previousFid = metric;\n });\n}\n\nfunction instrumentLcp(): void {\n onLCP(metric => {\n triggerHandlers('lcp', {\n metric,\n });\n _previousLcp = metric;\n });\n}\n\nfunction addMetricObserver(\n type: InstrumentHandlerTypeMetric,\n callback: InstrumentHandlerCallback,\n instrumentFn: () => void,\n previousValue: Metric | undefined,\n): CleanupHandlerCallback {\n addHandler(type, callback);\n\n if (!instrumented[type]) {\n instrumentFn();\n instrumented[type] = true;\n }\n\n if (previousValue) {\n callback({ metric: previousValue });\n }\n\n return getCleanupCallback(type, callback);\n}\n\nfunction instrumentPerformanceObserver(type: InstrumentHandlerTypePerformanceObserver): void {\n const options: PerformanceObserverInit = {};\n\n // Special per-type options we want to use\n if (type === 'event') {\n options.durationThreshold = 0;\n }\n\n observe(\n type,\n entries => {\n triggerHandlers(type, { entries });\n },\n options,\n );\n}\n\nfunction addHandler(type: InstrumentHandlerType, handler: InstrumentHandlerCallback): void {\n handlers[type] = handlers[type] || [];\n (handlers[type] as InstrumentHandlerCallback[]).push(handler);\n}\n\n// Get a callback which can be called to remove the instrumentation handler\nfunction getCleanupCallback(type: InstrumentHandlerType, callback: InstrumentHandlerCallback): CleanupHandlerCallback {\n return () => {\n const typeHandlers = handlers[type];\n\n if (!typeHandlers) {\n return;\n }\n\n const index = typeHandlers.indexOf(callback);\n if (index !== -1) {\n typeHandlers.splice(index, 1);\n }\n };\n}\n", "import type { Transaction } from '@sentry/core';\nimport type { Span, SpanContext } from '@sentry/types';\n\n/**\n * Checks if a given value is a valid measurement value.\n */\nexport function isMeasurementValue(value: unknown): value is number {\n return typeof value === 'number' && isFinite(value);\n}\n\n/**\n * Helper function to start child on transactions. This function will make sure that the transaction will\n * use the start timestamp of the created child span if it is earlier than the transactions actual\n * start timestamp.\n */\nexport function _startChild(transaction: Transaction, { startTimestamp, ...ctx }: SpanContext): Span {\n if (startTimestamp && transaction.startTimestamp > startTimestamp) {\n transaction.startTimestamp = startTimestamp;\n }\n\n return transaction.startChild({\n startTimestamp,\n ...ctx,\n });\n}\n", "/* eslint-disable max-lines */\nimport type { IdleTransaction, Transaction } from '@sentry/core';\nimport { getActiveTransaction } from '@sentry/core';\nimport type { Measurements } from '@sentry/types';\nimport { browserPerformanceTimeOrigin, htmlTreeAsString, logger } from '@sentry/utils';\n\nimport {\n addClsInstrumentationHandler,\n addFidInstrumentationHandler,\n addLcpInstrumentationHandler,\n addPerformanceInstrumentationHandler,\n} from '../instrument';\nimport { WINDOW } from '../types';\nimport { getVisibilityWatcher } from '../web-vitals/lib/getVisibilityWatcher';\nimport type { NavigatorDeviceMemory, NavigatorNetworkInformation } from '../web-vitals/types';\nimport { _startChild, isMeasurementValue } from './utils';\n\n/**\n * Converts from milliseconds to seconds\n * @param time time in ms\n */\nfunction msToSec(time: number): number {\n return time / 1000;\n}\n\nfunction getBrowserPerformanceAPI(): Performance | undefined {\n // @ts-expect-error we want to make sure all of these are available, even if TS is sure they are\n return WINDOW && WINDOW.addEventListener && WINDOW.performance;\n}\n\nlet _performanceCursor: number = 0;\n\nlet _measurements: Measurements = {};\nlet _lcpEntry: LargestContentfulPaint | undefined;\nlet _clsEntry: LayoutShift | undefined;\n\n/**\n * Start tracking web vitals\n *\n * @returns A function that forces web vitals collection\n */\nexport function startTrackingWebVitals(): () => void {\n const performance = getBrowserPerformanceAPI();\n if (performance && browserPerformanceTimeOrigin) {\n // @ts-expect-error we want to make sure all of these are available, even if TS is sure they are\n if (performance.mark) {\n WINDOW.performance.mark('sentry-tracing-init');\n }\n const fidCallback = _trackFID();\n const clsCallback = _trackCLS();\n const lcpCallback = _trackLCP();\n\n return (): void => {\n fidCallback();\n clsCallback();\n lcpCallback();\n };\n }\n\n return () => undefined;\n}\n\n/**\n * Start tracking long tasks.\n */\nexport function startTrackingLongTasks(): void {\n addPerformanceInstrumentationHandler('longtask', ({ entries }) => {\n for (const entry of entries) {\n const transaction = getActiveTransaction() as IdleTransaction | undefined;\n if (!transaction) {\n return;\n }\n const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n const duration = msToSec(entry.duration);\n\n transaction.startChild({\n description: 'Main UI thread blocked',\n op: 'ui.long-task',\n origin: 'auto.ui.browser.metrics',\n startTimestamp: startTime,\n endTimestamp: startTime + duration,\n });\n }\n });\n}\n\n/**\n * Start tracking interaction events.\n */\nexport function startTrackingInteractions(): void {\n addPerformanceInstrumentationHandler('event', ({ entries }) => {\n for (const entry of entries) {\n const transaction = getActiveTransaction() as IdleTransaction | undefined;\n if (!transaction) {\n return;\n }\n\n if (entry.name === 'click') {\n const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n const duration = msToSec(entry.duration);\n\n transaction.startChild({\n description: htmlTreeAsString(entry.target),\n op: `ui.interaction.${entry.name}`,\n origin: 'auto.ui.browser.metrics',\n startTimestamp: startTime,\n endTimestamp: startTime + duration,\n });\n }\n }\n });\n}\n\n/** Starts tracking the Cumulative Layout Shift on the current page. */\nfunction _trackCLS(): () => void {\n return addClsInstrumentationHandler(({ metric }) => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding CLS');\n _measurements['cls'] = { value: metric.value, unit: '' };\n _clsEntry = entry as LayoutShift;\n });\n}\n\n/** Starts tracking the Largest Contentful Paint on the current page. */\nfunction _trackLCP(): () => void {\n return addLcpInstrumentationHandler(({ metric }) => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding LCP');\n _measurements['lcp'] = { value: metric.value, unit: 'millisecond' };\n _lcpEntry = entry as LargestContentfulPaint;\n });\n}\n\n/** Starts tracking the First Input Delay on the current page. */\nfunction _trackFID(): () => void {\n return addFidInstrumentationHandler(({ metric }) => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n const timeOrigin = msToSec(browserPerformanceTimeOrigin as number);\n const startTime = msToSec(entry.startTime);\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FID');\n _measurements['fid'] = { value: metric.value, unit: 'millisecond' };\n _measurements['mark.fid'] = { value: timeOrigin + startTime, unit: 'second' };\n });\n}\n\n/** Add performance related spans to a transaction */\nexport function addPerformanceEntries(transaction: Transaction): void {\n const performance = getBrowserPerformanceAPI();\n if (!performance || !WINDOW.performance.getEntries || !browserPerformanceTimeOrigin) {\n // Gatekeeper if performance API not available\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Tracing] Adding & adjusting spans using Performance API');\n const timeOrigin = msToSec(browserPerformanceTimeOrigin);\n\n const performanceEntries = performance.getEntries();\n\n let responseStartTimestamp: number | undefined;\n let requestStartTimestamp: number | undefined;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n performanceEntries.slice(_performanceCursor).forEach((entry: Record<string, any>) => {\n const startTime = msToSec(entry.startTime);\n const duration = msToSec(entry.duration);\n\n if (transaction.op === 'navigation' && timeOrigin + startTime < transaction.startTimestamp) {\n return;\n }\n\n switch (entry.entryType) {\n case 'navigation': {\n _addNavigationSpans(transaction, entry, timeOrigin);\n responseStartTimestamp = timeOrigin + msToSec(entry.responseStart);\n requestStartTimestamp = timeOrigin + msToSec(entry.requestStart);\n break;\n }\n case 'mark':\n case 'paint':\n case 'measure': {\n _addMeasureSpans(transaction, entry, startTime, duration, timeOrigin);\n\n // capture web vitals\n const firstHidden = getVisibilityWatcher();\n // Only report if the page wasn't hidden prior to the web vital.\n const shouldRecord = entry.startTime < firstHidden.firstHiddenTime;\n\n if (entry.name === 'first-paint' && shouldRecord) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FP');\n _measurements['fp'] = { value: entry.startTime, unit: 'millisecond' };\n }\n if (entry.name === 'first-contentful-paint' && shouldRecord) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FCP');\n _measurements['fcp'] = { value: entry.startTime, unit: 'millisecond' };\n }\n break;\n }\n case 'resource': {\n const resourceName = (entry.name as string).replace(WINDOW.location.origin, '');\n _addResourceSpans(transaction, entry, resourceName, startTime, duration, timeOrigin);\n break;\n }\n default:\n // Ignore other entry types.\n }\n });\n\n _performanceCursor = Math.max(performanceEntries.length - 1, 0);\n\n _trackNavigator(transaction);\n\n // Measurements are only available for pageload transactions\n if (transaction.op === 'pageload') {\n // Generate TTFB (Time to First Byte), which measured as the time between the beginning of the transaction and the\n // start of the response in milliseconds\n if (typeof responseStartTimestamp === 'number') {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding TTFB');\n _measurements['ttfb'] = {\n value: (responseStartTimestamp - transaction.startTimestamp) * 1000,\n unit: 'millisecond',\n };\n\n if (typeof requestStartTimestamp === 'number' && requestStartTimestamp <= responseStartTimestamp) {\n // Capture the time spent making the request and receiving the first byte of the response.\n // This is the time between the start of the request and the start of the response in milliseconds.\n _measurements['ttfb.requestTime'] = {\n value: (responseStartTimestamp - requestStartTimestamp) * 1000,\n unit: 'millisecond',\n };\n }\n }\n\n ['fcp', 'fp', 'lcp'].forEach(name => {\n if (!_measurements[name] || timeOrigin >= transaction.startTimestamp) {\n return;\n }\n // The web vitals, fcp, fp, lcp, and ttfb, all measure relative to timeOrigin.\n // Unfortunately, timeOrigin is not captured within the transaction span data, so these web vitals will need\n // to be adjusted to be relative to transaction.startTimestamp.\n const oldValue = _measurements[name].value;\n const measurementTimestamp = timeOrigin + msToSec(oldValue);\n\n // normalizedValue should be in milliseconds\n const normalizedValue = Math.abs((measurementTimestamp - transaction.startTimestamp) * 1000);\n const delta = normalizedValue - oldValue;\n\n __DEBUG_BUILD__ &&\n logger.log(`[Measurements] Normalized ${name} from ${oldValue} to ${normalizedValue} (${delta})`);\n _measurements[name].value = normalizedValue;\n });\n\n const fidMark = _measurements['mark.fid'];\n if (fidMark && _measurements['fid']) {\n // create span for FID\n _startChild(transaction, {\n description: 'first input delay',\n endTimestamp: fidMark.value + msToSec(_measurements['fid'].value),\n op: 'ui.action',\n origin: 'auto.ui.browser.metrics',\n startTimestamp: fidMark.value,\n });\n\n // Delete mark.fid as we don't want it to be part of final payload\n delete _measurements['mark.fid'];\n }\n\n // If FCP is not recorded we should not record the cls value\n // according to the new definition of CLS.\n if (!('fcp' in _measurements)) {\n delete _measurements.cls;\n }\n\n Object.keys(_measurements).forEach(measurementName => {\n transaction.setMeasurement(\n measurementName,\n _measurements[measurementName].value,\n _measurements[measurementName].unit,\n );\n });\n\n _tagMetricInfo(transaction);\n }\n\n _lcpEntry = undefined;\n _clsEntry = undefined;\n _measurements = {};\n}\n\n/** Create measure related spans */\nexport function _addMeasureSpans(\n transaction: Transaction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n entry: Record<string, any>,\n startTime: number,\n duration: number,\n timeOrigin: number,\n): number {\n const measureStartTimestamp = timeOrigin + startTime;\n const measureEndTimestamp = measureStartTimestamp + duration;\n\n _startChild(transaction, {\n description: entry.name as string,\n endTimestamp: measureEndTimestamp,\n op: entry.entryType as string,\n origin: 'auto.resource.browser.metrics',\n startTimestamp: measureStartTimestamp,\n });\n\n return measureStartTimestamp;\n}\n\n/** Instrument navigation entries */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _addNavigationSpans(transaction: Transaction, entry: Record<string, any>, timeOrigin: number): void {\n ['unloadEvent', 'redirect', 'domContentLoadedEvent', 'loadEvent', 'connect'].forEach(event => {\n _addPerformanceNavigationTiming(transaction, entry, event, timeOrigin);\n });\n _addPerformanceNavigationTiming(transaction, entry, 'secureConnection', timeOrigin, 'TLS/SSL', 'connectEnd');\n _addPerformanceNavigationTiming(transaction, entry, 'fetch', timeOrigin, 'cache', 'domainLookupStart');\n _addPerformanceNavigationTiming(transaction, entry, 'domainLookup', timeOrigin, 'DNS');\n _addRequest(transaction, entry, timeOrigin);\n}\n\n/** Create performance navigation related spans */\nfunction _addPerformanceNavigationTiming(\n transaction: Transaction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n entry: Record<string, any>,\n event: string,\n timeOrigin: number,\n description?: string,\n eventEnd?: string,\n): void {\n const end = eventEnd ? (entry[eventEnd] as number | undefined) : (entry[`${event}End`] as number | undefined);\n const start = entry[`${event}Start`] as number | undefined;\n if (!start || !end) {\n return;\n }\n _startChild(transaction, {\n op: 'browser',\n origin: 'auto.browser.browser.metrics',\n description: description || event,\n startTimestamp: timeOrigin + msToSec(start),\n endTimestamp: timeOrigin + msToSec(end),\n });\n}\n\n/** Create request and response related spans */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _addRequest(transaction: Transaction, entry: Record<string, any>, timeOrigin: number): void {\n _startChild(transaction, {\n op: 'browser',\n origin: 'auto.browser.browser.metrics',\n description: 'request',\n startTimestamp: timeOrigin + msToSec(entry.requestStart as number),\n endTimestamp: timeOrigin + msToSec(entry.responseEnd as number),\n });\n\n _startChild(transaction, {\n op: 'browser',\n origin: 'auto.browser.browser.metrics',\n description: 'response',\n startTimestamp: timeOrigin + msToSec(entry.responseStart as number),\n endTimestamp: timeOrigin + msToSec(entry.responseEnd as number),\n });\n}\n\nexport interface ResourceEntry extends Record<string, unknown> {\n initiatorType?: string;\n transferSize?: number;\n encodedBodySize?: number;\n decodedBodySize?: number;\n renderBlockingStatus?: string;\n}\n\n/** Create resource-related spans */\nexport function _addResourceSpans(\n transaction: Transaction,\n entry: ResourceEntry,\n resourceName: string,\n startTime: number,\n duration: number,\n timeOrigin: number,\n): void {\n // we already instrument based on fetch and xhr, so we don't need to\n // duplicate spans here.\n if (entry.initiatorType === 'xmlhttprequest' || entry.initiatorType === 'fetch') {\n return;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const data: Record<string, any> = {};\n if ('transferSize' in entry) {\n data['http.response_transfer_size'] = entry.transferSize;\n }\n if ('encodedBodySize' in entry) {\n data['http.response_content_length'] = entry.encodedBodySize;\n }\n if ('decodedBodySize' in entry) {\n data['http.decoded_response_content_length'] = entry.decodedBodySize;\n }\n if ('renderBlockingStatus' in entry) {\n data['resource.render_blocking_status'] = entry.renderBlockingStatus;\n }\n\n const startTimestamp = timeOrigin + startTime;\n const endTimestamp = startTimestamp + duration;\n\n _startChild(transaction, {\n description: resourceName,\n endTimestamp,\n op: entry.initiatorType ? `resource.${entry.initiatorType}` : 'resource.other',\n origin: 'auto.resource.browser.metrics',\n startTimestamp,\n data,\n });\n}\n\n/**\n * Capture the information of the user agent.\n */\nfunction _trackNavigator(transaction: Transaction): void {\n const navigator = WINDOW.navigator as null | (Navigator & NavigatorNetworkInformation & NavigatorDeviceMemory);\n if (!navigator) {\n return;\n }\n\n // track network connectivity\n const connection = navigator.connection;\n if (connection) {\n if (connection.effectiveType) {\n transaction.setTag('effectiveConnectionType', connection.effectiveType);\n }\n\n if (connection.type) {\n transaction.setTag('connectionType', connection.type);\n }\n\n if (isMeasurementValue(connection.rtt)) {\n _measurements['connection.rtt'] = { value: connection.rtt, unit: 'millisecond' };\n }\n }\n\n if (isMeasurementValue(navigator.deviceMemory)) {\n transaction.setTag('deviceMemory', `${navigator.deviceMemory} GB`);\n }\n\n if (isMeasurementValue(navigator.hardwareConcurrency)) {\n transaction.setTag('hardwareConcurrency', String(navigator.hardwareConcurrency));\n }\n}\n\n/** Add LCP / CLS data to transaction to allow debugging */\nfunction _tagMetricInfo(transaction: Transaction): void {\n if (_lcpEntry) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding LCP Data');\n\n // Capture Properties of the LCP element that contributes to the LCP.\n\n if (_lcpEntry.element) {\n transaction.setTag('lcp.element', htmlTreeAsString(_lcpEntry.element));\n }\n\n if (_lcpEntry.id) {\n transaction.setTag('lcp.id', _lcpEntry.id);\n }\n\n if (_lcpEntry.url) {\n // Trim URL to the first 200 characters.\n transaction.setTag('lcp.url', _lcpEntry.url.trim().slice(0, 200));\n }\n\n transaction.setTag('lcp.size', _lcpEntry.size);\n }\n\n // See: https://developer.mozilla.org/en-US/docs/Web/API/LayoutShift\n if (_clsEntry && _clsEntry.sources) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding CLS Data');\n _clsEntry.sources.forEach((source, index) =>\n transaction.setTag(`cls.source.${index + 1}`, htmlTreeAsString(source.node)),\n );\n }\n}\n", "/* eslint-disable max-lines */\nimport { getCurrentHub, getDynamicSamplingContextFromClient, hasTracingEnabled } from '@sentry/core';\nimport type { Client, Scope, Span } from '@sentry/types';\nimport {\n addInstrumentationHandler,\n BAGGAGE_HEADER_NAME,\n browserPerformanceTimeOrigin,\n dynamicSamplingContextToSentryBaggageHeader,\n generateSentryTraceHeader,\n isInstanceOf,\n SENTRY_XHR_DATA_KEY,\n stringMatchesSomePattern,\n} from '@sentry/utils';\n\nimport { addPerformanceInstrumentationHandler } from './instrument';\n\nexport const DEFAULT_TRACE_PROPAGATION_TARGETS = ['localhost', /^\\/(?!\\/)/];\n\n/** Options for Request Instrumentation */\nexport interface RequestInstrumentationOptions {\n /**\n * @deprecated Will be removed in v8.\n * Use `shouldCreateSpanForRequest` to control span creation and `tracePropagationTargets` to control\n * trace header attachment.\n */\n tracingOrigins: Array<string | RegExp>;\n\n /**\n * List of strings and/or regexes used to determine which outgoing requests will have `sentry-trace` and `baggage`\n * headers attached.\n *\n * @deprecated Use the top-level `tracePropagationTargets` option in `Sentry.init` instead.\n * This option will be removed in v8.\n *\n * Default: ['localhost', /^\\//] @see {DEFAULT_TRACE_PROPAGATION_TARGETS}\n */\n tracePropagationTargets: Array<string | RegExp>;\n\n /**\n * Flag to disable patching all together for fetch requests.\n *\n * Default: true\n */\n traceFetch: boolean;\n\n /**\n * Flag to disable patching all together for xhr requests.\n *\n * Default: true\n */\n traceXHR: boolean;\n\n /**\n * If true, Sentry will capture http timings and add them to the corresponding http spans.\n *\n * Default: true\n */\n enableHTTPTimings: boolean;\n\n /**\n * This function will be called before creating a span for a request with the given url.\n * Return false if you don't want a span for the given url.\n *\n * Default: (url: string) => true\n */\n shouldCreateSpanForRequest?(this: void, url: string): boolean;\n}\n\n/** Data returned from fetch callback */\nexport interface FetchData {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n args: any[]; // the arguments passed to the fetch call itself\n fetchData?: {\n method: string;\n url: string;\n // span_id\n __span?: string;\n };\n\n // TODO Should this be unknown instead? If we vendor types, make it a Response\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n response?: any;\n error?: unknown;\n\n startTimestamp: number;\n endTimestamp?: number;\n}\n\n/** Data returned from XHR request */\nexport interface XHRData {\n xhr?: {\n [SENTRY_XHR_DATA_KEY]?: {\n method: string;\n url: string;\n status_code: number;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: Record<string, any>;\n };\n __sentry_xhr_span_id__?: string;\n setRequestHeader?: (key: string, val: string) => void;\n getRequestHeader?: (key: string) => string;\n __sentry_own_request__?: boolean;\n };\n startTimestamp: number;\n endTimestamp?: number;\n}\n\ntype PolymorphicRequestHeaders =\n | Record<string, string | undefined>\n | Array<[string, string]>\n // the below is not preicsely the Header type used in Request, but it'll pass duck-typing\n | {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n append: (key: string, value: string) => void;\n get: (key: string) => string | null | undefined;\n };\n\nexport const defaultRequestInstrumentationOptions: RequestInstrumentationOptions = {\n traceFetch: true,\n traceXHR: true,\n enableHTTPTimings: true,\n // TODO (v8): Remove this property\n tracingOrigins: DEFAULT_TRACE_PROPAGATION_TARGETS,\n tracePropagationTargets: DEFAULT_TRACE_PROPAGATION_TARGETS,\n};\n\n/** Registers span creators for xhr and fetch requests */\nexport function instrumentOutgoingRequests(_options?: Partial<RequestInstrumentationOptions>): void {\n const {\n traceFetch,\n traceXHR,\n // eslint-disable-next-line deprecation/deprecation\n tracePropagationTargets,\n // eslint-disable-next-line deprecation/deprecation\n tracingOrigins,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n } = {\n traceFetch: defaultRequestInstrumentationOptions.traceFetch,\n traceXHR: defaultRequestInstrumentationOptions.traceXHR,\n ..._options,\n };\n\n const shouldCreateSpan =\n typeof shouldCreateSpanForRequest === 'function' ? shouldCreateSpanForRequest : (_: string) => true;\n\n // TODO(v8) Remove tracingOrigins here\n // The only reason we're passing it in here is because this instrumentOutgoingRequests function is publicly exported\n // and we don't want to break the API. We can remove it in v8.\n const shouldAttachHeadersWithTargets = (url: string): boolean =>\n shouldAttachHeaders(url, tracePropagationTargets || tracingOrigins);\n\n const spans: Record<string, Span> = {};\n\n if (traceFetch) {\n addInstrumentationHandler('fetch', (handlerData: FetchData) => {\n const createdSpan = fetchCallback(handlerData, shouldCreateSpan, shouldAttachHeadersWithTargets, spans);\n if (enableHTTPTimings && createdSpan) {\n addHTTPTimings(createdSpan);\n }\n });\n }\n\n if (traceXHR) {\n addInstrumentationHandler('xhr', (handlerData: XHRData) => {\n const createdSpan = xhrCallback(handlerData, shouldCreateSpan, shouldAttachHeadersWithTargets, spans);\n if (enableHTTPTimings && createdSpan) {\n addHTTPTimings(createdSpan);\n }\n });\n }\n}\n\nfunction isPerformanceResourceTiming(entry: PerformanceEntry): entry is PerformanceResourceTiming {\n return (\n entry.entryType === 'resource' &&\n 'initiatorType' in entry &&\n typeof (entry as PerformanceResourceTiming).nextHopProtocol === 'string' &&\n (entry.initiatorType === 'fetch' || entry.initiatorType === 'xmlhttprequest')\n );\n}\n\n/**\n * Creates a temporary observer to listen to the next fetch/xhr resourcing timings,\n * so that when timings hit their per-browser limit they don't need to be removed.\n *\n * @param span A span that has yet to be finished, must contain `url` on data.\n */\nfunction addHTTPTimings(span: Span): void {\n const url = span.data.url;\n\n if (!url) {\n return;\n }\n\n const cleanup = addPerformanceInstrumentationHandler('resource', ({ entries }) => {\n entries.forEach(entry => {\n if (isPerformanceResourceTiming(entry) && entry.name.endsWith(url)) {\n const spanData = resourceTimingEntryToSpanData(entry);\n spanData.forEach(data => span.setData(...data));\n // In the next tick, clean this handler up\n // We have to wait here because otherwise this cleans itself up before it is fully done\n setTimeout(cleanup);\n }\n });\n });\n}\n\n/**\n * Converts ALPN protocol ids to name and version.\n *\n * (https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids)\n * @param nextHopProtocol PerformanceResourceTiming.nextHopProtocol\n */\nexport function extractNetworkProtocol(nextHopProtocol: string): { name: string; version: string } {\n let name = 'unknown';\n let version = 'unknown';\n let _name = '';\n for (const char of nextHopProtocol) {\n // http/1.1 etc.\n if (char === '/') {\n [name, version] = nextHopProtocol.split('/');\n break;\n }\n // h2, h3 etc.\n if (!isNaN(Number(char))) {\n name = _name === 'h' ? 'http' : _name;\n version = nextHopProtocol.split(_name)[1];\n break;\n }\n _name += char;\n }\n if (_name === nextHopProtocol) {\n // webrtc, ftp, etc.\n name = _name;\n }\n return { name, version };\n}\n\nfunction getAbsoluteTime(time: number = 0): number {\n return ((browserPerformanceTimeOrigin || performance.timeOrigin) + time) / 1000;\n}\n\nfunction resourceTimingEntryToSpanData(resourceTiming: PerformanceResourceTiming): [string, string | number][] {\n const { name, version } = extractNetworkProtocol(resourceTiming.nextHopProtocol);\n\n const timingSpanData: [string, string | number][] = [];\n\n timingSpanData.push(['network.protocol.version', version], ['network.protocol.name', name]);\n\n if (!browserPerformanceTimeOrigin) {\n return timingSpanData;\n }\n return [\n ...timingSpanData,\n ['http.request.redirect_start', getAbsoluteTime(resourceTiming.redirectStart)],\n ['http.request.fetch_start', getAbsoluteTime(resourceTiming.fetchStart)],\n ['http.request.domain_lookup_start', getAbsoluteTime(resourceTiming.domainLookupStart)],\n ['http.request.domain_lookup_end', getAbsoluteTime(resourceTiming.domainLookupEnd)],\n ['http.request.connect_start', getAbsoluteTime(resourceTiming.connectStart)],\n ['http.request.secure_connection_start', getAbsoluteTime(resourceTiming.secureConnectionStart)],\n ['http.request.connection_end', getAbsoluteTime(resourceTiming.connectEnd)],\n ['http.request.request_start', getAbsoluteTime(resourceTiming.requestStart)],\n ['http.request.response_start', getAbsoluteTime(resourceTiming.responseStart)],\n ['http.request.response_end', getAbsoluteTime(resourceTiming.responseEnd)],\n ];\n}\n\n/**\n * A function that determines whether to attach tracing headers to a request.\n * This was extracted from `instrumentOutgoingRequests` to make it easier to test shouldAttachHeaders.\n * We only export this fuction for testing purposes.\n */\nexport function shouldAttachHeaders(url: string, tracePropagationTargets: (string | RegExp)[] | undefined): boolean {\n return stringMatchesSomePattern(url, tracePropagationTargets || DEFAULT_TRACE_PROPAGATION_TARGETS);\n}\n\n/**\n * Create and track fetch request spans\n *\n * @returns Span if a span was created, otherwise void.\n */\nexport function fetchCallback(\n handlerData: FetchData,\n shouldCreateSpan: (url: string) => boolean,\n shouldAttachHeaders: (url: string) => boolean,\n spans: Record<string, Span>,\n): Span | undefined {\n if (!hasTracingEnabled() || !handlerData.fetchData) {\n return undefined;\n }\n\n const shouldCreateSpanResult = shouldCreateSpan(handlerData.fetchData.url);\n\n if (handlerData.endTimestamp && shouldCreateSpanResult) {\n const spanId = handlerData.fetchData.__span;\n if (!spanId) return;\n\n const span = spans[spanId];\n if (span) {\n if (handlerData.response) {\n // TODO (kmclb) remove this once types PR goes through\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n span.setHttpStatus(handlerData.response.status);\n\n const contentLength: string =\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n handlerData.response && handlerData.response.headers && handlerData.response.headers.get('content-length');\n\n const contentLengthNum = parseInt(contentLength);\n if (contentLengthNum > 0) {\n span.setData('http.response_content_length', contentLengthNum);\n }\n } else if (handlerData.error) {\n span.setStatus('internal_error');\n }\n span.finish();\n\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete spans[spanId];\n }\n return undefined;\n }\n\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const client = hub.getClient();\n const parentSpan = scope.getSpan();\n\n const { method, url } = handlerData.fetchData;\n\n const span =\n shouldCreateSpanResult && parentSpan\n ? parentSpan.startChild({\n data: {\n url,\n type: 'fetch',\n 'http.method': method,\n },\n description: `${method} ${url}`,\n op: 'http.client',\n origin: 'auto.http.browser',\n })\n : undefined;\n\n if (span) {\n handlerData.fetchData.__span = span.spanId;\n spans[span.spanId] = span;\n }\n\n if (shouldAttachHeaders(handlerData.fetchData.url) && client) {\n const request: string | Request = handlerData.args[0];\n\n // In case the user hasn't set the second argument of a fetch call we default it to `{}`.\n handlerData.args[1] = handlerData.args[1] || {};\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const options: { [key: string]: any } = handlerData.args[1];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n options.headers = addTracingHeadersToFetchRequest(request, client, scope, options, span);\n }\n\n return span;\n}\n\n/**\n * Adds sentry-trace and baggage headers to the various forms of fetch headers\n */\nexport function addTracingHeadersToFetchRequest(\n request: string | unknown, // unknown is actually type Request but we can't export DOM types from this package,\n client: Client,\n scope: Scope,\n options: {\n headers?:\n | {\n [key: string]: string[] | string | undefined;\n }\n | PolymorphicRequestHeaders;\n },\n requestSpan?: Span,\n): PolymorphicRequestHeaders | undefined {\n const span = requestSpan || scope.getSpan();\n\n const transaction = span && span.transaction;\n\n const { traceId, sampled, dsc } = scope.getPropagationContext();\n\n const sentryTraceHeader = span ? span.toTraceparent() : generateSentryTraceHeader(traceId, undefined, sampled);\n const dynamicSamplingContext = transaction\n ? transaction.getDynamicSamplingContext()\n : dsc\n ? dsc\n : getDynamicSamplingContextFromClient(traceId, client, scope);\n\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n\n const headers =\n typeof Request !== 'undefined' && isInstanceOf(request, Request) ? (request as Request).headers : options.headers;\n\n if (!headers) {\n return { 'sentry-trace': sentryTraceHeader, baggage: sentryBaggageHeader };\n } else if (typeof Headers !== 'undefined' && isInstanceOf(headers, Headers)) {\n const newHeaders = new Headers(headers as Headers);\n\n newHeaders.append('sentry-trace', sentryTraceHeader);\n\n if (sentryBaggageHeader) {\n // If the same header is appended multiple times the browser will merge the values into a single request header.\n // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n newHeaders.append(BAGGAGE_HEADER_NAME, sentryBaggageHeader);\n }\n\n return newHeaders as PolymorphicRequestHeaders;\n } else if (Array.isArray(headers)) {\n const newHeaders = [...headers, ['sentry-trace', sentryTraceHeader]];\n\n if (sentryBaggageHeader) {\n // If there are multiple entries with the same key, the browser will merge the values into a single request header.\n // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n newHeaders.push([BAGGAGE_HEADER_NAME, sentryBaggageHeader]);\n }\n\n return newHeaders as PolymorphicRequestHeaders;\n } else {\n const existingBaggageHeader = 'baggage' in headers ? headers.baggage : undefined;\n const newBaggageHeaders: string[] = [];\n\n if (Array.isArray(existingBaggageHeader)) {\n newBaggageHeaders.push(...existingBaggageHeader);\n } else if (existingBaggageHeader) {\n newBaggageHeaders.push(existingBaggageHeader);\n }\n\n if (sentryBaggageHeader) {\n newBaggageHeaders.push(sentryBaggageHeader);\n }\n\n return {\n ...(headers as Exclude<typeof headers, Headers>),\n 'sentry-trace': sentryTraceHeader,\n baggage: newBaggageHeaders.length > 0 ? newBaggageHeaders.join(',') : undefined,\n };\n }\n}\n\n/**\n * Create and track xhr request spans\n *\n * @returns Span if a span was created, otherwise void.\n */\n// eslint-disable-next-line complexity\nexport function xhrCallback(\n handlerData: XHRData,\n shouldCreateSpan: (url: string) => boolean,\n shouldAttachHeaders: (url: string) => boolean,\n spans: Record<string, Span>,\n): Span | undefined {\n const xhr = handlerData.xhr;\n const sentryXhrData = xhr && xhr[SENTRY_XHR_DATA_KEY];\n\n if (!hasTracingEnabled() || (xhr && xhr.__sentry_own_request__) || !xhr || !sentryXhrData) {\n return undefined;\n }\n\n const shouldCreateSpanResult = shouldCreateSpan(sentryXhrData.url);\n\n // check first if the request has finished and is tracked by an existing span which should now end\n if (handlerData.endTimestamp && shouldCreateSpanResult) {\n const spanId = xhr.__sentry_xhr_span_id__;\n if (!spanId) return;\n\n const span = spans[spanId];\n if (span) {\n span.setHttpStatus(sentryXhrData.status_code);\n span.finish();\n\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete spans[spanId];\n }\n return undefined;\n }\n\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const parentSpan = scope.getSpan();\n\n const span =\n shouldCreateSpanResult && parentSpan\n ? parentSpan.startChild({\n data: {\n ...sentryXhrData.data,\n type: 'xhr',\n 'http.method': sentryXhrData.method,\n url: sentryXhrData.url,\n },\n description: `${sentryXhrData.method} ${sentryXhrData.url}`,\n op: 'http.client',\n origin: 'auto.http.browser',\n })\n : undefined;\n\n if (span) {\n xhr.__sentry_xhr_span_id__ = span.spanId;\n spans[xhr.__sentry_xhr_span_id__] = span;\n }\n\n if (xhr.setRequestHeader && shouldAttachHeaders(sentryXhrData.url)) {\n if (span) {\n const transaction = span && span.transaction;\n const dynamicSamplingContext = transaction && transaction.getDynamicSamplingContext();\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n setHeaderOnXhr(xhr, span.toTraceparent(), sentryBaggageHeader);\n } else {\n const client = hub.getClient();\n const { traceId, sampled, dsc } = scope.getPropagationContext();\n const sentryTraceHeader = generateSentryTraceHeader(traceId, undefined, sampled);\n const dynamicSamplingContext =\n dsc || (client ? getDynamicSamplingContextFromClient(traceId, client, scope) : undefined);\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n setHeaderOnXhr(xhr, sentryTraceHeader, sentryBaggageHeader);\n }\n }\n\n return span;\n}\n\nfunction setHeaderOnXhr(\n xhr: NonNullable<XHRData['xhr']>,\n sentryTraceHeader: string,\n sentryBaggageHeader: string | undefined,\n): void {\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n xhr.setRequestHeader!('sentry-trace', sentryTraceHeader);\n if (sentryBaggageHeader) {\n // From MDN: \"If this method is called several times with the same header, the values are merged into one single request header.\"\n // We can therefore simply set a baggage header without checking what was there before\n // https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/setRequestHeader\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n xhr.setRequestHeader!(BAGGAGE_HEADER_NAME, sentryBaggageHeader);\n }\n } catch (_) {\n // Error: InvalidStateError: Failed to execute 'setRequestHeader' on 'XMLHttpRequest': The object's state must be OPENED.\n }\n}\n", "import type { Transaction, TransactionContext } from '@sentry/types';\nimport { addInstrumentationHandler, browserPerformanceTimeOrigin, logger } from '@sentry/utils';\n\nimport { WINDOW } from './types';\n\n/**\n * Default function implementing pageload and navigation transactions\n */\nexport function instrumentRoutingWithDefaults<T extends Transaction>(\n customStartTransaction: (context: TransactionContext) => T | undefined,\n startTransactionOnPageLoad: boolean = true,\n startTransactionOnLocationChange: boolean = true,\n): void {\n if (!WINDOW || !WINDOW.location) {\n __DEBUG_BUILD__ && logger.warn('Could not initialize routing instrumentation due to invalid location');\n return;\n }\n\n let startingUrl: string | undefined = WINDOW.location.href;\n\n let activeTransaction: T | undefined;\n if (startTransactionOnPageLoad) {\n activeTransaction = customStartTransaction({\n name: WINDOW.location.pathname,\n // pageload should always start at timeOrigin (and needs to be in s, not ms)\n startTimestamp: browserPerformanceTimeOrigin ? browserPerformanceTimeOrigin / 1000 : undefined,\n op: 'pageload',\n origin: 'auto.pageload.browser',\n metadata: { source: 'url' },\n });\n }\n\n if (startTransactionOnLocationChange) {\n addInstrumentationHandler('history', ({ to, from }: { to: string; from?: string }) => {\n /**\n * This early return is there to account for some cases where a navigation transaction starts right after\n * long-running pageload. We make sure that if `from` is undefined and a valid `startingURL` exists, we don't\n * create an uneccessary navigation transaction.\n *\n * This was hard to duplicate, but this behavior stopped as soon as this fix was applied. This issue might also\n * only be caused in certain development environments where the usage of a hot module reloader is causing\n * errors.\n */\n if (from === undefined && startingUrl && startingUrl.indexOf(to) !== -1) {\n startingUrl = undefined;\n return;\n }\n\n if (from !== to) {\n startingUrl = undefined;\n if (activeTransaction) {\n __DEBUG_BUILD__ && logger.log(`[Tracing] Finishing current transaction with op: ${activeTransaction.op}`);\n // If there's an open transaction on the scope, we need to finish it before creating an new one.\n activeTransaction.finish();\n }\n activeTransaction = customStartTransaction({\n name: WINDOW.location.pathname,\n op: 'navigation',\n origin: 'auto.navigation.browser',\n metadata: { source: 'url' },\n });\n }\n });\n }\n}\n", "/* eslint-disable max-lines */\nimport type { Hub, IdleTransaction } from '@sentry/core';\nimport { addTracingExtensions, getActiveTransaction, startIdleTransaction, TRACING_DEFAULTS } from '@sentry/core';\nimport type { EventProcessor, Integration, Transaction, TransactionContext, TransactionSource } from '@sentry/types';\nimport { getDomElement, logger, tracingContextFromHeaders } from '@sentry/utils';\n\nimport { registerBackgroundTabDetection } from './backgroundtab';\nimport {\n addPerformanceEntries,\n startTrackingInteractions,\n startTrackingLongTasks,\n startTrackingWebVitals,\n} from './metrics';\nimport type { RequestInstrumentationOptions } from './request';\nimport { defaultRequestInstrumentationOptions, instrumentOutgoingRequests } from './request';\nimport { instrumentRoutingWithDefaults } from './router';\nimport { WINDOW } from './types';\n\nexport const BROWSER_TRACING_INTEGRATION_ID = 'BrowserTracing';\n\n/** Options for Browser Tracing integration */\nexport interface BrowserTracingOptions extends RequestInstrumentationOptions {\n /**\n * The time to wait in ms until the transaction will be finished during an idle state. An idle state is defined\n * by a moment where there are no in-progress spans.\n *\n * The transaction will use the end timestamp of the last finished span as the endtime for the transaction.\n * If there are still active spans when this the `idleTimeout` is set, the `idleTimeout` will get reset.\n * Time is in ms.\n *\n * Default: 1000\n */\n idleTimeout: number;\n\n /**\n * The max duration for a transaction. If a transaction duration hits the `finalTimeout` value, it\n * will be finished.\n * Time is in ms.\n *\n * Default: 30000\n */\n finalTimeout: number;\n\n /**\n * The heartbeat interval. If no new spans are started or open spans are finished within 3 heartbeats,\n * the transaction will be finished.\n * Time is in ms.\n *\n * Default: 5000\n */\n heartbeatInterval: number;\n\n /**\n * Flag to enable/disable creation of `navigation` transaction on history changes.\n *\n * Default: true\n */\n startTransactionOnLocationChange: boolean;\n\n /**\n * Flag to enable/disable creation of `pageload` transaction on first pageload.\n *\n * Default: true\n */\n startTransactionOnPageLoad: boolean;\n\n /**\n * Flag Transactions where tabs moved to background with \"cancelled\". Browser background tab timing is\n * not suited towards doing precise measurements of operations. By default, we recommend that this option\n * be enabled as background transactions can mess up your statistics in nondeterministic ways.\n *\n * Default: true\n */\n markBackgroundTransactions: boolean;\n\n /**\n * If true, Sentry will capture long tasks and add them to the corresponding transaction.\n *\n * Default: true\n */\n enableLongTask: boolean;\n\n /**\n * _metricOptions allows the user to send options to change how metrics are collected.\n *\n * _metricOptions is currently experimental.\n *\n * Default: undefined\n */\n _metricOptions?: Partial<{\n /**\n * @deprecated This property no longer has any effect and will be removed in v8.\n */\n _reportAllChanges: boolean;\n }>;\n\n /**\n * _experiments allows the user to send options to define how this integration works.\n * Note that the `enableLongTask` options is deprecated in favor of the option at the top level, and will be removed in v8.\n *\n * TODO (v8): Remove enableLongTask\n *\n * Default: undefined\n */\n _experiments: Partial<{\n enableLongTask: boolean;\n enableInteractions: boolean;\n onStartRouteTransaction: (t: Transaction | undefined, ctx: TransactionContext, getCurrentHub: () => Hub) => void;\n }>;\n\n /**\n * beforeNavigate is called before a pageload/navigation transaction is created and allows users to modify transaction\n * context data, or drop the transaction entirely (by setting `sampled = false` in the context).\n *\n * Note: For legacy reasons, transactions can also be dropped by returning `undefined`.\n *\n * @param context: The context data which will be passed to `startTransaction` by default\n *\n * @returns A (potentially) modified context object, with `sampled = false` if the transaction should be dropped.\n */\n beforeNavigate?(this: void, context: TransactionContext): TransactionContext | undefined;\n\n /**\n * Instrumentation that creates routing change transactions. By default creates\n * pageload and navigation transactions.\n */\n routingInstrumentation<T extends Transaction>(\n this: void,\n customStartTransaction: (context: TransactionContext) => T | undefined,\n startTransactionOnPageLoad?: boolean,\n startTransactionOnLocationChange?: boolean,\n ): void;\n}\n\nconst DEFAULT_BROWSER_TRACING_OPTIONS: BrowserTracingOptions = {\n ...TRACING_DEFAULTS,\n markBackgroundTransactions: true,\n routingInstrumentation: instrumentRoutingWithDefaults,\n startTransactionOnLocationChange: true,\n startTransactionOnPageLoad: true,\n enableLongTask: true,\n _experiments: {},\n ...defaultRequestInstrumentationOptions,\n};\n\n/**\n * The Browser Tracing integration automatically instruments browser pageload/navigation\n * actions as transactions, and captures requests, metrics and errors as spans.\n *\n * The integration can be configured with a variety of options, and can be extended to use\n * any routing library. This integration uses {@see IdleTransaction} to create transactions.\n */\nexport class BrowserTracing implements Integration {\n // This class currently doesn't have a static `id` field like the other integration classes, because it prevented\n // @sentry/tracing from being treeshaken. Tree shakers do not like static fields, because they behave like side effects.\n // TODO: Come up with a better plan, than using static fields on integration classes, and use that plan on all\n // integrations.\n\n /** Browser Tracing integration options */\n public options: BrowserTracingOptions;\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n private _getCurrentHub?: () => Hub;\n\n private _latestRouteName?: string;\n private _latestRouteSource?: TransactionSource;\n\n private _collectWebVitals: () => void;\n\n private _hasSetTracePropagationTargets: boolean;\n\n public constructor(_options?: Partial<BrowserTracingOptions>) {\n this.name = BROWSER_TRACING_INTEGRATION_ID;\n this._hasSetTracePropagationTargets = false;\n\n addTracingExtensions();\n\n if (__DEBUG_BUILD__) {\n this._hasSetTracePropagationTargets = !!(\n _options &&\n // eslint-disable-next-line deprecation/deprecation\n (_options.tracePropagationTargets || _options.tracingOrigins)\n );\n }\n\n this.options = {\n ...DEFAULT_BROWSER_TRACING_OPTIONS,\n ..._options,\n };\n\n // Special case: enableLongTask can be set in _experiments\n // TODO (v8): Remove this in v8\n if (this.options._experiments.enableLongTask !== undefined) {\n this.options.enableLongTask = this.options._experiments.enableLongTask;\n }\n\n // TODO (v8): remove this block after tracingOrigins is removed\n // Set tracePropagationTargets to tracingOrigins if specified by the user\n // In case both are specified, tracePropagationTargets takes precedence\n // eslint-disable-next-line deprecation/deprecation\n if (_options && !_options.tracePropagationTargets && _options.tracingOrigins) {\n // eslint-disable-next-line deprecation/deprecation\n this.options.tracePropagationTargets = _options.tracingOrigins;\n }\n\n this._collectWebVitals = startTrackingWebVitals();\n if (this.options.enableLongTask) {\n startTrackingLongTasks();\n }\n if (this.options._experiments.enableInteractions) {\n startTrackingInteractions();\n }\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(_: (callback: EventProcessor) => void, getCurrentHub: () => Hub): void {\n this._getCurrentHub = getCurrentHub;\n const hub = getCurrentHub();\n const client = hub.getClient();\n const clientOptions = client && client.getOptions();\n\n const {\n routingInstrumentation: instrumentRouting,\n startTransactionOnLocationChange,\n startTransactionOnPageLoad,\n markBackgroundTransactions,\n traceFetch,\n traceXHR,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n _experiments,\n } = this.options;\n\n const clientOptionsTracePropagationTargets = clientOptions && clientOptions.tracePropagationTargets;\n // There are three ways to configure tracePropagationTargets:\n // 1. via top level client option `tracePropagationTargets`\n // 2. via BrowserTracing option `tracePropagationTargets`\n // 3. via BrowserTracing option `tracingOrigins` (deprecated)\n //\n // To avoid confusion, favour top level client option `tracePropagationTargets`, and fallback to\n // BrowserTracing option `tracePropagationTargets` and then `tracingOrigins` (deprecated).\n // This is done as it minimizes bundle size (we don't have to have undefined checks).\n //\n // If both 1 and either one of 2 or 3 are set (from above), we log out a warning.\n // eslint-disable-next-line deprecation/deprecation\n const tracePropagationTargets = clientOptionsTracePropagationTargets || this.options.tracePropagationTargets;\n if (__DEBUG_BUILD__ && this._hasSetTracePropagationTargets && clientOptionsTracePropagationTargets) {\n logger.warn(\n '[Tracing] The `tracePropagationTargets` option was set in the BrowserTracing integration and top level `Sentry.init`. The top level `Sentry.init` value is being used.',\n );\n }\n\n instrumentRouting(\n (context: TransactionContext) => {\n const transaction = this._createRouteTransaction(context);\n\n this.options._experiments.onStartRouteTransaction &&\n this.options._experiments.onStartRouteTransaction(transaction, context, getCurrentHub);\n\n return transaction;\n },\n startTransactionOnPageLoad,\n startTransactionOnLocationChange,\n );\n\n if (markBackgroundTransactions) {\n registerBackgroundTabDetection();\n }\n\n if (_experiments.enableInteractions) {\n this._registerInteractionListener();\n }\n\n instrumentOutgoingRequests({\n traceFetch,\n traceXHR,\n tracePropagationTargets,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n });\n }\n\n /** Create routing idle transaction. */\n private _createRouteTransaction(context: TransactionContext): Transaction | undefined {\n if (!this._getCurrentHub) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Did not create ${context.op} transaction because _getCurrentHub is invalid.`);\n return undefined;\n }\n\n const hub = this._getCurrentHub();\n\n const { beforeNavigate, idleTimeout, finalTimeout, heartbeatInterval } = this.options;\n\n const isPageloadTransaction = context.op === 'pageload';\n\n const sentryTrace = isPageloadTransaction ? getMetaContent('sentry-trace') : '';\n const baggage = isPageloadTransaction ? getMetaContent('baggage') : '';\n const { traceparentData, dynamicSamplingContext, propagationContext } = tracingContextFromHeaders(\n sentryTrace,\n baggage,\n );\n\n const expandedContext: TransactionContext = {\n ...context,\n ...traceparentData,\n metadata: {\n ...context.metadata,\n dynamicSamplingContext: traceparentData && !dynamicSamplingContext ? {} : dynamicSamplingContext,\n },\n trimEnd: true,\n };\n\n const modifiedContext = typeof beforeNavigate === 'function' ? beforeNavigate(expandedContext) : expandedContext;\n\n // For backwards compatibility reasons, beforeNavigate can return undefined to \"drop\" the transaction (prevent it\n // from being sent to Sentry).\n const finalContext = modifiedContext === undefined ? { ...expandedContext, sampled: false } : modifiedContext;\n\n // If `beforeNavigate` set a custom name, record that fact\n finalContext.metadata =\n finalContext.name !== expandedContext.name\n ? { ...finalContext.metadata, source: 'custom' }\n : finalContext.metadata;\n\n this._latestRouteName = finalContext.name;\n this._latestRouteSource = finalContext.metadata && finalContext.metadata.source;\n\n if (finalContext.sampled === false) {\n __DEBUG_BUILD__ &&\n logger.log(`[Tracing] Will not send ${finalContext.op} transaction because of beforeNavigate.`);\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] Starting ${finalContext.op} transaction on scope`);\n\n const { location } = WINDOW;\n\n const idleTransaction = startIdleTransaction(\n hub,\n finalContext,\n idleTimeout,\n finalTimeout,\n true,\n { location }, // for use in the tracesSampler\n heartbeatInterval,\n );\n\n const scope = hub.getScope();\n\n // If it's a pageload and there is a meta tag set\n // use the traceparentData as the propagation context\n if (isPageloadTransaction && traceparentData) {\n scope.setPropagationContext(propagationContext);\n } else {\n // Navigation transactions should set a new propagation context based on the\n // created idle transaction.\n scope.setPropagationContext({\n traceId: idleTransaction.traceId,\n spanId: idleTransaction.spanId,\n parentSpanId: idleTransaction.parentSpanId,\n sampled: idleTransaction.sampled,\n });\n }\n\n idleTransaction.registerBeforeFinishCallback(transaction => {\n this._collectWebVitals();\n addPerformanceEntries(transaction);\n });\n\n return idleTransaction as Transaction;\n }\n\n /** Start listener for interaction transactions */\n private _registerInteractionListener(): void {\n let inflightInteractionTransaction: IdleTransaction | undefined;\n const registerInteractionTransaction = (): void => {\n const { idleTimeout, finalTimeout, heartbeatInterval } = this.options;\n const op = 'ui.action.click';\n\n const currentTransaction = getActiveTransaction();\n if (currentTransaction && currentTransaction.op && ['navigation', 'pageload'].includes(currentTransaction.op)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `[Tracing] Did not create ${op} transaction because a pageload or navigation transaction is in progress.`,\n );\n return undefined;\n }\n\n if (inflightInteractionTransaction) {\n inflightInteractionTransaction.setFinishReason('interactionInterrupted');\n inflightInteractionTransaction.finish();\n inflightInteractionTransaction = undefined;\n }\n\n if (!this._getCurrentHub) {\n __DEBUG_BUILD__ && logger.warn(`[Tracing] Did not create ${op} transaction because _getCurrentHub is invalid.`);\n return undefined;\n }\n\n if (!this._latestRouteName) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Did not create ${op} transaction because _latestRouteName is missing.`);\n return undefined;\n }\n\n const hub = this._getCurrentHub();\n const { location } = WINDOW;\n\n const context: TransactionContext = {\n name: this._latestRouteName,\n op,\n trimEnd: true,\n metadata: {\n source: this._latestRouteSource || 'url',\n },\n };\n\n inflightInteractionTransaction = startIdleTransaction(\n hub,\n context,\n idleTimeout,\n finalTimeout,\n true,\n { location }, // for use in the tracesSampler\n heartbeatInterval,\n );\n };\n\n ['click'].forEach(type => {\n addEventListener(type, registerInteractionTransaction, { once: false, capture: true });\n });\n }\n}\n\n/** Returns the value of a meta tag */\nexport function getMetaContent(metaName: string): string | undefined {\n // Can't specify generic to `getDomElement` because tracing can be used\n // in a variety of environments, have to disable `no-unsafe-member-access`\n // as a result.\n const metaTag = getDomElement(`meta[name=${metaName}]`);\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return metaTag ? metaTag.getAttribute('content') : undefined;\n}\n", "export * from './exports';\n\nimport { Integrations as CoreIntegrations } from '@sentry/core';\n\nimport { WINDOW } from './helpers';\nimport * as BrowserIntegrations from './integrations';\n\nlet windowIntegrations = {};\n\n// This block is needed to add compatibility with the integrations packages when used with a CDN\nif (WINDOW.Sentry && WINDOW.Sentry.Integrations) {\n windowIntegrations = WINDOW.Sentry.Integrations;\n}\n\nconst INTEGRATIONS = {\n ...windowIntegrations,\n ...CoreIntegrations,\n ...BrowserIntegrations,\n};\n\nexport { INTEGRATIONS as Integrations };\n\nexport { Replay } from '@sentry/replay';\nexport type {\n ReplayEventType,\n ReplayEventWithTime,\n ReplayBreadcrumbFrame,\n ReplayBreadcrumbFrameEvent,\n ReplayOptionFrameEvent,\n ReplayFrame,\n ReplayFrameEvent,\n ReplaySpanFrame,\n ReplaySpanFrameEvent,\n} from '@sentry/replay';\n\nexport {\n BrowserTracing,\n defaultRequestInstrumentationOptions,\n instrumentOutgoingRequests,\n} from '@sentry-internal/tracing';\nexport type { RequestInstrumentationOptions } from '@sentry-internal/tracing';\nexport {\n addTracingExtensions,\n setMeasurement,\n extractTraceparentData,\n getActiveTransaction,\n spanStatusfromHttpCode,\n trace,\n makeMultiplexedTransport,\n ModuleMetadata,\n} from '@sentry/core';\nexport type { SpanStatusType } from '@sentry/core';\nexport type { Span } from '@sentry/types';\nexport { makeBrowserOfflineTransport } from './transports/offline';\nexport { onProfilingStartRouteTransaction } from './profiling/hubextensions';\nexport { BrowserProfilingIntegration } from './profiling/integration';\n", "// This const is used for nothing except to make this file identifiable via its content.\n// We search for \"_sentry_release_injection_file\" in the plugin to determine for sure that the file we look at is the release injection file.\n\n// _sentry_release_injection_file\n\n var _global =\n typeof window !== 'undefined' ?\n window :\n typeof global !== 'undefined' ?\n global :\n typeof self !== 'undefined' ?\n self :\n {};\n\n _global.SENTRY_RELEASE={id:\"3.1.8\"};", "import * as Sentry from \"@sentry/browser\";\n\nlet hasSentryInitiated = false;\nfunction initiateSentry() {\n Sentry.init({\n dsn: \"https://903950caba7d4802afe6c1e985ad5ebd@o128085.ingest.sentry.io/4504854496149504\",\n\n /**\n * The release identifier used when uploading respective source maps. Specify\n * this value to allow Sentry to resolve the correct source maps when\n * processing events.\n */\n release: process.env.COMPONENT_VERSION,\n\n /**\n * List of integrations that should be installed after SDK was initialized.\n * Accepts either a list of integrations or a function that receives\n * default integrations and returns a new, updated list.\n */\n integrations: [new Sentry.BrowserTracing()],\n\n /**\n * Sample rate to determine trace sampling.\n *\n * 0.0 = 0% chance of a given trace being sent (send no traces) 1.0 = 100% chance of a given trace being sent (send\n * all traces)\n *\n * Tracing is enabled if either this or `tracesSampler` is defined. If both are defined, `tracesSampleRate` is\n * ignored.\n */\n tracesSampleRate: 1,\n });\n hasSentryInitiated = true;\n}\n\nexport const captureErrorInSentry = (error: Error) => {\n if (!hasSentryInitiated) {\n initiateSentry();\n }\n\n return Sentry.captureException(error);\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { captureErrorInSentry } from \"@lib/captureErrorInSentry\";\nimport React from \"react\";\nimport { Button } from \"./Button\";\nimport { NonIdealState } from \"./NonIdealState\";\n\nexport class ErrorBoundary extends React.Component<{\n children: React.ReactNode | React.ReactNode[];\n}> {\n state = { hasError: false };\n\n static getDerivedStateFromError() {\n // Update state so the next render will show the fallback UI.\n return { hasError: true };\n }\n\n componentDidCatch(error: Error) {\n // You can also log the error to an error reporting service\n captureErrorInSentry(error);\n }\n\n render() {\n if (this.state.hasError) {\n return (\n <NonIdealState>\n <p style={{ marginBlock: \"0\" }} className=\"p1--semibold\">\n We ran into an error\n </p>\n <p\n className=\"p1--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginBlock: \"12px\",\n textAlign: \"center\",\n }}\n >\n Please try reloading. If the problem persists reach out to our\n support team.\n </p>\n <div>\n <Button\n variant=\"outlined\"\n iconBefore=\"autorenew\"\n onClick={() => location.reload()}\n >\n Try again\n </Button>\n </div>\n </NonIdealState>\n );\n }\n\n return this.props.children;\n }\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import * as Sentry from \"@sentry/browser\";\n\nconst MESSAGE_PREFIX = \"[Duffel Ancillaries] \";\nconst LOCAL_STORAGE_KEY = \"duffel-ancillaries-logger-state\";\nlet LOG_INITIALISED = false;\n\nconst storeLoggerState = (shouldLog: boolean) => {\n localStorage.setItem(LOCAL_STORAGE_KEY, shouldLog.toString());\n};\n\nconst shouldLog = () => localStorage.getItem(LOCAL_STORAGE_KEY) === \"true\";\n\n/**\n * The functions in this file are used to enable logging.\n *\n * Usage:\n *\n * In your app's outermost container, import the LogContext and wrap your app in it:\n *\n * ```jsx\n * import { LogContext, initializeLogger } from '@lib/logging'\n *\n * const logger = initializeLogger(props.debugMode || false)\n *\n * <LogContext.Provider value={logger}>\n * ...\n * </LogContext.Provider>\n * ```\n *\n * Then in your components nested within the above container, import the useLog hook and use it:\n *\n * import { useLog } from '@lib/logging'\n *\n * const { log, logGroup } = useLog()\n * log('This is a log message')\n * logGroup('These messages will be grouped together', ['This is a log message', 'This is another log message'])\n */\nconst initializeLogger = (debugMode: boolean): void => {\n storeLoggerState(debugMode);\n if (debugMode && !LOG_INITIALISED) {\n // eslint-disable-next-line\n console.info(\n MESSAGE_PREFIX,\n `\\n\\nDebug mode is enabled. Information about your setup will be printed to the console.\n \n If you do not want to enable debug mode (for example in a production environment), pass \"debug: false\" when initializing this component.\n \n Learn more about the Ancillaries component:\n http://duffel.com/docs/guides/ancillaries-component`\n );\n }\n LOG_INITIALISED = true;\n};\n\n/**\n * Log a message to the console. Messages will be prefixed with \"[Duffel Ancillaries]\".\n * @param message The message to print to the console.\n */\nconst log = (message: any) => {\n if (shouldLog()) {\n // eslint-disable-next-line\n console.info(MESSAGE_PREFIX, message);\n } else {\n Sentry.addBreadcrumb({\n category: \"log\",\n message,\n });\n }\n};\n\n/**\n * Log a series of messages to the console inside a collapsible group.\n * @param groupName The name of the group of messages. This will be prefixed with \"[Duffel Ancillaries]\".\n * @param messages An array of messages to print to the console, inside the group.\n */\nfunction logGroup(groupName: string, messages: any[]): void;\n\n/**\n * Log a series of messages to the console inside a collapsible group.\n * @param groupName The name of the group of messages. This will be prefixed with \"[Duffel Ancillaries]\".\n * @param object An object to print to the console, inside the group.\n */\nfunction logGroup(groupName: string, object: { [key: string]: any }): void;\n\n// Overloaded function implementation.\n// https://www.typescriptlang.org/docs/handbook/2/functions.html#function-overloads\nfunction logGroup(\n groupName: string,\n messagesOrObject: any[] | { [key: string]: any }\n): void {\n let transformedMessagesOrObject = [];\n if (Array.isArray(messagesOrObject)) {\n transformedMessagesOrObject = messagesOrObject;\n } else {\n transformedMessagesOrObject = Object.entries(messagesOrObject).map(\n ([key, value]) => ({ property: key, value })\n );\n }\n\n if (shouldLog()) {\n // eslint-disable-next-line\n console.groupCollapsed(MESSAGE_PREFIX, groupName);\n\n transformedMessagesOrObject.forEach((message) => {\n // eslint-disable-next-line\n console.info(message);\n });\n\n // eslint-disable-next-line\n console.groupEnd();\n } else {\n Sentry.addBreadcrumb({\n category: \"log.group\",\n message: groupName,\n data: messagesOrObject,\n });\n }\n}\n\nexport { initializeLogger, log, logGroup };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { log } from \"@lib/logging\";\nimport * as React from \"react\";\n\n/* eslint-disable react/no-unknown-property */\n/* eslint sort-keys: \"error\" */\nexport const ICON_MAP = {\n add: (\n <path d=\"M18 13h-5v5c0 .55-.45 1-1 1s-1-.45-1-1v-5H6c-.55 0-1-.45-1-1s.45-1 1-1h5V6c0-.55.45-1 1-1s1 .45 1 1v5h5c.55 0 1 .45 1 1s-.45 1-1 1z\" />\n ),\n apartment: (\n <path d=\"M3.8496 19.9752V7.2744H7.4496V3.6744H15.9504V10.8744H20.1504V19.9752H13.4496V16.3752H10.5504V19.9752H3.8496ZM5.1504 18.6744H7.4496V16.3752H5.1504V18.6744ZM5.1504 14.7744H7.4496V12.4752H5.1504V14.7744ZM5.1504 10.8744H7.4496V8.5752H5.1504V10.8744ZM8.7504 14.7744H11.0496V12.4752H8.7504V14.7744ZM8.7504 10.8744H11.0496V8.5752H8.7504V10.8744ZM8.7504 7.2744H11.0496V4.9752H8.7504V7.2744ZM12.3504 14.7744H14.6496V12.4752H12.3504V14.7744ZM12.3504 10.8744H14.6496V8.5752H12.3504V10.8744ZM12.3504 7.2744H14.6496V4.9752H12.3504V7.2744ZM16.5504 18.6744H18.8496V16.3752H16.5504V18.6744ZM16.5504 14.7744H18.8496V12.4752H16.5504V14.7744Z\" />\n ),\n arrow_forward: (\n <path d=\"M5 13h11.17l-4.88 4.88c-.39.39-.39 1.03 0 1.42.39.39 1.02.39 1.41 0l6.59-6.59c.39-.39.39-1.02 0-1.41l-6.58-6.6c-.39-.39-1.02-.39-1.41 0-.39.39-.39 1.02 0 1.41L16.17 11H5c-.55 0-1 .45-1 1s.45 1 1 1z\" />\n ),\n arrow_left: (\n <path d=\"M9 19L2 12L9 5L10.425 6.4L5.825 11H22V13H5.825L10.4 17.6L9 19Z\" />\n ),\n arrow_right: (\n <path d=\"M15 19L13.6 17.6L18.2 13H2V11H18.2L13.6 6.4L15 5L22 12L15 19Z\" />\n ),\n\n autorenew: (\n <path d=\"M5.69728 14.4104C5.49326 13.9833 5.32604 13.5257 5.19562 13.0374C5.06521 12.5492 5 12.0367 5 11.5C5 9.56481 5.69083 7.91679 7.07249 6.55591C8.45416 5.19504 10.147 4.53946 12.1511 4.58918H12.7613L11.0742 2.92359L12.0097 2L15.2869 5.23549L12.0097 8.47099L11.0742 7.54739L12.7613 5.88181H12.1511C10.5021 5.84866 9.11624 6.38632 7.99347 7.49479C6.87069 8.60326 6.30931 9.93833 6.30931 11.5C6.30931 11.8455 6.33804 12.1824 6.3955 12.5106C6.45296 12.8389 6.53915 13.1573 6.65407 13.4658L5.69728 14.4104ZM11.9903 21L8.71309 17.7645L11.9903 14.529L12.9258 15.4526L11.2387 17.1182H11.8489C13.4979 17.1513 14.8838 16.6137 16.0065 15.5052C17.1293 14.3967 17.6907 13.0617 17.6907 11.5C17.6907 11.1545 17.662 10.8176 17.6045 10.4894C17.547 10.1611 17.4609 9.84273 17.3459 9.53421L18.3027 8.58959C18.5067 9.01665 18.674 9.47431 18.8044 9.96256C18.9348 10.4508 19 10.9633 19 11.5C19 13.4186 18.3092 15.0625 16.9275 16.4317C15.5458 17.8008 13.853 18.4605 11.8489 18.4108H11.2387L12.9258 20.0764L11.9903 21Z\" />\n ),\n bassinet: (\n <>\n <path d=\"M19 12C19 14.1217 18.1571 16.1566 16.6569 17.6569C15.1566 19.1571 13.1217 20 11 20C8.87827 20 6.84344 19.1571 5.34315 17.6569C3.84286 16.1566 3 14.1217 3 12L11 12H19Z\" />\n <path d=\"M16.1347 5.86529L11 11V4C12.0506 4 13.0909 4.20693 14.0615 4.60896C14.8136 4.92052 15.5125 5.34451 16.1347 5.86529ZM16.8602 6.55405L12.4142 11H18.9373C18.8482 10.293 18.6649 9.59962 18.391 8.93853C18.0264 8.05823 17.5077 7.25087 16.8602 6.55405Z\" />\n </>\n ),\n cabin_bag: (\n <path d=\"M7.3077 20.5C6.81058 20.5 6.38502 20.323 6.03102 19.969C5.67701 19.615 5.5 19.1894 5.5 18.6923V8.25007C5.5 7.76417 5.67019 7.35103 6.01057 7.01065C6.35096 6.67027 6.7641 6.50007 7.25 6.50007H9.25V3.6924C9.25 3.43631 9.33622 3.22166 9.50865 3.04842C9.68108 2.87519 9.89773 2.78857 10.1586 2.78857H13.8414C14.1022 2.78857 14.3189 2.87519 14.4913 3.04842C14.6637 3.22166 14.75 3.43631 14.75 3.6924V6.50007H16.6922C17.1894 6.50007 17.6149 6.67708 17.9689 7.0311C18.3229 7.3851 18.5 7.81066 18.5 8.30777V18.6923C18.5 19.1894 18.3229 19.615 17.9689 19.969C17.6149 20.323 17.1894 20.5 16.6922 20.5C16.6922 20.7507 16.6074 20.9608 16.4377 21.1303C16.2681 21.2999 16.0578 21.3846 15.807 21.3846C15.5561 21.3846 15.3461 21.2999 15.1769 21.1303C15.0077 20.9608 14.923 20.7507 14.923 20.5H9.0769C9.0769 20.7513 8.99206 20.9615 8.82237 21.1308C8.65271 21.3 8.44246 21.3846 8.19162 21.3846C7.94079 21.3846 7.73076 21.2999 7.56153 21.1303C7.39231 20.9608 7.3077 20.7507 7.3077 20.5ZM10.4423 6.50007H13.5577V3.98085H10.4423V6.50007ZM7.3077 19H16.6922C16.782 19 16.8557 18.9712 16.9134 18.9135C16.9711 18.8558 17 18.7821 17 18.6923V8.30777C17 8.21802 16.9711 8.1443 16.9134 8.0866C16.8557 8.0289 16.782 8.00005 16.6922 8.00005H7.3077C7.21795 8.00005 7.14423 8.0289 7.08652 8.0866C7.02882 8.1443 6.99997 8.21802 6.99997 8.30777V18.6923C6.99997 18.7821 7.02882 18.8558 7.08652 18.9135C7.14423 18.9712 7.21795 19 7.3077 19ZM8.15382 17.1539C8.15382 17.3261 8.21009 17.4685 8.32262 17.5811C8.43514 17.6937 8.57744 17.75 8.74952 17.75C8.92161 17.75 9.06407 17.6937 9.1769 17.5811C9.28972 17.4685 9.34613 17.3261 9.34613 17.1539V9.8462C9.34613 9.67398 9.28986 9.53157 9.17732 9.41897C9.06481 9.30637 8.92251 9.25007 8.75043 9.25007C8.57834 9.25007 8.43588 9.30637 8.32305 9.41897C8.21023 9.53157 8.15382 9.67398 8.15382 9.8462V17.1539ZM11.4038 17.1539C11.4038 17.3261 11.4601 17.4685 11.5726 17.5811C11.6851 17.6937 11.8274 17.75 11.9995 17.75C12.1716 17.75 12.3141 17.6937 12.4269 17.5811C12.5397 17.4685 12.5961 17.3261 12.5961 17.1539V9.8462C12.5961 9.67398 12.5399 9.53157 12.4273 9.41897C12.3148 9.30637 12.1725 9.25007 12.0004 9.25007C11.8283 9.25007 11.6859 9.30637 11.5731 9.41897C11.4602 9.53157 11.4038 9.67398 11.4038 9.8462V17.1539ZM14.6538 17.1539C14.6538 17.3261 14.7101 17.4685 14.8226 17.5811C14.9351 17.6937 15.0774 17.75 15.2495 17.75C15.4216 17.75 15.5641 17.6937 15.6769 17.5811C15.7897 17.4685 15.8461 17.3261 15.8461 17.1539V9.8462C15.8461 9.67398 15.7899 9.53157 15.6773 9.41897C15.5648 9.30637 15.4225 9.25007 15.2504 9.25007C15.0783 9.25007 14.9359 9.30637 14.823 9.41897C14.7102 9.53157 14.6538 9.67398 14.6538 9.8462V17.1539Z\" />\n ),\n check: (\n <path d=\"M10.3333 15.8646L7 12.5313L8.0625 11.4688L10.3333 13.7396L15.9375 8.13544L17 9.19794L10.3333 15.8646Z\" />\n ),\n checked_bag: (\n <path d=\"M22 19H2V21H22V19M4 15C4 15.5 4.2 16 4.6 16.4C5 16.8 5.5 17 6 17V6C5.5 6 5 6.2 4.6 6.6C4.2 7 4 7.5 4 8V15M13.5 6H10.5C10.5 5.6 10.6 5.2 10.9 4.9C11.2 4.6 11.5 4.5 12 4.5C12.4 4.5 12.8 4.6 13.1 4.9C13.3 5.2 13.5 5.6 13.5 6M7 6V17H17V6H15C15 5.2 14.7 4.5 14.1 3.9S12.8 3 12 3C11.2 3 10.5 3.3 9.9 3.9C9.3 4.5 9 5.2 9 6H7M18 17C18.5 17 19 16.8 19.4 16.4C19.8 16 20 15.5 20 15V8C20 7.5 19.8 7 19.4 6.6C19 6.2 18.5 6 18 6V17Z\" />\n ),\n chevron: (\n <path d=\"M5 13H16.17L11.29 17.88C10.9 18.27 10.9 18.91 11.29 19.3C11.68 19.69 12.31 19.69 12.7 19.3L19.29 12.71C19.68 12.32 19.68 11.69 19.29 11.3L12.71 4.7C12.32 4.31 11.69 4.31 11.3 4.7C10.91 5.09 10.91 5.72 11.3 6.11L16.17 11H5C4.45 11 4 11.45 4 12C4 12.55 4.45 13 5 13Z\" />\n ),\n close: (\n <path d=\"M18.3 5.71c-.39-.39-1.02-.39-1.41 0L12 10.59 7.11 5.7c-.39-.39-1.02-.39-1.41 0-.39.39-.39 1.02 0 1.41L10.59 12 5.7 16.89c-.39.39-.39 1.02 0 1.41.39.39 1.02.39 1.41 0L12 13.41l4.89 4.89c.39.39 1.02.39 1.41 0 .39-.39.39-1.02 0-1.41L13.41 12l4.89-4.89c.38-.38.38-1.02 0-1.4z\" />\n ),\n closet: (\n <path d=\"M12 4C11.0717 4 10.1815 4.36875 9.52513 5.02513C8.86875 5.6815 8.5 6.57174 8.5 7.5H10.5C10.5 7.10218 10.658 6.72064 10.9393 6.43934C11.2206 6.15804 11.6022 6 12 6C12.3978 6 12.7794 6.15804 13.0607 6.43934C13.342 6.72064 13.5 7.10218 13.5 7.5C13.5 7.89782 13.342 8.27936 13.0607 8.56066C12.7794 8.84196 12.3978 9 12 9C11.45 9 11 9.45 11 10V11.75L2.4 18.2C2.23209 18.3259 2.10807 18.5015 2.04549 18.7018C1.98291 18.9022 1.98495 19.1171 2.05132 19.3162C2.11769 19.5153 2.24502 19.6885 2.41529 19.8112C2.58556 19.934 2.79012 20 3 20H21C21.2099 20 21.4144 19.934 21.5847 19.8112C21.755 19.6885 21.8823 19.5153 21.9487 19.3162C22.0151 19.1171 22.0171 18.9022 21.9545 18.7018C21.8919 18.5015 21.7679 18.3259 21.6 18.2L13 11.75V10.85C13.7216 10.6349 14.3546 10.1927 14.805 9.58919C15.2554 8.98569 15.4991 8.25303 15.5 7.5C15.5 6.57174 15.1313 5.6815 14.4749 5.02513C13.8185 4.36875 12.9283 4 12 4ZM12 13.5L18 18H6L12 13.5Z\" />\n ),\n exit_row: (\n <path d=\"M20 11H6.83001L9.71001 8.12001C10.1 7.73001 10.1 7.10001 9.71001 6.71001C9.32001 6.32001 8.69001 6.32001 8.30001 6.71001L3.71001 11.3C3.32001 11.69 3.32001 12.32 3.71001 12.71L8.30001 17.3C8.69001 17.69 9.32001 17.69 9.71001 17.3C10.1 16.91 10.1 16.28 9.71001 15.89L6.83001 13H20C20.55 13 21 12.55 21 12C21 11.45 20.55 11 20 11Z\" />\n ),\n exit_row_right: (\n <path d=\"M4 11H17.17L14.29 8.12001C13.9 7.73001 13.9 7.10001 14.29 6.71001C14.68 6.32001 15.31 6.32001 15.7 6.71001L20.29 11.3C20.68 11.69 20.68 12.32 20.29 12.71L15.7 17.3C15.31 17.69 14.68 17.69 14.29 17.3C13.9 16.91 13.9 16.28 14.29 15.89L17.17 13H4C3.45 13 3 12.55 3 12C3 11.45 3.45 11 4 11Z\" />\n ),\n expand_content: <path d=\"M5 19V13H7V17H11V19H5ZM17 11V7H13V5H19V11H17Z\" />,\n flight_class: (\n <path d=\"M14.2596 12.5C13.7737 12.5 13.3606 12.3298 13.0202 11.9894C12.6798 11.649 12.5096 11.2359 12.5096 10.75V6.25C12.5096 5.7641 12.6798 5.35096 13.0202 5.01058C13.3606 4.67019 13.7737 4.5 14.2596 4.5H15.75C16.2359 4.5 16.649 4.67019 16.9894 5.01058C17.3298 5.35096 17.5 5.7641 17.5 6.25V10.75C17.5 11.2359 17.3298 11.649 16.9894 11.9894C16.649 12.3298 16.2359 12.5 15.75 12.5H14.2596ZM14.2596 11H15.75C15.8205 11 15.8798 10.9759 15.9278 10.9279C15.9759 10.8798 16 10.8205 16 10.75V6.25C16 6.17948 15.9759 6.12018 15.9278 6.0721C15.8798 6.02402 15.8205 5.99998 15.75 5.99998H14.2596C14.1891 5.99998 14.1298 6.02402 14.0817 6.0721C14.0336 6.12018 14.0096 6.17948 14.0096 6.25V10.75C14.0096 10.8205 14.0336 10.8798 14.0817 10.9279C14.1298 10.9759 14.1891 11 14.2596 11ZM9.5673 17.5C9.21345 17.5 8.89678 17.398 8.6173 17.1942C8.33782 16.9903 8.14423 16.7198 8.03655 16.3827L5.5 8.02883V4.5H6.99997V7.99998L9.49997 16H17.7596V17.5H9.5673ZM8.25 20.5V19H17.75V20.5H8.25ZM14.2596 5.99998H16H14.0096H14.2596Z\" />\n ),\n flight_takeoff: (\n <path d=\"M3.77521 20.1498V18.849H20.0748V20.1498H3.77521ZM5.45041 15.2742L2.94961 11.0994L4.05001 10.8246L5.90041 12.399L10.05 11.2998L6.27481 4.89902L7.72561 4.62422L14.1 10.1994L19.4004 8.77382C19.75 8.67462 20.0832 8.72062 20.4 8.91182C20.7168 9.10382 20.9252 9.37462 21.0252 9.72422C21.1084 10.0746 21.0624 10.4038 20.8872 10.7118C20.7128 11.0198 20.4504 11.2242 20.1 11.325L5.45041 15.2742Z\" />\n ),\n galley: (\n <path d=\"M20 3H4v10c0 2.21 1.79 4 4 4h6c2.21 0 4-1.79 4-4v-3h2c1.11 0 2-.9 2-2V5c0-1.11-.89-2-2-2zm0 5h-2V5h2v3zM4 19h16v2H4z\" />\n ),\n lavatory: (\n <path d=\"M5.5 22v-7.5H4V9c0-1.1.9-2 2-2h3c1.1 0 2 .9 2 2v5.5H9.5V22h-4zM18 22v-6h3l-2.54-7.63C18.18 7.55 17.42 7 16.56 7h-.12c-.86 0-1.63.55-1.9 1.37L12 16h3v6h3zM7.5 6c1.11 0 2-.89 2-2s-.89-2-2-2-2 .89-2 2 .89 2 2 2zm9 0c1.11 0 2-.89 2-2s-.89-2-2-2-2 .89-2 2 .89 2 2 2z\" />\n ),\n lie_flat_seat: (\n <path d=\"M6.16667 12.8333C6.81667 12.8333 7.45834 12.5833 7.95001 12.0833C8.91667 11.0916 8.90001 9.51659 7.91667 8.54992C7.42501 8.07492 6.79167 7.83325 6.16667 7.83325C5.51667 7.83325 4.87501 8.08325 4.38334 8.58325C3.41667 9.57492 3.43334 11.1499 4.41667 12.1166C4.90834 12.5916 5.54167 12.8333 6.16667 12.8333ZM5.57501 9.74992C5.73334 9.59159 5.94167 9.49992 6.16667 9.49992C6.38334 9.49992 6.59167 9.58325 6.75001 9.73325C7.08334 10.0583 7.08334 10.5749 6.76667 10.9083C6.60001 11.0749 6.39167 11.1666 6.16667 11.1666C5.95001 11.1666 5.74167 11.0833 5.58334 10.9333C5.25001 10.5999 5.25001 10.0833 5.57501 9.74992ZM17 7.83325H9.50001V12.8333H20.3333V11.1666C20.3333 9.32492 18.8417 7.83325 17 7.83325ZM11.1667 11.1666V9.49992H17C17.9167 9.49992 18.6667 10.2499 18.6667 11.1666H11.1667ZM3.66667 15.3333H8.66667V16.9999H15.3333V15.3333H20.3333V13.6666H3.66667V15.3333Z\" />\n ),\n minus: (\n <path d=\"M18 13H6c-.55 0-1-.45-1-1s.45-1 1-1h12c.55 0 1 .45 1 1s-.45 1-1 1z\" />\n ),\n no_airplane: (\n <path d=\"M14.6674 10.0001V2.66675C14.6674 1.56008 13.7741 0.666748 12.6674 0.666748C11.5607 0.666748 10.6674 1.56008 10.6674 2.66675V7.57341L21.1074 18.0134L25.3341 19.3334V16.6667L14.6674 10.0001ZM1.33407 5.02675L7.9874 11.6801L0.000732422 16.6667V19.3334L10.6674 16.0001V23.3334L8.00073 25.3334V27.3334L12.6674 26.0001L17.3341 27.3334V25.3334L14.6674 23.3334V18.3601L22.3074 26.0001L24.0007 24.3067L3.0274 3.33341L1.33407 5.02675Z\" />\n ),\n no_bag: (\n <path d=\"M16.8992 6.12037H14.9392V3.18101C14.9385 2.92148 14.8351 2.67278 14.6516 2.48926C14.4681 2.30574 14.2194 2.20234 13.9599 2.20166H10.0399C9.78034 2.20234 9.53163 2.30574 9.34811 2.48926C9.16459 2.67278 9.06119 2.92148 9.06051 3.18101V6.12037H8.20711L8.34715 6.25804L14.3973 12.0871V9.06102H15.9676V13.6L17.3022 14.8859L18.8592 16.4748V8.08037C18.8579 7.56096 18.6509 7.06322 18.2836 6.69594C17.9164 6.32867 17.4186 6.12173 16.8992 6.12037ZM5.14051 8.09559L3.77173 6.71825L5.00821 5.48945L7.16586 7.6606L13.9581 14.4953L15.8932 16.4426L19.7441 20.3175L20.2279 20.8043L18.9914 22.0331L17.635 20.6683C17.4035 20.7625 17.154 20.8126 16.8992 20.8133C16.904 20.945 16.8822 21.0763 16.8351 21.1993C16.788 21.3224 16.7166 21.4347 16.6251 21.5296C16.5336 21.6244 16.424 21.6999 16.3027 21.7514C16.1814 21.8029 16.051 21.8295 15.9192 21.8295C15.7874 21.8295 15.657 21.8029 15.5357 21.7514C15.4145 21.6999 15.3048 21.6244 15.2133 21.5296C15.1219 21.4347 15.0504 21.3224 15.0034 21.1993C14.9563 21.0763 14.9344 20.945 14.9392 20.8133H9.06051C9.06529 20.945 9.04348 21.0763 8.99638 21.1993C8.94929 21.3224 8.87787 21.4347 8.7864 21.5296C8.69492 21.6244 8.58527 21.6999 8.46399 21.7514C8.34271 21.8029 8.21229 21.8295 8.08051 21.8295C7.94874 21.8295 7.81832 21.8029 7.69703 21.7514C7.57575 21.6999 7.4661 21.6244 7.37463 21.5296C7.28316 21.4347 7.21174 21.3224 7.16464 21.1993C7.11754 21.0763 7.09573 20.945 7.10051 20.8133C6.58222 20.8119 6.08545 20.6059 5.71835 20.24C5.35126 19.8741 5.14357 19.378 5.14051 18.8597V8.09559ZM14.8632 17.8791L14.3973 17.4103V17.8791H14.8632ZM9.596 12.579V17.8791H8.03083V11.004L9.596 12.579ZM10.5302 3.67134H13.4695V6.12295H10.5302V3.67134Z\" />\n ),\n no_seat: (\n <>\n <path d=\"M25.1667 21.9733L23.4733 23.6667L2.5 2.69333L4.19333 1L7.16667 3.97333L16.5267 13.3333L19.1933 16L24.5 21.3067L25.1667 21.9733Z\" />\n <path d=\"M7.16667 24H3.16667V16H19.1933L24.5 21.3067V24H20.5V20H7.16667V24ZM27.1667 9.33333H23.1667V13.3333H27.1667V9.33333ZM4.5 9.33333H0.5V13.3333H4.5V9.33333ZM20.3333 13.3333H20.5V2.66667C20.5 1.2 19.3 0 17.8333 0H9.83333C9.05784 0 8.3569 0.335483 7.86848 0.868484L20.3333 13.3333ZM16.5267 13.3333L7.16667 3.97333V13.3333H16.5267Z\" />\n </>\n ),\n north_east: (\n <path d=\"M4.69999 19.3C4.51665 19.1167 4.42499 18.8833 4.42499 18.6C4.42499 18.3167 4.51665 18.0833 4.69999 17.9L15.6 7H9.99999C9.71665 7 9.47915 6.90417 9.28749 6.7125C9.09582 6.52083 8.99999 6.28333 8.99999 6C8.99999 5.71667 9.09582 5.47917 9.28749 5.2875C9.47915 5.09583 9.71665 5 9.99999 5H18C18.2833 5 18.5208 5.09583 18.7125 5.2875C18.9042 5.47917 19 5.71667 19 6V14C19 14.2833 18.9042 14.5208 18.7125 14.7125C18.5208 14.9042 18.2833 15 18 15C17.7167 15 17.4792 14.9042 17.2875 14.7125C17.0958 14.5208 17 14.2833 17 14V8.4L6.09999 19.3C5.91665 19.4833 5.68332 19.575 5.39999 19.575C5.11665 19.575 4.88332 19.4833 4.69999 19.3Z\" />\n ),\n seat: (\n <path d=\"M7.59 5.41012C6.81 4.63012 6.81 3.36012 7.59 2.58012C8.37 1.80012 9.64 1.80012 10.42 2.58012C11.2 3.36012 11.2 4.63012 10.42 5.41012C9.63 6.20012 8.37 6.20012 7.59 5.41012ZM6 16.0001V8.00012C6 7.45012 5.55 7.00012 5 7.00012C4.45 7.00012 4 7.45012 4 8.00012V16.0001C4 18.7601 6.24 21.0001 9 21.0001H14C14.55 21.0001 15 20.5501 15 20.0001C15 19.4501 14.55 19.0001 14 19.0001H9C7.34 19.0001 6 17.6601 6 16.0001ZM19.28 19.3501L15.51 15.5801C15.14 15.2101 14.63 15.0001 14.1 15.0001H11.5V11.3201C12.59 12.2101 14.16 13.0201 15.7 13.3401C16.37 13.4801 17 12.9801 17 12.3001C17 11.7701 16.61 11.3401 16.08 11.2501C14.66 11.0101 13.2 10.2401 12.33 9.28012L10.93 7.73012C10.74 7.52012 10.5 7.35012 10.24 7.23012C9.95 7.09012 9.62 7.00012 9.28 7.00012H9.25C8.01 7.00012 7 8.01012 7 9.25012V15.0001C7 16.6601 8.34 18.0001 10 18.0001H15.07L17.85 20.7801C18.24 21.1701 18.89 21.1701 19.28 20.7801C19.68 20.3901 19.68 19.7501 19.28 19.3501Z\" />\n ),\n seat_paid_indicator: (\n <path d=\"M11.7686 0.731368C12.7766 -0.276576 14.5 0.437294 14.5 1.86274V10.8C14.5 12.5673 13.0673 14 11.3 14H2.36274C0.937294 14 0.223427 12.2766 1.23137 11.2686L11.7686 0.731368Z\" />\n ),\n shield_with_moon: (\n <path d=\"M12.525 15.75C13.0814 15.75 13.6269 15.6408 14.1615 15.4222C14.6961 15.2036 15.166 14.8757 15.5711 14.4385C15.6749 14.3244 15.7032 14.2033 15.6557 14.0751C15.6083 13.9469 15.5077 13.8629 15.3538 13.8232C14.7269 13.6783 14.1477 13.4183 13.6163 13.0433C13.0849 12.6683 12.6474 12.1789 12.3038 11.5751C11.9769 11.0046 11.7682 10.393 11.6778 9.74048C11.5874 9.08791 11.6589 8.45458 11.8923 7.84048C11.9525 7.68663 11.9301 7.55586 11.8249 7.44817C11.7198 7.34049 11.5916 7.30332 11.4403 7.33665C10.4442 7.59177 9.65927 8.1142 9.08555 8.90395C8.51185 9.69368 8.225 10.5591 8.225 11.5001C8.225 12.6796 8.64519 13.6828 9.48558 14.5097C10.3259 15.3366 11.3391 15.75 12.525 15.75ZM12 21.4808C9.83716 20.8911 8.04646 19.618 6.62787 17.6616C5.20929 15.7052 4.5 13.518 4.5 11.1001V5.34625L12 2.53857L19.5 5.34625V11.1001C19.5 13.518 18.7907 15.7052 17.3721 17.6616C15.9535 19.618 14.1628 20.8911 12 21.4808ZM12 19.9001C13.7333 19.3501 15.1666 18.2501 16.3 16.6001C17.4333 14.9501 18 13.1167 18 11.1001V6.37507L12 4.1347L5.99997 6.37507V11.1001C5.99997 13.1167 6.56664 14.9501 7.69997 16.6001C8.83331 18.2501 10.2666 19.3501 12 19.9001Z\" />\n ),\n stairs: (\n <path d=\"M19,3H5C3.9,3,3,3.9,3,5v14c0,1.1,0.9,2,2,2h14c1.1,0,2-0.9,2-2V5C21,3.9,20.1,3,19,3z M18,8h-2.42v3.33H13v3.33h-2.58 V18H6v-2h2.42v-3.33H11V9.33h2.58V6H18V8z\" />\n ),\n warning: (\n <path d=\"M20 12C20 16.4183 16.4183 20 12 20C7.58172 20 4 16.4183 4 12C4 7.58172 7.58172 4 12 4C16.4183 4 20 7.58172 20 12ZM8.21071 9.25592L10.9548 12L8.21071 14.7441L9.38922 15.9226L12.1333 13.1785L14.8774 15.9226L16.0559 14.7441L13.3118 12L16.0559 9.25592L14.8774 8.07741L12.1333 10.8215L9.38922 8.07741L8.21071 9.25592Z\" />\n ),\n wifi: (\n <path d=\"M2.83333 9.50005L4.49999 11.1667C8.64166 7.02505 15.3583 7.02505 19.5 11.1667L21.1667 9.50005C16.1083 4.44172 7.89999 4.44172 2.83333 9.50005ZM9.49999 16.1667L12 18.6667L14.5 16.1667C13.125 14.7834 10.8833 14.7834 9.49999 16.1667ZM6.16666 12.8334L7.83333 14.5C10.1333 12.2 13.8667 12.2 16.1667 14.5L17.8333 12.8334C14.6167 9.61672 9.39166 9.61672 6.16666 12.8334Z\" />\n ),\n};\n/* eslint-enable */\n\nexport type IconName = keyof typeof ICON_MAP;\n\nconst getIconPath = (name: IconName) => {\n if (!(name in ICON_MAP)) {\n log(`The icon \"${name}\" is missing from ICON_MAP`);\n return null;\n }\n return ICON_MAP[name];\n};\n\ninterface IconProps {\n name: IconName;\n className?: string;\n size?: number;\n onClick?: (event: React.MouseEvent<SVGSVGElement, MouseEvent>) => void;\n\n ml?: string;\n viewBox?: string;\n style?: React.CSSProperties;\n}\n\nexport const Icon: React.FunctionComponent<IconProps> = ({\n name,\n size,\n className,\n viewBox,\n style,\n}) => (\n <svg\n className={className}\n width={size || 24}\n height={size || 24}\n viewBox={viewBox || \"0 0 24 24\"}\n aria-label={name}\n data-testid={name}\n style={{\n display: \"block\",\n fill: \"currentColor\",\n ...style,\n }}\n >\n {getIconPath(name)}\n </svg>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon, IconName } from \"@components/shared/Icon\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\n\nconst BUTTON_VARIANTS = {\n primary: \"button--primary\",\n outlined: \"button--outlined\",\n destructive: \"button--destructive\",\n};\ntype ButtonVariants = keyof typeof BUTTON_VARIANTS;\n\nconst BUTTON_SIZES = {\n 32: \"button--32\",\n 40: \"button--40\",\n 48: \"button--48\",\n};\n\ntype ButtonSizes = keyof typeof BUTTON_SIZES;\n\ntype NativeButtonProps = React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n>;\n\nexport interface ButtonProps\n extends Pick<\n NativeButtonProps,\n \"id\" | \"onClick\" | \"disabled\" | \"children\" | \"className\" | \"type\"\n > {\n \"data-testid\"?: string;\n iconBefore?: IconName;\n variant?: ButtonVariants;\n size?: ButtonSizes;\n}\n\nexport const Button: React.FC<ButtonProps> = ({\n iconBefore,\n variant = \"primary\",\n size = 40,\n children,\n className,\n type = \"button\",\n ...nativeButtonProps\n}) => (\n <button\n type={type}\n className={classNames(\n \"button\",\n BUTTON_VARIANTS[variant],\n BUTTON_SIZES[size],\n className\n )}\n {...nativeButtonProps}\n >\n {iconBefore && (\n <Icon\n className=\"duffel-button__icon duffel-button__icon--before\"\n name={iconBefore}\n />\n )}\n {children}\n </button>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import React from \"react\";\n\nexport const NonIdealState: React.FC<\n React.PropsWithChildren<{ style?: React.CSSProperties }>\n> = ({ style, children }) => (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n border: \"dashed 1px var(--GREY-300)\",\n borderRadius: \"4px\",\n paddingBlock: \"32px\",\n ...style,\n }}\n >\n <div\n style={{\n display: \"flex\",\n flexDirection: \"column\",\n alignItems: \"center\",\n maxWidth: \"470px\",\n }}\n >\n {children}\n </div>\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import * as React from \"react\";\nimport { Button } from \"./Button\";\nimport { NonIdealState } from \"./NonIdealState\";\n\nexport const FetchOfferErrorState: React.FC<{\n height: string;\n message: string;\n}> = ({ height, message }) => (\n <NonIdealState style={{ minHeight: height }}>\n <p style={{ marginBlock: \"0\" }} className=\"p1--semibold\">\n Failed to load extras\n </p>\n <p\n className=\"p2--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginBlock: \"12px\",\n textAlign: \"center\",\n }}\n >\n {message\n ? message\n : \"Please try reloading. If the problem persists reach out to our support team.\"}\n </p>\n <div>\n <Button\n variant=\"outlined\"\n onClick={() => location.reload()}\n iconBefore=\"autorenew\"\n >\n Try again\n </Button>\n </div>\n </NonIdealState>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferAvailableService } from \"@duffel/api/types\";\n\nexport type ServicePriceMapById = Record<\n OfferAvailableService[\"id\"],\n Pick<OfferAvailableService, \"total_amount\" | \"total_currency\">\n>;\n\nexport const getServicePriceMapById = (\n availableServices: OfferAvailableService[]\n): ServicePriceMapById =>\n availableServices.reduce(\n (all, { id, total_amount, total_currency }) => ({\n [id]: {\n total_amount,\n total_currency,\n },\n ...all,\n }),\n {} as ServicePriceMapById\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder, Offer, SeatMap } from \"@duffel/api/types\";\nimport { captureErrorInSentry } from \"./captureErrorInSentry\";\nimport {\n ServicePriceMapById,\n getServicePriceMapById,\n} from \"./getServicePriceMapById\";\n\nexport const getTotalAmountForServices = (\n offer: Offer,\n selectedServices: CreateOrder[\"services\"],\n seatMaps?: SeatMap[]\n): number => {\n if (!offer || !selectedServices || selectedServices.length === 0) return 0;\n const servicePriceMap = getServicePriceMapById(offer.available_services);\n return getTotalAmountForServicesWithPriceMap(\n servicePriceMap,\n selectedServices,\n seatMaps\n );\n};\n\nexport const getTotalAmountForServicesWithPriceMap = (\n servicePriceMap: ServicePriceMapById,\n selectedServices: CreateOrder[\"services\"],\n seatMaps?: SeatMap[]\n) =>\n (selectedServices || []).reduce(\n (total, { quantity, id }) => {\n let newTotal = total;\n\n if (id in servicePriceMap) {\n newTotal += quantity * +servicePriceMap[id].total_amount;\n } else if (seatMaps) {\n newTotal += quantity * getTotalAmountFromSeatMaps(id, seatMaps);\n } else {\n captureErrorInSentry(\n new Error(\n `The service id (${id}) provided could not be found in neither the offer nor the seat maps.`\n )\n );\n }\n\n return newTotal;\n },\n\n 0\n );\n\nconst getTotalAmountFromSeatMaps = (serviceId: string, seatMaps: SeatMap[]) => {\n for (const seatMap of seatMaps) {\n for (const cabin of seatMap.cabins) {\n for (const row of cabin.rows) {\n for (const section of row.sections) {\n for (const element of section.elements) {\n if (\n element.type === \"seat\" &&\n Array.isArray(element.available_services)\n ) {\n const serviceMatch = element.available_services.find(\n (service) => service.id === serviceId\n );\n if (serviceMatch) return +serviceMatch.total_amount;\n }\n }\n }\n }\n }\n }\n return 0;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder, Offer, SeatMap } from \"@duffel/api/types\";\nimport { getTotalAmountForServices } from \"./getTotalAmountForServices\";\nimport { DuffelAncillariesProps } from \"src/types\";\n\ninterface CompileCreateOrderPayloadInput {\n offer: Offer;\n passengers: DuffelAncillariesProps[\"passengers\"];\n baggageSelectedServices: CreateOrder[\"services\"];\n seatSelectedServices: CreateOrder[\"services\"];\n cfarSelectedServices: CreateOrder[\"services\"];\n seatMaps?: SeatMap[];\n}\n\nexport const compileCreateOrderPayload = ({\n baggageSelectedServices,\n seatSelectedServices,\n cfarSelectedServices,\n offer,\n seatMaps,\n passengers,\n}: CompileCreateOrderPayloadInput): Partial<CreateOrder> => {\n const selectedServicesWithInformation = [\n ...(baggageSelectedServices ? baggageSelectedServices : []),\n ...(seatSelectedServices ? seatSelectedServices : []),\n ...(cfarSelectedServices ? cfarSelectedServices : []),\n ];\n\n const totalAmountWithServices =\n +offer.total_amount +\n getTotalAmountForServices(offer, selectedServicesWithInformation, seatMaps);\n\n return {\n ...(offer && { selected_offers: [offer.id] }),\n passengers,\n services: filterServicesForPayload(selectedServicesWithInformation),\n ...(offer && {\n payments: [\n {\n type: \"balance\",\n amount: `${totalAmountWithServices}`,\n currency: offer.total_currency,\n },\n ],\n }),\n type: \"instant\",\n metadata: { source: `duffel-ancillaries@${process.env.COMPONENT_VERSION}` },\n };\n};\n\nconst filterServicesForPayload = (\n selectedServices: CreateOrder[\"services\"]\n): CreateOrder[\"services\"] => {\n if (!Array.isArray(selectedServices)) return [];\n return selectedServices\n .filter(({ quantity }) => quantity > 0)\n .map(({ id, quantity }) => ({ id, quantity }));\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n DuffelAncillariesMarkup,\n DuffelAncillariesMarkupDefinition,\n DuffelAncillariesPriceFormatters,\n} from \"../types/DuffelAncillariesProps\";\n\nconst convertMarkupIntoPriceFormatter = (\n markup: DuffelAncillariesMarkupDefinition\n) => {\n return (amount: number, currency: string) => {\n const { rate, amount: markupAmount } = markup;\n const newAmount = amount * (1 + rate) + markupAmount;\n return { amount: newAmount, currency };\n };\n};\n\nconst errorMessage =\n \"You cannot supply both markup and priceFormatters for the same service.\";\n\n/**\n * Creates price formatters from the markup and priceFormatters passed in.\n * Throws an error if both are supplied.\n * If neither are supplied, the priceFormatters will be undefined.\n *\n * @param markup The markup to be applied to the prices of the available services of an offer.\n * @param priceFormatters Price formatters to apply to the prices of the available services of an offer.\n * @returns\n */\nconst createPriceFormatters = (\n markup?: DuffelAncillariesMarkup,\n priceFormatters?: DuffelAncillariesPriceFormatters\n): DuffelAncillariesPriceFormatters => {\n const formatters: DuffelAncillariesPriceFormatters = {};\n\n if (priceFormatters) {\n if (priceFormatters.bags) {\n formatters.bags = priceFormatters.bags;\n }\n if (priceFormatters.seats) {\n formatters.seats = priceFormatters.seats;\n }\n if (priceFormatters.cancel_for_any_reason) {\n formatters.cancel_for_any_reason = priceFormatters.cancel_for_any_reason;\n }\n }\n\n // Markup takes precedence over priceFormatters.\n if (markup) {\n if (markup.bags) {\n if (priceFormatters && priceFormatters.bags) {\n throw new Error(errorMessage);\n }\n formatters.bags = convertMarkupIntoPriceFormatter(markup.bags);\n }\n if (markup.seats) {\n if (priceFormatters && priceFormatters.seats) {\n throw new Error(errorMessage);\n }\n formatters.seats = convertMarkupIntoPriceFormatter(markup.seats);\n }\n if (markup.cancel_for_any_reason) {\n if (priceFormatters && priceFormatters.cancel_for_any_reason) {\n throw new Error(errorMessage);\n }\n formatters.cancel_for_any_reason = convertMarkupIntoPriceFormatter(\n markup.cancel_for_any_reason\n );\n }\n }\n return formatters;\n};\n\nexport { createPriceFormatters };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n OfferAvailableService,\n OfferAvailableServiceBaggage,\n} from \"@duffel/api/types\";\n\nexport const isBaggageService = (\n service: OfferAvailableService\n): service is OfferAvailableServiceBaggage => service.type === \"baggage\";\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n OfferAvailableService,\n OfferAvailableServiceCFAR,\n} from \"@duffel/api/types\";\n\nexport const isCancelForAnyReasonService = (\n service: OfferAvailableService\n): service is OfferAvailableServiceCFAR =>\n service.type === \"cancel_for_any_reason\";\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\nimport { DuffelAncillariesPriceFormatters } from \"../types/DuffelAncillariesProps\";\nimport { isBaggageService } from \"./isBaggageService\";\nimport { isCancelForAnyReasonService } from \"./isCancelForAnyReasonService\";\n\nconst multipleCurrenciesErrorMessage = (\n label: string,\n currencies: Set<string>\n) => {\n return `${label} must all have the same currency, but they have ${\n currencies.size\n } different currencies (${[...currencies].join(\n \", \"\n )}). Check the price formatters passed into the component's render function.`;\n};\n\n/**\n * Formats the prices of the available services of an offer according to the\n * priceFormatters passed in.\n *\n * @param offer An offer from the Duffel API\n * @param priceFormatters Optional price formatting functions. If not passed in, the offer will be returned unchanged.\n * @returns An offer with the prices of its available services formatted according to the priceFormatters passed in.\n */\nconst formatAvailableServices = (\n offer: Offer,\n priceFormatters?: DuffelAncillariesPriceFormatters\n): Offer => {\n // If no custom formatters were passed in, don't do anything.\n if (!priceFormatters) {\n return offer;\n }\n\n const availableServices = offer.available_services;\n\n const foundCurrencies = new Set<string>();\n\n const formatters = {\n baggage: priceFormatters?.bags,\n cancel_for_any_reason: priceFormatters?.cancel_for_any_reason,\n };\n\n const servicesWithFormattedPrices = availableServices.map((service) => {\n const serviceWithFormattedPrices = { ...service };\n\n if (service.type in formatters && formatters[service.type]) {\n let { total_amount, total_currency } = service;\n\n if (isBaggageService(service)) {\n const { amount, currency } = formatters[service.type]!(\n +service.total_amount,\n service.total_currency,\n service\n );\n\n total_amount = amount.toString();\n if (currency) {\n total_currency = currency;\n }\n }\n\n if (isCancelForAnyReasonService(service)) {\n const { amount, currency } = formatters[service.type]!(\n +service.total_amount,\n service.total_currency,\n service\n );\n\n total_amount = amount.toString();\n if (currency) {\n total_currency = currency;\n }\n }\n\n // Guard against different currencies being passed in for different services.\n foundCurrencies.add(total_currency);\n if (foundCurrencies.size > 1) {\n throw new Error(\n multipleCurrenciesErrorMessage(service.type, foundCurrencies)\n );\n }\n\n serviceWithFormattedPrices.total_amount = total_amount;\n serviceWithFormattedPrices.total_currency = total_currency;\n }\n return serviceWithFormattedPrices;\n });\n return { ...offer, available_services: servicesWithFormattedPrices };\n};\n\nexport { formatAvailableServices };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n SeatMapCabinRowSectionElement,\n SeatMapCabinRowSectionElementSeat,\n} from \"@duffel/api/types\";\n\nexport function isSeatElement(\n element: SeatMapCabinRowSectionElement\n): element is SeatMapCabinRowSectionElementSeat {\n return element.type === \"seat\";\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap, SeatMapCabinRowSectionElement } from \"@duffel/api/types\";\nimport { DuffelAncillariesPriceFormatterForSeats } from \"../types/DuffelAncillariesProps\";\nimport { isSeatElement } from \"./isSeatElement\";\n\nconst multipleCurrenciesErrorMessage = (currencies: Set<string>) => {\n return `Seats must all have the same currency, but they have ${\n currencies.size\n } different currencies (${[...currencies].join(\n \", \"\n )}). Check the price formatters passed into the component's render function.`;\n};\n\nconst formatElement = (\n element: SeatMapCabinRowSectionElement,\n priceFormatter: DuffelAncillariesPriceFormatterForSeats,\n foundCurrencies: Set<string>\n) => {\n const formattedElement = { ...element };\n if (\n isSeatElement(formattedElement) &&\n formattedElement.available_services.length > 0\n ) {\n const formattedServices = formattedElement.available_services.map(\n (service) => {\n const formattedService = { ...service };\n const { amount, currency } = priceFormatter(\n +service.total_amount,\n service.total_currency,\n service\n );\n\n formattedService.total_amount = amount.toString();\n\n // Guard against different currencies being passed in for different seats.\n if (currency) {\n formattedService.total_currency = currency;\n foundCurrencies.add(currency);\n if (foundCurrencies.size > 1) {\n throw new Error(multipleCurrenciesErrorMessage(foundCurrencies));\n }\n }\n\n return formattedService;\n }\n );\n formattedElement.available_services = formattedServices;\n }\n return formattedElement;\n};\n\nconst formatSeatMaps = (\n seatMaps: SeatMap[],\n priceFormatter?: DuffelAncillariesPriceFormatterForSeats\n): SeatMap[] => {\n // If a custom formatter wasn't passed in, don't do anything.\n if (!priceFormatter) {\n return seatMaps;\n }\n\n const foundCurrencies = new Set<string>();\n\n const formattedSeatMaps: SeatMap[] = seatMaps.map((seatMap) => {\n const formattedCabins = seatMap.cabins.map((cabin) => {\n const formattedRows = cabin.rows.map((row) => {\n const formattedSections = row.sections.map((section) => {\n const formattedElements = section.elements.map((element) => {\n return formatElement(element, priceFormatter, foundCurrencies);\n });\n return { ...section, elements: formattedElements };\n });\n return { ...row, sections: formattedSections };\n });\n return { ...cabin, rows: formattedRows };\n });\n return { ...seatMap, cabins: formattedCabins };\n });\n\n return formattedSeatMaps;\n};\n\nexport { formatSeatMaps };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "/*\n * Use relative-luminance to determine whether the color is dark enough or not.\n * See also: https://www.w3.org/WAI/GL/wiki/Relative_luminance\n */\nexport const hasHighLuminance = (accentColor: string) => {\n const rgb = accentColor.split(\", \").map((x) => parseInt(x));\n const luminance = (0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2]) / 255;\n return luminance > 0.5;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder } from \"@duffel/api/types\";\n\nexport const isPayloadComplete = (\n payload: Partial<CreateOrder>\n): payload is CreateOrder =>\n \"selected_offers\" in payload &&\n \"passengers\" in payload &&\n \"services\" in payload &&\n \"payments\" in payload &&\n \"type\" in payload &&\n \"metadata\" in payload;\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\n\nexport const offerIsExpired = (offer: Offer) => {\n return offer.expires_at && new Date(offer.expires_at) < new Date();\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { logGroup } from \"./logging\";\n\nexport interface ErrorResponse extends Response {\n data: { meta: any; errors: any[] };\n}\nexport const isErrorResponse = (response: any): response is ErrorResponse => {\n return \"data\" in response && Array.isArray(response.data.errors);\n};\n\nconst DUFFEL_API_URL = process.env.DUFFEL_API_URL;\nconst COMPONENT_VERSION = process.env.COMPONENT_VERSION;\n\nexport async function fetchFromDuffelAPI(\n withClientKey: string,\n path: string,\n method = \"GET\",\n body?: string\n) {\n logGroup(\"Making request to the Duffel API\", { path, method });\n const fullUrl = `${DUFFEL_API_URL}/ancillaries-component/${path}`;\n let response: Response | null = null;\n try {\n response = await fetch(fullUrl, {\n method,\n body,\n headers: {\n \"Duffel-Version\": \"v1\",\n Authorization: `Bearer ${withClientKey}`,\n \"User-Agent\": `Duffel/ancillaries-component@${COMPONENT_VERSION}`,\n },\n });\n } catch (error) {\n logGroup(\"Failed to make request to the Duffel API\", { error });\n throw error;\n }\n\n const data = await response.json();\n if (Array.isArray(data.errors)) {\n logGroup(\"Request to the Duffel API failed\", {\n operation: `${method} ${fullUrl}`,\n method,\n request_id: data?.meta?.request_id,\n errors: data.errors,\n status: response.status,\n });\n throw { ...response, data };\n } else {\n logGroup(\"Request to the Duffel succeeded\", {\n request_id: data?.meta?.request_id,\n });\n }\n\n return data;\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer, SeatMap } from \"@duffel/api/types\";\n\nconst COMPONENT_CDN = process.env.COMPONENT_CDN;\n\nexport const importFromOfferFixtures = async (\n offerId: string\n): Promise<Offer> =>\n await (\n await fetch(COMPONENT_CDN + `/fixtures/offers/${offerId}.json`)\n ).json();\n\nexport const importFromSeatMapsFixtures = async (\n offerId: string\n): Promise<SeatMap[]> =>\n await (\n await fetch(COMPONENT_CDN + `/fixtures/seat-maps/${offerId}.json`)\n ).json();\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\n\nexport const isFixtureOfferId = (offerId: Offer[\"id\"]): boolean =>\n offerId.startsWith(\"fixture_off_\");\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { fetchFromDuffelAPI } from \"./fetchFromDuffelAPI\";\n\nexport async function retrieveOfferFromDuffelAPI(\n offer_id: string,\n client_key: string\n) {\n const getOfferResponse = await fetchFromDuffelAPI(\n client_key,\n `offers/${offer_id}?return_available_services=true`\n );\n\n return getOfferResponse.data;\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\nimport { captureErrorInSentry } from \"./captureErrorInSentry\";\nimport { isErrorResponse } from \"./fetchFromDuffelAPI\";\nimport { importFromOfferFixtures } from \"./fetchFromFixtures\";\nimport { isFixtureOfferId } from \"./isFixtureOfferId\";\nimport { retrieveOfferFromDuffelAPI } from \"./retrieveOfferFromDuffelAPI\";\n\nexport async function retrieveOffer(\n offer_id: string,\n client_key: string | null,\n onError: (error: string) => void,\n setIsLoading: (isLoading: boolean) => void,\n onOfferReady: (offer: Offer) => void\n) {\n setIsLoading(true);\n const useFixture = isFixtureOfferId(offer_id);\n offer_id = useFixture ? offer_id.replace(\"fixture_\", \"\") : offer_id;\n\n if (useFixture) {\n return importFromOfferFixtures(offer_id).then((offer) => {\n setIsLoading(false);\n onOfferReady(offer);\n });\n }\n\n if (!client_key) {\n throw new Error(\n \"Attempted to retrieve seat maps but the client key is missing.\"\n );\n }\n\n try {\n const data = await retrieveOfferFromDuffelAPI(offer_id, client_key);\n onOfferReady(data);\n } catch (error) {\n let message = \"An unknown error occurred while retrieving the offer.\";\n if (error instanceof Error) {\n message = error.message;\n if (error.message.includes(\"Load failed\")) {\n message = \"The Duffel API is not available. Please try again later.\";\n }\n } else if (isErrorResponse(error)) {\n if (error.status === 404) {\n message =\n \"The offer you are looking for does not exist or has expired.\";\n }\n }\n\n if (isErrorResponse(error) && error.status >= 500 && error.status < 600) {\n captureErrorInSentry(new Error(message));\n }\n onError(message);\n } finally {\n setIsLoading(false);\n }\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { fetchFromDuffelAPI } from \"./fetchFromDuffelAPI\";\n\nexport async function retrieveSeatMapsFromDuffelAPI(\n offer_id: string,\n client_key: string\n) {\n const getSeatMapResponse = await fetchFromDuffelAPI(\n client_key,\n `offers/${offer_id}/seat_maps`\n );\n\n return getSeatMapResponse.data;\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap } from \"@duffel/api/types\";\nimport { captureErrorInSentry } from \"./captureErrorInSentry\";\nimport { isErrorResponse } from \"./fetchFromDuffelAPI\";\nimport { importFromSeatMapsFixtures } from \"./fetchFromFixtures\";\nimport { isFixtureOfferId } from \"./isFixtureOfferId\";\nimport { retrieveSeatMapsFromDuffelAPI } from \"./retrieveSeatMapsFromDuffelAPI\";\n\nexport async function retrieveSeatMaps(\n offer_id: string,\n client_key: string | null,\n onError: () => void,\n setIsLoading: (isLoading: boolean) => void,\n onSeatMapReady: (seatMaps: SeatMap[]) => void\n) {\n setIsLoading(true);\n\n const useFixture = isFixtureOfferId(offer_id);\n offer_id = useFixture ? offer_id.replace(\"fixture_\", \"\") : offer_id;\n\n if (useFixture) {\n return importFromSeatMapsFixtures(offer_id).then((seatMaps) => {\n setIsLoading(false);\n onSeatMapReady(seatMaps);\n });\n }\n\n if (!client_key) {\n throw new Error(\n \"Attemptted to retrieve seat maps but the client key is missing.\"\n );\n }\n\n try {\n const data = await retrieveSeatMapsFromDuffelAPI(offer_id, client_key);\n onSeatMapReady(data);\n } catch (error) {\n let message = \"An unknown error occurred while retrieving the seat maps.\";\n\n if (error instanceof Error) {\n message = error.message;\n if (error.message.includes(\"Load failed\")) {\n message = \"The Duffel API is not available. Please try again later.\";\n }\n } else if (isErrorResponse(error)) {\n message =\n error.data.errors[0]?.message ||\n \"Received an unknown error from the Duffel API.\";\n }\n\n captureErrorInSentry(new Error(message));\n onError();\n } finally {\n setIsLoading(false);\n }\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n DuffelAncillariesProps,\n DuffelAncillariesPropsWithClientKeyAndOfferId,\n DuffelAncillariesPropsWithOfferIdForFixture,\n DuffelAncillariesPropsWithOffersAndSeatMaps,\n DuffelAncillariesPropWithOfferAndClientKey,\n} from \"../types/DuffelAncillariesProps\";\n\nexport const areDuffelAncillariesPropsValid = (props: DuffelAncillariesProps) =>\n hasCommonRequiredProps(props) &&\n (isDuffelAncillariesPropsWithOfferIdForFixture(props) ||\n isDuffelAncillariesPropsWithClientKeyAndOfferId(props) ||\n isDuffelAncillariesPropsWithOfferAndSeatMaps(props) ||\n isDuffelAncillariesPropsWithOfferAndClientKey(props));\n\nexport const hasCommonRequiredProps = (props: DuffelAncillariesProps) =>\n \"onPayloadReady\" in props && \"passengers\" in props && \"services\" in props;\n\nexport const isDuffelAncillariesPropsWithOfferIdForFixture = (\n props: DuffelAncillariesProps\n): props is DuffelAncillariesPropsWithOfferIdForFixture =>\n \"offer_id\" in props && props.offer_id.startsWith(\"fixture_\");\n\nexport const isDuffelAncillariesPropsWithClientKeyAndOfferId = (\n props: DuffelAncillariesProps\n): props is DuffelAncillariesPropsWithClientKeyAndOfferId =>\n \"offer_id\" in props && \"client_key\" in props;\n\nexport const isDuffelAncillariesPropsWithOfferAndSeatMaps = (\n props: DuffelAncillariesProps\n): props is DuffelAncillariesPropsWithOffersAndSeatMaps =>\n \"offer\" in props && \"seat_maps\" in props;\n\nexport const isDuffelAncillariesPropsWithOfferAndClientKey = (\n props: DuffelAncillariesProps\n): props is DuffelAncillariesPropWithOfferAndClientKey =>\n \"offer\" in props && \"client_key\" in props;\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { ErrorBoundary } from \"@components/shared/ErrorBoundary\";\nimport { FetchOfferErrorState } from \"@components/shared/FetchOfferErrorState\";\nimport { compileCreateOrderPayload } from \"@lib/compileCreateOrderPayload\";\nimport { createPriceFormatters } from \"@lib/createPriceFormatters\";\nimport { formatAvailableServices } from \"@lib/formatAvailableServices\";\nimport { formatSeatMaps } from \"@lib/formatSeatMaps\";\nimport { hasHighLuminance } from \"@lib/hasHighLuminance\";\nimport { isPayloadComplete } from \"@lib/isPayloadComplete\";\nimport { initializeLogger, logGroup } from \"@lib/logging\";\nimport { offerIsExpired } from \"@lib/offerIsExpired\";\nimport { retrieveOffer } from \"@lib/retrieveOffer\";\nimport { retrieveSeatMaps } from \"@lib/retrieveSeatMaps\";\nimport {\n areDuffelAncillariesPropsValid,\n isDuffelAncillariesPropsWithClientKeyAndOfferId,\n isDuffelAncillariesPropsWithOfferAndClientKey,\n isDuffelAncillariesPropsWithOfferAndSeatMaps,\n isDuffelAncillariesPropsWithOfferIdForFixture,\n} from \"@lib/validateProps\";\nimport * as Sentry from \"@sentry/browser\";\nimport * as React from \"react\";\nimport {\n DuffelAncillariesProps,\n WithServiceInformation,\n} from \"../../types/DuffelAncillariesProps\";\nimport { BaggageSelectionCard } from \"./bags/BaggageSelectionCard\";\nimport { CfarSelectionCard } from \"./cancel_for_any_reason/CfarSelectionCard\";\nimport { SeatSelectionCard } from \"./seats/SeatSelectionCard\";\nimport {\n CreateOrder,\n CreateOrderService,\n Offer,\n SeatMap,\n} from \"@duffel/api/types\";\n\nconst COMPONENT_CDN = process.env.COMPONENT_CDN || \"\";\nconst hrefToComponentStyles = `${COMPONENT_CDN}/global.css`;\n\nexport const DuffelAncillaries: React.FC<DuffelAncillariesProps> = (props) => {\n initializeLogger(props.debug || false);\n\n logGroup(\"Properties passed into the component:\", props);\n\n if (!areDuffelAncillariesPropsValid(props)) {\n throw new Error(\n `The props (${Object.keys(\n props\n )}) passed to DuffelAncillaries are invalid. ` +\n \"`onPayloadReady`, `passengers` and `services` are always required. \" +\n \"Then, depending on your use case you may have one of the following combinations of required props: \" +\n \"`offer_id` and `client_key`, `offer` and `seat_maps` or `offer` and `client_key`.\" +\n \"Please refer to the documentation for more information and working examples: \" +\n \"https://duffel.com/docs/guides/ancillaries-component\"\n );\n }\n if (props.services.length === 0) {\n throw new Error(\n `You must provide at least one service in the \"services\" prop. Valid services: [\"bags\", \"seats\", \"cancel_for_any_reason\"]`\n );\n }\n\n const isPropsWithOfferIdForFixture =\n isDuffelAncillariesPropsWithOfferIdForFixture(props);\n\n const isPropsWithClientKeyAndOfferId =\n isDuffelAncillariesPropsWithClientKeyAndOfferId(props);\n\n const isPropsWithOfferAndSeatMaps =\n isDuffelAncillariesPropsWithOfferAndSeatMaps(props);\n\n const isPropsWithOfferAndClientKey =\n isDuffelAncillariesPropsWithOfferAndClientKey(props);\n\n const shouldRetrieveSeatMaps =\n props.services.includes(\"seats\") &&\n !(\"seat_maps\" in props) &&\n (isPropsWithOfferIdForFixture ||\n isPropsWithClientKeyAndOfferId ||\n isPropsWithOfferAndClientKey);\n\n const [passengers, setPassengers] = React.useState<CreateOrder[\"passengers\"]>(\n props.passengers\n );\n\n const [offer, setOffer] = React.useState<Offer | undefined>(\n (props as any).offer\n );\n\n const [isOfferLoading, setIsOfferLoading] = React.useState(\n isPropsWithClientKeyAndOfferId\n );\n\n const [seatMaps, setSeatMaps] = React.useState<SeatMap[] | undefined>(\n isPropsWithOfferAndSeatMaps ? props.seat_maps : undefined\n );\n const [isSeatMapLoading, setIsSeatMapLoading] = React.useState(\n shouldRetrieveSeatMaps\n );\n\n const [error, setError] = React.useState<null | string>(null);\n\n const [baggageSelectedServices, setBaggageSelectedServices] = React.useState<\n WithServiceInformation<CreateOrderService>[]\n >([]);\n const [seatSelectedServices, setSeatSelectedServices] = React.useState<\n WithServiceInformation<CreateOrderService>[]\n >([]);\n const [cfarSelectedServices, setCfarSelectedServices] = React.useState<\n WithServiceInformation<CreateOrderService>[]\n >([]);\n\n const priceFormatters = createPriceFormatters(\n props.markup,\n props.priceFormatters\n );\n\n const updateOffer = (offer: Offer) => {\n const expiryErrorMessage = \"This offer has expired.\";\n if (offerIsExpired(offer)) {\n setError(expiryErrorMessage);\n return;\n } else {\n const msUntilExpiry = new Date(offer?.expires_at)?.getTime() - Date.now();\n\n // Only show the expiry error message if the offer expires in less than a day,\n // to prevent buffer overflows when showing offers for fixtures, which expire in\n // years.\n const milisecondsInOneDay = 1000 * 60 * 60 * 24;\n if (msUntilExpiry < milisecondsInOneDay) {\n setTimeout(() => setError(expiryErrorMessage), msUntilExpiry);\n }\n }\n\n const offerWithFormattedServices = formatAvailableServices(\n offer,\n priceFormatters\n );\n setOffer(offerWithFormattedServices);\n };\n\n const updateSeatMaps = (seatMaps: SeatMap[]) => {\n const formattedSeatMaps = formatSeatMaps(seatMaps, priceFormatters.seats);\n setSeatMaps(formattedSeatMaps);\n };\n\n React.useEffect(() => {\n // whenever the props change, we'll set the sentry context to thse values\n // so that we can see them in the sentry logs and better support the users of the component library\n Sentry.setContext(\"props\", {\n \"props.services\": props.services,\n \"props.passengers.length\": (props as any).passengers.length,\n \"props.offer_id\": (props as any).offer_id,\n \"props.client_key\": (props as any).client_key,\n \"props.offer?.id\": (props as any).offer?.id,\n \"props.seat_maps?.[0]?.id\": (props as any).seat_maps?.[0]?.id,\n });\n\n if (isPropsWithClientKeyAndOfferId || isPropsWithOfferIdForFixture) {\n retrieveOffer(\n props.offer_id,\n !isPropsWithOfferIdForFixture ? props.client_key : null,\n setError,\n setIsOfferLoading,\n (offer) => {\n updateOffer(offer);\n\n if (offer.passengers.length !== passengers.length) {\n throw new Error(\n `The number of passengers given to \\`duffel-ancillaries\\` (${props.passengers.length}) doesn't match ` +\n `the number of passengers on the given offer (${offer.passengers.length}).`\n );\n }\n\n if (isPropsWithOfferIdForFixture) {\n // There's no way the component users will know the passenger IDs for the fixture offer\n // so we'll need to add them here\n setPassengers(\n props.passengers.map((passenger, index) => ({\n ...passenger,\n id: offer.passengers[index].id,\n }))\n );\n }\n }\n );\n }\n\n if (shouldRetrieveSeatMaps) {\n retrieveSeatMaps(\n isPropsWithClientKeyAndOfferId || isPropsWithOfferIdForFixture\n ? props.offer_id\n : props.offer.id,\n !isPropsWithOfferIdForFixture ? props.client_key : null,\n () => updateSeatMaps([]),\n setIsSeatMapLoading,\n updateSeatMaps\n );\n }\n\n if (isPropsWithOfferAndClientKey) {\n updateOffer(props.offer);\n }\n\n if (isPropsWithOfferAndSeatMaps) {\n updateOffer(props.offer);\n updateSeatMaps(props.seat_maps);\n }\n }, [\n // `as any` is needed here because the list\n // of dependencies is different for each combination of props.\n // To satisfy typescript, we'd need to conditionally assign\n // the dependencies to the hook after checking its type,\n // however that is not possible in a react hook.\n (props as any).offer_id,\n (props as any).client_key,\n (props as any).offer?.id,\n (props as any).seat_maps?.[0]?.id,\n ]);\n\n React.useEffect(() => {\n if (!offer) return;\n\n const createOrderPayload = compileCreateOrderPayload({\n baggageSelectedServices,\n seatSelectedServices,\n cfarSelectedServices,\n offer,\n passengers,\n seatMaps,\n });\n\n if (isPayloadComplete(createOrderPayload)) {\n const metadata = {\n offer_total_amount: offer.total_amount,\n offer_total_currency: offer.total_currency,\n offer_tax_amount: offer.tax_amount,\n offer_tax_currency: offer.tax_currency,\n baggage_services: baggageSelectedServices,\n seat_services: seatSelectedServices,\n cancel_for_any_reason_services: cfarSelectedServices,\n };\n\n logGroup(\"Payload ready\", {\n \"Order creation payload\": createOrderPayload,\n \"Services metadata\": metadata,\n });\n\n props.onPayloadReady(createOrderPayload, metadata);\n }\n }, [baggageSelectedServices, seatSelectedServices, cfarSelectedServices]);\n\n if (!areDuffelAncillariesPropsValid(props)) {\n return null;\n }\n\n const nonIdealStateHeight = `${\n // 72 (card height) + 32 gap between cards\n 72 * props.services.length + 32 * (props.services.length - 1)\n }px`;\n\n const duffelComponentsStyle = {\n // Adding inline styles here to avoid the cards jumping down\n // before the css is loaded duet to the missing \"row gap\".\n display: \"flex\",\n width: \"100%\",\n flexDirection: \"column\",\n rowGap: \"12px\",\n ...(props.styles?.accentColor && {\n \"--ACCENT\": props.styles.accentColor,\n }),\n ...(props.styles?.accentColor &&\n hasHighLuminance(props.styles.accentColor) && {\n \"--SECONDARY\": \"var(--GREY-900)\",\n \"--TERTIARY\": \"var(--GREY-400)\",\n }),\n ...(props.styles?.fontFamily && {\n \"--FONT-FAMILY\": props.styles.fontFamily,\n }),\n ...(props.styles?.buttonCornerRadius && {\n \"--BUTTON-RADIUS\": props.styles.buttonCornerRadius,\n }),\n // `as any` is needed here is needed because we want to set css variables\n // that are not part of the css properties type\n } as any;\n\n const state = {\n isOfferLoading,\n isSeatMapLoading,\n baggageSelectedServices,\n seatSelectedServices,\n cfarSelectedServices,\n offer,\n seatMaps,\n error,\n };\n\n logGroup(\"Component's internal state:\", state);\n\n return (\n <>\n <link rel=\"stylesheet\" href={hrefToComponentStyles}></link>\n\n <div className=\"duffel-components\" style={duffelComponentsStyle}>\n <ErrorBoundary>\n {error && (\n <FetchOfferErrorState\n height={nonIdealStateHeight}\n message={error}\n />\n )}\n\n {!error &&\n props.services.map((ancillaryName) => {\n if (ancillaryName === \"bags\")\n return (\n <BaggageSelectionCard\n key=\"bags\"\n isLoading={isOfferLoading}\n offer={offer}\n passengers={passengers}\n selectedServices={baggageSelectedServices}\n setSelectedServices={setBaggageSelectedServices}\n />\n );\n\n if (ancillaryName === \"seats\")\n return (\n <SeatSelectionCard\n key=\"seats\"\n isLoading={isOfferLoading || isSeatMapLoading}\n seatMaps={seatMaps}\n offer={offer}\n passengers={passengers}\n selectedServices={seatSelectedServices}\n setSelectedServices={setSeatSelectedServices}\n />\n );\n\n if (ancillaryName === \"cancel_for_any_reason\")\n return (\n <CfarSelectionCard\n key=\"cancel_for_any_reason\"\n isLoading={isOfferLoading}\n offer={offer}\n selectedServices={cfarSelectedServices}\n setSelectedServices={setCfarSelectedServices}\n />\n );\n })}\n </ErrorBoundary>\n </div>\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import * as React from \"react\";\n\nexport const AnimatedLoaderEllipsis: React.FC = () => (\n <span className=\"textual-loading-indicator\" aria-hidden=\"true\" />\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import React from \"react\";\n\nexport interface StampProps {\n backgroundColor: React.CSSProperties[\"backgroundColor\"];\n color: React.CSSProperties[\"color\"];\n children: React.ReactNode;\n}\n\nexport const Stamp: React.FC<StampProps> = ({\n backgroundColor,\n color,\n children,\n}) => (\n <div\n style={{\n backgroundColor,\n color,\n padding: \"2px 8px\",\n whiteSpace: \"nowrap\",\n borderRadius: \"4px\",\n fontWeight: \"600\",\n fontSize: \"14px\",\n lineHeight: \"20px\",\n textAlign: \"center\",\n }}\n >\n {children}\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\n\n/**\n *\n * Returns the currency of the first service of the given type in the offer.\n *\n * @param offer An offer\n * @returns A string representing the currency of the services in the offer.\n * @throws If there are no services, or none of the services are of the given type.\n */\nconst getCurrencyForServices = (offer: Offer, serviceType: string): string => {\n if (offer.available_services.length === 0) {\n throw new Error(\"No services available\");\n }\n const firstService = offer.available_services.find(\n (service) => service.type === serviceType\n );\n if (!firstService) {\n throw new Error(`No ${serviceType} services available`);\n }\n return firstService.total_currency;\n};\n\nexport { getCurrencyForServices };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder } from \"@duffel/api/types\";\n\nexport const getTotalQuantity = (\n fromSelectedServices: CreateOrder[\"services\"]\n) =>\n (fromSelectedServices || []).reduce(\n (total, { quantity }) => total + quantity,\n 0\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer, OfferAvailableService } from \"@duffel/api/types\";\nimport { isBaggageService } from \"./isBaggageService\";\nimport { isCancelForAnyReasonService } from \"./isCancelForAnyReasonService\";\n\nconst checkFunctionsMap = {\n baggage: isBaggageService,\n cancel_for_any_reason: isCancelForAnyReasonService,\n};\n\nexport const hasService = (\n offer: Offer | undefined,\n type: OfferAvailableService[\"type\"]\n) => {\n const checkFunction = checkFunctionsMap[type];\n if (!checkFunction) throw new Error(`Unknown service type: ${type}`);\n\n return (\n offer &&\n Array.isArray(offer.available_services) &&\n offer.available_services.some(\n (service) => checkFunction(service) && service.maximum_quantity > 0\n )\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "/**\n * Return a function to format a number into a money amount for a given currency\n *\n * @param currency The ISO-4217 currency code to be used by the formatter\n */\nexport const moneyStringFormatter = (\n currency: string,\n locale = \"en-GB\",\n options: { [option: string]: string } = {}\n) => {\n return (value: number) => {\n try {\n const formatter = new Intl.NumberFormat(locale, {\n style: \"currency\",\n currency,\n ...options,\n });\n const numberFormatted = formatter.format(value);\n const signFormatted =\n options &&\n options[\"signDisplay\"] &&\n (options[\"signDisplay\"] === \"always\" ||\n (options[\"signDisplay\"] === \"exceptZero\" && value !== 0))\n ? numberFormatted.replace(/^([+-])/, \"$1 \")\n : numberFormatted;\n\n return signFormatted;\n } catch (error) {\n // If the currency is not supported by the browser, we return the value with the currency code.\n // This allows us to support made-up currencies, like \"1000 Duffel Points\"\n return `${value} ${currency}`;\n }\n };\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "export const withPlural = (\n totalQuantity: number,\n singular: string,\n plural: string\n) => {\n if (totalQuantity == 1) return `${totalQuantity} ${singular}`;\n else return `${totalQuantity} ${plural}`;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { AnimatedLoaderEllipsis } from \"@components/shared/AnimatedLoaderEllipsis\";\nimport { Stamp } from \"@components/shared/Stamp\";\nimport { getCurrencyForServices } from \"@lib/getCurrencyForServices\";\nimport { getTotalAmountForServices } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { hasService } from \"@lib/hasService\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\nimport { Card } from \"../Card\";\nimport { BaggageSelectionModal } from \"./BaggageSelectionModal\";\nimport { CreateOrder, CreateOrderService, Offer } from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface BaggageSelectionCardProps {\n isLoading: boolean;\n offer?: Offer;\n passengers: CreateOrder[\"passengers\"];\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const BaggageSelectionCard: React.FC<BaggageSelectionCardProps> = ({\n isLoading,\n offer,\n passengers,\n selectedServices,\n setSelectedServices,\n}) => {\n const [isOpen, setIsOpen] = React.useState(false);\n\n const containsBaggageService = hasService(offer, \"baggage\");\n const totalQuantity = getTotalQuantity(selectedServices);\n const isBaggageAdded = totalQuantity > 0;\n\n const totalAmount = getTotalAmountForServices(offer!, selectedServices);\n\n let currencyToUse = offer?.base_currency || \"\";\n if (containsBaggageService) {\n currencyToUse = getCurrencyForServices(offer!, \"baggage\");\n }\n\n const totalAmountFormatted = offer\n ? moneyStringFormatter(currencyToUse)(totalAmount)\n : \"0\";\n\n const copy =\n containsBaggageService && isBaggageAdded\n ? `${withPlural(\n totalQuantity,\n \"bag\",\n \"bags\"\n )} added for ${totalAmountFormatted}`\n : \"Add any extra baggage you need for your trip\";\n\n return (\n <>\n <Card\n buttonTitle=\"Select extra baggage\"\n title=\"Extra baggage\"\n copy={copy}\n icon=\"cabin_bag\"\n onClick={containsBaggageService ? () => setIsOpen(true) : null}\n isLoading={isLoading}\n disabled={!isLoading && !containsBaggageService}\n isSelected={isBaggageAdded}\n >\n {isLoading && (\n <Stamp color=\"var(--GREY-900)\" backgroundColor=\"var(--GREY-100)\">\n Loading\n <AnimatedLoaderEllipsis />\n </Stamp>\n )}\n {!isLoading && !containsBaggageService && (\n <Stamp color=\"var(--GREY-700)\" backgroundColor=\"var(--GREY-200)\">\n Not available\n </Stamp>\n )}\n </Card>\n\n <BaggageSelectionModal\n isOpen={Boolean(isOpen && offer)}\n offer={offer}\n passengers={passengers}\n onClose={(newSelectedServices) => {\n // We need to do a deep copy here because otherwise the modal changing the quantity\n // will affect the selected services regardless of whether it's saved or not\n const newSelectedServicesDeepCopy = JSON.parse(\n JSON.stringify(newSelectedServices)\n );\n setSelectedServices(newSelectedServicesDeepCopy);\n setIsOpen(false);\n }}\n selectedServices={selectedServices}\n />\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon, IconName } from \"@components/shared/Icon\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\n\nexport interface CardProps {\n buttonTitle: string;\n title: string;\n icon: IconName;\n onClick?: (() => void) | null;\n children: React.ReactNode;\n copy: string;\n isLoading?: boolean;\n disabled?: boolean;\n isSelected?: boolean;\n}\n\nexport const Card: React.FC<CardProps> = ({\n buttonTitle,\n title,\n icon,\n copy,\n onClick,\n children,\n isLoading,\n disabled,\n isSelected,\n}) => {\n const hasChildren = React.Children.toArray(children).length > 0;\n\n return (\n <button\n type=\"button\"\n title={buttonTitle}\n {...(onClick && { onClick })}\n disabled={disabled}\n className={classNames(\n \"ancillary-card\",\n isLoading && \"ancillary-card--loading\"\n )}\n // We are using inline styles here because\n // we don't want the cards to appear unstyled\n // before the CSS stylesheet loads.\n // This is important for this component since it\n // be on visible on the page when it loads.\n style={{\n cursor: \"pointer\",\n background: \"transparent\",\n color: \"var(--GREY-900)\",\n border: \"solid 1px rgba(226, 226, 232, 1)\",\n display: \"flex\",\n rowGap: \"4px\",\n padding: \"20px\",\n borderRadius: \"8px\",\n justifyContent: \"space-between\",\n flexWrap: \"wrap\",\n flexDirection: \"column\",\n width: \"100%\",\n boxSizing: \"border-box\",\n fontSize: \"16px\",\n fontWeight: \"400\",\n lineHeight: \"24px\",\n letterSpacing: \"0em\",\n transition:\n \"border-color 0.3s var(--TRANSITION-CUBIC-BEZIER) background-color 0.3s var(--TRANSITION-CUBIC-BEZIER)\",\n }}\n >\n <div\n style={{\n display: \"flex\",\n alignItems: \"flex-start\",\n marginBlock: \"0\",\n textAlign: \"start\",\n marginTop: \"2px\",\n columnGap: \"12px\",\n width: \"100%\",\n }}\n >\n <div>\n {isSelected ? (\n <Icon name=\"check\" className=\"ancillary-card__selected-icon\" />\n ) : (\n <Icon name={icon} />\n )}\n </div>\n\n <div\n style={{\n display: \"flex\",\n justifyContent: \"space-between\",\n alignItems: \"start\",\n width: \"100%\",\n }}\n >\n <p\n className=\"p1--semibold\"\n style={{\n marginBlock: \"0\",\n }}\n >\n {title}\n </p>\n <div className=\"ancillary-card__children\">\n {hasChildren ? (\n children\n ) : (\n <Icon\n name=\"expand_content\"\n className=\"ancillary-card__expand-icon\"\n />\n )}\n </div>\n </div>\n </div>\n <p\n className=\"p1--regular\"\n style={{\n textAlign: \"start\",\n color: \"var(--GREY-600)\",\n marginLeft: \"34px\",\n marginBlock: \"0\",\n }}\n >\n {copy}\n </p>\n </button>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "export const setBodyScrollability = (shouldScroll: boolean) => {\n if (shouldScroll) {\n document.body.style.overflow = \"\";\n } else {\n document.body.style.overflow = \"hidden\";\n }\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { setBodyScrollability } from \"@lib/setBodyScrollability\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\nimport { IconButton } from \"./IconButton\";\n\ninterface ModalProps {\n onClose: () => void;\n isOpen: boolean;\n children: React.ReactNode;\n}\n\nexport const Modal: React.FC<ModalProps> = ({ children, onClose, isOpen }) => {\n React.useEffect(() => {\n setBodyScrollability(!isOpen);\n return () => setBodyScrollability(true);\n }, [isOpen]);\n\n return (\n <div\n className={classNames(\"modal\", isOpen && \"modal--open\")}\n // setting inline style to avoid modal content to flash unstyled before stylesheet is loaded\n style={{ opacity: 0 }}\n >\n <div role=\"presentation\" className={\"modal--content\"}>\n {children}\n\n <IconButton\n icon=\"close\"\n onClick={onClose}\n title=\"Close modal\"\n className=\"modal--close-button\"\n />\n </div>\n </div>\n );\n};\n\nexport const ModalBody: React.FC<{ children: React.ReactNode }> = ({\n children,\n}) => <div className={\"modal-body\"}>{children}</div>;\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import classNames from \"classnames\";\nimport * as React from \"react\";\nimport { Icon, IconName } from \"./Icon\";\n\nconst ICON_BUTTON_VARIANTS = {\n primary: \"icon-button--primary\",\n outlined: \"icon-button--outlined\",\n};\n\ntype IconButtonVariants = keyof typeof ICON_BUTTON_VARIANTS;\n\ntype NativeButtonProps = React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n>;\n\nexport interface IconButtonProps\n extends Pick<NativeButtonProps, \"id\" | \"onClick\" | \"disabled\" | \"className\"> {\n \"data-testid\"?: string;\n icon: IconName;\n title: string;\n variant?: IconButtonVariants;\n}\n\nexport const IconButton: React.FC<IconButtonProps> = ({\n icon,\n variant = \"primary\",\n className,\n ...nativeButtonProps\n}) => (\n <button\n type=\"button\"\n className={classNames(\n \"icon-button\",\n ICON_BUTTON_VARIANTS[variant],\n className\n )}\n {...nativeButtonProps}\n >\n <Icon name={icon} />\n </button>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder, CreateOrderPassenger } from \"@duffel/api/types\";\n\nexport type PassengerMapById = Record<\n CreateOrderPassenger[\"id\"],\n CreateOrderPassenger\n>;\n\nexport const getPassengerMapById = (\n passengers: CreateOrder[\"passengers\"]\n): PassengerMapById =>\n passengers.reduce(\n (all, passenger) => ({ [passenger.id]: passenger, ...all }),\n {} as PassengerMapById\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer, OfferSliceSegment } from \"@duffel/api/types\";\n\nexport const getSegmentList = (offer: Offer) =>\n offer.slices.reduce(\n (accumulator, slice) => [...accumulator, ...slice.segments],\n new Array<OfferSliceSegment>()\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Modal } from \"@components/shared/Modal\";\nimport { getCurrencyForServices } from \"@lib/getCurrencyForServices\";\nimport { getPassengerMapById } from \"@lib/getPassengerMapById\";\nimport { getSegmentList } from \"@lib/getSegmentList\";\nimport { getServicePriceMapById } from \"@lib/getServicePriceMapById\";\nimport { hasService } from \"@lib/hasService\";\nimport React, { useState } from \"react\";\nimport { BaggageSelectionModalBody } from \"./BaggageSelectionModalBody\";\nimport { BaggageSelectionModalFooter } from \"./BaggageSelectionModalFooter\";\nimport { BaggageSelectionModalHeader } from \"./BaggageSelectionModalHeader\";\nimport { CreateOrder, CreateOrderService, Offer } from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface BaggageSelectionModalProps {\n isOpen: boolean;\n offer?: Offer;\n passengers: CreateOrder[\"passengers\"];\n selectedServices: WithServiceInformation<CreateOrderService>[];\n onClose: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const BaggageSelectionModal: React.FC<BaggageSelectionModalProps> = ({\n isOpen,\n offer,\n passengers,\n onClose,\n selectedServices,\n}) => {\n const [currentSegmentIndex, setCurrentSegmentIndex] = useState(0);\n\n const [selectedServicesState, setSelectedServicesState] =\n React.useState(selectedServices);\n\n if (!offer) return null;\n\n const segments = getSegmentList(offer);\n const currentSegment = segments[currentSegmentIndex];\n\n const passengerMapById = getPassengerMapById(passengers);\n const servicePricesMap = getServicePriceMapById(offer.available_services);\n\n let currencyToUse = offer.base_currency;\n if (hasService(offer, \"baggage\")) {\n currencyToUse = getCurrencyForServices(offer, \"baggage\");\n }\n\n return (\n <Modal isOpen={isOpen} onClose={() => onClose(selectedServices)}>\n <BaggageSelectionModalHeader\n segmentCount={segments.length}\n currentSegment={currentSegment}\n currentSegmentIndex={currentSegmentIndex}\n setCurrentSegmentIndex={(index) => setCurrentSegmentIndex(index)}\n />\n <BaggageSelectionModalBody\n offer={offer}\n selectedServices={selectedServicesState}\n passengersById={passengerMapById}\n segment={currentSegment}\n setSelectedServices={setSelectedServicesState}\n />\n <BaggageSelectionModalFooter\n currency={currencyToUse}\n selectedServices={selectedServicesState}\n servicePrices={servicePricesMap}\n isFirstSegment={currentSegmentIndex === 0}\n isLastSegment={currentSegmentIndex + 1 === segments.length}\n onNextSegmentButtonClicked={() =>\n setCurrentSegmentIndex(currentSegmentIndex + 1)\n }\n onPreviousSegmentButtonClicked={() =>\n setCurrentSegmentIndex(currentSegmentIndex - 1)\n }\n onClose={() => onClose(selectedServicesState)}\n />\n </Modal>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrderPassenger, OfferPassenger } from \"@duffel/api/types\";\n\nexport const getPassengerName = (\n createOrderPayloadPassenger: CreateOrderPassenger,\n offerPassenger: OfferPassenger | undefined,\n fallbackIndex: number\n): string => {\n if (!createOrderPayloadPassenger) {\n return `Passenger ${fallbackIndex}`;\n }\n\n if (\n createOrderPayloadPassenger.given_name &&\n createOrderPayloadPassenger.family_name\n ) {\n return `${createOrderPayloadPassenger.given_name} ${createOrderPayloadPassenger.family_name}`;\n }\n\n if (createOrderPayloadPassenger.given_name) {\n return createOrderPayloadPassenger.given_name;\n }\n\n if (createOrderPayloadPassenger.family_name) {\n return createOrderPayloadPassenger.family_name;\n }\n\n if (offerPassenger?.given_name && offerPassenger?.family_name) {\n return `${offerPassenger.given_name} ${offerPassenger.family_name}`;\n }\n\n if (offerPassenger?.given_name) {\n return offerPassenger.given_name;\n }\n\n if (offerPassenger?.family_name) {\n return offerPassenger.family_name;\n }\n\n return `Passenger ${fallbackIndex}`;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferAvailableServiceBaggageMetadata } from \"@duffel/api/types\";\nimport { captureErrorInSentry } from \"@lib/captureErrorInSentry\";\n\nexport const getBaggageServiceDescription = (\n metadata: OfferAvailableServiceBaggageMetadata\n) => {\n if (!metadata) {\n captureErrorInSentry(\n new Error(\"getBaggageServiceDescription was not given any metadata\")\n );\n return null;\n }\n\n if (\n !metadata.maximum_weight_kg &&\n !metadata.maximum_length_cm &&\n !metadata.maximum_height_cm &&\n !metadata.maximum_depth_cm\n ) {\n return null;\n }\n\n const hasAllDimensions =\n metadata.maximum_length_cm &&\n metadata.maximum_height_cm &&\n metadata.maximum_depth_cm;\n\n let dimensionsLabel = \"\";\n if (hasAllDimensions) {\n dimensionsLabel = ` / ${metadata.maximum_height_cm} x ${metadata.maximum_length_cm} x ${metadata.maximum_depth_cm} cm`;\n }\n\n let weightLabel = \"\";\n if (metadata.maximum_weight_kg) {\n weightLabel = `Up to ${metadata.maximum_weight_kg}kg`;\n }\n\n return `${weightLabel}${dimensionsLabel}`;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n CreateOrderService,\n OfferAvailableServiceBaggage,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport const hasServiceOfSameMetadataTypeAlreadyBeenSelected = (\n selectedServices: WithServiceInformation<CreateOrderService>[],\n segmentId: string,\n passengerId: string,\n availableService: OfferAvailableServiceBaggage\n) =>\n selectedServices.some((selectedService) => {\n if (selectedService.id === availableService.id) {\n // if the selected service is the one on the counter, don't disable it\n // the max quantity will be availableService.maximum_quantity\n return false;\n } else if (\n selectedService.serviceInformation?.type !== \"carry_on\" &&\n selectedService.serviceInformation?.type !== \"checked\"\n ) {\n return false;\n } else if (selectedService.serviceInformation?.segmentId !== segmentId) {\n // if the selected service doesn't belong to the same segment, don't disable it\n return false;\n } else if (\n // if the selected service doesn't belong to the same passenger, don't disable it\n selectedService.serviceInformation?.passengerId !== passengerId\n ) {\n return false;\n } else {\n // if this service selection controller is for the same passenger and segment, disable it\n return (\n selectedService.serviceInformation?.type ===\n availableService.metadata.type\n );\n }\n });\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { IconButton } from \"@components/shared/IconButton\";\nimport * as React from \"react\";\n\ninterface CounterProps {\n id: string;\n min: number;\n max: number;\n value: number;\n onChange: (value: number) => void;\n}\n\nexport const Counter: React.FC<CounterProps> = ({\n id,\n min,\n max,\n value,\n onChange,\n}) => (\n <div className=\"counter\" id={id}>\n <IconButton\n icon=\"minus\"\n title=\"Remove one\"\n id={`${id}-minus`}\n data-testid={`${id}-minus`}\n variant=\"outlined\"\n disabled={value <= min}\n onClick={() => onChange(Math.max(value - 1, min))}\n />\n <div className=\"counter__count-label\">{value}</div>\n <IconButton\n icon=\"add\"\n title=\"Add one\"\n id={`${id}-plus`}\n data-testid={`${id}-plus`}\n variant=\"outlined\"\n disabled={value >= max}\n onClick={() => onChange(Math.min(value + 1, max))}\n />\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n CreateOrderService,\n OfferAvailableServiceBaggage,\n} from \"@duffel/api/types\";\nimport { getBaggageServiceDescription } from \"@lib/getBaggageServiceDescription\";\nimport { hasServiceOfSameMetadataTypeAlreadyBeenSelected } from \"@lib/hasServiceOfSameMetadataTypeAlreadyBeenSelected\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\nimport { Counter } from \"../Counter\";\n\ninterface BaggageSelectionControllerProps {\n segmentId: string;\n passengerId: string;\n availableService: OfferAvailableServiceBaggage;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n quantity: number;\n onQuantityChanged: (quantity: number) => void;\n}\n\nexport const BaggageSelectionController: React.FC<\n BaggageSelectionControllerProps\n> = ({\n segmentId,\n passengerId,\n availableService,\n quantity,\n onQuantityChanged,\n selectedServices,\n}) => {\n const serviceName =\n availableService.metadata.type === \"carry_on\" ? \"Cabin bag\" : \"Checked bag\";\n\n const servicePrice = moneyStringFormatter(availableService.total_currency)(\n +availableService.total_amount\n );\n const serviceDescription = getBaggageServiceDescription(\n availableService.metadata\n );\n\n const shouldDisableController =\n hasServiceOfSameMetadataTypeAlreadyBeenSelected(\n selectedServices,\n segmentId,\n passengerId,\n availableService\n );\n\n return (\n <div\n style={{\n display: \"flex\",\n justifyContent: \"space-between\",\n alignItems: \"center\",\n }}\n >\n <div>\n <p style={{ margin: 0 }} className=\"p2--regular\">\n {serviceName}\n <span\n style={{\n marginInline: \"4px\",\n color: \"var(--GREY-400)\",\n }}\n >\n \u2022\n </span>\n <span\n className=\"p2--semibold\"\n data-testid={`price-label--${availableService.id}--${passengerId}`}\n >\n {servicePrice}\n </span>\n </p>\n <p\n style={{ margin: 0, color: \"var(--GREY-600)\" }}\n className=\"p3--regular\"\n >\n {serviceDescription}\n </p>\n </div>\n <Counter\n id={`counter--${availableService.id}--${passengerId}`}\n min={0}\n value={quantity}\n onChange={onQuantityChanged}\n max={shouldDisableController ? 0 : availableService.maximum_quantity}\n />\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferSliceSegmentPassengerBaggage } from \"@duffel/api/types\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\n\ninterface IncludedBaggageBannerProps {\n includedBaggage: OfferSliceSegmentPassengerBaggage[];\n}\n\nexport const IncludedBaggageBanner: React.FC<IncludedBaggageBannerProps> = ({\n includedBaggage,\n}) => {\n const { carryOnBagsQuantity, checkedBagsQuantity } = includedBaggage.reduce(\n (sum, { type, quantity }) => ({\n carryOnBagsQuantity:\n sum.carryOnBagsQuantity + (type === \"carry_on\" ? quantity : 0),\n checkedBagsQuantity:\n sum.checkedBagsQuantity + (type === \"checked\" ? quantity : 0),\n }),\n {\n carryOnBagsQuantity: 0,\n checkedBagsQuantity: 0,\n }\n );\n\n const baggageLabelStringArray = new Array<string>();\n if (carryOnBagsQuantity > 0) {\n baggageLabelStringArray.push(\n withPlural(carryOnBagsQuantity, \"cabin bag\", \"cabin bags\")\n );\n }\n if (checkedBagsQuantity > 0) {\n baggageLabelStringArray.push(\n withPlural(checkedBagsQuantity, \"checked bag\", \"checked bags\")\n );\n }\n\n return (\n <div\n style={{\n marginBlock: \"8px\",\n padding: \"8px 12px\",\n color: ` var(--GREEN-300)`,\n backgroundColor: ` var(--GREEN-100)`,\n borderRadius: \"6px\",\n }}\n className=\"p2--regular\"\n >\n {baggageLabelStringArray.join(\" and \")} included with ticket\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n CreateOrderService,\n OfferAvailableServiceBaggage,\n OfferSliceSegmentPassengerBaggage,\n} from \"@duffel/api/types\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\nimport { BaggageSelectionController } from \"./BaggageSelectionController\";\nimport { IncludedBaggageBanner } from \"./IncludedBaggageBanner\";\n\nexport interface BaggageSelectionModalBodyPassengerProps {\n segmentId: string;\n passengerId: string;\n passengerName: string;\n includedBaggage: OfferSliceSegmentPassengerBaggage[];\n passengerServicesForSegment: OfferAvailableServiceBaggage[];\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const BaggageSelectionModalBodyPassenger: React.FC<\n BaggageSelectionModalBodyPassengerProps\n> = ({\n segmentId,\n passengerId,\n passengerName,\n includedBaggage,\n passengerServicesForSegment,\n selectedServices,\n setSelectedServices,\n}) => {\n const hasIncludedBaggage = includedBaggage.reduce(\n (sum, bag) => sum + bag.quantity,\n 0\n );\n\n return (\n <div style={{ marginTop: \"24px\" }}>\n <h3 style={{ margin: 0 }} className=\"p1--semibold\">\n {passengerName}\n </h3>\n {hasIncludedBaggage ? (\n <IncludedBaggageBanner includedBaggage={includedBaggage} />\n ) : null}\n\n <div style={{ display: \"flex\", rowGap: \"8px\", flexDirection: \"column\" }}>\n {passengerServicesForSegment.map((availableService) => (\n <BaggageSelectionController\n key={availableService.id}\n passengerId={passengerId}\n segmentId={segmentId}\n availableService={availableService}\n selectedServices={selectedServices}\n quantity={\n selectedServices.find(({ id }) => id == availableService.id)\n ?.quantity || 0\n }\n onQuantityChanged={(newQuantity) =>\n onBaggageQuantityChanged(\n newQuantity,\n segmentId,\n passengerId,\n passengerName,\n availableService,\n selectedServices,\n setSelectedServices\n )\n }\n />\n ))}\n </div>\n\n {passengerServicesForSegment.length === 0 && (\n <p style={{ color: `var(--GREY-700)`, margin: 0 }}>\n Extra baggage is not available for this passenger on this flight\n </p>\n )}\n </div>\n );\n};\n\nconst onBaggageQuantityChanged = (\n newQuantity: number,\n segmentId: string,\n passengerId: string,\n passengerName: string,\n availableService: OfferAvailableServiceBaggage,\n selectedServices: WithServiceInformation<CreateOrderService>[],\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void\n) => {\n // check if the service which had its quantity changed is already in the list\n const changedServiceIndex = selectedServices.findIndex(\n ({ id }) => availableService.id === id\n );\n\n // create a copy of the existing list of selected services\n const newSelectedServices = Array.from(selectedServices);\n\n // if the service is not in the list, add it\n if (changedServiceIndex < 0) {\n newSelectedServices.push({\n id: availableService.id,\n quantity: newQuantity,\n serviceInformation: {\n segmentId,\n passengerId,\n passengerName,\n total_amount: availableService.total_amount,\n total_currency: availableService.total_currency,\n ...availableService.metadata,\n },\n });\n } else {\n // if the service is in the list, update its quantity\n newSelectedServices[changedServiceIndex].quantity = newQuantity;\n }\n\n // remove any services with a quantity of 0\n // and update the list of selected services\n setSelectedServices(\n newSelectedServices.filter(({ quantity }) => quantity !== 0)\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { ModalBody } from \"@components/shared/Modal\";\nimport { getPassengerName } from \"@lib/getPassengerName\";\nimport React from \"react\";\n\nimport {\n CreateOrderPassenger,\n CreateOrderService,\n Offer,\n OfferAvailableServiceBaggage,\n OfferSliceSegment,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\nimport { BaggageSelectionModalBodyPassenger } from \"./BaggageSelectionModalBodyPassenger\";\n\nexport interface BaggageSelectionModalBodyProps {\n offer: Offer;\n segment: OfferSliceSegment;\n passengersById: Record<CreateOrderPassenger[\"id\"], CreateOrderPassenger>;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const BaggageSelectionModalBody: React.FC<\n BaggageSelectionModalBodyProps\n> = ({\n offer,\n segment,\n passengersById,\n selectedServices,\n setSelectedServices,\n}) => (\n <ModalBody>\n {segment.passengers.map(({ passenger_id, baggages }, index) => (\n <BaggageSelectionModalBodyPassenger\n key={passenger_id}\n segmentId={segment.id}\n passengerId={passenger_id}\n passengerName={getPassengerName(\n passengersById[passenger_id],\n offer.passengers.find(({ id }) => id === passenger_id),\n index + 1\n )}\n includedBaggage={baggages}\n passengerServicesForSegment={\n offer.available_services.filter(\n ({ type, passenger_ids, segment_ids }) =>\n type === \"baggage\" &&\n passenger_ids.includes(passenger_id) &&\n segment_ids.includes(segment.id)\n ) as OfferAvailableServiceBaggage[]\n }\n selectedServices={selectedServices}\n setSelectedServices={setSelectedServices}\n />\n ))}\n </ModalBody>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Button } from \"@components/shared/Button\";\nimport { CreateOrder } from \"@duffel/api/types\";\nimport { ServicePriceMapById } from \"@lib/getServicePriceMapById\";\nimport { getTotalAmountForServicesWithPriceMap } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\n\nexport interface BaggageSelectionModalFooterProps {\n currency: string;\n selectedServices: CreateOrder[\"services\"];\n servicePrices: ServicePriceMapById;\n\n isFirstSegment: boolean;\n isLastSegment: boolean;\n\n onNextSegmentButtonClicked: () => void;\n onPreviousSegmentButtonClicked: () => void;\n onClose: () => void;\n}\n\nexport const BaggageSelectionModalFooter: React.FC<\n BaggageSelectionModalFooterProps\n> = ({\n selectedServices,\n servicePrices,\n currency,\n isFirstSegment,\n isLastSegment,\n onNextSegmentButtonClicked,\n onPreviousSegmentButtonClicked,\n onClose,\n}) => {\n const totalQuantity = getTotalQuantity(selectedServices);\n const totalAmount = getTotalAmountForServicesWithPriceMap(\n servicePrices,\n selectedServices\n );\n const totalAmountLabel = moneyStringFormatter(currency)(totalAmount);\n const isOneWay = isFirstSegment && isFirstSegment;\n\n return (\n <div style={{ padding: \"16px 24px 24px\" }}>\n <div className=\"flex--space-between\">\n <div>\n Price for {withPlural(totalQuantity, \"extra bag\", \"extra bags\")}\n </div>\n <div className=\"h3--semibold\" data-testid=\"baggage-total-amount-label\">\n + {totalAmountLabel}\n </div>\n </div>\n\n <div\n style={\n isOneWay\n ? { marginTop: \"16px\", display: \"grid\" }\n : {\n marginTop: \"16px\",\n display: \"grid\",\n columnGap: \"12px\",\n gridTemplateColumns: \"repeat(2, 1fr)\",\n }\n }\n >\n {!isOneWay && (\n <Button\n size={48}\n variant=\"outlined\"\n disabled={isFirstSegment}\n onClick={() => onPreviousSegmentButtonClicked()}\n >\n Back\n </Button>\n )}\n <Button\n size={48}\n data-testid=\"confirm-selection-for-baggage\"\n onClick={() =>\n isLastSegment ? onClose() : onNextSegmentButtonClicked()\n }\n >\n {isLastSegment ? \"Confirm\" : \"Next\"}\n </Button>\n </div>\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { captureErrorInSentry } from \"./captureErrorInSentry\";\n\nexport const formatDateString = (dateString: string) => {\n const date = new Date(dateString);\n if (!isNaN(date.valueOf())) return formatDate(date);\n else {\n captureErrorInSentry(\n new Error(\n `formatDateString attempted to parse an invalid date string: ${dateString}`\n )\n );\n }\n};\n\nexport const formatDate = (date: Date) => {\n const { format } = new Intl.DateTimeFormat(undefined, {\n dateStyle: \"medium\",\n });\n return format(date);\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferSliceSegment } from \"@duffel/api/types\";\nimport { formatDateString } from \"@lib/formatDate\";\nimport React from \"react\";\n\nexport interface BaggageSelectionModalHeaderProps {\n segmentCount: number;\n currentSegmentIndex: number;\n currentSegment: OfferSliceSegment;\n setCurrentSegmentIndex: (index: number) => void;\n}\n\nexport const BaggageSelectionModalHeader: React.FC<\n BaggageSelectionModalHeaderProps\n> = ({\n segmentCount,\n currentSegmentIndex,\n currentSegment,\n setCurrentSegmentIndex,\n}) => (\n <div style={{ padding: \"24px 24px 16px\" }}>\n {segmentCount > 1 && (\n <div style={{ display: \"flex\", columnGap: \"4px\" }}>\n {Array(segmentCount)\n .fill(0)\n .map((_, index) =>\n index === currentSegmentIndex ? (\n <ActiveSegment key={`segment_${index}`} />\n ) : (\n <InactiveSegment\n key={`segment_${index}`}\n onClick={() => setCurrentSegmentIndex(index)}\n />\n )\n )}\n </div>\n )}\n <h2\n className=\"h3--semibold\"\n style={segmentCount > 1 ? { marginTop: \"12px\" } : {}}\n >\n Flight to {currentSegment.destination.iata_code}\n <span\n className=\"p2--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginLeft: \"8px\",\n }}\n >\n {formatDateString(currentSegment.departing_at)}\n </span>\n </h2>\n </div>\n);\n\nconst InactiveSegment: React.FC<{\n style?: React.CSSProperties;\n onClick?: React.MouseEventHandler<HTMLButtonElement>;\n}> = ({ onClick, style }) => (\n <button\n onClick={onClick}\n style={{\n border: \"none\",\n width: \"4px\",\n height: \"4px\",\n padding: \"0\",\n borderRadius: \"4px\",\n backgroundColor:\n \"var(--TERTIARY, rgba(var(--ACCENT), var(--ACCENT-LIGHT-200)))\",\n transition: \"background-color 0.3s var(--TRANSITION-CUBIC-BEZIER)\",\n ...style,\n }}\n />\n);\n\nconst ActiveSegment = () => (\n <InactiveSegment\n onClick={undefined}\n style={{\n backgroundColor: \"var(--SECONDARY, rgb(var(--ACCENT)))\",\n }}\n />\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { AnimatedLoaderEllipsis } from \"@components/shared/AnimatedLoaderEllipsis\";\nimport { Stamp } from \"@components/shared/Stamp\";\nimport { CreateOrderService, Offer } from \"@duffel/api/types\";\nimport { getCurrencyForServices } from \"@lib/getCurrencyForServices\";\nimport { getTotalAmountForServices } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { hasService } from \"@lib/hasService\";\nimport { isCancelForAnyReasonService } from \"@lib/isCancelForAnyReasonService\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\nimport { Card } from \"../Card\";\nimport { CfarSelectionModal } from \"./CfarSelectionModal\";\n\nexport interface CfarSelectionCardProps {\n isLoading: boolean;\n offer?: Offer;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const CfarSelectionCard: React.FC<CfarSelectionCardProps> = ({\n isLoading,\n offer,\n selectedServices,\n setSelectedServices,\n}) => {\n const [isOpen, setIsOpen] = React.useState(false);\n\n const containsCfarService = hasService(offer, \"cancel_for_any_reason\");\n const totalQuantity = getTotalQuantity(selectedServices);\n const isCfarAdded = totalQuantity > 0;\n\n let currencyToUse = offer?.base_currency || \"\";\n if (containsCfarService) {\n currencyToUse = getCurrencyForServices(offer!, \"cancel_for_any_reason\");\n }\n\n const totalAmount = getTotalAmountForServices(offer!, selectedServices);\n const totalAmountFormatted = offer\n ? moneyStringFormatter(currencyToUse)(totalAmount)\n : \"0\";\n\n const cfarService = offer?.available_services.find(\n isCancelForAnyReasonService\n );\n\n const copy =\n containsCfarService && isCfarAdded\n ? `Your trip is protected for ${totalAmountFormatted}`\n : `Protect your purchase if you decide to cancel`;\n\n return (\n <>\n <Card\n buttonTitle=\"Add cancel for any reason\"\n title=\"Cancel for any reason\"\n copy={copy}\n icon=\"shield_with_moon\"\n onClick={containsCfarService ? () => setIsOpen(true) : null}\n isLoading={isLoading}\n disabled={!isLoading && !containsCfarService}\n isSelected={isCfarAdded}\n >\n {isLoading && (\n <Stamp color=\"var(--GREY-900)\" backgroundColor=\"var(--GREY-100)\">\n Loading\n <AnimatedLoaderEllipsis />\n </Stamp>\n )}\n {!isLoading && !containsCfarService && (\n <Stamp color=\"var(--GREY-700)\" backgroundColor=\"var(--GREY-200)\">\n Not available\n </Stamp>\n )}\n </Card>\n\n <CfarSelectionModal\n isOpen={Boolean(isOpen && offer && cfarService)}\n offerCurrency={offer?.base_currency}\n service={cfarService}\n onClose={(newSelectedServices) => {\n setIsOpen(false);\n setSelectedServices(newSelectedServices);\n }}\n selectedServices={selectedServices}\n />\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared/Icon\";\nimport React, { ReactNode } from \"react\";\n\nexport const CfarSelectionModalBodyListItem: React.FC<{\n children: ReactNode;\n}> = ({ children }) => (\n <li className=\"cfar-modal-list-item\">\n <Icon name=\"check\" />\n <p>{children}</p>\n </li>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared//Icon\";\nimport { ModalBody } from \"@components/shared/Modal\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport React from \"react\";\nimport { CfarSelectionModalBodyListItem } from \"./CfarSelectionModalBodyListItem\";\nimport { Offer, OfferAvailableServiceCFAR } from \"@duffel/api/types\";\n\nexport interface CfarSelectionModalBodyProps {\n offerCurrency: Offer[\"base_currency\"];\n service: OfferAvailableServiceCFAR;\n}\n\nexport const CfarSelectionModalBody: React.FC<CfarSelectionModalBodyProps> = ({\n offerCurrency,\n service,\n}) => (\n <ModalBody>\n <ul style={{ padding: 0 }}>\n <CfarSelectionModalBodyListItem>\n Cancel your trip for any reason\n </CfarSelectionModalBodyListItem>\n\n <CfarSelectionModalBodyListItem>\n Guaranteed refund of{\" \"}\n {moneyStringFormatter(offerCurrency)(+service.metadata.refund_amount)}\n </CfarSelectionModalBodyListItem>\n\n <CfarSelectionModalBodyListItem>\n Redeemable up to 24 hours before first flight departure\n </CfarSelectionModalBodyListItem>\n </ul>\n <a\n href={service.metadata.terms_and_conditions_url}\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n className=\"p2--regular\"\n style={{\n color: \"var(--GREY-600)\",\n }}\n >\n Terms and conditions\n <Icon\n name=\"north_east\"\n size={16}\n style={{\n display: \"inline\",\n verticalAlign: \"middle\",\n marginLeft: \"4px\",\n }}\n />\n </a>\n </ModalBody>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Button } from \"@components/shared/Button\";\nimport { Icon } from \"@components/shared/Icon\";\nimport {\n CreateOrderService,\n OfferAvailableServiceCFAR,\n} from \"@duffel/api/types\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface CfarSelectionModalFooterProps {\n service: OfferAvailableServiceCFAR;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n onAddCfarService: () => void;\n onRemoveCfarService: () => void;\n onClose: () => void;\n}\n\nexport const CfarSelectionModalFooter: React.FC<\n CfarSelectionModalFooterProps\n> = ({\n service,\n selectedServices,\n onAddCfarService,\n onRemoveCfarService,\n onClose,\n}) => {\n const serviceIncluded = selectedServices.some(({ id }) => id == service.id);\n const formattedPrice = moneyStringFormatter(service.total_currency)(\n +service.total_amount\n );\n\n return (\n <div className=\"cfar-modal-footer\">\n <Button\n size={48}\n variant={serviceIncluded ? \"destructive\" : \"outlined\"}\n onClick={serviceIncluded ? onRemoveCfarService : onClose}\n >\n {serviceIncluded ? \"Remove protection\" : \"Don\u2019t protect trip\"}\n </Button>\n\n {!serviceIncluded && (\n <Button\n size={48}\n data-testid=\"confirm-selection-for-cfar\"\n onClick={onAddCfarService}\n >\n Add protection for {formattedPrice}\n </Button>\n )}\n\n {serviceIncluded && <ProtectedTripBanner />}\n </div>\n );\n};\n\nconst ProtectedTripBanner: React.FC = () => (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n columnGap: \"8px\",\n backgroundColor: \"var(--GREY-100)\",\n padding: \"var(--space-12)\",\n borderRadius: \"var(--BUTTON-RADIUS)\",\n }}\n >\n <Icon\n size={20}\n name=\"shield_with_moon\"\n style={{ fill: \"var(--SECONDARY, rgb(var(--ACCENT)))\" }}\n />\n Your trip is protected\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import React from \"react\";\n\nexport const CfarSelectionModalHeader: React.FC = () => (\n <div style={{ padding: \"24px 24px 16px\" }}>\n <h2 className=\"h3--semibold\" style={{ marginBlock: 0 }}>\n Cancel for any reason\n </h2>\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Modal } from \"@components/shared/Modal\";\nimport {\n CreateOrderService,\n Offer,\n OfferAvailableServiceCFAR,\n} from \"@duffel/api/types\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\nimport { CfarSelectionModalBody } from \"./CfarSelectionModalBody\";\nimport { CfarSelectionModalFooter } from \"./CfarSelectionModalFooter\";\nimport { CfarSelectionModalHeader } from \"./CfarSelectionModalHeader\";\n\nexport interface CfarSelectionModalProps {\n isOpen: boolean;\n offerCurrency?: Offer[\"base_currency\"];\n service?: OfferAvailableServiceCFAR;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n onClose: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const CfarSelectionModal: React.FC<CfarSelectionModalProps> = ({\n isOpen,\n offerCurrency,\n service,\n onClose,\n selectedServices,\n}) => {\n return (\n <Modal isOpen={isOpen} onClose={() => onClose(selectedServices)}>\n <CfarSelectionModalHeader />\n {service && offerCurrency && (\n <>\n <CfarSelectionModalBody\n service={service}\n offerCurrency={offerCurrency}\n />\n <CfarSelectionModalFooter\n service={service}\n selectedServices={selectedServices}\n onAddCfarService={() =>\n onClose([\n {\n id: service.id,\n quantity: 1,\n serviceInformation: {\n type: \"cancel_for_any_reason\",\n total_amount: service.total_amount,\n total_currency: service.total_currency,\n ...service.metadata,\n },\n },\n ])\n }\n onRemoveCfarService={() => onClose([])}\n onClose={() => onClose(selectedServices)}\n />\n </>\n )}\n </Modal>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap, SeatMapCabinRowSectionElement } from \"@duffel/api/types\";\n\nconst getFirstSeatElementMatchingCriteria = (\n seatMaps: SeatMap[],\n matcher: (element: SeatMapCabinRowSectionElement) => boolean\n) => {\n for (const seatMap of seatMaps) {\n for (const cabin of seatMap.cabins) {\n for (const row of cabin.rows) {\n for (const section of row.sections) {\n for (const element of section.elements) {\n if (matcher(element)) {\n return element;\n }\n }\n }\n }\n }\n }\n};\n\nexport { getFirstSeatElementMatchingCriteria };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap, SeatMapCabinRowSectionElementSeat } from \"@duffel/api/types\";\nimport { getFirstSeatElementMatchingCriteria } from \"./getFirstSeatElementMatchingCriteria\";\n\n/**\n *\n * Returns the currency of the first service of the given seat maps.\n *\n * @param seatMaps[] Array of seat maps\n * @returns A string representing the currency of the seat maps in the offer.\n */\nconst getCurrencyForSeatMaps = (seatMaps: SeatMap[]): string | undefined => {\n const firstElementWithServices:\n | SeatMapCabinRowSectionElementSeat\n | undefined = getFirstSeatElementMatchingCriteria(\n seatMaps,\n (element) =>\n element.type === \"seat\" && element.available_services.length > 0\n ) as SeatMapCabinRowSectionElementSeat;\n return firstElementWithServices?.available_services[0]?.total_currency;\n};\n\nexport { getCurrencyForSeatMaps };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { AnimatedLoaderEllipsis } from \"@components/shared/AnimatedLoaderEllipsis\";\nimport { Stamp } from \"@components/shared/Stamp\";\nimport { getCurrencyForSeatMaps } from \"@lib/getCurrencyForSeatMaps\";\nimport { getTotalAmountForServices } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\nimport { Card } from \"../Card\";\nimport { SeatSelectionModal } from \"./SeatSelectionModal\";\nimport {\n CreateOrder,\n CreateOrderService,\n Offer,\n SeatMap,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface SeatSelectionCardProps {\n isLoading: boolean;\n offer?: Offer;\n seatMaps?: SeatMap[];\n passengers: CreateOrder[\"passengers\"];\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const SeatSelectionCard: React.FC<SeatSelectionCardProps> = ({\n isLoading,\n offer,\n seatMaps,\n passengers,\n selectedServices,\n setSelectedServices,\n}) => {\n const [isOpen, setIsOpen] = React.useState(false);\n\n const containsSeatService = Array.isArray(seatMaps) && seatMaps.length > 0;\n const totalQuantity = getTotalQuantity(selectedServices);\n const areSeatsAdded = totalQuantity > 0;\n\n const totalAmount = getTotalAmountForServices(\n offer!,\n selectedServices,\n seatMaps\n );\n let currencyToUse = offer?.base_currency ?? \"\";\n if (seatMaps) {\n currencyToUse = getCurrencyForSeatMaps(seatMaps) ?? currencyToUse;\n }\n\n const totalAmountFormatted = offer\n ? moneyStringFormatter(currencyToUse)(totalAmount)\n : \"0\";\n\n const copy =\n containsSeatService && areSeatsAdded\n ? `${withPlural(\n totalQuantity,\n \"seat\",\n \"seats\"\n )} selected for ${totalAmountFormatted}`\n : \"Specify where on the plane you\u2019d like to sit\";\n\n return (\n <>\n <Card\n buttonTitle=\"Select seats\"\n title=\"Seat selection\"\n copy={copy}\n icon=\"flight_class\"\n onClick={containsSeatService ? () => setIsOpen(true) : null}\n isLoading={isLoading}\n disabled={isLoading && !containsSeatService}\n isSelected={areSeatsAdded}\n >\n {isLoading && (\n <Stamp color=\"var(--GREY-900)\" backgroundColor=\"var(--GREY-100)\">\n Loading\n <AnimatedLoaderEllipsis />\n </Stamp>\n )}\n {!isLoading && !containsSeatService && (\n <Stamp color=\"var(--GREY-700)\" backgroundColor=\"var(--GREY-200)\">\n Not available\n </Stamp>\n )}\n </Card>\n\n <SeatSelectionModal\n isOpen={Boolean(offer && seatMaps && isOpen)}\n seatMaps={seatMaps}\n offer={offer}\n passengers={passengers}\n selectedServices={selectedServices}\n onClose={(services) => {\n setSelectedServices(services);\n setIsOpen(false);\n }}\n />\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferSliceSegment } from \"@duffel/api/types\";\n\nexport const getPassengerBySegmentList = (segments: OfferSliceSegment[]) =>\n segments.flatMap((segment) =>\n segment.passengers.map((passenger, passengerIndex) => ({\n passenger,\n passengerIndex,\n segment,\n }))\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Modal } from \"@components/shared/Modal\";\nimport { getCurrencyForSeatMaps } from \"@lib/getCurrencyForSeatMaps\";\nimport { getPassengerBySegmentList } from \"@lib/getPassengerBySegmentList\";\nimport { getPassengerMapById } from \"@lib/getPassengerMapById\";\nimport { getPassengerName } from \"@lib/getPassengerName\";\nimport { getSegmentList } from \"@lib/getSegmentList\";\nimport { getServicePriceMapById } from \"@lib/getServicePriceMapById\";\nimport React from \"react\";\nimport { SeatSelectionModalBody } from \"./SeatSelectionModalBody\";\nimport { SeatSelectionModalFooter } from \"./SeatSelectionModalFooter\";\nimport { SeatSelectionModalHeader } from \"./SeatSelectionModalHeader\";\nimport {\n CreateOrder,\n CreateOrderService,\n Offer,\n SeatMap,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\ntype CreateOrderServiceWithInformation =\n WithServiceInformation<CreateOrderService>;\n\nexport interface SeatSelectionModalProps {\n isOpen: boolean;\n offer?: Offer;\n seatMaps?: SeatMap[];\n selectedServices: CreateOrderServiceWithInformation[];\n passengers: CreateOrder[\"passengers\"];\n onClose: (selectedServices: CreateOrderServiceWithInformation[]) => void;\n}\n\nexport const SeatSelectionModal: React.FC<SeatSelectionModalProps> = ({\n isOpen,\n offer,\n passengers,\n seatMaps,\n selectedServices,\n onClose,\n}) => {\n const [currentPermutationIndex, setCurrentPermutationIndex] =\n React.useState(0);\n\n const [selectedServicesState, setSelectedServicesState] =\n React.useState<CreateOrderServiceWithInformation[]>(selectedServices);\n const selectedServicesStateMap = selectedServicesState.reduce(\n (all, service) => ({ ...all, [service.id]: service }),\n {} as Record<string, CreateOrderServiceWithInformation>\n );\n\n if (!offer || !seatMaps) return null;\n\n const segments = getSegmentList(offer);\n const passengerMapById = getPassengerMapById(passengers);\n const servicePricesMap = getServicePriceMapById(offer.available_services);\n const segmentAndPassengerPermutations = getPassengerBySegmentList(segments);\n const {\n passenger: { passenger_id: currentPassengerId },\n passengerIndex: currentPassengerIndex,\n segment: { id: currentSegmentId },\n } = segmentAndPassengerPermutations[currentPermutationIndex];\n\n const currentSegment = segments.find(({ id }) => id === currentSegmentId)!;\n const currentPassenger = passengerMapById[currentPassengerId];\n const currentSeatMap = seatMaps.find(\n (seatMap) => seatMap.segment_id === currentSegmentId\n )!;\n\n const currentPassengerName = getPassengerName(\n currentPassenger,\n offer.passengers[currentPassengerIndex],\n currentPassengerIndex + 1\n );\n\n const onSeatToggle = (\n seatServiceToToggle: CreateOrderServiceWithInformation\n ) => {\n let newSeatServices = new Array<CreateOrderServiceWithInformation>();\n\n for (const selectedServiceFromState of selectedServicesState) {\n const hasClickedSeatToToggleOff =\n selectedServiceFromState.id === seatServiceToToggle.id &&\n seatServiceToToggle.quantity === 0;\n\n const isSelectedServiceFromStateForTheSameSegmentAndPassengerPermutation =\n selectedServiceFromState.serviceInformation?.segmentId ===\n currentSegmentId &&\n selectedServiceFromState.serviceInformation?.passengerId ===\n currentPassengerId;\n\n if (\n !hasClickedSeatToToggleOff &&\n !isSelectedServiceFromStateForTheSameSegmentAndPassengerPermutation\n ) {\n newSeatServices = [...newSeatServices, selectedServiceFromState];\n }\n }\n\n if (seatServiceToToggle.quantity > 0) {\n newSeatServices = [...newSeatServices, seatServiceToToggle];\n }\n\n setSelectedServicesState(newSeatServices);\n };\n\n const currencyToUse =\n getCurrencyForSeatMaps(seatMaps) ?? offer.total_currency;\n\n return (\n <Modal isOpen={isOpen} onClose={() => onClose(selectedServices)}>\n <SeatSelectionModalHeader\n segmentAndPassengerPermutationsCount={\n segmentAndPassengerPermutations.length\n }\n currentSegment={currentSegment}\n currentPassengerName={currentPassengerName}\n currentSegmentAndPassengerPermutationsIndex={currentPermutationIndex}\n setCurrentSegmentAndPassengerPermutationsIndex={\n setCurrentPermutationIndex\n }\n />\n <SeatSelectionModalBody\n selectedServicesMap={selectedServicesStateMap}\n seatMap={currentSeatMap}\n onSeatToggled={onSeatToggle}\n currentPassengerId={currentPassengerId}\n currentPassengerName={currentPassengerName}\n currentSegmentId={currentSegmentId}\n />\n <SeatSelectionModalFooter\n seatMaps={seatMaps}\n currency={currencyToUse}\n selectedServices={selectedServicesState}\n servicePrices={servicePricesMap}\n isFirstSegment={currentPermutationIndex === 0}\n isLastSegment={\n currentPermutationIndex + 1 === segmentAndPassengerPermutations.length\n }\n onNextSegmentButtonClicked={() => {\n setCurrentPermutationIndex(currentPermutationIndex + 1);\n }}\n onPreviousSegmentButtonClicked={() => {\n setCurrentPermutationIndex(currentPermutationIndex - 1);\n }}\n onClose={() => onClose(selectedServicesState)}\n />\n </Modal>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap } from \"@duffel/api/types\";\n\nexport const getCabinsForSegmentAndDeck = (forDeck: number, seatMap: SeatMap) =>\n seatMap.cabins.filter((cabin) => cabin.deck === forDeck);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n SeatMapCabin,\n SeatMapCabinRowSectionElementAmenity,\n} from \"@duffel/api/types\";\n\nexport const getSymbols = (\n cabins: SeatMapCabin[]\n): Set<SeatMapCabinRowSectionElementAmenity> => {\n const results: Set<SeatMapCabinRowSectionElementAmenity> = new Set();\n for (const cabin of cabins) {\n for (const row of cabin.rows) {\n for (const section of row.sections) {\n for (const element of section.elements) {\n if (element.type !== \"seat\" && element.type !== \"empty\") {\n results.add(element.type);\n }\n }\n }\n }\n }\n return results;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMapCabin } from \"@duffel/api/types\";\n\nexport const hasWings = (cabin: SeatMapCabin, rowIndex: number) =>\n Boolean(\n cabin.wings &&\n cabin.wings.first_row_index <= rowIndex &&\n cabin.wings.last_row_index >= rowIndex\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { getCabinsForSegmentAndDeck } from \"@lib/getCabinsForSegmentAndDeck\";\nimport { getSymbols } from \"@lib/getSymbols\";\nimport { hasWings } from \"@lib/hasWings\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\nimport { CreateOrderService, SeatMap as SeatMapType } from \"@duffel/api/types\";\nimport { DeckSelect } from \"./DeckSelect\";\nimport { Legend } from \"./Legend\";\nimport { Row } from \"./Row\";\nimport { SeatMapUnavailable } from \"./SeatMapUnavailable\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface SeatMapProps {\n seatMap: SeatMapType;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n currentPassengerId: string;\n currentPassengerName: string;\n currentSegmentId: string;\n}\n\nexport const SeatMap: React.FC<SeatMapProps> = ({\n seatMap,\n onSeatToggled,\n selectedServicesMap,\n currentPassengerId,\n currentPassengerName,\n currentSegmentId,\n}) => {\n const [selectedDeck, setSelectedDeck] = React.useState(0);\n\n if (!seatMap || !seatMap.cabins || !seatMap.cabins.length) {\n return <SeatMapUnavailable />;\n }\n\n const cabins = getCabinsForSegmentAndDeck(selectedDeck, seatMap);\n const hasMultipleDecks = cabins.length !== seatMap.cabins.length;\n const anyHasWings = seatMap.cabins.some((cabin) => cabin.wings);\n\n if (!cabins || !cabins.length) {\n return <SeatMapUnavailable />;\n }\n\n const symbols = getSymbols(cabins);\n\n return (\n <div\n className={classNames(\"seat-map\", {\n \"seat-map--wings\": anyHasWings,\n })}\n >\n {hasMultipleDecks && (\n <DeckSelect\n value={selectedDeck}\n setValue={(value) => {\n setSelectedDeck(value);\n }}\n />\n )}\n <div className=\"seat-map__legend-container\">\n <Legend symbols={symbols} />\n </div>\n {cabins.map((cabin, cabinIndex) => (\n <div\n key={`cabin-${cabinIndex}`}\n className=\"seat-map__map-container\"\n style={{ \"--CABIN-AISLES\": cabin.aisles } as React.CSSProperties}\n >\n {cabin.rows.map((row, rowIndex) => (\n <Row\n key={rowIndex}\n row={row}\n hasWings={hasWings(cabin, rowIndex)}\n onSeatToggled={onSeatToggled}\n selectedServicesMap={selectedServicesMap}\n currentPassengerId={currentPassengerId}\n currentPassengerName={currentPassengerName}\n currentSegmentId={currentSegmentId}\n />\n ))}\n </div>\n ))}\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import classNames from \"classnames\";\nimport React from \"react\";\n\nexport interface TabsProps {\n /**\n * The currently selected tab option\n */\n value: string;\n\n /**\n * Callback for when a new tab option is selected\n */\n onChange: (value: string) => void;\n\n /**\n * The options you want to render on the tabs\n */\n options: string[];\n}\n\nexport const Tabs: React.FC<TabsProps> = ({ value, onChange, options }) => (\n <div className=\"seat-map__tab-select\">\n {options.map((option) => (\n <button\n key={option}\n type=\"button\"\n className={classNames(\"seat-map__tab-select-option\", {\n \"seat-map__tab-select-option--selected\": option === value,\n })}\n onClick={() => value !== option && onChange(option)}\n >\n {option}\n </button>\n ))}\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Tabs } from \"@components/shared/Tabs\";\nimport * as React from \"react\";\n\nexport interface DeckSelectProps {\n /**\n * The currently selected deck number\n */\n value: number;\n /**\n * What to do when the user selects a deck\n */\n setValue: (value: number) => void;\n}\n\n/**\n * The deck selection component for the seat map.\n */\nexport const DeckSelect: React.FC<DeckSelectProps> = ({ value, setValue }) => {\n const options = [\"Lower deck\", \"Upper deck\"];\n return (\n <Tabs\n options={options}\n value={options[value]}\n onChange={(item) => setValue(options.indexOf(item))}\n />\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon, IconName } from \"@components/shared/Icon\";\nimport { SeatMapCabinRowSectionElementAmenity } from \"@duffel/api/types\";\nimport * as React from \"react\";\n\nexport interface LegendProps {\n /**\n * The set of additional symbols to display\n */\n symbols: Set<SeatMapCabinRowSectionElementAmenity>;\n}\n\n/**\n * The legend for the seat map.\n */\nexport const Legend: React.FC<LegendProps> = ({ symbols }) => (\n <div className=\"seat-map__legend\">\n <span className=\"seat-map__legend-item\">\n <span\n className=\"seat-map__legend-seat seat-map__legend-seat--fee-payable\"\n aria-label=\"Additional cost for seat\"\n >\n <Icon\n name=\"seat_paid_indicator\"\n className=\"seat-map__legend-seat--fee-payable-indicator\"\n size={12}\n />\n </span>\n Additional Cost\n </span>\n <span className=\"seat-map__legend-item\">\n <span\n className=\"seat-map__legend-seat seat-map__legend-seat--included\"\n aria-label=\"Included seat\"\n />\n Included\n </span>\n <span className=\"seat-map__legend-item\">\n <span\n className=\"seat-map__legend-seat seat-map__legend-seat--selected\"\n aria-label=\"Selected seat\"\n />\n Selected\n </span>\n <span className=\"seat-map__legend-item\">\n <span className=\"seat-map__legend-seat\" aria-label=\"Unavailable seat\">\n <Icon name=\"close\" size={14} />\n </span>\n Unavailable\n </span>\n {[...symbols].map((symbol) => (\n <span\n key={symbol}\n className=\"seat-map__legend-item seat-map__legend-item--symbol\"\n >\n <Icon name={symbol as IconName} size={20} />\n {symbol.split(\"_\")[0]}\n </span>\n ))}\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n SeatMapCabinRow,\n SeatMapCabinRowSectionElementSeat,\n} from \"@duffel/api/types\";\n\nexport const getRowNumber = (row: SeatMapCabinRow): string | null => {\n const seats = Object.values(row.sections)\n .map((section) => section.elements)\n .reduce((acc, val) => acc.concat(val), [])\n .filter(\n (element) => element.type === \"seat\"\n ) as SeatMapCabinRowSectionElementSeat[];\n\n return seats.length > 0\n ? seats[0].designator.substring(0, seats[0].designator.length - 1)\n : null;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import classNames from \"classnames\";\nimport * as React from \"react\";\nimport { Element } from \"./Element\";\nimport { EmptyElement } from \"./EmptyElement\";\nimport {\n CreateOrderService,\n SeatMapCabinRow,\n SeatMapCabinRowSection,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\ninterface RowSectionProps {\n row: SeatMapCabinRow;\n rowNumber: string | null;\n hasWings: boolean;\n section: SeatMapCabinRowSection;\n sectionIndex: number;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n currentPassengerId: string;\n currentPassengerName: string;\n currentSegmentId: string;\n}\n\nexport const RowSection: React.FC<RowSectionProps> = ({\n row,\n rowNumber,\n hasWings,\n section,\n sectionIndex,\n onSeatToggled,\n selectedServicesMap,\n currentPassengerId,\n currentPassengerName,\n currentSegmentId,\n}) => {\n const rowLength = Object.keys(row.sections).length;\n const isOneSectionRow = rowLength === 1;\n\n return (\n <React.Fragment key={sectionIndex}>\n <div\n className={classNames(\"map-section\", {\n \"map-section--left\": sectionIndex === 0,\n \"map-section--right\": !isOneSectionRow\n ? sectionIndex === rowLength - 1\n : false,\n \"map-section--wing\": hasWings,\n })}\n >\n {section.elements.length > 0 ? (\n section.elements.map((element, elementIndex) => (\n <React.Fragment key={elementIndex}>\n <Element\n sectionIndex={sectionIndex}\n elementIndex={elementIndex}\n element={element}\n selectedServicesMap={selectedServicesMap}\n onSeatToggled={onSeatToggled}\n currentPassengerId={currentPassengerId}\n currentSegmentId={currentSegmentId}\n currentPassengerName={currentPassengerName}\n />\n </React.Fragment>\n ))\n ) : (\n <EmptyElement />\n )}\n </div>\n {(sectionIndex < rowLength - 1 ||\n (isOneSectionRow && sectionIndex < rowLength)) && (\n <span className=\"map-section__aisle\">{rowNumber}</span>\n )}\n {isOneSectionRow && sectionIndex === row.sections.length - 1 && (\n <EmptyElement />\n )}\n </React.Fragment>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon, IconName } from \"@components/shared/Icon\";\nimport { SeatMapCabinRowSectionElementAmenity } from \"@duffel/api/types\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\n\nconst amenitiesWithoutWrapper = [\"bassinet\", \"exit_row\"];\n\nexport interface AmenityProps {\n type: SeatMapCabinRowSectionElementAmenity;\n}\n\nexport const Amenity: React.FC<AmenityProps> = ({ type }) => (\n <div\n className={classNames(\"map-element map-element--amenity\", {\n \"map-element--wrapped\": !amenitiesWithoutWrapper.includes(type),\n })}\n aria-label={type.toString()}\n >\n <Icon name={type as IconName} size={16} />\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import * as React from \"react\";\n\nexport const EmptyElement: React.FC = () => (\n <div className=\"map-element map-element--empty\" />\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared/Icon\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\n\ninterface ExitElementProps {\n isRight: boolean;\n}\n\nexport const ExitElement: React.FC<ExitElementProps> = ({ isRight }) => (\n <div\n className={classNames(\"map-element map-element--exit\", {\n \"map-element--exit--right\": isRight,\n })}\n >\n {isRight ? <Icon name=\"exit_row_right\" /> : <Icon name=\"exit_row\" />}\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "export const getPassengerInitials = (passengerName = \"\") =>\n passengerName\n .split(\" \")\n .map((partOfTheName) => partOfTheName[0])\n .slice(0, 2)\n .join(\"\");\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared/Icon\";\nimport {\n CreateOrderService,\n SeatMapCabinRowSectionElementSeat,\n} from \"@duffel/api/types\";\nimport { getPassengerInitials } from \"@lib/getPassengerInitials\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\nimport { SeatInfo } from \"./SeatInfo\";\nimport { SeatUnavailable } from \"./SeatUnavailable\";\nimport { WithServiceInformation } from \"src/types\";\n\ninterface SeatElementProps {\n element: SeatMapCabinRowSectionElementSeat;\n currentSegmentId: string;\n currentPassengerId: string;\n currentPassengerName: string;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n}\n\nexport const SeatElement: React.FC<SeatElementProps> = ({\n element,\n currentPassengerId,\n currentSegmentId,\n currentPassengerName,\n onSeatToggled,\n selectedServicesMap,\n}) => {\n const seatServiceFromElement = element.available_services.find(\n (service) => service.passenger_id === currentPassengerId\n );\n if (!seatServiceFromElement) return <SeatUnavailable seat={element} />;\n\n const selectedServiceFromMap = Object.values(selectedServicesMap).find(\n (service) =>\n service.serviceInformation?.designator === element.designator &&\n service.serviceInformation?.segmentId === currentSegmentId\n );\n\n const isSeatSelected = selectedServiceFromMap != undefined;\n\n const seatLabel = isSeatSelected\n ? getPassengerInitials(\n selectedServiceFromMap.serviceInformation?.passengerName\n )\n : element.designator.charAt(element.designator.length - 1);\n\n const isFeePayable =\n !isNaN(+seatServiceFromElement?.total_amount) &&\n +seatServiceFromElement?.total_amount !== 0;\n\n const isSeatSelectionAvaiable =\n !isSeatSelected &&\n seatServiceFromElement.passenger_id === currentPassengerId;\n\n const isActionable =\n !isSeatSelected ||\n (isSeatSelected &&\n currentSegmentId ===\n selectedServiceFromMap.serviceInformation?.segmentId &&\n currentPassengerId ===\n selectedServiceFromMap.serviceInformation?.passengerId);\n\n const seatClassName = classNames(\"map-element\", \"map-element__seat\", {\n \"map-element--available\": isSeatSelectionAvaiable,\n \"map-element--selected\": isSeatSelected,\n \"map-element--actionable\": isActionable,\n });\n\n const priceLabel = moneyStringFormatter(\n seatServiceFromElement.total_currency\n )(+seatServiceFromElement.total_amount);\n\n const isSeatInfoDisplayed =\n isSeatSelected &&\n currentSegmentId === selectedServiceFromMap.serviceInformation?.segmentId &&\n currentPassengerId ===\n selectedServiceFromMap.serviceInformation?.passengerId;\n\n return (\n <>\n <button\n data-testid={`seat-${element.designator}`}\n id={element.designator}\n className={seatClassName}\n onClick={() => {\n if (!isActionable) return;\n onSeatToggled({\n quantity: isSeatSelected ? 0 : 1,\n id: seatServiceFromElement.id,\n serviceInformation: {\n type: \"seat\",\n segmentId: currentSegmentId,\n passengerId: currentPassengerId,\n passengerName: currentPassengerName,\n designator: element.designator,\n disclosures: element.disclosures,\n total_amount: seatServiceFromElement.total_amount,\n total_currency: seatServiceFromElement.total_currency,\n },\n });\n }}\n aria-label={`${element.designator} ${\n element.name || \"Seat\"\n } ${priceLabel}`}\n >\n {isFeePayable && (\n <Icon\n name=\"seat_paid_indicator\"\n className=\"map-element--fee-payable\"\n size={16}\n />\n )}\n {seatLabel}\n </button>\n {isSeatInfoDisplayed && (\n <SeatInfo seat={element} service={seatServiceFromElement} />\n )}\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n SeatMapCabinRowSectionAvailableService,\n SeatMapCabinRowSectionElementSeat,\n} from \"@duffel/api/types\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport * as React from \"react\";\n\nexport interface SeatInfoProps {\n seat: SeatMapCabinRowSectionElementSeat | null;\n service: SeatMapCabinRowSectionAvailableService | undefined;\n}\n\nexport const SeatInfo: React.FC<SeatInfoProps> = ({ seat, service }) => {\n const price = service\n ? moneyStringFormatter(service.total_currency)(+service.total_amount)\n : \"\";\n\n return (\n <div className=\"seat-info\">\n <div className=\"seat-info__details\">\n <strong>{seat?.designator}</strong>\n <span>{seat?.name || \"Seat\"} </span>\n <strong>{price}</strong>\n </div>\n {seat?.disclosures.map((disclosure, index) => (\n <div key={index} className=\"seat-info__disclosure\">\n {disclosure}\n </div>\n ))}\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared/Icon\";\nimport { SeatMapCabinRowSectionElementSeat } from \"@duffel/api/types\";\nimport * as React from \"react\";\n\nexport const SeatUnavailable: React.FC<{\n seat: SeatMapCabinRowSectionElementSeat;\n}> = ({ seat }) => (\n <span\n className=\"map-element map-element__seat\"\n aria-label={`${seat.designator} ${seat.name || \"Seat\"} Unavailable`}\n >\n <Icon name=\"close\" size={14} />\n </span>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { isSeatElement } from \"@lib/isSeatElement\";\nimport * as React from \"react\";\nimport { Amenity } from \"./Amenity\";\nimport { EmptyElement } from \"./EmptyElement\";\nimport { ExitElement } from \"./ExitElement\";\nimport { SeatElement } from \"./SeatElement\";\nimport {\n CreateOrderService,\n SeatMapCabinRowSectionElement,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\ninterface ElementProps {\n sectionIndex: number;\n elementIndex: number;\n element: SeatMapCabinRowSectionElement;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n currentPassengerId: string;\n currentSegmentId: string;\n currentPassengerName: string;\n}\n\nexport const Element: React.FC<ElementProps> = ({\n element,\n elementIndex,\n sectionIndex,\n onSeatToggled,\n selectedServicesMap,\n currentPassengerId,\n currentSegmentId,\n currentPassengerName,\n}) => {\n return (\n <>\n {isSeatElement(element) ? (\n <SeatElement\n currentSegmentId={currentSegmentId}\n currentPassengerId={currentPassengerId}\n currentPassengerName={currentPassengerName}\n selectedServicesMap={selectedServicesMap}\n key={elementIndex}\n element={element}\n onSeatToggled={onSeatToggled}\n />\n ) : element.type === \"empty\" ? (\n <EmptyElement key={elementIndex} />\n ) : element.type === \"exit_row\" ? (\n <ExitElement key={elementIndex} isRight={sectionIndex > 0} />\n ) : (\n <Amenity key={elementIndex} type={element.type} />\n )}\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { getRowNumber } from \"@lib/getRowNumber\";\nimport * as React from \"react\";\nimport { RowSection } from \"./RowSection\";\nimport { CreateOrderService, SeatMapCabinRow } from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface RowProps {\n row: SeatMapCabinRow;\n hasWings: boolean;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n currentPassengerId: string;\n currentPassengerName: string;\n currentSegmentId: string;\n}\n\nexport const Row: React.FC<RowProps> = ({\n row,\n hasWings,\n onSeatToggled,\n selectedServicesMap,\n currentPassengerId,\n currentPassengerName,\n currentSegmentId,\n}) => {\n const rowNumber = getRowNumber(row);\n\n return (\n <>\n {row.sections.map((section, sectionIndex) => (\n <RowSection\n key={sectionIndex}\n row={row}\n rowNumber={rowNumber}\n hasWings={hasWings}\n section={section}\n sectionIndex={sectionIndex}\n selectedServicesMap={selectedServicesMap}\n onSeatToggled={onSeatToggled}\n currentPassengerId={currentPassengerId}\n currentPassengerName={currentPassengerName}\n currentSegmentId={currentSegmentId}\n />\n ))}\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { NonIdealState } from \"@components/shared/NonIdealState\";\nimport * as React from \"react\";\n\nexport const SeatMapUnavailable: React.FC = () => (\n <NonIdealState>\n <p style={{ marginBlock: \"0\" }} className=\"p1--semibold\">\n Seat selection unavailable\n </p>\n <p\n className=\"p1--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginBlock: \"12px\",\n textAlign: \"center\",\n }}\n >\n Unfortunately seat selection is not available for this flight. A seat will\n be allocated by the airline.\n </p>\n </NonIdealState>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { ModalBody } from \"@components/shared/Modal\";\nimport React from \"react\";\nimport { SeatMap, SeatMapProps } from \"./SeatMap\";\n\nexport type SeatSelectionModalBodyProps = SeatMapProps;\n\nexport const SeatSelectionModalBody: React.FC<SeatSelectionModalBodyProps> = (\n props\n) => (\n <ModalBody>\n <SeatMap {...props} />\n </ModalBody>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Button } from \"@components/shared/Button\";\nimport { ServicePriceMapById } from \"@lib/getServicePriceMapById\";\nimport { getTotalAmountForServicesWithPriceMap } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\nimport { CreateOrder, SeatMap } from \"@duffel/api/types\";\n\nexport interface SeatSelectionModalFooterProps {\n currency: string;\n selectedServices: CreateOrder[\"services\"];\n servicePrices: ServicePriceMapById;\n\n isFirstSegment: boolean;\n isLastSegment: boolean;\n\n onNextSegmentButtonClicked: () => void;\n onPreviousSegmentButtonClicked: () => void;\n onClose: () => void;\n seatMaps: SeatMap[];\n}\n\nexport const SeatSelectionModalFooter: React.FC<\n SeatSelectionModalFooterProps\n> = ({\n selectedServices,\n servicePrices,\n currency,\n isFirstSegment,\n isLastSegment,\n onNextSegmentButtonClicked,\n onPreviousSegmentButtonClicked,\n onClose,\n seatMaps,\n}) => {\n const totalQuantity = getTotalQuantity(selectedServices);\n const totalAmount = getTotalAmountForServicesWithPriceMap(\n servicePrices,\n selectedServices,\n seatMaps\n );\n const totalAmountLabel = moneyStringFormatter(currency)(totalAmount);\n const isOneWay = isFirstSegment && isLastSegment;\n\n return (\n <div style={{ padding: \"16px 24px 24px\" }}>\n <div className=\"flex--space-between\">\n <div>Price for {withPlural(totalQuantity, \"seat\", \"seats\")}</div>\n <div className=\"h3--semibold\">+ {totalAmountLabel}</div>\n </div>\n\n <div\n style={\n isOneWay\n ? { marginTop: \"16px\", display: \"grid\" }\n : {\n marginTop: \"16px\",\n display: \"grid\",\n columnGap: \"12px\",\n gridTemplateColumns: \"repeat(2, 1fr)\",\n }\n }\n >\n {!isOneWay && (\n <Button\n size={48}\n disabled={isFirstSegment}\n variant=\"outlined\"\n onClick={() => onPreviousSegmentButtonClicked()}\n >\n Back\n </Button>\n )}\n\n <Button\n size={48}\n data-testid=\"confirm-selection-for-seats\"\n onClick={() =>\n isLastSegment ? onClose() : onNextSegmentButtonClicked()\n }\n >\n {isLastSegment ? \"Confirm\" : \"Next\"}\n </Button>\n </div>\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferSliceSegment } from \"@duffel/api/types\";\nimport { formatDateString } from \"@lib/formatDate\";\nimport React from \"react\";\n\nexport interface SeatSelectionModalHeaderProps {\n segmentAndPassengerPermutationsCount: number;\n currentSegment: OfferSliceSegment;\n currentPassengerName: string;\n\n currentSegmentAndPassengerPermutationsIndex: number;\n setCurrentSegmentAndPassengerPermutationsIndex: (index: number) => void;\n}\n\nexport const SeatSelectionModalHeader: React.FC<\n SeatSelectionModalHeaderProps\n> = ({\n segmentAndPassengerPermutationsCount,\n currentSegmentAndPassengerPermutationsIndex,\n currentSegment,\n currentPassengerName,\n setCurrentSegmentAndPassengerPermutationsIndex,\n}) => (\n <div style={{ padding: \"24px 24px 16px\" }}>\n {segmentAndPassengerPermutationsCount > 1 && (\n <div style={{ display: \"flex\", columnGap: \"4px\" }}>\n {Array(segmentAndPassengerPermutationsCount)\n .fill(0)\n .map((_, index) =>\n index === currentSegmentAndPassengerPermutationsIndex ? (\n <ActiveSegment key={`segment_${index}`} />\n ) : (\n <InactiveSegment\n key={`segment_${index}`}\n onClick={() =>\n setCurrentSegmentAndPassengerPermutationsIndex(index)\n }\n />\n )\n )}\n </div>\n )}\n <h2\n className=\"h3--semibold\"\n style={\n segmentAndPassengerPermutationsCount > 1\n ? { marginBlock: \"12px 0px\" }\n : {}\n }\n >\n Flight to {currentSegment.destination.iata_code}\n <span\n className=\"p2--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginLeft: \"8px\",\n }}\n >\n {formatDateString(currentSegment.departing_at)}\n </span>\n </h2>\n <p\n className=\"h3--semibold\"\n style={{ color: `var(--GREY-600)`, marginBlock: \"0 4px\" }}\n >\n {currentPassengerName}\n </p>\n </div>\n);\n\nconst InactiveSegment: React.FC<{\n style?: React.CSSProperties;\n onClick?: React.MouseEventHandler<HTMLButtonElement>;\n}> = ({ onClick, style }) => (\n <button\n onClick={onClick}\n style={{\n border: \"none\",\n width: \"4px\",\n height: \"4px\",\n padding: \"0\",\n borderRadius: \"4px\",\n backgroundColor:\n \"var(--TERTIARY, rgba(var(--ACCENT), var(--ACCENT-LIGHT-200)))\",\n transition: \"background-color 0.3s var(--TRANSITION-CUBIC-BEZIER)\",\n ...style,\n }}\n />\n);\n\nconst ActiveSegment = () => (\n <InactiveSegment\n onClick={undefined}\n style={{\n backgroundColor: \"var(--SECONDARY, rgb(var(--ACCENT)))\",\n }}\n />\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { StripeError } from \"@stripe/stripe-js\";\nimport { createRoot, Root } from \"react-dom/client\";\nimport { DuffelPayments, DuffelPaymentsProps } from \"./DuffelPayments\";\n\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/no-namespace\n namespace JSX {\n interface IntrinsicElements {\n \"duffel-payments\": React.DetailedHTMLProps<\n React.HTMLAttributes<HTMLElement>,\n HTMLElement\n >;\n }\n }\n}\n\nconst CUSTOM_ELEMENT_TAG = \"duffel-payments\";\n\ntype DuffelPaymentsCustomElementRenderArguments = Pick<\n DuffelPaymentsProps,\n \"paymentIntentClientToken\" | \"styles\"\n>;\n\nclass DuffelPaymentsCustomElement extends HTMLElement {\n /**\n * The React root for displaying content inside a browser DOM element.\n */\n private root!: Root;\n\n /**\n * `connectedCallback` is called to initialise the custom element\n */\n connectedCallback() {\n const container = document.createElement(\"div\");\n this.appendChild(container);\n\n this.root = createRoot(container);\n }\n\n /**\n * When this function is called, it will render/re-render\n * the `DuffelPayments` component with the given props.\n */\n public render(withProps: DuffelPaymentsCustomElementRenderArguments) {\n if (!this.root) {\n throw \"It was not possible to render `duffel-payments` because `this.root` is missing.\";\n }\n\n this.root.render(\n <DuffelPayments\n {...withProps}\n onSuccessfulPayment={() => {\n this.dispatchEvent(\n new CustomEvent(\"onSuccessfulPayment\", {\n composed: true,\n })\n );\n }}\n onFailedPayment={(error: StripeError) => {\n this.dispatchEvent(\n new CustomEvent(\"onFailedPayment\", {\n detail: { error },\n composed: true,\n })\n );\n }}\n />\n );\n }\n}\n\nwindow.customElements.get(CUSTOM_ELEMENT_TAG) ||\n window.customElements.define(CUSTOM_ELEMENT_TAG, DuffelPaymentsCustomElement);\n\nfunction tryToGetDuffelPaymentsCustomElement(\n caller: string\n): DuffelPaymentsCustomElement {\n const element =\n document.querySelector<DuffelPaymentsCustomElement>(CUSTOM_ELEMENT_TAG);\n if (!element) {\n throw new Error(\n `Could not find duffel-payments element in the DOM. Maybe you need to call ${caller} after 'window.onload'?`\n );\n }\n return element;\n}\n\nexport function renderDuffelPaymentsCustomElement(\n props: DuffelPaymentsCustomElementRenderArguments\n) {\n const element = tryToGetDuffelPaymentsCustomElement(\n \"renderDuffelPaymentsCustomElement\"\n );\n element.render(props);\n}\n\nexport function onDuffelPaymentsSuccessfulPayment(\n onSuccessfulPayment: DuffelPaymentsProps[\"onSuccessfulPayment\"]\n) {\n const element = tryToGetDuffelPaymentsCustomElement(\n \"onDuffelPaymentsPayloadReady\"\n );\n\n // using `as EventListener` here because typescript doesn't know the event type for `onPayloadReady`\n // There's a few different suggestions to resolve this seemed good enough\n // You can learn more here: https://github.com/microsoft/TypeScript/issues/28357\n element.addEventListener(\n \"onPayloadReady\",\n onSuccessfulPayment as EventListener\n );\n}\n\ntype OnFailedPaymentCustomEvent = CustomEvent<{\n error: StripeError;\n}>;\nexport function onDuffelPaymentsFailedPayment(\n onFailedPayment: DuffelPaymentsProps[\"onFailedPayment\"]\n) {\n const element = tryToGetDuffelPaymentsCustomElement(\n \"onDuffelPaymentsPayloadReady\"\n );\n const eventListener = (event: OnFailedPaymentCustomEvent) => {\n onFailedPayment(event.detail.error);\n };\n\n // using `as EventListener` here because typescript doesn't know the event type for `onPayloadReady`\n // There's a few different suggestions to resolve this seemed good enough\n // You can learn more here: https://github.com/microsoft/TypeScript/issues/28357\n element.addEventListener(\"onPayloadReady\", eventListener as EventListener);\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { ErrorBoundary } from \"@components/shared/ErrorBoundary\";\nimport { hasHighLuminance } from \"@lib/hasHighLuminance\";\nimport { initializeLogger } from \"@lib/logging\";\nimport {\n CardElement,\n Elements,\n useElements,\n useStripe,\n} from \"@stripe/react-stripe-js\";\nimport { StripeCardElement, StripeError, loadStripe } from \"@stripe/stripe-js\";\nimport * as React from \"react\";\nimport { CustomStyles } from \"../../types\";\nimport { Button } from \"../shared/Button\";\n\nconst COMPONENT_CDN = process.env.COMPONENT_CDN || \"\";\nconst hrefToComponentStyles = `${COMPONENT_CDN}/global.css`;\n\nconst STRIPE_CARD_ELEMENT = \"card\";\nconst COMPONENT_VERSION = process.env.COMPONENT_VERSION;\n\nexport interface DuffelPaymentsProps {\n paymentIntentClientToken: string;\n onSuccessfulPayment: () => void;\n onFailedPayment: (error: StripeError) => void;\n\n styles?: CustomStyles;\n debug?: boolean;\n}\n\nconst CARD_ELEMENT_STYLE_BASE = {\n color: \"var(--GREY-900)\",\n fontFamily:\n '\"-apple-system\", \"BlinkMacSystemFont\", \"Segoe UI\", \"Roboto\", \"Oxygen\", \"Ubuntu\", \"Cantarell\", \"Fira Sans\", \"Droid Sans\", \"Helvetica Neue\", \"sans-serif\"',\n fontSmoothing: \"antialiased\",\n fontSize: \"16px\",\n \"::placeholder\": {\n color: \"#ababb4\",\n },\n};\n\nconst CARD_ELEMENT_STYLE_INVALID = {\n color: \"#ef4444\",\n iconColor: \"#ef4444\",\n};\n\nconst CardPaymentComponent: React.FC<DuffelPaymentsProps> = ({\n styles,\n paymentIntentClientToken,\n onSuccessfulPayment,\n onFailedPayment,\n}) => {\n const [cardElement, setCardElement] =\n React.useState<StripeCardElement | null>(null);\n const [isComplete, setIsComplete] = React.useState<boolean>(false);\n const [isInvalid, setIsInvalid] = React.useState<boolean>(false);\n const [isProcessing, setIsProcessing] = React.useState<boolean>(false);\n const [errorMessage, setErrorMessage] = React.useState<string>(\"\");\n const stripe = useStripe();\n const elements = useElements();\n\n React.useEffect(() => {\n if (elements && !cardElement) {\n const maybeCard = elements?.getElement(STRIPE_CARD_ELEMENT);\n maybeCard && setCardElement(maybeCard as StripeCardElement);\n }\n }, [elements, cardElement]);\n\n React.useEffect(() => {\n if (cardElement) {\n cardElement.on(\"change\", (event) => {\n const { error, complete } = event;\n\n if (error) {\n setIsInvalid(true);\n setErrorMessage(error.message);\n } else {\n setIsInvalid(false);\n }\n complete ? setIsComplete(true) : setIsComplete(false);\n });\n }\n }, [cardElement]);\n\n // User is responsible for handling outcome of payment.\n const handleSubmit = async (\n e: React.MouseEvent<HTMLFormElement, MouseEvent>\n ) => {\n e.preventDefault();\n if (!stripe || !elements) {\n return;\n }\n\n if (cardElement) {\n setIsProcessing(true);\n const decodedDuffelPaymentIntentClientToken = atob(\n paymentIntentClientToken\n );\n const parsedDuffelPaymentIntentClientToken = JSON.parse(\n decodedDuffelPaymentIntentClientToken\n );\n const { client_secret: clientSecret } =\n parsedDuffelPaymentIntentClientToken;\n\n const result = await stripe.confirmCardPayment(clientSecret, {\n payment_method: {\n card: cardElement,\n metadata: {\n duffel_components_version:\n COMPONENT_VERSION || \"failed-to-get-version\",\n },\n },\n });\n\n setIsProcessing(false);\n if (result.error) {\n const { error } = result;\n onFailedPayment(error);\n } else {\n onSuccessfulPayment();\n }\n }\n };\n\n return paymentIntentClientToken ? (\n <div className=\"card-payment__container\">\n <form onSubmit={handleSubmit}>\n {isProcessing && (\n <div\n className=\"card-payment--in-progress\"\n aria-live=\"polite\"\n aria-busy=\"true\"\n />\n )}\n <CardElement\n className=\"card-details\"\n options={{\n style: {\n base: {\n ...CARD_ELEMENT_STYLE_BASE,\n ...(styles?.fontFamily && {\n fontFamily: styles.fontFamily,\n }),\n },\n invalid: { ...CARD_ELEMENT_STYLE_INVALID },\n },\n }}\n />\n <div className=\"card-payment__container--invalid\" role=\"alert\">\n {isInvalid && errorMessage}\n </div>\n <Button\n className=\"card-payment__pay-button\"\n type=\"submit\"\n disabled={!isComplete || isProcessing}\n aria-label=\"Pay\"\n >\n {isProcessing ? \"Processing...\" : \"Pay\"}\n </Button>\n </form>\n </div>\n ) : null;\n};\n\nexport const DuffelPayments: React.FC<DuffelPaymentsProps> = (props) => {\n const [stripe, setStripe] = React.useState<Promise<any> | null>(null);\n initializeLogger(props.debug || false);\n\n const decodedDuffelPaymentIntentClientToken = atob(\n props.paymentIntentClientToken\n );\n\n let parsedDuffelPaymentIntentClientToken;\n\n try {\n parsedDuffelPaymentIntentClientToken = JSON.parse(\n decodedDuffelPaymentIntentClientToken\n );\n } catch (error) {\n throw new Error(\"Invalid Duffel payment intent client token provided\");\n }\n\n const { publishable_key: duffelPublishableKey } =\n parsedDuffelPaymentIntentClientToken;\n\n React.useEffect(() => {\n if (!stripe && duffelPublishableKey) {\n const stripe = loadStripe(duffelPublishableKey);\n stripe && setStripe(stripe);\n }\n }, [stripe, duffelPublishableKey]);\n\n const duffelComponentsStyle: React.CSSProperties = {\n ...(props.styles?.accentColor && {\n \"--ACCENT\": props.styles.accentColor,\n }),\n ...(props.styles?.accentColor &&\n hasHighLuminance(props.styles.accentColor) && {\n \"--SECONDARY\": \"black\",\n \"--TERTIARY\": \"grey\",\n }),\n ...(props.styles?.fontFamily && {\n \"--FONT-FAMILY\": props.styles.fontFamily,\n }),\n ...(props.styles?.buttonCornerRadius && {\n \"--BUTTON-RADIUS\": props.styles.buttonCornerRadius,\n }),\n // `as any` is needed here is needed because we want to set css variables\n // that are not part of the css properties type\n } as any;\n\n return (\n <>\n <link rel=\"stylesheet\" href={hrefToComponentStyles}></link>\n\n <div className=\"duffel-components\" style={duffelComponentsStyle}>\n <ErrorBoundary>\n <Elements stripe={stripe}>\n <CardPaymentComponent {...props} />\n </Elements>\n </ErrorBoundary>\n </div>\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "var V3_URL = 'https://js.stripe.com/v3';\nvar V3_URL_REGEX = /^https:\\/\\/js\\.stripe\\.com\\/v3\\/?(\\?.*)?$/;\nvar EXISTING_SCRIPT_MESSAGE = 'loadStripe.setLoadParameters was called but an existing Stripe.js script already exists in the document; existing script parameters will be used';\nvar findScript = function findScript() {\n var scripts = document.querySelectorAll(\"script[src^=\\\"\".concat(V3_URL, \"\\\"]\"));\n\n for (var i = 0; i < scripts.length; i++) {\n var script = scripts[i];\n\n if (!V3_URL_REGEX.test(script.src)) {\n continue;\n }\n\n return script;\n }\n\n return null;\n};\n\nvar injectScript = function injectScript(params) {\n var queryString = params && !params.advancedFraudSignals ? '?advancedFraudSignals=false' : '';\n var script = document.createElement('script');\n script.src = \"\".concat(V3_URL).concat(queryString);\n var headOrBody = document.head || document.body;\n\n if (!headOrBody) {\n throw new Error('Expected document.body not to be null. Stripe.js requires a <body> element.');\n }\n\n headOrBody.appendChild(script);\n return script;\n};\n\nvar registerWrapper = function registerWrapper(stripe, startTime) {\n if (!stripe || !stripe._registerWrapper) {\n return;\n }\n\n stripe._registerWrapper({\n name: 'stripe-js',\n version: \"1.54.0\",\n startTime: startTime\n });\n};\n\nvar stripePromise = null;\nvar loadScript = function loadScript(params) {\n // Ensure that we only attempt to load Stripe.js at most once\n if (stripePromise !== null) {\n return stripePromise;\n }\n\n stripePromise = new Promise(function (resolve, reject) {\n if (typeof window === 'undefined' || typeof document === 'undefined') {\n // Resolve to null when imported server side. This makes the module\n // safe to import in an isomorphic code base.\n resolve(null);\n return;\n }\n\n if (window.Stripe && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n }\n\n if (window.Stripe) {\n resolve(window.Stripe);\n return;\n }\n\n try {\n var script = findScript();\n\n if (script && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n } else if (!script) {\n script = injectScript(params);\n }\n\n script.addEventListener('load', function () {\n if (window.Stripe) {\n resolve(window.Stripe);\n } else {\n reject(new Error('Stripe.js not available'));\n }\n });\n script.addEventListener('error', function () {\n reject(new Error('Failed to load Stripe.js'));\n });\n } catch (error) {\n reject(error);\n return;\n }\n });\n return stripePromise;\n};\nvar initStripe = function initStripe(maybeStripe, args, startTime) {\n if (maybeStripe === null) {\n return null;\n }\n\n var stripe = maybeStripe.apply(undefined, args);\n registerWrapper(stripe, startTime);\n return stripe;\n}; // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\n// own script injection.\n\nvar stripePromise$1 = Promise.resolve().then(function () {\n return loadScript(null);\n});\nvar loadCalled = false;\nstripePromise$1[\"catch\"](function (err) {\n if (!loadCalled) {\n console.warn(err);\n }\n});\nvar loadStripe = function loadStripe() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n loadCalled = true;\n var startTime = Date.now();\n return stripePromise$1.then(function (maybeStripe) {\n return initStripe(maybeStripe, args, startTime);\n });\n};\n\nexport { loadStripe };\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\tvar nativeCodeString = '[native code]';\n\n\tfunction classNames() {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg)) {\n\t\t\t\tif (arg.length) {\n\t\t\t\t\tvar inner = classNames.apply(null, arg);\n\t\t\t\t\tif (inner) {\n\t\t\t\t\t\tclasses.push(inner);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\t\t\tclasses.push(arg.toString());\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tfor (var key in arg) {\n\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n", "(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react')) :\n typeof define === 'function' && define.amd ? define(['exports', 'react'], factory) :\n (global = global || self, factory(global.ReactStripe = {}, global.React));\n}(this, (function (exports, React) { 'use strict';\n\n React = React && Object.prototype.hasOwnProperty.call(React, 'default') ? React['default'] : React;\n\n function ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n\n if (enumerableOnly) {\n symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n }\n\n keys.push.apply(keys, symbols);\n }\n\n return keys;\n }\n\n function _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(Object(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(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n }\n\n return target;\n }\n\n function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n _typeof = function (obj) {\n return typeof obj;\n };\n } else {\n _typeof = function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n }\n\n function _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\n function _slicedToArray(arr, i) {\n return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();\n }\n\n function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n }\n\n function _iterableToArrayLimit(arr, i) {\n var _i = arr && (typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"]);\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n }\n\n function _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 }\n\n function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n\n return arr2;\n }\n\n function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n function createCommonjsModule(fn, module) {\n \treturn module = { exports: {} }, fn(module, module.exports), module.exports;\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\n var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n var ReactPropTypesSecret_1 = ReactPropTypesSecret;\n\n function emptyFunction() {}\n\n function emptyFunctionWithReset() {}\n\n emptyFunctionWithReset.resetWarningCache = emptyFunction;\n\n var factoryWithThrowingShims = function () {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret_1) {\n // It is still safe when called from React.\n return;\n }\n\n var err = new Error('Calling PropTypes validators directly is not supported by the `prop-types` package. ' + 'Use PropTypes.checkPropTypes() to call them. ' + 'Read more at http://fb.me/use-check-prop-types');\n err.name = 'Invariant Violation';\n throw err;\n }\n shim.isRequired = shim;\n\n function getShim() {\n return shim;\n }\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\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 checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n ReactPropTypes.PropTypes = ReactPropTypes;\n return ReactPropTypes;\n };\n\n var propTypes = createCommonjsModule(function (module) {\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 // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = factoryWithThrowingShims();\n }\n });\n\n var usePrevious = function usePrevious(value) {\n var ref = React.useRef(value);\n React.useEffect(function () {\n ref.current = value;\n }, [value]);\n return ref.current;\n };\n\n var isUnknownObject = function isUnknownObject(raw) {\n return raw !== null && _typeof(raw) === 'object';\n };\n var isPromise = function isPromise(raw) {\n return isUnknownObject(raw) && typeof raw.then === 'function';\n }; // We are using types to enforce the `stripe` prop in this lib,\n // but in an untyped integration `stripe` could be anything, so we need\n // to do some sanity validation to prevent type errors.\n\n var isStripe = function isStripe(raw) {\n return isUnknownObject(raw) && typeof raw.elements === 'function' && typeof raw.createToken === 'function' && typeof raw.createPaymentMethod === 'function' && typeof raw.confirmCardPayment === 'function';\n };\n\n var PLAIN_OBJECT_STR = '[object Object]';\n var isEqual = function isEqual(left, right) {\n if (!isUnknownObject(left) || !isUnknownObject(right)) {\n return left === right;\n }\n\n var leftArray = Array.isArray(left);\n var rightArray = Array.isArray(right);\n if (leftArray !== rightArray) return false;\n var leftPlainObject = Object.prototype.toString.call(left) === PLAIN_OBJECT_STR;\n var rightPlainObject = Object.prototype.toString.call(right) === PLAIN_OBJECT_STR;\n if (leftPlainObject !== rightPlainObject) return false; // not sure what sort of special object this is (regexp is one option), so\n // fallback to reference check.\n\n if (!leftPlainObject && !leftArray) return left === right;\n var leftKeys = Object.keys(left);\n var rightKeys = Object.keys(right);\n if (leftKeys.length !== rightKeys.length) return false;\n var keySet = {};\n\n for (var i = 0; i < leftKeys.length; i += 1) {\n keySet[leftKeys[i]] = true;\n }\n\n for (var _i = 0; _i < rightKeys.length; _i += 1) {\n keySet[rightKeys[_i]] = true;\n }\n\n var allKeys = Object.keys(keySet);\n\n if (allKeys.length !== leftKeys.length) {\n return false;\n }\n\n var l = left;\n var r = right;\n\n var pred = function pred(key) {\n return isEqual(l[key], r[key]);\n };\n\n return allKeys.every(pred);\n };\n\n var extractAllowedOptionsUpdates = function extractAllowedOptionsUpdates(options, prevOptions, immutableKeys) {\n if (!isUnknownObject(options)) {\n return null;\n }\n\n return Object.keys(options).reduce(function (newOptions, key) {\n var isUpdated = !isUnknownObject(prevOptions) || !isEqual(options[key], prevOptions[key]);\n\n if (immutableKeys.includes(key)) {\n if (isUpdated) {\n console.warn(\"Unsupported prop change: options.\".concat(key, \" is not a mutable property.\"));\n }\n\n return newOptions;\n }\n\n if (!isUpdated) {\n return newOptions;\n }\n\n return _objectSpread2(_objectSpread2({}, newOptions || {}), {}, _defineProperty({}, key, options[key]));\n }, null);\n };\n\n var INVALID_STRIPE_ERROR = 'Invalid prop `stripe` supplied to `Elements`. We recommend using the `loadStripe` utility from `@stripe/stripe-js`. See https://stripe.com/docs/stripe-js/react#elements-props-stripe for details.'; // We are using types to enforce the `stripe` prop in this lib, but in a real\n // integration `stripe` could be anything, so we need to do some sanity\n // validation to prevent type errors.\n\n var validateStripe = function validateStripe(maybeStripe) {\n if (maybeStripe === null || isStripe(maybeStripe)) {\n return maybeStripe;\n }\n\n throw new Error(INVALID_STRIPE_ERROR);\n };\n\n var parseStripeProp = function parseStripeProp(raw) {\n if (isPromise(raw)) {\n return {\n tag: 'async',\n stripePromise: Promise.resolve(raw).then(validateStripe)\n };\n }\n\n var stripe = validateStripe(raw);\n\n if (stripe === null) {\n return {\n tag: 'empty'\n };\n }\n\n return {\n tag: 'sync',\n stripe: stripe\n };\n };\n\n var ElementsContext = /*#__PURE__*/React.createContext(null);\n ElementsContext.displayName = 'ElementsContext';\n var parseElementsContext = function parseElementsContext(ctx, useCase) {\n if (!ctx) {\n throw new Error(\"Could not find Elements context; You need to wrap the part of your app that \".concat(useCase, \" in an <Elements> provider.\"));\n }\n\n return ctx;\n };\n var CartElementContext = /*#__PURE__*/React.createContext(null);\n CartElementContext.displayName = 'CartElementContext';\n var parseCartElementContext = function parseCartElementContext(ctx, useCase) {\n if (!ctx) {\n throw new Error(\"Could not find Elements context; You need to wrap the part of your app that \".concat(useCase, \" in an <Elements> provider.\"));\n }\n\n return ctx;\n };\n /**\n * The `Elements` provider allows you to use [Element components](https://stripe.com/docs/stripe-js/react#element-components) and access the [Stripe object](https://stripe.com/docs/js/initializing) in any nested component.\n * Render an `Elements` provider at the root of your React app so that it is available everywhere you need it.\n *\n * To use the `Elements` provider, call `loadStripe` from `@stripe/stripe-js` with your publishable key.\n * The `loadStripe` function will asynchronously load the Stripe.js script and initialize a `Stripe` object.\n * Pass the returned `Promise` to `Elements`.\n *\n * @docs https://stripe.com/docs/stripe-js/react#elements-provider\n */\n\n var Elements = function Elements(_ref) {\n var rawStripeProp = _ref.stripe,\n options = _ref.options,\n children = _ref.children;\n var parsed = React.useMemo(function () {\n return parseStripeProp(rawStripeProp);\n }, [rawStripeProp]);\n\n var _React$useState = React.useState(null),\n _React$useState2 = _slicedToArray(_React$useState, 2),\n cart = _React$useState2[0],\n setCart = _React$useState2[1];\n\n var _React$useState3 = React.useState(null),\n _React$useState4 = _slicedToArray(_React$useState3, 2),\n cartState = _React$useState4[0],\n setCartState = _React$useState4[1]; // For a sync stripe instance, initialize into context\n\n\n var _React$useState5 = React.useState(function () {\n return {\n stripe: parsed.tag === 'sync' ? parsed.stripe : null,\n elements: parsed.tag === 'sync' ? parsed.stripe.elements(options) : null\n };\n }),\n _React$useState6 = _slicedToArray(_React$useState5, 2),\n ctx = _React$useState6[0],\n setContext = _React$useState6[1];\n\n React.useEffect(function () {\n var isMounted = true;\n\n var safeSetContext = function safeSetContext(stripe) {\n setContext(function (ctx) {\n // no-op if we already have a stripe instance (https://github.com/stripe/react-stripe-js/issues/296)\n if (ctx.stripe) return ctx;\n return {\n stripe: stripe,\n elements: stripe.elements(options)\n };\n });\n }; // For an async stripePromise, store it in context once resolved\n\n\n if (parsed.tag === 'async' && !ctx.stripe) {\n parsed.stripePromise.then(function (stripe) {\n if (stripe && isMounted) {\n // Only update Elements context if the component is still mounted\n // and stripe is not null. We allow stripe to be null to make\n // handling SSR easier.\n safeSetContext(stripe);\n }\n });\n } else if (parsed.tag === 'sync' && !ctx.stripe) {\n // Or, handle a sync stripe instance going from null -> populated\n safeSetContext(parsed.stripe);\n }\n\n return function () {\n isMounted = false;\n };\n }, [parsed, ctx, options]); // Warn on changes to stripe prop\n\n var prevStripe = usePrevious(rawStripeProp);\n React.useEffect(function () {\n if (prevStripe !== null && prevStripe !== rawStripeProp) {\n console.warn('Unsupported prop change on Elements: You cannot change the `stripe` prop after setting it.');\n }\n }, [prevStripe, rawStripeProp]); // Apply updates to elements when options prop has relevant changes\n\n var prevOptions = usePrevious(options);\n React.useEffect(function () {\n if (!ctx.elements) {\n return;\n }\n\n var updates = extractAllowedOptionsUpdates(options, prevOptions, ['clientSecret', 'fonts']);\n\n if (updates) {\n ctx.elements.update(updates);\n }\n }, [options, prevOptions, ctx.elements]); // Attach react-stripe-js version to stripe.js instance\n\n React.useEffect(function () {\n var anyStripe = ctx.stripe;\n\n if (!anyStripe || !anyStripe._registerWrapper || !anyStripe.registerAppInfo) {\n return;\n }\n\n anyStripe._registerWrapper({\n name: 'react-stripe-js',\n version: \"2.1.0\"\n });\n\n anyStripe.registerAppInfo({\n name: 'react-stripe-js',\n version: \"2.1.0\",\n url: 'https://stripe.com/docs/stripe-js/react'\n });\n }, [ctx.stripe]);\n return /*#__PURE__*/React.createElement(ElementsContext.Provider, {\n value: ctx\n }, /*#__PURE__*/React.createElement(CartElementContext.Provider, {\n value: {\n cart: cart,\n setCart: setCart,\n cartState: cartState,\n setCartState: setCartState\n }\n }, children));\n };\n Elements.propTypes = {\n stripe: propTypes.any,\n options: propTypes.object\n };\n var useElementsContextWithUseCase = function useElementsContextWithUseCase(useCaseMessage) {\n var ctx = React.useContext(ElementsContext);\n return parseElementsContext(ctx, useCaseMessage);\n };\n var useCartElementContextWithUseCase = function useCartElementContextWithUseCase(useCaseMessage) {\n var ctx = React.useContext(CartElementContext);\n return parseCartElementContext(ctx, useCaseMessage);\n };\n /**\n * @docs https://stripe.com/docs/stripe-js/react#useelements-hook\n */\n\n var useElements = function useElements() {\n var _useElementsContextWi = useElementsContextWithUseCase('calls useElements()'),\n elements = _useElementsContextWi.elements;\n\n return elements;\n };\n /**\n * @docs https://stripe.com/docs/stripe-js/react#usestripe-hook\n */\n\n var useStripe = function useStripe() {\n var _useElementsContextWi2 = useElementsContextWithUseCase('calls useStripe()'),\n stripe = _useElementsContextWi2.stripe;\n\n return stripe;\n };\n /**\n * @docs https://stripe.com/docs/payments/checkout/cart-element\n */\n\n var useCartElement = function useCartElement() {\n var _useCartElementContex = useCartElementContextWithUseCase('calls useCartElement()'),\n cart = _useCartElementContex.cart;\n\n return cart;\n };\n /**\n * @docs https://stripe.com/docs/payments/checkout/cart-element\n */\n\n var useCartElementState = function useCartElementState() {\n var _useCartElementContex2 = useCartElementContextWithUseCase('calls useCartElementState()'),\n cartState = _useCartElementContex2.cartState;\n\n return cartState;\n };\n /**\n * @docs https://stripe.com/docs/stripe-js/react#elements-consumer\n */\n\n var ElementsConsumer = function ElementsConsumer(_ref2) {\n var children = _ref2.children;\n var ctx = useElementsContextWithUseCase('mounts <ElementsConsumer>'); // Assert to satisfy the busted React.FC return type (it should be ReactNode)\n\n return children(ctx);\n };\n ElementsConsumer.propTypes = {\n children: propTypes.func.isRequired\n };\n\n var useAttachEvent = function useAttachEvent(element, event, cb) {\n var cbDefined = !!cb;\n var cbRef = React.useRef(cb); // In many integrations the callback prop changes on each render.\n // Using a ref saves us from calling element.on/.off every render.\n\n React.useEffect(function () {\n cbRef.current = cb;\n }, [cb]);\n React.useEffect(function () {\n if (!cbDefined || !element) {\n return function () {};\n }\n\n var decoratedCb = function decoratedCb() {\n if (cbRef.current) {\n cbRef.current.apply(cbRef, arguments);\n }\n };\n\n element.on(event, decoratedCb);\n return function () {\n element.off(event, decoratedCb);\n };\n }, [cbDefined, event, element, cbRef]);\n };\n\n var capitalized = function capitalized(str) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n };\n\n var createElementComponent = function createElementComponent(type, isServer) {\n var displayName = \"\".concat(capitalized(type), \"Element\");\n\n var ClientElement = function ClientElement(_ref) {\n var id = _ref.id,\n className = _ref.className,\n _ref$options = _ref.options,\n options = _ref$options === void 0 ? {} : _ref$options,\n onBlur = _ref.onBlur,\n onFocus = _ref.onFocus,\n onReady = _ref.onReady,\n onChange = _ref.onChange,\n onEscape = _ref.onEscape,\n onClick = _ref.onClick,\n onLoadError = _ref.onLoadError,\n onLoaderStart = _ref.onLoaderStart,\n onNetworksChange = _ref.onNetworksChange,\n onCheckout = _ref.onCheckout,\n onLineItemClick = _ref.onLineItemClick,\n onConfirm = _ref.onConfirm,\n onCancel = _ref.onCancel,\n onShippingAddressChange = _ref.onShippingAddressChange,\n onShippingRateChange = _ref.onShippingRateChange;\n\n var _useElementsContextWi = useElementsContextWithUseCase(\"mounts <\".concat(displayName, \">\")),\n elements = _useElementsContextWi.elements;\n\n var _React$useState = React.useState(null),\n _React$useState2 = _slicedToArray(_React$useState, 2),\n element = _React$useState2[0],\n setElement = _React$useState2[1];\n\n var elementRef = React.useRef(null);\n var domNode = React.useRef(null);\n\n var _useCartElementContex = useCartElementContextWithUseCase(\"mounts <\".concat(displayName, \">\")),\n setCart = _useCartElementContex.setCart,\n setCartState = _useCartElementContex.setCartState; // For every event where the merchant provides a callback, call element.on\n // with that callback. If the merchant ever changes the callback, removes\n // the old callback with element.off and then call element.on with the new one.\n\n\n useAttachEvent(element, 'blur', onBlur);\n useAttachEvent(element, 'focus', onFocus);\n useAttachEvent(element, 'escape', onEscape);\n useAttachEvent(element, 'click', onClick);\n useAttachEvent(element, 'loaderror', onLoadError);\n useAttachEvent(element, 'loaderstart', onLoaderStart);\n useAttachEvent(element, 'networkschange', onNetworksChange);\n useAttachEvent(element, 'lineitemclick', onLineItemClick);\n useAttachEvent(element, 'confirm', onConfirm);\n useAttachEvent(element, 'cancel', onCancel);\n useAttachEvent(element, 'shippingaddresschange', onShippingAddressChange);\n useAttachEvent(element, 'shippingratechange', onShippingRateChange);\n var readyCallback;\n\n if (type === 'cart') {\n readyCallback = function readyCallback(event) {\n setCartState(event);\n onReady && onReady(event);\n };\n } else if (onReady) {\n if (type === 'expressCheckout') {\n // Passes through the event, which includes visible PM types\n readyCallback = onReady;\n } else {\n // For other Elements, pass through the Element itself.\n readyCallback = function readyCallback() {\n onReady(element);\n };\n }\n }\n\n useAttachEvent(element, 'ready', readyCallback);\n var changeCallback = type === 'cart' ? function (event) {\n setCartState(event);\n onChange && onChange(event);\n } : onChange;\n useAttachEvent(element, 'change', changeCallback);\n var checkoutCallback = type === 'cart' ? function (event) {\n setCartState(event);\n onCheckout && onCheckout(event);\n } : onCheckout;\n useAttachEvent(element, 'checkout', checkoutCallback);\n React.useLayoutEffect(function () {\n if (elementRef.current === null && elements && domNode.current !== null) {\n var newElement = elements.create(type, options);\n\n if (type === 'cart' && setCart) {\n // we know that elements.create return value must be of type StripeCartElement if type is 'cart',\n // we need to cast because typescript is not able to infer which overloaded method is used based off param type\n setCart(newElement);\n } // Store element in a ref to ensure it's _immediately_ available in cleanup hooks in StrictMode\n\n\n elementRef.current = newElement; // Store element in state to facilitate event listener attachment\n\n setElement(newElement);\n newElement.mount(domNode.current);\n }\n }, [elements, options, setCart]);\n var prevOptions = usePrevious(options);\n React.useEffect(function () {\n if (!elementRef.current) {\n return;\n }\n\n var updates = extractAllowedOptionsUpdates(options, prevOptions, ['paymentRequest']);\n\n if (updates) {\n elementRef.current.update(updates);\n }\n }, [options, prevOptions]);\n React.useLayoutEffect(function () {\n return function () {\n if (elementRef.current) {\n elementRef.current.destroy();\n elementRef.current = null;\n }\n };\n }, []);\n return /*#__PURE__*/React.createElement(\"div\", {\n id: id,\n className: className,\n ref: domNode\n });\n }; // Only render the Element wrapper in a server environment.\n\n\n var ServerElement = function ServerElement(props) {\n // Validate that we are in the right context by calling useElementsContextWithUseCase.\n useElementsContextWithUseCase(\"mounts <\".concat(displayName, \">\"));\n useCartElementContextWithUseCase(\"mounts <\".concat(displayName, \">\"));\n var id = props.id,\n className = props.className;\n return /*#__PURE__*/React.createElement(\"div\", {\n id: id,\n className: className\n });\n };\n\n var Element = isServer ? ServerElement : ClientElement;\n Element.propTypes = {\n id: propTypes.string,\n className: propTypes.string,\n onChange: propTypes.func,\n onBlur: propTypes.func,\n onFocus: propTypes.func,\n onReady: propTypes.func,\n onEscape: propTypes.func,\n onClick: propTypes.func,\n onLoadError: propTypes.func,\n onLoaderStart: propTypes.func,\n onNetworksChange: propTypes.func,\n onCheckout: propTypes.func,\n onLineItemClick: propTypes.func,\n onConfirm: propTypes.func,\n onCancel: propTypes.func,\n onShippingAddressChange: propTypes.func,\n onShippingRateChange: propTypes.func,\n options: propTypes.object\n };\n Element.displayName = displayName;\n Element.__elementType = type;\n return Element;\n };\n\n var isServer = typeof window === 'undefined';\n /**\n * Requires beta access:\n * Contact [Stripe support](https://support.stripe.com/) for more information.\n *\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var AuBankAccountElement = createElementComponent('auBankAccount', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var CardElement = createElementComponent('card', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var CardNumberElement = createElementComponent('cardNumber', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var CardExpiryElement = createElementComponent('cardExpiry', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var CardCvcElement = createElementComponent('cardCvc', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var FpxBankElement = createElementComponent('fpxBank', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var IbanElement = createElementComponent('iban', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var IdealBankElement = createElementComponent('idealBank', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var P24BankElement = createElementComponent('p24Bank', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var EpsBankElement = createElementComponent('epsBank', isServer);\n var PaymentElement = createElementComponent('payment', isServer);\n /**\n * Requires beta access:\n * Contact [Stripe support](https://support.stripe.com/) for more information.\n *\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var ExpressCheckoutElement = createElementComponent('expressCheckout', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var PaymentRequestButtonElement = createElementComponent('paymentRequestButton', isServer);\n /**\n * Requires beta access:\n * Contact [Stripe support](https://support.stripe.com/) for more information.\n *\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var LinkAuthenticationElement = createElementComponent('linkAuthentication', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var AddressElement = createElementComponent('address', isServer);\n /**\n * @deprecated\n * Use `AddressElement` instead.\n *\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var ShippingAddressElement = createElementComponent('shippingAddress', isServer);\n /**\n * Requires beta access:\n * Contact [Stripe support](https://support.stripe.com/) for more information.\n *\n * @docs https://stripe.com/docs/elements/cart-element\n */\n\n var CartElement = createElementComponent('cart', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var PaymentMethodMessagingElement = createElementComponent('paymentMethodMessaging', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var AffirmMessageElement = createElementComponent('affirmMessage', isServer);\n /**\n * @docs https://stripe.com/docs/stripe-js/react#element-components\n */\n\n var AfterpayClearpayMessageElement = createElementComponent('afterpayClearpayMessage', isServer);\n\n exports.AddressElement = AddressElement;\n exports.AffirmMessageElement = AffirmMessageElement;\n exports.AfterpayClearpayMessageElement = AfterpayClearpayMessageElement;\n exports.AuBankAccountElement = AuBankAccountElement;\n exports.CardCvcElement = CardCvcElement;\n exports.CardElement = CardElement;\n exports.CardExpiryElement = CardExpiryElement;\n exports.CardNumberElement = CardNumberElement;\n exports.CartElement = CartElement;\n exports.Elements = Elements;\n exports.ElementsConsumer = ElementsConsumer;\n exports.EpsBankElement = EpsBankElement;\n exports.ExpressCheckoutElement = ExpressCheckoutElement;\n exports.FpxBankElement = FpxBankElement;\n exports.IbanElement = IbanElement;\n exports.IdealBankElement = IdealBankElement;\n exports.LinkAuthenticationElement = LinkAuthenticationElement;\n exports.P24BankElement = P24BankElement;\n exports.PaymentElement = PaymentElement;\n exports.PaymentMethodMessagingElement = PaymentMethodMessagingElement;\n exports.PaymentRequestButtonElement = PaymentRequestButtonElement;\n exports.ShippingAddressElement = ShippingAddressElement;\n exports.useCartElement = useCartElement;\n exports.useCartElementState = useCartElementState;\n exports.useElements = useElements;\n exports.useStripe = useStripe;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n})));\n", "/**\n * This file is one of the entry points for the library -- `@duffel/components/custom-elements`.\n * If you'd like to expose other custom element functions, please add them here.\n */\nexport {\n onDuffelAncillariesPayloadReady,\n renderDuffelAncillariesCustomElement,\n} from \"./components/DuffelAncillaries/DuffelAncillariesCustomElement\";\nexport {\n onDuffelPaymentsFailedPayment,\n onDuffelPaymentsSuccessfulPayment,\n renderDuffelPaymentsCustomElement,\n} from \"./components/DuffelPayments/DuffelPaymentsCustomElement\";\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { createRoot, Root } from \"react-dom/client\";\nimport {\n DuffelAncillariesPropsWithClientKeyAndOfferId,\n DuffelAncillariesPropsWithOfferIdForFixture,\n DuffelAncillariesPropsWithOffersAndSeatMaps,\n DuffelAncillariesPropWithOfferAndClientKey,\n OnPayloadReady,\n OnPayloadReadyMetadata,\n} from \"../../types/DuffelAncillariesProps\";\nimport { DuffelAncillaries } from \"./DuffelAncillaries\";\nimport { CreateOrder } from \"@duffel/api/types\";\n\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/no-namespace\n namespace JSX {\n interface IntrinsicElements {\n \"duffel-ancillaries\": React.DetailedHTMLProps<\n React.HTMLAttributes<HTMLElement>,\n HTMLElement\n >;\n }\n }\n}\n\nconst CUSTOM_ELEMENT_TAG = \"duffel-ancillaries\";\n\n// A bit reptitive but typescript is not clever enough\n// to infer the correct type if we just use\n// `Omit<DuffelAncillariesProps, 'onPayloadReady'>`\ntype DuffelAncillariesCustomElementRenderArguments =\n | Omit<DuffelAncillariesPropsWithOfferIdForFixture, \"onPayloadReady\">\n | Omit<DuffelAncillariesPropsWithClientKeyAndOfferId, \"onPayloadReady\">\n | Omit<DuffelAncillariesPropWithOfferAndClientKey, \"onPayloadReady\">\n | Omit<DuffelAncillariesPropsWithOffersAndSeatMaps, \"onPayloadReady\">;\n\nclass DuffelAncillariesCustomElement extends HTMLElement {\n /**\n * The React root for displaying content inside a browser DOM element.\n */\n private root!: Root;\n\n /**\n * `connectedCallback` is called to initialise the custom element\n */\n connectedCallback() {\n const container = document.createElement(\"div\");\n this.attachShadow({ mode: \"open\" }).appendChild(container);\n\n this.root = createRoot(container);\n }\n\n /**\n * When this function is called, it will render/re-render\n * the `DuffelAncillaries` component with the given props.\n */\n public render(withProps: DuffelAncillariesCustomElementRenderArguments) {\n if (!this.root) {\n throw \"It was not possible to render `duffel-ancillaries` because `this.root` is missing.\";\n }\n\n this.root.render(\n <DuffelAncillaries\n {...withProps}\n onPayloadReady={(data, metadata) => {\n this.dispatchEvent(\n new CustomEvent(\"onPayloadReady\", {\n detail: { data, metadata },\n composed: true,\n })\n );\n }}\n />\n );\n }\n}\n\nwindow.customElements.get(CUSTOM_ELEMENT_TAG) ||\n window.customElements.define(\n CUSTOM_ELEMENT_TAG,\n DuffelAncillariesCustomElement\n );\n\nfunction tryToGetDuffelAncillariesCustomElement(\n caller: string\n): DuffelAncillariesCustomElement {\n const element =\n document.querySelector<DuffelAncillariesCustomElement>(CUSTOM_ELEMENT_TAG);\n if (!element) {\n throw new Error(\n `Could not find duffel-ancillaries element in the DOM. Maybe you need to call ${caller} after 'window.onload'?`\n );\n }\n return element;\n}\n\nexport function renderDuffelAncillariesCustomElement(\n props: DuffelAncillariesCustomElementRenderArguments\n) {\n const element = tryToGetDuffelAncillariesCustomElement(\n \"renderDuffelAncillariesCustomElement\"\n );\n element.render(props);\n}\n\ntype OnPayloadReadyCustomEvent = CustomEvent<{\n data: CreateOrder;\n metadata: OnPayloadReadyMetadata;\n}>;\n\nexport function onDuffelAncillariesPayloadReady(\n onPayloadReady: OnPayloadReady\n) {\n const element = tryToGetDuffelAncillariesCustomElement(\n \"onDuffelAncillariesPayloadReady\"\n );\n const eventListener = (event: OnPayloadReadyCustomEvent) => {\n onPayloadReady(event.detail.data, event.detail.metadata);\n };\n\n // using `as EventListener` here because typescript doesn't know the event type for `onPayloadReady`\n // There's a few different suggestions to resolve this seemed good enough\n // You can learn more here: https://github.com/microsoft/TypeScript/issues/28357\n element.addEventListener(\"onPayloadReady\", eventListener as EventListener);\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n\nimport type { PolymorphicEvent, Primitive } from '@sentry/types';\n\n// eslint-disable-next-line @typescript-eslint/unbound-method\nconst objectToString = Object.prototype.toString;\n\n/**\n * Checks whether given value's type is one of a few Error or Error-like\n * {@link isError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isError(wat: unknown): wat is Error {\n switch (objectToString.call(wat)) {\n case '[object Error]':\n case '[object Exception]':\n case '[object DOMException]':\n return true;\n default:\n return isInstanceOf(wat, Error);\n }\n}\n/**\n * Checks whether given value is an instance of the given built-in class.\n *\n * @param wat The value to be checked\n * @param className\n * @returns A boolean representing the result.\n */\nfunction isBuiltin(wat: unknown, className: string): boolean {\n return objectToString.call(wat) === `[object ${className}]`;\n}\n\n/**\n * Checks whether given value's type is ErrorEvent\n * {@link isErrorEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isErrorEvent(wat: unknown): boolean {\n return isBuiltin(wat, 'ErrorEvent');\n}\n\n/**\n * Checks whether given value's type is DOMError\n * {@link isDOMError}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isDOMError(wat: unknown): boolean {\n return isBuiltin(wat, 'DOMError');\n}\n\n/**\n * Checks whether given value's type is DOMException\n * {@link isDOMException}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isDOMException(wat: unknown): boolean {\n return isBuiltin(wat, 'DOMException');\n}\n\n/**\n * Checks whether given value's type is a string\n * {@link isString}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isString(wat: unknown): wat is string {\n return isBuiltin(wat, 'String');\n}\n\n/**\n * Checks whether given value is a primitive (undefined, null, number, boolean, string, bigint, symbol)\n * {@link isPrimitive}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isPrimitive(wat: unknown): wat is Primitive {\n return wat === null || (typeof wat !== 'object' && typeof wat !== 'function');\n}\n\n/**\n * Checks whether given value's type is an object literal\n * {@link isPlainObject}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isPlainObject(wat: unknown): wat is Record<string, unknown> {\n return isBuiltin(wat, 'Object');\n}\n\n/**\n * Checks whether given value's type is an Event instance\n * {@link isEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isEvent(wat: unknown): wat is PolymorphicEvent {\n return typeof Event !== 'undefined' && isInstanceOf(wat, Event);\n}\n\n/**\n * Checks whether given value's type is an Element instance\n * {@link isElement}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isElement(wat: unknown): boolean {\n return typeof Element !== 'undefined' && isInstanceOf(wat, Element);\n}\n\n/**\n * Checks whether given value's type is an regexp\n * {@link isRegExp}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isRegExp(wat: unknown): wat is RegExp {\n return isBuiltin(wat, 'RegExp');\n}\n\n/**\n * Checks whether given value has a then function.\n * @param wat A value to be checked.\n */\nexport function isThenable(wat: any): wat is PromiseLike<any> {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return Boolean(wat && wat.then && typeof wat.then === 'function');\n}\n\n/**\n * Checks whether given value's type is a SyntheticEvent\n * {@link isSyntheticEvent}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isSyntheticEvent(wat: unknown): boolean {\n return isPlainObject(wat) && 'nativeEvent' in wat && 'preventDefault' in wat && 'stopPropagation' in wat;\n}\n\n/**\n * Checks whether given value is NaN\n * {@link isNaN}.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isNaN(wat: unknown): boolean {\n return typeof wat === 'number' && wat !== wat;\n}\n\n/**\n * Checks whether given value's type is an instance of provided constructor.\n * {@link isInstanceOf}.\n *\n * @param wat A value to be checked.\n * @param base A constructor to be used in a check.\n * @returns A boolean representing the result.\n */\nexport function isInstanceOf(wat: any, base: any): boolean {\n try {\n return wat instanceof base;\n } catch (_e) {\n return false;\n }\n}\n\ninterface VueViewModel {\n // Vue3\n __isVue?: boolean;\n // Vue2\n _isVue?: boolean;\n}\n/**\n * Checks whether given value's type is a Vue ViewModel.\n *\n * @param wat A value to be checked.\n * @returns A boolean representing the result.\n */\nexport function isVueViewModel(wat: unknown): boolean {\n // Not using Object.prototype.toString because in Vue 3 it would read the instance's Symbol(Symbol.toStringTag) property.\n return !!(typeof wat === 'object' && wat !== null && ((wat as VueViewModel).__isVue || (wat as VueViewModel)._isVue));\n}\n", "import { isRegExp, isString, isVueViewModel } from './is';\n\nexport { escapeStringForRegex } from './vendor/escapeStringForRegex';\n\n/**\n * Truncates given string to the maximum characters count\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string (0 = unlimited)\n * @returns string Encoded\n */\nexport function truncate(str: string, max: number = 0): string {\n if (typeof str !== 'string' || max === 0) {\n return str;\n }\n return str.length <= max ? str : `${str.slice(0, max)}...`;\n}\n\n/**\n * This is basically just `trim_line` from\n * https://github.com/getsentry/sentry/blob/master/src/sentry/lang/javascript/processor.py#L67\n *\n * @param str An object that contains serializable values\n * @param max Maximum number of characters in truncated string\n * @returns string Encoded\n */\nexport function snipLine(line: string, colno: number): string {\n let newLine = line;\n const lineLength = newLine.length;\n if (lineLength <= 150) {\n return newLine;\n }\n if (colno > lineLength) {\n // eslint-disable-next-line no-param-reassign\n colno = lineLength;\n }\n\n let start = Math.max(colno - 60, 0);\n if (start < 5) {\n start = 0;\n }\n\n let end = Math.min(start + 140, lineLength);\n if (end > lineLength - 5) {\n end = lineLength;\n }\n if (end === lineLength) {\n start = Math.max(end - 140, 0);\n }\n\n newLine = newLine.slice(start, end);\n if (start > 0) {\n newLine = `'{snip} ${newLine}`;\n }\n if (end < lineLength) {\n newLine += ' {snip}';\n }\n\n return newLine;\n}\n\n/**\n * Join values in array\n * @param input array of values to be joined together\n * @param delimiter string to be placed in-between values\n * @returns Joined values\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function safeJoin(input: any[], delimiter?: string): string {\n if (!Array.isArray(input)) {\n return '';\n }\n\n const output = [];\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < input.length; i++) {\n const value = input[i];\n try {\n // This is a hack to fix a Vue3-specific bug that causes an infinite loop of\n // console warnings. This happens when a Vue template is rendered with\n // an undeclared variable, which we try to stringify, ultimately causing\n // Vue to issue another warning which repeats indefinitely.\n // see: https://github.com/getsentry/sentry-javascript/pull/8981\n if (isVueViewModel(value)) {\n output.push('[VueViewModel]');\n } else {\n output.push(String(value));\n }\n } catch (e) {\n output.push('[value cannot be serialized]');\n }\n }\n\n return output.join(delimiter);\n}\n\n/**\n * Checks if the given value matches a regex or string\n *\n * @param value The string to test\n * @param pattern Either a regex or a string against which `value` will be matched\n * @param requireExactStringMatch If true, `value` must match `pattern` exactly. If false, `value` will match\n * `pattern` if it contains `pattern`. Only applies to string-type patterns.\n */\nexport function isMatchingPattern(\n value: string,\n pattern: RegExp | string,\n requireExactStringMatch: boolean = false,\n): boolean {\n if (!isString(value)) {\n return false;\n }\n\n if (isRegExp(pattern)) {\n return pattern.test(value);\n }\n if (isString(pattern)) {\n return requireExactStringMatch ? value === pattern : value.includes(pattern);\n }\n\n return false;\n}\n\n/**\n * Test the given string against an array of strings and regexes. By default, string matching is done on a\n * substring-inclusion basis rather than a strict equality basis\n *\n * @param testString The string to test\n * @param patterns The patterns against which to test the string\n * @param requireExactStringMatch If true, `testString` must match one of the given string patterns exactly in order to\n * count. If false, `testString` will match a string pattern if it contains that pattern.\n * @returns\n */\nexport function stringMatchesSomePattern(\n testString: string,\n patterns: Array<string | RegExp> = [],\n requireExactStringMatch: boolean = false,\n): boolean {\n return patterns.some(pattern => isMatchingPattern(testString, pattern, requireExactStringMatch));\n}\n", "import type { Event, EventHint, Exception, ExtendedError, StackParser } from '@sentry/types';\n\nimport { isInstanceOf } from './is';\nimport { truncate } from './string';\n\n/**\n * Creates exceptions inside `event.exception.values` for errors that are nested on properties based on the `key` parameter.\n */\nexport function applyAggregateErrorsToEvent(\n exceptionFromErrorImplementation: (stackParser: StackParser, ex: Error) => Exception,\n parser: StackParser,\n maxValueLimit: number = 250,\n key: string,\n limit: number,\n event: Event,\n hint?: EventHint,\n): void {\n if (!event.exception || !event.exception.values || !hint || !isInstanceOf(hint.originalException, Error)) {\n return;\n }\n\n // Generally speaking the last item in `event.exception.values` is the exception originating from the original Error\n const originalException: Exception | undefined =\n event.exception.values.length > 0 ? event.exception.values[event.exception.values.length - 1] : undefined;\n\n // We only create exception grouping if there is an exception in the event.\n if (originalException) {\n event.exception.values = truncateAggregateExceptions(\n aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n hint.originalException as ExtendedError,\n key,\n event.exception.values,\n originalException,\n 0,\n ),\n maxValueLimit,\n );\n }\n}\n\nfunction aggregateExceptionsFromError(\n exceptionFromErrorImplementation: (stackParser: StackParser, ex: Error) => Exception,\n parser: StackParser,\n limit: number,\n error: ExtendedError,\n key: string,\n prevExceptions: Exception[],\n exception: Exception,\n exceptionId: number,\n): Exception[] {\n if (prevExceptions.length >= limit + 1) {\n return prevExceptions;\n }\n\n let newExceptions = [...prevExceptions];\n\n if (isInstanceOf(error[key], Error)) {\n applyExceptionGroupFieldsForParentException(exception, exceptionId);\n const newException = exceptionFromErrorImplementation(parser, error[key]);\n const newExceptionId = newExceptions.length;\n applyExceptionGroupFieldsForChildException(newException, key, newExceptionId, exceptionId);\n newExceptions = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n error[key],\n key,\n [newException, ...newExceptions],\n newException,\n newExceptionId,\n );\n }\n\n // This will create exception grouping for AggregateErrors\n // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AggregateError\n if (Array.isArray(error.errors)) {\n error.errors.forEach((childError, i) => {\n if (isInstanceOf(childError, Error)) {\n applyExceptionGroupFieldsForParentException(exception, exceptionId);\n const newException = exceptionFromErrorImplementation(parser, childError);\n const newExceptionId = newExceptions.length;\n applyExceptionGroupFieldsForChildException(newException, `errors[${i}]`, newExceptionId, exceptionId);\n newExceptions = aggregateExceptionsFromError(\n exceptionFromErrorImplementation,\n parser,\n limit,\n childError,\n key,\n [newException, ...newExceptions],\n newException,\n newExceptionId,\n );\n }\n });\n }\n\n return newExceptions;\n}\n\nfunction applyExceptionGroupFieldsForParentException(exception: Exception, exceptionId: number): void {\n // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n exception.mechanism = {\n ...exception.mechanism,\n is_exception_group: true,\n exception_id: exceptionId,\n };\n}\n\nfunction applyExceptionGroupFieldsForChildException(\n exception: Exception,\n source: string,\n exceptionId: number,\n parentId: number | undefined,\n): void {\n // Don't know if this default makes sense. The protocol requires us to set these values so we pick *some* default.\n exception.mechanism = exception.mechanism || { type: 'generic', handled: true };\n\n exception.mechanism = {\n ...exception.mechanism,\n type: 'chained',\n source,\n exception_id: exceptionId,\n parent_id: parentId,\n };\n}\n\n/**\n * Truncate the message (exception.value) of all exceptions in the event.\n * Because this event processor is ran after `applyClientOptions`,\n * we need to truncate the message of the added exceptions here.\n */\nfunction truncateAggregateExceptions(exceptions: Exception[], maxValueLength: number): Exception[] {\n return exceptions.map(exception => {\n if (exception.value) {\n exception.value = truncate(exception.value, maxValueLength);\n }\n return exception;\n });\n}\n", "/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the logger, or b) put your function elsewhere.\n *\n * Note: This file was originally called `global.ts`, but was changed to unblock users which might be doing\n * string replaces with bundlers like Vite for `global` (would break imports that rely on importing from utils/src/global).\n *\n * Why worldwide?\n *\n * Why not?\n */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport type { Integration } from '@sentry/types';\n\nimport type { SdkSource } from './env';\n\n/** Internal global with common properties and Sentry extensions */\nexport interface InternalGlobal {\n navigator?: { userAgent?: string };\n console: Console;\n Sentry?: {\n Integrations?: Integration[];\n };\n onerror?: {\n (msg: unknown, url: unknown, line: unknown, column: unknown, error: unknown): boolean;\n __SENTRY_INSTRUMENTED__?: true;\n __SENTRY_LOADER__?: true;\n };\n onunhandledrejection?: {\n (event: unknown): boolean;\n __SENTRY_INSTRUMENTED__?: true;\n __SENTRY_LOADER__?: true;\n };\n SENTRY_ENVIRONMENT?: string;\n SENTRY_DSN?: string;\n SENTRY_RELEASE?: {\n id?: string;\n };\n SENTRY_SDK_SOURCE?: SdkSource;\n /**\n * Debug IDs are indirectly injected by Sentry CLI or bundler plugins to directly reference a particular source map\n * for resolving of a source file. The injected code will place an entry into the record for each loaded bundle/JS\n * file.\n */\n _sentryDebugIds?: Record<string, string>;\n __SENTRY__: {\n globalEventProcessors: any;\n hub: any;\n logger: any;\n extensions?: {\n /** Extension methods for the hub, which are bound to the current Hub instance */\n // eslint-disable-next-line @typescript-eslint/ban-types\n [key: string]: Function;\n };\n };\n /**\n * Raw module metadata that is injected by bundler plugins.\n *\n * Keys are `error.stack` strings, values are the metadata.\n */\n _sentryModuleMetadata?: Record<string, any>;\n}\n\n// The code below for 'isGlobalObj' and 'GLOBAL_OBJ' was copied from core-js before modification\n// https://github.com/zloirock/core-js/blob/1b944df55282cdc99c90db5f49eb0b6eda2cc0a3/packages/core-js/internals/global.js\n// core-js has the following licence:\n//\n// Copyright (c) 2014-2022 Denis Pushkarev\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\n/** Returns 'obj' if it's the global object, otherwise returns undefined */\nfunction isGlobalObj(obj: { Math?: Math }): any | undefined {\n return obj && obj.Math == Math ? obj : undefined;\n}\n\n/** Get's the global object for the current JavaScript runtime */\nexport const GLOBAL_OBJ: InternalGlobal =\n (typeof globalThis == 'object' && isGlobalObj(globalThis)) ||\n // eslint-disable-next-line no-restricted-globals\n (typeof window == 'object' && isGlobalObj(window)) ||\n (typeof self == 'object' && isGlobalObj(self)) ||\n (typeof global == 'object' && isGlobalObj(global)) ||\n (function (this: any) {\n return this;\n })() ||\n {};\n\n/**\n * @deprecated Use GLOBAL_OBJ instead or WINDOW from @sentry/browser. This will be removed in v8\n */\nexport function getGlobalObject<T>(): T & InternalGlobal {\n return GLOBAL_OBJ as T & InternalGlobal;\n}\n\n/**\n * Returns a global singleton contained in the global `__SENTRY__` object.\n *\n * If the singleton doesn't already exist in `__SENTRY__`, it will be created using the given factory\n * function and added to the `__SENTRY__` object.\n *\n * @param name name of the global singleton on __SENTRY__\n * @param creator creator Factory function to create the singleton if it doesn't already exist on `__SENTRY__`\n * @param obj (Optional) The global object on which to look for `__SENTRY__`, if not `GLOBAL_OBJ`'s return value\n * @returns the singleton\n */\nexport function getGlobalSingleton<T>(name: keyof InternalGlobal['__SENTRY__'], creator: () => T, obj?: unknown): T {\n const gbl = (obj || GLOBAL_OBJ) as InternalGlobal;\n const __SENTRY__ = (gbl.__SENTRY__ = gbl.__SENTRY__ || {});\n const singleton = __SENTRY__[name] || (__SENTRY__[name] = creator());\n return singleton;\n}\n", "import { isString } from './is';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nconst DEFAULT_MAX_STRING_LENGTH = 80;\n\n/**\n * Given a child DOM element, returns a query-selector statement describing that\n * and its ancestors\n * e.g. [HTMLElement] => body > div > input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nexport function htmlTreeAsString(\n elem: unknown,\n options: string[] | { keyAttrs?: string[]; maxStringLength?: number } = {},\n): string {\n type SimpleNode = {\n parentNode: SimpleNode;\n } | null;\n\n if (!elem) {\n return '<unknown>';\n }\n\n // try/catch both:\n // - accessing event.target (see getsentry/raven-js#838, #768)\n // - `htmlTreeAsString` because it's complex, and just accessing the DOM incorrectly\n // - can throw an exception in some circumstances.\n try {\n let currentElem = elem as SimpleNode;\n const MAX_TRAVERSE_HEIGHT = 5;\n const out = [];\n let height = 0;\n let len = 0;\n const separator = ' > ';\n const sepLength = separator.length;\n let nextStr;\n const keyAttrs = Array.isArray(options) ? options : options.keyAttrs;\n const maxStringLength = (!Array.isArray(options) && options.maxStringLength) || DEFAULT_MAX_STRING_LENGTH;\n\n while (currentElem && height++ < MAX_TRAVERSE_HEIGHT) {\n nextStr = _htmlElementAsString(currentElem, keyAttrs);\n // bail out if\n // - nextStr is the 'html' element\n // - the length of the string that would be created exceeds maxStringLength\n // (ignore this limit if we are on the first iteration)\n if (nextStr === 'html' || (height > 1 && len + out.length * sepLength + nextStr.length >= maxStringLength)) {\n break;\n }\n\n out.push(nextStr);\n\n len += nextStr.length;\n currentElem = currentElem.parentNode;\n }\n\n return out.reverse().join(separator);\n } catch (_oO) {\n return '<unknown>';\n }\n}\n\n/**\n * Returns a simple, query-selector representation of a DOM element\n * e.g. [HTMLElement] => input#foo.btn[name=baz]\n * @returns generated DOM path\n */\nfunction _htmlElementAsString(el: unknown, keyAttrs?: string[]): string {\n const elem = el as {\n tagName?: string;\n id?: string;\n className?: string;\n getAttribute(key: string): string;\n };\n\n const out = [];\n let className;\n let classes;\n let key;\n let attr;\n let i;\n\n if (!elem || !elem.tagName) {\n return '';\n }\n\n out.push(elem.tagName.toLowerCase());\n\n // Pairs of attribute keys defined in `serializeAttribute` and their values on element.\n const keyAttrPairs =\n keyAttrs && keyAttrs.length\n ? keyAttrs.filter(keyAttr => elem.getAttribute(keyAttr)).map(keyAttr => [keyAttr, elem.getAttribute(keyAttr)])\n : null;\n\n if (keyAttrPairs && keyAttrPairs.length) {\n keyAttrPairs.forEach(keyAttrPair => {\n out.push(`[${keyAttrPair[0]}=\"${keyAttrPair[1]}\"]`);\n });\n } else {\n if (elem.id) {\n out.push(`#${elem.id}`);\n }\n\n // eslint-disable-next-line prefer-const\n className = elem.className;\n if (className && isString(className)) {\n classes = className.split(/\\s+/);\n for (i = 0; i < classes.length; i++) {\n out.push(`.${classes[i]}`);\n }\n }\n }\n const allowedAttrs = ['aria-label', 'type', 'name', 'title', 'alt'];\n for (i = 0; i < allowedAttrs.length; i++) {\n key = allowedAttrs[i];\n attr = elem.getAttribute(key);\n if (attr) {\n out.push(`[${key}=\"${attr}\"]`);\n }\n }\n return out.join('');\n}\n\n/**\n * A safe form of location.href\n */\nexport function getLocationHref(): string {\n try {\n return WINDOW.document.location.href;\n } catch (oO) {\n return '';\n }\n}\n\n/**\n * Gets a DOM element by using document.querySelector.\n *\n * This wrapper will first check for the existance of the function before\n * actually calling it so that we don't have to take care of this check,\n * every time we want to access the DOM.\n *\n * Reason: DOM/querySelector is not available in all environments.\n *\n * We have to cast to any because utils can be consumed by a variety of environments,\n * and we don't want to break TS users. If you know what element will be selected by\n * `document.querySelector`, specify it as part of the generic call. For example,\n * `const element = getDomElement<Element>('selector');`\n *\n * @param selector the selector string passed on to document.querySelector\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getDomElement<E = any>(selector: string): E | null {\n if (WINDOW.document && WINDOW.document.querySelector) {\n return WINDOW.document.querySelector(selector) as unknown as E;\n }\n return null;\n}\n", "import { GLOBAL_OBJ } from './worldwide';\n\n/** Prefix for logging strings */\nconst PREFIX = 'Sentry Logger ';\n\nexport const CONSOLE_LEVELS = ['debug', 'info', 'warn', 'error', 'log', 'assert', 'trace'] as const;\nexport type ConsoleLevel = (typeof CONSOLE_LEVELS)[number];\n\ntype LoggerMethod = (...args: unknown[]) => void;\ntype LoggerConsoleMethods = Record<ConsoleLevel, LoggerMethod>;\n\n/** This may be mutated by the console instrumentation. */\nexport const originalConsoleMethods: {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key in ConsoleLevel]?: (...args: any[]) => void;\n} = {};\n\n/** JSDoc */\ninterface Logger extends LoggerConsoleMethods {\n disable(): void;\n enable(): void;\n isEnabled(): boolean;\n}\n\n/**\n * Temporarily disable sentry console instrumentations.\n *\n * @param callback The function to run against the original `console` messages\n * @returns The results of the callback\n */\nexport function consoleSandbox<T>(callback: () => T): T {\n if (!('console' in GLOBAL_OBJ)) {\n return callback();\n }\n\n const console = GLOBAL_OBJ.console as Console;\n const wrappedFuncs: Partial<LoggerConsoleMethods> = {};\n\n const wrappedLevels = Object.keys(originalConsoleMethods) as ConsoleLevel[];\n\n // Restore all wrapped console methods\n wrappedLevels.forEach(level => {\n const originalConsoleMethod = originalConsoleMethods[level] as LoggerMethod;\n wrappedFuncs[level] = console[level] as LoggerMethod | undefined;\n console[level] = originalConsoleMethod;\n });\n\n try {\n return callback();\n } finally {\n // Revert restoration to wrapped state\n wrappedLevels.forEach(level => {\n console[level] = wrappedFuncs[level] as LoggerMethod;\n });\n }\n}\n\nfunction makeLogger(): Logger {\n let enabled = false;\n const logger: Partial<Logger> = {\n enable: () => {\n enabled = true;\n },\n disable: () => {\n enabled = false;\n },\n isEnabled: () => enabled,\n };\n\n if (__DEBUG_BUILD__) {\n CONSOLE_LEVELS.forEach(name => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n logger[name] = (...args: any[]) => {\n if (enabled) {\n consoleSandbox(() => {\n GLOBAL_OBJ.console[name](`${PREFIX}[${name}]:`, ...args);\n });\n }\n };\n });\n } else {\n CONSOLE_LEVELS.forEach(name => {\n logger[name] = () => undefined;\n });\n }\n\n return logger as Logger;\n}\n\nexport const logger = makeLogger();\n", "import type { DsnComponents, DsnLike, DsnProtocol } from '@sentry/types';\n\nimport { logger } from './logger';\n\n/** Regular expression used to parse a Dsn. */\nconst DSN_REGEX = /^(?:(\\w+):)\\/\\/(?:(\\w+)(?::(\\w+)?)?@)([\\w.-]+)(?::(\\d+))?\\/(.+)/;\n\nfunction isValidProtocol(protocol?: string): protocol is DsnProtocol {\n return protocol === 'http' || protocol === 'https';\n}\n\n/**\n * Renders the string representation of this Dsn.\n *\n * By default, this will render the public representation without the password\n * component. To get the deprecated private representation, set `withPassword`\n * to true.\n *\n * @param withPassword When set to true, the password will be included.\n */\nexport function dsnToString(dsn: DsnComponents, withPassword: boolean = false): string {\n const { host, path, pass, port, projectId, protocol, publicKey } = dsn;\n return (\n `${protocol}://${publicKey}${withPassword && pass ? `:${pass}` : ''}` +\n `@${host}${port ? `:${port}` : ''}/${path ? `${path}/` : path}${projectId}`\n );\n}\n\n/**\n * Parses a Dsn from a given string.\n *\n * @param str A Dsn as string\n * @returns Dsn as DsnComponents or undefined if @param str is not a valid DSN string\n */\nexport function dsnFromString(str: string): DsnComponents | undefined {\n const match = DSN_REGEX.exec(str);\n\n if (!match) {\n // This should be logged to the console\n // eslint-disable-next-line no-console\n console.error(`Invalid Sentry Dsn: ${str}`);\n return undefined;\n }\n\n const [protocol, publicKey, pass = '', host, port = '', lastPath] = match.slice(1);\n let path = '';\n let projectId = lastPath;\n\n const split = projectId.split('/');\n if (split.length > 1) {\n path = split.slice(0, -1).join('/');\n projectId = split.pop() as string;\n }\n\n if (projectId) {\n const projectMatch = projectId.match(/^\\d+/);\n if (projectMatch) {\n projectId = projectMatch[0];\n }\n }\n\n return dsnFromComponents({ host, pass, path, projectId, port, protocol: protocol as DsnProtocol, publicKey });\n}\n\nfunction dsnFromComponents(components: DsnComponents): DsnComponents {\n return {\n protocol: components.protocol,\n publicKey: components.publicKey || '',\n pass: components.pass || '',\n host: components.host,\n port: components.port || '',\n path: components.path || '',\n projectId: components.projectId,\n };\n}\n\nfunction validateDsn(dsn: DsnComponents): boolean {\n if (!__DEBUG_BUILD__) {\n return true;\n }\n\n const { port, projectId, protocol } = dsn;\n\n const requiredComponents: ReadonlyArray<keyof DsnComponents> = ['protocol', 'publicKey', 'host', 'projectId'];\n const hasMissingRequiredComponent = requiredComponents.find(component => {\n if (!dsn[component]) {\n logger.error(`Invalid Sentry Dsn: ${component} missing`);\n return true;\n }\n return false;\n });\n\n if (hasMissingRequiredComponent) {\n return false;\n }\n\n if (!projectId.match(/^\\d+$/)) {\n logger.error(`Invalid Sentry Dsn: Invalid projectId ${projectId}`);\n return false;\n }\n\n if (!isValidProtocol(protocol)) {\n logger.error(`Invalid Sentry Dsn: Invalid protocol ${protocol}`);\n return false;\n }\n\n if (port && isNaN(parseInt(port, 10))) {\n logger.error(`Invalid Sentry Dsn: Invalid port ${port}`);\n return false;\n }\n\n return true;\n}\n\n/**\n * Creates a valid Sentry Dsn object, identifying a Sentry instance and project.\n * @returns a valid DsnComponents object or `undefined` if @param from is an invalid DSN source\n */\nexport function makeDsn(from: DsnLike): DsnComponents | undefined {\n const components = typeof from === 'string' ? dsnFromString(from) : dsnFromComponents(from);\n if (!components || !validateDsn(components)) {\n return undefined;\n }\n return components;\n}\n", "import type { ConsoleLevel } from './logger';\n\n/** An error emitted by Sentry SDKs and related utilities. */\nexport class SentryError extends Error {\n /** Display name of this error instance. */\n public name: string;\n\n public logLevel: ConsoleLevel;\n\n public constructor(public message: string, logLevel: ConsoleLevel = 'warn') {\n super(message);\n\n this.name = new.target.prototype.constructor.name;\n // This sets the prototype to be `Error`, not `SentryError`. It's unclear why we do this, but commenting this line\n // out causes various (seemingly totally unrelated) playwright tests consistently time out. FYI, this makes\n // instances of `SentryError` fail `obj instanceof SentryError` checks.\n Object.setPrototypeOf(this, new.target.prototype);\n this.logLevel = logLevel;\n }\n}\n", "/* eslint-disable max-lines */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { WrappedFunction } from '@sentry/types';\n\nimport { htmlTreeAsString } from './browser';\nimport { isElement, isError, isEvent, isInstanceOf, isPlainObject, isPrimitive } from './is';\nimport { logger } from './logger';\nimport { truncate } from './string';\n\n/**\n * Replace a method in an object with a wrapped version of itself.\n *\n * @param source An object that contains a method to be wrapped.\n * @param name The name of the method to be wrapped.\n * @param replacementFactory A higher-order function that takes the original version of the given method and returns a\n * wrapped version. Note: The function returned by `replacementFactory` needs to be a non-arrow function, in order to\n * preserve the correct value of `this`, and the original method must be called using `origMethod.call(this, <other\n * args>)` or `origMethod.apply(this, [<other args>])` (rather than being called directly), again to preserve `this`.\n * @returns void\n */\nexport function fill(source: { [key: string]: any }, name: string, replacementFactory: (...args: any[]) => any): void {\n if (!(name in source)) {\n return;\n }\n\n const original = source[name] as () => any;\n const wrapped = replacementFactory(original) as WrappedFunction;\n\n // Make sure it's a function first, as we need to attach an empty prototype for `defineProperties` to work\n // otherwise it'll throw \"TypeError: Object.defineProperties called on non-object\"\n if (typeof wrapped === 'function') {\n markFunctionWrapped(wrapped, original);\n }\n\n source[name] = wrapped;\n}\n\n/**\n * Defines a non-enumerable property on the given object.\n *\n * @param obj The object on which to set the property\n * @param name The name of the property to be set\n * @param value The value to which to set the property\n */\nexport function addNonEnumerableProperty(obj: object, name: string, value: unknown): void {\n try {\n Object.defineProperty(obj, name, {\n // enumerable: false, // the default, so we can save on bundle size by not explicitly setting it\n value: value,\n writable: true,\n configurable: true,\n });\n } catch (o_O) {\n __DEBUG_BUILD__ && logger.log(`Failed to add non-enumerable property \"${name}\" to object`, obj);\n }\n}\n\n/**\n * Remembers the original function on the wrapped function and\n * patches up the prototype.\n *\n * @param wrapped the wrapper function\n * @param original the original function that gets wrapped\n */\nexport function markFunctionWrapped(wrapped: WrappedFunction, original: WrappedFunction): void {\n try {\n const proto = original.prototype || {};\n wrapped.prototype = original.prototype = proto;\n addNonEnumerableProperty(wrapped, '__sentry_original__', original);\n } catch (o_O) {} // eslint-disable-line no-empty\n}\n\n/**\n * This extracts the original function if available. See\n * `markFunctionWrapped` for more information.\n *\n * @param func the function to unwrap\n * @returns the unwrapped version of the function if available.\n */\nexport function getOriginalFunction(func: WrappedFunction): WrappedFunction | undefined {\n return func.__sentry_original__;\n}\n\n/**\n * Encodes given object into url-friendly format\n *\n * @param object An object that contains serializable values\n * @returns string Encoded\n */\nexport function urlEncode(object: { [key: string]: any }): string {\n return Object.keys(object)\n .map(key => `${encodeURIComponent(key)}=${encodeURIComponent(object[key])}`)\n .join('&');\n}\n\n/**\n * Transforms any `Error` or `Event` into a plain object with all of their enumerable properties, and some of their\n * non-enumerable properties attached.\n *\n * @param value Initial source that we have to transform in order for it to be usable by the serializer\n * @returns An Event or Error turned into an object - or the value argurment itself, when value is neither an Event nor\n * an Error.\n */\nexport function convertToPlainObject<V>(value: V):\n | {\n [ownProps: string]: unknown;\n type: string;\n target: string;\n currentTarget: string;\n detail?: unknown;\n }\n | {\n [ownProps: string]: unknown;\n message: string;\n name: string;\n stack?: string;\n }\n | V {\n if (isError(value)) {\n return {\n message: value.message,\n name: value.name,\n stack: value.stack,\n ...getOwnProperties(value),\n };\n } else if (isEvent(value)) {\n const newObj: {\n [ownProps: string]: unknown;\n type: string;\n target: string;\n currentTarget: string;\n detail?: unknown;\n } = {\n type: value.type,\n target: serializeEventTarget(value.target),\n currentTarget: serializeEventTarget(value.currentTarget),\n ...getOwnProperties(value),\n };\n\n if (typeof CustomEvent !== 'undefined' && isInstanceOf(value, CustomEvent)) {\n newObj.detail = value.detail;\n }\n\n return newObj;\n } else {\n return value;\n }\n}\n\n/** Creates a string representation of the target of an `Event` object */\nfunction serializeEventTarget(target: unknown): string {\n try {\n return isElement(target) ? htmlTreeAsString(target) : Object.prototype.toString.call(target);\n } catch (_oO) {\n return '<unknown>';\n }\n}\n\n/** Filters out all but an object's own properties */\nfunction getOwnProperties(obj: unknown): { [key: string]: unknown } {\n if (typeof obj === 'object' && obj !== null) {\n const extractedProps: { [key: string]: unknown } = {};\n for (const property in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, property)) {\n extractedProps[property] = (obj as Record<string, unknown>)[property];\n }\n }\n return extractedProps;\n } else {\n return {};\n }\n}\n\n/**\n * Given any captured exception, extract its keys and create a sorted\n * and truncated list that will be used inside the event message.\n * eg. `Non-error exception captured with keys: foo, bar, baz`\n */\nexport function extractExceptionKeysForMessage(exception: Record<string, unknown>, maxLength: number = 40): string {\n const keys = Object.keys(convertToPlainObject(exception));\n keys.sort();\n\n if (!keys.length) {\n return '[object has no keys]';\n }\n\n if (keys[0].length >= maxLength) {\n return truncate(keys[0], maxLength);\n }\n\n for (let includedKeys = keys.length; includedKeys > 0; includedKeys--) {\n const serialized = keys.slice(0, includedKeys).join(', ');\n if (serialized.length > maxLength) {\n continue;\n }\n if (includedKeys === keys.length) {\n return serialized;\n }\n return truncate(serialized, maxLength);\n }\n\n return '';\n}\n\n/**\n * Given any object, return a new object having removed all fields whose value was `undefined`.\n * Works recursively on objects and arrays.\n *\n * Attention: This function keeps circular references in the returned object.\n */\nexport function dropUndefinedKeys<T>(inputValue: T): T {\n // This map keeps track of what already visited nodes map to.\n // Our Set - based memoBuilder doesn't work here because we want to the output object to have the same circular\n // references as the input object.\n const memoizationMap = new Map<unknown, unknown>();\n\n // This function just proxies `_dropUndefinedKeys` to keep the `memoBuilder` out of this function's API\n return _dropUndefinedKeys(inputValue, memoizationMap);\n}\n\nfunction _dropUndefinedKeys<T>(inputValue: T, memoizationMap: Map<unknown, unknown>): T {\n if (isPlainObject(inputValue)) {\n // If this node has already been visited due to a circular reference, return the object it was mapped to in the new object\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal as T;\n }\n\n const returnValue: { [key: string]: any } = {};\n // Store the mapping of this value in case we visit it again, in case of circular data\n memoizationMap.set(inputValue, returnValue);\n\n for (const key of Object.keys(inputValue)) {\n if (typeof inputValue[key] !== 'undefined') {\n returnValue[key] = _dropUndefinedKeys(inputValue[key], memoizationMap);\n }\n }\n\n return returnValue as T;\n }\n\n if (Array.isArray(inputValue)) {\n // If this node has already been visited due to a circular reference, return the array it was mapped to in the new object\n const memoVal = memoizationMap.get(inputValue);\n if (memoVal !== undefined) {\n return memoVal as T;\n }\n\n const returnValue: unknown[] = [];\n // Store the mapping of this value in case we visit it again, in case of circular data\n memoizationMap.set(inputValue, returnValue);\n\n inputValue.forEach((item: unknown) => {\n returnValue.push(_dropUndefinedKeys(item, memoizationMap));\n });\n\n return returnValue as unknown as T;\n }\n\n return inputValue;\n}\n\n/**\n * Ensure that something is an object.\n *\n * Turns `undefined` and `null` into `String`s and all other primitives into instances of their respective wrapper\n * classes (String, Boolean, Number, etc.). Acts as the identity function on non-primitives.\n *\n * @param wat The subject of the objectification\n * @returns A version of `wat` which can safely be used with `Object` class methods\n */\nexport function objectify(wat: unknown): typeof Object {\n let objectified;\n switch (true) {\n case wat === undefined || wat === null:\n objectified = new String(wat);\n break;\n\n // Though symbols and bigints do have wrapper classes (`Symbol` and `BigInt`, respectively), for whatever reason\n // those classes don't have constructors which can be used with the `new` keyword. We therefore need to cast each as\n // an object in order to wrap it.\n case typeof wat === 'symbol' || typeof wat === 'bigint':\n objectified = Object(wat);\n break;\n\n // this will catch the remaining primitives: `String`, `Number`, and `Boolean`\n case isPrimitive(wat):\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n objectified = new (wat as any).constructor(wat);\n break;\n\n // by process of elimination, at this point we know that `wat` must already be an object\n default:\n objectified = wat;\n break;\n }\n return objectified;\n}\n", "/* eslint-disable @typescript-eslint/no-explicit-any */\nimport type { Event, Exception, Mechanism, StackFrame } from '@sentry/types';\n\nimport { addNonEnumerableProperty } from './object';\nimport { snipLine } from './string';\nimport { GLOBAL_OBJ } from './worldwide';\n\ninterface CryptoInternal {\n getRandomValues(array: Uint8Array): Uint8Array;\n randomUUID?(): string;\n}\n\n/** An interface for common properties on global */\ninterface CryptoGlobal {\n msCrypto?: CryptoInternal;\n crypto?: CryptoInternal;\n}\n\n/**\n * UUID4 generator\n *\n * @returns string Generated UUID4.\n */\nexport function uuid4(): string {\n const gbl = GLOBAL_OBJ as typeof GLOBAL_OBJ & CryptoGlobal;\n const crypto = gbl.crypto || gbl.msCrypto;\n\n let getRandomByte = (): number => Math.random() * 16;\n try {\n if (crypto && crypto.randomUUID) {\n return crypto.randomUUID().replace(/-/g, '');\n }\n if (crypto && crypto.getRandomValues) {\n getRandomByte = () => crypto.getRandomValues(new Uint8Array(1))[0];\n }\n } catch (_) {\n // some runtimes can crash invoking crypto\n // https://github.com/getsentry/sentry-javascript/issues/8935\n }\n\n // http://stackoverflow.com/questions/105034/how-to-create-a-guid-uuid-in-javascript/2117523#2117523\n // Concatenating the following numbers as strings results in '10000000100040008000100000000000'\n return (([1e7] as unknown as string) + 1e3 + 4e3 + 8e3 + 1e11).replace(/[018]/g, c =>\n // eslint-disable-next-line no-bitwise\n ((c as unknown as number) ^ ((getRandomByte() & 15) >> ((c as unknown as number) / 4))).toString(16),\n );\n}\n\nfunction getFirstException(event: Event): Exception | undefined {\n return event.exception && event.exception.values ? event.exception.values[0] : undefined;\n}\n\n/**\n * Extracts either message or type+value from an event that can be used for user-facing logs\n * @returns event's description\n */\nexport function getEventDescription(event: Event): string {\n const { message, event_id: eventId } = event;\n if (message) {\n return message;\n }\n\n const firstException = getFirstException(event);\n if (firstException) {\n if (firstException.type && firstException.value) {\n return `${firstException.type}: ${firstException.value}`;\n }\n return firstException.type || firstException.value || eventId || '<unknown>';\n }\n return eventId || '<unknown>';\n}\n\n/**\n * Adds exception values, type and value to an synthetic Exception.\n * @param event The event to modify.\n * @param value Value of the exception.\n * @param type Type of the exception.\n * @hidden\n */\nexport function addExceptionTypeValue(event: Event, value?: string, type?: string): void {\n const exception = (event.exception = event.exception || {});\n const values = (exception.values = exception.values || []);\n const firstException = (values[0] = values[0] || {});\n if (!firstException.value) {\n firstException.value = value || '';\n }\n if (!firstException.type) {\n firstException.type = type || 'Error';\n }\n}\n\n/**\n * Adds exception mechanism data to a given event. Uses defaults if the second parameter is not passed.\n *\n * @param event The event to modify.\n * @param newMechanism Mechanism data to add to the event.\n * @hidden\n */\nexport function addExceptionMechanism(event: Event, newMechanism?: Partial<Mechanism>): void {\n const firstException = getFirstException(event);\n if (!firstException) {\n return;\n }\n\n const defaultMechanism = { type: 'generic', handled: true };\n const currentMechanism = firstException.mechanism;\n firstException.mechanism = { ...defaultMechanism, ...currentMechanism, ...newMechanism };\n\n if (newMechanism && 'data' in newMechanism) {\n const mergedData = { ...(currentMechanism && currentMechanism.data), ...newMechanism.data };\n firstException.mechanism.data = mergedData;\n }\n}\n\n// https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string\nconst SEMVER_REGEXP =\n /^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$/;\n\n/**\n * Represents Semantic Versioning object\n */\ninterface SemVer {\n major?: number;\n minor?: number;\n patch?: number;\n prerelease?: string;\n buildmetadata?: string;\n}\n\n/**\n * Parses input into a SemVer interface\n * @param input string representation of a semver version\n */\nexport function parseSemver(input: string): SemVer {\n const match = input.match(SEMVER_REGEXP) || [];\n const major = parseInt(match[1], 10);\n const minor = parseInt(match[2], 10);\n const patch = parseInt(match[3], 10);\n return {\n buildmetadata: match[5],\n major: isNaN(major) ? undefined : major,\n minor: isNaN(minor) ? undefined : minor,\n patch: isNaN(patch) ? undefined : patch,\n prerelease: match[4],\n };\n}\n\n/**\n * This function adds context (pre/post/line) lines to the provided frame\n *\n * @param lines string[] containing all lines\n * @param frame StackFrame that will be mutated\n * @param linesOfContext number of context lines we want to add pre/post\n */\nexport function addContextToFrame(lines: string[], frame: StackFrame, linesOfContext: number = 5): void {\n // When there is no line number in the frame, attaching context is nonsensical and will even break grouping\n if (frame.lineno === undefined) {\n return;\n }\n\n const maxLines = lines.length;\n const sourceLine = Math.max(Math.min(maxLines - 1, frame.lineno - 1), 0);\n\n frame.pre_context = lines\n .slice(Math.max(0, sourceLine - linesOfContext), sourceLine)\n .map((line: string) => snipLine(line, 0));\n\n frame.context_line = snipLine(lines[Math.min(maxLines - 1, sourceLine)], frame.colno || 0);\n\n frame.post_context = lines\n .slice(Math.min(sourceLine + 1, maxLines), sourceLine + 1 + linesOfContext)\n .map((line: string) => snipLine(line, 0));\n}\n\n/**\n * Checks whether or not we've already captured the given exception (note: not an identical exception - the very object\n * in question), and marks it captured if not.\n *\n * This is useful because it's possible for an error to get captured by more than one mechanism. After we intercept and\n * record an error, we rethrow it (assuming we've intercepted it before it's reached the top-level global handlers), so\n * that we don't interfere with whatever effects the error might have had were the SDK not there. At that point, because\n * the error has been rethrown, it's possible for it to bubble up to some other code we've instrumented. If it's not\n * caught after that, it will bubble all the way up to the global handlers (which of course we also instrument). This\n * function helps us ensure that even if we encounter the same error more than once, we only record it the first time we\n * see it.\n *\n * Note: It will ignore primitives (always return `false` and not mark them as seen), as properties can't be set on\n * them. {@link: Object.objectify} can be used on exceptions to convert any that are primitives into their equivalent\n * object wrapper forms so that this check will always work. However, because we need to flag the exact object which\n * will get rethrown, and because that rethrowing happens outside of the event processing pipeline, the objectification\n * must be done before the exception captured.\n *\n * @param A thrown exception to check or flag as having been seen\n * @returns `true` if the exception has already been captured, `false` if not (with the side effect of marking it seen)\n */\nexport function checkOrSetAlreadyCaught(exception: unknown): boolean {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (exception && (exception as any).__sentry_captured__) {\n return true;\n }\n\n try {\n // set it this way rather than by assignment so that it's not ennumerable and therefore isn't recorded by the\n // `ExtraErrorData` integration\n addNonEnumerableProperty(exception as { [key: string]: unknown }, '__sentry_captured__', true);\n } catch (err) {\n // `exception` is a primitive, so we can't mark it seen\n }\n\n return false;\n}\n\n/**\n * Checks whether the given input is already an array, and if it isn't, wraps it in one.\n *\n * @param maybeArray Input to turn into an array, if necessary\n * @returns The input, if already an array, or an array with the input as the only element, if not\n */\nexport function arrayify<T = unknown>(maybeArray: T | T[]): T[] {\n return Array.isArray(maybeArray) ? maybeArray : [maybeArray];\n}\n", "import type { StackFrame, StackLineParser, StackParser } from '@sentry/types';\n\nimport type { GetModuleFn } from './node-stack-trace';\nimport { filenameIsInApp, node } from './node-stack-trace';\n\nexport { filenameIsInApp };\n\nconst STACKTRACE_FRAME_LIMIT = 50;\n// Used to sanitize webpack (error: *) wrapped stack errors\nconst WEBPACK_ERROR_REGEXP = /\\(error: (.*)\\)/;\nconst STRIP_FRAME_REGEXP = /captureMessage|captureException/;\n\n/**\n * Creates a stack parser with the supplied line parsers\n *\n * StackFrames are returned in the correct order for Sentry Exception\n * frames and with Sentry SDK internal frames removed from the top and bottom\n *\n */\nexport function createStackParser(...parsers: StackLineParser[]): StackParser {\n const sortedParsers = parsers.sort((a, b) => a[0] - b[0]).map(p => p[1]);\n\n return (stack: string, skipFirst: number = 0): StackFrame[] => {\n const frames: StackFrame[] = [];\n const lines = stack.split('\\n');\n\n for (let i = skipFirst; i < lines.length; i++) {\n const line = lines[i];\n // Ignore lines over 1kb as they are unlikely to be stack frames.\n // Many of the regular expressions use backtracking which results in run time that increases exponentially with\n // input size. Huge strings can result in hangs/Denial of Service:\n // https://github.com/getsentry/sentry-javascript/issues/2286\n if (line.length > 1024) {\n continue;\n }\n\n // https://github.com/getsentry/sentry-javascript/issues/5459\n // Remove webpack (error: *) wrappers\n const cleanedLine = WEBPACK_ERROR_REGEXP.test(line) ? line.replace(WEBPACK_ERROR_REGEXP, '$1') : line;\n\n // https://github.com/getsentry/sentry-javascript/issues/7813\n // Skip Error: lines\n if (cleanedLine.match(/\\S*Error: /)) {\n continue;\n }\n\n for (const parser of sortedParsers) {\n const frame = parser(cleanedLine);\n\n if (frame) {\n frames.push(frame);\n break;\n }\n }\n\n if (frames.length >= STACKTRACE_FRAME_LIMIT) {\n break;\n }\n }\n\n return stripSentryFramesAndReverse(frames);\n };\n}\n\n/**\n * Gets a stack parser implementation from Options.stackParser\n * @see Options\n *\n * If options contains an array of line parsers, it is converted into a parser\n */\nexport function stackParserFromStackParserOptions(stackParser: StackParser | StackLineParser[]): StackParser {\n if (Array.isArray(stackParser)) {\n return createStackParser(...stackParser);\n }\n return stackParser;\n}\n\n/**\n * Removes Sentry frames from the top and bottom of the stack if present and enforces a limit of max number of frames.\n * Assumes stack input is ordered from top to bottom and returns the reverse representation so call site of the\n * function that caused the crash is the last frame in the array.\n * @hidden\n */\nexport function stripSentryFramesAndReverse(stack: ReadonlyArray<StackFrame>): StackFrame[] {\n if (!stack.length) {\n return [];\n }\n\n const localStack = Array.from(stack);\n\n // If stack starts with one of our API calls, remove it (starts, meaning it's the top of the stack - aka last call)\n if (/sentryWrapped/.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n }\n\n // Reversing in the middle of the procedure allows us to just pop the values off the stack\n localStack.reverse();\n\n // If stack ends with one of our internal API calls, remove it (ends, meaning it's the bottom of the stack - aka top-most call)\n if (STRIP_FRAME_REGEXP.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n\n // When using synthetic events, we will have a 2 levels deep stack, as `new Error('Sentry syntheticException')`\n // is produced within the hub itself, making it:\n //\n // Sentry.captureException()\n // getCurrentHub().captureException()\n //\n // instead of just the top `Sentry` call itself.\n // This forces us to possibly strip an additional frame in the exact same was as above.\n if (STRIP_FRAME_REGEXP.test(localStack[localStack.length - 1].function || '')) {\n localStack.pop();\n }\n }\n\n return localStack.slice(0, STACKTRACE_FRAME_LIMIT).map(frame => ({\n ...frame,\n filename: frame.filename || localStack[localStack.length - 1].filename,\n function: frame.function || '?',\n }));\n}\n\nconst defaultFunctionName = '<anonymous>';\n\n/**\n * Safely extract function name from itself\n */\nexport function getFunctionName(fn: unknown): string {\n try {\n if (!fn || typeof fn !== 'function') {\n return defaultFunctionName;\n }\n return fn.name || defaultFunctionName;\n } catch (e) {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n return defaultFunctionName;\n }\n}\n\n/**\n * Node.js stack line parser\n *\n * This is in @sentry/utils so it can be used from the Electron SDK in the browser for when `nodeIntegration == true`.\n * This allows it to be used without referencing or importing any node specific code which causes bundlers to complain\n */\nexport function nodeStackLineParser(getModule?: GetModuleFn): StackLineParser {\n return [90, node(getModule)];\n}\n", "import { logger } from './logger';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nexport { supportsHistory } from './vendor/supportsHistory';\n\n/**\n * Tells whether current environment supports ErrorEvent objects\n * {@link supportsErrorEvent}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsErrorEvent(): boolean {\n try {\n new ErrorEvent('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMError objects\n * {@link supportsDOMError}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsDOMError(): boolean {\n try {\n // Chrome: VM89:1 Uncaught TypeError: Failed to construct 'DOMError':\n // 1 argument required, but only 0 present.\n // @ts-expect-error It really needs 1 argument, not 0.\n new DOMError('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports DOMException objects\n * {@link supportsDOMException}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsDOMException(): boolean {\n try {\n new DOMException('');\n return true;\n } catch (e) {\n return false;\n }\n}\n\n/**\n * Tells whether current environment supports Fetch API\n * {@link supportsFetch}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsFetch(): boolean {\n if (!('fetch' in WINDOW)) {\n return false;\n }\n\n try {\n new Headers();\n new Request('http://www.example.com');\n new Response();\n return true;\n } catch (e) {\n return false;\n }\n}\n/**\n * isNativeFetch checks if the given function is a native implementation of fetch()\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function isNativeFetch(func: Function): boolean {\n return func && /^function fetch\\(\\)\\s+\\{\\s+\\[native code\\]\\s+\\}$/.test(func.toString());\n}\n\n/**\n * Tells whether current environment supports Fetch API natively\n * {@link supportsNativeFetch}.\n *\n * @returns true if `window.fetch` is natively implemented, false otherwise\n */\nexport function supportsNativeFetch(): boolean {\n if (!supportsFetch()) {\n return false;\n }\n\n // Fast path to avoid DOM I/O\n // eslint-disable-next-line @typescript-eslint/unbound-method\n if (isNativeFetch(WINDOW.fetch)) {\n return true;\n }\n\n // window.fetch is implemented, but is polyfilled or already wrapped (e.g: by a chrome extension)\n // so create a \"pure\" iframe to see if that has native fetch\n let result = false;\n const doc = WINDOW.document;\n // eslint-disable-next-line deprecation/deprecation\n if (doc && typeof (doc.createElement as unknown) === 'function') {\n try {\n const sandbox = doc.createElement('iframe');\n sandbox.hidden = true;\n doc.head.appendChild(sandbox);\n if (sandbox.contentWindow && sandbox.contentWindow.fetch) {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n result = isNativeFetch(sandbox.contentWindow.fetch);\n }\n doc.head.removeChild(sandbox);\n } catch (err) {\n __DEBUG_BUILD__ &&\n logger.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', err);\n }\n }\n\n return result;\n}\n\n/**\n * Tells whether current environment supports ReportingObserver API\n * {@link supportsReportingObserver}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsReportingObserver(): boolean {\n return 'ReportingObserver' in WINDOW;\n}\n\n/**\n * Tells whether current environment supports Referrer Policy API\n * {@link supportsReferrerPolicy}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsReferrerPolicy(): boolean {\n // Despite all stars in the sky saying that Edge supports old draft syntax, aka 'never', 'always', 'origin' and 'default'\n // (see https://caniuse.com/#feat=referrer-policy),\n // it doesn't. And it throws an exception instead of ignoring this parameter...\n // REF: https://github.com/getsentry/raven-js/issues/1233\n\n if (!supportsFetch()) {\n return false;\n }\n\n try {\n new Request('_', {\n referrerPolicy: 'origin' as ReferrerPolicy,\n });\n return true;\n } catch (e) {\n return false;\n }\n}\n", "// Based on https://github.com/angular/angular.js/pull/13945/files\n// The MIT License\n\n// Copyright (c) 2010-2016 Google, Inc. http://angularjs.org\n\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport { getGlobalObject } from '../worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\n/**\n * Tells whether current environment supports History API\n * {@link supportsHistory}.\n *\n * @returns Answer to the given question.\n */\nexport function supportsHistory(): boolean {\n // NOTE: in Chrome App environment, touching history.pushState, *even inside\n // a try/catch block*, will cause Chrome to output an error to console.error\n // borrowed from: https://github.com/angular/angular.js/pull/13945/files\n /* eslint-disable @typescript-eslint/no-unsafe-member-access */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const chrome = (WINDOW as any).chrome;\n const isChromePackagedApp = chrome && chrome.app && chrome.app.runtime;\n /* eslint-enable @typescript-eslint/no-unsafe-member-access */\n const hasHistoryApi = 'history' in WINDOW && !!WINDOW.history.pushState && !!WINDOW.history.replaceState;\n\n return !isChromePackagedApp && hasHistoryApi;\n}\n", "/* eslint-disable max-lines */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/ban-types */\nimport type {\n HandlerDataFetch,\n HandlerDataXhr,\n SentryWrappedXMLHttpRequest,\n SentryXhrData,\n WrappedFunction,\n} from '@sentry/types';\n\nimport { isString } from './is';\nimport type { ConsoleLevel } from './logger';\nimport { CONSOLE_LEVELS, logger, originalConsoleMethods } from './logger';\nimport { uuid4 } from './misc';\nimport { addNonEnumerableProperty, fill } from './object';\nimport { getFunctionName } from './stacktrace';\nimport { supportsHistory, supportsNativeFetch } from './supports';\nimport { getGlobalObject, GLOBAL_OBJ } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\nexport const SENTRY_XHR_DATA_KEY = '__sentry_xhr_v2__';\n\nexport type InstrumentHandlerType =\n | 'console'\n | 'dom'\n | 'fetch'\n | 'history'\n | 'sentry'\n | 'xhr'\n | 'error'\n | 'unhandledrejection';\nexport type InstrumentHandlerCallback = (data: any) => void;\n\n/**\n * Instrument native APIs to call handlers that can be used to create breadcrumbs, APM spans etc.\n * - Console API\n * - Fetch API\n * - XHR API\n * - History API\n * - DOM API (click/typing)\n * - Error API\n * - UnhandledRejection API\n */\n\nconst handlers: { [key in InstrumentHandlerType]?: InstrumentHandlerCallback[] } = {};\nconst instrumented: { [key in InstrumentHandlerType]?: boolean } = {};\n\n/** Instruments given API */\nfunction instrument(type: InstrumentHandlerType): void {\n if (instrumented[type]) {\n return;\n }\n\n instrumented[type] = true;\n\n switch (type) {\n case 'console':\n instrumentConsole();\n break;\n case 'dom':\n instrumentDOM();\n break;\n case 'xhr':\n instrumentXHR();\n break;\n case 'fetch':\n instrumentFetch();\n break;\n case 'history':\n instrumentHistory();\n break;\n case 'error':\n instrumentError();\n break;\n case 'unhandledrejection':\n instrumentUnhandledRejection();\n break;\n default:\n __DEBUG_BUILD__ && logger.warn('unknown instrumentation type:', type);\n return;\n }\n}\n\n/**\n * Add handler that will be called when given type of instrumentation triggers.\n * Use at your own risk, this might break without changelog notice, only used internally.\n * @hidden\n */\nexport function addInstrumentationHandler(type: InstrumentHandlerType, callback: InstrumentHandlerCallback): void {\n handlers[type] = handlers[type] || [];\n (handlers[type] as InstrumentHandlerCallback[]).push(callback);\n instrument(type);\n}\n\n/**\n * Reset all instrumentation handlers.\n * This can be used by tests to ensure we have a clean slate of instrumentation handlers.\n */\nexport function resetInstrumentationHandlers(): void {\n Object.keys(handlers).forEach(key => {\n handlers[key as InstrumentHandlerType] = undefined;\n });\n}\n\n/** JSDoc */\nfunction triggerHandlers(type: InstrumentHandlerType, data: any): void {\n if (!type || !handlers[type]) {\n return;\n }\n\n for (const handler of handlers[type] || []) {\n try {\n handler(data);\n } catch (e) {\n __DEBUG_BUILD__ &&\n logger.error(\n `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${getFunctionName(handler)}\\nError:`,\n e,\n );\n }\n }\n}\n\n/** JSDoc */\nfunction instrumentConsole(): void {\n if (!('console' in GLOBAL_OBJ)) {\n return;\n }\n\n CONSOLE_LEVELS.forEach(function (level: ConsoleLevel): void {\n if (!(level in GLOBAL_OBJ.console)) {\n return;\n }\n\n fill(GLOBAL_OBJ.console, level, function (originalConsoleMethod: () => any): Function {\n originalConsoleMethods[level] = originalConsoleMethod;\n\n return function (...args: any[]): void {\n triggerHandlers('console', { args, level });\n\n const log = originalConsoleMethods[level];\n log && log.apply(GLOBAL_OBJ.console, args);\n };\n });\n });\n}\n\n/** JSDoc */\nfunction instrumentFetch(): void {\n if (!supportsNativeFetch()) {\n return;\n }\n\n fill(GLOBAL_OBJ, 'fetch', function (originalFetch: () => void): () => void {\n return function (...args: any[]): void {\n const { method, url } = parseFetchArgs(args);\n\n const handlerData: HandlerDataFetch = {\n args,\n fetchData: {\n method,\n url,\n },\n startTimestamp: Date.now(),\n };\n\n triggerHandlers('fetch', {\n ...handlerData,\n });\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return originalFetch.apply(GLOBAL_OBJ, args).then(\n (response: Response) => {\n triggerHandlers('fetch', {\n ...handlerData,\n endTimestamp: Date.now(),\n response,\n });\n return response;\n },\n (error: Error) => {\n triggerHandlers('fetch', {\n ...handlerData,\n endTimestamp: Date.now(),\n error,\n });\n // NOTE: If you are a Sentry user, and you are seeing this stack frame,\n // it means the sentry.javascript SDK caught an error invoking your application code.\n // This is expected behavior and NOT indicative of a bug with sentry.javascript.\n throw error;\n },\n );\n };\n });\n}\n\nfunction hasProp<T extends string>(obj: unknown, prop: T): obj is Record<string, string> {\n return !!obj && typeof obj === 'object' && !!(obj as Record<string, string>)[prop];\n}\n\ntype FetchResource = string | { toString(): string } | { url: string };\n\nfunction getUrlFromResource(resource: FetchResource): string {\n if (typeof resource === 'string') {\n return resource;\n }\n\n if (!resource) {\n return '';\n }\n\n if (hasProp(resource, 'url')) {\n return resource.url;\n }\n\n if (resource.toString) {\n return resource.toString();\n }\n\n return '';\n}\n\n/**\n * Parses the fetch arguments to find the used Http method and the url of the request\n */\nexport function parseFetchArgs(fetchArgs: unknown[]): { method: string; url: string } {\n if (fetchArgs.length === 0) {\n return { method: 'GET', url: '' };\n }\n\n if (fetchArgs.length === 2) {\n const [url, options] = fetchArgs as [FetchResource, object];\n\n return {\n url: getUrlFromResource(url),\n method: hasProp(options, 'method') ? String(options.method).toUpperCase() : 'GET',\n };\n }\n\n const arg = fetchArgs[0];\n return {\n url: getUrlFromResource(arg as FetchResource),\n method: hasProp(arg, 'method') ? String(arg.method).toUpperCase() : 'GET',\n };\n}\n\n/** JSDoc */\nexport function instrumentXHR(): void {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (!(WINDOW as any).XMLHttpRequest) {\n return;\n }\n\n const xhrproto = XMLHttpRequest.prototype;\n\n fill(xhrproto, 'open', function (originalOpen: () => void): () => void {\n return function (this: XMLHttpRequest & SentryWrappedXMLHttpRequest, ...args: any[]): void {\n const startTimestamp = Date.now();\n\n const url = args[1];\n const xhrInfo: SentryXhrData = (this[SENTRY_XHR_DATA_KEY] = {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n method: isString(args[0]) ? args[0].toUpperCase() : args[0],\n url: args[1],\n request_headers: {},\n });\n\n // if Sentry key appears in URL, don't capture it as a request\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (isString(url) && xhrInfo.method === 'POST' && url.match(/sentry_key/)) {\n this.__sentry_own_request__ = true;\n }\n\n const onreadystatechangeHandler: () => void = () => {\n // For whatever reason, this is not the same instance here as from the outer method\n const xhrInfo = this[SENTRY_XHR_DATA_KEY];\n\n if (!xhrInfo) {\n return;\n }\n\n if (this.readyState === 4) {\n try {\n // touching statusCode in some platforms throws\n // an exception\n xhrInfo.status_code = this.status;\n } catch (e) {\n /* do nothing */\n }\n\n triggerHandlers('xhr', {\n args: args as [string, string],\n endTimestamp: Date.now(),\n startTimestamp,\n xhr: this,\n } as HandlerDataXhr);\n }\n };\n\n if ('onreadystatechange' in this && typeof this.onreadystatechange === 'function') {\n fill(this, 'onreadystatechange', function (original: WrappedFunction): Function {\n return function (this: SentryWrappedXMLHttpRequest, ...readyStateArgs: any[]): void {\n onreadystatechangeHandler();\n return original.apply(this, readyStateArgs);\n };\n });\n } else {\n this.addEventListener('readystatechange', onreadystatechangeHandler);\n }\n\n // Intercepting `setRequestHeader` to access the request headers of XHR instance.\n // This will only work for user/library defined headers, not for the default/browser-assigned headers.\n // Request cookies are also unavailable for XHR, as `Cookie` header can't be defined by `setRequestHeader`.\n fill(this, 'setRequestHeader', function (original: WrappedFunction): Function {\n return function (this: SentryWrappedXMLHttpRequest, ...setRequestHeaderArgs: unknown[]): void {\n const [header, value] = setRequestHeaderArgs as [string, string];\n\n const xhrInfo = this[SENTRY_XHR_DATA_KEY];\n\n if (xhrInfo) {\n xhrInfo.request_headers[header.toLowerCase()] = value;\n }\n\n return original.apply(this, setRequestHeaderArgs);\n };\n });\n\n return originalOpen.apply(this, args);\n };\n });\n\n fill(xhrproto, 'send', function (originalSend: () => void): () => void {\n return function (this: XMLHttpRequest & SentryWrappedXMLHttpRequest, ...args: any[]): void {\n const sentryXhrData = this[SENTRY_XHR_DATA_KEY];\n if (sentryXhrData && args[0] !== undefined) {\n sentryXhrData.body = args[0];\n }\n\n triggerHandlers('xhr', {\n args,\n startTimestamp: Date.now(),\n xhr: this,\n });\n\n return originalSend.apply(this, args);\n };\n });\n}\n\nlet lastHref: string;\n\n/** JSDoc */\nfunction instrumentHistory(): void {\n if (!supportsHistory()) {\n return;\n }\n\n const oldOnPopState = WINDOW.onpopstate;\n WINDOW.onpopstate = function (this: WindowEventHandlers, ...args: any[]): any {\n const to = WINDOW.location.href;\n // keep track of the current URL state, as we always receive only the updated state\n const from = lastHref;\n lastHref = to;\n triggerHandlers('history', {\n from,\n to,\n });\n if (oldOnPopState) {\n // Apparently this can throw in Firefox when incorrectly implemented plugin is installed.\n // https://github.com/getsentry/sentry-javascript/issues/3344\n // https://github.com/bugsnag/bugsnag-js/issues/469\n try {\n return oldOnPopState.apply(this, args);\n } catch (_oO) {\n // no-empty\n }\n }\n };\n\n /** @hidden */\n function historyReplacementFunction(originalHistoryFunction: () => void): () => void {\n return function (this: History, ...args: any[]): void {\n const url = args.length > 2 ? args[2] : undefined;\n if (url) {\n // coerce to string (this is what pushState does)\n const from = lastHref;\n const to = String(url);\n // keep track of the current URL state, as we always receive only the updated state\n lastHref = to;\n triggerHandlers('history', {\n from,\n to,\n });\n }\n return originalHistoryFunction.apply(this, args);\n };\n }\n\n fill(WINDOW.history, 'pushState', historyReplacementFunction);\n fill(WINDOW.history, 'replaceState', historyReplacementFunction);\n}\n\nconst DEBOUNCE_DURATION = 1000;\nlet debounceTimerID: number | undefined;\nlet lastCapturedEventType: string | undefined;\nlet lastCapturedEventTargetId: string | undefined;\n\ntype SentryWrappedTarget = HTMLElement & { _sentryId?: string };\n\n/**\n * Check whether the event is similar to the last captured one. For example, two click events on the same button.\n */\nfunction isSimilarToLastCapturedEvent(event: Event): boolean {\n // If both events have different type, then user definitely performed two separate actions. e.g. click + keypress.\n if (event.type !== lastCapturedEventType) {\n return false;\n }\n\n try {\n // If both events have the same type, it's still possible that actions were performed on different targets.\n // e.g. 2 clicks on different buttons.\n if (!event.target || (event.target as SentryWrappedTarget)._sentryId !== lastCapturedEventTargetId) {\n return false;\n }\n } catch (e) {\n // just accessing `target` property can throw an exception in some rare circumstances\n // see: https://github.com/getsentry/sentry-javascript/issues/838\n }\n\n // If both events have the same type _and_ same `target` (an element which triggered an event, _not necessarily_\n // to which an event listener was attached), we treat them as the same action, as we want to capture\n // only one breadcrumb. e.g. multiple clicks on the same button, or typing inside a user input box.\n return true;\n}\n\n/**\n * Decide whether an event should be captured.\n * @param event event to be captured\n */\nfunction shouldSkipDOMEvent(eventType: string, target: SentryWrappedTarget | null): boolean {\n // We are only interested in filtering `keypress` events for now.\n if (eventType !== 'keypress') {\n return false;\n }\n\n if (!target || !target.tagName) {\n return true;\n }\n\n // Only consider keypress events on actual input elements. This will disregard keypresses targeting body\n // e.g.tabbing through elements, hotkeys, etc.\n if (target.tagName === 'INPUT' || target.tagName === 'TEXTAREA' || target.isContentEditable) {\n return false;\n }\n\n return true;\n}\n\nfunction getEventTarget(event: Event): SentryWrappedTarget | null {\n try {\n return event.target as SentryWrappedTarget | null;\n } catch (e) {\n // just accessing `target` property can throw an exception in some rare circumstances\n // see: https://github.com/getsentry/sentry-javascript/issues/838\n return null;\n }\n}\n\n/**\n * Wraps addEventListener to capture UI breadcrumbs\n * @param handler function that will be triggered\n * @param globalListener indicates whether event was captured by the global event listener\n * @returns wrapped breadcrumb events handler\n * @hidden\n */\nfunction makeDOMEventHandler(handler: Function, globalListener: boolean = false): (event: Event) => void {\n return (event: Event & { _sentryCaptured?: true }): void => {\n // It's possible this handler might trigger multiple times for the same\n // event (e.g. event propagation through node ancestors).\n // Ignore if we've already captured that event.\n if (!event || event['_sentryCaptured']) {\n return;\n }\n\n const target = getEventTarget(event);\n\n // We always want to skip _some_ events.\n if (shouldSkipDOMEvent(event.type, target)) {\n return;\n }\n\n // Mark event as \"seen\"\n addNonEnumerableProperty(event, '_sentryCaptured', true);\n\n if (target && !target._sentryId) {\n // Add UUID to event target so we can identify if\n addNonEnumerableProperty(target, '_sentryId', uuid4());\n }\n\n const name = event.type === 'keypress' ? 'input' : event.type;\n\n // If there is no last captured event, it means that we can safely capture the new event and store it for future comparisons.\n // If there is a last captured event, see if the new event is different enough to treat it as a unique one.\n // If that's the case, emit the previous event and store locally the newly-captured DOM event.\n if (!isSimilarToLastCapturedEvent(event)) {\n handler({\n event: event,\n name,\n global: globalListener,\n });\n lastCapturedEventType = event.type;\n lastCapturedEventTargetId = target ? target._sentryId : undefined;\n }\n\n // Start a new debounce timer that will prevent us from capturing multiple events that should be grouped together.\n clearTimeout(debounceTimerID);\n debounceTimerID = WINDOW.setTimeout(() => {\n lastCapturedEventTargetId = undefined;\n lastCapturedEventType = undefined;\n }, DEBOUNCE_DURATION);\n };\n}\n\ntype AddEventListener = (\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | AddEventListenerOptions,\n) => void;\ntype RemoveEventListener = (\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | EventListenerOptions,\n) => void;\n\ntype InstrumentedElement = Element & {\n __sentry_instrumentation_handlers__?: {\n [key in 'click' | 'keypress']?: {\n handler?: Function;\n /** The number of custom listeners attached to this element */\n refCount: number;\n };\n };\n};\n\n/** JSDoc */\nexport function instrumentDOM(): void {\n if (!WINDOW.document) {\n return;\n }\n\n // Make it so that any click or keypress that is unhandled / bubbled up all the way to the document triggers our dom\n // handlers. (Normally we have only one, which captures a breadcrumb for each click or keypress.) Do this before\n // we instrument `addEventListener` so that we don't end up attaching this handler twice.\n const triggerDOMHandler = triggerHandlers.bind(null, 'dom');\n const globalDOMEventHandler = makeDOMEventHandler(triggerDOMHandler, true);\n WINDOW.document.addEventListener('click', globalDOMEventHandler, false);\n WINDOW.document.addEventListener('keypress', globalDOMEventHandler, false);\n\n // After hooking into click and keypress events bubbled up to `document`, we also hook into user-handled\n // clicks & keypresses, by adding an event listener of our own to any element to which they add a listener. That\n // way, whenever one of their handlers is triggered, ours will be, too. (This is needed because their handler\n // could potentially prevent the event from bubbling up to our global listeners. This way, our handler are still\n // guaranteed to fire at least once.)\n ['EventTarget', 'Node'].forEach((target: string) => {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const proto = (WINDOW as any)[target] && (WINDOW as any)[target].prototype;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, no-prototype-builtins\n if (!proto || !proto.hasOwnProperty || !proto.hasOwnProperty('addEventListener')) {\n return;\n }\n\n fill(proto, 'addEventListener', function (originalAddEventListener: AddEventListener): AddEventListener {\n return function (\n this: Element,\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ): AddEventListener {\n if (type === 'click' || type == 'keypress') {\n try {\n const el = this as InstrumentedElement;\n const handlers = (el.__sentry_instrumentation_handlers__ = el.__sentry_instrumentation_handlers__ || {});\n const handlerForType = (handlers[type] = handlers[type] || { refCount: 0 });\n\n if (!handlerForType.handler) {\n const handler = makeDOMEventHandler(triggerDOMHandler);\n handlerForType.handler = handler;\n originalAddEventListener.call(this, type, handler, options);\n }\n\n handlerForType.refCount++;\n } catch (e) {\n // Accessing dom properties is always fragile.\n // Also allows us to skip `addEventListenrs` calls with no proper `this` context.\n }\n }\n\n return originalAddEventListener.call(this, type, listener, options);\n };\n });\n\n fill(\n proto,\n 'removeEventListener',\n function (originalRemoveEventListener: RemoveEventListener): RemoveEventListener {\n return function (\n this: Element,\n type: string,\n listener: EventListenerOrEventListenerObject,\n options?: boolean | EventListenerOptions,\n ): () => void {\n if (type === 'click' || type == 'keypress') {\n try {\n const el = this as InstrumentedElement;\n const handlers = el.__sentry_instrumentation_handlers__ || {};\n const handlerForType = handlers[type];\n\n if (handlerForType) {\n handlerForType.refCount--;\n // If there are no longer any custom handlers of the current type on this element, we can remove ours, too.\n if (handlerForType.refCount <= 0) {\n originalRemoveEventListener.call(this, type, handlerForType.handler, options);\n handlerForType.handler = undefined;\n delete handlers[type]; // eslint-disable-line @typescript-eslint/no-dynamic-delete\n }\n\n // If there are no longer any custom handlers of any type on this element, cleanup everything.\n if (Object.keys(handlers).length === 0) {\n delete el.__sentry_instrumentation_handlers__;\n }\n }\n } catch (e) {\n // Accessing dom properties is always fragile.\n // Also allows us to skip `addEventListenrs` calls with no proper `this` context.\n }\n }\n\n return originalRemoveEventListener.call(this, type, listener, options);\n };\n },\n );\n });\n}\n\nlet _oldOnErrorHandler: (typeof WINDOW)['onerror'] | null = null;\n/** JSDoc */\nfunction instrumentError(): void {\n _oldOnErrorHandler = WINDOW.onerror;\n\n WINDOW.onerror = function (msg: unknown, url: unknown, line: unknown, column: unknown, error: unknown): boolean {\n triggerHandlers('error', {\n column,\n error,\n line,\n msg,\n url,\n });\n\n if (_oldOnErrorHandler && !_oldOnErrorHandler.__SENTRY_LOADER__) {\n // eslint-disable-next-line prefer-rest-params\n return _oldOnErrorHandler.apply(this, arguments);\n }\n\n return false;\n };\n\n WINDOW.onerror.__SENTRY_INSTRUMENTED__ = true;\n}\n\nlet _oldOnUnhandledRejectionHandler: (typeof WINDOW)['onunhandledrejection'] | null = null;\n/** JSDoc */\nfunction instrumentUnhandledRejection(): void {\n _oldOnUnhandledRejectionHandler = WINDOW.onunhandledrejection;\n\n WINDOW.onunhandledrejection = function (e: any): boolean {\n triggerHandlers('unhandledrejection', e);\n\n if (_oldOnUnhandledRejectionHandler && !_oldOnUnhandledRejectionHandler.__SENTRY_LOADER__) {\n // eslint-disable-next-line prefer-rest-params\n return _oldOnUnhandledRejectionHandler.apply(this, arguments);\n }\n\n return true;\n };\n\n WINDOW.onunhandledrejection.__SENTRY_INSTRUMENTED__ = true;\n}\n", "/*\n * This module exists for optimizations in the build process through rollup and terser. We define some global\n * constants, which can be overridden during build. By guarding certain pieces of code with functions that return these\n * constants, we can control whether or not they appear in the final bundle. (Any code guarded by a false condition will\n * never run, and will hence be dropped during treeshaking.) The two primary uses for this are stripping out calls to\n * `logger` and preventing node-related code from appearing in browser bundles.\n *\n * Attention:\n * This file should not be used to define constants/flags that are intended to be used for tree-shaking conducted by\n * users. These flags should live in their respective packages, as we identified user tooling (specifically webpack)\n * having issues tree-shaking these constants across package boundaries.\n * An example for this is the __SENTRY_DEBUG__ constant. It is declared in each package individually because we want\n * users to be able to shake away expressions that it guards.\n */\n\ndeclare const __SENTRY_BROWSER_BUNDLE__: boolean | undefined;\n\nexport type SdkSource = 'npm' | 'cdn' | 'loader';\n\n/**\n * Figures out if we're building a browser bundle.\n *\n * @returns true if this is a browser bundle build.\n */\nexport function isBrowserBundle(): boolean {\n return typeof __SENTRY_BROWSER_BUNDLE__ !== 'undefined' && !!__SENTRY_BROWSER_BUNDLE__;\n}\n\n/**\n * Get source of SDK.\n */\nexport function getSDKSource(): SdkSource {\n // @ts-expect-error __SENTRY_SDK_SOURCE__ is injected by rollup during build process\n return __SENTRY_SDK_SOURCE__;\n}\n", "/**\n * NOTE: In order to avoid circular dependencies, if you add a function to this module and it needs to print something,\n * you must either a) use `console.log` rather than the logger, or b) put your function elsewhere.\n */\n\nimport { isBrowserBundle } from './env';\n\n/**\n * Checks whether we're in the Node.js or Browser environment\n *\n * @returns Answer to given question\n */\nexport function isNodeEnv(): boolean {\n // explicitly check for browser bundles as those can be optimized statically\n // by terser/rollup.\n return (\n !isBrowserBundle() &&\n Object.prototype.toString.call(typeof process !== 'undefined' ? process : 0) === '[object process]'\n );\n}\n\n/**\n * Requires a module which is protected against bundler minification.\n *\n * @param request The module path to resolve\n */\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types, @typescript-eslint/no-explicit-any\nexport function dynamicRequire(mod: any, request: string): any {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return mod.require(request);\n}\n\n/**\n * Helper for dynamically loading module that should work with linked dependencies.\n * The problem is that we _should_ be using `require(require.resolve(moduleName, { paths: [cwd()] }))`\n * However it's _not possible_ to do that with Webpack, as it has to know all the dependencies during\n * build time. `require.resolve` is also not available in any other way, so we cannot create,\n * a fake helper like we do with `dynamicRequire`.\n *\n * We always prefer to use local package, thus the value is not returned early from each `try/catch` block.\n * That is to mimic the behavior of `require.resolve` exactly.\n *\n * @param moduleName module name to require\n * @returns possibly required module\n */\nexport function loadModule<T>(moduleName: string): T | undefined {\n let mod: T | undefined;\n\n try {\n mod = dynamicRequire(module, moduleName);\n } catch (e) {\n // no-empty\n }\n\n try {\n const { cwd } = dynamicRequire(module, 'process');\n mod = dynamicRequire(module, `${cwd()}/node_modules/${moduleName}`) as T;\n } catch (e) {\n // no-empty\n }\n\n return mod;\n}\n", "/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nexport type MemoFunc = [\n // memoize\n (obj: any) => boolean,\n // unmemoize\n (obj: any) => void,\n];\n\n/**\n * Helper to decycle json objects\n */\nexport function memoBuilder(): MemoFunc {\n const hasWeakSet = typeof WeakSet === 'function';\n const inner: any = hasWeakSet ? new WeakSet() : [];\n function memoize(obj: any): boolean {\n if (hasWeakSet) {\n if (inner.has(obj)) {\n return true;\n }\n inner.add(obj);\n return false;\n }\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < inner.length; i++) {\n const value = inner[i];\n if (value === obj) {\n return true;\n }\n }\n inner.push(obj);\n return false;\n }\n\n function unmemoize(obj: any): void {\n if (hasWeakSet) {\n inner.delete(obj);\n } else {\n for (let i = 0; i < inner.length; i++) {\n if (inner[i] === obj) {\n inner.splice(i, 1);\n break;\n }\n }\n }\n }\n return [memoize, unmemoize];\n}\n", "import type { Primitive } from '@sentry/types';\n\nimport { isNaN, isSyntheticEvent, isVueViewModel } from './is';\nimport type { MemoFunc } from './memo';\nimport { memoBuilder } from './memo';\nimport { convertToPlainObject } from './object';\nimport { getFunctionName } from './stacktrace';\n\ntype Prototype = { constructor: (...args: unknown[]) => unknown };\n// This is a hack to placate TS, relying on the fact that technically, arrays are objects with integer keys. Normally we\n// think of those keys as actual numbers, but `arr['0']` turns out to work just as well as `arr[0]`, and doing it this\n// way lets us use a single type in the places where behave as if we are only dealing with objects, even if some of them\n// might be arrays.\ntype ObjOrArray<T> = { [key: string]: T };\n\n/**\n * Recursively normalizes the given object.\n *\n * - Creates a copy to prevent original input mutation\n * - Skips non-enumerable properties\n * - When stringifying, calls `toJSON` if implemented\n * - Removes circular references\n * - Translates non-serializable values (`undefined`/`NaN`/functions) to serializable format\n * - Translates known global objects/classes to a string representations\n * - Takes care of `Error` object serialization\n * - Optionally limits depth of final output\n * - Optionally limits number of properties/elements included in any single object/array\n *\n * @param input The object to be normalized.\n * @param depth The max depth to which to normalize the object. (Anything deeper stringified whole.)\n * @param maxProperties The max number of elements or properties to be included in any single array or\n * object in the normallized output.\n * @returns A normalized version of the object, or `\"**non-serializable**\"` if any errors are thrown during normalization.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function normalize(input: unknown, depth: number = 100, maxProperties: number = +Infinity): any {\n try {\n // since we're at the outermost level, we don't provide a key\n return visit('', input, depth, maxProperties);\n } catch (err) {\n return { ERROR: `**non-serializable** (${err})` };\n }\n}\n\n/** JSDoc */\nexport function normalizeToSize<T>(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n object: { [key: string]: any },\n // Default Node.js REPL depth\n depth: number = 3,\n // 100kB, as 200kB is max payload size, so half sounds reasonable\n maxSize: number = 100 * 1024,\n): T {\n const normalized = normalize(object, depth);\n\n if (jsonSize(normalized) > maxSize) {\n return normalizeToSize(object, depth - 1, maxSize);\n }\n\n return normalized as T;\n}\n\n/**\n * Visits a node to perform normalization on it\n *\n * @param key The key corresponding to the given node\n * @param value The node to be visited\n * @param depth Optional number indicating the maximum recursion depth\n * @param maxProperties Optional maximum number of properties/elements included in any single object/array\n * @param memo Optional Memo class handling decycling\n */\nfunction visit(\n key: string,\n value: unknown,\n depth: number = +Infinity,\n maxProperties: number = +Infinity,\n memo: MemoFunc = memoBuilder(),\n): Primitive | ObjOrArray<unknown> {\n const [memoize, unmemoize] = memo;\n\n // Get the simple cases out of the way first\n if (\n value == null || // this matches null and undefined -> eqeq not eqeqeq\n (['number', 'boolean', 'string'].includes(typeof value) && !isNaN(value))\n ) {\n return value as Primitive;\n }\n\n const stringified = stringifyValue(key, value);\n\n // Anything we could potentially dig into more (objects or arrays) will have come back as `\"[object XXXX]\"`.\n // Everything else will have already been serialized, so if we don't see that pattern, we're done.\n if (!stringified.startsWith('[object ')) {\n return stringified;\n }\n\n // From here on, we can assert that `value` is either an object or an array.\n\n // Do not normalize objects that we know have already been normalized. As a general rule, the\n // \"__sentry_skip_normalization__\" property should only be used sparingly and only should only be set on objects that\n // have already been normalized.\n if ((value as ObjOrArray<unknown>)['__sentry_skip_normalization__']) {\n return value as ObjOrArray<unknown>;\n }\n\n // We can set `__sentry_override_normalization_depth__` on an object to ensure that from there\n // We keep a certain amount of depth.\n // This should be used sparingly, e.g. we use it for the redux integration to ensure we get a certain amount of state.\n const remainingDepth =\n typeof (value as ObjOrArray<unknown>)['__sentry_override_normalization_depth__'] === 'number'\n ? ((value as ObjOrArray<unknown>)['__sentry_override_normalization_depth__'] as number)\n : depth;\n\n // We're also done if we've reached the max depth\n if (remainingDepth === 0) {\n // At this point we know `serialized` is a string of the form `\"[object XXXX]\"`. Clean it up so it's just `\"[XXXX]\"`.\n return stringified.replace('object ', '');\n }\n\n // If we've already visited this branch, bail out, as it's circular reference. If not, note that we're seeing it now.\n if (memoize(value)) {\n return '[Circular ~]';\n }\n\n // If the value has a `toJSON` method, we call it to extract more information\n const valueWithToJSON = value as unknown & { toJSON?: () => unknown };\n if (valueWithToJSON && typeof valueWithToJSON.toJSON === 'function') {\n try {\n const jsonValue = valueWithToJSON.toJSON();\n // We need to normalize the return value of `.toJSON()` in case it has circular references\n return visit('', jsonValue, remainingDepth - 1, maxProperties, memo);\n } catch (err) {\n // pass (The built-in `toJSON` failed, but we can still try to do it ourselves)\n }\n }\n\n // At this point we know we either have an object or an array, we haven't seen it before, and we're going to recurse\n // because we haven't yet reached the max depth. Create an accumulator to hold the results of visiting each\n // property/entry, and keep track of the number of items we add to it.\n const normalized = (Array.isArray(value) ? [] : {}) as ObjOrArray<unknown>;\n let numAdded = 0;\n\n // Before we begin, convert`Error` and`Event` instances into plain objects, since some of each of their relevant\n // properties are non-enumerable and otherwise would get missed.\n const visitable = convertToPlainObject(value as ObjOrArray<unknown>);\n\n for (const visitKey in visitable) {\n // Avoid iterating over fields in the prototype if they've somehow been exposed to enumeration.\n if (!Object.prototype.hasOwnProperty.call(visitable, visitKey)) {\n continue;\n }\n\n if (numAdded >= maxProperties) {\n normalized[visitKey] = '[MaxProperties ~]';\n break;\n }\n\n // Recursively visit all the child nodes\n const visitValue = visitable[visitKey];\n normalized[visitKey] = visit(visitKey, visitValue, remainingDepth - 1, maxProperties, memo);\n\n numAdded++;\n }\n\n // Once we've visited all the branches, remove the parent from memo storage\n unmemoize(value);\n\n // Return accumulated values\n return normalized;\n}\n\n/**\n * @deprecated This export will be removed in v8.\n */\nexport { visit as walk };\n\n/* eslint-disable complexity */\n/**\n * Stringify the given value. Handles various known special values and types.\n *\n * Not meant to be used on simple primitives which already have a string representation, as it will, for example, turn\n * the number 1231 into \"[Object Number]\", nor on `null`, as it will throw.\n *\n * @param value The value to stringify\n * @returns A stringified representation of the given value\n */\nfunction stringifyValue(\n key: unknown,\n // this type is a tiny bit of a cheat, since this function does handle NaN (which is technically a number), but for\n // our internal use, it'll do\n value: Exclude<unknown, string | number | boolean | null>,\n): string {\n try {\n if (key === 'domain' && value && typeof value === 'object' && (value as { _events: unknown })._events) {\n return '[Domain]';\n }\n\n if (key === 'domainEmitter') {\n return '[DomainEmitter]';\n }\n\n // It's safe to use `global`, `window`, and `document` here in this manner, as we are asserting using `typeof` first\n // which won't throw if they are not present.\n\n if (typeof global !== 'undefined' && value === global) {\n return '[Global]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof window !== 'undefined' && value === window) {\n return '[Window]';\n }\n\n // eslint-disable-next-line no-restricted-globals\n if (typeof document !== 'undefined' && value === document) {\n return '[Document]';\n }\n\n if (isVueViewModel(value)) {\n return '[VueViewModel]';\n }\n\n // React's SyntheticEvent thingy\n if (isSyntheticEvent(value)) {\n return '[SyntheticEvent]';\n }\n\n if (typeof value === 'number' && value !== value) {\n return '[NaN]';\n }\n\n if (typeof value === 'function') {\n return `[Function: ${getFunctionName(value)}]`;\n }\n\n if (typeof value === 'symbol') {\n return `[${String(value)}]`;\n }\n\n // stringified BigInts are indistinguishable from regular numbers, so we need to label them to avoid confusion\n if (typeof value === 'bigint') {\n return `[BigInt: ${String(value)}]`;\n }\n\n // Now that we've knocked out all the special cases and the primitives, all we have left are objects. Simply casting\n // them to strings means that instances of classes which haven't defined their `toStringTag` will just come out as\n // `\"[object Object]\"`. If we instead look at the constructor's name (which is the same as the name of the class),\n // we can make sure that only plain objects come out that way.\n const objName = getConstructorName(value);\n\n // Handle HTML Elements\n if (/^HTML(\\w*)Element$/.test(objName)) {\n return `[HTMLElement: ${objName}]`;\n }\n\n return `[object ${objName}]`;\n } catch (err) {\n return `**non-serializable** (${err})`;\n }\n}\n/* eslint-enable complexity */\n\nfunction getConstructorName(value: unknown): string {\n const prototype: Prototype | null = Object.getPrototypeOf(value);\n\n return prototype ? prototype.constructor.name : 'null prototype';\n}\n\n/** Calculates bytes size of input string */\nfunction utf8Length(value: string): number {\n // eslint-disable-next-line no-bitwise\n return ~-encodeURI(value).split(/%..|./).length;\n}\n\n/** Calculates bytes size of input object */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction jsonSize(value: any): number {\n return utf8Length(JSON.stringify(value));\n}\n", "/* eslint-disable @typescript-eslint/explicit-function-return-type */\n/* eslint-disable @typescript-eslint/typedef */\n/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { isThenable } from './is';\n\n/** SyncPromise internal states */\nconst enum States {\n /** Pending */\n PENDING = 0,\n /** Resolved / OK */\n RESOLVED = 1,\n /** Rejected / Error */\n REJECTED = 2,\n}\n\n// Overloads so we can call resolvedSyncPromise without arguments and generic argument\nexport function resolvedSyncPromise(): PromiseLike<void>;\nexport function resolvedSyncPromise<T>(value: T | PromiseLike<T>): PromiseLike<T>;\n\n/**\n * Creates a resolved sync promise.\n *\n * @param value the value to resolve the promise with\n * @returns the resolved sync promise\n */\nexport function resolvedSyncPromise<T>(value?: T | PromiseLike<T>): PromiseLike<T> {\n return new SyncPromise(resolve => {\n resolve(value);\n });\n}\n\n/**\n * Creates a rejected sync promise.\n *\n * @param value the value to reject the promise with\n * @returns the rejected sync promise\n */\nexport function rejectedSyncPromise<T = never>(reason?: any): PromiseLike<T> {\n return new SyncPromise((_, reject) => {\n reject(reason);\n });\n}\n\n/**\n * Thenable class that behaves like a Promise and follows it's interface\n * but is not async internally\n */\nclass SyncPromise<T> implements PromiseLike<T> {\n private _state: States;\n private _handlers: Array<[boolean, (value: T) => void, (reason: any) => any]>;\n private _value: any;\n\n public constructor(\n executor: (resolve: (value?: T | PromiseLike<T> | null) => void, reject: (reason?: any) => void) => void,\n ) {\n this._state = States.PENDING;\n this._handlers = [];\n\n try {\n executor(this._resolve, this._reject);\n } catch (e) {\n this._reject(e);\n }\n }\n\n /** JSDoc */\n public then<TResult1 = T, TResult2 = never>(\n onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | null,\n onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null,\n ): PromiseLike<TResult1 | TResult2> {\n return new SyncPromise((resolve, reject) => {\n this._handlers.push([\n false,\n result => {\n if (!onfulfilled) {\n // TODO: ¯\\_(ツ)_/¯\n // TODO: FIXME\n resolve(result as any);\n } else {\n try {\n resolve(onfulfilled(result));\n } catch (e) {\n reject(e);\n }\n }\n },\n reason => {\n if (!onrejected) {\n reject(reason);\n } else {\n try {\n resolve(onrejected(reason));\n } catch (e) {\n reject(e);\n }\n }\n },\n ]);\n this._executeHandlers();\n });\n }\n\n /** JSDoc */\n public catch<TResult = never>(\n onrejected?: ((reason: any) => TResult | PromiseLike<TResult>) | null,\n ): PromiseLike<T | TResult> {\n return this.then(val => val, onrejected);\n }\n\n /** JSDoc */\n public finally<TResult>(onfinally?: (() => void) | null): PromiseLike<TResult> {\n return new SyncPromise<TResult>((resolve, reject) => {\n let val: TResult | any;\n let isRejected: boolean;\n\n return this.then(\n value => {\n isRejected = false;\n val = value;\n if (onfinally) {\n onfinally();\n }\n },\n reason => {\n isRejected = true;\n val = reason;\n if (onfinally) {\n onfinally();\n }\n },\n ).then(() => {\n if (isRejected) {\n reject(val);\n return;\n }\n\n resolve(val as unknown as any);\n });\n });\n }\n\n /** JSDoc */\n private readonly _resolve = (value?: T | PromiseLike<T> | null) => {\n this._setResult(States.RESOLVED, value);\n };\n\n /** JSDoc */\n private readonly _reject = (reason?: any) => {\n this._setResult(States.REJECTED, reason);\n };\n\n /** JSDoc */\n private readonly _setResult = (state: States, value?: T | PromiseLike<T> | any) => {\n if (this._state !== States.PENDING) {\n return;\n }\n\n if (isThenable(value)) {\n void (value as PromiseLike<T>).then(this._resolve, this._reject);\n return;\n }\n\n this._state = state;\n this._value = value;\n\n this._executeHandlers();\n };\n\n /** JSDoc */\n private readonly _executeHandlers = () => {\n if (this._state === States.PENDING) {\n return;\n }\n\n const cachedHandlers = this._handlers.slice();\n this._handlers = [];\n\n cachedHandlers.forEach(handler => {\n if (handler[0]) {\n return;\n }\n\n if (this._state === States.RESOLVED) {\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n handler[1](this._value as unknown as any);\n }\n\n if (this._state === States.REJECTED) {\n handler[2](this._value);\n }\n\n handler[0] = true;\n });\n };\n}\n\nexport { SyncPromise };\n", "import { SentryError } from './error';\nimport { rejectedSyncPromise, resolvedSyncPromise, SyncPromise } from './syncpromise';\n\nexport interface PromiseBuffer<T> {\n // exposes the internal array so tests can assert on the state of it.\n // XXX: this really should not be public api.\n $: Array<PromiseLike<T>>;\n add(taskProducer: () => PromiseLike<T>): PromiseLike<T>;\n drain(timeout?: number): PromiseLike<boolean>;\n}\n\n/**\n * Creates an new PromiseBuffer object with the specified limit\n * @param limit max number of promises that can be stored in the buffer\n */\nexport function makePromiseBuffer<T>(limit?: number): PromiseBuffer<T> {\n const buffer: Array<PromiseLike<T>> = [];\n\n function isReady(): boolean {\n return limit === undefined || buffer.length < limit;\n }\n\n /**\n * Remove a promise from the queue.\n *\n * @param task Can be any PromiseLike<T>\n * @returns Removed promise.\n */\n function remove(task: PromiseLike<T>): PromiseLike<T> {\n return buffer.splice(buffer.indexOf(task), 1)[0];\n }\n\n /**\n * Add a promise (representing an in-flight action) to the queue, and set it to remove itself on fulfillment.\n *\n * @param taskProducer A function producing any PromiseLike<T>; In previous versions this used to be `task:\n * PromiseLike<T>`, but under that model, Promises were instantly created on the call-site and their executor\n * functions therefore ran immediately. Thus, even if the buffer was full, the action still happened. By\n * requiring the promise to be wrapped in a function, we can defer promise creation until after the buffer\n * limit check.\n * @returns The original promise.\n */\n function add(taskProducer: () => PromiseLike<T>): PromiseLike<T> {\n if (!isReady()) {\n return rejectedSyncPromise(new SentryError('Not adding Promise because buffer limit was reached.'));\n }\n\n // start the task and add its promise to the queue\n const task = taskProducer();\n if (buffer.indexOf(task) === -1) {\n buffer.push(task);\n }\n void task\n .then(() => remove(task))\n // Use `then(null, rejectionHandler)` rather than `catch(rejectionHandler)` so that we can use `PromiseLike`\n // rather than `Promise`. `PromiseLike` doesn't have a `.catch` method, making its polyfill smaller. (ES5 didn't\n // have promises, so TS has to polyfill when down-compiling.)\n .then(null, () =>\n remove(task).then(null, () => {\n // We have to add another catch here because `remove()` starts a new promise chain.\n }),\n );\n return task;\n }\n\n /**\n * Wait for all promises in the queue to resolve or for timeout to expire, whichever comes first.\n *\n * @param timeout The time, in ms, after which to resolve to `false` if the queue is still non-empty. Passing `0` (or\n * not passing anything) will make the promise wait as long as it takes for the queue to drain before resolving to\n * `true`.\n * @returns A promise which will resolve to `true` if the queue is already empty or drains before the timeout, and\n * `false` otherwise\n */\n function drain(timeout?: number): PromiseLike<boolean> {\n return new SyncPromise<boolean>((resolve, reject) => {\n let counter = buffer.length;\n\n if (!counter) {\n return resolve(true);\n }\n\n // wait for `timeout` ms and then resolve to `false` (if not cancelled first)\n const capturedSetTimeout = setTimeout(() => {\n if (timeout && timeout > 0) {\n resolve(false);\n }\n }, timeout);\n\n // if all promises resolve in time, cancel the timer and resolve to `true`\n buffer.forEach(item => {\n void resolvedSyncPromise(item).then(() => {\n if (!--counter) {\n clearTimeout(capturedSetTimeout);\n resolve(true);\n }\n }, reject);\n });\n });\n }\n\n return {\n $: buffer,\n add,\n drain,\n };\n}\n", "type PartialURL = {\n host?: string;\n path?: string;\n protocol?: string;\n relative?: string;\n search?: string;\n hash?: string;\n};\n\n/**\n * Parses string form of URL into an object\n * // borrowed from https://tools.ietf.org/html/rfc3986#appendix-B\n * // intentionally using regex and not <a/> href parsing trick because React Native and other\n * // environments where DOM might not be available\n * @returns parsed URL object\n */\nexport function parseUrl(url: string): PartialURL {\n if (!url) {\n return {};\n }\n\n const match = url.match(/^(([^:/?#]+):)?(\\/\\/([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?$/);\n\n if (!match) {\n return {};\n }\n\n // coerce to undefined values to empty string so we don't get 'undefined'\n const query = match[6] || '';\n const fragment = match[8] || '';\n return {\n host: match[4],\n path: match[5],\n protocol: match[2],\n search: query,\n hash: fragment,\n relative: match[5] + query + fragment, // everything minus origin\n };\n}\n\n/**\n * Strip the query string and fragment off of a given URL or path (if present)\n *\n * @param urlPath Full URL or path, including possible query string and/or fragment\n * @returns URL or path without query string or fragment\n */\nexport function stripUrlQueryAndFragment(urlPath: string): string {\n // eslint-disable-next-line no-useless-escape\n return urlPath.split(/[\\?#]/, 1)[0];\n}\n\n/**\n * Returns number of URL segments of a passed string URL.\n */\nexport function getNumberOfUrlSegments(url: string): number {\n // split at '/' or at '\\/' to split regex urls correctly\n return url.split(/\\\\?\\//).filter(s => s.length > 0 && s !== ',').length;\n}\n\n/**\n * Takes a URL object and returns a sanitized string which is safe to use as span description\n * see: https://develop.sentry.dev/sdk/data-handling/#structuring-data\n */\nexport function getSanitizedUrlString(url: PartialURL): string {\n const { protocol, host, path } = url;\n\n const filteredHost =\n (host &&\n host\n // Always filter out authority\n .replace(/^.*@/, '[filtered]:[filtered]@')\n // Don't show standard :80 (http) and :443 (https) ports to reduce the noise\n .replace(':80', '')\n .replace(':443', '')) ||\n '';\n\n return `${protocol ? `${protocol}://` : ''}${filteredHost}${path}`;\n}\n", "/* eslint-disable deprecation/deprecation */\nimport type { Severity, SeverityLevel } from '@sentry/types';\n\n// Note: Ideally the `SeverityLevel` type would be derived from `validSeverityLevels`, but that would mean either\n//\n// a) moving `validSeverityLevels` to `@sentry/types`,\n// b) moving the`SeverityLevel` type here, or\n// c) importing `validSeverityLevels` from here into `@sentry/types`.\n//\n// Option A would make `@sentry/types` a runtime dependency of `@sentry/utils` (not good), and options B and C would\n// create a circular dependency between `@sentry/types` and `@sentry/utils` (also not good). So a TODO accompanying the\n// type, reminding anyone who changes it to change this list also, will have to do.\n\nexport const validSeverityLevels = ['fatal', 'error', 'warning', 'log', 'info', 'debug'];\n\n/**\n * Converts a string-based level into a member of the deprecated {@link Severity} enum.\n *\n * @deprecated `severityFromString` is deprecated. Please use `severityLevelFromString` instead.\n *\n * @param level String representation of Severity\n * @returns Severity\n */\nexport function severityFromString(level: Severity | SeverityLevel | string): Severity {\n return severityLevelFromString(level) as Severity;\n}\n\n/**\n * Converts a string-based level into a `SeverityLevel`, normalizing it along the way.\n *\n * @param level String representation of desired `SeverityLevel`.\n * @returns The `SeverityLevel` corresponding to the given string, or 'log' if the string isn't a valid level.\n */\nexport function severityLevelFromString(level: SeverityLevel | string): SeverityLevel {\n return (level === 'warn' ? 'warning' : validSeverityLevels.includes(level) ? level : 'log') as SeverityLevel;\n}\n", "import { dynamicRequire, isNodeEnv } from './node';\nimport { getGlobalObject } from './worldwide';\n\n// eslint-disable-next-line deprecation/deprecation\nconst WINDOW = getGlobalObject<Window>();\n\n/**\n * An object that can return the current timestamp in seconds since the UNIX epoch.\n */\ninterface TimestampSource {\n nowSeconds(): number;\n}\n\n/**\n * A TimestampSource implementation for environments that do not support the Performance Web API natively.\n *\n * Note that this TimestampSource does not use a monotonic clock. A call to `nowSeconds` may return a timestamp earlier\n * than a previously returned value. We do not try to emulate a monotonic behavior in order to facilitate debugging. It\n * is more obvious to explain \"why does my span have negative duration\" than \"why my spans have zero duration\".\n */\nconst dateTimestampSource: TimestampSource = {\n nowSeconds: () => Date.now() / 1000,\n};\n\n/**\n * A partial definition of the [Performance Web API]{@link https://developer.mozilla.org/en-US/docs/Web/API/Performance}\n * for accessing a high-resolution monotonic clock.\n */\ninterface Performance {\n /**\n * The millisecond timestamp at which measurement began, measured in Unix time.\n */\n timeOrigin: number;\n /**\n * Returns the current millisecond timestamp, where 0 represents the start of measurement.\n */\n now(): number;\n}\n\n/**\n * Returns a wrapper around the native Performance API browser implementation, or undefined for browsers that do not\n * support the API.\n *\n * Wrapping the native API works around differences in behavior from different browsers.\n */\nfunction getBrowserPerformance(): Performance | undefined {\n const { performance } = WINDOW;\n if (!performance || !performance.now) {\n return undefined;\n }\n\n // Replace performance.timeOrigin with our own timeOrigin based on Date.now().\n //\n // This is a partial workaround for browsers reporting performance.timeOrigin such that performance.timeOrigin +\n // performance.now() gives a date arbitrarily in the past.\n //\n // Additionally, computing timeOrigin in this way fills the gap for browsers where performance.timeOrigin is\n // undefined.\n //\n // The assumption that performance.timeOrigin + performance.now() ~= Date.now() is flawed, but we depend on it to\n // interact with data coming out of performance entries.\n //\n // Note that despite recommendations against it in the spec, browsers implement the Performance API with a clock that\n // might stop when the computer is asleep (and perhaps under other circumstances). Such behavior causes\n // performance.timeOrigin + performance.now() to have an arbitrary skew over Date.now(). In laptop computers, we have\n // observed skews that can be as long as days, weeks or months.\n //\n // See https://github.com/getsentry/sentry-javascript/issues/2590.\n //\n // BUG: despite our best intentions, this workaround has its limitations. It mostly addresses timings of pageload\n // transactions, but ignores the skew built up over time that can aversely affect timestamps of navigation\n // transactions of long-lived web pages.\n const timeOrigin = Date.now() - performance.now();\n\n return {\n now: () => performance.now(),\n timeOrigin,\n };\n}\n\n/**\n * Returns the native Performance API implementation from Node.js. Returns undefined in old Node.js versions that don't\n * implement the API.\n */\nfunction getNodePerformance(): Performance | undefined {\n try {\n const perfHooks = dynamicRequire(module, 'perf_hooks') as { performance: Performance };\n return perfHooks.performance;\n } catch (_) {\n return undefined;\n }\n}\n\n/**\n * The Performance API implementation for the current platform, if available.\n */\nconst platformPerformance: Performance | undefined = isNodeEnv() ? getNodePerformance() : getBrowserPerformance();\n\nconst timestampSource: TimestampSource =\n platformPerformance === undefined\n ? dateTimestampSource\n : {\n nowSeconds: () => (platformPerformance.timeOrigin + platformPerformance.now()) / 1000,\n };\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using the Date API.\n */\nexport const dateTimestampInSeconds: () => number = dateTimestampSource.nowSeconds.bind(dateTimestampSource);\n\n/**\n * Returns a timestamp in seconds since the UNIX epoch using either the Performance or Date APIs, depending on the\n * availability of the Performance API.\n *\n * See `usingPerformanceAPI` to test whether the Performance API is used.\n *\n * BUG: Note that because of how browsers implement the Performance API, the clock might stop when the computer is\n * asleep. This creates a skew between `dateTimestampInSeconds` and `timestampInSeconds`. The\n * skew can grow to arbitrary amounts like days, weeks or months.\n * See https://github.com/getsentry/sentry-javascript/issues/2590.\n */\nexport const timestampInSeconds: () => number = timestampSource.nowSeconds.bind(timestampSource);\n\n/**\n * Re-exported with an old name for backwards-compatibility.\n * TODO (v8): Remove this\n *\n * @deprecated Use `timestampInSeconds` instead.\n */\nexport const timestampWithMs = timestampInSeconds;\n\n/**\n * A boolean that is true when timestampInSeconds uses the Performance API to produce monotonic timestamps.\n */\nexport const usingPerformanceAPI = platformPerformance !== undefined;\n\n/**\n * Internal helper to store what is the source of browserPerformanceTimeOrigin below. For debugging only.\n */\nexport let _browserPerformanceTimeOriginMode: string;\n\n/**\n * The number of milliseconds since the UNIX epoch. This value is only usable in a browser, and only when the\n * performance API is available.\n */\nexport const browserPerformanceTimeOrigin = ((): number | undefined => {\n // Unfortunately browsers may report an inaccurate time origin data, through either performance.timeOrigin or\n // performance.timing.navigationStart, which results in poor results in performance data. We only treat time origin\n // data as reliable if they are within a reasonable threshold of the current time.\n\n const { performance } = WINDOW;\n if (!performance || !performance.now) {\n _browserPerformanceTimeOriginMode = 'none';\n return undefined;\n }\n\n const threshold = 3600 * 1000;\n const performanceNow = performance.now();\n const dateNow = Date.now();\n\n // if timeOrigin isn't available set delta to threshold so it isn't used\n const timeOriginDelta = performance.timeOrigin\n ? Math.abs(performance.timeOrigin + performanceNow - dateNow)\n : threshold;\n const timeOriginIsReliable = timeOriginDelta < threshold;\n\n // While performance.timing.navigationStart is deprecated in favor of performance.timeOrigin, performance.timeOrigin\n // is not as widely supported. Namely, performance.timeOrigin is undefined in Safari as of writing.\n // Also as of writing, performance.timing is not available in Web Workers in mainstream browsers, so it is not always\n // a valid fallback. In the absence of an initial time provided by the browser, fallback to the current time from the\n // Date API.\n // eslint-disable-next-line deprecation/deprecation\n const navigationStart = performance.timing && performance.timing.navigationStart;\n const hasNavigationStart = typeof navigationStart === 'number';\n // if navigationStart isn't available set delta to threshold so it isn't used\n const navigationStartDelta = hasNavigationStart ? Math.abs(navigationStart + performanceNow - dateNow) : threshold;\n const navigationStartIsReliable = navigationStartDelta < threshold;\n\n if (timeOriginIsReliable || navigationStartIsReliable) {\n // Use the more reliable time origin\n if (timeOriginDelta <= navigationStartDelta) {\n _browserPerformanceTimeOriginMode = 'timeOrigin';\n return performance.timeOrigin;\n } else {\n _browserPerformanceTimeOriginMode = 'navigationStart';\n return navigationStart;\n }\n }\n\n // Either both timeOrigin and navigationStart are skewed or neither is available, fallback to Date.\n _browserPerformanceTimeOriginMode = 'dateNow';\n return dateNow;\n})();\n", "import type { DynamicSamplingContext } from '@sentry/types';\n\nimport { isString } from './is';\nimport { logger } from './logger';\n\nexport const BAGGAGE_HEADER_NAME = 'baggage';\n\nexport const SENTRY_BAGGAGE_KEY_PREFIX = 'sentry-';\n\nexport const SENTRY_BAGGAGE_KEY_PREFIX_REGEX = /^sentry-/;\n\n/**\n * Max length of a serialized baggage string\n *\n * https://www.w3.org/TR/baggage/#limits\n */\nexport const MAX_BAGGAGE_STRING_LENGTH = 8192;\n\n/**\n * Takes a baggage header and turns it into Dynamic Sampling Context, by extracting all the \"sentry-\" prefixed values\n * from it.\n *\n * @param baggageHeader A very bread definition of a baggage header as it might appear in various frameworks.\n * @returns The Dynamic Sampling Context that was found on `baggageHeader`, if there was any, `undefined` otherwise.\n */\nexport function baggageHeaderToDynamicSamplingContext(\n // Very liberal definition of what any incoming header might look like\n baggageHeader: string | string[] | number | null | undefined | boolean,\n): Partial<DynamicSamplingContext> | undefined {\n if (!isString(baggageHeader) && !Array.isArray(baggageHeader)) {\n return undefined;\n }\n\n // Intermediary object to store baggage key value pairs of incoming baggage headers on.\n // It is later used to read Sentry-DSC-values from.\n let baggageObject: Readonly<Record<string, string>> = {};\n\n if (Array.isArray(baggageHeader)) {\n // Combine all baggage headers into one object containing the baggage values so we can later read the Sentry-DSC-values from it\n baggageObject = baggageHeader.reduce<Record<string, string>>((acc, curr) => {\n const currBaggageObject = baggageHeaderToObject(curr);\n return {\n ...acc,\n ...currBaggageObject,\n };\n }, {});\n } else {\n // Return undefined if baggage header is an empty string (technically an empty baggage header is not spec conform but\n // this is how we choose to handle it)\n if (!baggageHeader) {\n return undefined;\n }\n\n baggageObject = baggageHeaderToObject(baggageHeader);\n }\n\n // Read all \"sentry-\" prefixed values out of the baggage object and put it onto a dynamic sampling context object.\n const dynamicSamplingContext = Object.entries(baggageObject).reduce<Record<string, string>>((acc, [key, value]) => {\n if (key.match(SENTRY_BAGGAGE_KEY_PREFIX_REGEX)) {\n const nonPrefixedKey = key.slice(SENTRY_BAGGAGE_KEY_PREFIX.length);\n acc[nonPrefixedKey] = value;\n }\n return acc;\n }, {});\n\n // Only return a dynamic sampling context object if there are keys in it.\n // A keyless object means there were no sentry values on the header, which means that there is no DSC.\n if (Object.keys(dynamicSamplingContext).length > 0) {\n return dynamicSamplingContext as Partial<DynamicSamplingContext>;\n } else {\n return undefined;\n }\n}\n\n/**\n * Turns a Dynamic Sampling Object into a baggage header by prefixing all the keys on the object with \"sentry-\".\n *\n * @param dynamicSamplingContext The Dynamic Sampling Context to turn into a header. For convenience and compatibility\n * with the `getDynamicSamplingContext` method on the Transaction class ,this argument can also be `undefined`. If it is\n * `undefined` the function will return `undefined`.\n * @returns a baggage header, created from `dynamicSamplingContext`, or `undefined` either if `dynamicSamplingContext`\n * was `undefined`, or if `dynamicSamplingContext` didn't contain any values.\n */\nexport function dynamicSamplingContextToSentryBaggageHeader(\n // this also takes undefined for convenience and bundle size in other places\n dynamicSamplingContext?: Partial<DynamicSamplingContext>,\n): string | undefined {\n if (!dynamicSamplingContext) {\n return undefined;\n }\n\n // Prefix all DSC keys with \"sentry-\" and put them into a new object\n const sentryPrefixedDSC = Object.entries(dynamicSamplingContext).reduce<Record<string, string>>(\n (acc, [dscKey, dscValue]) => {\n if (dscValue) {\n acc[`${SENTRY_BAGGAGE_KEY_PREFIX}${dscKey}`] = dscValue;\n }\n return acc;\n },\n {},\n );\n\n return objectToBaggageHeader(sentryPrefixedDSC);\n}\n\n/**\n * Will parse a baggage header, which is a simple key-value map, into a flat object.\n *\n * @param baggageHeader The baggage header to parse.\n * @returns a flat object containing all the key-value pairs from `baggageHeader`.\n */\nfunction baggageHeaderToObject(baggageHeader: string): Record<string, string> {\n return baggageHeader\n .split(',')\n .map(baggageEntry => baggageEntry.split('=').map(keyOrValue => decodeURIComponent(keyOrValue.trim())))\n .reduce<Record<string, string>>((acc, [key, value]) => {\n acc[key] = value;\n return acc;\n }, {});\n}\n\n/**\n * Turns a flat object (key-value pairs) into a baggage header, which is also just key-value pairs.\n *\n * @param object The object to turn into a baggage header.\n * @returns a baggage header string, or `undefined` if the object didn't have any values, since an empty baggage header\n * is not spec compliant.\n */\nfunction objectToBaggageHeader(object: Record<string, string>): string | undefined {\n if (Object.keys(object).length === 0) {\n // An empty baggage header is not spec compliant: We return undefined.\n return undefined;\n }\n\n return Object.entries(object).reduce((baggageHeader, [objectKey, objectValue], currentIndex) => {\n const baggageEntry = `${encodeURIComponent(objectKey)}=${encodeURIComponent(objectValue)}`;\n const newBaggageHeader = currentIndex === 0 ? baggageEntry : `${baggageHeader},${baggageEntry}`;\n if (newBaggageHeader.length > MAX_BAGGAGE_STRING_LENGTH) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Not adding key: ${objectKey} with val: ${objectValue} to baggage header due to exceeding baggage size limits.`,\n );\n return baggageHeader;\n } else {\n return newBaggageHeader;\n }\n }, '');\n}\n", "import type { DynamicSamplingContext, PropagationContext, TraceparentData } from '@sentry/types';\n\nimport { baggageHeaderToDynamicSamplingContext } from './baggage';\nimport { uuid4 } from './misc';\n\nexport const TRACEPARENT_REGEXP = new RegExp(\n '^[ \\\\t]*' + // whitespace\n '([0-9a-f]{32})?' + // trace_id\n '-?([0-9a-f]{16})?' + // span_id\n '-?([01])?' + // sampled\n '[ \\\\t]*$', // whitespace\n);\n\n/**\n * Extract transaction context data from a `sentry-trace` header.\n *\n * @param traceparent Traceparent string\n *\n * @returns Object containing data from the header, or undefined if traceparent string is malformed\n */\nexport function extractTraceparentData(traceparent?: string): TraceparentData | undefined {\n if (!traceparent) {\n return undefined;\n }\n\n const matches = traceparent.match(TRACEPARENT_REGEXP);\n if (!matches) {\n return undefined;\n }\n\n let parentSampled: boolean | undefined;\n if (matches[3] === '1') {\n parentSampled = true;\n } else if (matches[3] === '0') {\n parentSampled = false;\n }\n\n return {\n traceId: matches[1],\n parentSampled,\n parentSpanId: matches[2],\n };\n}\n\n/**\n * Create tracing context from incoming headers.\n */\nexport function tracingContextFromHeaders(\n sentryTrace: Parameters<typeof extractTraceparentData>[0],\n baggage: Parameters<typeof baggageHeaderToDynamicSamplingContext>[0],\n): {\n traceparentData: ReturnType<typeof extractTraceparentData>;\n dynamicSamplingContext: ReturnType<typeof baggageHeaderToDynamicSamplingContext>;\n propagationContext: PropagationContext;\n} {\n const traceparentData = extractTraceparentData(sentryTrace);\n const dynamicSamplingContext = baggageHeaderToDynamicSamplingContext(baggage);\n\n const { traceId, parentSpanId, parentSampled } = traceparentData || {};\n\n const propagationContext: PropagationContext = {\n traceId: traceId || uuid4(),\n spanId: uuid4().substring(16),\n sampled: parentSampled,\n };\n\n if (parentSpanId) {\n propagationContext.parentSpanId = parentSpanId;\n }\n\n if (dynamicSamplingContext) {\n propagationContext.dsc = dynamicSamplingContext as DynamicSamplingContext;\n }\n\n return {\n traceparentData,\n dynamicSamplingContext,\n propagationContext,\n };\n}\n\n/**\n * Create sentry-trace header from span context values.\n */\nexport function generateSentryTraceHeader(\n traceId: string = uuid4(),\n spanId: string = uuid4().substring(16),\n sampled?: boolean,\n): string {\n let sampledString = '';\n if (sampled !== undefined) {\n sampledString = sampled ? '-1' : '-0';\n }\n return `${traceId}-${spanId}${sampledString}`;\n}\n", "import type {\n Attachment,\n AttachmentItem,\n BaseEnvelopeHeaders,\n BaseEnvelopeItemHeaders,\n DataCategory,\n DsnComponents,\n Envelope,\n EnvelopeItemType,\n Event,\n EventEnvelopeHeaders,\n SdkInfo,\n SdkMetadata,\n TextEncoderInternal,\n} from '@sentry/types';\n\nimport { dsnToString } from './dsn';\nimport { normalize } from './normalize';\nimport { dropUndefinedKeys } from './object';\n\n/**\n * Creates an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nexport function createEnvelope<E extends Envelope>(headers: E[0], items: E[1] = []): E {\n return [headers, items] as E;\n}\n\n/**\n * Add an item to an envelope.\n * Make sure to always explicitly provide the generic to this function\n * so that the envelope types resolve correctly.\n */\nexport function addItemToEnvelope<E extends Envelope>(envelope: E, newItem: E[1][number]): E {\n const [headers, items] = envelope;\n return [headers, [...items, newItem]] as unknown as E;\n}\n\n/**\n * Convenience function to loop through the items and item types of an envelope.\n * (This function was mostly created because working with envelope types is painful at the moment)\n *\n * If the callback returns true, the rest of the items will be skipped.\n */\nexport function forEachEnvelopeItem<E extends Envelope>(\n envelope: Envelope,\n callback: (envelopeItem: E[1][number], envelopeItemType: E[1][number][0]['type']) => boolean | void,\n): boolean {\n const envelopeItems = envelope[1];\n\n for (const envelopeItem of envelopeItems) {\n const envelopeItemType = envelopeItem[0].type;\n const result = callback(envelopeItem, envelopeItemType);\n\n if (result) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Returns true if the envelope contains any of the given envelope item types\n */\nexport function envelopeContainsItemType(envelope: Envelope, types: EnvelopeItemType[]): boolean {\n return forEachEnvelopeItem(envelope, (_, type) => types.includes(type));\n}\n\n/**\n * Encode a string to UTF8.\n */\nfunction encodeUTF8(input: string, textEncoder?: TextEncoderInternal): Uint8Array {\n const utf8 = textEncoder || new TextEncoder();\n return utf8.encode(input);\n}\n\n/**\n * Serializes an envelope.\n */\nexport function serializeEnvelope(envelope: Envelope, textEncoder?: TextEncoderInternal): string | Uint8Array {\n const [envHeaders, items] = envelope;\n\n // Initially we construct our envelope as a string and only convert to binary chunks if we encounter binary data\n let parts: string | Uint8Array[] = JSON.stringify(envHeaders);\n\n function append(next: string | Uint8Array): void {\n if (typeof parts === 'string') {\n parts = typeof next === 'string' ? parts + next : [encodeUTF8(parts, textEncoder), next];\n } else {\n parts.push(typeof next === 'string' ? encodeUTF8(next, textEncoder) : next);\n }\n }\n\n for (const item of items) {\n const [itemHeaders, payload] = item;\n\n append(`\\n${JSON.stringify(itemHeaders)}\\n`);\n\n if (typeof payload === 'string' || payload instanceof Uint8Array) {\n append(payload);\n } else {\n let stringifiedPayload: string;\n try {\n stringifiedPayload = JSON.stringify(payload);\n } catch (e) {\n // In case, despite all our efforts to keep `payload` circular-dependency-free, `JSON.strinify()` still\n // fails, we try again after normalizing it again with infinite normalization depth. This of course has a\n // performance impact but in this case a performance hit is better than throwing.\n stringifiedPayload = JSON.stringify(normalize(payload));\n }\n append(stringifiedPayload);\n }\n }\n\n return typeof parts === 'string' ? parts : concatBuffers(parts);\n}\n\nfunction concatBuffers(buffers: Uint8Array[]): Uint8Array {\n const totalLength = buffers.reduce((acc, buf) => acc + buf.length, 0);\n\n const merged = new Uint8Array(totalLength);\n let offset = 0;\n for (const buffer of buffers) {\n merged.set(buffer, offset);\n offset += buffer.length;\n }\n\n return merged;\n}\n\nexport interface TextDecoderInternal {\n decode(input?: Uint8Array): string;\n}\n\n/**\n * Parses an envelope\n */\nexport function parseEnvelope(\n env: string | Uint8Array,\n textEncoder: TextEncoderInternal,\n textDecoder: TextDecoderInternal,\n): Envelope {\n let buffer = typeof env === 'string' ? textEncoder.encode(env) : env;\n\n function readBinary(length: number): Uint8Array {\n const bin = buffer.subarray(0, length);\n // Replace the buffer with the remaining data excluding trailing newline\n buffer = buffer.subarray(length + 1);\n return bin;\n }\n\n function readJson<T>(): T {\n let i = buffer.indexOf(0xa);\n // If we couldn't find a newline, we must have found the end of the buffer\n if (i < 0) {\n i = buffer.length;\n }\n\n return JSON.parse(textDecoder.decode(readBinary(i))) as T;\n }\n\n const envelopeHeader = readJson<BaseEnvelopeHeaders>();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const items: [any, any][] = [];\n\n while (buffer.length) {\n const itemHeader = readJson<BaseEnvelopeItemHeaders>();\n const binaryLength = typeof itemHeader.length === 'number' ? itemHeader.length : undefined;\n\n items.push([itemHeader, binaryLength ? readBinary(binaryLength) : readJson()]);\n }\n\n return [envelopeHeader, items];\n}\n\n/**\n * Creates attachment envelope items\n */\nexport function createAttachmentEnvelopeItem(\n attachment: Attachment,\n textEncoder?: TextEncoderInternal,\n): AttachmentItem {\n const buffer = typeof attachment.data === 'string' ? encodeUTF8(attachment.data, textEncoder) : attachment.data;\n\n return [\n dropUndefinedKeys({\n type: 'attachment',\n length: buffer.length,\n filename: attachment.filename,\n content_type: attachment.contentType,\n attachment_type: attachment.attachmentType,\n }),\n buffer,\n ];\n}\n\nconst ITEM_TYPE_TO_DATA_CATEGORY_MAP: Record<EnvelopeItemType, DataCategory> = {\n session: 'session',\n sessions: 'session',\n attachment: 'attachment',\n transaction: 'transaction',\n event: 'error',\n client_report: 'internal',\n user_report: 'default',\n profile: 'profile',\n replay_event: 'replay',\n replay_recording: 'replay',\n check_in: 'monitor',\n // TODO: This is a temporary workaround until we have a proper data category for metrics\n statsd: 'unknown',\n};\n\n/**\n * Maps the type of an envelope item to a data category.\n */\nexport function envelopeItemTypeToDataCategory(type: EnvelopeItemType): DataCategory {\n return ITEM_TYPE_TO_DATA_CATEGORY_MAP[type];\n}\n\n/** Extracts the minimal SDK info from from the metadata or an events */\nexport function getSdkMetadataForEnvelopeHeader(metadataOrEvent?: SdkMetadata | Event): SdkInfo | undefined {\n if (!metadataOrEvent || !metadataOrEvent.sdk) {\n return;\n }\n const { name, version } = metadataOrEvent.sdk;\n return { name, version };\n}\n\n/**\n * Creates event envelope headers, based on event, sdk info and tunnel\n * Note: This function was extracted from the core package to make it available in Replay\n */\nexport function createEventEnvelopeHeaders(\n event: Event,\n sdkInfo: SdkInfo | undefined,\n tunnel: string | undefined,\n dsn?: DsnComponents,\n): EventEnvelopeHeaders {\n const dynamicSamplingContext = event.sdkProcessingMetadata && event.sdkProcessingMetadata.dynamicSamplingContext;\n return {\n event_id: event.event_id as string,\n sent_at: new Date().toISOString(),\n ...(sdkInfo && { sdk: sdkInfo }),\n ...(!!tunnel && dsn && { dsn: dsnToString(dsn) }),\n ...(dynamicSamplingContext && {\n trace: dropUndefinedKeys({ ...dynamicSamplingContext }),\n }),\n };\n}\n", "import type { ClientReport, ClientReportEnvelope, ClientReportItem } from '@sentry/types';\n\nimport { createEnvelope } from './envelope';\nimport { dateTimestampInSeconds } from './time';\n\n/**\n * Creates client report envelope\n * @param discarded_events An array of discard events\n * @param dsn A DSN that can be set on the header. Optional.\n */\nexport function createClientReportEnvelope(\n discarded_events: ClientReport['discarded_events'],\n dsn?: string,\n timestamp?: number,\n): ClientReportEnvelope {\n const clientReportItem: ClientReportItem = [\n { type: 'client_report' },\n {\n timestamp: timestamp || dateTimestampInSeconds(),\n discarded_events,\n },\n ];\n return createEnvelope<ClientReportEnvelope>(dsn ? { dsn } : {}, [clientReportItem]);\n}\n", "import type { TransportMakeRequestResponse } from '@sentry/types';\n\n// Intentionally keeping the key broad, as we don't know for sure what rate limit headers get returned from backend\nexport type RateLimits = Record<string, number>;\n\nexport const DEFAULT_RETRY_AFTER = 60 * 1000; // 60 seconds\n\n/**\n * Extracts Retry-After value from the request header or returns default value\n * @param header string representation of 'Retry-After' header\n * @param now current unix timestamp\n *\n */\nexport function parseRetryAfterHeader(header: string, now: number = Date.now()): number {\n const headerDelay = parseInt(`${header}`, 10);\n if (!isNaN(headerDelay)) {\n return headerDelay * 1000;\n }\n\n const headerDate = Date.parse(`${header}`);\n if (!isNaN(headerDate)) {\n return headerDate - now;\n }\n\n return DEFAULT_RETRY_AFTER;\n}\n\n/**\n * Gets the time that the given category is disabled until for rate limiting.\n * In case no category-specific limit is set but a general rate limit across all categories is active,\n * that time is returned.\n *\n * @return the time in ms that the category is disabled until or 0 if there's no active rate limit.\n */\nexport function disabledUntil(limits: RateLimits, category: string): number {\n return limits[category] || limits.all || 0;\n}\n\n/**\n * Checks if a category is rate limited\n */\nexport function isRateLimited(limits: RateLimits, category: string, now: number = Date.now()): boolean {\n return disabledUntil(limits, category) > now;\n}\n\n/**\n * Update ratelimits from incoming headers.\n *\n * @return the updated RateLimits object.\n */\nexport function updateRateLimits(\n limits: RateLimits,\n { statusCode, headers }: TransportMakeRequestResponse,\n now: number = Date.now(),\n): RateLimits {\n const updatedRateLimits: RateLimits = {\n ...limits,\n };\n\n // \"The name is case-insensitive.\"\n // https://developer.mozilla.org/en-US/docs/Web/API/Headers/get\n const rateLimitHeader = headers && headers['x-sentry-rate-limits'];\n const retryAfterHeader = headers && headers['retry-after'];\n\n if (rateLimitHeader) {\n /**\n * rate limit headers are of the form\n * <header>,<header>,..\n * where each <header> is of the form\n * <retry_after>: <categories>: <scope>: <reason_code>\n * where\n * <retry_after> is a delay in seconds\n * <categories> is the event type(s) (error, transaction, etc) being rate limited and is of the form\n * <category>;<category>;...\n * <scope> is what's being limited (org, project, or key) - ignored by SDK\n * <reason_code> is an arbitrary string like \"org_quota\" - ignored by SDK\n */\n for (const limit of rateLimitHeader.trim().split(',')) {\n const [retryAfter, categories] = limit.split(':', 2);\n const headerDelay = parseInt(retryAfter, 10);\n const delay = (!isNaN(headerDelay) ? headerDelay : 60) * 1000; // 60sec default\n if (!categories) {\n updatedRateLimits.all = now + delay;\n } else {\n for (const category of categories.split(';')) {\n updatedRateLimits[category] = now + delay;\n }\n }\n }\n } else if (retryAfterHeader) {\n updatedRateLimits.all = now + parseRetryAfterHeader(retryAfterHeader, now);\n } else if (statusCode === 429) {\n updatedRateLimits.all = now + 60 * 1000;\n }\n\n return updatedRateLimits;\n}\n", "import type {\n Event,\n EventHint,\n Exception,\n Hub,\n Mechanism,\n Severity,\n SeverityLevel,\n StackFrame,\n StackParser,\n} from '@sentry/types';\n\nimport { isError, isPlainObject } from './is';\nimport { addExceptionMechanism, addExceptionTypeValue } from './misc';\nimport { normalizeToSize } from './normalize';\nimport { extractExceptionKeysForMessage } from './object';\n\n/**\n * Extracts stack frames from the error.stack string\n */\nexport function parseStackFrames(stackParser: StackParser, error: Error): StackFrame[] {\n return stackParser(error.stack || '', 1);\n}\n\n/**\n * Extracts stack frames from the error and builds a Sentry Exception\n */\nexport function exceptionFromError(stackParser: StackParser, error: Error): Exception {\n const exception: Exception = {\n type: error.name || error.constructor.name,\n value: error.message,\n };\n\n const frames = parseStackFrames(stackParser, error);\n if (frames.length) {\n exception.stacktrace = { frames };\n }\n\n return exception;\n}\n\nfunction getMessageForObject(exception: object): string {\n if ('name' in exception && typeof exception.name === 'string') {\n let message = `'${exception.name}' captured as exception`;\n\n if ('message' in exception && typeof exception.message === 'string') {\n message += ` with message '${exception.message}'`;\n }\n\n return message;\n } else if ('message' in exception && typeof exception.message === 'string') {\n return exception.message;\n } else {\n // This will allow us to group events based on top-level keys\n // which is much better than creating new group when any key/value change\n return `Object captured as exception with keys: ${extractExceptionKeysForMessage(\n exception as Record<string, unknown>,\n )}`;\n }\n}\n\n/**\n * Builds and Event from a Exception\n * @hidden\n */\nexport function eventFromUnknownInput(\n getCurrentHub: () => Hub,\n stackParser: StackParser,\n exception: unknown,\n hint?: EventHint,\n): Event {\n let ex: unknown = exception;\n const providedMechanism: Mechanism | undefined =\n hint && hint.data && (hint.data as { mechanism: Mechanism }).mechanism;\n const mechanism: Mechanism = providedMechanism || {\n handled: true,\n type: 'generic',\n };\n\n if (!isError(exception)) {\n if (isPlainObject(exception)) {\n const hub = getCurrentHub();\n const client = hub.getClient();\n const normalizeDepth = client && client.getOptions().normalizeDepth;\n hub.configureScope(scope => {\n scope.setExtra('__serialized__', normalizeToSize(exception, normalizeDepth));\n });\n\n const message = getMessageForObject(exception);\n ex = (hint && hint.syntheticException) || new Error(message);\n (ex as Error).message = message;\n } else {\n // This handles when someone does: `throw \"something awesome\";`\n // We use synthesized Error here so we can extract a (rough) stack trace.\n ex = (hint && hint.syntheticException) || new Error(exception as string);\n (ex as Error).message = exception as string;\n }\n mechanism.synthetic = true;\n }\n\n const event = {\n exception: {\n values: [exceptionFromError(stackParser, ex as Error)],\n },\n };\n\n addExceptionTypeValue(event, undefined, undefined);\n addExceptionMechanism(event, mechanism);\n\n return {\n ...event,\n event_id: hint && hint.event_id,\n };\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nexport function eventFromMessage(\n stackParser: StackParser,\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel = 'info',\n hint?: EventHint,\n attachStacktrace?: boolean,\n): Event {\n const event: Event = {\n event_id: hint && hint.event_id,\n level,\n message,\n };\n\n if (attachStacktrace && hint && hint.syntheticException) {\n const frames = parseStackFrames(stackParser, hint.syntheticException);\n if (frames.length) {\n event.exception = {\n values: [\n {\n value: message,\n stacktrace: { frames },\n },\n ],\n };\n }\n }\n\n return event;\n}\n", "export const DEFAULT_ENVIRONMENT = 'production';\n", "import type { Event, EventHint, EventProcessor } from '@sentry/types';\nimport { getGlobalSingleton, isThenable, logger, SyncPromise } from '@sentry/utils';\n\n/**\n * Returns the global event processors.\n */\nexport function getGlobalEventProcessors(): EventProcessor[] {\n return getGlobalSingleton<EventProcessor[]>('globalEventProcessors', () => []);\n}\n\n/**\n * Add a EventProcessor to be kept globally.\n * @param callback EventProcessor to add\n */\nexport function addGlobalEventProcessor(callback: EventProcessor): void {\n getGlobalEventProcessors().push(callback);\n}\n\n/**\n * Process an array of event processors, returning the processed event (or `null` if the event was dropped).\n */\nexport function notifyEventProcessors(\n processors: EventProcessor[],\n event: Event | null,\n hint: EventHint,\n index: number = 0,\n): PromiseLike<Event | null> {\n return new SyncPromise<Event | null>((resolve, reject) => {\n const processor = processors[index];\n if (event === null || typeof processor !== 'function') {\n resolve(event);\n } else {\n const result = processor({ ...event }, hint) as Event | null;\n\n __DEBUG_BUILD__ &&\n processor.id &&\n result === null &&\n logger.log(`Event processor \"${processor.id}\" dropped event`);\n\n if (isThenable(result)) {\n void result\n .then(final => notifyEventProcessors(processors, final, hint, index + 1).then(resolve))\n .then(null, reject);\n } else {\n void notifyEventProcessors(processors, result, hint, index + 1)\n .then(resolve)\n .then(null, reject);\n }\n }\n });\n}\n", "import type { SerializedSession, Session, SessionContext, SessionStatus } from '@sentry/types';\nimport { dropUndefinedKeys, timestampInSeconds, uuid4 } from '@sentry/utils';\n\n/**\n * Creates a new `Session` object by setting certain default parameters. If optional @param context\n * is passed, the passed properties are applied to the session object.\n *\n * @param context (optional) additional properties to be applied to the returned session object\n *\n * @returns a new `Session` object\n */\nexport function makeSession(context?: Omit<SessionContext, 'started' | 'status'>): Session {\n // Both timestamp and started are in seconds since the UNIX epoch.\n const startingTime = timestampInSeconds();\n\n const session: Session = {\n sid: uuid4(),\n init: true,\n timestamp: startingTime,\n started: startingTime,\n duration: 0,\n status: 'ok',\n errors: 0,\n ignoreDuration: false,\n toJSON: () => sessionToJSON(session),\n };\n\n if (context) {\n updateSession(session, context);\n }\n\n return session;\n}\n\n/**\n * Updates a session object with the properties passed in the context.\n *\n * Note that this function mutates the passed object and returns void.\n * (Had to do this instead of returning a new and updated session because closing and sending a session\n * makes an update to the session after it was passed to the sending logic.\n * @see BaseClient.captureSession )\n *\n * @param session the `Session` to update\n * @param context the `SessionContext` holding the properties that should be updated in @param session\n */\n// eslint-disable-next-line complexity\nexport function updateSession(session: Session, context: SessionContext = {}): void {\n if (context.user) {\n if (!session.ipAddress && context.user.ip_address) {\n session.ipAddress = context.user.ip_address;\n }\n\n if (!session.did && !context.did) {\n session.did = context.user.id || context.user.email || context.user.username;\n }\n }\n\n session.timestamp = context.timestamp || timestampInSeconds();\n\n if (context.abnormal_mechanism) {\n session.abnormal_mechanism = context.abnormal_mechanism;\n }\n\n if (context.ignoreDuration) {\n session.ignoreDuration = context.ignoreDuration;\n }\n if (context.sid) {\n // Good enough uuid validation. — Kamil\n session.sid = context.sid.length === 32 ? context.sid : uuid4();\n }\n if (context.init !== undefined) {\n session.init = context.init;\n }\n if (!session.did && context.did) {\n session.did = `${context.did}`;\n }\n if (typeof context.started === 'number') {\n session.started = context.started;\n }\n if (session.ignoreDuration) {\n session.duration = undefined;\n } else if (typeof context.duration === 'number') {\n session.duration = context.duration;\n } else {\n const duration = session.timestamp - session.started;\n session.duration = duration >= 0 ? duration : 0;\n }\n if (context.release) {\n session.release = context.release;\n }\n if (context.environment) {\n session.environment = context.environment;\n }\n if (!session.ipAddress && context.ipAddress) {\n session.ipAddress = context.ipAddress;\n }\n if (!session.userAgent && context.userAgent) {\n session.userAgent = context.userAgent;\n }\n if (typeof context.errors === 'number') {\n session.errors = context.errors;\n }\n if (context.status) {\n session.status = context.status;\n }\n}\n\n/**\n * Closes a session by setting its status and updating the session object with it.\n * Internally calls `updateSession` to update the passed session object.\n *\n * Note that this function mutates the passed session (@see updateSession for explanation).\n *\n * @param session the `Session` object to be closed\n * @param status the `SessionStatus` with which the session was closed. If you don't pass a status,\n * this function will keep the previously set status, unless it was `'ok'` in which case\n * it is changed to `'exited'`.\n */\nexport function closeSession(session: Session, status?: Exclude<SessionStatus, 'ok'>): void {\n let context = {};\n if (status) {\n context = { status };\n } else if (session.status === 'ok') {\n context = { status: 'exited' };\n }\n\n updateSession(session, context);\n}\n\n/**\n * Serializes a passed session object to a JSON object with a slightly different structure.\n * This is necessary because the Sentry backend requires a slightly different schema of a session\n * than the one the JS SDKs use internally.\n *\n * @param session the session to be converted\n *\n * @returns a JSON object of the passed session\n */\nfunction sessionToJSON(session: Session): SerializedSession {\n return dropUndefinedKeys({\n sid: `${session.sid}`,\n init: session.init,\n // Make sure that sec is converted to ms for date constructor\n started: new Date(session.started * 1000).toISOString(),\n timestamp: new Date(session.timestamp * 1000).toISOString(),\n status: session.status,\n errors: session.errors,\n did: typeof session.did === 'number' || typeof session.did === 'string' ? `${session.did}` : undefined,\n duration: session.duration,\n abnormal_mechanism: session.abnormal_mechanism,\n attrs: {\n release: session.release,\n environment: session.environment,\n ip_address: session.ipAddress,\n user_agent: session.userAgent,\n },\n });\n}\n", "/* eslint-disable max-lines */\nimport type {\n Attachment,\n Breadcrumb,\n CaptureContext,\n Context,\n Contexts,\n Event,\n EventHint,\n EventProcessor,\n Extra,\n Extras,\n Primitive,\n PropagationContext,\n RequestSession,\n Scope as ScopeInterface,\n ScopeContext,\n Session,\n Severity,\n SeverityLevel,\n Span,\n Transaction,\n User,\n} from '@sentry/types';\nimport { arrayify, dateTimestampInSeconds, isPlainObject, uuid4 } from '@sentry/utils';\n\nimport { getGlobalEventProcessors, notifyEventProcessors } from './eventProcessors';\nimport { updateSession } from './session';\n\n/**\n * Default value for maximum number of breadcrumbs added to an event.\n */\nconst DEFAULT_MAX_BREADCRUMBS = 100;\n\n/**\n * Holds additional event information. {@link Scope.applyToEvent} will be\n * called by the client before an event will be sent.\n */\nexport class Scope implements ScopeInterface {\n /** Flag if notifying is happening. */\n protected _notifyingListeners: boolean;\n\n /** Callback for client to receive scope changes. */\n protected _scopeListeners: Array<(scope: Scope) => void>;\n\n /** Callback list that will be called after {@link applyToEvent}. */\n protected _eventProcessors: EventProcessor[];\n\n /** Array of breadcrumbs. */\n protected _breadcrumbs: Breadcrumb[];\n\n /** User */\n protected _user: User;\n\n /** Tags */\n protected _tags: { [key: string]: Primitive };\n\n /** Extra */\n protected _extra: Extras;\n\n /** Contexts */\n protected _contexts: Contexts;\n\n /** Attachments */\n protected _attachments: Attachment[];\n\n /** Propagation Context for distributed tracing */\n protected _propagationContext: PropagationContext;\n\n /**\n * A place to stash data which is needed at some point in the SDK's event processing pipeline but which shouldn't get\n * sent to Sentry\n */\n protected _sdkProcessingMetadata: { [key: string]: unknown };\n\n /** Fingerprint */\n protected _fingerprint?: string[];\n\n /** Severity */\n // eslint-disable-next-line deprecation/deprecation\n protected _level?: Severity | SeverityLevel;\n\n /** Transaction Name */\n protected _transactionName?: string;\n\n /** Span */\n protected _span?: Span;\n\n /** Session */\n protected _session?: Session;\n\n /** Request Mode Session Status */\n protected _requestSession?: RequestSession;\n\n // NOTE: Any field which gets added here should get added not only to the constructor but also to the `clone` method.\n\n public constructor() {\n this._notifyingListeners = false;\n this._scopeListeners = [];\n this._eventProcessors = [];\n this._breadcrumbs = [];\n this._attachments = [];\n this._user = {};\n this._tags = {};\n this._extra = {};\n this._contexts = {};\n this._sdkProcessingMetadata = {};\n this._propagationContext = generatePropagationContext();\n }\n\n /**\n * Inherit values from the parent scope.\n * @param scope to clone.\n */\n public static clone(scope?: Scope): Scope {\n const newScope = new Scope();\n if (scope) {\n newScope._breadcrumbs = [...scope._breadcrumbs];\n newScope._tags = { ...scope._tags };\n newScope._extra = { ...scope._extra };\n newScope._contexts = { ...scope._contexts };\n newScope._user = scope._user;\n newScope._level = scope._level;\n newScope._span = scope._span;\n newScope._session = scope._session;\n newScope._transactionName = scope._transactionName;\n newScope._fingerprint = scope._fingerprint;\n newScope._eventProcessors = [...scope._eventProcessors];\n newScope._requestSession = scope._requestSession;\n newScope._attachments = [...scope._attachments];\n newScope._sdkProcessingMetadata = { ...scope._sdkProcessingMetadata };\n newScope._propagationContext = { ...scope._propagationContext };\n }\n return newScope;\n }\n\n /**\n * Add internal on change listener. Used for sub SDKs that need to store the scope.\n * @hidden\n */\n public addScopeListener(callback: (scope: Scope) => void): void {\n this._scopeListeners.push(callback);\n }\n\n /**\n * @inheritDoc\n */\n public addEventProcessor(callback: EventProcessor): this {\n this._eventProcessors.push(callback);\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setUser(user: User | null): this {\n this._user = user || {};\n if (this._session) {\n updateSession(this._session, { user });\n }\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getUser(): User | undefined {\n return this._user;\n }\n\n /**\n * @inheritDoc\n */\n public getRequestSession(): RequestSession | undefined {\n return this._requestSession;\n }\n\n /**\n * @inheritDoc\n */\n public setRequestSession(requestSession?: RequestSession): this {\n this._requestSession = requestSession;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTags(tags: { [key: string]: Primitive }): this {\n this._tags = {\n ...this._tags,\n ...tags,\n };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): this {\n this._tags = { ...this._tags, [key]: value };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setExtras(extras: Extras): this {\n this._extra = {\n ...this._extra,\n ...extras,\n };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setExtra(key: string, extra: Extra): this {\n this._extra = { ...this._extra, [key]: extra };\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setFingerprint(fingerprint: string[]): this {\n this._fingerprint = fingerprint;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setLevel(\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel,\n ): this {\n this._level = level;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setTransactionName(name?: string): this {\n this._transactionName = name;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setContext(key: string, context: Context | null): this {\n if (context === null) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this._contexts[key];\n } else {\n this._contexts[key] = context;\n }\n\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setSpan(span?: Span): this {\n this._span = span;\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getSpan(): Span | undefined {\n return this._span;\n }\n\n /**\n * @inheritDoc\n */\n public getTransaction(): Transaction | undefined {\n // Often, this span (if it exists at all) will be a transaction, but it's not guaranteed to be. Regardless, it will\n // have a pointer to the currently-active transaction.\n const span = this.getSpan();\n return span && span.transaction;\n }\n\n /**\n * @inheritDoc\n */\n public setSession(session?: Session): this {\n if (!session) {\n delete this._session;\n } else {\n this._session = session;\n }\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getSession(): Session | undefined {\n return this._session;\n }\n\n /**\n * @inheritDoc\n */\n public update(captureContext?: CaptureContext): this {\n if (!captureContext) {\n return this;\n }\n\n if (typeof captureContext === 'function') {\n const updatedScope = (captureContext as <T>(scope: T) => T)(this);\n return updatedScope instanceof Scope ? updatedScope : this;\n }\n\n if (captureContext instanceof Scope) {\n this._tags = { ...this._tags, ...captureContext._tags };\n this._extra = { ...this._extra, ...captureContext._extra };\n this._contexts = { ...this._contexts, ...captureContext._contexts };\n if (captureContext._user && Object.keys(captureContext._user).length) {\n this._user = captureContext._user;\n }\n if (captureContext._level) {\n this._level = captureContext._level;\n }\n if (captureContext._fingerprint) {\n this._fingerprint = captureContext._fingerprint;\n }\n if (captureContext._requestSession) {\n this._requestSession = captureContext._requestSession;\n }\n if (captureContext._propagationContext) {\n this._propagationContext = captureContext._propagationContext;\n }\n } else if (isPlainObject(captureContext)) {\n // eslint-disable-next-line no-param-reassign\n captureContext = captureContext as ScopeContext;\n this._tags = { ...this._tags, ...captureContext.tags };\n this._extra = { ...this._extra, ...captureContext.extra };\n this._contexts = { ...this._contexts, ...captureContext.contexts };\n if (captureContext.user) {\n this._user = captureContext.user;\n }\n if (captureContext.level) {\n this._level = captureContext.level;\n }\n if (captureContext.fingerprint) {\n this._fingerprint = captureContext.fingerprint;\n }\n if (captureContext.requestSession) {\n this._requestSession = captureContext.requestSession;\n }\n if (captureContext.propagationContext) {\n this._propagationContext = captureContext.propagationContext;\n }\n }\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public clear(): this {\n this._breadcrumbs = [];\n this._tags = {};\n this._extra = {};\n this._user = {};\n this._contexts = {};\n this._level = undefined;\n this._transactionName = undefined;\n this._fingerprint = undefined;\n this._requestSession = undefined;\n this._span = undefined;\n this._session = undefined;\n this._notifyScopeListeners();\n this._attachments = [];\n this._propagationContext = generatePropagationContext();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public addBreadcrumb(breadcrumb: Breadcrumb, maxBreadcrumbs?: number): this {\n const maxCrumbs = typeof maxBreadcrumbs === 'number' ? maxBreadcrumbs : DEFAULT_MAX_BREADCRUMBS;\n\n // No data has been changed, so don't notify scope listeners\n if (maxCrumbs <= 0) {\n return this;\n }\n\n const mergedBreadcrumb = {\n timestamp: dateTimestampInSeconds(),\n ...breadcrumb,\n };\n\n const breadcrumbs = this._breadcrumbs;\n breadcrumbs.push(mergedBreadcrumb);\n this._breadcrumbs = breadcrumbs.length > maxCrumbs ? breadcrumbs.slice(-maxCrumbs) : breadcrumbs;\n\n this._notifyScopeListeners();\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getLastBreadcrumb(): Breadcrumb | undefined {\n return this._breadcrumbs[this._breadcrumbs.length - 1];\n }\n\n /**\n * @inheritDoc\n */\n public clearBreadcrumbs(): this {\n this._breadcrumbs = [];\n this._notifyScopeListeners();\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public addAttachment(attachment: Attachment): this {\n this._attachments.push(attachment);\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getAttachments(): Attachment[] {\n return this._attachments;\n }\n\n /**\n * @inheritDoc\n */\n public clearAttachments(): this {\n this._attachments = [];\n return this;\n }\n\n /**\n * Applies data from the scope to the event and runs all event processors on it.\n *\n * @param event Event\n * @param hint Object containing additional information about the original exception, for use by the event processors.\n * @hidden\n */\n public applyToEvent(\n event: Event,\n hint: EventHint = {},\n additionalEventProcessors?: EventProcessor[],\n ): PromiseLike<Event | null> {\n if (this._extra && Object.keys(this._extra).length) {\n event.extra = { ...this._extra, ...event.extra };\n }\n if (this._tags && Object.keys(this._tags).length) {\n event.tags = { ...this._tags, ...event.tags };\n }\n if (this._user && Object.keys(this._user).length) {\n event.user = { ...this._user, ...event.user };\n }\n if (this._contexts && Object.keys(this._contexts).length) {\n event.contexts = { ...this._contexts, ...event.contexts };\n }\n if (this._level) {\n event.level = this._level;\n }\n if (this._transactionName) {\n event.transaction = this._transactionName;\n }\n\n // We want to set the trace context for normal events only if there isn't already\n // a trace context on the event. There is a product feature in place where we link\n // errors with transaction and it relies on that.\n if (this._span) {\n event.contexts = { trace: this._span.getTraceContext(), ...event.contexts };\n const transaction = this._span.transaction;\n if (transaction) {\n event.sdkProcessingMetadata = {\n dynamicSamplingContext: transaction.getDynamicSamplingContext(),\n ...event.sdkProcessingMetadata,\n };\n const transactionName = transaction.name;\n if (transactionName) {\n event.tags = { transaction: transactionName, ...event.tags };\n }\n }\n }\n\n this._applyFingerprint(event);\n\n const scopeBreadcrumbs = this._getBreadcrumbs();\n const breadcrumbs = [...(event.breadcrumbs || []), ...scopeBreadcrumbs];\n event.breadcrumbs = breadcrumbs.length > 0 ? breadcrumbs : undefined;\n\n event.sdkProcessingMetadata = {\n ...event.sdkProcessingMetadata,\n ...this._sdkProcessingMetadata,\n propagationContext: this._propagationContext,\n };\n\n // TODO (v8): Update this order to be: Global > Client > Scope\n return notifyEventProcessors(\n [...(additionalEventProcessors || []), ...getGlobalEventProcessors(), ...this._eventProcessors],\n event,\n hint,\n );\n }\n\n /**\n * Add data which will be accessible during event processing but won't get sent to Sentry\n */\n public setSDKProcessingMetadata(newData: { [key: string]: unknown }): this {\n this._sdkProcessingMetadata = { ...this._sdkProcessingMetadata, ...newData };\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setPropagationContext(context: PropagationContext): this {\n this._propagationContext = context;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getPropagationContext(): PropagationContext {\n return this._propagationContext;\n }\n\n /**\n * Get the breadcrumbs for this scope.\n */\n protected _getBreadcrumbs(): Breadcrumb[] {\n return this._breadcrumbs;\n }\n\n /**\n * This will be called on every set call.\n */\n protected _notifyScopeListeners(): void {\n // We need this check for this._notifyingListeners to be able to work on scope during updates\n // If this check is not here we'll produce endless recursion when something is done with the scope\n // during the callback.\n if (!this._notifyingListeners) {\n this._notifyingListeners = true;\n this._scopeListeners.forEach(callback => {\n callback(this);\n });\n this._notifyingListeners = false;\n }\n }\n\n /**\n * Applies fingerprint from the scope to the event if there's one,\n * uses message if there's one instead or get rid of empty fingerprint\n */\n private _applyFingerprint(event: Event): void {\n // Make sure it's an array first and we actually have something in place\n event.fingerprint = event.fingerprint ? arrayify(event.fingerprint) : [];\n\n // If we have something on the scope, then merge it with event\n if (this._fingerprint) {\n event.fingerprint = event.fingerprint.concat(this._fingerprint);\n }\n\n // If we have no data at all, remove empty array default\n if (event.fingerprint && !event.fingerprint.length) {\n delete event.fingerprint;\n }\n }\n}\n\nfunction generatePropagationContext(): PropagationContext {\n return {\n traceId: uuid4(),\n spanId: uuid4().substring(16),\n };\n}\n", "/* eslint-disable max-lines */\nimport type {\n Breadcrumb,\n BreadcrumbHint,\n Client,\n CustomSamplingContext,\n Event,\n EventHint,\n Extra,\n Extras,\n Hub as HubInterface,\n Integration,\n IntegrationClass,\n Primitive,\n Session,\n SessionContext,\n Severity,\n SeverityLevel,\n Transaction,\n TransactionContext,\n User,\n} from '@sentry/types';\nimport { consoleSandbox, dateTimestampInSeconds, getGlobalSingleton, GLOBAL_OBJ, logger, uuid4 } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from './constants';\nimport { Scope } from './scope';\nimport { closeSession, makeSession, updateSession } from './session';\n\n/**\n * API compatibility version of this hub.\n *\n * WARNING: This number should only be increased when the global interface\n * changes and new methods are introduced.\n *\n * @hidden\n */\nexport const API_VERSION = 4;\n\n/**\n * Default maximum number of breadcrumbs added to an event. Can be overwritten\n * with {@link Options.maxBreadcrumbs}.\n */\nconst DEFAULT_BREADCRUMBS = 100;\n\nexport interface RunWithAsyncContextOptions {\n /** Whether to reuse an existing async context if one exists. Defaults to false. */\n reuseExisting?: boolean;\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Strategy used to track async context.\n */\nexport interface AsyncContextStrategy {\n /**\n * Gets the current async context. Returns undefined if there is no current async context.\n */\n getCurrentHub: () => Hub | undefined;\n /**\n * Runs the supplied callback in its own async context.\n */\n runWithAsyncContext<T>(callback: () => T, options: RunWithAsyncContextOptions): T;\n}\n\n/**\n * A layer in the process stack.\n * @hidden\n */\nexport interface Layer {\n client?: Client;\n scope: Scope;\n}\n\n/**\n * An object that contains a hub and maintains a scope stack.\n * @hidden\n */\nexport interface Carrier {\n __SENTRY__?: {\n hub?: Hub;\n acs?: AsyncContextStrategy;\n /**\n * Extra Hub properties injected by various SDKs\n */\n integrations?: Integration[];\n extensions?: {\n /** Extension methods for the hub, which are bound to the current Hub instance */\n // eslint-disable-next-line @typescript-eslint/ban-types\n [key: string]: Function;\n };\n };\n}\n\n/**\n * @inheritDoc\n */\nexport class Hub implements HubInterface {\n /** Is a {@link Layer}[] containing the client and scope */\n private readonly _stack: Layer[];\n\n /** Contains the last event id of a captured event. */\n private _lastEventId?: string;\n\n /**\n * Creates a new instance of the hub, will push one {@link Layer} into the\n * internal stack on creation.\n *\n * @param client bound to the hub.\n * @param scope bound to the hub.\n * @param version number, higher number means higher priority.\n */\n public constructor(client?: Client, scope: Scope = new Scope(), private readonly _version: number = API_VERSION) {\n this._stack = [{ scope }];\n if (client) {\n this.bindClient(client);\n }\n }\n\n /**\n * @inheritDoc\n */\n public isOlderThan(version: number): boolean {\n return this._version < version;\n }\n\n /**\n * @inheritDoc\n */\n public bindClient(client?: Client): void {\n const top = this.getStackTop();\n top.client = client;\n if (client && client.setupIntegrations) {\n client.setupIntegrations();\n }\n }\n\n /**\n * @inheritDoc\n */\n public pushScope(): Scope {\n // We want to clone the content of prev scope\n const scope = Scope.clone(this.getScope());\n this.getStack().push({\n client: this.getClient(),\n scope,\n });\n return scope;\n }\n\n /**\n * @inheritDoc\n */\n public popScope(): boolean {\n if (this.getStack().length <= 1) return false;\n return !!this.getStack().pop();\n }\n\n /**\n * @inheritDoc\n */\n public withScope(callback: (scope: Scope) => void): void {\n const scope = this.pushScope();\n try {\n callback(scope);\n } finally {\n this.popScope();\n }\n }\n\n /**\n * @inheritDoc\n */\n public getClient<C extends Client>(): C | undefined {\n return this.getStackTop().client as C;\n }\n\n /** Returns the scope of the top stack. */\n public getScope(): Scope {\n return this.getStackTop().scope;\n }\n\n /** Returns the scope stack for domains or the process. */\n public getStack(): Layer[] {\n return this._stack;\n }\n\n /** Returns the topmost scope layer in the order domain > local > process. */\n public getStackTop(): Layer {\n return this._stack[this._stack.length - 1];\n }\n\n /**\n * @inheritDoc\n */\n public captureException(exception: unknown, hint?: EventHint): string {\n const eventId = (this._lastEventId = hint && hint.event_id ? hint.event_id : uuid4());\n const syntheticException = new Error('Sentry syntheticException');\n this._withClient((client, scope) => {\n client.captureException(\n exception,\n {\n originalException: exception,\n syntheticException,\n ...hint,\n event_id: eventId,\n },\n scope,\n );\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level?: Severity | SeverityLevel,\n hint?: EventHint,\n ): string {\n const eventId = (this._lastEventId = hint && hint.event_id ? hint.event_id : uuid4());\n const syntheticException = new Error(message);\n this._withClient((client, scope) => {\n client.captureMessage(\n message,\n level,\n {\n originalException: message,\n syntheticException,\n ...hint,\n event_id: eventId,\n },\n scope,\n );\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureEvent(event: Event, hint?: EventHint): string {\n const eventId = hint && hint.event_id ? hint.event_id : uuid4();\n if (!event.type) {\n this._lastEventId = eventId;\n }\n\n this._withClient((client, scope) => {\n client.captureEvent(event, { ...hint, event_id: eventId }, scope);\n });\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public lastEventId(): string | undefined {\n return this._lastEventId;\n }\n\n /**\n * @inheritDoc\n */\n public addBreadcrumb(breadcrumb: Breadcrumb, hint?: BreadcrumbHint): void {\n const { scope, client } = this.getStackTop();\n\n if (!client) return;\n\n const { beforeBreadcrumb = null, maxBreadcrumbs = DEFAULT_BREADCRUMBS } =\n (client.getOptions && client.getOptions()) || {};\n\n if (maxBreadcrumbs <= 0) return;\n\n const timestamp = dateTimestampInSeconds();\n const mergedBreadcrumb = { timestamp, ...breadcrumb };\n const finalBreadcrumb = beforeBreadcrumb\n ? (consoleSandbox(() => beforeBreadcrumb(mergedBreadcrumb, hint)) as Breadcrumb | null)\n : mergedBreadcrumb;\n\n if (finalBreadcrumb === null) return;\n\n if (client.emit) {\n client.emit('beforeAddBreadcrumb', finalBreadcrumb, hint);\n }\n\n scope.addBreadcrumb(finalBreadcrumb, maxBreadcrumbs);\n }\n\n /**\n * @inheritDoc\n */\n public setUser(user: User | null): void {\n this.getScope().setUser(user);\n }\n\n /**\n * @inheritDoc\n */\n public setTags(tags: { [key: string]: Primitive }): void {\n this.getScope().setTags(tags);\n }\n\n /**\n * @inheritDoc\n */\n public setExtras(extras: Extras): void {\n this.getScope().setExtras(extras);\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): void {\n this.getScope().setTag(key, value);\n }\n\n /**\n * @inheritDoc\n */\n public setExtra(key: string, extra: Extra): void {\n this.getScope().setExtra(key, extra);\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public setContext(name: string, context: { [key: string]: any } | null): void {\n this.getScope().setContext(name, context);\n }\n\n /**\n * @inheritDoc\n */\n public configureScope(callback: (scope: Scope) => void): void {\n const { scope, client } = this.getStackTop();\n if (client) {\n callback(scope);\n }\n }\n\n /**\n * @inheritDoc\n */\n public run(callback: (hub: Hub) => void): void {\n const oldHub = makeMain(this);\n try {\n callback(this);\n } finally {\n makeMain(oldHub);\n }\n }\n\n /**\n * @inheritDoc\n */\n public getIntegration<T extends Integration>(integration: IntegrationClass<T>): T | null {\n const client = this.getClient();\n if (!client) return null;\n try {\n return client.getIntegration(integration);\n } catch (_oO) {\n __DEBUG_BUILD__ && logger.warn(`Cannot retrieve integration ${integration.id} from the current Hub`);\n return null;\n }\n }\n\n /**\n * @inheritDoc\n */\n public startTransaction(context: TransactionContext, customSamplingContext?: CustomSamplingContext): Transaction {\n const result = this._callExtensionMethod<Transaction>('startTransaction', context, customSamplingContext);\n\n if (__DEBUG_BUILD__ && !result) {\n const client = this.getClient();\n if (!client) {\n // eslint-disable-next-line no-console\n console.warn(\n \"Tracing extension 'startTransaction' is missing. You should 'init' the SDK before calling 'startTransaction'\",\n );\n } else {\n // eslint-disable-next-line no-console\n console.warn(`Tracing extension 'startTransaction' has not been added. Call 'addTracingExtensions' before calling 'init':\nSentry.addTracingExtensions();\nSentry.init({...});\n`);\n }\n }\n\n return result;\n }\n\n /**\n * @inheritDoc\n */\n public traceHeaders(): { [key: string]: string } {\n return this._callExtensionMethod<{ [key: string]: string }>('traceHeaders');\n }\n\n /**\n * @inheritDoc\n */\n public captureSession(endSession: boolean = false): void {\n // both send the update and pull the session from the scope\n if (endSession) {\n return this.endSession();\n }\n\n // only send the update\n this._sendSessionUpdate();\n }\n\n /**\n * @inheritDoc\n */\n public endSession(): void {\n const layer = this.getStackTop();\n const scope = layer.scope;\n const session = scope.getSession();\n if (session) {\n closeSession(session);\n }\n this._sendSessionUpdate();\n\n // the session is over; take it off of the scope\n scope.setSession();\n }\n\n /**\n * @inheritDoc\n */\n public startSession(context?: SessionContext): Session {\n const { scope, client } = this.getStackTop();\n const { release, environment = DEFAULT_ENVIRONMENT } = (client && client.getOptions()) || {};\n\n // Will fetch userAgent if called from browser sdk\n const { userAgent } = GLOBAL_OBJ.navigator || {};\n\n const session = makeSession({\n release,\n environment,\n user: scope.getUser(),\n ...(userAgent && { userAgent }),\n ...context,\n });\n\n // End existing session if there's one\n const currentSession = scope.getSession && scope.getSession();\n if (currentSession && currentSession.status === 'ok') {\n updateSession(currentSession, { status: 'exited' });\n }\n this.endSession();\n\n // Afterwards we set the new session on the scope\n scope.setSession(session);\n\n return session;\n }\n\n /**\n * Returns if default PII should be sent to Sentry and propagated in ourgoing requests\n * when Tracing is used.\n */\n public shouldSendDefaultPii(): boolean {\n const client = this.getClient();\n const options = client && client.getOptions();\n return Boolean(options && options.sendDefaultPii);\n }\n\n /**\n * Sends the current Session on the scope\n */\n private _sendSessionUpdate(): void {\n const { scope, client } = this.getStackTop();\n\n const session = scope.getSession();\n if (session && client && client.captureSession) {\n client.captureSession(session);\n }\n }\n\n /**\n * Internal helper function to call a method on the top client if it exists.\n *\n * @param method The method to call on the client.\n * @param args Arguments to pass to the client function.\n */\n private _withClient(callback: (client: Client, scope: Scope) => void): void {\n const { scope, client } = this.getStackTop();\n if (client) {\n callback(client, scope);\n }\n }\n\n /**\n * Calls global extension method and binding current instance to the function call\n */\n // @ts-expect-error Function lacks ending return statement and return type does not include 'undefined'. ts(2366)\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private _callExtensionMethod<T>(method: string, ...args: any[]): T {\n const carrier = getMainCarrier();\n const sentry = carrier.__SENTRY__;\n if (sentry && sentry.extensions && typeof sentry.extensions[method] === 'function') {\n return sentry.extensions[method].apply(this, args);\n }\n __DEBUG_BUILD__ && logger.warn(`Extension method ${method} couldn't be found, doing nothing.`);\n }\n}\n\n/**\n * Returns the global shim registry.\n *\n * FIXME: This function is problematic, because despite always returning a valid Carrier,\n * it has an optional `__SENTRY__` property, which then in turn requires us to always perform an unnecessary check\n * at the call-site. We always access the carrier through this function, so we can guarantee that `__SENTRY__` is there.\n **/\nexport function getMainCarrier(): Carrier {\n GLOBAL_OBJ.__SENTRY__ = GLOBAL_OBJ.__SENTRY__ || {\n extensions: {},\n hub: undefined,\n };\n return GLOBAL_OBJ;\n}\n\n/**\n * Replaces the current main hub with the passed one on the global object\n *\n * @returns The old replaced hub\n */\nexport function makeMain(hub: Hub): Hub {\n const registry = getMainCarrier();\n const oldHub = getHubFromCarrier(registry);\n setHubOnCarrier(registry, hub);\n return oldHub;\n}\n\n/**\n * Returns the default hub instance.\n *\n * If a hub is already registered in the global carrier but this module\n * contains a more recent version, it replaces the registered version.\n * Otherwise, the currently registered hub will be returned.\n */\nexport function getCurrentHub(): Hub {\n // Get main carrier (global for every environment)\n const registry = getMainCarrier();\n\n if (registry.__SENTRY__ && registry.__SENTRY__.acs) {\n const hub = registry.__SENTRY__.acs.getCurrentHub();\n\n if (hub) {\n return hub;\n }\n }\n\n // Return hub that lives on a global object\n return getGlobalHub(registry);\n}\n\nfunction getGlobalHub(registry: Carrier = getMainCarrier()): Hub {\n // If there's no hub, or its an old API, assign a new one\n if (!hasHubOnCarrier(registry) || getHubFromCarrier(registry).isOlderThan(API_VERSION)) {\n setHubOnCarrier(registry, new Hub());\n }\n\n // Return hub that lives on a global object\n return getHubFromCarrier(registry);\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * If the carrier does not contain a hub, a new hub is created with the global hub client and scope.\n */\nexport function ensureHubOnCarrier(carrier: Carrier, parent: Hub = getGlobalHub()): void {\n // If there's no hub on current domain, or it's an old API, assign a new one\n if (!hasHubOnCarrier(carrier) || getHubFromCarrier(carrier).isOlderThan(API_VERSION)) {\n const globalHubTopStack = parent.getStackTop();\n setHubOnCarrier(carrier, new Hub(globalHubTopStack.client, Scope.clone(globalHubTopStack.scope)));\n }\n}\n\n/**\n * @private Private API with no semver guarantees!\n *\n * Sets the global async context strategy\n */\nexport function setAsyncContextStrategy(strategy: AsyncContextStrategy | undefined): void {\n // Get main carrier (global for every environment)\n const registry = getMainCarrier();\n registry.__SENTRY__ = registry.__SENTRY__ || {};\n registry.__SENTRY__.acs = strategy;\n}\n\n/**\n * Runs the supplied callback in its own async context. Async Context strategies are defined per SDK.\n *\n * @param callback The callback to run in its own async context\n * @param options Options to pass to the async context strategy\n * @returns The result of the callback\n */\nexport function runWithAsyncContext<T>(callback: () => T, options: RunWithAsyncContextOptions = {}): T {\n const registry = getMainCarrier();\n\n if (registry.__SENTRY__ && registry.__SENTRY__.acs) {\n return registry.__SENTRY__.acs.runWithAsyncContext(callback, options);\n }\n\n // if there was no strategy, fallback to just calling the callback\n return callback();\n}\n\n/**\n * This will tell whether a carrier has a hub on it or not\n * @param carrier object\n */\nfunction hasHubOnCarrier(carrier: Carrier): boolean {\n return !!(carrier && carrier.__SENTRY__ && carrier.__SENTRY__.hub);\n}\n\n/**\n * This will create a new {@link Hub} and add to the passed object on\n * __SENTRY__.hub.\n * @param carrier object\n * @hidden\n */\nexport function getHubFromCarrier(carrier: Carrier): Hub {\n return getGlobalSingleton<Hub>('hub', () => new Hub(), carrier);\n}\n\n/**\n * This will set passed {@link Hub} on the passed object's __SENTRY__.hub attribute\n * @param carrier object\n * @param hub Hub\n * @returns A boolean indicating success or failure\n */\nexport function setHubOnCarrier(carrier: Carrier, hub: Hub): boolean {\n if (!carrier) return false;\n const __SENTRY__ = (carrier.__SENTRY__ = carrier.__SENTRY__ || {});\n __SENTRY__.hub = hub;\n return true;\n}\n", "import type { Transaction } from '@sentry/types';\n\nimport type { Hub } from '../hub';\nimport { getCurrentHub } from '../hub';\n\n/**\n * The `extractTraceparentData` function and `TRACEPARENT_REGEXP` constant used\n * to be declared in this file. It was later moved into `@sentry/utils` as part of a\n * move to remove `@sentry/tracing` dependencies from `@sentry/node` (`extractTraceparentData`\n * is the only tracing function used by `@sentry/node`).\n *\n * These exports are kept here for backwards compatability's sake.\n *\n * TODO(v7): Reorganize these exports\n *\n * See https://github.com/getsentry/sentry-javascript/issues/4642 for more details.\n */\nexport { TRACEPARENT_REGEXP, extractTraceparentData } from '@sentry/utils';\n\n/** Grabs active transaction off scope, if any */\nexport function getActiveTransaction<T extends Transaction>(maybeHub?: Hub): T | undefined {\n const hub = maybeHub || getCurrentHub();\n const scope = hub.getScope();\n return scope.getTransaction() as T | undefined;\n}\n\n// so it can be used in manual instrumentation without necessitating a hard dependency on @sentry/utils\nexport { stripUrlQueryAndFragment } from '@sentry/utils';\n", "import { addInstrumentationHandler, logger } from '@sentry/utils';\n\nimport type { SpanStatusType } from './span';\nimport { getActiveTransaction } from './utils';\n\nlet errorsInstrumented = false;\n\n/**\n * Configures global error listeners\n */\nexport function registerErrorInstrumentation(): void {\n if (errorsInstrumented) {\n return;\n }\n\n errorsInstrumented = true;\n addInstrumentationHandler('error', errorCallback);\n addInstrumentationHandler('unhandledrejection', errorCallback);\n}\n\n/**\n * If an error or unhandled promise occurs, we mark the active transaction as failed\n */\nfunction errorCallback(): void {\n const activeTransaction = getActiveTransaction();\n if (activeTransaction) {\n const status: SpanStatusType = 'internal_error';\n __DEBUG_BUILD__ && logger.log(`[Tracing] Transaction: ${status} -> Global error occured`);\n activeTransaction.setStatus(status);\n }\n}\n\n// The function name will be lost when bundling but we need to be able to identify this listener later to maintain the\n// node.js default exit behaviour\nerrorCallback.tag = 'sentry_tracingErrorCallback';\n", "/* eslint-disable max-lines */\nimport type {\n Instrumenter,\n Primitive,\n Span as SpanInterface,\n SpanContext,\n SpanOrigin,\n TraceContext,\n Transaction,\n} from '@sentry/types';\nimport { dropUndefinedKeys, generateSentryTraceHeader, logger, timestampInSeconds, uuid4 } from '@sentry/utils';\n\n/**\n * Keeps track of finished spans for a given transaction\n * @internal\n * @hideconstructor\n * @hidden\n */\nexport class SpanRecorder {\n public spans: Span[];\n\n private readonly _maxlen: number;\n\n public constructor(maxlen: number = 1000) {\n this._maxlen = maxlen;\n this.spans = [];\n }\n\n /**\n * This is just so that we don't run out of memory while recording a lot\n * of spans. At some point we just stop and flush out the start of the\n * trace tree (i.e.the first n spans with the smallest\n * start_timestamp).\n */\n public add(span: Span): void {\n if (this.spans.length > this._maxlen) {\n span.spanRecorder = undefined;\n } else {\n this.spans.push(span);\n }\n }\n}\n\n/**\n * Span contains all data about a span\n */\nexport class Span implements SpanInterface {\n /**\n * @inheritDoc\n */\n public traceId: string;\n\n /**\n * @inheritDoc\n */\n public spanId: string;\n\n /**\n * @inheritDoc\n */\n public parentSpanId?: string;\n\n /**\n * Internal keeper of the status\n */\n public status?: SpanStatusType | string;\n\n /**\n * @inheritDoc\n */\n public sampled?: boolean;\n\n /**\n * Timestamp in seconds when the span was created.\n */\n public startTimestamp: number;\n\n /**\n * Timestamp in seconds when the span ended.\n */\n public endTimestamp?: number;\n\n /**\n * @inheritDoc\n */\n public op?: string;\n\n /**\n * @inheritDoc\n */\n public description?: string;\n\n /**\n * @inheritDoc\n */\n public tags: { [key: string]: Primitive };\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public data: { [key: string]: any };\n\n /**\n * List of spans that were finalized\n */\n public spanRecorder?: SpanRecorder;\n\n /**\n * @inheritDoc\n */\n public transaction?: Transaction;\n\n /**\n * The instrumenter that created this span.\n */\n public instrumenter: Instrumenter;\n\n /**\n * The origin of the span, giving context about what created the span.\n */\n public origin?: SpanOrigin;\n\n /**\n * You should never call the constructor manually, always use `Sentry.startTransaction()`\n * or call `startChild()` on an existing span.\n * @internal\n * @hideconstructor\n * @hidden\n */\n public constructor(spanContext: SpanContext = {}) {\n this.traceId = spanContext.traceId || uuid4();\n this.spanId = spanContext.spanId || uuid4().substring(16);\n this.startTimestamp = spanContext.startTimestamp || timestampInSeconds();\n this.tags = spanContext.tags || {};\n this.data = spanContext.data || {};\n this.instrumenter = spanContext.instrumenter || 'sentry';\n this.origin = spanContext.origin || 'manual';\n\n if (spanContext.parentSpanId) {\n this.parentSpanId = spanContext.parentSpanId;\n }\n // We want to include booleans as well here\n if ('sampled' in spanContext) {\n this.sampled = spanContext.sampled;\n }\n if (spanContext.op) {\n this.op = spanContext.op;\n }\n if (spanContext.description) {\n this.description = spanContext.description;\n }\n if (spanContext.name) {\n this.description = spanContext.name;\n }\n if (spanContext.status) {\n this.status = spanContext.status;\n }\n if (spanContext.endTimestamp) {\n this.endTimestamp = spanContext.endTimestamp;\n }\n }\n\n /** An alias for `description` of the Span. */\n public get name(): string {\n return this.description || '';\n }\n /** Update the name of the span. */\n public set name(name: string) {\n this.setName(name);\n }\n\n /**\n * @inheritDoc\n */\n public startChild(\n spanContext?: Pick<SpanContext, Exclude<keyof SpanContext, 'sampled' | 'traceId' | 'parentSpanId'>>,\n ): Span {\n const childSpan = new Span({\n ...spanContext,\n parentSpanId: this.spanId,\n sampled: this.sampled,\n traceId: this.traceId,\n });\n\n childSpan.spanRecorder = this.spanRecorder;\n if (childSpan.spanRecorder) {\n childSpan.spanRecorder.add(childSpan);\n }\n\n childSpan.transaction = this.transaction;\n\n if (__DEBUG_BUILD__ && childSpan.transaction) {\n const opStr = (spanContext && spanContext.op) || '< unknown op >';\n const nameStr = childSpan.transaction.name || '< unknown name >';\n const idStr = childSpan.transaction.spanId;\n\n const logMessage = `[Tracing] Starting '${opStr}' span on transaction '${nameStr}' (${idStr}).`;\n childSpan.transaction.metadata.spanMetadata[childSpan.spanId] = { logMessage };\n logger.log(logMessage);\n }\n\n return childSpan;\n }\n\n /**\n * @inheritDoc\n */\n public setTag(key: string, value: Primitive): this {\n this.tags = { ...this.tags, [key]: value };\n return this;\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public setData(key: string, value: any): this {\n this.data = { ...this.data, [key]: value };\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setStatus(value: SpanStatusType): this {\n this.status = value;\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setHttpStatus(httpStatus: number): this {\n this.setTag('http.status_code', String(httpStatus));\n this.setData('http.response.status_code', httpStatus);\n const spanStatus = spanStatusfromHttpCode(httpStatus);\n if (spanStatus !== 'unknown_error') {\n this.setStatus(spanStatus);\n }\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public setName(name: string): void {\n this.description = name;\n }\n\n /**\n * @inheritDoc\n */\n public isSuccess(): boolean {\n return this.status === 'ok';\n }\n\n /**\n * @inheritDoc\n */\n public finish(endTimestamp?: number): void {\n if (\n __DEBUG_BUILD__ &&\n // Don't call this for transactions\n this.transaction &&\n this.transaction.spanId !== this.spanId\n ) {\n const { logMessage } = this.transaction.metadata.spanMetadata[this.spanId];\n if (logMessage) {\n logger.log((logMessage as string).replace('Starting', 'Finishing'));\n }\n }\n\n this.endTimestamp = typeof endTimestamp === 'number' ? endTimestamp : timestampInSeconds();\n }\n\n /**\n * @inheritDoc\n */\n public toTraceparent(): string {\n return generateSentryTraceHeader(this.traceId, this.spanId, this.sampled);\n }\n\n /**\n * @inheritDoc\n */\n public toContext(): SpanContext {\n return dropUndefinedKeys({\n data: this.data,\n description: this.description,\n endTimestamp: this.endTimestamp,\n op: this.op,\n parentSpanId: this.parentSpanId,\n sampled: this.sampled,\n spanId: this.spanId,\n startTimestamp: this.startTimestamp,\n status: this.status,\n tags: this.tags,\n traceId: this.traceId,\n });\n }\n\n /**\n * @inheritDoc\n */\n public updateWithContext(spanContext: SpanContext): this {\n this.data = spanContext.data || {};\n this.description = spanContext.description;\n this.endTimestamp = spanContext.endTimestamp;\n this.op = spanContext.op;\n this.parentSpanId = spanContext.parentSpanId;\n this.sampled = spanContext.sampled;\n this.spanId = spanContext.spanId || this.spanId;\n this.startTimestamp = spanContext.startTimestamp || this.startTimestamp;\n this.status = spanContext.status;\n this.tags = spanContext.tags || {};\n this.traceId = spanContext.traceId || this.traceId;\n\n return this;\n }\n\n /**\n * @inheritDoc\n */\n public getTraceContext(): TraceContext {\n return dropUndefinedKeys({\n data: Object.keys(this.data).length > 0 ? this.data : undefined,\n description: this.description,\n op: this.op,\n parent_span_id: this.parentSpanId,\n span_id: this.spanId,\n status: this.status,\n tags: Object.keys(this.tags).length > 0 ? this.tags : undefined,\n trace_id: this.traceId,\n });\n }\n\n /**\n * @inheritDoc\n */\n public toJSON(): {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data?: { [key: string]: any };\n description?: string;\n op?: string;\n parent_span_id?: string;\n span_id: string;\n start_timestamp: number;\n status?: string;\n tags?: { [key: string]: Primitive };\n timestamp?: number;\n trace_id: string;\n origin?: SpanOrigin;\n } {\n return dropUndefinedKeys({\n data: Object.keys(this.data).length > 0 ? this.data : undefined,\n description: this.description,\n op: this.op,\n parent_span_id: this.parentSpanId,\n span_id: this.spanId,\n start_timestamp: this.startTimestamp,\n status: this.status,\n tags: Object.keys(this.tags).length > 0 ? this.tags : undefined,\n timestamp: this.endTimestamp,\n trace_id: this.traceId,\n origin: this.origin,\n });\n }\n}\n\nexport type SpanStatusType =\n /** The operation completed successfully. */\n | 'ok'\n /** Deadline expired before operation could complete. */\n | 'deadline_exceeded'\n /** 401 Unauthorized (actually does mean unauthenticated according to RFC 7235) */\n | 'unauthenticated'\n /** 403 Forbidden */\n | 'permission_denied'\n /** 404 Not Found. Some requested entity (file or directory) was not found. */\n | 'not_found'\n /** 429 Too Many Requests */\n | 'resource_exhausted'\n /** Client specified an invalid argument. 4xx. */\n | 'invalid_argument'\n /** 501 Not Implemented */\n | 'unimplemented'\n /** 503 Service Unavailable */\n | 'unavailable'\n /** Other/generic 5xx. */\n | 'internal_error'\n /** Unknown. Any non-standard HTTP status code. */\n | 'unknown_error'\n /** The operation was cancelled (typically by the user). */\n | 'cancelled'\n /** Already exists (409) */\n | 'already_exists'\n /** Operation was rejected because the system is not in a state required for the operation's */\n | 'failed_precondition'\n /** The operation was aborted, typically due to a concurrency issue. */\n | 'aborted'\n /** Operation was attempted past the valid range. */\n | 'out_of_range'\n /** Unrecoverable data loss or corruption */\n | 'data_loss';\n\n/**\n * Converts a HTTP status code into a {@link SpanStatusType}.\n *\n * @param httpStatus The HTTP response status code.\n * @returns The span status or unknown_error.\n */\nexport function spanStatusfromHttpCode(httpStatus: number): SpanStatusType {\n if (httpStatus < 400 && httpStatus >= 100) {\n return 'ok';\n }\n\n if (httpStatus >= 400 && httpStatus < 500) {\n switch (httpStatus) {\n case 401:\n return 'unauthenticated';\n case 403:\n return 'permission_denied';\n case 404:\n return 'not_found';\n case 409:\n return 'already_exists';\n case 413:\n return 'failed_precondition';\n case 429:\n return 'resource_exhausted';\n default:\n return 'invalid_argument';\n }\n }\n\n if (httpStatus >= 500 && httpStatus < 600) {\n switch (httpStatus) {\n case 501:\n return 'unimplemented';\n case 503:\n return 'unavailable';\n case 504:\n return 'deadline_exceeded';\n default:\n return 'internal_error';\n }\n }\n\n return 'unknown_error';\n}\n", "import type { Client, DynamicSamplingContext, Scope } from '@sentry/types';\nimport { dropUndefinedKeys } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from '../constants';\n\n/**\n * Creates a dynamic sampling context from a client.\n *\n * Dispatchs the `createDsc` lifecycle hook as a side effect.\n */\nexport function getDynamicSamplingContextFromClient(\n trace_id: string,\n client: Client,\n scope?: Scope,\n): DynamicSamplingContext {\n const options = client.getOptions();\n\n const { publicKey: public_key } = client.getDsn() || {};\n const { segment: user_segment } = (scope && scope.getUser()) || {};\n\n const dsc = dropUndefinedKeys({\n environment: options.environment || DEFAULT_ENVIRONMENT,\n release: options.release,\n user_segment,\n public_key,\n trace_id,\n }) as DynamicSamplingContext;\n\n client.emit && client.emit('createDsc', dsc);\n\n return dsc;\n}\n", "import type {\n Context,\n Contexts,\n DynamicSamplingContext,\n Measurements,\n MeasurementUnit,\n Transaction as TransactionInterface,\n TransactionContext,\n TransactionEvent,\n TransactionMetadata,\n} from '@sentry/types';\nimport { dropUndefinedKeys, logger } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport { getCurrentHub } from '../hub';\nimport { getDynamicSamplingContextFromClient } from './dynamicSamplingContext';\nimport { Span as SpanClass, SpanRecorder } from './span';\n\n/** JSDoc */\nexport class Transaction extends SpanClass implements TransactionInterface {\n public metadata: TransactionMetadata;\n\n /**\n * The reference to the current hub.\n */\n public _hub: Hub;\n\n private _name: string;\n\n private _measurements: Measurements;\n\n private _contexts: Contexts;\n\n private _trimEnd?: boolean;\n\n private _frozenDynamicSamplingContext: Readonly<Partial<DynamicSamplingContext>> | undefined;\n\n /**\n * This constructor should never be called manually. Those instrumenting tracing should use\n * `Sentry.startTransaction()`, and internal methods should use `hub.startTransaction()`.\n * @internal\n * @hideconstructor\n * @hidden\n */\n public constructor(transactionContext: TransactionContext, hub?: Hub) {\n super(transactionContext);\n // We need to delete description since it's set by the Span class constructor\n // but not needed for transactions.\n delete this.description;\n\n this._measurements = {};\n this._contexts = {};\n\n this._hub = hub || getCurrentHub();\n\n this._name = transactionContext.name || '';\n\n this.metadata = {\n source: 'custom',\n ...transactionContext.metadata,\n spanMetadata: {},\n };\n\n this._trimEnd = transactionContext.trimEnd;\n\n // this is because transactions are also spans, and spans have a transaction pointer\n this.transaction = this;\n\n // If Dynamic Sampling Context is provided during the creation of the transaction, we freeze it as it usually means\n // there is incoming Dynamic Sampling Context. (Either through an incoming request, a baggage meta-tag, or other means)\n const incomingDynamicSamplingContext = this.metadata.dynamicSamplingContext;\n if (incomingDynamicSamplingContext) {\n // We shallow copy this in case anything writes to the original reference of the passed in `dynamicSamplingContext`\n this._frozenDynamicSamplingContext = { ...incomingDynamicSamplingContext };\n }\n }\n\n /** Getter for `name` property */\n public get name(): string {\n return this._name;\n }\n\n /** Setter for `name` property, which also sets `source` as custom */\n public set name(newName: string) {\n this.setName(newName);\n }\n\n /**\n * JSDoc\n */\n public setName(name: string, source: TransactionMetadata['source'] = 'custom'): void {\n this._name = name;\n this.metadata.source = source;\n }\n\n /**\n * Attaches SpanRecorder to the span itself\n * @param maxlen maximum number of spans that can be recorded\n */\n public initSpanRecorder(maxlen: number = 1000): void {\n if (!this.spanRecorder) {\n this.spanRecorder = new SpanRecorder(maxlen);\n }\n this.spanRecorder.add(this);\n }\n\n /**\n * @inheritDoc\n */\n public setContext(key: string, context: Context | null): void {\n if (context === null) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this._contexts[key];\n } else {\n this._contexts[key] = context;\n }\n }\n\n /**\n * @inheritDoc\n */\n public setMeasurement(name: string, value: number, unit: MeasurementUnit = ''): void {\n this._measurements[name] = { value, unit };\n }\n\n /**\n * @inheritDoc\n */\n public setMetadata(newMetadata: Partial<TransactionMetadata>): void {\n this.metadata = { ...this.metadata, ...newMetadata };\n }\n\n /**\n * @inheritDoc\n */\n public finish(endTimestamp?: number): string | undefined {\n const transaction = this._finishTransaction(endTimestamp);\n if (!transaction) {\n return undefined;\n }\n return this._hub.captureEvent(transaction);\n }\n\n /**\n * @inheritDoc\n */\n public toContext(): TransactionContext {\n const spanContext = super.toContext();\n\n return dropUndefinedKeys({\n ...spanContext,\n name: this.name,\n trimEnd: this._trimEnd,\n });\n }\n\n /**\n * @inheritDoc\n */\n public updateWithContext(transactionContext: TransactionContext): this {\n super.updateWithContext(transactionContext);\n\n this.name = transactionContext.name || '';\n\n this._trimEnd = transactionContext.trimEnd;\n\n return this;\n }\n\n /**\n * @inheritdoc\n *\n * @experimental\n */\n public getDynamicSamplingContext(): Readonly<Partial<DynamicSamplingContext>> {\n if (this._frozenDynamicSamplingContext) {\n return this._frozenDynamicSamplingContext;\n }\n\n const hub = this._hub || getCurrentHub();\n const client = hub.getClient();\n\n if (!client) return {};\n\n const scope = hub.getScope();\n const dsc = getDynamicSamplingContextFromClient(this.traceId, client, scope);\n\n const maybeSampleRate = this.metadata.sampleRate;\n if (maybeSampleRate !== undefined) {\n dsc.sample_rate = `${maybeSampleRate}`;\n }\n\n // We don't want to have a transaction name in the DSC if the source is \"url\" because URLs might contain PII\n const source = this.metadata.source;\n if (source && source !== 'url') {\n dsc.transaction = this.name;\n }\n\n if (this.sampled !== undefined) {\n dsc.sampled = String(this.sampled);\n }\n\n // Uncomment if we want to make DSC immutable\n // this._frozenDynamicSamplingContext = dsc;\n\n return dsc;\n }\n\n /**\n * Override the current hub with a new one.\n * Used if you want another hub to finish the transaction.\n *\n * @internal\n */\n public setHub(hub: Hub): void {\n this._hub = hub;\n }\n\n /**\n * Finish the transaction & prepare the event to send to Sentry.\n */\n protected _finishTransaction(endTimestamp?: number): TransactionEvent | undefined {\n // This transaction is already finished, so we should not flush it again.\n if (this.endTimestamp !== undefined) {\n return undefined;\n }\n\n if (!this.name) {\n __DEBUG_BUILD__ && logger.warn('Transaction has no name, falling back to `<unlabeled transaction>`.');\n this.name = '<unlabeled transaction>';\n }\n\n // just sets the end timestamp\n super.finish(endTimestamp);\n\n const client = this._hub.getClient();\n if (client && client.emit) {\n client.emit('finishTransaction', this);\n }\n\n if (this.sampled !== true) {\n // At this point if `sampled !== true` we want to discard the transaction.\n __DEBUG_BUILD__ && logger.log('[Tracing] Discarding transaction because its trace was not chosen to be sampled.');\n\n if (client) {\n client.recordDroppedEvent('sample_rate', 'transaction');\n }\n\n return undefined;\n }\n\n const finishedSpans = this.spanRecorder ? this.spanRecorder.spans.filter(s => s !== this && s.endTimestamp) : [];\n\n if (this._trimEnd && finishedSpans.length > 0) {\n this.endTimestamp = finishedSpans.reduce((prev: SpanClass, current: SpanClass) => {\n if (prev.endTimestamp && current.endTimestamp) {\n return prev.endTimestamp > current.endTimestamp ? prev : current;\n }\n return prev;\n }).endTimestamp;\n }\n\n const metadata = this.metadata;\n\n const transaction: TransactionEvent = {\n contexts: {\n ...this._contexts,\n // We don't want to override trace context\n trace: this.getTraceContext(),\n },\n spans: finishedSpans,\n start_timestamp: this.startTimestamp,\n tags: this.tags,\n timestamp: this.endTimestamp,\n transaction: this.name,\n type: 'transaction',\n sdkProcessingMetadata: {\n ...metadata,\n dynamicSamplingContext: this.getDynamicSamplingContext(),\n },\n ...(metadata.source && {\n transaction_info: {\n source: metadata.source,\n },\n }),\n };\n\n const hasMeasurements = Object.keys(this._measurements).length > 0;\n\n if (hasMeasurements) {\n __DEBUG_BUILD__ &&\n logger.log(\n '[Measurements] Adding measurements to transaction',\n JSON.stringify(this._measurements, undefined, 2),\n );\n transaction.measurements = this._measurements;\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] Finishing ${this.op} transaction: ${this.name}.`);\n\n return transaction;\n }\n}\n", "/* eslint-disable max-lines */\nimport type { TransactionContext } from '@sentry/types';\nimport { logger, timestampInSeconds } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport type { Span } from './span';\nimport { SpanRecorder } from './span';\nimport { Transaction } from './transaction';\n\nexport const TRACING_DEFAULTS = {\n idleTimeout: 1000,\n finalTimeout: 30000,\n heartbeatInterval: 5000,\n};\n\nconst FINISH_REASON_TAG = 'finishReason';\n\nconst IDLE_TRANSACTION_FINISH_REASONS = [\n 'heartbeatFailed',\n 'idleTimeout',\n 'documentHidden',\n 'finalTimeout',\n 'externalFinish',\n 'cancelled',\n];\n\n/**\n * @inheritDoc\n */\nexport class IdleTransactionSpanRecorder extends SpanRecorder {\n public constructor(\n private readonly _pushActivity: (id: string) => void,\n private readonly _popActivity: (id: string) => void,\n public transactionSpanId: string,\n maxlen?: number,\n ) {\n super(maxlen);\n }\n\n /**\n * @inheritDoc\n */\n public add(span: Span): void {\n // We should make sure we do not push and pop activities for\n // the transaction that this span recorder belongs to.\n if (span.spanId !== this.transactionSpanId) {\n // We patch span.finish() to pop an activity after setting an endTimestamp.\n span.finish = (endTimestamp?: number) => {\n span.endTimestamp = typeof endTimestamp === 'number' ? endTimestamp : timestampInSeconds();\n this._popActivity(span.spanId);\n };\n\n // We should only push new activities if the span does not have an end timestamp.\n if (span.endTimestamp === undefined) {\n this._pushActivity(span.spanId);\n }\n }\n\n super.add(span);\n }\n}\n\nexport type BeforeFinishCallback = (transactionSpan: IdleTransaction, endTimestamp: number) => void;\n\n/**\n * An IdleTransaction is a transaction that automatically finishes. It does this by tracking child spans as activities.\n * You can have multiple IdleTransactions active, but if the `onScope` option is specified, the idle transaction will\n * put itself on the scope on creation.\n */\nexport class IdleTransaction extends Transaction {\n // Activities store a list of active spans\n public activities: Record<string, boolean>;\n // Track state of activities in previous heartbeat\n private _prevHeartbeatString: string | undefined;\n\n // Amount of times heartbeat has counted. Will cause transaction to finish after 3 beats.\n private _heartbeatCounter: number;\n\n // We should not use heartbeat if we finished a transaction\n private _finished: boolean;\n\n // Idle timeout was canceled and we should finish the transaction with the last span end.\n private _idleTimeoutCanceledPermanently: boolean;\n\n private readonly _beforeFinishCallbacks: BeforeFinishCallback[];\n\n /**\n * Timer that tracks Transaction idleTimeout\n */\n private _idleTimeoutID: ReturnType<typeof setTimeout> | undefined;\n\n private _finishReason: (typeof IDLE_TRANSACTION_FINISH_REASONS)[number];\n\n public constructor(\n transactionContext: TransactionContext,\n private readonly _idleHub: Hub,\n /**\n * The time to wait in ms until the idle transaction will be finished. This timer is started each time\n * there are no active spans on this transaction.\n */\n private readonly _idleTimeout: number = TRACING_DEFAULTS.idleTimeout,\n /**\n * The final value in ms that a transaction cannot exceed\n */\n private readonly _finalTimeout: number = TRACING_DEFAULTS.finalTimeout,\n private readonly _heartbeatInterval: number = TRACING_DEFAULTS.heartbeatInterval,\n // Whether or not the transaction should put itself on the scope when it starts and pop itself off when it ends\n private readonly _onScope: boolean = false,\n ) {\n super(transactionContext, _idleHub);\n\n this.activities = {};\n this._heartbeatCounter = 0;\n this._finished = false;\n this._idleTimeoutCanceledPermanently = false;\n this._beforeFinishCallbacks = [];\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[4];\n\n if (_onScope) {\n // We set the transaction here on the scope so error events pick up the trace\n // context and attach it to the error.\n __DEBUG_BUILD__ && logger.log(`Setting idle transaction on scope. Span ID: ${this.spanId}`);\n _idleHub.configureScope(scope => scope.setSpan(this));\n }\n\n this._restartIdleTimeout();\n setTimeout(() => {\n if (!this._finished) {\n this.setStatus('deadline_exceeded');\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[3];\n this.finish();\n }\n }, this._finalTimeout);\n }\n\n /** {@inheritDoc} */\n public finish(endTimestamp: number = timestampInSeconds()): string | undefined {\n this._finished = true;\n this.activities = {};\n\n if (this.op === 'ui.action.click') {\n this.setTag(FINISH_REASON_TAG, this._finishReason);\n }\n\n if (this.spanRecorder) {\n __DEBUG_BUILD__ &&\n logger.log('[Tracing] finishing IdleTransaction', new Date(endTimestamp * 1000).toISOString(), this.op);\n\n for (const callback of this._beforeFinishCallbacks) {\n callback(this, endTimestamp);\n }\n\n this.spanRecorder.spans = this.spanRecorder.spans.filter((span: Span) => {\n // If we are dealing with the transaction itself, we just return it\n if (span.spanId === this.spanId) {\n return true;\n }\n\n // We cancel all pending spans with status \"cancelled\" to indicate the idle transaction was finished early\n if (!span.endTimestamp) {\n span.endTimestamp = endTimestamp;\n span.setStatus('cancelled');\n __DEBUG_BUILD__ &&\n logger.log('[Tracing] cancelling span since transaction ended early', JSON.stringify(span, undefined, 2));\n }\n\n const spanStartedBeforeTransactionFinish = span.startTimestamp < endTimestamp;\n\n // Add a delta with idle timeout so that we prevent false positives\n const timeoutWithMarginOfError = (this._finalTimeout + this._idleTimeout) / 1000;\n const spanEndedBeforeFinalTimeout = span.endTimestamp - this.startTimestamp < timeoutWithMarginOfError;\n\n if (__DEBUG_BUILD__) {\n const stringifiedSpan = JSON.stringify(span, undefined, 2);\n if (!spanStartedBeforeTransactionFinish) {\n logger.log('[Tracing] discarding Span since it happened after Transaction was finished', stringifiedSpan);\n } else if (!spanEndedBeforeFinalTimeout) {\n logger.log('[Tracing] discarding Span since it finished after Transaction final timeout', stringifiedSpan);\n }\n }\n\n return spanStartedBeforeTransactionFinish && spanEndedBeforeFinalTimeout;\n });\n\n __DEBUG_BUILD__ && logger.log('[Tracing] flushing IdleTransaction');\n } else {\n __DEBUG_BUILD__ && logger.log('[Tracing] No active IdleTransaction');\n }\n\n // if `this._onScope` is `true`, the transaction put itself on the scope when it started\n if (this._onScope) {\n const scope = this._idleHub.getScope();\n if (scope.getTransaction() === this) {\n scope.setSpan(undefined);\n }\n }\n\n return super.finish(endTimestamp);\n }\n\n /**\n * Register a callback function that gets excecuted before the transaction finishes.\n * Useful for cleanup or if you want to add any additional spans based on current context.\n *\n * This is exposed because users have no other way of running something before an idle transaction\n * finishes.\n */\n public registerBeforeFinishCallback(callback: BeforeFinishCallback): void {\n this._beforeFinishCallbacks.push(callback);\n }\n\n /**\n * @inheritDoc\n */\n public initSpanRecorder(maxlen?: number): void {\n if (!this.spanRecorder) {\n const pushActivity = (id: string): void => {\n if (this._finished) {\n return;\n }\n this._pushActivity(id);\n };\n const popActivity = (id: string): void => {\n if (this._finished) {\n return;\n }\n this._popActivity(id);\n };\n\n this.spanRecorder = new IdleTransactionSpanRecorder(pushActivity, popActivity, this.spanId, maxlen);\n\n // Start heartbeat so that transactions do not run forever.\n __DEBUG_BUILD__ && logger.log('Starting heartbeat');\n this._pingHeartbeat();\n }\n this.spanRecorder.add(this);\n }\n\n /**\n * Cancels the existing idle timeout, if there is one.\n * @param restartOnChildSpanChange Default is `true`.\n * If set to false the transaction will end\n * with the last child span.\n */\n public cancelIdleTimeout(\n endTimestamp?: Parameters<IdleTransaction['finish']>[0],\n {\n restartOnChildSpanChange,\n }: {\n restartOnChildSpanChange?: boolean;\n } = {\n restartOnChildSpanChange: true,\n },\n ): void {\n this._idleTimeoutCanceledPermanently = restartOnChildSpanChange === false;\n if (this._idleTimeoutID) {\n clearTimeout(this._idleTimeoutID);\n this._idleTimeoutID = undefined;\n\n if (Object.keys(this.activities).length === 0 && this._idleTimeoutCanceledPermanently) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[5];\n this.finish(endTimestamp);\n }\n }\n }\n\n /**\n * Temporary method used to externally set the transaction's `finishReason`\n *\n * ** WARNING**\n * This is for the purpose of experimentation only and will be removed in the near future, do not use!\n *\n * @internal\n *\n */\n public setFinishReason(reason: string): void {\n this._finishReason = reason;\n }\n\n /**\n * Restarts idle timeout, if there is no running idle timeout it will start one.\n */\n private _restartIdleTimeout(endTimestamp?: Parameters<IdleTransaction['finish']>[0]): void {\n this.cancelIdleTimeout();\n this._idleTimeoutID = setTimeout(() => {\n if (!this._finished && Object.keys(this.activities).length === 0) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[1];\n this.finish(endTimestamp);\n }\n }, this._idleTimeout);\n }\n\n /**\n * Start tracking a specific activity.\n * @param spanId The span id that represents the activity\n */\n private _pushActivity(spanId: string): void {\n this.cancelIdleTimeout(undefined, { restartOnChildSpanChange: !this._idleTimeoutCanceledPermanently });\n __DEBUG_BUILD__ && logger.log(`[Tracing] pushActivity: ${spanId}`);\n this.activities[spanId] = true;\n __DEBUG_BUILD__ && logger.log('[Tracing] new activities count', Object.keys(this.activities).length);\n }\n\n /**\n * Remove an activity from usage\n * @param spanId The span id that represents the activity\n */\n private _popActivity(spanId: string): void {\n if (this.activities[spanId]) {\n __DEBUG_BUILD__ && logger.log(`[Tracing] popActivity ${spanId}`);\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete this.activities[spanId];\n __DEBUG_BUILD__ && logger.log('[Tracing] new activities count', Object.keys(this.activities).length);\n }\n\n if (Object.keys(this.activities).length === 0) {\n const endTimestamp = timestampInSeconds();\n if (this._idleTimeoutCanceledPermanently) {\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[5];\n this.finish(endTimestamp);\n } else {\n // We need to add the timeout here to have the real endtimestamp of the transaction\n // Remember timestampInSeconds is in seconds, timeout is in ms\n this._restartIdleTimeout(endTimestamp + this._idleTimeout / 1000);\n }\n }\n }\n\n /**\n * Checks when entries of this.activities are not changing for 3 beats.\n * If this occurs we finish the transaction.\n */\n private _beat(): void {\n // We should not be running heartbeat if the idle transaction is finished.\n if (this._finished) {\n return;\n }\n\n const heartbeatString = Object.keys(this.activities).join('');\n\n if (heartbeatString === this._prevHeartbeatString) {\n this._heartbeatCounter++;\n } else {\n this._heartbeatCounter = 1;\n }\n\n this._prevHeartbeatString = heartbeatString;\n\n if (this._heartbeatCounter >= 3) {\n __DEBUG_BUILD__ && logger.log('[Tracing] Transaction finished because of no change for 3 heart beats');\n this.setStatus('deadline_exceeded');\n this._finishReason = IDLE_TRANSACTION_FINISH_REASONS[0];\n this.finish();\n } else {\n this._pingHeartbeat();\n }\n }\n\n /**\n * Pings the heartbeat\n */\n private _pingHeartbeat(): void {\n __DEBUG_BUILD__ && logger.log(`pinging Heartbeat -> current counter: ${this._heartbeatCounter}`);\n setTimeout(() => {\n this._beat();\n }, this._heartbeatInterval);\n }\n}\n", "import type { Options } from '@sentry/types';\n\nimport { getCurrentHub } from '../hub';\n\n// Treeshakable guard to remove all code related to tracing\ndeclare const __SENTRY_TRACING__: boolean | undefined;\n\n/**\n * Determines if tracing is currently enabled.\n *\n * Tracing is enabled when at least one of `tracesSampleRate` and `tracesSampler` is defined in the SDK config.\n */\nexport function hasTracingEnabled(\n maybeOptions?: Pick<Options, 'tracesSampleRate' | 'tracesSampler' | 'enableTracing'> | undefined,\n): boolean {\n if (typeof __SENTRY_TRACING__ === 'boolean' && !__SENTRY_TRACING__) {\n return false;\n }\n\n const client = getCurrentHub().getClient();\n const options = maybeOptions || (client && client.getOptions());\n return !!options && (options.enableTracing || 'tracesSampleRate' in options || 'tracesSampler' in options);\n}\n", "import type { Options, SamplingContext } from '@sentry/types';\nimport { isNaN, logger } from '@sentry/utils';\n\nimport { hasTracingEnabled } from '../utils/hasTracingEnabled';\nimport type { Transaction } from './transaction';\n\n/**\n * Makes a sampling decision for the given transaction and stores it on the transaction.\n *\n * Called every time a transaction is created. Only transactions which emerge with a `sampled` value of `true` will be\n * sent to Sentry.\n *\n * This method muttes the given `transaction` and will set the `sampled` value on it.\n * It returns the same transaction, for convenience.\n */\nexport function sampleTransaction<T extends Transaction>(\n transaction: T,\n options: Pick<Options, 'tracesSampleRate' | 'tracesSampler' | 'enableTracing'>,\n samplingContext: SamplingContext,\n): T {\n // nothing to do if tracing is not enabled\n if (!hasTracingEnabled(options)) {\n transaction.sampled = false;\n return transaction;\n }\n\n // if the user has forced a sampling decision by passing a `sampled` value in their transaction context, go with that\n if (transaction.sampled !== undefined) {\n transaction.setMetadata({\n sampleRate: Number(transaction.sampled),\n });\n return transaction;\n }\n\n // we would have bailed already if neither `tracesSampler` nor `tracesSampleRate` nor `enableTracing` were defined, so one of these should\n // work; prefer the hook if so\n let sampleRate;\n if (typeof options.tracesSampler === 'function') {\n sampleRate = options.tracesSampler(samplingContext);\n transaction.setMetadata({\n sampleRate: Number(sampleRate),\n });\n } else if (samplingContext.parentSampled !== undefined) {\n sampleRate = samplingContext.parentSampled;\n } else if (typeof options.tracesSampleRate !== 'undefined') {\n sampleRate = options.tracesSampleRate;\n transaction.setMetadata({\n sampleRate: Number(sampleRate),\n });\n } else {\n // When `enableTracing === true`, we use a sample rate of 100%\n sampleRate = 1;\n transaction.setMetadata({\n sampleRate,\n });\n }\n\n // Since this is coming from the user (or from a function provided by the user), who knows what we might get. (The\n // only valid values are booleans or numbers between 0 and 1.)\n if (!isValidSampleRate(sampleRate)) {\n __DEBUG_BUILD__ && logger.warn('[Tracing] Discarding transaction because of invalid sample rate.');\n transaction.sampled = false;\n return transaction;\n }\n\n // if the function returned 0 (or false), or if `tracesSampleRate` is 0, it's a sign the transaction should be dropped\n if (!sampleRate) {\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Discarding transaction because ${\n typeof options.tracesSampler === 'function'\n ? 'tracesSampler returned 0 or false'\n : 'a negative sampling decision was inherited or tracesSampleRate is set to 0'\n }`,\n );\n transaction.sampled = false;\n return transaction;\n }\n\n // Now we roll the dice. Math.random is inclusive of 0, but not of 1, so strict < is safe here. In case sampleRate is\n // a boolean, the < comparison will cause it to be automatically cast to 1 if it's true and 0 if it's false.\n transaction.sampled = Math.random() < (sampleRate as number | boolean);\n\n // if we're not going to keep it, we're done\n if (!transaction.sampled) {\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Discarding transaction because it's not included in the random sample (sampling rate = ${Number(\n sampleRate,\n )})`,\n );\n return transaction;\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] starting ${transaction.op} transaction - ${transaction.name}`);\n return transaction;\n}\n\n/**\n * Checks the given sample rate to make sure it is valid type and value (a boolean, or a number between 0 and 1).\n */\nfunction isValidSampleRate(rate: unknown): boolean {\n // we need to check NaN explicitly because it's of type 'number' and therefore wouldn't get caught by this typecheck\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (isNaN(rate) || !(typeof rate === 'number' || typeof rate === 'boolean')) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `[Tracing] Given sample rate is invalid. Sample rate must be a boolean or a number between 0 and 1. Got ${JSON.stringify(\n rate,\n )} of type ${JSON.stringify(typeof rate)}.`,\n );\n return false;\n }\n\n // in case sampleRate is a boolean, it will get automatically cast to 1 if it's true and 0 if it's false\n if (rate < 0 || rate > 1) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Given sample rate is invalid. Sample rate must be between 0 and 1. Got ${rate}.`);\n return false;\n }\n return true;\n}\n", "import type { ClientOptions, CustomSamplingContext, TransactionContext } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport type { Hub } from '../hub';\nimport { getMainCarrier } from '../hub';\nimport { registerErrorInstrumentation } from './errors';\nimport { IdleTransaction } from './idletransaction';\nimport { sampleTransaction } from './sampling';\nimport { Transaction } from './transaction';\n\n/** Returns all trace headers that are currently on the top scope. */\nfunction traceHeaders(this: Hub): { [key: string]: string } {\n const scope = this.getScope();\n const span = scope.getSpan();\n\n return span\n ? {\n 'sentry-trace': span.toTraceparent(),\n }\n : {};\n}\n\n/**\n * Creates a new transaction and adds a sampling decision if it doesn't yet have one.\n *\n * The Hub.startTransaction method delegates to this method to do its work, passing the Hub instance in as `this`, as if\n * it had been called on the hub directly. Exists as a separate function so that it can be injected into the class as an\n * \"extension method.\"\n *\n * @param this: The Hub starting the transaction\n * @param transactionContext: Data used to configure the transaction\n * @param CustomSamplingContext: Optional data to be provided to the `tracesSampler` function (if any)\n *\n * @returns The new transaction\n *\n * @see {@link Hub.startTransaction}\n */\nfunction _startTransaction(\n this: Hub,\n transactionContext: TransactionContext,\n customSamplingContext?: CustomSamplingContext,\n): Transaction {\n const client = this.getClient();\n const options: Partial<ClientOptions> = (client && client.getOptions()) || {};\n\n const configInstrumenter = options.instrumenter || 'sentry';\n const transactionInstrumenter = transactionContext.instrumenter || 'sentry';\n\n if (configInstrumenter !== transactionInstrumenter) {\n __DEBUG_BUILD__ &&\n logger.error(\n `A transaction was started with instrumenter=\\`${transactionInstrumenter}\\`, but the SDK is configured with the \\`${configInstrumenter}\\` instrumenter.\nThe transaction will not be sampled. Please use the ${configInstrumenter} instrumentation to start transactions.`,\n );\n\n transactionContext.sampled = false;\n }\n\n let transaction = new Transaction(transactionContext, this);\n transaction = sampleTransaction(transaction, options, {\n parentSampled: transactionContext.parentSampled,\n transactionContext,\n ...customSamplingContext,\n });\n if (transaction.sampled) {\n transaction.initSpanRecorder(options._experiments && (options._experiments.maxSpans as number));\n }\n if (client && client.emit) {\n client.emit('startTransaction', transaction);\n }\n return transaction;\n}\n\n/**\n * Create new idle transaction.\n */\nexport function startIdleTransaction(\n hub: Hub,\n transactionContext: TransactionContext,\n idleTimeout: number,\n finalTimeout: number,\n onScope?: boolean,\n customSamplingContext?: CustomSamplingContext,\n heartbeatInterval?: number,\n): IdleTransaction {\n const client = hub.getClient();\n const options: Partial<ClientOptions> = (client && client.getOptions()) || {};\n\n let transaction = new IdleTransaction(transactionContext, hub, idleTimeout, finalTimeout, heartbeatInterval, onScope);\n transaction = sampleTransaction(transaction, options, {\n parentSampled: transactionContext.parentSampled,\n transactionContext,\n ...customSamplingContext,\n });\n if (transaction.sampled) {\n transaction.initSpanRecorder(options._experiments && (options._experiments.maxSpans as number));\n }\n if (client && client.emit) {\n client.emit('startTransaction', transaction);\n }\n return transaction;\n}\n\n/**\n * Adds tracing extensions to the global hub.\n */\nexport function addTracingExtensions(): void {\n const carrier = getMainCarrier();\n if (!carrier.__SENTRY__) {\n return;\n }\n carrier.__SENTRY__.extensions = carrier.__SENTRY__.extensions || {};\n if (!carrier.__SENTRY__.extensions.startTransaction) {\n carrier.__SENTRY__.extensions.startTransaction = _startTransaction;\n }\n if (!carrier.__SENTRY__.extensions.traceHeaders) {\n carrier.__SENTRY__.extensions.traceHeaders = traceHeaders;\n }\n\n registerErrorInstrumentation();\n}\n", "import type {\n Breadcrumb,\n CaptureContext,\n CheckIn,\n CustomSamplingContext,\n Event,\n EventHint,\n Extra,\n Extras,\n FinishedCheckIn,\n MonitorConfig,\n Primitive,\n Severity,\n SeverityLevel,\n TransactionContext,\n User,\n} from '@sentry/types';\nimport { isThenable, logger, timestampInSeconds, uuid4 } from '@sentry/utils';\n\nimport type { Hub } from './hub';\nimport { getCurrentHub } from './hub';\nimport type { Scope } from './scope';\n\n// Note: All functions in this file are typed with a return value of `ReturnType<Hub[HUB_FUNCTION]>`,\n// where HUB_FUNCTION is some method on the Hub class.\n//\n// This is done to make sure the top level SDK methods stay in sync with the hub methods.\n// Although every method here has an explicit return type, some of them (that map to void returns) do not\n// contain `return` keywords. This is done to save on bundle size, as `return` is not minifiable.\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception An exception-like object.\n * @param captureContext Additional scope data to apply to exception event.\n * @returns The generated eventId.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\nexport function captureException(exception: any, captureContext?: CaptureContext): ReturnType<Hub['captureException']> {\n return getCurrentHub().captureException(exception, { captureContext });\n}\n\n/**\n * Captures a message event and sends it to Sentry.\n *\n * @param message The message to send to Sentry.\n * @param Severity Define the level of the message.\n * @returns The generated eventId.\n */\nexport function captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n captureContext?: CaptureContext | Severity | SeverityLevel,\n): ReturnType<Hub['captureMessage']> {\n // This is necessary to provide explicit scopes upgrade, without changing the original\n // arity of the `captureMessage(message, level)` method.\n const level = typeof captureContext === 'string' ? captureContext : undefined;\n const context = typeof captureContext !== 'string' ? { captureContext } : undefined;\n return getCurrentHub().captureMessage(message, level, context);\n}\n\n/**\n * Captures a manually created event and sends it to Sentry.\n *\n * @param event The event to send to Sentry.\n * @returns The generated eventId.\n */\nexport function captureEvent(event: Event, hint?: EventHint): ReturnType<Hub['captureEvent']> {\n return getCurrentHub().captureEvent(event, hint);\n}\n\n/**\n * Callback to set context information onto the scope.\n * @param callback Callback function that receives Scope.\n */\nexport function configureScope(callback: (scope: Scope) => void): ReturnType<Hub['configureScope']> {\n getCurrentHub().configureScope(callback);\n}\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on\n * user's actions prior to an error or crash.\n *\n * @param breadcrumb The breadcrumb to record.\n */\nexport function addBreadcrumb(breadcrumb: Breadcrumb): ReturnType<Hub['addBreadcrumb']> {\n getCurrentHub().addBreadcrumb(breadcrumb);\n}\n\n/**\n * Sets context data with the given name.\n * @param name of the context\n * @param context Any kind of data. This data will be normalized.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function setContext(name: string, context: { [key: string]: any } | null): ReturnType<Hub['setContext']> {\n getCurrentHub().setContext(name, context);\n}\n\n/**\n * Set an object that will be merged sent as extra data with the event.\n * @param extras Extras object to merge into current context.\n */\nexport function setExtras(extras: Extras): ReturnType<Hub['setExtras']> {\n getCurrentHub().setExtras(extras);\n}\n\n/**\n * Set key:value that will be sent as extra data with the event.\n * @param key String of extra\n * @param extra Any kind of data. This data will be normalized.\n */\nexport function setExtra(key: string, extra: Extra): ReturnType<Hub['setExtra']> {\n getCurrentHub().setExtra(key, extra);\n}\n\n/**\n * Set an object that will be merged sent as tags data with the event.\n * @param tags Tags context object to merge into current context.\n */\nexport function setTags(tags: { [key: string]: Primitive }): ReturnType<Hub['setTags']> {\n getCurrentHub().setTags(tags);\n}\n\n/**\n * Set key:value that will be sent as tags data with the event.\n *\n * Can also be used to unset a tag, by passing `undefined`.\n *\n * @param key String key of tag\n * @param value Value of tag\n */\nexport function setTag(key: string, value: Primitive): ReturnType<Hub['setTag']> {\n getCurrentHub().setTag(key, value);\n}\n\n/**\n * Updates user context information for future events.\n *\n * @param user User context object to be set in the current context. Pass `null` to unset the user.\n */\nexport function setUser(user: User | null): ReturnType<Hub['setUser']> {\n getCurrentHub().setUser(user);\n}\n\n/**\n * Creates a new scope with and executes the given operation within.\n * The scope is automatically removed once the operation\n * finishes or throws.\n *\n * This is essentially a convenience function for:\n *\n * pushScope();\n * callback();\n * popScope();\n *\n * @param callback that will be enclosed into push/popScope.\n */\nexport function withScope(callback: (scope: Scope) => void): ReturnType<Hub['withScope']> {\n getCurrentHub().withScope(callback);\n}\n\n/**\n * Starts a new `Transaction` and returns it. This is the entry point to manual tracing instrumentation.\n *\n * A tree structure can be built by adding child spans to the transaction, and child spans to other spans. To start a\n * new child span within the transaction or any span, call the respective `.startChild()` method.\n *\n * Every child span must be finished before the transaction is finished, otherwise the unfinished spans are discarded.\n *\n * The transaction must be finished with a call to its `.finish()` method, at which point the transaction with all its\n * finished child spans will be sent to Sentry.\n *\n * NOTE: This function should only be used for *manual* instrumentation. Auto-instrumentation should call\n * `startTransaction` directly on the hub.\n *\n * @param context Properties of the new `Transaction`.\n * @param customSamplingContext Information given to the transaction sampling function (along with context-dependent\n * default values). See {@link Options.tracesSampler}.\n *\n * @returns The transaction which was just started\n */\nexport function startTransaction(\n context: TransactionContext,\n customSamplingContext?: CustomSamplingContext,\n): ReturnType<Hub['startTransaction']> {\n return getCurrentHub().startTransaction({ ...context }, customSamplingContext);\n}\n\n/**\n * Create a cron monitor check in and send it to Sentry.\n *\n * @param checkIn An object that describes a check in.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nexport function captureCheckIn(checkIn: CheckIn, upsertMonitorConfig?: MonitorConfig): string {\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const client = hub.getClient();\n if (!client) {\n __DEBUG_BUILD__ && logger.warn('Cannot capture check-in. No client defined.');\n } else if (!client.captureCheckIn) {\n __DEBUG_BUILD__ && logger.warn('Cannot capture check-in. Client does not support sending check-ins.');\n } else {\n return client.captureCheckIn(checkIn, upsertMonitorConfig, scope);\n }\n\n return uuid4();\n}\n\n/**\n * Wraps a callback with a cron monitor check in. The check in will be sent to Sentry when the callback finishes.\n *\n * @param monitorSlug The distinct slug of the monitor.\n * @param upsertMonitorConfig An optional object that describes a monitor config. Use this if you want\n * to create a monitor automatically when sending a check in.\n */\nexport function withMonitor<T>(\n monitorSlug: CheckIn['monitorSlug'],\n callback: () => T,\n upsertMonitorConfig?: MonitorConfig,\n): T {\n const checkInId = captureCheckIn({ monitorSlug, status: 'in_progress' }, upsertMonitorConfig);\n const now = timestampInSeconds();\n\n function finishCheckIn(status: FinishedCheckIn['status']): void {\n captureCheckIn({ monitorSlug, status, checkInId, duration: timestampInSeconds() - now });\n }\n\n let maybePromiseResult: T;\n try {\n maybePromiseResult = callback();\n } catch (e) {\n finishCheckIn('error');\n throw e;\n }\n\n if (isThenable(maybePromiseResult)) {\n Promise.resolve(maybePromiseResult).then(\n () => {\n finishCheckIn('ok');\n },\n () => {\n finishCheckIn('error');\n },\n );\n } else {\n finishCheckIn('ok');\n }\n\n return maybePromiseResult;\n}\n\n/**\n * Call `flush()` on the current client, if there is one. See {@link Client.flush}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue. Omitting this parameter will cause\n * the client to wait until all events are sent before resolving the promise.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nexport async function flush(timeout?: number): Promise<boolean> {\n const client = getCurrentHub().getClient();\n if (client) {\n return client.flush(timeout);\n }\n __DEBUG_BUILD__ && logger.warn('Cannot flush events. No client defined.');\n return Promise.resolve(false);\n}\n\n/**\n * Call `close()` on the current client, if there is one. See {@link Client.close}.\n *\n * @param timeout Maximum time in ms the client should wait to flush its event queue before shutting down. Omitting this\n * parameter will cause the client to wait until all events are sent before disabling itself.\n * @returns A promise which resolves to `true` if the queue successfully drains before the timeout, or `false` if it\n * doesn't (or if there's no client defined).\n */\nexport async function close(timeout?: number): Promise<boolean> {\n const client = getCurrentHub().getClient();\n if (client) {\n return client.close(timeout);\n }\n __DEBUG_BUILD__ && logger.warn('Cannot flush events and disable SDK. No client defined.');\n return Promise.resolve(false);\n}\n\n/**\n * This is the getter for lastEventId.\n *\n * @returns The last event id of a captured event.\n */\nexport function lastEventId(): string | undefined {\n return getCurrentHub().lastEventId();\n}\n", "import type { ClientOptions, DsnComponents, DsnLike, SdkInfo } from '@sentry/types';\nimport { dsnToString, makeDsn, urlEncode } from '@sentry/utils';\n\nconst SENTRY_API_VERSION = '7';\n\n/** Returns the prefix to construct Sentry ingestion API endpoints. */\nfunction getBaseApiEndpoint(dsn: DsnComponents): string {\n const protocol = dsn.protocol ? `${dsn.protocol}:` : '';\n const port = dsn.port ? `:${dsn.port}` : '';\n return `${protocol}//${dsn.host}${port}${dsn.path ? `/${dsn.path}` : ''}/api/`;\n}\n\n/** Returns the ingest API endpoint for target. */\nfunction _getIngestEndpoint(dsn: DsnComponents): string {\n return `${getBaseApiEndpoint(dsn)}${dsn.projectId}/envelope/`;\n}\n\n/** Returns a URL-encoded string with auth config suitable for a query string. */\nfunction _encodedAuth(dsn: DsnComponents, sdkInfo: SdkInfo | undefined): string {\n return urlEncode({\n // We send only the minimum set of required information. See\n // https://github.com/getsentry/sentry-javascript/issues/2572.\n sentry_key: dsn.publicKey,\n sentry_version: SENTRY_API_VERSION,\n ...(sdkInfo && { sentry_client: `${sdkInfo.name}/${sdkInfo.version}` }),\n });\n}\n\n/**\n * Returns the envelope endpoint URL with auth in the query string.\n *\n * Sending auth as part of the query string and not as custom HTTP headers avoids CORS preflight requests.\n */\nexport function getEnvelopeEndpointWithUrlEncodedAuth(\n dsn: DsnComponents,\n // TODO (v8): Remove `tunnelOrOptions` in favor of `options`, and use the substitute code below\n // options: ClientOptions = {} as ClientOptions,\n tunnelOrOptions: string | ClientOptions = {} as ClientOptions,\n): string {\n // TODO (v8): Use this code instead\n // const { tunnel, _metadata = {} } = options;\n // return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, _metadata.sdk)}`;\n\n const tunnel = typeof tunnelOrOptions === 'string' ? tunnelOrOptions : tunnelOrOptions.tunnel;\n const sdkInfo =\n typeof tunnelOrOptions === 'string' || !tunnelOrOptions._metadata ? undefined : tunnelOrOptions._metadata.sdk;\n\n return tunnel ? tunnel : `${_getIngestEndpoint(dsn)}?${_encodedAuth(dsn, sdkInfo)}`;\n}\n\n/** Returns the url to the report dialog endpoint. */\nexport function getReportDialogEndpoint(\n dsnLike: DsnLike,\n dialogOptions: {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n user?: { name?: string; email?: string };\n },\n): string {\n const dsn = makeDsn(dsnLike);\n if (!dsn) {\n return '';\n }\n\n const endpoint = `${getBaseApiEndpoint(dsn)}embed/error-page/`;\n\n let encodedOptions = `dsn=${dsnToString(dsn)}`;\n for (const key in dialogOptions) {\n if (key === 'dsn') {\n continue;\n }\n\n if (key === 'user') {\n const user = dialogOptions.user;\n if (!user) {\n continue;\n }\n if (user.name) {\n encodedOptions += `&name=${encodeURIComponent(user.name)}`;\n }\n if (user.email) {\n encodedOptions += `&email=${encodeURIComponent(user.email)}`;\n }\n } else {\n encodedOptions += `&${encodeURIComponent(key)}=${encodeURIComponent(dialogOptions[key] as string)}`;\n }\n }\n\n return `${endpoint}?${encodedOptions}`;\n}\n", "import type {\n DsnComponents,\n Event,\n EventEnvelope,\n EventItem,\n SdkInfo,\n SdkMetadata,\n Session,\n SessionAggregates,\n SessionEnvelope,\n SessionItem,\n} from '@sentry/types';\nimport {\n createEnvelope,\n createEventEnvelopeHeaders,\n dsnToString,\n getSdkMetadataForEnvelopeHeader,\n} from '@sentry/utils';\n\n/**\n * Apply SdkInfo (name, version, packages, integrations) to the corresponding event key.\n * Merge with existing data if any.\n **/\nfunction enhanceEventWithSdkInfo(event: Event, sdkInfo?: SdkInfo): Event {\n if (!sdkInfo) {\n return event;\n }\n event.sdk = event.sdk || {};\n event.sdk.name = event.sdk.name || sdkInfo.name;\n event.sdk.version = event.sdk.version || sdkInfo.version;\n event.sdk.integrations = [...(event.sdk.integrations || []), ...(sdkInfo.integrations || [])];\n event.sdk.packages = [...(event.sdk.packages || []), ...(sdkInfo.packages || [])];\n return event;\n}\n\n/** Creates an envelope from a Session */\nexport function createSessionEnvelope(\n session: Session | SessionAggregates,\n dsn?: DsnComponents,\n metadata?: SdkMetadata,\n tunnel?: string,\n): SessionEnvelope {\n const sdkInfo = getSdkMetadataForEnvelopeHeader(metadata);\n const envelopeHeaders = {\n sent_at: new Date().toISOString(),\n ...(sdkInfo && { sdk: sdkInfo }),\n ...(!!tunnel && dsn && { dsn: dsnToString(dsn) }),\n };\n\n const envelopeItem: SessionItem =\n 'aggregates' in session ? [{ type: 'sessions' }, session] : [{ type: 'session' }, session.toJSON()];\n\n return createEnvelope<SessionEnvelope>(envelopeHeaders, [envelopeItem]);\n}\n\n/**\n * Create an Envelope from an event.\n */\nexport function createEventEnvelope(\n event: Event,\n dsn?: DsnComponents,\n metadata?: SdkMetadata,\n tunnel?: string,\n): EventEnvelope {\n const sdkInfo = getSdkMetadataForEnvelopeHeader(metadata);\n\n /*\n Note: Due to TS, event.type may be `replay_event`, theoretically.\n In practice, we never call `createEventEnvelope` with `replay_event` type,\n and we'd have to adjut a looot of types to make this work properly.\n We want to avoid casting this around, as that could lead to bugs (e.g. when we add another type)\n So the safe choice is to really guard against the replay_event type here.\n */\n const eventType = event.type && event.type !== 'replay_event' ? event.type : 'event';\n\n enhanceEventWithSdkInfo(event, metadata && metadata.sdk);\n\n const envelopeHeaders = createEventEnvelopeHeaders(event, sdkInfo, tunnel, dsn);\n\n // Prevent this data (which, if it exists, was used in earlier steps in the processing pipeline) from being sent to\n // sentry. (Note: Our use of this property comes and goes with whatever we might be debugging, whatever hacks we may\n // have temporarily added, etc. Even if we don't happen to be using it at some point in the future, let's not get rid\n // of this `delete`, lest we miss putting it back in the next time the property is in use.)\n delete event.sdkProcessingMetadata;\n\n const eventItem: EventItem = [{ type: eventType }, event];\n return createEnvelope<EventEnvelope>(envelopeHeaders, [eventItem]);\n}\n", "import type { Client, Event, EventHint, Integration, Options } from '@sentry/types';\nimport { arrayify, logger } from '@sentry/utils';\n\nimport { addGlobalEventProcessor } from './eventProcessors';\nimport { getCurrentHub } from './hub';\n\ndeclare module '@sentry/types' {\n interface Integration {\n isDefaultInstance?: boolean;\n }\n}\n\nexport const installedIntegrations: string[] = [];\n\n/** Map of integrations assigned to a client */\nexport type IntegrationIndex = {\n [key: string]: Integration;\n};\n\n/**\n * Remove duplicates from the given array, preferring the last instance of any duplicate. Not guaranteed to\n * preseve the order of integrations in the array.\n *\n * @private\n */\nfunction filterDuplicates(integrations: Integration[]): Integration[] {\n const integrationsByName: { [key: string]: Integration } = {};\n\n integrations.forEach(currentInstance => {\n const { name } = currentInstance;\n\n const existingInstance = integrationsByName[name];\n\n // We want integrations later in the array to overwrite earlier ones of the same type, except that we never want a\n // default instance to overwrite an existing user instance\n if (existingInstance && !existingInstance.isDefaultInstance && currentInstance.isDefaultInstance) {\n return;\n }\n\n integrationsByName[name] = currentInstance;\n });\n\n return Object.keys(integrationsByName).map(k => integrationsByName[k]);\n}\n\n/** Gets integrations to install */\nexport function getIntegrationsToSetup(options: Options): Integration[] {\n const defaultIntegrations = options.defaultIntegrations || [];\n const userIntegrations = options.integrations;\n\n // We flag default instances, so that later we can tell them apart from any user-created instances of the same class\n defaultIntegrations.forEach(integration => {\n integration.isDefaultInstance = true;\n });\n\n let integrations: Integration[];\n\n if (Array.isArray(userIntegrations)) {\n integrations = [...defaultIntegrations, ...userIntegrations];\n } else if (typeof userIntegrations === 'function') {\n integrations = arrayify(userIntegrations(defaultIntegrations));\n } else {\n integrations = defaultIntegrations;\n }\n\n const finalIntegrations = filterDuplicates(integrations);\n\n // The `Debug` integration prints copies of the `event` and `hint` which will be passed to `beforeSend` or\n // `beforeSendTransaction`. It therefore has to run after all other integrations, so that the changes of all event\n // processors will be reflected in the printed values. For lack of a more elegant way to guarantee that, we therefore\n // locate it and, assuming it exists, pop it out of its current spot and shove it onto the end of the array.\n const debugIndex = findIndex(finalIntegrations, integration => integration.name === 'Debug');\n if (debugIndex !== -1) {\n const [debugInstance] = finalIntegrations.splice(debugIndex, 1);\n finalIntegrations.push(debugInstance);\n }\n\n return finalIntegrations;\n}\n\n/**\n * Given a list of integration instances this installs them all. When `withDefaults` is set to `true` then all default\n * integrations are added unless they were already provided before.\n * @param integrations array of integration instances\n * @param withDefault should enable default integrations\n */\nexport function setupIntegrations(client: Client, integrations: Integration[]): IntegrationIndex {\n const integrationIndex: IntegrationIndex = {};\n\n integrations.forEach(integration => {\n // guard against empty provided integrations\n if (integration) {\n setupIntegration(client, integration, integrationIndex);\n }\n });\n\n return integrationIndex;\n}\n\n/** Setup a single integration. */\nexport function setupIntegration(client: Client, integration: Integration, integrationIndex: IntegrationIndex): void {\n integrationIndex[integration.name] = integration;\n\n if (installedIntegrations.indexOf(integration.name) === -1) {\n integration.setupOnce(addGlobalEventProcessor, getCurrentHub);\n installedIntegrations.push(integration.name);\n }\n\n if (client.on && typeof integration.preprocessEvent === 'function') {\n const callback = integration.preprocessEvent.bind(integration) as typeof integration.preprocessEvent;\n client.on('preprocessEvent', (event, hint) => callback(event, hint, client));\n }\n\n if (client.addEventProcessor && typeof integration.processEvent === 'function') {\n const callback = integration.processEvent.bind(integration) as typeof integration.processEvent;\n\n const processor = Object.assign((event: Event, hint: EventHint) => callback(event, hint, client), {\n id: integration.name,\n });\n\n client.addEventProcessor(processor);\n }\n\n __DEBUG_BUILD__ && logger.log(`Integration installed: ${integration.name}`);\n}\n\n/** Add an integration to the current hub's client. */\nexport function addIntegration(integration: Integration): void {\n const client = getCurrentHub().getClient();\n\n if (!client || !client.addIntegration) {\n __DEBUG_BUILD__ && logger.warn(`Cannot add integration \"${integration.name}\" because no SDK Client is available.`);\n return;\n }\n\n client.addIntegration(integration);\n}\n\n// Polyfill for Array.findIndex(), which is not supported in ES5\nfunction findIndex<T>(arr: T[], callback: (item: T) => boolean): number {\n for (let i = 0; i < arr.length; i++) {\n if (callback(arr[i]) === true) {\n return i;\n }\n }\n\n return -1;\n}\n", "import type { Client, ClientOptions, Event, EventHint, StackFrame, StackParser } from '@sentry/types';\nimport { dateTimestampInSeconds, GLOBAL_OBJ, normalize, resolvedSyncPromise, truncate, uuid4 } from '@sentry/utils';\n\nimport { DEFAULT_ENVIRONMENT } from '../constants';\nimport { getGlobalEventProcessors, notifyEventProcessors } from '../eventProcessors';\nimport { Scope } from '../scope';\n\n/**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * Note: This also triggers callbacks for `addGlobalEventProcessor`, but not `beforeSend`.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n * @hidden\n */\nexport function prepareEvent(\n options: ClientOptions,\n event: Event,\n hint: EventHint,\n scope?: Scope,\n client?: Client,\n): PromiseLike<Event | null> {\n const { normalizeDepth = 3, normalizeMaxBreadth = 1_000 } = options;\n const prepared: Event = {\n ...event,\n event_id: event.event_id || hint.event_id || uuid4(),\n timestamp: event.timestamp || dateTimestampInSeconds(),\n };\n const integrations = hint.integrations || options.integrations.map(i => i.name);\n\n applyClientOptions(prepared, options);\n applyIntegrationsMetadata(prepared, integrations);\n\n // Only put debug IDs onto frames for error events.\n if (event.type === undefined) {\n applyDebugIds(prepared, options.stackParser);\n }\n\n // If we have scope given to us, use it as the base for further modifications.\n // This allows us to prevent unnecessary copying of data if `captureContext` is not provided.\n let finalScope = scope;\n if (hint.captureContext) {\n finalScope = Scope.clone(finalScope).update(hint.captureContext);\n }\n\n // We prepare the result here with a resolved Event.\n let result = resolvedSyncPromise<Event | null>(prepared);\n\n const clientEventProcessors = client && client.getEventProcessors ? client.getEventProcessors() : [];\n\n // This should be the last thing called, since we want that\n // {@link Hub.addEventProcessor} gets the finished prepared event.\n //\n // We need to check for the existence of `finalScope.getAttachments`\n // because `getAttachments` can be undefined if users are using an older version\n // of `@sentry/core` that does not have the `getAttachments` method.\n // See: https://github.com/getsentry/sentry-javascript/issues/5229\n if (finalScope) {\n // Collect attachments from the hint and scope\n if (finalScope.getAttachments) {\n const attachments = [...(hint.attachments || []), ...finalScope.getAttachments()];\n\n if (attachments.length) {\n hint.attachments = attachments;\n }\n }\n\n // In case we have a hub we reassign it.\n result = finalScope.applyToEvent(prepared, hint, clientEventProcessors);\n } else {\n // Apply client & global event processors even if there is no scope\n // TODO (v8): Update the order to be Global > Client\n result = notifyEventProcessors([...clientEventProcessors, ...getGlobalEventProcessors()], prepared, hint);\n }\n\n return result.then(evt => {\n if (evt) {\n // We apply the debug_meta field only after all event processors have ran, so that if any event processors modified\n // file names (e.g.the RewriteFrames integration) the filename -> debug ID relationship isn't destroyed.\n // This should not cause any PII issues, since we're only moving data that is already on the event and not adding\n // any new data\n applyDebugMeta(evt);\n }\n\n if (typeof normalizeDepth === 'number' && normalizeDepth > 0) {\n return normalizeEvent(evt, normalizeDepth, normalizeMaxBreadth);\n }\n return evt;\n });\n}\n\n/**\n * Enhances event using the client configuration.\n * It takes care of all \"static\" values like environment, release and `dist`,\n * as well as truncating overly long values.\n * @param event event instance to be enhanced\n */\nfunction applyClientOptions(event: Event, options: ClientOptions): void {\n const { environment, release, dist, maxValueLength = 250 } = options;\n\n if (!('environment' in event)) {\n event.environment = 'environment' in options ? environment : DEFAULT_ENVIRONMENT;\n }\n\n if (event.release === undefined && release !== undefined) {\n event.release = release;\n }\n\n if (event.dist === undefined && dist !== undefined) {\n event.dist = dist;\n }\n\n if (event.message) {\n event.message = truncate(event.message, maxValueLength);\n }\n\n const exception = event.exception && event.exception.values && event.exception.values[0];\n if (exception && exception.value) {\n exception.value = truncate(exception.value, maxValueLength);\n }\n\n const request = event.request;\n if (request && request.url) {\n request.url = truncate(request.url, maxValueLength);\n }\n}\n\nconst debugIdStackParserCache = new WeakMap<StackParser, Map<string, StackFrame[]>>();\n\n/**\n * Puts debug IDs into the stack frames of an error event.\n */\nexport function applyDebugIds(event: Event, stackParser: StackParser): void {\n const debugIdMap = GLOBAL_OBJ._sentryDebugIds;\n\n if (!debugIdMap) {\n return;\n }\n\n let debugIdStackFramesCache: Map<string, StackFrame[]>;\n const cachedDebugIdStackFrameCache = debugIdStackParserCache.get(stackParser);\n if (cachedDebugIdStackFrameCache) {\n debugIdStackFramesCache = cachedDebugIdStackFrameCache;\n } else {\n debugIdStackFramesCache = new Map<string, StackFrame[]>();\n debugIdStackParserCache.set(stackParser, debugIdStackFramesCache);\n }\n\n // Build a map of filename -> debug_id\n const filenameDebugIdMap = Object.keys(debugIdMap).reduce<Record<string, string>>((acc, debugIdStackTrace) => {\n let parsedStack: StackFrame[];\n const cachedParsedStack = debugIdStackFramesCache.get(debugIdStackTrace);\n if (cachedParsedStack) {\n parsedStack = cachedParsedStack;\n } else {\n parsedStack = stackParser(debugIdStackTrace);\n debugIdStackFramesCache.set(debugIdStackTrace, parsedStack);\n }\n\n for (let i = parsedStack.length - 1; i >= 0; i--) {\n const stackFrame = parsedStack[i];\n if (stackFrame.filename) {\n acc[stackFrame.filename] = debugIdMap[debugIdStackTrace];\n break;\n }\n }\n return acc;\n }, {});\n\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n event!.exception!.values!.forEach(exception => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n exception.stacktrace!.frames!.forEach(frame => {\n if (frame.filename) {\n frame.debug_id = filenameDebugIdMap[frame.filename];\n }\n });\n });\n } catch (e) {\n // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n }\n}\n\n/**\n * Moves debug IDs from the stack frames of an error event into the debug_meta field.\n */\nexport function applyDebugMeta(event: Event): void {\n // Extract debug IDs and filenames from the stack frames on the event.\n const filenameDebugIdMap: Record<string, string> = {};\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n event.exception!.values!.forEach(exception => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n exception.stacktrace!.frames!.forEach(frame => {\n if (frame.debug_id) {\n if (frame.abs_path) {\n filenameDebugIdMap[frame.abs_path] = frame.debug_id;\n } else if (frame.filename) {\n filenameDebugIdMap[frame.filename] = frame.debug_id;\n }\n delete frame.debug_id;\n }\n });\n });\n } catch (e) {\n // To save bundle size we're just try catching here instead of checking for the existence of all the different objects.\n }\n\n if (Object.keys(filenameDebugIdMap).length === 0) {\n return;\n }\n\n // Fill debug_meta information\n event.debug_meta = event.debug_meta || {};\n event.debug_meta.images = event.debug_meta.images || [];\n const images = event.debug_meta.images;\n Object.keys(filenameDebugIdMap).forEach(filename => {\n images.push({\n type: 'sourcemap',\n code_file: filename,\n debug_id: filenameDebugIdMap[filename],\n });\n });\n}\n\n/**\n * This function adds all used integrations to the SDK info in the event.\n * @param event The event that will be filled with all integrations.\n */\nfunction applyIntegrationsMetadata(event: Event, integrationNames: string[]): void {\n if (integrationNames.length > 0) {\n event.sdk = event.sdk || {};\n event.sdk.integrations = [...(event.sdk.integrations || []), ...integrationNames];\n }\n}\n\n/**\n * Applies `normalize` function on necessary `Event` attributes to make them safe for serialization.\n * Normalized keys:\n * - `breadcrumbs.data`\n * - `user`\n * - `contexts`\n * - `extra`\n * @param event Event\n * @returns Normalized event\n */\nfunction normalizeEvent(event: Event | null, depth: number, maxBreadth: number): Event | null {\n if (!event) {\n return null;\n }\n\n const normalized: Event = {\n ...event,\n ...(event.breadcrumbs && {\n breadcrumbs: event.breadcrumbs.map(b => ({\n ...b,\n ...(b.data && {\n data: normalize(b.data, depth, maxBreadth),\n }),\n })),\n }),\n ...(event.user && {\n user: normalize(event.user, depth, maxBreadth),\n }),\n ...(event.contexts && {\n contexts: normalize(event.contexts, depth, maxBreadth),\n }),\n ...(event.extra && {\n extra: normalize(event.extra, depth, maxBreadth),\n }),\n };\n\n // event.contexts.trace stores information about a Transaction. Similarly,\n // event.spans[] stores information about child Spans. Given that a\n // Transaction is conceptually a Span, normalization should apply to both\n // Transactions and Spans consistently.\n // For now the decision is to skip normalization of Transactions and Spans,\n // so this block overwrites the normalized event to add back the original\n // Transaction information prior to normalization.\n if (event.contexts && event.contexts.trace && normalized.contexts) {\n normalized.contexts.trace = event.contexts.trace;\n\n // event.contexts.trace.data may contain circular/dangerous data so we need to normalize it\n if (event.contexts.trace.data) {\n normalized.contexts.trace.data = normalize(event.contexts.trace.data, depth, maxBreadth);\n }\n }\n\n // event.spans[].data may contain circular/dangerous data so we need to normalize it\n if (event.spans) {\n normalized.spans = event.spans.map(span => {\n // We cannot use the spread operator here because `toJSON` on `span` is non-enumerable\n if (span.data) {\n span.data = normalize(span.data, depth, maxBreadth);\n }\n return span;\n });\n }\n\n return normalized;\n}\n", "/* eslint-disable max-lines */\nimport type {\n Breadcrumb,\n BreadcrumbHint,\n Client,\n ClientOptions,\n DataCategory,\n DsnComponents,\n DynamicSamplingContext,\n Envelope,\n ErrorEvent,\n Event,\n EventDropReason,\n EventHint,\n EventProcessor,\n Integration,\n IntegrationClass,\n Outcome,\n PropagationContext,\n SdkMetadata,\n Session,\n SessionAggregates,\n Severity,\n SeverityLevel,\n Transaction,\n TransactionEvent,\n Transport,\n TransportMakeRequestResponse,\n} from '@sentry/types';\nimport {\n addItemToEnvelope,\n checkOrSetAlreadyCaught,\n createAttachmentEnvelopeItem,\n isPlainObject,\n isPrimitive,\n isThenable,\n logger,\n makeDsn,\n rejectedSyncPromise,\n resolvedSyncPromise,\n SentryError,\n SyncPromise,\n} from '@sentry/utils';\n\nimport { getEnvelopeEndpointWithUrlEncodedAuth } from './api';\nimport { createEventEnvelope, createSessionEnvelope } from './envelope';\nimport type { IntegrationIndex } from './integration';\nimport { setupIntegration, setupIntegrations } from './integration';\nimport type { Scope } from './scope';\nimport { updateSession } from './session';\nimport { getDynamicSamplingContextFromClient } from './tracing/dynamicSamplingContext';\nimport { prepareEvent } from './utils/prepareEvent';\n\nconst ALREADY_SEEN_ERROR = \"Not capturing exception because it's already been captured.\";\n\n/**\n * Base implementation for all JavaScript SDK clients.\n *\n * Call the constructor with the corresponding options\n * specific to the client subclass. To access these options later, use\n * {@link Client.getOptions}.\n *\n * If a Dsn is specified in the options, it will be parsed and stored. Use\n * {@link Client.getDsn} to retrieve the Dsn at any moment. In case the Dsn is\n * invalid, the constructor will throw a {@link SentryException}. Note that\n * without a valid Dsn, the SDK will not send any events to Sentry.\n *\n * Before sending an event, it is passed through\n * {@link BaseClient._prepareEvent} to add SDK information and scope data\n * (breadcrumbs and context). To add more custom information, override this\n * method and extend the resulting prepared event.\n *\n * To issue automatically created events (e.g. via instrumentation), use\n * {@link Client.captureEvent}. It will prepare the event and pass it through\n * the callback lifecycle. To issue auto-breadcrumbs, use\n * {@link Client.addBreadcrumb}.\n *\n * @example\n * class NodeClient extends BaseClient<NodeOptions> {\n * public constructor(options: NodeOptions) {\n * super(options);\n * }\n *\n * // ...\n * }\n */\nexport abstract class BaseClient<O extends ClientOptions> implements Client<O> {\n /** Options passed to the SDK. */\n protected readonly _options: O;\n\n /** The client Dsn, if specified in options. Without this Dsn, the SDK will be disabled. */\n protected readonly _dsn?: DsnComponents;\n\n protected readonly _transport?: Transport;\n\n /** Array of set up integrations. */\n protected _integrations: IntegrationIndex;\n\n /** Indicates whether this client's integrations have been set up. */\n protected _integrationsInitialized: boolean;\n\n /** Number of calls being processed */\n protected _numProcessing: number;\n\n /** Holds flushable */\n private _outcomes: { [key: string]: number };\n\n // eslint-disable-next-line @typescript-eslint/ban-types\n private _hooks: Record<string, Function[]>;\n\n private _eventProcessors: EventProcessor[];\n\n /**\n * Initializes this client instance.\n *\n * @param options Options for the client.\n */\n protected constructor(options: O) {\n this._options = options;\n this._integrations = {};\n this._integrationsInitialized = false;\n this._numProcessing = 0;\n this._outcomes = {};\n this._hooks = {};\n this._eventProcessors = [];\n\n if (options.dsn) {\n this._dsn = makeDsn(options.dsn);\n } else {\n __DEBUG_BUILD__ && logger.warn('No DSN provided, client will not send events.');\n }\n\n if (this._dsn) {\n const url = getEnvelopeEndpointWithUrlEncodedAuth(this._dsn, options);\n this._transport = options.transport({\n recordDroppedEvent: this.recordDroppedEvent.bind(this),\n ...options.transportOptions,\n url,\n });\n }\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public captureException(exception: any, hint?: EventHint, scope?: Scope): string | undefined {\n // ensure we haven't captured this very object before\n if (checkOrSetAlreadyCaught(exception)) {\n __DEBUG_BUILD__ && logger.log(ALREADY_SEEN_ERROR);\n return;\n }\n\n let eventId: string | undefined = hint && hint.event_id;\n\n this._process(\n this.eventFromException(exception, hint)\n .then(event => this._captureEvent(event, hint, scope))\n .then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level?: Severity | SeverityLevel,\n hint?: EventHint,\n scope?: Scope,\n ): string | undefined {\n let eventId: string | undefined = hint && hint.event_id;\n\n const promisedEvent = isPrimitive(message)\n ? this.eventFromMessage(String(message), level, hint)\n : this.eventFromException(message, hint);\n\n this._process(\n promisedEvent\n .then(event => this._captureEvent(event, hint, scope))\n .then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureEvent(event: Event, hint?: EventHint, scope?: Scope): string | undefined {\n // ensure we haven't captured this very object before\n if (hint && hint.originalException && checkOrSetAlreadyCaught(hint.originalException)) {\n __DEBUG_BUILD__ && logger.log(ALREADY_SEEN_ERROR);\n return;\n }\n\n let eventId: string | undefined = hint && hint.event_id;\n\n this._process(\n this._captureEvent(event, hint, scope).then(result => {\n eventId = result;\n }),\n );\n\n return eventId;\n }\n\n /**\n * @inheritDoc\n */\n public captureSession(session: Session): void {\n if (!(typeof session.release === 'string')) {\n __DEBUG_BUILD__ && logger.warn('Discarded session because of missing or non-string release');\n } else {\n this.sendSession(session);\n // After sending, we set init false to indicate it's not the first occurrence\n updateSession(session, { init: false });\n }\n }\n\n /**\n * @inheritDoc\n */\n public getDsn(): DsnComponents | undefined {\n return this._dsn;\n }\n\n /**\n * @inheritDoc\n */\n public getOptions(): O {\n return this._options;\n }\n\n /**\n * @see SdkMetadata in @sentry/types\n *\n * @return The metadata of the SDK\n */\n public getSdkMetadata(): SdkMetadata | undefined {\n return this._options._metadata;\n }\n\n /**\n * @inheritDoc\n */\n public getTransport(): Transport | undefined {\n return this._transport;\n }\n\n /**\n * @inheritDoc\n */\n public flush(timeout?: number): PromiseLike<boolean> {\n const transport = this._transport;\n if (transport) {\n return this._isClientDoneProcessing(timeout).then(clientFinished => {\n return transport.flush(timeout).then(transportFlushed => clientFinished && transportFlushed);\n });\n } else {\n return resolvedSyncPromise(true);\n }\n }\n\n /**\n * @inheritDoc\n */\n public close(timeout?: number): PromiseLike<boolean> {\n return this.flush(timeout).then(result => {\n this.getOptions().enabled = false;\n return result;\n });\n }\n\n /** Get all installed event processors. */\n public getEventProcessors(): EventProcessor[] {\n return this._eventProcessors;\n }\n\n /** @inheritDoc */\n public addEventProcessor(eventProcessor: EventProcessor): void {\n this._eventProcessors.push(eventProcessor);\n }\n\n /**\n * Sets up the integrations\n */\n public setupIntegrations(forceInitialize?: boolean): void {\n if ((forceInitialize && !this._integrationsInitialized) || (this._isEnabled() && !this._integrationsInitialized)) {\n this._integrations = setupIntegrations(this, this._options.integrations);\n this._integrationsInitialized = true;\n }\n }\n\n /**\n * Gets an installed integration by its `id`.\n *\n * @returns The installed integration or `undefined` if no integration with that `id` was installed.\n */\n public getIntegrationById(integrationId: string): Integration | undefined {\n return this._integrations[integrationId];\n }\n\n /**\n * @inheritDoc\n */\n public getIntegration<T extends Integration>(integration: IntegrationClass<T>): T | null {\n try {\n return (this._integrations[integration.id] as T) || null;\n } catch (_oO) {\n __DEBUG_BUILD__ && logger.warn(`Cannot retrieve integration ${integration.id} from the current Client`);\n return null;\n }\n }\n\n /**\n * @inheritDoc\n */\n public addIntegration(integration: Integration): void {\n setupIntegration(this, integration, this._integrations);\n }\n\n /**\n * @inheritDoc\n */\n public sendEvent(event: Event, hint: EventHint = {}): void {\n this.emit('beforeSendEvent', event, hint);\n\n let env = createEventEnvelope(event, this._dsn, this._options._metadata, this._options.tunnel);\n\n for (const attachment of hint.attachments || []) {\n env = addItemToEnvelope(\n env,\n createAttachmentEnvelopeItem(\n attachment,\n this._options.transportOptions && this._options.transportOptions.textEncoder,\n ),\n );\n }\n\n const promise = this._sendEnvelope(env);\n if (promise) {\n promise.then(sendResponse => this.emit('afterSendEvent', event, sendResponse), null);\n }\n }\n\n /**\n * @inheritDoc\n */\n public sendSession(session: Session | SessionAggregates): void {\n const env = createSessionEnvelope(session, this._dsn, this._options._metadata, this._options.tunnel);\n void this._sendEnvelope(env);\n }\n\n /**\n * @inheritDoc\n */\n public recordDroppedEvent(reason: EventDropReason, category: DataCategory, _event?: Event): void {\n // Note: we use `event` in replay, where we overwrite this hook.\n\n if (this._options.sendClientReports) {\n // We want to track each category (error, transaction, session, replay_event) separately\n // but still keep the distinction between different type of outcomes.\n // We could use nested maps, but it's much easier to read and type this way.\n // A correct type for map-based implementation if we want to go that route\n // would be `Partial<Record<SentryRequestType, Partial<Record<Outcome, number>>>>`\n // With typescript 4.1 we could even use template literal types\n const key = `${reason}:${category}`;\n __DEBUG_BUILD__ && logger.log(`Adding outcome: \"${key}\"`);\n\n // The following works because undefined + 1 === NaN and NaN is falsy\n this._outcomes[key] = this._outcomes[key] + 1 || 1;\n }\n }\n\n // Keep on() & emit() signatures in sync with types' client.ts interface\n /* eslint-disable @typescript-eslint/unified-signatures */\n\n /** @inheritdoc */\n public on(hook: 'startTransaction', callback: (transaction: Transaction) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'finishTransaction', callback: (transaction: Transaction) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'beforeEnvelope', callback: (envelope: Envelope) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'beforeSendEvent', callback: (event: Event, hint?: EventHint) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'preprocessEvent', callback: (event: Event, hint?: EventHint) => void): void;\n\n /** @inheritdoc */\n public on(\n hook: 'afterSendEvent',\n callback: (event: Event, sendResponse: TransportMakeRequestResponse | void) => void,\n ): void;\n\n /** @inheritdoc */\n public on(hook: 'beforeAddBreadcrumb', callback: (breadcrumb: Breadcrumb, hint?: BreadcrumbHint) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'createDsc', callback: (dsc: DynamicSamplingContext) => void): void;\n\n /** @inheritdoc */\n public on(hook: 'otelSpanEnd', callback: (otelSpan: unknown, mutableOptions: { drop: boolean }) => void): void;\n\n /** @inheritdoc */\n public on(hook: string, callback: unknown): void {\n if (!this._hooks[hook]) {\n this._hooks[hook] = [];\n }\n\n // @ts-expect-error We assue the types are correct\n this._hooks[hook].push(callback);\n }\n\n /** @inheritdoc */\n public emit(hook: 'startTransaction', transaction: Transaction): void;\n\n /** @inheritdoc */\n public emit(hook: 'finishTransaction', transaction: Transaction): void;\n\n /** @inheritdoc */\n public emit(hook: 'beforeEnvelope', envelope: Envelope): void;\n\n /** @inheritdoc */\n public emit(hook: 'beforeSendEvent', event: Event, hint?: EventHint): void;\n\n /** @inheritdoc */\n public emit(hook: 'preprocessEvent', event: Event, hint?: EventHint): void;\n\n /** @inheritdoc */\n public emit(hook: 'afterSendEvent', event: Event, sendResponse: TransportMakeRequestResponse | void): void;\n\n /** @inheritdoc */\n public emit(hook: 'beforeAddBreadcrumb', breadcrumb: Breadcrumb, hint?: BreadcrumbHint): void;\n\n /** @inheritdoc */\n public emit(hook: 'createDsc', dsc: DynamicSamplingContext): void;\n\n /** @inheritdoc */\n public emit(hook: 'otelSpanEnd', otelSpan: unknown, mutableOptions: { drop: boolean }): void;\n\n /** @inheritdoc */\n public emit(hook: string, ...rest: unknown[]): void {\n if (this._hooks[hook]) {\n this._hooks[hook].forEach(callback => callback(...rest));\n }\n }\n\n /* eslint-enable @typescript-eslint/unified-signatures */\n\n /** Updates existing session based on the provided event */\n protected _updateSessionFromEvent(session: Session, event: Event): void {\n let crashed = false;\n let errored = false;\n const exceptions = event.exception && event.exception.values;\n\n if (exceptions) {\n errored = true;\n\n for (const ex of exceptions) {\n const mechanism = ex.mechanism;\n if (mechanism && mechanism.handled === false) {\n crashed = true;\n break;\n }\n }\n }\n\n // A session is updated and that session update is sent in only one of the two following scenarios:\n // 1. Session with non terminal status and 0 errors + an error occurred -> Will set error count to 1 and send update\n // 2. Session with non terminal status and 1 error + a crash occurred -> Will set status crashed and send update\n const sessionNonTerminal = session.status === 'ok';\n const shouldUpdateAndSend = (sessionNonTerminal && session.errors === 0) || (sessionNonTerminal && crashed);\n\n if (shouldUpdateAndSend) {\n updateSession(session, {\n ...(crashed && { status: 'crashed' }),\n errors: session.errors || Number(errored || crashed),\n });\n this.captureSession(session);\n }\n }\n\n /**\n * Determine if the client is finished processing. Returns a promise because it will wait `timeout` ms before saying\n * \"no\" (resolving to `false`) in order to give the client a chance to potentially finish first.\n *\n * @param timeout The time, in ms, after which to resolve to `false` if the client is still busy. Passing `0` (or not\n * passing anything) will make the promise wait as long as it takes for processing to finish before resolving to\n * `true`.\n * @returns A promise which will resolve to `true` if processing is already done or finishes before the timeout, and\n * `false` otherwise\n */\n protected _isClientDoneProcessing(timeout?: number): PromiseLike<boolean> {\n return new SyncPromise(resolve => {\n let ticked: number = 0;\n const tick: number = 1;\n\n const interval = setInterval(() => {\n if (this._numProcessing == 0) {\n clearInterval(interval);\n resolve(true);\n } else {\n ticked += tick;\n if (timeout && ticked >= timeout) {\n clearInterval(interval);\n resolve(false);\n }\n }\n }, tick);\n });\n }\n\n /** Determines whether this SDK is enabled and a transport is present. */\n protected _isEnabled(): boolean {\n return this.getOptions().enabled !== false && this._transport !== undefined;\n }\n\n /**\n * Adds common information to events.\n *\n * The information includes release and environment from `options`,\n * breadcrumbs and context (extra, tags and user) from the scope.\n *\n * Information that is already present in the event is never overwritten. For\n * nested objects, such as the context, keys are merged.\n *\n * @param event The original event.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A new event with more information.\n */\n protected _prepareEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event | null> {\n const options = this.getOptions();\n const integrations = Object.keys(this._integrations);\n if (!hint.integrations && integrations.length > 0) {\n hint.integrations = integrations;\n }\n\n this.emit('preprocessEvent', event, hint);\n\n return prepareEvent(options, event, hint, scope, this).then(evt => {\n if (evt === null) {\n return evt;\n }\n\n // If a trace context is not set on the event, we use the propagationContext set on the event to\n // generate a trace context. If the propagationContext does not have a dynamic sampling context, we\n // also generate one for it.\n const { propagationContext } = evt.sdkProcessingMetadata || {};\n const trace = evt.contexts && evt.contexts.trace;\n if (!trace && propagationContext) {\n const { traceId: trace_id, spanId, parentSpanId, dsc } = propagationContext as PropagationContext;\n evt.contexts = {\n trace: {\n trace_id,\n span_id: spanId,\n parent_span_id: parentSpanId,\n },\n ...evt.contexts,\n };\n\n const dynamicSamplingContext = dsc ? dsc : getDynamicSamplingContextFromClient(trace_id, this, scope);\n\n evt.sdkProcessingMetadata = {\n dynamicSamplingContext,\n ...evt.sdkProcessingMetadata,\n };\n }\n return evt;\n });\n }\n\n /**\n * Processes the event and logs an error in case of rejection\n * @param event\n * @param hint\n * @param scope\n */\n protected _captureEvent(event: Event, hint: EventHint = {}, scope?: Scope): PromiseLike<string | undefined> {\n return this._processEvent(event, hint, scope).then(\n finalEvent => {\n return finalEvent.event_id;\n },\n reason => {\n if (__DEBUG_BUILD__) {\n // If something's gone wrong, log the error as a warning. If it's just us having used a `SentryError` for\n // control flow, log just the message (no stack) as a log-level log.\n const sentryError = reason as SentryError;\n if (sentryError.logLevel === 'log') {\n logger.log(sentryError.message);\n } else {\n logger.warn(sentryError);\n }\n }\n return undefined;\n },\n );\n }\n\n /**\n * Processes an event (either error or message) and sends it to Sentry.\n *\n * This also adds breadcrumbs and context information to the event. However,\n * platform specific meta data (such as the User's IP address) must be added\n * by the SDK implementor.\n *\n *\n * @param event The event to send to Sentry.\n * @param hint May contain additional information about the original exception.\n * @param scope A scope containing event metadata.\n * @returns A SyncPromise that resolves with the event or rejects in case event was/will not be send.\n */\n protected _processEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event> {\n const options = this.getOptions();\n const { sampleRate } = options;\n\n const isTransaction = isTransactionEvent(event);\n const isError = isErrorEvent(event);\n const eventType = event.type || 'error';\n const beforeSendLabel = `before send for type \\`${eventType}\\``;\n\n // 1.0 === 100% events are sent\n // 0.0 === 0% events are sent\n // Sampling for transaction happens somewhere else\n if (isError && typeof sampleRate === 'number' && Math.random() > sampleRate) {\n this.recordDroppedEvent('sample_rate', 'error', event);\n return rejectedSyncPromise(\n new SentryError(\n `Discarding event because it's not included in the random sample (sampling rate = ${sampleRate})`,\n 'log',\n ),\n );\n }\n\n const dataCategory: DataCategory = eventType === 'replay_event' ? 'replay' : eventType;\n\n return this._prepareEvent(event, hint, scope)\n .then(prepared => {\n if (prepared === null) {\n this.recordDroppedEvent('event_processor', dataCategory, event);\n throw new SentryError('An event processor returned `null`, will not send event.', 'log');\n }\n\n const isInternalException = hint.data && (hint.data as { __sentry__: boolean }).__sentry__ === true;\n if (isInternalException) {\n return prepared;\n }\n\n const result = processBeforeSend(options, prepared, hint);\n return _validateBeforeSendResult(result, beforeSendLabel);\n })\n .then(processedEvent => {\n if (processedEvent === null) {\n this.recordDroppedEvent('before_send', dataCategory, event);\n throw new SentryError(`${beforeSendLabel} returned \\`null\\`, will not send event.`, 'log');\n }\n\n const session = scope && scope.getSession();\n if (!isTransaction && session) {\n this._updateSessionFromEvent(session, processedEvent);\n }\n\n // None of the Sentry built event processor will update transaction name,\n // so if the transaction name has been changed by an event processor, we know\n // it has to come from custom event processor added by a user\n const transactionInfo = processedEvent.transaction_info;\n if (isTransaction && transactionInfo && processedEvent.transaction !== event.transaction) {\n const source = 'custom';\n processedEvent.transaction_info = {\n ...transactionInfo,\n source,\n };\n }\n\n this.sendEvent(processedEvent, hint);\n return processedEvent;\n })\n .then(null, reason => {\n if (reason instanceof SentryError) {\n throw reason;\n }\n\n this.captureException(reason, {\n data: {\n __sentry__: true,\n },\n originalException: reason,\n });\n throw new SentryError(\n `Event processing pipeline threw an error, original event will not be sent. Details have been sent as a new event.\\nReason: ${reason}`,\n );\n });\n }\n\n /**\n * Occupies the client with processing and event\n */\n protected _process<T>(promise: PromiseLike<T>): void {\n this._numProcessing++;\n void promise.then(\n value => {\n this._numProcessing--;\n return value;\n },\n reason => {\n this._numProcessing--;\n return reason;\n },\n );\n }\n\n /**\n * @inheritdoc\n */\n protected _sendEnvelope(envelope: Envelope): PromiseLike<void | TransportMakeRequestResponse> | void {\n this.emit('beforeEnvelope', envelope);\n\n if (this._isEnabled() && this._transport) {\n return this._transport.send(envelope).then(null, reason => {\n __DEBUG_BUILD__ && logger.error('Error while sending event:', reason);\n });\n } else {\n __DEBUG_BUILD__ && logger.error('Transport disabled');\n }\n }\n\n /**\n * Clears outcomes on this client and returns them.\n */\n protected _clearOutcomes(): Outcome[] {\n const outcomes = this._outcomes;\n this._outcomes = {};\n return Object.keys(outcomes).map(key => {\n const [reason, category] = key.split(':') as [EventDropReason, DataCategory];\n return {\n reason,\n category,\n quantity: outcomes[key],\n };\n });\n }\n\n /**\n * @inheritDoc\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/explicit-module-boundary-types\n public abstract eventFromException(_exception: any, _hint?: EventHint): PromiseLike<Event>;\n\n /**\n * @inheritDoc\n */\n public abstract eventFromMessage(\n _message: string,\n // eslint-disable-next-line deprecation/deprecation\n _level?: Severity | SeverityLevel,\n _hint?: EventHint,\n ): PromiseLike<Event>;\n}\n\n/**\n * Verifies that return value of configured `beforeSend` or `beforeSendTransaction` is of expected type, and returns the value if so.\n */\nfunction _validateBeforeSendResult(\n beforeSendResult: PromiseLike<Event | null> | Event | null,\n beforeSendLabel: string,\n): PromiseLike<Event | null> | Event | null {\n const invalidValueError = `${beforeSendLabel} must return \\`null\\` or a valid event.`;\n if (isThenable(beforeSendResult)) {\n return beforeSendResult.then(\n event => {\n if (!isPlainObject(event) && event !== null) {\n throw new SentryError(invalidValueError);\n }\n return event;\n },\n e => {\n throw new SentryError(`${beforeSendLabel} rejected with ${e}`);\n },\n );\n } else if (!isPlainObject(beforeSendResult) && beforeSendResult !== null) {\n throw new SentryError(invalidValueError);\n }\n return beforeSendResult;\n}\n\n/**\n * Process the matching `beforeSendXXX` callback.\n */\nfunction processBeforeSend(\n options: ClientOptions,\n event: Event,\n hint: EventHint,\n): PromiseLike<Event | null> | Event | null {\n const { beforeSend, beforeSendTransaction } = options;\n\n if (isErrorEvent(event) && beforeSend) {\n return beforeSend(event, hint);\n }\n\n if (isTransactionEvent(event) && beforeSendTransaction) {\n return beforeSendTransaction(event, hint);\n }\n\n return event;\n}\n\nfunction isErrorEvent(event: Event): event is ErrorEvent {\n return event.type === undefined;\n}\n\nfunction isTransactionEvent(event: Event): event is TransactionEvent {\n return event.type === 'transaction';\n}\n", "import type { Client, ClientOptions } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\nimport { getCurrentHub } from './hub';\n\n/** A class object that can instantiate Client objects. */\nexport type ClientClass<F extends Client, O extends ClientOptions> = new (options: O) => F;\n\n/**\n * Internal function to create a new SDK client instance. The client is\n * installed and then bound to the current scope.\n *\n * @param clientClass The client class to instantiate.\n * @param options Options to pass to the client.\n */\nexport function initAndBind<F extends Client, O extends ClientOptions>(\n clientClass: ClientClass<F, O>,\n options: O,\n): void {\n if (options.debug === true) {\n if (__DEBUG_BUILD__) {\n logger.enable();\n } else {\n // use `console.warn` rather than `logger.warn` since by non-debug bundles have all `logger.x` statements stripped\n // eslint-disable-next-line no-console\n console.warn('[Sentry] Cannot initialize SDK with `debug` option using a non-debug bundle.');\n }\n }\n const hub = getCurrentHub();\n const scope = hub.getScope();\n scope.update(options.initialScope);\n\n const client = new clientClass(options);\n hub.bindClient(client);\n}\n", "import type {\n Envelope,\n EnvelopeItem,\n EnvelopeItemType,\n Event,\n EventDropReason,\n EventItem,\n InternalBaseTransportOptions,\n Transport,\n TransportMakeRequestResponse,\n TransportRequestExecutor,\n} from '@sentry/types';\nimport type { PromiseBuffer, RateLimits } from '@sentry/utils';\nimport {\n createEnvelope,\n envelopeItemTypeToDataCategory,\n forEachEnvelopeItem,\n isRateLimited,\n logger,\n makePromiseBuffer,\n resolvedSyncPromise,\n SentryError,\n serializeEnvelope,\n updateRateLimits,\n} from '@sentry/utils';\n\nexport const DEFAULT_TRANSPORT_BUFFER_SIZE = 30;\n\n/**\n * Creates an instance of a Sentry `Transport`\n *\n * @param options\n * @param makeRequest\n */\nexport function createTransport(\n options: InternalBaseTransportOptions,\n makeRequest: TransportRequestExecutor,\n buffer: PromiseBuffer<void | TransportMakeRequestResponse> = makePromiseBuffer(\n options.bufferSize || DEFAULT_TRANSPORT_BUFFER_SIZE,\n ),\n): Transport {\n let rateLimits: RateLimits = {};\n const flush = (timeout?: number): PromiseLike<boolean> => buffer.drain(timeout);\n\n function send(envelope: Envelope): PromiseLike<void | TransportMakeRequestResponse> {\n const filteredEnvelopeItems: EnvelopeItem[] = [];\n\n // Drop rate limited items from envelope\n forEachEnvelopeItem(envelope, (item, type) => {\n const envelopeItemDataCategory = envelopeItemTypeToDataCategory(type);\n if (isRateLimited(rateLimits, envelopeItemDataCategory)) {\n const event: Event | undefined = getEventForEnvelopeItem(item, type);\n options.recordDroppedEvent('ratelimit_backoff', envelopeItemDataCategory, event);\n } else {\n filteredEnvelopeItems.push(item);\n }\n });\n\n // Skip sending if envelope is empty after filtering out rate limited events\n if (filteredEnvelopeItems.length === 0) {\n return resolvedSyncPromise();\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const filteredEnvelope: Envelope = createEnvelope(envelope[0], filteredEnvelopeItems as any);\n\n // Creates client report for each item in an envelope\n const recordEnvelopeLoss = (reason: EventDropReason): void => {\n forEachEnvelopeItem(filteredEnvelope, (item, type) => {\n const event: Event | undefined = getEventForEnvelopeItem(item, type);\n options.recordDroppedEvent(reason, envelopeItemTypeToDataCategory(type), event);\n });\n };\n\n const requestTask = (): PromiseLike<void | TransportMakeRequestResponse> =>\n makeRequest({ body: serializeEnvelope(filteredEnvelope, options.textEncoder) }).then(\n response => {\n // We don't want to throw on NOK responses, but we want to at least log them\n if (response.statusCode !== undefined && (response.statusCode < 200 || response.statusCode >= 300)) {\n __DEBUG_BUILD__ && logger.warn(`Sentry responded with status code ${response.statusCode} to sent event.`);\n }\n\n rateLimits = updateRateLimits(rateLimits, response);\n return response;\n },\n error => {\n recordEnvelopeLoss('network_error');\n throw error;\n },\n );\n\n return buffer.add(requestTask).then(\n result => result,\n error => {\n if (error instanceof SentryError) {\n __DEBUG_BUILD__ && logger.error('Skipped sending event because buffer is full.');\n recordEnvelopeLoss('queue_overflow');\n return resolvedSyncPromise();\n } else {\n throw error;\n }\n },\n );\n }\n\n // We use this to identifify if the transport is the base transport\n // TODO (v8): Remove this again as we'll no longer need it\n send.__sentry__baseTransport__ = true;\n\n return {\n send,\n flush,\n };\n}\n\nfunction getEventForEnvelopeItem(item: Envelope[1][number], type: EnvelopeItemType): Event | undefined {\n if (type !== 'event' && type !== 'transaction') {\n return undefined;\n }\n\n return Array.isArray(item) ? (item as EventItem)[1] : undefined;\n}\n", "export const SDK_VERSION = '7.77.0';\n", "export { FunctionToString } from './functiontostring.js';\nexport { InboundFilters } from './inboundfilters.js';\nexport { LinkedErrors } from './linkederrors.js';\n//# sourceMappingURL=index.js.map\n", "import type { Integration, WrappedFunction } from '@sentry/types';\nimport { getOriginalFunction } from '@sentry/utils';\n\nlet originalFunctionToString: () => void;\n\n/** Patch toString calls to return proper name for wrapped functions */\nexport class FunctionToString implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'FunctionToString';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n public constructor() {\n this.name = FunctionToString.id;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n // eslint-disable-next-line @typescript-eslint/unbound-method\n originalFunctionToString = Function.prototype.toString;\n\n // intrinsics (like Function.prototype) might be immutable in some environments\n // e.g. Node with --frozen-intrinsics, XS (an embedded JavaScript engine) or SES (a JavaScript proposal)\n try {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Function.prototype.toString = function (this: WrappedFunction, ...args: any[]): string {\n const context = getOriginalFunction(this) || this;\n return originalFunctionToString.apply(context, args);\n };\n } catch {\n // ignore errors here, just don't patch this\n }\n }\n}\n", "import type { Client, Event, EventHint, Integration, StackFrame } from '@sentry/types';\nimport { getEventDescription, logger, stringMatchesSomePattern } from '@sentry/utils';\n\n// \"Script error.\" is hard coded into browsers for errors that it can't read.\n// this is the result of a script being pulled in from an external domain and CORS.\nconst DEFAULT_IGNORE_ERRORS = [/^Script error\\.?$/, /^Javascript error: Script error\\.? on line 0$/];\n\nconst DEFAULT_IGNORE_TRANSACTIONS = [\n /^.*\\/healthcheck$/,\n /^.*\\/healthy$/,\n /^.*\\/live$/,\n /^.*\\/ready$/,\n /^.*\\/heartbeat$/,\n /^.*\\/health$/,\n /^.*\\/healthz$/,\n];\n\n/** Options for the InboundFilters integration */\nexport interface InboundFiltersOptions {\n allowUrls: Array<string | RegExp>;\n denyUrls: Array<string | RegExp>;\n ignoreErrors: Array<string | RegExp>;\n ignoreTransactions: Array<string | RegExp>;\n ignoreInternal: boolean;\n disableErrorDefaults: boolean;\n disableTransactionDefaults: boolean;\n}\n\n/** Inbound filters configurable by the user */\nexport class InboundFilters implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'InboundFilters';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n private readonly _options: Partial<InboundFiltersOptions>;\n\n public constructor(options: Partial<InboundFiltersOptions> = {}) {\n this.name = InboundFilters.id;\n this._options = options;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(_addGlobaleventProcessor: unknown, _getCurrentHub: unknown): void {\n // noop\n }\n\n /** @inheritDoc */\n public processEvent(event: Event, _eventHint: EventHint, client: Client): Event | null {\n const clientOptions = client.getOptions();\n const options = _mergeOptions(this._options, clientOptions);\n return _shouldDropEvent(event, options) ? null : event;\n }\n}\n\n/** JSDoc */\nexport function _mergeOptions(\n internalOptions: Partial<InboundFiltersOptions> = {},\n clientOptions: Partial<InboundFiltersOptions> = {},\n): Partial<InboundFiltersOptions> {\n return {\n allowUrls: [...(internalOptions.allowUrls || []), ...(clientOptions.allowUrls || [])],\n denyUrls: [...(internalOptions.denyUrls || []), ...(clientOptions.denyUrls || [])],\n ignoreErrors: [\n ...(internalOptions.ignoreErrors || []),\n ...(clientOptions.ignoreErrors || []),\n ...(internalOptions.disableErrorDefaults ? [] : DEFAULT_IGNORE_ERRORS),\n ],\n ignoreTransactions: [\n ...(internalOptions.ignoreTransactions || []),\n ...(clientOptions.ignoreTransactions || []),\n ...(internalOptions.disableTransactionDefaults ? [] : DEFAULT_IGNORE_TRANSACTIONS),\n ],\n ignoreInternal: internalOptions.ignoreInternal !== undefined ? internalOptions.ignoreInternal : true,\n };\n}\n\n/** JSDoc */\nexport function _shouldDropEvent(event: Event, options: Partial<InboundFiltersOptions>): boolean {\n if (options.ignoreInternal && _isSentryError(event)) {\n __DEBUG_BUILD__ &&\n logger.warn(`Event dropped due to being internal Sentry Error.\\nEvent: ${getEventDescription(event)}`);\n return true;\n }\n if (_isIgnoredError(event, options.ignoreErrors)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`ignoreErrors\\` option.\\nEvent: ${getEventDescription(event)}`,\n );\n return true;\n }\n if (_isIgnoredTransaction(event, options.ignoreTransactions)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`ignoreTransactions\\` option.\\nEvent: ${getEventDescription(event)}`,\n );\n return true;\n }\n if (_isDeniedUrl(event, options.denyUrls)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to being matched by \\`denyUrls\\` option.\\nEvent: ${getEventDescription(\n event,\n )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n );\n return true;\n }\n if (!_isAllowedUrl(event, options.allowUrls)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `Event dropped due to not being matched by \\`allowUrls\\` option.\\nEvent: ${getEventDescription(\n event,\n )}.\\nUrl: ${_getEventFilterUrl(event)}`,\n );\n return true;\n }\n return false;\n}\n\nfunction _isIgnoredError(event: Event, ignoreErrors?: Array<string | RegExp>): boolean {\n // If event.type, this is not an error\n if (event.type || !ignoreErrors || !ignoreErrors.length) {\n return false;\n }\n\n return _getPossibleEventMessages(event).some(message => stringMatchesSomePattern(message, ignoreErrors));\n}\n\nfunction _isIgnoredTransaction(event: Event, ignoreTransactions?: Array<string | RegExp>): boolean {\n if (event.type !== 'transaction' || !ignoreTransactions || !ignoreTransactions.length) {\n return false;\n }\n\n const name = event.transaction;\n return name ? stringMatchesSomePattern(name, ignoreTransactions) : false;\n}\n\nfunction _isDeniedUrl(event: Event, denyUrls?: Array<string | RegExp>): boolean {\n // TODO: Use Glob instead?\n if (!denyUrls || !denyUrls.length) {\n return false;\n }\n const url = _getEventFilterUrl(event);\n return !url ? false : stringMatchesSomePattern(url, denyUrls);\n}\n\nfunction _isAllowedUrl(event: Event, allowUrls?: Array<string | RegExp>): boolean {\n // TODO: Use Glob instead?\n if (!allowUrls || !allowUrls.length) {\n return true;\n }\n const url = _getEventFilterUrl(event);\n return !url ? true : stringMatchesSomePattern(url, allowUrls);\n}\n\nfunction _getPossibleEventMessages(event: Event): string[] {\n const possibleMessages: string[] = [];\n\n if (event.message) {\n possibleMessages.push(event.message);\n }\n\n let lastException;\n try {\n // @ts-expect-error Try catching to save bundle size\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n lastException = event.exception.values[event.exception.values.length - 1];\n } catch (e) {\n // try catching to save bundle size checking existence of variables\n }\n\n if (lastException) {\n if (lastException.value) {\n possibleMessages.push(lastException.value);\n if (lastException.type) {\n possibleMessages.push(`${lastException.type}: ${lastException.value}`);\n }\n }\n }\n\n if (__DEBUG_BUILD__ && possibleMessages.length === 0) {\n logger.error(`Could not extract message for event ${getEventDescription(event)}`);\n }\n\n return possibleMessages;\n}\n\nfunction _isSentryError(event: Event): boolean {\n try {\n // @ts-expect-error can't be a sentry error if undefined\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return event.exception.values[0].type === 'SentryError';\n } catch (e) {\n // ignore\n }\n return false;\n}\n\nfunction _getLastValidUrl(frames: StackFrame[] = []): string | null {\n for (let i = frames.length - 1; i >= 0; i--) {\n const frame = frames[i];\n\n if (frame && frame.filename !== '<anonymous>' && frame.filename !== '[native code]') {\n return frame.filename || null;\n }\n }\n\n return null;\n}\n\nfunction _getEventFilterUrl(event: Event): string | null {\n try {\n let frames;\n try {\n // @ts-expect-error we only care about frames if the whole thing here is defined\n frames = event.exception.values[0].stacktrace.frames;\n } catch (e) {\n // ignore\n }\n return frames ? _getLastValidUrl(frames) : null;\n } catch (oO) {\n __DEBUG_BUILD__ && logger.error(`Cannot extract url for event ${getEventDescription(event)}`);\n return null;\n }\n}\n", "import type { Client, Event, EventHint, Integration } from '@sentry/types';\nimport { applyAggregateErrorsToEvent, exceptionFromError } from '@sentry/utils';\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\n/** Adds SDK info to an event. */\nexport class LinkedErrors implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'LinkedErrors';\n\n /**\n * @inheritDoc\n */\n public readonly name: string;\n\n /**\n * @inheritDoc\n */\n private readonly _key: string;\n\n /**\n * @inheritDoc\n */\n private readonly _limit: number;\n\n /**\n * @inheritDoc\n */\n public constructor(options: { key?: string; limit?: number } = {}) {\n this._key = options.key || DEFAULT_KEY;\n this._limit = options.limit || DEFAULT_LIMIT;\n this.name = LinkedErrors.id;\n }\n\n /** @inheritdoc */\n public setupOnce(): void {\n // noop\n }\n\n /**\n * @inheritDoc\n */\n public preprocessEvent(event: Event, hint: EventHint | undefined, client: Client): void {\n const options = client.getOptions();\n\n applyAggregateErrorsToEvent(\n exceptionFromError,\n options.stackParser,\n options.maxValueLength,\n this._key,\n this._limit,\n event,\n hint,\n );\n }\n}\n", "import { captureException, withScope } from '@sentry/core';\nimport type { DsnLike, Event as SentryEvent, Mechanism, Scope, WrappedFunction } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addExceptionTypeValue,\n addNonEnumerableProperty,\n getOriginalFunction,\n GLOBAL_OBJ,\n markFunctionWrapped,\n} from '@sentry/utils';\n\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ & Window;\n\nlet ignoreOnError: number = 0;\n\n/**\n * @hidden\n */\nexport function shouldIgnoreOnError(): boolean {\n return ignoreOnError > 0;\n}\n\n/**\n * @hidden\n */\nexport function ignoreNextOnError(): void {\n // onerror should trigger before setTimeout\n ignoreOnError++;\n setTimeout(() => {\n ignoreOnError--;\n });\n}\n\n/**\n * Instruments the given function and sends an event to Sentry every time the\n * function throws an exception.\n *\n * @param fn A function to wrap. It is generally safe to pass an unbound function, because the returned wrapper always\n * has a correct `this` context.\n * @returns The wrapped function.\n * @hidden\n */\nexport function wrap(\n fn: WrappedFunction,\n options: {\n mechanism?: Mechanism;\n } = {},\n before?: WrappedFunction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n): any {\n // for future readers what this does is wrap a function and then create\n // a bi-directional wrapping between them.\n //\n // example: wrapped = wrap(original);\n // original.__sentry_wrapped__ -> wrapped\n // wrapped.__sentry_original__ -> original\n\n if (typeof fn !== 'function') {\n return fn;\n }\n\n try {\n // if we're dealing with a function that was previously wrapped, return\n // the original wrapper.\n const wrapper = fn.__sentry_wrapped__;\n if (wrapper) {\n return wrapper;\n }\n\n // We don't wanna wrap it twice\n if (getOriginalFunction(fn)) {\n return fn;\n }\n } catch (e) {\n // Just accessing custom props in some Selenium environments\n // can cause a \"Permission denied\" exception (see raven-js#495).\n // Bail on wrapping and return the function as-is (defers to window.onerror).\n return fn;\n }\n\n /* eslint-disable prefer-rest-params */\n // It is important that `sentryWrapped` is not an arrow function to preserve the context of `this`\n const sentryWrapped: WrappedFunction = function (this: unknown): void {\n const args = Array.prototype.slice.call(arguments);\n\n try {\n if (before && typeof before === 'function') {\n before.apply(this, arguments);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n const wrappedArguments = args.map((arg: any) => wrap(arg, options));\n\n // Attempt to invoke user-land function\n // NOTE: If you are a Sentry user, and you are seeing this stack frame, it\n // means the sentry.javascript SDK caught an error invoking your application code. This\n // is expected behavior and NOT indicative of a bug with sentry.javascript.\n return fn.apply(this, wrappedArguments);\n } catch (ex) {\n ignoreNextOnError();\n\n withScope((scope: Scope) => {\n scope.addEventProcessor((event: SentryEvent) => {\n if (options.mechanism) {\n addExceptionTypeValue(event, undefined, undefined);\n addExceptionMechanism(event, options.mechanism);\n }\n\n event.extra = {\n ...event.extra,\n arguments: args,\n };\n\n return event;\n });\n\n captureException(ex);\n });\n\n throw ex;\n }\n };\n /* eslint-enable prefer-rest-params */\n\n // Accessing some objects may throw\n // ref: https://github.com/getsentry/sentry-javascript/issues/1168\n try {\n for (const property in fn) {\n if (Object.prototype.hasOwnProperty.call(fn, property)) {\n sentryWrapped[property] = fn[property];\n }\n }\n } catch (_oO) {} // eslint-disable-line no-empty\n\n // Signal that this function has been wrapped/filled already\n // for both debugging and to prevent it to being wrapped/filled twice\n markFunctionWrapped(sentryWrapped, fn);\n\n addNonEnumerableProperty(fn, '__sentry_wrapped__', sentryWrapped);\n\n // Restore original function name (not all browsers allow that)\n try {\n const descriptor = Object.getOwnPropertyDescriptor(sentryWrapped, 'name') as PropertyDescriptor;\n if (descriptor.configurable) {\n Object.defineProperty(sentryWrapped, 'name', {\n get(): string {\n return fn.name;\n },\n });\n }\n // eslint-disable-next-line no-empty\n } catch (_oO) {}\n\n return sentryWrapped;\n}\n\n/**\n * All properties the report dialog supports\n */\nexport interface ReportDialogOptions {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n eventId?: string;\n dsn?: DsnLike;\n user?: {\n email?: string;\n name?: string;\n };\n lang?: string;\n title?: string;\n subtitle?: string;\n subtitle2?: string;\n labelName?: string;\n labelEmail?: string;\n labelComments?: string;\n labelClose?: string;\n labelSubmit?: string;\n errorGeneric?: string;\n errorFormEntry?: string;\n successMessage?: string;\n /** Callback after reportDialog showed up */\n onLoad?(this: void): void;\n}\n", "import { getCurrentHub } from '@sentry/core';\nimport type { Event, EventHint, Exception, Severity, SeverityLevel, StackFrame, StackParser } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addExceptionTypeValue,\n extractExceptionKeysForMessage,\n isDOMError,\n isDOMException,\n isError,\n isErrorEvent,\n isEvent,\n isPlainObject,\n normalizeToSize,\n resolvedSyncPromise,\n} from '@sentry/utils';\n\ntype Prototype = { constructor: (...args: unknown[]) => unknown };\n\n/**\n * This function creates an exception from a JavaScript Error\n */\nexport function exceptionFromError(stackParser: StackParser, ex: Error): Exception {\n // Get the frames first since Opera can lose the stack if we touch anything else first\n const frames = parseStackFrames(stackParser, ex);\n\n const exception: Exception = {\n type: ex && ex.name,\n value: extractMessage(ex),\n };\n\n if (frames.length) {\n exception.stacktrace = { frames };\n }\n\n if (exception.type === undefined && exception.value === '') {\n exception.value = 'Unrecoverable error caught';\n }\n\n return exception;\n}\n\n/**\n * @hidden\n */\nexport function eventFromPlainObject(\n stackParser: StackParser,\n exception: Record<string, unknown>,\n syntheticException?: Error,\n isUnhandledRejection?: boolean,\n): Event {\n const hub = getCurrentHub();\n const client = hub.getClient();\n const normalizeDepth = client && client.getOptions().normalizeDepth;\n\n const event: Event = {\n exception: {\n values: [\n {\n type: isEvent(exception) ? exception.constructor.name : isUnhandledRejection ? 'UnhandledRejection' : 'Error',\n value: getNonErrorObjectExceptionValue(exception, { isUnhandledRejection }),\n },\n ],\n },\n extra: {\n __serialized__: normalizeToSize(exception, normalizeDepth),\n },\n };\n\n if (syntheticException) {\n const frames = parseStackFrames(stackParser, syntheticException);\n if (frames.length) {\n // event.exception.values[0] has been set above\n (event.exception as { values: Exception[] }).values[0].stacktrace = { frames };\n }\n }\n\n return event;\n}\n\n/**\n * @hidden\n */\nexport function eventFromError(stackParser: StackParser, ex: Error): Event {\n return {\n exception: {\n values: [exceptionFromError(stackParser, ex)],\n },\n };\n}\n\n/** Parses stack frames from an error */\nexport function parseStackFrames(\n stackParser: StackParser,\n ex: Error & { framesToPop?: number; stacktrace?: string },\n): StackFrame[] {\n // Access and store the stacktrace property before doing ANYTHING\n // else to it because Opera is not very good at providing it\n // reliably in other circumstances.\n const stacktrace = ex.stacktrace || ex.stack || '';\n\n const popSize = getPopSize(ex);\n\n try {\n return stackParser(stacktrace, popSize);\n } catch (e) {\n // no-empty\n }\n\n return [];\n}\n\n// Based on our own mapping pattern - https://github.com/getsentry/sentry/blob/9f08305e09866c8bd6d0c24f5b0aabdd7dd6c59c/src/sentry/lang/javascript/errormapping.py#L83-L108\nconst reactMinifiedRegexp = /Minified React error #\\d+;/i;\n\nfunction getPopSize(ex: Error & { framesToPop?: number }): number {\n if (ex) {\n if (typeof ex.framesToPop === 'number') {\n return ex.framesToPop;\n }\n\n if (reactMinifiedRegexp.test(ex.message)) {\n return 1;\n }\n }\n\n return 0;\n}\n\n/**\n * There are cases where stacktrace.message is an Event object\n * https://github.com/getsentry/sentry-javascript/issues/1949\n * In this specific case we try to extract stacktrace.message.error.message\n */\nfunction extractMessage(ex: Error & { message: { error?: Error } }): string {\n const message = ex && ex.message;\n if (!message) {\n return 'No error message';\n }\n if (message.error && typeof message.error.message === 'string') {\n return message.error.message;\n }\n return message;\n}\n\n/**\n * Creates an {@link Event} from all inputs to `captureException` and non-primitive inputs to `captureMessage`.\n * @hidden\n */\nexport function eventFromException(\n stackParser: StackParser,\n exception: unknown,\n hint?: EventHint,\n attachStacktrace?: boolean,\n): PromiseLike<Event> {\n const syntheticException = (hint && hint.syntheticException) || undefined;\n const event = eventFromUnknownInput(stackParser, exception, syntheticException, attachStacktrace);\n addExceptionMechanism(event); // defaults to { type: 'generic', handled: true }\n event.level = 'error';\n if (hint && hint.event_id) {\n event.event_id = hint.event_id;\n }\n return resolvedSyncPromise(event);\n}\n\n/**\n * Builds and Event from a Message\n * @hidden\n */\nexport function eventFromMessage(\n stackParser: StackParser,\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel = 'info',\n hint?: EventHint,\n attachStacktrace?: boolean,\n): PromiseLike<Event> {\n const syntheticException = (hint && hint.syntheticException) || undefined;\n const event = eventFromString(stackParser, message, syntheticException, attachStacktrace);\n event.level = level;\n if (hint && hint.event_id) {\n event.event_id = hint.event_id;\n }\n return resolvedSyncPromise(event);\n}\n\n/**\n * @hidden\n */\nexport function eventFromUnknownInput(\n stackParser: StackParser,\n exception: unknown,\n syntheticException?: Error,\n attachStacktrace?: boolean,\n isUnhandledRejection?: boolean,\n): Event {\n let event: Event;\n\n if (isErrorEvent(exception as ErrorEvent) && (exception as ErrorEvent).error) {\n // If it is an ErrorEvent with `error` property, extract it to get actual Error\n const errorEvent = exception as ErrorEvent;\n return eventFromError(stackParser, errorEvent.error as Error);\n }\n\n // If it is a `DOMError` (which is a legacy API, but still supported in some browsers) then we just extract the name\n // and message, as it doesn't provide anything else. According to the spec, all `DOMExceptions` should also be\n // `Error`s, but that's not the case in IE11, so in that case we treat it the same as we do a `DOMError`.\n //\n // https://developer.mozilla.org/en-US/docs/Web/API/DOMError\n // https://developer.mozilla.org/en-US/docs/Web/API/DOMException\n // https://webidl.spec.whatwg.org/#es-DOMException-specialness\n if (isDOMError(exception) || isDOMException(exception as DOMException)) {\n const domException = exception as DOMException;\n\n if ('stack' in (exception as Error)) {\n event = eventFromError(stackParser, exception as Error);\n } else {\n const name = domException.name || (isDOMError(domException) ? 'DOMError' : 'DOMException');\n const message = domException.message ? `${name}: ${domException.message}` : name;\n event = eventFromString(stackParser, message, syntheticException, attachStacktrace);\n addExceptionTypeValue(event, message);\n }\n if ('code' in domException) {\n // eslint-disable-next-line deprecation/deprecation\n event.tags = { ...event.tags, 'DOMException.code': `${domException.code}` };\n }\n\n return event;\n }\n if (isError(exception)) {\n // we have a real Error object, do nothing\n return eventFromError(stackParser, exception);\n }\n if (isPlainObject(exception) || isEvent(exception)) {\n // If it's a plain object or an instance of `Event` (the built-in JS kind, not this SDK's `Event` type), serialize\n // it manually. This will allow us to group events based on top-level keys which is much better than creating a new\n // group on any key/value change.\n const objectException = exception as Record<string, unknown>;\n event = eventFromPlainObject(stackParser, objectException, syntheticException, isUnhandledRejection);\n addExceptionMechanism(event, {\n synthetic: true,\n });\n return event;\n }\n\n // If none of previous checks were valid, then it means that it's not:\n // - an instance of DOMError\n // - an instance of DOMException\n // - an instance of Event\n // - an instance of Error\n // - a valid ErrorEvent (one with an error property)\n // - a plain Object\n //\n // So bail out and capture it as a simple message:\n event = eventFromString(stackParser, exception as string, syntheticException, attachStacktrace);\n addExceptionTypeValue(event, `${exception}`, undefined);\n addExceptionMechanism(event, {\n synthetic: true,\n });\n\n return event;\n}\n\n/**\n * @hidden\n */\nexport function eventFromString(\n stackParser: StackParser,\n input: string,\n syntheticException?: Error,\n attachStacktrace?: boolean,\n): Event {\n const event: Event = {\n message: input,\n };\n\n if (attachStacktrace && syntheticException) {\n const frames = parseStackFrames(stackParser, syntheticException);\n if (frames.length) {\n event.exception = {\n values: [{ value: input, stacktrace: { frames } }],\n };\n }\n }\n\n return event;\n}\n\nfunction getNonErrorObjectExceptionValue(\n exception: Record<string, unknown>,\n { isUnhandledRejection }: { isUnhandledRejection?: boolean },\n): string {\n const keys = extractExceptionKeysForMessage(exception);\n const captureType = isUnhandledRejection ? 'promise rejection' : 'exception';\n\n // Some ErrorEvent instances do not have an `error` property, which is why they are not handled before\n // We still want to try to get a decent message for these cases\n if (isErrorEvent(exception)) {\n return `Event \\`ErrorEvent\\` captured as ${captureType} with message \\`${exception.message}\\``;\n }\n\n if (isEvent(exception)) {\n const className = getObjectClassName(exception);\n return `Event \\`${className}\\` (type=${exception.type}) captured as ${captureType}`;\n }\n\n return `Object captured as ${captureType} with keys: ${keys}`;\n}\n\nfunction getObjectClassName(obj: unknown): string | undefined | void {\n try {\n const prototype: Prototype | null = Object.getPrototypeOf(obj);\n return prototype ? prototype.constructor.name : undefined;\n } catch (e) {\n // ignore errors here\n }\n}\n", "import type { DsnComponents, EventEnvelope, SdkMetadata, UserFeedback, UserFeedbackItem } from '@sentry/types';\nimport { createEnvelope, dsnToString } from '@sentry/utils';\n\n/**\n * Creates an envelope from a user feedback.\n */\nexport function createUserFeedbackEnvelope(\n feedback: UserFeedback,\n {\n metadata,\n tunnel,\n dsn,\n }: {\n metadata: SdkMetadata | undefined;\n tunnel: string | undefined;\n dsn: DsnComponents | undefined;\n },\n): EventEnvelope {\n const headers: EventEnvelope[0] = {\n event_id: feedback.event_id,\n sent_at: new Date().toISOString(),\n ...(metadata &&\n metadata.sdk && {\n sdk: {\n name: metadata.sdk.name,\n version: metadata.sdk.version,\n },\n }),\n ...(!!tunnel && !!dsn && { dsn: dsnToString(dsn) }),\n };\n const item = createUserFeedbackEnvelopeItem(feedback);\n\n return createEnvelope(headers, [item]);\n}\n\nfunction createUserFeedbackEnvelopeItem(feedback: UserFeedback): UserFeedbackItem {\n const feedbackHeaders: UserFeedbackItem[0] = {\n type: 'user_report',\n };\n return [feedbackHeaders, feedback];\n}\n", "import type { Scope } from '@sentry/core';\nimport { BaseClient, SDK_VERSION } from '@sentry/core';\nimport type {\n BrowserClientProfilingOptions,\n BrowserClientReplayOptions,\n ClientOptions,\n Event,\n EventHint,\n Options,\n Severity,\n SeverityLevel,\n UserFeedback,\n} from '@sentry/types';\nimport { createClientReportEnvelope, dsnToString, getSDKSource, logger } from '@sentry/utils';\n\nimport { eventFromException, eventFromMessage } from './eventbuilder';\nimport { WINDOW } from './helpers';\nimport type { BrowserTransportOptions } from './transports/types';\nimport { createUserFeedbackEnvelope } from './userfeedback';\n\n/**\n * Configuration options for the Sentry Browser SDK.\n * @see @sentry/types Options for more information.\n */\nexport type BrowserOptions = Options<BrowserTransportOptions> &\n BrowserClientReplayOptions &\n BrowserClientProfilingOptions;\n\n/**\n * Configuration options for the Sentry Browser SDK Client class\n * @see BrowserClient for more information.\n */\nexport type BrowserClientOptions = ClientOptions<BrowserTransportOptions> &\n BrowserClientReplayOptions &\n BrowserClientProfilingOptions;\n\n/**\n * The Sentry Browser SDK Client.\n *\n * @see BrowserOptions for documentation on configuration options.\n * @see SentryClient for usage documentation.\n */\nexport class BrowserClient extends BaseClient<BrowserClientOptions> {\n /**\n * Creates a new Browser SDK instance.\n *\n * @param options Configuration options for this SDK.\n */\n public constructor(options: BrowserClientOptions) {\n const sdkSource = WINDOW.SENTRY_SDK_SOURCE || getSDKSource();\n\n options._metadata = options._metadata || {};\n options._metadata.sdk = options._metadata.sdk || {\n name: 'sentry.javascript.browser',\n packages: [\n {\n name: `${sdkSource}:@sentry/browser`,\n version: SDK_VERSION,\n },\n ],\n version: SDK_VERSION,\n };\n\n super(options);\n\n if (options.sendClientReports && WINDOW.document) {\n WINDOW.document.addEventListener('visibilitychange', () => {\n if (WINDOW.document.visibilityState === 'hidden') {\n this._flushOutcomes();\n }\n });\n }\n }\n\n /**\n * @inheritDoc\n */\n public eventFromException(exception: unknown, hint?: EventHint): PromiseLike<Event> {\n return eventFromException(this._options.stackParser, exception, hint, this._options.attachStacktrace);\n }\n\n /**\n * @inheritDoc\n */\n public eventFromMessage(\n message: string,\n // eslint-disable-next-line deprecation/deprecation\n level: Severity | SeverityLevel = 'info',\n hint?: EventHint,\n ): PromiseLike<Event> {\n return eventFromMessage(this._options.stackParser, message, level, hint, this._options.attachStacktrace);\n }\n\n /**\n * Sends user feedback to Sentry.\n */\n public captureUserFeedback(feedback: UserFeedback): void {\n if (!this._isEnabled()) {\n __DEBUG_BUILD__ && logger.warn('SDK not enabled, will not capture user feedback.');\n return;\n }\n\n const envelope = createUserFeedbackEnvelope(feedback, {\n metadata: this.getSdkMetadata(),\n dsn: this.getDsn(),\n tunnel: this.getOptions().tunnel,\n });\n void this._sendEnvelope(envelope);\n }\n\n /**\n * @inheritDoc\n */\n protected _prepareEvent(event: Event, hint: EventHint, scope?: Scope): PromiseLike<Event | null> {\n event.platform = event.platform || 'javascript';\n return super._prepareEvent(event, hint, scope);\n }\n\n /**\n * Sends client reports as an envelope.\n */\n private _flushOutcomes(): void {\n const outcomes = this._clearOutcomes();\n\n if (outcomes.length === 0) {\n __DEBUG_BUILD__ && logger.log('No outcomes to send');\n return;\n }\n\n // This is really the only place where we want to check for a DSN and only send outcomes then\n if (!this._dsn) {\n __DEBUG_BUILD__ && logger.log('No dsn provided, will not send outcomes');\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('Sending outcomes:', outcomes);\n\n const envelope = createClientReportEnvelope(outcomes, this._options.tunnel && dsnToString(this._dsn));\n void this._sendEnvelope(envelope);\n }\n}\n", "import { isNativeFetch, logger } from '@sentry/utils';\n\nimport { WINDOW } from '../helpers';\n\nlet cachedFetchImpl: FetchImpl | undefined = undefined;\n\nexport type FetchImpl = typeof fetch;\n\n/**\n * A special usecase for incorrectly wrapped Fetch APIs in conjunction with ad-blockers.\n * Whenever someone wraps the Fetch API and returns the wrong promise chain,\n * this chain becomes orphaned and there is no possible way to capture it's rejections\n * other than allowing it bubble up to this very handler. eg.\n *\n * const f = window.fetch;\n * window.fetch = function () {\n * const p = f.apply(this, arguments);\n *\n * p.then(function() {\n * console.log('hi.');\n * });\n *\n * return p;\n * }\n *\n * `p.then(function () { ... })` is producing a completely separate promise chain,\n * however, what's returned is `p` - the result of original `fetch` call.\n *\n * This mean, that whenever we use the Fetch API to send our own requests, _and_\n * some ad-blocker blocks it, this orphaned chain will _always_ reject,\n * effectively causing another event to be captured.\n * This makes a whole process become an infinite loop, which we need to somehow\n * deal with, and break it in one way or another.\n *\n * To deal with this issue, we are making sure that we _always_ use the real\n * browser Fetch API, instead of relying on what `window.fetch` exposes.\n * The only downside to this would be missing our own requests as breadcrumbs,\n * but because we are already not doing this, it should be just fine.\n *\n * Possible failed fetch error messages per-browser:\n *\n * Chrome: Failed to fetch\n * Edge: Failed to Fetch\n * Firefox: NetworkError when attempting to fetch resource\n * Safari: resource blocked by content blocker\n */\nexport function getNativeFetchImplementation(): FetchImpl {\n if (cachedFetchImpl) {\n return cachedFetchImpl;\n }\n\n /* eslint-disable @typescript-eslint/unbound-method */\n\n // Fast path to avoid DOM I/O\n if (isNativeFetch(WINDOW.fetch)) {\n return (cachedFetchImpl = WINDOW.fetch.bind(WINDOW));\n }\n\n const document = WINDOW.document;\n let fetchImpl = WINDOW.fetch;\n // eslint-disable-next-line deprecation/deprecation\n if (document && typeof document.createElement === 'function') {\n try {\n const sandbox = document.createElement('iframe');\n sandbox.hidden = true;\n document.head.appendChild(sandbox);\n const contentWindow = sandbox.contentWindow;\n if (contentWindow && contentWindow.fetch) {\n fetchImpl = contentWindow.fetch;\n }\n document.head.removeChild(sandbox);\n } catch (e) {\n __DEBUG_BUILD__ &&\n logger.warn('Could not create sandbox iframe for pure fetch check, bailing to window.fetch: ', e);\n }\n }\n\n return (cachedFetchImpl = fetchImpl.bind(WINDOW));\n /* eslint-enable @typescript-eslint/unbound-method */\n}\n\n/** Clears cached fetch impl */\nexport function clearCachedFetchImplementation(): void {\n cachedFetchImpl = undefined;\n}\n", "import { createTransport } from '@sentry/core';\nimport type { Transport, TransportMakeRequestResponse, TransportRequest } from '@sentry/types';\nimport { rejectedSyncPromise } from '@sentry/utils';\n\nimport type { BrowserTransportOptions } from './types';\nimport type { FetchImpl } from './utils';\nimport { clearCachedFetchImplementation, getNativeFetchImplementation } from './utils';\n\n/**\n * Creates a Transport that uses the Fetch API to send events to Sentry.\n */\nexport function makeFetchTransport(\n options: BrowserTransportOptions,\n nativeFetch: FetchImpl = getNativeFetchImplementation(),\n): Transport {\n let pendingBodySize = 0;\n let pendingCount = 0;\n\n function makeRequest(request: TransportRequest): PromiseLike<TransportMakeRequestResponse> {\n const requestSize = request.body.length;\n pendingBodySize += requestSize;\n pendingCount++;\n\n const requestOptions: RequestInit = {\n body: request.body,\n method: 'POST',\n referrerPolicy: 'origin',\n headers: options.headers,\n // Outgoing requests are usually cancelled when navigating to a different page, causing a \"TypeError: Failed to\n // fetch\" error and sending a \"network_error\" client-outcome - in Chrome, the request status shows \"(cancelled)\".\n // The `keepalive` flag keeps outgoing requests alive, even when switching pages. We want this since we're\n // frequently sending events right before the user is switching pages (eg. whenfinishing navigation transactions).\n // Gotchas:\n // - `keepalive` isn't supported by Firefox\n // - As per spec (https://fetch.spec.whatwg.org/#http-network-or-cache-fetch):\n // If the sum of contentLength and inflightKeepaliveBytes is greater than 64 kibibytes, then return a network error.\n // We will therefore only activate the flag when we're below that limit.\n // There is also a limit of requests that can be open at the same time, so we also limit this to 15\n // See https://github.com/getsentry/sentry-javascript/pull/7553 for details\n keepalive: pendingBodySize <= 60_000 && pendingCount < 15,\n ...options.fetchOptions,\n };\n\n try {\n return nativeFetch(options.url, requestOptions).then(response => {\n pendingBodySize -= requestSize;\n pendingCount--;\n return {\n statusCode: response.status,\n headers: {\n 'x-sentry-rate-limits': response.headers.get('X-Sentry-Rate-Limits'),\n 'retry-after': response.headers.get('Retry-After'),\n },\n };\n });\n } catch (e) {\n clearCachedFetchImplementation();\n pendingBodySize -= requestSize;\n pendingCount--;\n return rejectedSyncPromise(e);\n }\n }\n\n return createTransport(options, makeRequest);\n}\n", "import { createTransport } from '@sentry/core';\nimport type { Transport, TransportMakeRequestResponse, TransportRequest } from '@sentry/types';\nimport { SyncPromise } from '@sentry/utils';\n\nimport type { BrowserTransportOptions } from './types';\n\n/**\n * The DONE ready state for XmlHttpRequest\n *\n * Defining it here as a constant b/c XMLHttpRequest.DONE is not always defined\n * (e.g. during testing, it is `undefined`)\n *\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/readyState}\n */\nconst XHR_READYSTATE_DONE = 4;\n\n/**\n * Creates a Transport that uses the XMLHttpRequest API to send events to Sentry.\n */\nexport function makeXHRTransport(options: BrowserTransportOptions): Transport {\n function makeRequest(request: TransportRequest): PromiseLike<TransportMakeRequestResponse> {\n return new SyncPromise((resolve, reject) => {\n const xhr = new XMLHttpRequest();\n\n xhr.onerror = reject;\n\n xhr.onreadystatechange = (): void => {\n if (xhr.readyState === XHR_READYSTATE_DONE) {\n resolve({\n statusCode: xhr.status,\n headers: {\n 'x-sentry-rate-limits': xhr.getResponseHeader('X-Sentry-Rate-Limits'),\n 'retry-after': xhr.getResponseHeader('Retry-After'),\n },\n });\n }\n };\n\n xhr.open('POST', options.url);\n\n for (const header in options.headers) {\n if (Object.prototype.hasOwnProperty.call(options.headers, header)) {\n xhr.setRequestHeader(header, options.headers[header]);\n }\n }\n\n xhr.send(request.body);\n });\n }\n\n return createTransport(options, makeRequest);\n}\n", "// This was originally forked from https://github.com/csnover/TraceKit, and was largely\n// re - written as part of raven - js.\n//\n// This code was later copied to the JavaScript mono - repo and further modified and\n// refactored over the years.\n\n// Copyright (c) 2013 Onur Can Cakmak onur.cakmak@gmail.com and all TraceKit contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy of this\n// software and associated documentation files(the 'Software'), to deal in the Software\n// without restriction, including without limitation the rights to use, copy, modify,\n// merge, publish, distribute, sublicense, and / or sell copies of the Software, and to\n// permit persons to whom the Software is furnished to do so, subject to the following\n// conditions:\n//\n// The above copyright notice and this permission notice shall be included in all copies\n// or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,\n// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A\n// PARTICULAR PURPOSE AND NONINFRINGEMENT.IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT\n// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF\n// CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE\n// OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nimport type { StackFrame, StackLineParser, StackLineParserFn } from '@sentry/types';\nimport { createStackParser } from '@sentry/utils';\n\n// global reference to slice\nconst UNKNOWN_FUNCTION = '?';\n\nconst OPERA10_PRIORITY = 10;\nconst OPERA11_PRIORITY = 20;\nconst CHROME_PRIORITY = 30;\nconst WINJS_PRIORITY = 40;\nconst GECKO_PRIORITY = 50;\n\nfunction createFrame(filename: string, func: string, lineno?: number, colno?: number): StackFrame {\n const frame: StackFrame = {\n filename,\n function: func,\n in_app: true, // All browser frames are considered in_app\n };\n\n if (lineno !== undefined) {\n frame.lineno = lineno;\n }\n\n if (colno !== undefined) {\n frame.colno = colno;\n }\n\n return frame;\n}\n\n// Chromium based browsers: Chrome, Brave, new Opera, new Edge\nconst chromeRegex =\n /^\\s*at (?:(.+?\\)(?: \\[.+\\])?|.*?) ?\\((?:address at )?)?(?:async )?((?:<anonymous>|[-a-z]+:|.*bundle|\\/)?.*?)(?::(\\d+))?(?::(\\d+))?\\)?\\s*$/i;\nconst chromeEvalRegex = /\\((\\S*)(?::(\\d+))(?::(\\d+))\\)/;\n\nconst chrome: StackLineParserFn = line => {\n const parts = chromeRegex.exec(line);\n\n if (parts) {\n const isEval = parts[2] && parts[2].indexOf('eval') === 0; // start of line\n\n if (isEval) {\n const subMatch = chromeEvalRegex.exec(parts[2]);\n\n if (subMatch) {\n // throw out eval line/column and use top-most line/column number\n parts[2] = subMatch[1]; // url\n parts[3] = subMatch[2]; // line\n parts[4] = subMatch[3]; // column\n }\n }\n\n // Kamil: One more hack won't hurt us right? Understanding and adding more rules on top of these regexps right now\n // would be way too time consuming. (TODO: Rewrite whole RegExp to be more readable)\n const [func, filename] = extractSafariExtensionDetails(parts[1] || UNKNOWN_FUNCTION, parts[2]);\n\n return createFrame(filename, func, parts[3] ? +parts[3] : undefined, parts[4] ? +parts[4] : undefined);\n }\n\n return;\n};\n\nexport const chromeStackLineParser: StackLineParser = [CHROME_PRIORITY, chrome];\n\n// gecko regex: `(?:bundle|\\d+\\.js)`: `bundle` is for react native, `\\d+\\.js` also but specifically for ram bundles because it\n// generates filenames without a prefix like `file://` the filenames in the stacktrace are just 42.js\n// We need this specific case for now because we want no other regex to match.\nconst geckoREgex =\n /^\\s*(.*?)(?:\\((.*?)\\))?(?:^|@)?((?:[-a-z]+)?:\\/.*?|\\[native code\\]|[^@]*(?:bundle|\\d+\\.js)|\\/[\\w\\-. /=]+)(?::(\\d+))?(?::(\\d+))?\\s*$/i;\nconst geckoEvalRegex = /(\\S+) line (\\d+)(?: > eval line \\d+)* > eval/i;\n\nconst gecko: StackLineParserFn = line => {\n const parts = geckoREgex.exec(line);\n\n if (parts) {\n const isEval = parts[3] && parts[3].indexOf(' > eval') > -1;\n if (isEval) {\n const subMatch = geckoEvalRegex.exec(parts[3]);\n\n if (subMatch) {\n // throw out eval line/column and use top-most line number\n parts[1] = parts[1] || 'eval';\n parts[3] = subMatch[1];\n parts[4] = subMatch[2];\n parts[5] = ''; // no column when eval\n }\n }\n\n let filename = parts[3];\n let func = parts[1] || UNKNOWN_FUNCTION;\n [func, filename] = extractSafariExtensionDetails(func, filename);\n\n return createFrame(filename, func, parts[4] ? +parts[4] : undefined, parts[5] ? +parts[5] : undefined);\n }\n\n return;\n};\n\nexport const geckoStackLineParser: StackLineParser = [GECKO_PRIORITY, gecko];\n\nconst winjsRegex = /^\\s*at (?:((?:\\[object object\\])?.+) )?\\(?((?:[-a-z]+):.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nconst winjs: StackLineParserFn = line => {\n const parts = winjsRegex.exec(line);\n\n return parts\n ? createFrame(parts[2], parts[1] || UNKNOWN_FUNCTION, +parts[3], parts[4] ? +parts[4] : undefined)\n : undefined;\n};\n\nexport const winjsStackLineParser: StackLineParser = [WINJS_PRIORITY, winjs];\n\nconst opera10Regex = / line (\\d+).*script (?:in )?(\\S+)(?:: in function (\\S+))?$/i;\n\nconst opera10: StackLineParserFn = line => {\n const parts = opera10Regex.exec(line);\n return parts ? createFrame(parts[2], parts[3] || UNKNOWN_FUNCTION, +parts[1]) : undefined;\n};\n\nexport const opera10StackLineParser: StackLineParser = [OPERA10_PRIORITY, opera10];\n\nconst opera11Regex =\n / line (\\d+), column (\\d+)\\s*(?:in (?:<anonymous function: ([^>]+)>|([^)]+))\\(.*\\))? in (.*):\\s*$/i;\n\nconst opera11: StackLineParserFn = line => {\n const parts = opera11Regex.exec(line);\n return parts ? createFrame(parts[5], parts[3] || parts[4] || UNKNOWN_FUNCTION, +parts[1], +parts[2]) : undefined;\n};\n\nexport const opera11StackLineParser: StackLineParser = [OPERA11_PRIORITY, opera11];\n\nexport const defaultStackLineParsers = [chromeStackLineParser, geckoStackLineParser, winjsStackLineParser];\n\nexport const defaultStackParser = createStackParser(...defaultStackLineParsers);\n\n/**\n * Safari web extensions, starting version unknown, can produce \"frames-only\" stacktraces.\n * What it means, is that instead of format like:\n *\n * Error: wat\n * at function@url:row:col\n * at function@url:row:col\n * at function@url:row:col\n *\n * it produces something like:\n *\n * function@url:row:col\n * function@url:row:col\n * function@url:row:col\n *\n * Because of that, it won't be captured by `chrome` RegExp and will fall into `Gecko` branch.\n * This function is extracted so that we can use it in both places without duplicating the logic.\n * Unfortunately \"just\" changing RegExp is too complicated now and making it pass all tests\n * and fix this case seems like an impossible, or at least way too time-consuming task.\n */\nconst extractSafariExtensionDetails = (func: string, filename: string): [string, string] => {\n const isSafariExtension = func.indexOf('safari-extension') !== -1;\n const isSafariWebExtension = func.indexOf('safari-web-extension') !== -1;\n\n return isSafariExtension || isSafariWebExtension\n ? [\n func.indexOf('@') !== -1 ? func.split('@')[0] : UNKNOWN_FUNCTION,\n isSafariExtension ? `safari-extension:${filename}` : `safari-web-extension:${filename}`,\n ]\n : [func, filename];\n};\n", "/* eslint-disable @typescript-eslint/no-unsafe-member-access */\nimport { getCurrentHub } from '@sentry/core';\nimport type { Event, EventHint, Hub, Integration, Primitive, StackParser } from '@sentry/types';\nimport {\n addExceptionMechanism,\n addInstrumentationHandler,\n getLocationHref,\n isErrorEvent,\n isPrimitive,\n isString,\n logger,\n} from '@sentry/utils';\n\nimport type { BrowserClient } from '../client';\nimport { eventFromUnknownInput } from '../eventbuilder';\nimport { shouldIgnoreOnError } from '../helpers';\n\ntype GlobalHandlersIntegrationsOptionKeys = 'onerror' | 'onunhandledrejection';\n\n/** JSDoc */\ntype GlobalHandlersIntegrations = Record<GlobalHandlersIntegrationsOptionKeys, boolean>;\n\n/** Global handlers */\nexport class GlobalHandlers implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'GlobalHandlers';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /** JSDoc */\n private readonly _options: GlobalHandlersIntegrations;\n\n /**\n * Stores references functions to installing handlers. Will set to undefined\n * after they have been run so that they are not used twice.\n */\n private _installFunc: Record<GlobalHandlersIntegrationsOptionKeys, (() => void) | undefined>;\n\n /** JSDoc */\n public constructor(options?: GlobalHandlersIntegrations) {\n this.name = GlobalHandlers.id;\n this._options = {\n onerror: true,\n onunhandledrejection: true,\n ...options,\n };\n\n this._installFunc = {\n onerror: _installGlobalOnErrorHandler,\n onunhandledrejection: _installGlobalOnUnhandledRejectionHandler,\n };\n }\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n Error.stackTraceLimit = 50;\n const options = this._options;\n\n // We can disable guard-for-in as we construct the options object above + do checks against\n // `this._installFunc` for the property.\n // eslint-disable-next-line guard-for-in\n for (const key in options) {\n const installFunc = this._installFunc[key as GlobalHandlersIntegrationsOptionKeys];\n if (installFunc && options[key as GlobalHandlersIntegrationsOptionKeys]) {\n globalHandlerLog(key);\n installFunc();\n this._installFunc[key as GlobalHandlersIntegrationsOptionKeys] = undefined;\n }\n }\n }\n}\n\n/** JSDoc */\nfunction _installGlobalOnErrorHandler(): void {\n addInstrumentationHandler(\n 'error',\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (data: { msg: any; url: any; line: any; column: any; error: any }) => {\n const [hub, stackParser, attachStacktrace] = getHubAndOptions();\n if (!hub.getIntegration(GlobalHandlers)) {\n return;\n }\n const { msg, url, line, column, error } = data;\n if (shouldIgnoreOnError() || (error && error.__sentry_own_request__)) {\n return;\n }\n\n const event =\n error === undefined && isString(msg)\n ? _eventFromIncompleteOnError(msg, url, line, column)\n : _enhanceEventWithInitialFrame(\n eventFromUnknownInput(stackParser, error || msg, undefined, attachStacktrace, false),\n url,\n line,\n column,\n );\n\n event.level = 'error';\n\n addMechanismAndCapture(hub, error, event, 'onerror');\n },\n );\n}\n\n/** JSDoc */\nfunction _installGlobalOnUnhandledRejectionHandler(): void {\n addInstrumentationHandler(\n 'unhandledrejection',\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n (e: any) => {\n const [hub, stackParser, attachStacktrace] = getHubAndOptions();\n if (!hub.getIntegration(GlobalHandlers)) {\n return;\n }\n let error = e;\n\n // dig the object of the rejection out of known event types\n try {\n // PromiseRejectionEvents store the object of the rejection under 'reason'\n // see https://developer.mozilla.org/en-US/docs/Web/API/PromiseRejectionEvent\n if ('reason' in e) {\n error = e.reason;\n }\n // something, somewhere, (likely a browser extension) effectively casts PromiseRejectionEvents\n // to CustomEvents, moving the `promise` and `reason` attributes of the PRE into\n // the CustomEvent's `detail` attribute, since they're not part of CustomEvent's spec\n // see https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent and\n // https://github.com/getsentry/sentry-javascript/issues/2380\n else if ('detail' in e && 'reason' in e.detail) {\n error = e.detail.reason;\n }\n } catch (_oO) {\n // no-empty\n }\n\n if (shouldIgnoreOnError() || (error && error.__sentry_own_request__)) {\n return true;\n }\n\n const event = isPrimitive(error)\n ? _eventFromRejectionWithPrimitive(error)\n : eventFromUnknownInput(stackParser, error, undefined, attachStacktrace, true);\n\n event.level = 'error';\n\n addMechanismAndCapture(hub, error, event, 'onunhandledrejection');\n return;\n },\n );\n}\n\n/**\n * Create an event from a promise rejection where the `reason` is a primitive.\n *\n * @param reason: The `reason` property of the promise rejection\n * @returns An Event object with an appropriate `exception` value\n */\nfunction _eventFromRejectionWithPrimitive(reason: Primitive): Event {\n return {\n exception: {\n values: [\n {\n type: 'UnhandledRejection',\n // String() is needed because the Primitive type includes symbols (which can't be automatically stringified)\n value: `Non-Error promise rejection captured with value: ${String(reason)}`,\n },\n ],\n },\n };\n}\n\n/**\n * This function creates a stack from an old, error-less onerror handler.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _eventFromIncompleteOnError(msg: any, url: any, line: any, column: any): Event {\n const ERROR_TYPES_RE =\n /^(?:[Uu]ncaught (?:exception: )?)?(?:((?:Eval|Internal|Range|Reference|Syntax|Type|URI|)Error): )?(.*)$/i;\n\n // If 'message' is ErrorEvent, get real message from inside\n let message = isErrorEvent(msg) ? msg.message : msg;\n let name = 'Error';\n\n const groups = message.match(ERROR_TYPES_RE);\n if (groups) {\n name = groups[1];\n message = groups[2];\n }\n\n const event = {\n exception: {\n values: [\n {\n type: name,\n value: message,\n },\n ],\n },\n };\n\n return _enhanceEventWithInitialFrame(event, url, line, column);\n}\n\n/** JSDoc */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _enhanceEventWithInitialFrame(event: Event, url: any, line: any, column: any): Event {\n // event.exception\n const e = (event.exception = event.exception || {});\n // event.exception.values\n const ev = (e.values = e.values || []);\n // event.exception.values[0]\n const ev0 = (ev[0] = ev[0] || {});\n // event.exception.values[0].stacktrace\n const ev0s = (ev0.stacktrace = ev0.stacktrace || {});\n // event.exception.values[0].stacktrace.frames\n const ev0sf = (ev0s.frames = ev0s.frames || []);\n\n const colno = isNaN(parseInt(column, 10)) ? undefined : column;\n const lineno = isNaN(parseInt(line, 10)) ? undefined : line;\n const filename = isString(url) && url.length > 0 ? url : getLocationHref();\n\n // event.exception.values[0].stacktrace.frames\n if (ev0sf.length === 0) {\n ev0sf.push({\n colno,\n filename,\n function: '?',\n in_app: true,\n lineno,\n });\n }\n\n return event;\n}\n\nfunction globalHandlerLog(type: string): void {\n __DEBUG_BUILD__ && logger.log(`Global Handler attached: ${type}`);\n}\n\nfunction addMechanismAndCapture(hub: Hub, error: EventHint['originalException'], event: Event, type: string): void {\n addExceptionMechanism(event, {\n handled: false,\n type,\n });\n hub.captureEvent(event, {\n originalException: error,\n });\n}\n\nfunction getHubAndOptions(): [Hub, StackParser, boolean | undefined] {\n const hub = getCurrentHub();\n const client = hub.getClient<BrowserClient>();\n const options = (client && client.getOptions()) || {\n stackParser: () => [],\n attachStacktrace: false,\n };\n return [hub, options.stackParser, options.attachStacktrace];\n}\n", "import type { Integration, WrappedFunction } from '@sentry/types';\nimport { fill, getFunctionName, getOriginalFunction } from '@sentry/utils';\n\nimport { WINDOW, wrap } from '../helpers';\n\nconst DEFAULT_EVENT_TARGET = [\n 'EventTarget',\n 'Window',\n 'Node',\n 'ApplicationCache',\n 'AudioTrackList',\n 'BroadcastChannel',\n 'ChannelMergerNode',\n 'CryptoOperation',\n 'EventSource',\n 'FileReader',\n 'HTMLUnknownElement',\n 'IDBDatabase',\n 'IDBRequest',\n 'IDBTransaction',\n 'KeyOperation',\n 'MediaController',\n 'MessagePort',\n 'ModalWindow',\n 'Notification',\n 'SVGElementInstance',\n 'Screen',\n 'SharedWorker',\n 'TextTrack',\n 'TextTrackCue',\n 'TextTrackList',\n 'WebSocket',\n 'WebSocketWorker',\n 'Worker',\n 'XMLHttpRequest',\n 'XMLHttpRequestEventTarget',\n 'XMLHttpRequestUpload',\n];\n\ntype XMLHttpRequestProp = 'onload' | 'onerror' | 'onprogress' | 'onreadystatechange';\n\n/** JSDoc */\ninterface TryCatchOptions {\n setTimeout: boolean;\n setInterval: boolean;\n requestAnimationFrame: boolean;\n XMLHttpRequest: boolean;\n eventTarget: boolean | string[];\n}\n\n/** Wrap timer functions and event targets to catch errors and provide better meta data */\nexport class TryCatch implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'TryCatch';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /** JSDoc */\n private readonly _options: TryCatchOptions;\n\n /**\n * @inheritDoc\n */\n public constructor(options?: Partial<TryCatchOptions>) {\n this.name = TryCatch.id;\n this._options = {\n XMLHttpRequest: true,\n eventTarget: true,\n requestAnimationFrame: true,\n setInterval: true,\n setTimeout: true,\n ...options,\n };\n }\n\n /**\n * Wrap timer functions and event targets to catch errors\n * and provide better metadata.\n */\n public setupOnce(): void {\n if (this._options.setTimeout) {\n fill(WINDOW, 'setTimeout', _wrapTimeFunction);\n }\n\n if (this._options.setInterval) {\n fill(WINDOW, 'setInterval', _wrapTimeFunction);\n }\n\n if (this._options.requestAnimationFrame) {\n fill(WINDOW, 'requestAnimationFrame', _wrapRAF);\n }\n\n if (this._options.XMLHttpRequest && 'XMLHttpRequest' in WINDOW) {\n fill(XMLHttpRequest.prototype, 'send', _wrapXHR);\n }\n\n const eventTargetOption = this._options.eventTarget;\n if (eventTargetOption) {\n const eventTarget = Array.isArray(eventTargetOption) ? eventTargetOption : DEFAULT_EVENT_TARGET;\n eventTarget.forEach(_wrapEventTarget);\n }\n }\n}\n\n/** JSDoc */\nfunction _wrapTimeFunction(original: () => void): () => number {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: any, ...args: any[]): number {\n const originalCallback = args[0];\n args[0] = wrap(originalCallback, {\n mechanism: {\n data: { function: getFunctionName(original) },\n handled: false,\n type: 'instrument',\n },\n });\n return original.apply(this, args);\n };\n}\n\n/** JSDoc */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _wrapRAF(original: any): (callback: () => void) => any {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: any, callback: () => void): () => void {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return original.apply(this, [\n wrap(callback, {\n mechanism: {\n data: {\n function: 'requestAnimationFrame',\n handler: getFunctionName(original),\n },\n handled: false,\n type: 'instrument',\n },\n }),\n ]);\n };\n}\n\n/** JSDoc */\nfunction _wrapXHR(originalSend: () => void): () => void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return function (this: XMLHttpRequest, ...args: any[]): void {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const xhr = this;\n const xmlHttpRequestProps: XMLHttpRequestProp[] = ['onload', 'onerror', 'onprogress', 'onreadystatechange'];\n\n xmlHttpRequestProps.forEach(prop => {\n if (prop in xhr && typeof xhr[prop] === 'function') {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n fill(xhr, prop, function (original: WrappedFunction): () => any {\n const wrapOptions = {\n mechanism: {\n data: {\n function: prop,\n handler: getFunctionName(original),\n },\n handled: false,\n type: 'instrument',\n },\n };\n\n // If Instrument integration has been called before TryCatch, get the name of original function\n const originalFunction = getOriginalFunction(original);\n if (originalFunction) {\n wrapOptions.mechanism.data.handler = getFunctionName(originalFunction);\n }\n\n // Otherwise wrap directly\n return wrap(original, wrapOptions);\n });\n }\n });\n\n return originalSend.apply(this, args);\n };\n}\n\n/** JSDoc */\nfunction _wrapEventTarget(target: string): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const globalObject = WINDOW as { [key: string]: any };\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n const proto = globalObject[target] && globalObject[target].prototype;\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, no-prototype-builtins\n if (!proto || !proto.hasOwnProperty || !proto.hasOwnProperty('addEventListener')) {\n return;\n }\n\n fill(proto, 'addEventListener', function (original: () => void): (\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ) => void {\n return function (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this: any,\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | AddEventListenerOptions,\n ): (eventName: string, fn: EventListenerObject, capture?: boolean, secure?: boolean) => void {\n try {\n if (typeof fn.handleEvent === 'function') {\n // ESlint disable explanation:\n // First, it is generally safe to call `wrap` with an unbound function. Furthermore, using `.bind()` would\n // introduce a bug here, because bind returns a new function that doesn't have our\n // flags(like __sentry_original__) attached. `wrap` checks for those flags to avoid unnecessary wrapping.\n // Without those flags, every call to addEventListener wraps the function again, causing a memory leak.\n // eslint-disable-next-line @typescript-eslint/unbound-method\n fn.handleEvent = wrap(fn.handleEvent, {\n mechanism: {\n data: {\n function: 'handleEvent',\n handler: getFunctionName(fn),\n target,\n },\n handled: false,\n type: 'instrument',\n },\n });\n }\n } catch (err) {\n // can sometimes get 'Permission denied to access property \"handle Event'\n }\n\n return original.apply(this, [\n eventName,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n wrap(fn as any as WrappedFunction, {\n mechanism: {\n data: {\n function: 'addEventListener',\n handler: getFunctionName(fn),\n target,\n },\n handled: false,\n type: 'instrument',\n },\n }),\n options,\n ]);\n };\n });\n\n fill(\n proto,\n 'removeEventListener',\n function (\n originalRemoveEventListener: () => void,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): (this: any, eventName: string, fn: EventListenerObject, options?: boolean | EventListenerOptions) => () => void {\n return function (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n this: any,\n eventName: string,\n fn: EventListenerObject,\n options?: boolean | EventListenerOptions,\n ): () => void {\n /**\n * There are 2 possible scenarios here:\n *\n * 1. Someone passes a callback, which was attached prior to Sentry initialization, or by using unmodified\n * method, eg. `document.addEventListener.call(el, name, handler). In this case, we treat this function\n * as a pass-through, and call original `removeEventListener` with it.\n *\n * 2. Someone passes a callback, which was attached after Sentry was initialized, which means that it was using\n * our wrapped version of `addEventListener`, which internally calls `wrap` helper.\n * This helper \"wraps\" whole callback inside a try/catch statement, and attached appropriate metadata to it,\n * in order for us to make a distinction between wrapped/non-wrapped functions possible.\n * If a function was wrapped, it has additional property of `__sentry_wrapped__`, holding the handler.\n *\n * When someone adds a handler prior to initialization, and then do it again, but after,\n * then we have to detach both of them. Otherwise, if we'd detach only wrapped one, it'd be impossible\n * to get rid of the initial handler and it'd stick there forever.\n */\n const wrappedEventHandler = fn as unknown as WrappedFunction;\n try {\n const originalEventHandler = wrappedEventHandler && wrappedEventHandler.__sentry_wrapped__;\n if (originalEventHandler) {\n originalRemoveEventListener.call(this, eventName, originalEventHandler, options);\n }\n } catch (e) {\n // ignore, accessing __sentry_wrapped__ will throw in some Selenium environments\n }\n return originalRemoveEventListener.call(this, eventName, wrappedEventHandler, options);\n };\n },\n );\n}\n", "/* eslint-disable @typescript-eslint/no-unsafe-member-access */\n/* eslint-disable max-lines */\nimport { getCurrentHub } from '@sentry/core';\nimport type { Event as SentryEvent, HandlerDataFetch, HandlerDataXhr, Integration } from '@sentry/types';\nimport type {\n FetchBreadcrumbData,\n FetchBreadcrumbHint,\n XhrBreadcrumbData,\n XhrBreadcrumbHint,\n} from '@sentry/types/build/types/breadcrumb';\nimport {\n addInstrumentationHandler,\n getEventDescription,\n htmlTreeAsString,\n logger,\n parseUrl,\n safeJoin,\n SENTRY_XHR_DATA_KEY,\n severityLevelFromString,\n} from '@sentry/utils';\n\nimport { WINDOW } from '../helpers';\n\ntype HandlerData = Record<string, unknown>;\n\n/** JSDoc */\ninterface BreadcrumbsOptions {\n console: boolean;\n dom:\n | boolean\n | {\n serializeAttribute?: string | string[];\n maxStringLength?: number;\n };\n fetch: boolean;\n history: boolean;\n sentry: boolean;\n xhr: boolean;\n}\n\n/** maxStringLength gets capped to prevent 100 breadcrumbs exceeding 1MB event payload size */\nconst MAX_ALLOWED_STRING_LENGTH = 1024;\n\n/**\n * Default Breadcrumbs instrumentations\n * TODO: Deprecated - with v6, this will be renamed to `Instrument`\n */\nexport class Breadcrumbs implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'Breadcrumbs';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /**\n * Options of the breadcrumbs integration.\n */\n // This field is public, because we use it in the browser client to check if the `sentry` option is enabled.\n public readonly options: Readonly<BreadcrumbsOptions>;\n\n /**\n * @inheritDoc\n */\n public constructor(options?: Partial<BreadcrumbsOptions>) {\n this.name = Breadcrumbs.id;\n this.options = {\n console: true,\n dom: true,\n fetch: true,\n history: true,\n sentry: true,\n xhr: true,\n ...options,\n };\n }\n\n /**\n * Instrument browser built-ins w/ breadcrumb capturing\n * - Console API\n * - DOM API (click/typing)\n * - XMLHttpRequest API\n * - Fetch API\n * - History API\n */\n public setupOnce(): void {\n if (this.options.console) {\n addInstrumentationHandler('console', _consoleBreadcrumb);\n }\n if (this.options.dom) {\n addInstrumentationHandler('dom', _domBreadcrumb(this.options.dom));\n }\n if (this.options.xhr) {\n addInstrumentationHandler('xhr', _xhrBreadcrumb);\n }\n if (this.options.fetch) {\n addInstrumentationHandler('fetch', _fetchBreadcrumb);\n }\n if (this.options.history) {\n addInstrumentationHandler('history', _historyBreadcrumb);\n }\n if (this.options.sentry) {\n const client = getCurrentHub().getClient();\n client && client.on && client.on('beforeSendEvent', addSentryBreadcrumb);\n }\n }\n}\n\n/**\n * Adds a breadcrumb for Sentry events or transactions if this option is enabled.\n */\nfunction addSentryBreadcrumb(event: SentryEvent): void {\n getCurrentHub().addBreadcrumb(\n {\n category: `sentry.${event.type === 'transaction' ? 'transaction' : 'event'}`,\n event_id: event.event_id,\n level: event.level,\n message: getEventDescription(event),\n },\n {\n event,\n },\n );\n}\n\n/**\n * A HOC that creaes a function that creates breadcrumbs from DOM API calls.\n * This is a HOC so that we get access to dom options in the closure.\n */\nfunction _domBreadcrumb(dom: BreadcrumbsOptions['dom']): (handlerData: HandlerData) => void {\n function _innerDomBreadcrumb(handlerData: HandlerData): void {\n let target;\n let keyAttrs = typeof dom === 'object' ? dom.serializeAttribute : undefined;\n\n let maxStringLength =\n typeof dom === 'object' && typeof dom.maxStringLength === 'number' ? dom.maxStringLength : undefined;\n if (maxStringLength && maxStringLength > MAX_ALLOWED_STRING_LENGTH) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `\\`dom.maxStringLength\\` cannot exceed ${MAX_ALLOWED_STRING_LENGTH}, but a value of ${maxStringLength} was configured. Sentry will use ${MAX_ALLOWED_STRING_LENGTH} instead.`,\n );\n maxStringLength = MAX_ALLOWED_STRING_LENGTH;\n }\n\n if (typeof keyAttrs === 'string') {\n keyAttrs = [keyAttrs];\n }\n\n // Accessing event.target can throw (see getsentry/raven-js#838, #768)\n try {\n const event = handlerData.event as Event | Node;\n target = _isEvent(event)\n ? htmlTreeAsString(event.target, { keyAttrs, maxStringLength })\n : htmlTreeAsString(event, { keyAttrs, maxStringLength });\n } catch (e) {\n target = '<unknown>';\n }\n\n if (target.length === 0) {\n return;\n }\n\n getCurrentHub().addBreadcrumb(\n {\n category: `ui.${handlerData.name}`,\n message: target,\n },\n {\n event: handlerData.event,\n name: handlerData.name,\n global: handlerData.global,\n },\n );\n }\n\n return _innerDomBreadcrumb;\n}\n\n/**\n * Creates breadcrumbs from console API calls\n */\nfunction _consoleBreadcrumb(handlerData: HandlerData & { args: unknown[]; level: string }): void {\n const breadcrumb = {\n category: 'console',\n data: {\n arguments: handlerData.args,\n logger: 'console',\n },\n level: severityLevelFromString(handlerData.level),\n message: safeJoin(handlerData.args, ' '),\n };\n\n if (handlerData.level === 'assert') {\n if (handlerData.args[0] === false) {\n breadcrumb.message = `Assertion failed: ${safeJoin(handlerData.args.slice(1), ' ') || 'console.assert'}`;\n breadcrumb.data.arguments = handlerData.args.slice(1);\n } else {\n // Don't capture a breadcrumb for passed assertions\n return;\n }\n }\n\n getCurrentHub().addBreadcrumb(breadcrumb, {\n input: handlerData.args,\n level: handlerData.level,\n });\n}\n\n/**\n * Creates breadcrumbs from XHR API calls\n */\nfunction _xhrBreadcrumb(handlerData: HandlerData & HandlerDataXhr): void {\n const { startTimestamp, endTimestamp } = handlerData;\n\n const sentryXhrData = handlerData.xhr[SENTRY_XHR_DATA_KEY];\n\n // We only capture complete, non-sentry requests\n if (!startTimestamp || !endTimestamp || !sentryXhrData) {\n return;\n }\n\n const { method, url, status_code, body } = sentryXhrData;\n\n const data: XhrBreadcrumbData = {\n method,\n url,\n status_code,\n };\n\n const hint: XhrBreadcrumbHint = {\n xhr: handlerData.xhr,\n input: body,\n startTimestamp,\n endTimestamp,\n };\n\n getCurrentHub().addBreadcrumb(\n {\n category: 'xhr',\n data,\n type: 'http',\n },\n hint,\n );\n}\n\n/**\n * Creates breadcrumbs from fetch API calls\n */\nfunction _fetchBreadcrumb(handlerData: HandlerData & HandlerDataFetch & { response?: Response }): void {\n const { startTimestamp, endTimestamp } = handlerData;\n\n // We only capture complete fetch requests\n if (!endTimestamp) {\n return;\n }\n\n if (handlerData.fetchData.url.match(/sentry_key/) && handlerData.fetchData.method === 'POST') {\n // We will not create breadcrumbs for fetch requests that contain `sentry_key` (internal sentry requests)\n return;\n }\n\n if (handlerData.error) {\n const data: FetchBreadcrumbData = handlerData.fetchData;\n const hint: FetchBreadcrumbHint = {\n data: handlerData.error,\n input: handlerData.args,\n startTimestamp,\n endTimestamp,\n };\n\n getCurrentHub().addBreadcrumb(\n {\n category: 'fetch',\n data,\n level: 'error',\n type: 'http',\n },\n hint,\n );\n } else {\n const data: FetchBreadcrumbData = {\n ...handlerData.fetchData,\n status_code: handlerData.response && handlerData.response.status,\n };\n const hint: FetchBreadcrumbHint = {\n input: handlerData.args,\n response: handlerData.response,\n startTimestamp,\n endTimestamp,\n };\n getCurrentHub().addBreadcrumb(\n {\n category: 'fetch',\n data,\n type: 'http',\n },\n hint,\n );\n }\n}\n\n/**\n * Creates breadcrumbs from history API calls\n */\nfunction _historyBreadcrumb(handlerData: HandlerData & { from: string; to: string }): void {\n let from: string | undefined = handlerData.from;\n let to: string | undefined = handlerData.to;\n const parsedLoc = parseUrl(WINDOW.location.href);\n let parsedFrom = parseUrl(from);\n const parsedTo = parseUrl(to);\n\n // Initial pushState doesn't provide `from` information\n if (!parsedFrom.path) {\n parsedFrom = parsedLoc;\n }\n\n // Use only the path component of the URL if the URL matches the current\n // document (almost all the time when using pushState)\n if (parsedLoc.protocol === parsedTo.protocol && parsedLoc.host === parsedTo.host) {\n to = parsedTo.relative;\n }\n if (parsedLoc.protocol === parsedFrom.protocol && parsedLoc.host === parsedFrom.host) {\n from = parsedFrom.relative;\n }\n\n getCurrentHub().addBreadcrumb({\n category: 'navigation',\n data: {\n from,\n to,\n },\n });\n}\n\nfunction _isEvent(event: unknown): event is Event {\n return !!event && !!(event as Record<string, unknown>).target;\n}\n", "import type { Client, Event, EventHint, Integration } from '@sentry/types';\nimport { applyAggregateErrorsToEvent } from '@sentry/utils';\n\nimport { exceptionFromError } from '../eventbuilder';\n\nconst DEFAULT_KEY = 'cause';\nconst DEFAULT_LIMIT = 5;\n\ninterface LinkedErrorsOptions {\n key: string;\n limit: number;\n}\n\n/** Adds SDK info to an event. */\nexport class LinkedErrors implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'LinkedErrors';\n\n /**\n * @inheritDoc\n */\n public readonly name: string;\n\n /**\n * @inheritDoc\n */\n private readonly _key: LinkedErrorsOptions['key'];\n\n /**\n * @inheritDoc\n */\n private readonly _limit: LinkedErrorsOptions['limit'];\n\n /**\n * @inheritDoc\n */\n public constructor(options: Partial<LinkedErrorsOptions> = {}) {\n this.name = LinkedErrors.id;\n this._key = options.key || DEFAULT_KEY;\n this._limit = options.limit || DEFAULT_LIMIT;\n }\n\n /** @inheritdoc */\n public setupOnce(): void {\n // noop\n }\n\n /**\n * @inheritDoc\n */\n public preprocessEvent(event: Event, hint: EventHint | undefined, client: Client): void {\n const options = client.getOptions();\n\n applyAggregateErrorsToEvent(\n exceptionFromError,\n options.stackParser,\n options.maxValueLength,\n this._key,\n this._limit,\n event,\n hint,\n );\n }\n}\n", "import type { Event, Integration } from '@sentry/types';\n\nimport { WINDOW } from '../helpers';\n\n/** HttpContext integration collects information about HTTP request headers */\nexport class HttpContext implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'HttpContext';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n public constructor() {\n this.name = HttpContext.id;\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(): void {\n // noop\n }\n\n /** @inheritDoc */\n public preprocessEvent(event: Event): void {\n // if none of the information we want exists, don't bother\n if (!WINDOW.navigator && !WINDOW.location && !WINDOW.document) {\n return;\n }\n\n // grab as much info as exists and add it to the event\n const url = (event.request && event.request.url) || (WINDOW.location && WINDOW.location.href);\n const { referrer } = WINDOW.document || {};\n const { userAgent } = WINDOW.navigator || {};\n\n const headers = {\n ...(event.request && event.request.headers),\n ...(referrer && { Referer: referrer }),\n ...(userAgent && { 'User-Agent': userAgent }),\n };\n const request = { ...event.request, ...(url && { url }), headers };\n\n event.request = request;\n }\n}\n", "import type { Event, Exception, Integration, StackFrame } from '@sentry/types';\nimport { logger } from '@sentry/utils';\n\n/** Deduplication filter */\nexport class Dedupe implements Integration {\n /**\n * @inheritDoc\n */\n public static id: string = 'Dedupe';\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n /**\n * @inheritDoc\n */\n private _previousEvent?: Event;\n\n public constructor() {\n this.name = Dedupe.id;\n }\n\n /** @inheritDoc */\n public setupOnce(_addGlobaleventProcessor: unknown, _getCurrentHub: unknown): void {\n // noop\n }\n\n /**\n * @inheritDoc\n */\n public processEvent(currentEvent: Event): Event | null {\n // We want to ignore any non-error type events, e.g. transactions or replays\n // These should never be deduped, and also not be compared against as _previousEvent.\n if (currentEvent.type) {\n return currentEvent;\n }\n\n // Juuust in case something goes wrong\n try {\n if (_shouldDropEvent(currentEvent, this._previousEvent)) {\n __DEBUG_BUILD__ && logger.warn('Event dropped due to being a duplicate of previously captured event.');\n return null;\n }\n } catch (_oO) {} // eslint-disable-line no-empty\n\n return (this._previousEvent = currentEvent);\n }\n}\n\n/** JSDoc */\nfunction _shouldDropEvent(currentEvent: Event, previousEvent?: Event): boolean {\n if (!previousEvent) {\n return false;\n }\n\n if (_isSameMessageEvent(currentEvent, previousEvent)) {\n return true;\n }\n\n if (_isSameExceptionEvent(currentEvent, previousEvent)) {\n return true;\n }\n\n return false;\n}\n\n/** JSDoc */\nfunction _isSameMessageEvent(currentEvent: Event, previousEvent: Event): boolean {\n const currentMessage = currentEvent.message;\n const previousMessage = previousEvent.message;\n\n // If neither event has a message property, they were both exceptions, so bail out\n if (!currentMessage && !previousMessage) {\n return false;\n }\n\n // If only one event has a stacktrace, but not the other one, they are not the same\n if ((currentMessage && !previousMessage) || (!currentMessage && previousMessage)) {\n return false;\n }\n\n if (currentMessage !== previousMessage) {\n return false;\n }\n\n if (!_isSameFingerprint(currentEvent, previousEvent)) {\n return false;\n }\n\n if (!_isSameStacktrace(currentEvent, previousEvent)) {\n return false;\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameExceptionEvent(currentEvent: Event, previousEvent: Event): boolean {\n const previousException = _getExceptionFromEvent(previousEvent);\n const currentException = _getExceptionFromEvent(currentEvent);\n\n if (!previousException || !currentException) {\n return false;\n }\n\n if (previousException.type !== currentException.type || previousException.value !== currentException.value) {\n return false;\n }\n\n if (!_isSameFingerprint(currentEvent, previousEvent)) {\n return false;\n }\n\n if (!_isSameStacktrace(currentEvent, previousEvent)) {\n return false;\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameStacktrace(currentEvent: Event, previousEvent: Event): boolean {\n let currentFrames = _getFramesFromEvent(currentEvent);\n let previousFrames = _getFramesFromEvent(previousEvent);\n\n // If neither event has a stacktrace, they are assumed to be the same\n if (!currentFrames && !previousFrames) {\n return true;\n }\n\n // If only one event has a stacktrace, but not the other one, they are not the same\n if ((currentFrames && !previousFrames) || (!currentFrames && previousFrames)) {\n return false;\n }\n\n currentFrames = currentFrames as StackFrame[];\n previousFrames = previousFrames as StackFrame[];\n\n // If number of frames differ, they are not the same\n if (previousFrames.length !== currentFrames.length) {\n return false;\n }\n\n // Otherwise, compare the two\n for (let i = 0; i < previousFrames.length; i++) {\n const frameA = previousFrames[i];\n const frameB = currentFrames[i];\n\n if (\n frameA.filename !== frameB.filename ||\n frameA.lineno !== frameB.lineno ||\n frameA.colno !== frameB.colno ||\n frameA.function !== frameB.function\n ) {\n return false;\n }\n }\n\n return true;\n}\n\n/** JSDoc */\nfunction _isSameFingerprint(currentEvent: Event, previousEvent: Event): boolean {\n let currentFingerprint = currentEvent.fingerprint;\n let previousFingerprint = previousEvent.fingerprint;\n\n // If neither event has a fingerprint, they are assumed to be the same\n if (!currentFingerprint && !previousFingerprint) {\n return true;\n }\n\n // If only one event has a fingerprint, but not the other one, they are not the same\n if ((currentFingerprint && !previousFingerprint) || (!currentFingerprint && previousFingerprint)) {\n return false;\n }\n\n currentFingerprint = currentFingerprint as string[];\n previousFingerprint = previousFingerprint as string[];\n\n // Otherwise, compare the two\n try {\n return !!(currentFingerprint.join('') === previousFingerprint.join(''));\n } catch (_oO) {\n return false;\n }\n}\n\n/** JSDoc */\nfunction _getExceptionFromEvent(event: Event): Exception | undefined {\n return event.exception && event.exception.values && event.exception.values[0];\n}\n\n/** JSDoc */\nfunction _getFramesFromEvent(event: Event): StackFrame[] | undefined {\n const exception = event.exception;\n\n if (exception) {\n try {\n // @ts-expect-error Object could be undefined\n return exception.values[0].stacktrace.frames;\n } catch (_oO) {\n return undefined;\n }\n }\n return undefined;\n}\n", "import type { Hub } from '@sentry/core';\nimport {\n getCurrentHub,\n getIntegrationsToSetup,\n getReportDialogEndpoint,\n initAndBind,\n Integrations as CoreIntegrations,\n} from '@sentry/core';\nimport type { UserFeedback } from '@sentry/types';\nimport { addInstrumentationHandler, logger, stackParserFromStackParserOptions, supportsFetch } from '@sentry/utils';\n\nimport type { BrowserClientOptions, BrowserOptions } from './client';\nimport { BrowserClient } from './client';\nimport type { ReportDialogOptions } from './helpers';\nimport { WINDOW, wrap as internalWrap } from './helpers';\nimport { Breadcrumbs, Dedupe, GlobalHandlers, HttpContext, LinkedErrors, TryCatch } from './integrations';\nimport { defaultStackParser } from './stack-parsers';\nimport { makeFetchTransport, makeXHRTransport } from './transports';\n\nexport const defaultIntegrations = [\n new CoreIntegrations.InboundFilters(),\n new CoreIntegrations.FunctionToString(),\n new TryCatch(),\n new Breadcrumbs(),\n new GlobalHandlers(),\n new LinkedErrors(),\n new Dedupe(),\n new HttpContext(),\n];\n\n/**\n * A magic string that build tooling can leverage in order to inject a release value into the SDK.\n */\ndeclare const __SENTRY_RELEASE__: string | undefined;\n\n/**\n * The Sentry Browser SDK Client.\n *\n * To use this SDK, call the {@link init} function as early as possible when\n * loading the web page. To set context information or send manual events, use\n * the provided methods.\n *\n * @example\n *\n * ```\n *\n * import { init } from '@sentry/browser';\n *\n * init({\n * dsn: '__DSN__',\n * // ...\n * });\n * ```\n *\n * @example\n * ```\n *\n * import { configureScope } from '@sentry/browser';\n * configureScope((scope: Scope) => {\n * scope.setExtra({ battery: 0.7 });\n * scope.setTag({ user_mode: 'admin' });\n * scope.setUser({ id: '4711' });\n * });\n * ```\n *\n * @example\n * ```\n *\n * import { addBreadcrumb } from '@sentry/browser';\n * addBreadcrumb({\n * message: 'My Breadcrumb',\n * // ...\n * });\n * ```\n *\n * @example\n *\n * ```\n *\n * import * as Sentry from '@sentry/browser';\n * Sentry.captureMessage('Hello, world!');\n * Sentry.captureException(new Error('Good bye'));\n * Sentry.captureEvent({\n * message: 'Manual',\n * stacktrace: [\n * // ...\n * ],\n * });\n * ```\n *\n * @see {@link BrowserOptions} for documentation on configuration options.\n */\nexport function init(options: BrowserOptions = {}): void {\n if (options.defaultIntegrations === undefined) {\n options.defaultIntegrations = defaultIntegrations;\n }\n if (options.release === undefined) {\n // This allows build tooling to find-and-replace __SENTRY_RELEASE__ to inject a release value\n if (typeof __SENTRY_RELEASE__ === 'string') {\n options.release = __SENTRY_RELEASE__;\n }\n\n // This supports the variable that sentry-webpack-plugin injects\n if (WINDOW.SENTRY_RELEASE && WINDOW.SENTRY_RELEASE.id) {\n options.release = WINDOW.SENTRY_RELEASE.id;\n }\n }\n if (options.autoSessionTracking === undefined) {\n options.autoSessionTracking = true;\n }\n if (options.sendClientReports === undefined) {\n options.sendClientReports = true;\n }\n\n const clientOptions: BrowserClientOptions = {\n ...options,\n stackParser: stackParserFromStackParserOptions(options.stackParser || defaultStackParser),\n integrations: getIntegrationsToSetup(options),\n transport: options.transport || (supportsFetch() ? makeFetchTransport : makeXHRTransport),\n };\n\n initAndBind(BrowserClient, clientOptions);\n\n if (options.autoSessionTracking) {\n startSessionTracking();\n }\n}\n\n/**\n * Present the user with a report dialog.\n *\n * @param options Everything is optional, we try to fetch all info need from the global scope.\n */\nexport function showReportDialog(options: ReportDialogOptions = {}, hub: Hub = getCurrentHub()): void {\n // doesn't work without a document (React Native)\n if (!WINDOW.document) {\n __DEBUG_BUILD__ && logger.error('Global document not defined in showReportDialog call');\n return;\n }\n\n const { client, scope } = hub.getStackTop();\n const dsn = options.dsn || (client && client.getDsn());\n if (!dsn) {\n __DEBUG_BUILD__ && logger.error('DSN not configured for showReportDialog call');\n return;\n }\n\n if (scope) {\n options.user = {\n ...scope.getUser(),\n ...options.user,\n };\n }\n\n if (!options.eventId) {\n options.eventId = hub.lastEventId();\n }\n\n const script = WINDOW.document.createElement('script');\n script.async = true;\n script.crossOrigin = 'anonymous';\n script.src = getReportDialogEndpoint(dsn, options);\n\n if (options.onLoad) {\n script.onload = options.onLoad;\n }\n\n const injectionPoint = WINDOW.document.head || WINDOW.document.body;\n if (injectionPoint) {\n injectionPoint.appendChild(script);\n } else {\n __DEBUG_BUILD__ && logger.error('Not injecting report dialog. No injection point found in HTML');\n }\n}\n\n/**\n * This function is here to be API compatible with the loader.\n * @hidden\n */\nexport function forceLoad(): void {\n // Noop\n}\n\n/**\n * This function is here to be API compatible with the loader.\n * @hidden\n */\nexport function onLoad(callback: () => void): void {\n callback();\n}\n\n/**\n * Wrap code within a try/catch block so the SDK is able to capture errors.\n *\n * @deprecated This function will be removed in v8.\n * It is not part of Sentry's official API and it's easily replaceable by using a try/catch block\n * and calling Sentry.captureException.\n *\n * @param fn A function to wrap.\n *\n * @returns The result of wrapped function call.\n */\n// TODO(v8): Remove this function\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function wrap(fn: (...args: any) => any): any {\n return internalWrap(fn)();\n}\n\nfunction startSessionOnHub(hub: Hub): void {\n hub.startSession({ ignoreDuration: true });\n hub.captureSession();\n}\n\n/**\n * Enable automatic Session Tracking for the initial page load.\n */\nfunction startSessionTracking(): void {\n if (typeof WINDOW.document === 'undefined') {\n __DEBUG_BUILD__ &&\n logger.warn('Session tracking in non-browser environment with @sentry/browser is not supported.');\n return;\n }\n\n const hub = getCurrentHub();\n\n // The only way for this to be false is for there to be a version mismatch between @sentry/browser (>= 6.0.0) and\n // @sentry/hub (< 5.27.0). In the simple case, there won't ever be such a mismatch, because the two packages are\n // pinned at the same version in package.json, but there are edge cases where it's possible. See\n // https://github.com/getsentry/sentry-javascript/issues/3207 and\n // https://github.com/getsentry/sentry-javascript/issues/3234 and\n // https://github.com/getsentry/sentry-javascript/issues/3278.\n if (!hub.captureSession) {\n return;\n }\n\n // The session duration for browser sessions does not track a meaningful\n // concept that can be used as a metric.\n // Automatically captured sessions are akin to page views, and thus we\n // discard their duration.\n startSessionOnHub(hub);\n\n // We want to create a session for every navigation as well\n addInstrumentationHandler('history', ({ from, to }) => {\n // Don't create an additional session for the initial route or if the location did not change\n if (!(from === undefined || from === to)) {\n startSessionOnHub(getCurrentHub());\n }\n });\n}\n\n/**\n * Captures user feedback and sends it to Sentry.\n */\nexport function captureUserFeedback(feedback: UserFeedback): void {\n const client = getCurrentHub().getClient<BrowserClient>();\n if (client) {\n client.captureUserFeedback(feedback);\n }\n}\n", "export { GlobalHandlers } from './globalhandlers.js';\nexport { TryCatch } from './trycatch.js';\nexport { Breadcrumbs } from './breadcrumbs.js';\nexport { LinkedErrors } from './linkederrors.js';\nexport { HttpContext } from './httpcontext.js';\nexport { Dedupe } from './dedupe.js';\n//# sourceMappingURL=index.js.map\n", "import { GLOBAL_OBJ } from '@sentry/utils';\n\nexport const WINDOW = GLOBAL_OBJ as typeof GLOBAL_OBJ & Window;\n", "import type { IdleTransaction, SpanStatusType } from '@sentry/core';\nimport { getActiveTransaction } from '@sentry/core';\nimport { logger } from '@sentry/utils';\n\nimport { WINDOW } from './types';\n\n/**\n * Add a listener that cancels and finishes a transaction when the global\n * document is hidden.\n */\nexport function registerBackgroundTabDetection(): void {\n if (WINDOW && WINDOW.document) {\n WINDOW.document.addEventListener('visibilitychange', () => {\n const activeTransaction = getActiveTransaction() as IdleTransaction;\n if (WINDOW.document.hidden && activeTransaction) {\n const statusType: SpanStatusType = 'cancelled';\n\n __DEBUG_BUILD__ &&\n logger.log(\n `[Tracing] Transaction: ${statusType} -> since tab moved to the background, op: ${activeTransaction.op}`,\n );\n // We should not set status if it is already set, this prevent important statuses like\n // error or data loss from being overwritten on transaction.\n if (!activeTransaction.status) {\n activeTransaction.setStatus(statusType);\n }\n activeTransaction.setTag('visibilitychange', 'document.hidden');\n activeTransaction.finish();\n }\n });\n } else {\n __DEBUG_BUILD__ &&\n logger.warn('[Tracing] Could not set up background tab detection due to lack of global document');\n }\n}\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { Metric, ReportCallback } from '../types';\n\nexport const bindReporter = (\n callback: ReportCallback,\n metric: Metric,\n reportAllChanges?: boolean,\n): ((forceReport?: boolean) => void) => {\n let prevValue: number;\n let delta: number;\n return (forceReport?: boolean) => {\n if (metric.value >= 0) {\n if (forceReport || reportAllChanges) {\n delta = metric.value - (prevValue || 0);\n\n // Report the metric if there's a non-zero delta or if no previous\n // value exists (which can happen in the case of the document becoming\n // hidden when the metric value is 0).\n // See: https://github.com/GoogleChrome/web-vitals/issues/14\n if (delta || prevValue === undefined) {\n prevValue = metric.value;\n metric.delta = delta;\n callback(metric);\n }\n }\n }\n };\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Performantly generate a unique, 30-char string by combining a version\n * number, the current timestamp with a 13-digit number integer.\n * @return {string}\n */\nexport const generateUniqueID = (): string => {\n return `v3-${Date.now()}-${Math.floor(Math.random() * (9e12 - 1)) + 1e12}`;\n};\n", "/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport type { NavigationTimingPolyfillEntry } from '../types';\n\nconst getNavigationEntryFromPerformanceTiming = (): NavigationTimingPolyfillEntry => {\n // eslint-disable-next-line deprecation/deprecation\n const timing = WINDOW.performance.timing;\n // eslint-disable-next-line deprecation/deprecation\n const type = WINDOW.performance.navigation.type;\n\n const navigationEntry: { [key: string]: number | string } = {\n entryType: 'navigation',\n startTime: 0,\n type: type == 2 ? 'back_forward' : type === 1 ? 'reload' : 'navigate',\n };\n\n for (const key in timing) {\n if (key !== 'navigationStart' && key !== 'toJSON') {\n // eslint-disable-next-line deprecation/deprecation\n navigationEntry[key] = Math.max((timing[key as keyof PerformanceTiming] as number) - timing.navigationStart, 0);\n }\n }\n return navigationEntry as unknown as NavigationTimingPolyfillEntry;\n};\n\nexport const getNavigationEntry = (): PerformanceNavigationTiming | NavigationTimingPolyfillEntry | undefined => {\n if (WINDOW.__WEB_VITALS_POLYFILL__) {\n return (\n WINDOW.performance &&\n ((performance.getEntriesByType && performance.getEntriesByType('navigation')[0]) ||\n getNavigationEntryFromPerformanceTiming())\n );\n } else {\n return WINDOW.performance && performance.getEntriesByType && performance.getEntriesByType('navigation')[0];\n }\n};\n", "/*\n * Copyright 2022 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getNavigationEntry } from './getNavigationEntry';\n\nexport const getActivationStart = (): number => {\n const navEntry = getNavigationEntry();\n return (navEntry && navEntry.activationStart) || 0;\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport type { Metric } from '../types';\nimport { generateUniqueID } from './generateUniqueID';\nimport { getActivationStart } from './getActivationStart';\nimport { getNavigationEntry } from './getNavigationEntry';\n\nexport const initMetric = (name: Metric['name'], value?: number): Metric => {\n const navEntry = getNavigationEntry();\n let navigationType: Metric['navigationType'] = 'navigate';\n\n if (navEntry) {\n if (WINDOW.document.prerendering || getActivationStart() > 0) {\n navigationType = 'prerender';\n } else {\n navigationType = navEntry.type.replace(/_/g, '-') as Metric['navigationType'];\n }\n }\n\n return {\n name,\n value: typeof value === 'undefined' ? -1 : value,\n rating: 'good', // Will be updated if the value changes.\n delta: 0,\n entries: [],\n id: generateUniqueID(),\n navigationType,\n };\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport type { FirstInputPolyfillEntry, NavigationTimingPolyfillEntry, PerformancePaintTiming } from '../types';\n\nexport interface PerformanceEntryHandler {\n (entry: PerformanceEntry): void;\n}\n\ninterface PerformanceEntryMap {\n event: PerformanceEventTiming[];\n paint: PerformancePaintTiming[];\n 'layout-shift': LayoutShift[];\n 'largest-contentful-paint': LargestContentfulPaint[];\n 'first-input': PerformanceEventTiming[] | FirstInputPolyfillEntry[];\n navigation: PerformanceNavigationTiming[] | NavigationTimingPolyfillEntry[];\n resource: PerformanceResourceTiming[];\n longtask: PerformanceEntry[];\n}\n\n/**\n * Takes a performance entry type and a callback function, and creates a\n * `PerformanceObserver` instance that will observe the specified entry type\n * with buffering enabled and call the callback _for each entry_.\n *\n * This function also feature-detects entry support and wraps the logic in a\n * try/catch to avoid errors in unsupporting browsers.\n */\nexport const observe = <K extends keyof PerformanceEntryMap>(\n type: K,\n callback: (entries: PerformanceEntryMap[K]) => void,\n opts?: PerformanceObserverInit,\n): PerformanceObserver | undefined => {\n try {\n if (PerformanceObserver.supportedEntryTypes.includes(type)) {\n const po = new PerformanceObserver(list => {\n callback(list.getEntries() as PerformanceEntryMap[K]);\n });\n po.observe(\n Object.assign(\n {\n type,\n buffered: true,\n },\n opts || {},\n ) as PerformanceObserverInit,\n );\n return po;\n }\n } catch (e) {\n // Do nothing.\n }\n return;\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\n\nexport interface OnHiddenCallback {\n (event: Event): void;\n}\n\nexport const onHidden = (cb: OnHiddenCallback, once?: boolean): void => {\n const onHiddenOrPageHide = (event: Event): void => {\n if (event.type === 'pagehide' || WINDOW.document.visibilityState === 'hidden') {\n cb(event);\n if (once) {\n removeEventListener('visibilitychange', onHiddenOrPageHide, true);\n removeEventListener('pagehide', onHiddenOrPageHide, true);\n }\n }\n };\n addEventListener('visibilitychange', onHiddenOrPageHide, true);\n // Some browsers have buggy implementations of visibilitychange,\n // so we use pagehide in addition, just to be safe.\n addEventListener('pagehide', onHiddenOrPageHide, true);\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { CLSMetric, ReportCallback, StopListening } from './types';\n\n/**\n * Calculates the [CLS](https://web.dev/cls/) value for the current page and\n * calls the `callback` function once the value is ready to be reported, along\n * with all `layout-shift` performance entries that were used in the metric\n * value calculation. The reported value is a `double` (corresponding to a\n * [layout shift score](https://web.dev/cls/#layout-shift-score)).\n *\n * If the `reportAllChanges` configuration option is set to `true`, the\n * `callback` function will be called as soon as the value is initially\n * determined as well as any time the value changes throughout the page\n * lifespan.\n *\n * _**Important:** CLS should be continually monitored for changes throughout\n * the entire lifespan of a page—including if the user returns to the page after\n * it's been hidden/backgrounded. However, since browsers often [will not fire\n * additional callbacks once the user has backgrounded a\n * page](https://developer.chrome.com/blog/page-lifecycle-api/#advice-hidden),\n * `callback` is always called when the page's visibility state changes to\n * hidden. As a result, the `callback` function might be called multiple times\n * during the same page load._\n */\nexport const onCLS = (onReport: ReportCallback): StopListening | undefined => {\n const metric = initMetric('CLS', 0);\n let report: ReturnType<typeof bindReporter>;\n\n let sessionValue = 0;\n let sessionEntries: PerformanceEntry[] = [];\n\n // const handleEntries = (entries: Metric['entries']) => {\n const handleEntries = (entries: LayoutShift[]): void => {\n entries.forEach(entry => {\n // Only count layout shifts without recent user input.\n if (!entry.hadRecentInput) {\n const firstSessionEntry = sessionEntries[0];\n const lastSessionEntry = sessionEntries[sessionEntries.length - 1];\n\n // If the entry occurred less than 1 second after the previous entry and\n // less than 5 seconds after the first entry in the session, include the\n // entry in the current session. Otherwise, start a new session.\n if (\n sessionValue &&\n sessionEntries.length !== 0 &&\n entry.startTime - lastSessionEntry.startTime < 1000 &&\n entry.startTime - firstSessionEntry.startTime < 5000\n ) {\n sessionValue += entry.value;\n sessionEntries.push(entry);\n } else {\n sessionValue = entry.value;\n sessionEntries = [entry];\n }\n\n // If the current session value is larger than the current CLS value,\n // update CLS and the entries contributing to it.\n if (sessionValue > metric.value) {\n metric.value = sessionValue;\n metric.entries = sessionEntries;\n if (report) {\n report();\n }\n }\n }\n });\n };\n\n const po = observe('layout-shift', handleEntries);\n if (po) {\n report = bindReporter(onReport, metric);\n\n const stopListening = (): void => {\n handleEntries(po.takeRecords() as CLSMetric['entries']);\n report(true);\n };\n\n onHidden(stopListening);\n\n return stopListening;\n }\n\n return;\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WINDOW } from '../../types';\nimport { onHidden } from './onHidden';\n\nlet firstHiddenTime = -1;\n\nconst initHiddenTime = (): number => {\n // If the document is hidden and not prerendering, assume it was always\n // hidden and the page was loaded in the background.\n return WINDOW.document.visibilityState === 'hidden' && !WINDOW.document.prerendering ? 0 : Infinity;\n};\n\nconst trackChanges = (): void => {\n // Update the time if/when the document becomes hidden.\n onHidden(({ timeStamp }) => {\n firstHiddenTime = timeStamp;\n }, true);\n};\n\nexport const getVisibilityWatcher = (): {\n readonly firstHiddenTime: number;\n} => {\n if (firstHiddenTime < 0) {\n // If the document is hidden when this code runs, assume it was hidden\n // since navigation start. This isn't a perfect heuristic, but it's the\n // best we can do until an API is available to support querying past\n // visibilityState.\n firstHiddenTime = initHiddenTime();\n trackChanges();\n }\n return {\n get firstHiddenTime() {\n return firstHiddenTime;\n },\n };\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { FIDMetric, PerformanceEventTiming, ReportCallback } from './types';\n\n/**\n * Calculates the [FID](https://web.dev/fid/) value for the current page and\n * calls the `callback` function once the value is ready, along with the\n * relevant `first-input` performance entry used to determine the value. The\n * reported value is a `DOMHighResTimeStamp`.\n *\n * _**Important:** since FID is only reported after the user interacts with the\n * page, it's possible that it will not be reported for some page loads._\n */\nexport const onFID = (onReport: ReportCallback): void => {\n const visibilityWatcher = getVisibilityWatcher();\n const metric = initMetric('FID');\n // eslint-disable-next-line prefer-const\n let report: ReturnType<typeof bindReporter>;\n\n const handleEntry = (entry: PerformanceEventTiming): void => {\n // Only report if the page wasn't hidden prior to the first input.\n if (entry.startTime < visibilityWatcher.firstHiddenTime) {\n metric.value = entry.processingStart - entry.startTime;\n metric.entries.push(entry);\n report(true);\n }\n };\n\n const handleEntries = (entries: FIDMetric['entries']): void => {\n (entries as PerformanceEventTiming[]).forEach(handleEntry);\n };\n\n const po = observe('first-input', handleEntries);\n report = bindReporter(onReport, metric);\n\n if (po) {\n onHidden(() => {\n handleEntries(po.takeRecords() as FIDMetric['entries']);\n po.disconnect();\n }, true);\n }\n};\n", "/*\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bindReporter } from './lib/bindReporter';\nimport { getActivationStart } from './lib/getActivationStart';\nimport { getVisibilityWatcher } from './lib/getVisibilityWatcher';\nimport { initMetric } from './lib/initMetric';\nimport { observe } from './lib/observe';\nimport { onHidden } from './lib/onHidden';\nimport type { LCPMetric, ReportCallback, StopListening } from './types';\n\nconst reportedMetricIDs: Record<string, boolean> = {};\n\n/**\n * Calculates the [LCP](https://web.dev/lcp/) value for the current page and\n * calls the `callback` function once the value is ready (along with the\n * relevant `largest-contentful-paint` performance entry used to determine the\n * value). The reported value is a `DOMHighResTimeStamp`.\n */\nexport const onLCP = (onReport: ReportCallback): StopListening | undefined => {\n const visibilityWatcher = getVisibilityWatcher();\n const metric = initMetric('LCP');\n let report: ReturnType<typeof bindReporter>;\n\n const handleEntries = (entries: LCPMetric['entries']): void => {\n const lastEntry = entries[entries.length - 1] as LargestContentfulPaint;\n if (lastEntry) {\n // The startTime attribute returns the value of the renderTime if it is\n // not 0, and the value of the loadTime otherwise. The activationStart\n // reference is used because LCP should be relative to page activation\n // rather than navigation start if the page was prerendered.\n const value = Math.max(lastEntry.startTime - getActivationStart(), 0);\n\n // Only report if the page wasn't hidden prior to LCP.\n if (value < visibilityWatcher.firstHiddenTime) {\n metric.value = value;\n metric.entries = [lastEntry];\n report();\n }\n }\n };\n\n const po = observe('largest-contentful-paint', handleEntries);\n\n if (po) {\n report = bindReporter(onReport, metric);\n\n const stopListening = (): void => {\n if (!reportedMetricIDs[metric.id]) {\n handleEntries(po.takeRecords() as LCPMetric['entries']);\n po.disconnect();\n reportedMetricIDs[metric.id] = true;\n report(true);\n }\n };\n\n // Stop listening after input. Note: while scrolling is an input that\n // stop LCP observation, it's unreliable since it can be programmatically\n // generated. See: https://github.com/GoogleChrome/web-vitals/issues/75\n ['keydown', 'click'].forEach(type => {\n addEventListener(type, stopListening, { once: true, capture: true });\n });\n\n onHidden(stopListening, true);\n\n return stopListening;\n }\n\n return;\n};\n", "import { getFunctionName, logger } from '@sentry/utils';\n\nimport { onCLS } from './web-vitals/getCLS';\nimport { onFID } from './web-vitals/getFID';\nimport { onLCP } from './web-vitals/getLCP';\nimport { observe } from './web-vitals/lib/observe';\n\ntype InstrumentHandlerTypePerformanceObserver = 'longtask' | 'event' | 'navigation' | 'paint' | 'resource';\n\ntype InstrumentHandlerTypeMetric = 'cls' | 'lcp' | 'fid';\n\n// We provide this here manually instead of relying on a global, as this is not available in non-browser environements\n// And we do not want to expose such types\ninterface PerformanceEntry {\n readonly duration: number;\n readonly entryType: string;\n readonly name: string;\n readonly startTime: number;\n toJSON(): Record<string, unknown>;\n}\n\ninterface Metric {\n /**\n * The name of the metric (in acronym form).\n */\n name: 'CLS' | 'FCP' | 'FID' | 'INP' | 'LCP' | 'TTFB';\n\n /**\n * The current value of the metric.\n */\n value: number;\n\n /**\n * The rating as to whether the metric value is within the \"good\",\n * \"needs improvement\", or \"poor\" thresholds of the metric.\n */\n rating: 'good' | 'needs-improvement' | 'poor';\n\n /**\n * The delta between the current value and the last-reported value.\n * On the first report, `delta` and `value` will always be the same.\n */\n delta: number;\n\n /**\n * A unique ID representing this particular metric instance. This ID can\n * be used by an analytics tool to dedupe multiple values sent for the same\n * metric instance, or to group multiple deltas together and calculate a\n * total. It can also be used to differentiate multiple different metric\n * instances sent from the same page, which can happen if the page is\n * restored from the back/forward cache (in that case new metrics object\n * get created).\n */\n id: string;\n\n /**\n * Any performance entries relevant to the metric value calculation.\n * The array may also be empty if the metric value was not based on any\n * entries (e.g. a CLS value of 0 given no layout shifts).\n */\n entries: PerformanceEntry[];\n\n /**\n * The type of navigation\n *\n * Navigation Timing API (or `undefined` if the browser doesn't\n * support that API). For pages that are restored from the bfcache, this\n * value will be 'back-forward-cache'.\n */\n navigationType: 'navigate' | 'reload' | 'back-forward' | 'back-forward-cache' | 'prerender';\n}\n\ntype InstrumentHandlerType = InstrumentHandlerTypeMetric | InstrumentHandlerTypePerformanceObserver;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ntype InstrumentHandlerCallback = (data: any) => void;\n\ntype CleanupHandlerCallback = () => void;\n\nconst handlers: { [key in InstrumentHandlerType]?: InstrumentHandlerCallback[] } = {};\nconst instrumented: { [key in InstrumentHandlerType]?: boolean } = {};\n\nlet _previousCls: Metric | undefined;\nlet _previousFid: Metric | undefined;\nlet _previousLcp: Metric | undefined;\n\n/**\n * Add a callback that will be triggered when a CLS metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addClsInstrumentationHandler(callback: (data: { metric: Metric }) => void): CleanupHandlerCallback {\n return addMetricObserver('cls', callback, instrumentCls, _previousCls);\n}\n\n/**\n * Add a callback that will be triggered when a LCP metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addLcpInstrumentationHandler(callback: (data: { metric: Metric }) => void): CleanupHandlerCallback {\n return addMetricObserver('lcp', callback, instrumentLcp, _previousLcp);\n}\n\n/**\n * Add a callback that will be triggered when a FID metric is available.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addFidInstrumentationHandler(callback: (data: { metric: Metric }) => void): CleanupHandlerCallback {\n return addMetricObserver('fid', callback, instrumentFid, _previousFid);\n}\n\nexport function addPerformanceInstrumentationHandler(\n type: 'event',\n callback: (data: { entries: (PerformanceEntry & { target?: unknown | null })[] }) => void,\n): CleanupHandlerCallback;\nexport function addPerformanceInstrumentationHandler(\n type: InstrumentHandlerTypePerformanceObserver,\n callback: (data: { entries: PerformanceEntry[] }) => void,\n): CleanupHandlerCallback;\n\n/**\n * Add a callback that will be triggered when a performance observer is triggered,\n * and receives the entries of the observer.\n * Returns a cleanup callback which can be called to remove the instrumentation handler.\n */\nexport function addPerformanceInstrumentationHandler(\n type: InstrumentHandlerTypePerformanceObserver,\n callback: (data: { entries: PerformanceEntry[] }) => void,\n): CleanupHandlerCallback {\n addHandler(type, callback);\n\n if (!instrumented[type]) {\n instrumentPerformanceObserver(type);\n instrumented[type] = true;\n }\n\n return getCleanupCallback(type, callback);\n}\n\n/** Trigger all handlers of a given type. */\nfunction triggerHandlers(type: InstrumentHandlerType, data: unknown): void {\n const typeHandlers = handlers[type];\n\n if (!typeHandlers || !typeHandlers.length) {\n return;\n }\n\n for (const handler of typeHandlers) {\n try {\n handler(data);\n } catch (e) {\n __DEBUG_BUILD__ &&\n logger.error(\n `Error while triggering instrumentation handler.\\nType: ${type}\\nName: ${getFunctionName(handler)}\\nError:`,\n e,\n );\n }\n }\n}\n\nfunction instrumentCls(): void {\n onCLS(metric => {\n triggerHandlers('cls', {\n metric,\n });\n _previousCls = metric;\n });\n}\n\nfunction instrumentFid(): void {\n onFID(metric => {\n triggerHandlers('fid', {\n metric,\n });\n _previousFid = metric;\n });\n}\n\nfunction instrumentLcp(): void {\n onLCP(metric => {\n triggerHandlers('lcp', {\n metric,\n });\n _previousLcp = metric;\n });\n}\n\nfunction addMetricObserver(\n type: InstrumentHandlerTypeMetric,\n callback: InstrumentHandlerCallback,\n instrumentFn: () => void,\n previousValue: Metric | undefined,\n): CleanupHandlerCallback {\n addHandler(type, callback);\n\n if (!instrumented[type]) {\n instrumentFn();\n instrumented[type] = true;\n }\n\n if (previousValue) {\n callback({ metric: previousValue });\n }\n\n return getCleanupCallback(type, callback);\n}\n\nfunction instrumentPerformanceObserver(type: InstrumentHandlerTypePerformanceObserver): void {\n const options: PerformanceObserverInit = {};\n\n // Special per-type options we want to use\n if (type === 'event') {\n options.durationThreshold = 0;\n }\n\n observe(\n type,\n entries => {\n triggerHandlers(type, { entries });\n },\n options,\n );\n}\n\nfunction addHandler(type: InstrumentHandlerType, handler: InstrumentHandlerCallback): void {\n handlers[type] = handlers[type] || [];\n (handlers[type] as InstrumentHandlerCallback[]).push(handler);\n}\n\n// Get a callback which can be called to remove the instrumentation handler\nfunction getCleanupCallback(type: InstrumentHandlerType, callback: InstrumentHandlerCallback): CleanupHandlerCallback {\n return () => {\n const typeHandlers = handlers[type];\n\n if (!typeHandlers) {\n return;\n }\n\n const index = typeHandlers.indexOf(callback);\n if (index !== -1) {\n typeHandlers.splice(index, 1);\n }\n };\n}\n", "import type { Transaction } from '@sentry/core';\nimport type { Span, SpanContext } from '@sentry/types';\n\n/**\n * Checks if a given value is a valid measurement value.\n */\nexport function isMeasurementValue(value: unknown): value is number {\n return typeof value === 'number' && isFinite(value);\n}\n\n/**\n * Helper function to start child on transactions. This function will make sure that the transaction will\n * use the start timestamp of the created child span if it is earlier than the transactions actual\n * start timestamp.\n */\nexport function _startChild(transaction: Transaction, { startTimestamp, ...ctx }: SpanContext): Span {\n if (startTimestamp && transaction.startTimestamp > startTimestamp) {\n transaction.startTimestamp = startTimestamp;\n }\n\n return transaction.startChild({\n startTimestamp,\n ...ctx,\n });\n}\n", "/* eslint-disable max-lines */\nimport type { IdleTransaction, Transaction } from '@sentry/core';\nimport { getActiveTransaction } from '@sentry/core';\nimport type { Measurements } from '@sentry/types';\nimport { browserPerformanceTimeOrigin, htmlTreeAsString, logger } from '@sentry/utils';\n\nimport {\n addClsInstrumentationHandler,\n addFidInstrumentationHandler,\n addLcpInstrumentationHandler,\n addPerformanceInstrumentationHandler,\n} from '../instrument';\nimport { WINDOW } from '../types';\nimport { getVisibilityWatcher } from '../web-vitals/lib/getVisibilityWatcher';\nimport type { NavigatorDeviceMemory, NavigatorNetworkInformation } from '../web-vitals/types';\nimport { _startChild, isMeasurementValue } from './utils';\n\n/**\n * Converts from milliseconds to seconds\n * @param time time in ms\n */\nfunction msToSec(time: number): number {\n return time / 1000;\n}\n\nfunction getBrowserPerformanceAPI(): Performance | undefined {\n // @ts-expect-error we want to make sure all of these are available, even if TS is sure they are\n return WINDOW && WINDOW.addEventListener && WINDOW.performance;\n}\n\nlet _performanceCursor: number = 0;\n\nlet _measurements: Measurements = {};\nlet _lcpEntry: LargestContentfulPaint | undefined;\nlet _clsEntry: LayoutShift | undefined;\n\n/**\n * Start tracking web vitals\n *\n * @returns A function that forces web vitals collection\n */\nexport function startTrackingWebVitals(): () => void {\n const performance = getBrowserPerformanceAPI();\n if (performance && browserPerformanceTimeOrigin) {\n // @ts-expect-error we want to make sure all of these are available, even if TS is sure they are\n if (performance.mark) {\n WINDOW.performance.mark('sentry-tracing-init');\n }\n const fidCallback = _trackFID();\n const clsCallback = _trackCLS();\n const lcpCallback = _trackLCP();\n\n return (): void => {\n fidCallback();\n clsCallback();\n lcpCallback();\n };\n }\n\n return () => undefined;\n}\n\n/**\n * Start tracking long tasks.\n */\nexport function startTrackingLongTasks(): void {\n addPerformanceInstrumentationHandler('longtask', ({ entries }) => {\n for (const entry of entries) {\n const transaction = getActiveTransaction() as IdleTransaction | undefined;\n if (!transaction) {\n return;\n }\n const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n const duration = msToSec(entry.duration);\n\n transaction.startChild({\n description: 'Main UI thread blocked',\n op: 'ui.long-task',\n origin: 'auto.ui.browser.metrics',\n startTimestamp: startTime,\n endTimestamp: startTime + duration,\n });\n }\n });\n}\n\n/**\n * Start tracking interaction events.\n */\nexport function startTrackingInteractions(): void {\n addPerformanceInstrumentationHandler('event', ({ entries }) => {\n for (const entry of entries) {\n const transaction = getActiveTransaction() as IdleTransaction | undefined;\n if (!transaction) {\n return;\n }\n\n if (entry.name === 'click') {\n const startTime = msToSec((browserPerformanceTimeOrigin as number) + entry.startTime);\n const duration = msToSec(entry.duration);\n\n transaction.startChild({\n description: htmlTreeAsString(entry.target),\n op: `ui.interaction.${entry.name}`,\n origin: 'auto.ui.browser.metrics',\n startTimestamp: startTime,\n endTimestamp: startTime + duration,\n });\n }\n }\n });\n}\n\n/** Starts tracking the Cumulative Layout Shift on the current page. */\nfunction _trackCLS(): () => void {\n return addClsInstrumentationHandler(({ metric }) => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding CLS');\n _measurements['cls'] = { value: metric.value, unit: '' };\n _clsEntry = entry as LayoutShift;\n });\n}\n\n/** Starts tracking the Largest Contentful Paint on the current page. */\nfunction _trackLCP(): () => void {\n return addLcpInstrumentationHandler(({ metric }) => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding LCP');\n _measurements['lcp'] = { value: metric.value, unit: 'millisecond' };\n _lcpEntry = entry as LargestContentfulPaint;\n });\n}\n\n/** Starts tracking the First Input Delay on the current page. */\nfunction _trackFID(): () => void {\n return addFidInstrumentationHandler(({ metric }) => {\n const entry = metric.entries.pop();\n if (!entry) {\n return;\n }\n\n const timeOrigin = msToSec(browserPerformanceTimeOrigin as number);\n const startTime = msToSec(entry.startTime);\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FID');\n _measurements['fid'] = { value: metric.value, unit: 'millisecond' };\n _measurements['mark.fid'] = { value: timeOrigin + startTime, unit: 'second' };\n });\n}\n\n/** Add performance related spans to a transaction */\nexport function addPerformanceEntries(transaction: Transaction): void {\n const performance = getBrowserPerformanceAPI();\n if (!performance || !WINDOW.performance.getEntries || !browserPerformanceTimeOrigin) {\n // Gatekeeper if performance API not available\n return;\n }\n\n __DEBUG_BUILD__ && logger.log('[Tracing] Adding & adjusting spans using Performance API');\n const timeOrigin = msToSec(browserPerformanceTimeOrigin);\n\n const performanceEntries = performance.getEntries();\n\n let responseStartTimestamp: number | undefined;\n let requestStartTimestamp: number | undefined;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n performanceEntries.slice(_performanceCursor).forEach((entry: Record<string, any>) => {\n const startTime = msToSec(entry.startTime);\n const duration = msToSec(entry.duration);\n\n if (transaction.op === 'navigation' && timeOrigin + startTime < transaction.startTimestamp) {\n return;\n }\n\n switch (entry.entryType) {\n case 'navigation': {\n _addNavigationSpans(transaction, entry, timeOrigin);\n responseStartTimestamp = timeOrigin + msToSec(entry.responseStart);\n requestStartTimestamp = timeOrigin + msToSec(entry.requestStart);\n break;\n }\n case 'mark':\n case 'paint':\n case 'measure': {\n _addMeasureSpans(transaction, entry, startTime, duration, timeOrigin);\n\n // capture web vitals\n const firstHidden = getVisibilityWatcher();\n // Only report if the page wasn't hidden prior to the web vital.\n const shouldRecord = entry.startTime < firstHidden.firstHiddenTime;\n\n if (entry.name === 'first-paint' && shouldRecord) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FP');\n _measurements['fp'] = { value: entry.startTime, unit: 'millisecond' };\n }\n if (entry.name === 'first-contentful-paint' && shouldRecord) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding FCP');\n _measurements['fcp'] = { value: entry.startTime, unit: 'millisecond' };\n }\n break;\n }\n case 'resource': {\n const resourceName = (entry.name as string).replace(WINDOW.location.origin, '');\n _addResourceSpans(transaction, entry, resourceName, startTime, duration, timeOrigin);\n break;\n }\n default:\n // Ignore other entry types.\n }\n });\n\n _performanceCursor = Math.max(performanceEntries.length - 1, 0);\n\n _trackNavigator(transaction);\n\n // Measurements are only available for pageload transactions\n if (transaction.op === 'pageload') {\n // Generate TTFB (Time to First Byte), which measured as the time between the beginning of the transaction and the\n // start of the response in milliseconds\n if (typeof responseStartTimestamp === 'number') {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding TTFB');\n _measurements['ttfb'] = {\n value: (responseStartTimestamp - transaction.startTimestamp) * 1000,\n unit: 'millisecond',\n };\n\n if (typeof requestStartTimestamp === 'number' && requestStartTimestamp <= responseStartTimestamp) {\n // Capture the time spent making the request and receiving the first byte of the response.\n // This is the time between the start of the request and the start of the response in milliseconds.\n _measurements['ttfb.requestTime'] = {\n value: (responseStartTimestamp - requestStartTimestamp) * 1000,\n unit: 'millisecond',\n };\n }\n }\n\n ['fcp', 'fp', 'lcp'].forEach(name => {\n if (!_measurements[name] || timeOrigin >= transaction.startTimestamp) {\n return;\n }\n // The web vitals, fcp, fp, lcp, and ttfb, all measure relative to timeOrigin.\n // Unfortunately, timeOrigin is not captured within the transaction span data, so these web vitals will need\n // to be adjusted to be relative to transaction.startTimestamp.\n const oldValue = _measurements[name].value;\n const measurementTimestamp = timeOrigin + msToSec(oldValue);\n\n // normalizedValue should be in milliseconds\n const normalizedValue = Math.abs((measurementTimestamp - transaction.startTimestamp) * 1000);\n const delta = normalizedValue - oldValue;\n\n __DEBUG_BUILD__ &&\n logger.log(`[Measurements] Normalized ${name} from ${oldValue} to ${normalizedValue} (${delta})`);\n _measurements[name].value = normalizedValue;\n });\n\n const fidMark = _measurements['mark.fid'];\n if (fidMark && _measurements['fid']) {\n // create span for FID\n _startChild(transaction, {\n description: 'first input delay',\n endTimestamp: fidMark.value + msToSec(_measurements['fid'].value),\n op: 'ui.action',\n origin: 'auto.ui.browser.metrics',\n startTimestamp: fidMark.value,\n });\n\n // Delete mark.fid as we don't want it to be part of final payload\n delete _measurements['mark.fid'];\n }\n\n // If FCP is not recorded we should not record the cls value\n // according to the new definition of CLS.\n if (!('fcp' in _measurements)) {\n delete _measurements.cls;\n }\n\n Object.keys(_measurements).forEach(measurementName => {\n transaction.setMeasurement(\n measurementName,\n _measurements[measurementName].value,\n _measurements[measurementName].unit,\n );\n });\n\n _tagMetricInfo(transaction);\n }\n\n _lcpEntry = undefined;\n _clsEntry = undefined;\n _measurements = {};\n}\n\n/** Create measure related spans */\nexport function _addMeasureSpans(\n transaction: Transaction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n entry: Record<string, any>,\n startTime: number,\n duration: number,\n timeOrigin: number,\n): number {\n const measureStartTimestamp = timeOrigin + startTime;\n const measureEndTimestamp = measureStartTimestamp + duration;\n\n _startChild(transaction, {\n description: entry.name as string,\n endTimestamp: measureEndTimestamp,\n op: entry.entryType as string,\n origin: 'auto.resource.browser.metrics',\n startTimestamp: measureStartTimestamp,\n });\n\n return measureStartTimestamp;\n}\n\n/** Instrument navigation entries */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _addNavigationSpans(transaction: Transaction, entry: Record<string, any>, timeOrigin: number): void {\n ['unloadEvent', 'redirect', 'domContentLoadedEvent', 'loadEvent', 'connect'].forEach(event => {\n _addPerformanceNavigationTiming(transaction, entry, event, timeOrigin);\n });\n _addPerformanceNavigationTiming(transaction, entry, 'secureConnection', timeOrigin, 'TLS/SSL', 'connectEnd');\n _addPerformanceNavigationTiming(transaction, entry, 'fetch', timeOrigin, 'cache', 'domainLookupStart');\n _addPerformanceNavigationTiming(transaction, entry, 'domainLookup', timeOrigin, 'DNS');\n _addRequest(transaction, entry, timeOrigin);\n}\n\n/** Create performance navigation related spans */\nfunction _addPerformanceNavigationTiming(\n transaction: Transaction,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n entry: Record<string, any>,\n event: string,\n timeOrigin: number,\n description?: string,\n eventEnd?: string,\n): void {\n const end = eventEnd ? (entry[eventEnd] as number | undefined) : (entry[`${event}End`] as number | undefined);\n const start = entry[`${event}Start`] as number | undefined;\n if (!start || !end) {\n return;\n }\n _startChild(transaction, {\n op: 'browser',\n origin: 'auto.browser.browser.metrics',\n description: description || event,\n startTimestamp: timeOrigin + msToSec(start),\n endTimestamp: timeOrigin + msToSec(end),\n });\n}\n\n/** Create request and response related spans */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction _addRequest(transaction: Transaction, entry: Record<string, any>, timeOrigin: number): void {\n _startChild(transaction, {\n op: 'browser',\n origin: 'auto.browser.browser.metrics',\n description: 'request',\n startTimestamp: timeOrigin + msToSec(entry.requestStart as number),\n endTimestamp: timeOrigin + msToSec(entry.responseEnd as number),\n });\n\n _startChild(transaction, {\n op: 'browser',\n origin: 'auto.browser.browser.metrics',\n description: 'response',\n startTimestamp: timeOrigin + msToSec(entry.responseStart as number),\n endTimestamp: timeOrigin + msToSec(entry.responseEnd as number),\n });\n}\n\nexport interface ResourceEntry extends Record<string, unknown> {\n initiatorType?: string;\n transferSize?: number;\n encodedBodySize?: number;\n decodedBodySize?: number;\n renderBlockingStatus?: string;\n}\n\n/** Create resource-related spans */\nexport function _addResourceSpans(\n transaction: Transaction,\n entry: ResourceEntry,\n resourceName: string,\n startTime: number,\n duration: number,\n timeOrigin: number,\n): void {\n // we already instrument based on fetch and xhr, so we don't need to\n // duplicate spans here.\n if (entry.initiatorType === 'xmlhttprequest' || entry.initiatorType === 'fetch') {\n return;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const data: Record<string, any> = {};\n if ('transferSize' in entry) {\n data['http.response_transfer_size'] = entry.transferSize;\n }\n if ('encodedBodySize' in entry) {\n data['http.response_content_length'] = entry.encodedBodySize;\n }\n if ('decodedBodySize' in entry) {\n data['http.decoded_response_content_length'] = entry.decodedBodySize;\n }\n if ('renderBlockingStatus' in entry) {\n data['resource.render_blocking_status'] = entry.renderBlockingStatus;\n }\n\n const startTimestamp = timeOrigin + startTime;\n const endTimestamp = startTimestamp + duration;\n\n _startChild(transaction, {\n description: resourceName,\n endTimestamp,\n op: entry.initiatorType ? `resource.${entry.initiatorType}` : 'resource.other',\n origin: 'auto.resource.browser.metrics',\n startTimestamp,\n data,\n });\n}\n\n/**\n * Capture the information of the user agent.\n */\nfunction _trackNavigator(transaction: Transaction): void {\n const navigator = WINDOW.navigator as null | (Navigator & NavigatorNetworkInformation & NavigatorDeviceMemory);\n if (!navigator) {\n return;\n }\n\n // track network connectivity\n const connection = navigator.connection;\n if (connection) {\n if (connection.effectiveType) {\n transaction.setTag('effectiveConnectionType', connection.effectiveType);\n }\n\n if (connection.type) {\n transaction.setTag('connectionType', connection.type);\n }\n\n if (isMeasurementValue(connection.rtt)) {\n _measurements['connection.rtt'] = { value: connection.rtt, unit: 'millisecond' };\n }\n }\n\n if (isMeasurementValue(navigator.deviceMemory)) {\n transaction.setTag('deviceMemory', `${navigator.deviceMemory} GB`);\n }\n\n if (isMeasurementValue(navigator.hardwareConcurrency)) {\n transaction.setTag('hardwareConcurrency', String(navigator.hardwareConcurrency));\n }\n}\n\n/** Add LCP / CLS data to transaction to allow debugging */\nfunction _tagMetricInfo(transaction: Transaction): void {\n if (_lcpEntry) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding LCP Data');\n\n // Capture Properties of the LCP element that contributes to the LCP.\n\n if (_lcpEntry.element) {\n transaction.setTag('lcp.element', htmlTreeAsString(_lcpEntry.element));\n }\n\n if (_lcpEntry.id) {\n transaction.setTag('lcp.id', _lcpEntry.id);\n }\n\n if (_lcpEntry.url) {\n // Trim URL to the first 200 characters.\n transaction.setTag('lcp.url', _lcpEntry.url.trim().slice(0, 200));\n }\n\n transaction.setTag('lcp.size', _lcpEntry.size);\n }\n\n // See: https://developer.mozilla.org/en-US/docs/Web/API/LayoutShift\n if (_clsEntry && _clsEntry.sources) {\n __DEBUG_BUILD__ && logger.log('[Measurements] Adding CLS Data');\n _clsEntry.sources.forEach((source, index) =>\n transaction.setTag(`cls.source.${index + 1}`, htmlTreeAsString(source.node)),\n );\n }\n}\n", "/* eslint-disable max-lines */\nimport { getCurrentHub, getDynamicSamplingContextFromClient, hasTracingEnabled } from '@sentry/core';\nimport type { Client, Scope, Span } from '@sentry/types';\nimport {\n addInstrumentationHandler,\n BAGGAGE_HEADER_NAME,\n browserPerformanceTimeOrigin,\n dynamicSamplingContextToSentryBaggageHeader,\n generateSentryTraceHeader,\n isInstanceOf,\n SENTRY_XHR_DATA_KEY,\n stringMatchesSomePattern,\n} from '@sentry/utils';\n\nimport { addPerformanceInstrumentationHandler } from './instrument';\n\nexport const DEFAULT_TRACE_PROPAGATION_TARGETS = ['localhost', /^\\/(?!\\/)/];\n\n/** Options for Request Instrumentation */\nexport interface RequestInstrumentationOptions {\n /**\n * @deprecated Will be removed in v8.\n * Use `shouldCreateSpanForRequest` to control span creation and `tracePropagationTargets` to control\n * trace header attachment.\n */\n tracingOrigins: Array<string | RegExp>;\n\n /**\n * List of strings and/or regexes used to determine which outgoing requests will have `sentry-trace` and `baggage`\n * headers attached.\n *\n * @deprecated Use the top-level `tracePropagationTargets` option in `Sentry.init` instead.\n * This option will be removed in v8.\n *\n * Default: ['localhost', /^\\//] @see {DEFAULT_TRACE_PROPAGATION_TARGETS}\n */\n tracePropagationTargets: Array<string | RegExp>;\n\n /**\n * Flag to disable patching all together for fetch requests.\n *\n * Default: true\n */\n traceFetch: boolean;\n\n /**\n * Flag to disable patching all together for xhr requests.\n *\n * Default: true\n */\n traceXHR: boolean;\n\n /**\n * If true, Sentry will capture http timings and add them to the corresponding http spans.\n *\n * Default: true\n */\n enableHTTPTimings: boolean;\n\n /**\n * This function will be called before creating a span for a request with the given url.\n * Return false if you don't want a span for the given url.\n *\n * Default: (url: string) => true\n */\n shouldCreateSpanForRequest?(this: void, url: string): boolean;\n}\n\n/** Data returned from fetch callback */\nexport interface FetchData {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n args: any[]; // the arguments passed to the fetch call itself\n fetchData?: {\n method: string;\n url: string;\n // span_id\n __span?: string;\n };\n\n // TODO Should this be unknown instead? If we vendor types, make it a Response\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n response?: any;\n error?: unknown;\n\n startTimestamp: number;\n endTimestamp?: number;\n}\n\n/** Data returned from XHR request */\nexport interface XHRData {\n xhr?: {\n [SENTRY_XHR_DATA_KEY]?: {\n method: string;\n url: string;\n status_code: number;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n data: Record<string, any>;\n };\n __sentry_xhr_span_id__?: string;\n setRequestHeader?: (key: string, val: string) => void;\n getRequestHeader?: (key: string) => string;\n __sentry_own_request__?: boolean;\n };\n startTimestamp: number;\n endTimestamp?: number;\n}\n\ntype PolymorphicRequestHeaders =\n | Record<string, string | undefined>\n | Array<[string, string]>\n // the below is not preicsely the Header type used in Request, but it'll pass duck-typing\n | {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n append: (key: string, value: string) => void;\n get: (key: string) => string | null | undefined;\n };\n\nexport const defaultRequestInstrumentationOptions: RequestInstrumentationOptions = {\n traceFetch: true,\n traceXHR: true,\n enableHTTPTimings: true,\n // TODO (v8): Remove this property\n tracingOrigins: DEFAULT_TRACE_PROPAGATION_TARGETS,\n tracePropagationTargets: DEFAULT_TRACE_PROPAGATION_TARGETS,\n};\n\n/** Registers span creators for xhr and fetch requests */\nexport function instrumentOutgoingRequests(_options?: Partial<RequestInstrumentationOptions>): void {\n const {\n traceFetch,\n traceXHR,\n // eslint-disable-next-line deprecation/deprecation\n tracePropagationTargets,\n // eslint-disable-next-line deprecation/deprecation\n tracingOrigins,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n } = {\n traceFetch: defaultRequestInstrumentationOptions.traceFetch,\n traceXHR: defaultRequestInstrumentationOptions.traceXHR,\n ..._options,\n };\n\n const shouldCreateSpan =\n typeof shouldCreateSpanForRequest === 'function' ? shouldCreateSpanForRequest : (_: string) => true;\n\n // TODO(v8) Remove tracingOrigins here\n // The only reason we're passing it in here is because this instrumentOutgoingRequests function is publicly exported\n // and we don't want to break the API. We can remove it in v8.\n const shouldAttachHeadersWithTargets = (url: string): boolean =>\n shouldAttachHeaders(url, tracePropagationTargets || tracingOrigins);\n\n const spans: Record<string, Span> = {};\n\n if (traceFetch) {\n addInstrumentationHandler('fetch', (handlerData: FetchData) => {\n const createdSpan = fetchCallback(handlerData, shouldCreateSpan, shouldAttachHeadersWithTargets, spans);\n if (enableHTTPTimings && createdSpan) {\n addHTTPTimings(createdSpan);\n }\n });\n }\n\n if (traceXHR) {\n addInstrumentationHandler('xhr', (handlerData: XHRData) => {\n const createdSpan = xhrCallback(handlerData, shouldCreateSpan, shouldAttachHeadersWithTargets, spans);\n if (enableHTTPTimings && createdSpan) {\n addHTTPTimings(createdSpan);\n }\n });\n }\n}\n\nfunction isPerformanceResourceTiming(entry: PerformanceEntry): entry is PerformanceResourceTiming {\n return (\n entry.entryType === 'resource' &&\n 'initiatorType' in entry &&\n typeof (entry as PerformanceResourceTiming).nextHopProtocol === 'string' &&\n (entry.initiatorType === 'fetch' || entry.initiatorType === 'xmlhttprequest')\n );\n}\n\n/**\n * Creates a temporary observer to listen to the next fetch/xhr resourcing timings,\n * so that when timings hit their per-browser limit they don't need to be removed.\n *\n * @param span A span that has yet to be finished, must contain `url` on data.\n */\nfunction addHTTPTimings(span: Span): void {\n const url = span.data.url;\n\n if (!url) {\n return;\n }\n\n const cleanup = addPerformanceInstrumentationHandler('resource', ({ entries }) => {\n entries.forEach(entry => {\n if (isPerformanceResourceTiming(entry) && entry.name.endsWith(url)) {\n const spanData = resourceTimingEntryToSpanData(entry);\n spanData.forEach(data => span.setData(...data));\n // In the next tick, clean this handler up\n // We have to wait here because otherwise this cleans itself up before it is fully done\n setTimeout(cleanup);\n }\n });\n });\n}\n\n/**\n * Converts ALPN protocol ids to name and version.\n *\n * (https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#alpn-protocol-ids)\n * @param nextHopProtocol PerformanceResourceTiming.nextHopProtocol\n */\nexport function extractNetworkProtocol(nextHopProtocol: string): { name: string; version: string } {\n let name = 'unknown';\n let version = 'unknown';\n let _name = '';\n for (const char of nextHopProtocol) {\n // http/1.1 etc.\n if (char === '/') {\n [name, version] = nextHopProtocol.split('/');\n break;\n }\n // h2, h3 etc.\n if (!isNaN(Number(char))) {\n name = _name === 'h' ? 'http' : _name;\n version = nextHopProtocol.split(_name)[1];\n break;\n }\n _name += char;\n }\n if (_name === nextHopProtocol) {\n // webrtc, ftp, etc.\n name = _name;\n }\n return { name, version };\n}\n\nfunction getAbsoluteTime(time: number = 0): number {\n return ((browserPerformanceTimeOrigin || performance.timeOrigin) + time) / 1000;\n}\n\nfunction resourceTimingEntryToSpanData(resourceTiming: PerformanceResourceTiming): [string, string | number][] {\n const { name, version } = extractNetworkProtocol(resourceTiming.nextHopProtocol);\n\n const timingSpanData: [string, string | number][] = [];\n\n timingSpanData.push(['network.protocol.version', version], ['network.protocol.name', name]);\n\n if (!browserPerformanceTimeOrigin) {\n return timingSpanData;\n }\n return [\n ...timingSpanData,\n ['http.request.redirect_start', getAbsoluteTime(resourceTiming.redirectStart)],\n ['http.request.fetch_start', getAbsoluteTime(resourceTiming.fetchStart)],\n ['http.request.domain_lookup_start', getAbsoluteTime(resourceTiming.domainLookupStart)],\n ['http.request.domain_lookup_end', getAbsoluteTime(resourceTiming.domainLookupEnd)],\n ['http.request.connect_start', getAbsoluteTime(resourceTiming.connectStart)],\n ['http.request.secure_connection_start', getAbsoluteTime(resourceTiming.secureConnectionStart)],\n ['http.request.connection_end', getAbsoluteTime(resourceTiming.connectEnd)],\n ['http.request.request_start', getAbsoluteTime(resourceTiming.requestStart)],\n ['http.request.response_start', getAbsoluteTime(resourceTiming.responseStart)],\n ['http.request.response_end', getAbsoluteTime(resourceTiming.responseEnd)],\n ];\n}\n\n/**\n * A function that determines whether to attach tracing headers to a request.\n * This was extracted from `instrumentOutgoingRequests` to make it easier to test shouldAttachHeaders.\n * We only export this fuction for testing purposes.\n */\nexport function shouldAttachHeaders(url: string, tracePropagationTargets: (string | RegExp)[] | undefined): boolean {\n return stringMatchesSomePattern(url, tracePropagationTargets || DEFAULT_TRACE_PROPAGATION_TARGETS);\n}\n\n/**\n * Create and track fetch request spans\n *\n * @returns Span if a span was created, otherwise void.\n */\nexport function fetchCallback(\n handlerData: FetchData,\n shouldCreateSpan: (url: string) => boolean,\n shouldAttachHeaders: (url: string) => boolean,\n spans: Record<string, Span>,\n): Span | undefined {\n if (!hasTracingEnabled() || !handlerData.fetchData) {\n return undefined;\n }\n\n const shouldCreateSpanResult = shouldCreateSpan(handlerData.fetchData.url);\n\n if (handlerData.endTimestamp && shouldCreateSpanResult) {\n const spanId = handlerData.fetchData.__span;\n if (!spanId) return;\n\n const span = spans[spanId];\n if (span) {\n if (handlerData.response) {\n // TODO (kmclb) remove this once types PR goes through\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n span.setHttpStatus(handlerData.response.status);\n\n const contentLength: string =\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n handlerData.response && handlerData.response.headers && handlerData.response.headers.get('content-length');\n\n const contentLengthNum = parseInt(contentLength);\n if (contentLengthNum > 0) {\n span.setData('http.response_content_length', contentLengthNum);\n }\n } else if (handlerData.error) {\n span.setStatus('internal_error');\n }\n span.finish();\n\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete spans[spanId];\n }\n return undefined;\n }\n\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const client = hub.getClient();\n const parentSpan = scope.getSpan();\n\n const { method, url } = handlerData.fetchData;\n\n const span =\n shouldCreateSpanResult && parentSpan\n ? parentSpan.startChild({\n data: {\n url,\n type: 'fetch',\n 'http.method': method,\n },\n description: `${method} ${url}`,\n op: 'http.client',\n origin: 'auto.http.browser',\n })\n : undefined;\n\n if (span) {\n handlerData.fetchData.__span = span.spanId;\n spans[span.spanId] = span;\n }\n\n if (shouldAttachHeaders(handlerData.fetchData.url) && client) {\n const request: string | Request = handlerData.args[0];\n\n // In case the user hasn't set the second argument of a fetch call we default it to `{}`.\n handlerData.args[1] = handlerData.args[1] || {};\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const options: { [key: string]: any } = handlerData.args[1];\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n options.headers = addTracingHeadersToFetchRequest(request, client, scope, options, span);\n }\n\n return span;\n}\n\n/**\n * Adds sentry-trace and baggage headers to the various forms of fetch headers\n */\nexport function addTracingHeadersToFetchRequest(\n request: string | unknown, // unknown is actually type Request but we can't export DOM types from this package,\n client: Client,\n scope: Scope,\n options: {\n headers?:\n | {\n [key: string]: string[] | string | undefined;\n }\n | PolymorphicRequestHeaders;\n },\n requestSpan?: Span,\n): PolymorphicRequestHeaders | undefined {\n const span = requestSpan || scope.getSpan();\n\n const transaction = span && span.transaction;\n\n const { traceId, sampled, dsc } = scope.getPropagationContext();\n\n const sentryTraceHeader = span ? span.toTraceparent() : generateSentryTraceHeader(traceId, undefined, sampled);\n const dynamicSamplingContext = transaction\n ? transaction.getDynamicSamplingContext()\n : dsc\n ? dsc\n : getDynamicSamplingContextFromClient(traceId, client, scope);\n\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n\n const headers =\n typeof Request !== 'undefined' && isInstanceOf(request, Request) ? (request as Request).headers : options.headers;\n\n if (!headers) {\n return { 'sentry-trace': sentryTraceHeader, baggage: sentryBaggageHeader };\n } else if (typeof Headers !== 'undefined' && isInstanceOf(headers, Headers)) {\n const newHeaders = new Headers(headers as Headers);\n\n newHeaders.append('sentry-trace', sentryTraceHeader);\n\n if (sentryBaggageHeader) {\n // If the same header is appended multiple times the browser will merge the values into a single request header.\n // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n newHeaders.append(BAGGAGE_HEADER_NAME, sentryBaggageHeader);\n }\n\n return newHeaders as PolymorphicRequestHeaders;\n } else if (Array.isArray(headers)) {\n const newHeaders = [...headers, ['sentry-trace', sentryTraceHeader]];\n\n if (sentryBaggageHeader) {\n // If there are multiple entries with the same key, the browser will merge the values into a single request header.\n // Its therefore safe to simply push a \"baggage\" entry, even though there might already be another baggage header.\n newHeaders.push([BAGGAGE_HEADER_NAME, sentryBaggageHeader]);\n }\n\n return newHeaders as PolymorphicRequestHeaders;\n } else {\n const existingBaggageHeader = 'baggage' in headers ? headers.baggage : undefined;\n const newBaggageHeaders: string[] = [];\n\n if (Array.isArray(existingBaggageHeader)) {\n newBaggageHeaders.push(...existingBaggageHeader);\n } else if (existingBaggageHeader) {\n newBaggageHeaders.push(existingBaggageHeader);\n }\n\n if (sentryBaggageHeader) {\n newBaggageHeaders.push(sentryBaggageHeader);\n }\n\n return {\n ...(headers as Exclude<typeof headers, Headers>),\n 'sentry-trace': sentryTraceHeader,\n baggage: newBaggageHeaders.length > 0 ? newBaggageHeaders.join(',') : undefined,\n };\n }\n}\n\n/**\n * Create and track xhr request spans\n *\n * @returns Span if a span was created, otherwise void.\n */\n// eslint-disable-next-line complexity\nexport function xhrCallback(\n handlerData: XHRData,\n shouldCreateSpan: (url: string) => boolean,\n shouldAttachHeaders: (url: string) => boolean,\n spans: Record<string, Span>,\n): Span | undefined {\n const xhr = handlerData.xhr;\n const sentryXhrData = xhr && xhr[SENTRY_XHR_DATA_KEY];\n\n if (!hasTracingEnabled() || (xhr && xhr.__sentry_own_request__) || !xhr || !sentryXhrData) {\n return undefined;\n }\n\n const shouldCreateSpanResult = shouldCreateSpan(sentryXhrData.url);\n\n // check first if the request has finished and is tracked by an existing span which should now end\n if (handlerData.endTimestamp && shouldCreateSpanResult) {\n const spanId = xhr.__sentry_xhr_span_id__;\n if (!spanId) return;\n\n const span = spans[spanId];\n if (span) {\n span.setHttpStatus(sentryXhrData.status_code);\n span.finish();\n\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete spans[spanId];\n }\n return undefined;\n }\n\n const hub = getCurrentHub();\n const scope = hub.getScope();\n const parentSpan = scope.getSpan();\n\n const span =\n shouldCreateSpanResult && parentSpan\n ? parentSpan.startChild({\n data: {\n ...sentryXhrData.data,\n type: 'xhr',\n 'http.method': sentryXhrData.method,\n url: sentryXhrData.url,\n },\n description: `${sentryXhrData.method} ${sentryXhrData.url}`,\n op: 'http.client',\n origin: 'auto.http.browser',\n })\n : undefined;\n\n if (span) {\n xhr.__sentry_xhr_span_id__ = span.spanId;\n spans[xhr.__sentry_xhr_span_id__] = span;\n }\n\n if (xhr.setRequestHeader && shouldAttachHeaders(sentryXhrData.url)) {\n if (span) {\n const transaction = span && span.transaction;\n const dynamicSamplingContext = transaction && transaction.getDynamicSamplingContext();\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n setHeaderOnXhr(xhr, span.toTraceparent(), sentryBaggageHeader);\n } else {\n const client = hub.getClient();\n const { traceId, sampled, dsc } = scope.getPropagationContext();\n const sentryTraceHeader = generateSentryTraceHeader(traceId, undefined, sampled);\n const dynamicSamplingContext =\n dsc || (client ? getDynamicSamplingContextFromClient(traceId, client, scope) : undefined);\n const sentryBaggageHeader = dynamicSamplingContextToSentryBaggageHeader(dynamicSamplingContext);\n setHeaderOnXhr(xhr, sentryTraceHeader, sentryBaggageHeader);\n }\n }\n\n return span;\n}\n\nfunction setHeaderOnXhr(\n xhr: NonNullable<XHRData['xhr']>,\n sentryTraceHeader: string,\n sentryBaggageHeader: string | undefined,\n): void {\n try {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n xhr.setRequestHeader!('sentry-trace', sentryTraceHeader);\n if (sentryBaggageHeader) {\n // From MDN: \"If this method is called several times with the same header, the values are merged into one single request header.\"\n // We can therefore simply set a baggage header without checking what was there before\n // https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/setRequestHeader\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n xhr.setRequestHeader!(BAGGAGE_HEADER_NAME, sentryBaggageHeader);\n }\n } catch (_) {\n // Error: InvalidStateError: Failed to execute 'setRequestHeader' on 'XMLHttpRequest': The object's state must be OPENED.\n }\n}\n", "import type { Transaction, TransactionContext } from '@sentry/types';\nimport { addInstrumentationHandler, browserPerformanceTimeOrigin, logger } from '@sentry/utils';\n\nimport { WINDOW } from './types';\n\n/**\n * Default function implementing pageload and navigation transactions\n */\nexport function instrumentRoutingWithDefaults<T extends Transaction>(\n customStartTransaction: (context: TransactionContext) => T | undefined,\n startTransactionOnPageLoad: boolean = true,\n startTransactionOnLocationChange: boolean = true,\n): void {\n if (!WINDOW || !WINDOW.location) {\n __DEBUG_BUILD__ && logger.warn('Could not initialize routing instrumentation due to invalid location');\n return;\n }\n\n let startingUrl: string | undefined = WINDOW.location.href;\n\n let activeTransaction: T | undefined;\n if (startTransactionOnPageLoad) {\n activeTransaction = customStartTransaction({\n name: WINDOW.location.pathname,\n // pageload should always start at timeOrigin (and needs to be in s, not ms)\n startTimestamp: browserPerformanceTimeOrigin ? browserPerformanceTimeOrigin / 1000 : undefined,\n op: 'pageload',\n origin: 'auto.pageload.browser',\n metadata: { source: 'url' },\n });\n }\n\n if (startTransactionOnLocationChange) {\n addInstrumentationHandler('history', ({ to, from }: { to: string; from?: string }) => {\n /**\n * This early return is there to account for some cases where a navigation transaction starts right after\n * long-running pageload. We make sure that if `from` is undefined and a valid `startingURL` exists, we don't\n * create an uneccessary navigation transaction.\n *\n * This was hard to duplicate, but this behavior stopped as soon as this fix was applied. This issue might also\n * only be caused in certain development environments where the usage of a hot module reloader is causing\n * errors.\n */\n if (from === undefined && startingUrl && startingUrl.indexOf(to) !== -1) {\n startingUrl = undefined;\n return;\n }\n\n if (from !== to) {\n startingUrl = undefined;\n if (activeTransaction) {\n __DEBUG_BUILD__ && logger.log(`[Tracing] Finishing current transaction with op: ${activeTransaction.op}`);\n // If there's an open transaction on the scope, we need to finish it before creating an new one.\n activeTransaction.finish();\n }\n activeTransaction = customStartTransaction({\n name: WINDOW.location.pathname,\n op: 'navigation',\n origin: 'auto.navigation.browser',\n metadata: { source: 'url' },\n });\n }\n });\n }\n}\n", "/* eslint-disable max-lines */\nimport type { Hub, IdleTransaction } from '@sentry/core';\nimport { addTracingExtensions, getActiveTransaction, startIdleTransaction, TRACING_DEFAULTS } from '@sentry/core';\nimport type { EventProcessor, Integration, Transaction, TransactionContext, TransactionSource } from '@sentry/types';\nimport { getDomElement, logger, tracingContextFromHeaders } from '@sentry/utils';\n\nimport { registerBackgroundTabDetection } from './backgroundtab';\nimport {\n addPerformanceEntries,\n startTrackingInteractions,\n startTrackingLongTasks,\n startTrackingWebVitals,\n} from './metrics';\nimport type { RequestInstrumentationOptions } from './request';\nimport { defaultRequestInstrumentationOptions, instrumentOutgoingRequests } from './request';\nimport { instrumentRoutingWithDefaults } from './router';\nimport { WINDOW } from './types';\n\nexport const BROWSER_TRACING_INTEGRATION_ID = 'BrowserTracing';\n\n/** Options for Browser Tracing integration */\nexport interface BrowserTracingOptions extends RequestInstrumentationOptions {\n /**\n * The time to wait in ms until the transaction will be finished during an idle state. An idle state is defined\n * by a moment where there are no in-progress spans.\n *\n * The transaction will use the end timestamp of the last finished span as the endtime for the transaction.\n * If there are still active spans when this the `idleTimeout` is set, the `idleTimeout` will get reset.\n * Time is in ms.\n *\n * Default: 1000\n */\n idleTimeout: number;\n\n /**\n * The max duration for a transaction. If a transaction duration hits the `finalTimeout` value, it\n * will be finished.\n * Time is in ms.\n *\n * Default: 30000\n */\n finalTimeout: number;\n\n /**\n * The heartbeat interval. If no new spans are started or open spans are finished within 3 heartbeats,\n * the transaction will be finished.\n * Time is in ms.\n *\n * Default: 5000\n */\n heartbeatInterval: number;\n\n /**\n * Flag to enable/disable creation of `navigation` transaction on history changes.\n *\n * Default: true\n */\n startTransactionOnLocationChange: boolean;\n\n /**\n * Flag to enable/disable creation of `pageload` transaction on first pageload.\n *\n * Default: true\n */\n startTransactionOnPageLoad: boolean;\n\n /**\n * Flag Transactions where tabs moved to background with \"cancelled\". Browser background tab timing is\n * not suited towards doing precise measurements of operations. By default, we recommend that this option\n * be enabled as background transactions can mess up your statistics in nondeterministic ways.\n *\n * Default: true\n */\n markBackgroundTransactions: boolean;\n\n /**\n * If true, Sentry will capture long tasks and add them to the corresponding transaction.\n *\n * Default: true\n */\n enableLongTask: boolean;\n\n /**\n * _metricOptions allows the user to send options to change how metrics are collected.\n *\n * _metricOptions is currently experimental.\n *\n * Default: undefined\n */\n _metricOptions?: Partial<{\n /**\n * @deprecated This property no longer has any effect and will be removed in v8.\n */\n _reportAllChanges: boolean;\n }>;\n\n /**\n * _experiments allows the user to send options to define how this integration works.\n * Note that the `enableLongTask` options is deprecated in favor of the option at the top level, and will be removed in v8.\n *\n * TODO (v8): Remove enableLongTask\n *\n * Default: undefined\n */\n _experiments: Partial<{\n enableLongTask: boolean;\n enableInteractions: boolean;\n onStartRouteTransaction: (t: Transaction | undefined, ctx: TransactionContext, getCurrentHub: () => Hub) => void;\n }>;\n\n /**\n * beforeNavigate is called before a pageload/navigation transaction is created and allows users to modify transaction\n * context data, or drop the transaction entirely (by setting `sampled = false` in the context).\n *\n * Note: For legacy reasons, transactions can also be dropped by returning `undefined`.\n *\n * @param context: The context data which will be passed to `startTransaction` by default\n *\n * @returns A (potentially) modified context object, with `sampled = false` if the transaction should be dropped.\n */\n beforeNavigate?(this: void, context: TransactionContext): TransactionContext | undefined;\n\n /**\n * Instrumentation that creates routing change transactions. By default creates\n * pageload and navigation transactions.\n */\n routingInstrumentation<T extends Transaction>(\n this: void,\n customStartTransaction: (context: TransactionContext) => T | undefined,\n startTransactionOnPageLoad?: boolean,\n startTransactionOnLocationChange?: boolean,\n ): void;\n}\n\nconst DEFAULT_BROWSER_TRACING_OPTIONS: BrowserTracingOptions = {\n ...TRACING_DEFAULTS,\n markBackgroundTransactions: true,\n routingInstrumentation: instrumentRoutingWithDefaults,\n startTransactionOnLocationChange: true,\n startTransactionOnPageLoad: true,\n enableLongTask: true,\n _experiments: {},\n ...defaultRequestInstrumentationOptions,\n};\n\n/**\n * The Browser Tracing integration automatically instruments browser pageload/navigation\n * actions as transactions, and captures requests, metrics and errors as spans.\n *\n * The integration can be configured with a variety of options, and can be extended to use\n * any routing library. This integration uses {@see IdleTransaction} to create transactions.\n */\nexport class BrowserTracing implements Integration {\n // This class currently doesn't have a static `id` field like the other integration classes, because it prevented\n // @sentry/tracing from being treeshaken. Tree shakers do not like static fields, because they behave like side effects.\n // TODO: Come up with a better plan, than using static fields on integration classes, and use that plan on all\n // integrations.\n\n /** Browser Tracing integration options */\n public options: BrowserTracingOptions;\n\n /**\n * @inheritDoc\n */\n public name: string;\n\n private _getCurrentHub?: () => Hub;\n\n private _latestRouteName?: string;\n private _latestRouteSource?: TransactionSource;\n\n private _collectWebVitals: () => void;\n\n private _hasSetTracePropagationTargets: boolean;\n\n public constructor(_options?: Partial<BrowserTracingOptions>) {\n this.name = BROWSER_TRACING_INTEGRATION_ID;\n this._hasSetTracePropagationTargets = false;\n\n addTracingExtensions();\n\n if (__DEBUG_BUILD__) {\n this._hasSetTracePropagationTargets = !!(\n _options &&\n // eslint-disable-next-line deprecation/deprecation\n (_options.tracePropagationTargets || _options.tracingOrigins)\n );\n }\n\n this.options = {\n ...DEFAULT_BROWSER_TRACING_OPTIONS,\n ..._options,\n };\n\n // Special case: enableLongTask can be set in _experiments\n // TODO (v8): Remove this in v8\n if (this.options._experiments.enableLongTask !== undefined) {\n this.options.enableLongTask = this.options._experiments.enableLongTask;\n }\n\n // TODO (v8): remove this block after tracingOrigins is removed\n // Set tracePropagationTargets to tracingOrigins if specified by the user\n // In case both are specified, tracePropagationTargets takes precedence\n // eslint-disable-next-line deprecation/deprecation\n if (_options && !_options.tracePropagationTargets && _options.tracingOrigins) {\n // eslint-disable-next-line deprecation/deprecation\n this.options.tracePropagationTargets = _options.tracingOrigins;\n }\n\n this._collectWebVitals = startTrackingWebVitals();\n if (this.options.enableLongTask) {\n startTrackingLongTasks();\n }\n if (this.options._experiments.enableInteractions) {\n startTrackingInteractions();\n }\n }\n\n /**\n * @inheritDoc\n */\n public setupOnce(_: (callback: EventProcessor) => void, getCurrentHub: () => Hub): void {\n this._getCurrentHub = getCurrentHub;\n const hub = getCurrentHub();\n const client = hub.getClient();\n const clientOptions = client && client.getOptions();\n\n const {\n routingInstrumentation: instrumentRouting,\n startTransactionOnLocationChange,\n startTransactionOnPageLoad,\n markBackgroundTransactions,\n traceFetch,\n traceXHR,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n _experiments,\n } = this.options;\n\n const clientOptionsTracePropagationTargets = clientOptions && clientOptions.tracePropagationTargets;\n // There are three ways to configure tracePropagationTargets:\n // 1. via top level client option `tracePropagationTargets`\n // 2. via BrowserTracing option `tracePropagationTargets`\n // 3. via BrowserTracing option `tracingOrigins` (deprecated)\n //\n // To avoid confusion, favour top level client option `tracePropagationTargets`, and fallback to\n // BrowserTracing option `tracePropagationTargets` and then `tracingOrigins` (deprecated).\n // This is done as it minimizes bundle size (we don't have to have undefined checks).\n //\n // If both 1 and either one of 2 or 3 are set (from above), we log out a warning.\n // eslint-disable-next-line deprecation/deprecation\n const tracePropagationTargets = clientOptionsTracePropagationTargets || this.options.tracePropagationTargets;\n if (__DEBUG_BUILD__ && this._hasSetTracePropagationTargets && clientOptionsTracePropagationTargets) {\n logger.warn(\n '[Tracing] The `tracePropagationTargets` option was set in the BrowserTracing integration and top level `Sentry.init`. The top level `Sentry.init` value is being used.',\n );\n }\n\n instrumentRouting(\n (context: TransactionContext) => {\n const transaction = this._createRouteTransaction(context);\n\n this.options._experiments.onStartRouteTransaction &&\n this.options._experiments.onStartRouteTransaction(transaction, context, getCurrentHub);\n\n return transaction;\n },\n startTransactionOnPageLoad,\n startTransactionOnLocationChange,\n );\n\n if (markBackgroundTransactions) {\n registerBackgroundTabDetection();\n }\n\n if (_experiments.enableInteractions) {\n this._registerInteractionListener();\n }\n\n instrumentOutgoingRequests({\n traceFetch,\n traceXHR,\n tracePropagationTargets,\n shouldCreateSpanForRequest,\n enableHTTPTimings,\n });\n }\n\n /** Create routing idle transaction. */\n private _createRouteTransaction(context: TransactionContext): Transaction | undefined {\n if (!this._getCurrentHub) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Did not create ${context.op} transaction because _getCurrentHub is invalid.`);\n return undefined;\n }\n\n const hub = this._getCurrentHub();\n\n const { beforeNavigate, idleTimeout, finalTimeout, heartbeatInterval } = this.options;\n\n const isPageloadTransaction = context.op === 'pageload';\n\n const sentryTrace = isPageloadTransaction ? getMetaContent('sentry-trace') : '';\n const baggage = isPageloadTransaction ? getMetaContent('baggage') : '';\n const { traceparentData, dynamicSamplingContext, propagationContext } = tracingContextFromHeaders(\n sentryTrace,\n baggage,\n );\n\n const expandedContext: TransactionContext = {\n ...context,\n ...traceparentData,\n metadata: {\n ...context.metadata,\n dynamicSamplingContext: traceparentData && !dynamicSamplingContext ? {} : dynamicSamplingContext,\n },\n trimEnd: true,\n };\n\n const modifiedContext = typeof beforeNavigate === 'function' ? beforeNavigate(expandedContext) : expandedContext;\n\n // For backwards compatibility reasons, beforeNavigate can return undefined to \"drop\" the transaction (prevent it\n // from being sent to Sentry).\n const finalContext = modifiedContext === undefined ? { ...expandedContext, sampled: false } : modifiedContext;\n\n // If `beforeNavigate` set a custom name, record that fact\n finalContext.metadata =\n finalContext.name !== expandedContext.name\n ? { ...finalContext.metadata, source: 'custom' }\n : finalContext.metadata;\n\n this._latestRouteName = finalContext.name;\n this._latestRouteSource = finalContext.metadata && finalContext.metadata.source;\n\n if (finalContext.sampled === false) {\n __DEBUG_BUILD__ &&\n logger.log(`[Tracing] Will not send ${finalContext.op} transaction because of beforeNavigate.`);\n }\n\n __DEBUG_BUILD__ && logger.log(`[Tracing] Starting ${finalContext.op} transaction on scope`);\n\n const { location } = WINDOW;\n\n const idleTransaction = startIdleTransaction(\n hub,\n finalContext,\n idleTimeout,\n finalTimeout,\n true,\n { location }, // for use in the tracesSampler\n heartbeatInterval,\n );\n\n const scope = hub.getScope();\n\n // If it's a pageload and there is a meta tag set\n // use the traceparentData as the propagation context\n if (isPageloadTransaction && traceparentData) {\n scope.setPropagationContext(propagationContext);\n } else {\n // Navigation transactions should set a new propagation context based on the\n // created idle transaction.\n scope.setPropagationContext({\n traceId: idleTransaction.traceId,\n spanId: idleTransaction.spanId,\n parentSpanId: idleTransaction.parentSpanId,\n sampled: idleTransaction.sampled,\n });\n }\n\n idleTransaction.registerBeforeFinishCallback(transaction => {\n this._collectWebVitals();\n addPerformanceEntries(transaction);\n });\n\n return idleTransaction as Transaction;\n }\n\n /** Start listener for interaction transactions */\n private _registerInteractionListener(): void {\n let inflightInteractionTransaction: IdleTransaction | undefined;\n const registerInteractionTransaction = (): void => {\n const { idleTimeout, finalTimeout, heartbeatInterval } = this.options;\n const op = 'ui.action.click';\n\n const currentTransaction = getActiveTransaction();\n if (currentTransaction && currentTransaction.op && ['navigation', 'pageload'].includes(currentTransaction.op)) {\n __DEBUG_BUILD__ &&\n logger.warn(\n `[Tracing] Did not create ${op} transaction because a pageload or navigation transaction is in progress.`,\n );\n return undefined;\n }\n\n if (inflightInteractionTransaction) {\n inflightInteractionTransaction.setFinishReason('interactionInterrupted');\n inflightInteractionTransaction.finish();\n inflightInteractionTransaction = undefined;\n }\n\n if (!this._getCurrentHub) {\n __DEBUG_BUILD__ && logger.warn(`[Tracing] Did not create ${op} transaction because _getCurrentHub is invalid.`);\n return undefined;\n }\n\n if (!this._latestRouteName) {\n __DEBUG_BUILD__ &&\n logger.warn(`[Tracing] Did not create ${op} transaction because _latestRouteName is missing.`);\n return undefined;\n }\n\n const hub = this._getCurrentHub();\n const { location } = WINDOW;\n\n const context: TransactionContext = {\n name: this._latestRouteName,\n op,\n trimEnd: true,\n metadata: {\n source: this._latestRouteSource || 'url',\n },\n };\n\n inflightInteractionTransaction = startIdleTransaction(\n hub,\n context,\n idleTimeout,\n finalTimeout,\n true,\n { location }, // for use in the tracesSampler\n heartbeatInterval,\n );\n };\n\n ['click'].forEach(type => {\n addEventListener(type, registerInteractionTransaction, { once: false, capture: true });\n });\n }\n}\n\n/** Returns the value of a meta tag */\nexport function getMetaContent(metaName: string): string | undefined {\n // Can't specify generic to `getDomElement` because tracing can be used\n // in a variety of environments, have to disable `no-unsafe-member-access`\n // as a result.\n const metaTag = getDomElement(`meta[name=${metaName}]`);\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n return metaTag ? metaTag.getAttribute('content') : undefined;\n}\n", "export * from './exports';\n\nimport { Integrations as CoreIntegrations } from '@sentry/core';\n\nimport { WINDOW } from './helpers';\nimport * as BrowserIntegrations from './integrations';\n\nlet windowIntegrations = {};\n\n// This block is needed to add compatibility with the integrations packages when used with a CDN\nif (WINDOW.Sentry && WINDOW.Sentry.Integrations) {\n windowIntegrations = WINDOW.Sentry.Integrations;\n}\n\nconst INTEGRATIONS = {\n ...windowIntegrations,\n ...CoreIntegrations,\n ...BrowserIntegrations,\n};\n\nexport { INTEGRATIONS as Integrations };\n\nexport { Replay } from '@sentry/replay';\nexport type {\n ReplayEventType,\n ReplayEventWithTime,\n ReplayBreadcrumbFrame,\n ReplayBreadcrumbFrameEvent,\n ReplayOptionFrameEvent,\n ReplayFrame,\n ReplayFrameEvent,\n ReplaySpanFrame,\n ReplaySpanFrameEvent,\n} from '@sentry/replay';\n\nexport {\n BrowserTracing,\n defaultRequestInstrumentationOptions,\n instrumentOutgoingRequests,\n} from '@sentry-internal/tracing';\nexport type { RequestInstrumentationOptions } from '@sentry-internal/tracing';\nexport {\n addTracingExtensions,\n setMeasurement,\n extractTraceparentData,\n getActiveTransaction,\n spanStatusfromHttpCode,\n trace,\n makeMultiplexedTransport,\n ModuleMetadata,\n} from '@sentry/core';\nexport type { SpanStatusType } from '@sentry/core';\nexport type { Span } from '@sentry/types';\nexport { makeBrowserOfflineTransport } from './transports/offline';\nexport { onProfilingStartRouteTransaction } from './profiling/hubextensions';\nexport { BrowserProfilingIntegration } from './profiling/integration';\n", "// This const is used for nothing except to make this file identifiable via its content.\n// We search for \"_sentry_release_injection_file\" in the plugin to determine for sure that the file we look at is the release injection file.\n\n// _sentry_release_injection_file\n\n var _global =\n typeof window !== 'undefined' ?\n window :\n typeof global !== 'undefined' ?\n global :\n typeof self !== 'undefined' ?\n self :\n {};\n\n _global.SENTRY_RELEASE={id:\"3.2.0\"};", "import * as Sentry from \"@sentry/browser\";\n\nlet hasSentryInitiated = false;\nfunction initiateSentry() {\n Sentry.init({\n dsn: \"https://903950caba7d4802afe6c1e985ad5ebd@o128085.ingest.sentry.io/4504854496149504\",\n\n /**\n * The release identifier used when uploading respective source maps. Specify\n * this value to allow Sentry to resolve the correct source maps when\n * processing events.\n */\n release: process.env.COMPONENT_VERSION,\n\n /**\n * List of integrations that should be installed after SDK was initialized.\n * Accepts either a list of integrations or a function that receives\n * default integrations and returns a new, updated list.\n */\n integrations: [new Sentry.BrowserTracing()],\n\n /**\n * Sample rate to determine trace sampling.\n *\n * 0.0 = 0% chance of a given trace being sent (send no traces) 1.0 = 100% chance of a given trace being sent (send\n * all traces)\n *\n * Tracing is enabled if either this or `tracesSampler` is defined. If both are defined, `tracesSampleRate` is\n * ignored.\n */\n tracesSampleRate: 1,\n });\n hasSentryInitiated = true;\n}\n\nexport const captureErrorInSentry = (error: Error) => {\n if (!hasSentryInitiated) {\n initiateSentry();\n }\n\n return Sentry.captureException(error);\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { captureErrorInSentry } from \"@lib/captureErrorInSentry\";\nimport React from \"react\";\nimport { Button } from \"./Button\";\nimport { NonIdealState } from \"./NonIdealState\";\n\nexport class ErrorBoundary extends React.Component<{\n children: React.ReactNode | React.ReactNode[];\n}> {\n state = { hasError: false };\n\n static getDerivedStateFromError() {\n // Update state so the next render will show the fallback UI.\n return { hasError: true };\n }\n\n componentDidCatch(error: Error) {\n // You can also log the error to an error reporting service\n captureErrorInSentry(error);\n }\n\n render() {\n if (this.state.hasError) {\n return (\n <NonIdealState>\n <p style={{ marginBlock: \"0\" }} className=\"p1--semibold\">\n We ran into an error\n </p>\n <p\n className=\"p1--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginBlock: \"12px\",\n textAlign: \"center\",\n }}\n >\n Please try reloading. If the problem persists reach out to our\n support team.\n </p>\n <div>\n <Button\n variant=\"outlined\"\n iconBefore=\"autorenew\"\n onClick={() => location.reload()}\n >\n Try again\n </Button>\n </div>\n </NonIdealState>\n );\n }\n\n return this.props.children;\n }\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import * as Sentry from \"@sentry/browser\";\n\nconst MESSAGE_PREFIX = \"[Duffel Ancillaries] \";\nconst LOCAL_STORAGE_KEY = \"duffel-ancillaries-logger-state\";\nlet LOG_INITIALISED = false;\n\nconst storeLoggerState = (shouldLog: boolean) => {\n localStorage.setItem(LOCAL_STORAGE_KEY, shouldLog.toString());\n};\n\nconst shouldLog = () => localStorage.getItem(LOCAL_STORAGE_KEY) === \"true\";\n\n/**\n * The functions in this file are used to enable logging.\n *\n * Usage:\n *\n * In your app's outermost container, import the LogContext and wrap your app in it:\n *\n * ```jsx\n * import { LogContext, initializeLogger } from '@lib/logging'\n *\n * const logger = initializeLogger(props.debugMode || false)\n *\n * <LogContext.Provider value={logger}>\n * ...\n * </LogContext.Provider>\n * ```\n *\n * Then in your components nested within the above container, import the useLog hook and use it:\n *\n * import { useLog } from '@lib/logging'\n *\n * const { log, logGroup } = useLog()\n * log('This is a log message')\n * logGroup('These messages will be grouped together', ['This is a log message', 'This is another log message'])\n */\nconst initializeLogger = (debugMode: boolean): void => {\n storeLoggerState(debugMode);\n if (debugMode && !LOG_INITIALISED) {\n // eslint-disable-next-line\n console.info(\n MESSAGE_PREFIX,\n `\\n\\nDebug mode is enabled. Information about your setup will be printed to the console.\n \n If you do not want to enable debug mode (for example in a production environment), pass \"debug: false\" when initializing this component.\n \n Learn more about the Ancillaries component:\n http://duffel.com/docs/guides/ancillaries-component`\n );\n }\n LOG_INITIALISED = true;\n};\n\n/**\n * Log a message to the console. Messages will be prefixed with \"[Duffel Ancillaries]\".\n * @param message The message to print to the console.\n */\nconst log = (message: any) => {\n if (shouldLog()) {\n // eslint-disable-next-line\n console.info(MESSAGE_PREFIX, message);\n } else {\n Sentry.addBreadcrumb({\n category: \"log\",\n message,\n });\n }\n};\n\n/**\n * Log a series of messages to the console inside a collapsible group.\n * @param groupName The name of the group of messages. This will be prefixed with \"[Duffel Ancillaries]\".\n * @param messages An array of messages to print to the console, inside the group.\n */\nfunction logGroup(groupName: string, messages: any[]): void;\n\n/**\n * Log a series of messages to the console inside a collapsible group.\n * @param groupName The name of the group of messages. This will be prefixed with \"[Duffel Ancillaries]\".\n * @param object An object to print to the console, inside the group.\n */\nfunction logGroup(groupName: string, object: { [key: string]: any }): void;\n\n// Overloaded function implementation.\n// https://www.typescriptlang.org/docs/handbook/2/functions.html#function-overloads\nfunction logGroup(\n groupName: string,\n messagesOrObject: any[] | { [key: string]: any }\n): void {\n let transformedMessagesOrObject = [];\n if (Array.isArray(messagesOrObject)) {\n transformedMessagesOrObject = messagesOrObject;\n } else {\n transformedMessagesOrObject = Object.entries(messagesOrObject).map(\n ([key, value]) => ({ property: key, value })\n );\n }\n\n if (shouldLog()) {\n // eslint-disable-next-line\n console.groupCollapsed(MESSAGE_PREFIX, groupName);\n\n transformedMessagesOrObject.forEach((message) => {\n // eslint-disable-next-line\n console.info(message);\n });\n\n // eslint-disable-next-line\n console.groupEnd();\n } else {\n Sentry.addBreadcrumb({\n category: \"log.group\",\n message: groupName,\n data: messagesOrObject,\n });\n }\n}\n\nexport { initializeLogger, log, logGroup };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { log } from \"@lib/logging\";\nimport * as React from \"react\";\n\n/* eslint-disable react/no-unknown-property */\n/* eslint sort-keys: \"error\" */\nexport const ICON_MAP = {\n add: (\n <path d=\"M18 13h-5v5c0 .55-.45 1-1 1s-1-.45-1-1v-5H6c-.55 0-1-.45-1-1s.45-1 1-1h5V6c0-.55.45-1 1-1s1 .45 1 1v5h5c.55 0 1 .45 1 1s-.45 1-1 1z\" />\n ),\n apartment: (\n <path d=\"M3.8496 19.9752V7.2744H7.4496V3.6744H15.9504V10.8744H20.1504V19.9752H13.4496V16.3752H10.5504V19.9752H3.8496ZM5.1504 18.6744H7.4496V16.3752H5.1504V18.6744ZM5.1504 14.7744H7.4496V12.4752H5.1504V14.7744ZM5.1504 10.8744H7.4496V8.5752H5.1504V10.8744ZM8.7504 14.7744H11.0496V12.4752H8.7504V14.7744ZM8.7504 10.8744H11.0496V8.5752H8.7504V10.8744ZM8.7504 7.2744H11.0496V4.9752H8.7504V7.2744ZM12.3504 14.7744H14.6496V12.4752H12.3504V14.7744ZM12.3504 10.8744H14.6496V8.5752H12.3504V10.8744ZM12.3504 7.2744H14.6496V4.9752H12.3504V7.2744ZM16.5504 18.6744H18.8496V16.3752H16.5504V18.6744ZM16.5504 14.7744H18.8496V12.4752H16.5504V14.7744Z\" />\n ),\n arrow_forward: (\n <path d=\"M5 13h11.17l-4.88 4.88c-.39.39-.39 1.03 0 1.42.39.39 1.02.39 1.41 0l6.59-6.59c.39-.39.39-1.02 0-1.41l-6.58-6.6c-.39-.39-1.02-.39-1.41 0-.39.39-.39 1.02 0 1.41L16.17 11H5c-.55 0-1 .45-1 1s.45 1 1 1z\" />\n ),\n arrow_left: (\n <path d=\"M9 19L2 12L9 5L10.425 6.4L5.825 11H22V13H5.825L10.4 17.6L9 19Z\" />\n ),\n arrow_right: (\n <path d=\"M15 19L13.6 17.6L18.2 13H2V11H18.2L13.6 6.4L15 5L22 12L15 19Z\" />\n ),\n\n autorenew: (\n <path d=\"M5.69728 14.4104C5.49326 13.9833 5.32604 13.5257 5.19562 13.0374C5.06521 12.5492 5 12.0367 5 11.5C5 9.56481 5.69083 7.91679 7.07249 6.55591C8.45416 5.19504 10.147 4.53946 12.1511 4.58918H12.7613L11.0742 2.92359L12.0097 2L15.2869 5.23549L12.0097 8.47099L11.0742 7.54739L12.7613 5.88181H12.1511C10.5021 5.84866 9.11624 6.38632 7.99347 7.49479C6.87069 8.60326 6.30931 9.93833 6.30931 11.5C6.30931 11.8455 6.33804 12.1824 6.3955 12.5106C6.45296 12.8389 6.53915 13.1573 6.65407 13.4658L5.69728 14.4104ZM11.9903 21L8.71309 17.7645L11.9903 14.529L12.9258 15.4526L11.2387 17.1182H11.8489C13.4979 17.1513 14.8838 16.6137 16.0065 15.5052C17.1293 14.3967 17.6907 13.0617 17.6907 11.5C17.6907 11.1545 17.662 10.8176 17.6045 10.4894C17.547 10.1611 17.4609 9.84273 17.3459 9.53421L18.3027 8.58959C18.5067 9.01665 18.674 9.47431 18.8044 9.96256C18.9348 10.4508 19 10.9633 19 11.5C19 13.4186 18.3092 15.0625 16.9275 16.4317C15.5458 17.8008 13.853 18.4605 11.8489 18.4108H11.2387L12.9258 20.0764L11.9903 21Z\" />\n ),\n bassinet: (\n <>\n <path d=\"M19 12C19 14.1217 18.1571 16.1566 16.6569 17.6569C15.1566 19.1571 13.1217 20 11 20C8.87827 20 6.84344 19.1571 5.34315 17.6569C3.84286 16.1566 3 14.1217 3 12L11 12H19Z\" />\n <path d=\"M16.1347 5.86529L11 11V4C12.0506 4 13.0909 4.20693 14.0615 4.60896C14.8136 4.92052 15.5125 5.34451 16.1347 5.86529ZM16.8602 6.55405L12.4142 11H18.9373C18.8482 10.293 18.6649 9.59962 18.391 8.93853C18.0264 8.05823 17.5077 7.25087 16.8602 6.55405Z\" />\n </>\n ),\n cabin_bag: (\n <path d=\"M7.3077 20.5C6.81058 20.5 6.38502 20.323 6.03102 19.969C5.67701 19.615 5.5 19.1894 5.5 18.6923V8.25007C5.5 7.76417 5.67019 7.35103 6.01057 7.01065C6.35096 6.67027 6.7641 6.50007 7.25 6.50007H9.25V3.6924C9.25 3.43631 9.33622 3.22166 9.50865 3.04842C9.68108 2.87519 9.89773 2.78857 10.1586 2.78857H13.8414C14.1022 2.78857 14.3189 2.87519 14.4913 3.04842C14.6637 3.22166 14.75 3.43631 14.75 3.6924V6.50007H16.6922C17.1894 6.50007 17.6149 6.67708 17.9689 7.0311C18.3229 7.3851 18.5 7.81066 18.5 8.30777V18.6923C18.5 19.1894 18.3229 19.615 17.9689 19.969C17.6149 20.323 17.1894 20.5 16.6922 20.5C16.6922 20.7507 16.6074 20.9608 16.4377 21.1303C16.2681 21.2999 16.0578 21.3846 15.807 21.3846C15.5561 21.3846 15.3461 21.2999 15.1769 21.1303C15.0077 20.9608 14.923 20.7507 14.923 20.5H9.0769C9.0769 20.7513 8.99206 20.9615 8.82237 21.1308C8.65271 21.3 8.44246 21.3846 8.19162 21.3846C7.94079 21.3846 7.73076 21.2999 7.56153 21.1303C7.39231 20.9608 7.3077 20.7507 7.3077 20.5ZM10.4423 6.50007H13.5577V3.98085H10.4423V6.50007ZM7.3077 19H16.6922C16.782 19 16.8557 18.9712 16.9134 18.9135C16.9711 18.8558 17 18.7821 17 18.6923V8.30777C17 8.21802 16.9711 8.1443 16.9134 8.0866C16.8557 8.0289 16.782 8.00005 16.6922 8.00005H7.3077C7.21795 8.00005 7.14423 8.0289 7.08652 8.0866C7.02882 8.1443 6.99997 8.21802 6.99997 8.30777V18.6923C6.99997 18.7821 7.02882 18.8558 7.08652 18.9135C7.14423 18.9712 7.21795 19 7.3077 19ZM8.15382 17.1539C8.15382 17.3261 8.21009 17.4685 8.32262 17.5811C8.43514 17.6937 8.57744 17.75 8.74952 17.75C8.92161 17.75 9.06407 17.6937 9.1769 17.5811C9.28972 17.4685 9.34613 17.3261 9.34613 17.1539V9.8462C9.34613 9.67398 9.28986 9.53157 9.17732 9.41897C9.06481 9.30637 8.92251 9.25007 8.75043 9.25007C8.57834 9.25007 8.43588 9.30637 8.32305 9.41897C8.21023 9.53157 8.15382 9.67398 8.15382 9.8462V17.1539ZM11.4038 17.1539C11.4038 17.3261 11.4601 17.4685 11.5726 17.5811C11.6851 17.6937 11.8274 17.75 11.9995 17.75C12.1716 17.75 12.3141 17.6937 12.4269 17.5811C12.5397 17.4685 12.5961 17.3261 12.5961 17.1539V9.8462C12.5961 9.67398 12.5399 9.53157 12.4273 9.41897C12.3148 9.30637 12.1725 9.25007 12.0004 9.25007C11.8283 9.25007 11.6859 9.30637 11.5731 9.41897C11.4602 9.53157 11.4038 9.67398 11.4038 9.8462V17.1539ZM14.6538 17.1539C14.6538 17.3261 14.7101 17.4685 14.8226 17.5811C14.9351 17.6937 15.0774 17.75 15.2495 17.75C15.4216 17.75 15.5641 17.6937 15.6769 17.5811C15.7897 17.4685 15.8461 17.3261 15.8461 17.1539V9.8462C15.8461 9.67398 15.7899 9.53157 15.6773 9.41897C15.5648 9.30637 15.4225 9.25007 15.2504 9.25007C15.0783 9.25007 14.9359 9.30637 14.823 9.41897C14.7102 9.53157 14.6538 9.67398 14.6538 9.8462V17.1539Z\" />\n ),\n check: (\n <path d=\"M10.3333 15.8646L7 12.5313L8.0625 11.4688L10.3333 13.7396L15.9375 8.13544L17 9.19794L10.3333 15.8646Z\" />\n ),\n checked_bag: (\n <path d=\"M22 19H2V21H22V19M4 15C4 15.5 4.2 16 4.6 16.4C5 16.8 5.5 17 6 17V6C5.5 6 5 6.2 4.6 6.6C4.2 7 4 7.5 4 8V15M13.5 6H10.5C10.5 5.6 10.6 5.2 10.9 4.9C11.2 4.6 11.5 4.5 12 4.5C12.4 4.5 12.8 4.6 13.1 4.9C13.3 5.2 13.5 5.6 13.5 6M7 6V17H17V6H15C15 5.2 14.7 4.5 14.1 3.9S12.8 3 12 3C11.2 3 10.5 3.3 9.9 3.9C9.3 4.5 9 5.2 9 6H7M18 17C18.5 17 19 16.8 19.4 16.4C19.8 16 20 15.5 20 15V8C20 7.5 19.8 7 19.4 6.6C19 6.2 18.5 6 18 6V17Z\" />\n ),\n chevron: (\n <path d=\"M5 13H16.17L11.29 17.88C10.9 18.27 10.9 18.91 11.29 19.3C11.68 19.69 12.31 19.69 12.7 19.3L19.29 12.71C19.68 12.32 19.68 11.69 19.29 11.3L12.71 4.7C12.32 4.31 11.69 4.31 11.3 4.7C10.91 5.09 10.91 5.72 11.3 6.11L16.17 11H5C4.45 11 4 11.45 4 12C4 12.55 4.45 13 5 13Z\" />\n ),\n close: (\n <path d=\"M18.3 5.71c-.39-.39-1.02-.39-1.41 0L12 10.59 7.11 5.7c-.39-.39-1.02-.39-1.41 0-.39.39-.39 1.02 0 1.41L10.59 12 5.7 16.89c-.39.39-.39 1.02 0 1.41.39.39 1.02.39 1.41 0L12 13.41l4.89 4.89c.39.39 1.02.39 1.41 0 .39-.39.39-1.02 0-1.41L13.41 12l4.89-4.89c.38-.38.38-1.02 0-1.4z\" />\n ),\n closet: (\n <path d=\"M12 4C11.0717 4 10.1815 4.36875 9.52513 5.02513C8.86875 5.6815 8.5 6.57174 8.5 7.5H10.5C10.5 7.10218 10.658 6.72064 10.9393 6.43934C11.2206 6.15804 11.6022 6 12 6C12.3978 6 12.7794 6.15804 13.0607 6.43934C13.342 6.72064 13.5 7.10218 13.5 7.5C13.5 7.89782 13.342 8.27936 13.0607 8.56066C12.7794 8.84196 12.3978 9 12 9C11.45 9 11 9.45 11 10V11.75L2.4 18.2C2.23209 18.3259 2.10807 18.5015 2.04549 18.7018C1.98291 18.9022 1.98495 19.1171 2.05132 19.3162C2.11769 19.5153 2.24502 19.6885 2.41529 19.8112C2.58556 19.934 2.79012 20 3 20H21C21.2099 20 21.4144 19.934 21.5847 19.8112C21.755 19.6885 21.8823 19.5153 21.9487 19.3162C22.0151 19.1171 22.0171 18.9022 21.9545 18.7018C21.8919 18.5015 21.7679 18.3259 21.6 18.2L13 11.75V10.85C13.7216 10.6349 14.3546 10.1927 14.805 9.58919C15.2554 8.98569 15.4991 8.25303 15.5 7.5C15.5 6.57174 15.1313 5.6815 14.4749 5.02513C13.8185 4.36875 12.9283 4 12 4ZM12 13.5L18 18H6L12 13.5Z\" />\n ),\n exit_row: (\n <path d=\"M20 11H6.83001L9.71001 8.12001C10.1 7.73001 10.1 7.10001 9.71001 6.71001C9.32001 6.32001 8.69001 6.32001 8.30001 6.71001L3.71001 11.3C3.32001 11.69 3.32001 12.32 3.71001 12.71L8.30001 17.3C8.69001 17.69 9.32001 17.69 9.71001 17.3C10.1 16.91 10.1 16.28 9.71001 15.89L6.83001 13H20C20.55 13 21 12.55 21 12C21 11.45 20.55 11 20 11Z\" />\n ),\n exit_row_right: (\n <path d=\"M4 11H17.17L14.29 8.12001C13.9 7.73001 13.9 7.10001 14.29 6.71001C14.68 6.32001 15.31 6.32001 15.7 6.71001L20.29 11.3C20.68 11.69 20.68 12.32 20.29 12.71L15.7 17.3C15.31 17.69 14.68 17.69 14.29 17.3C13.9 16.91 13.9 16.28 14.29 15.89L17.17 13H4C3.45 13 3 12.55 3 12C3 11.45 3.45 11 4 11Z\" />\n ),\n expand_content: <path d=\"M5 19V13H7V17H11V19H5ZM17 11V7H13V5H19V11H17Z\" />,\n flight_class: (\n <path d=\"M14.2596 12.5C13.7737 12.5 13.3606 12.3298 13.0202 11.9894C12.6798 11.649 12.5096 11.2359 12.5096 10.75V6.25C12.5096 5.7641 12.6798 5.35096 13.0202 5.01058C13.3606 4.67019 13.7737 4.5 14.2596 4.5H15.75C16.2359 4.5 16.649 4.67019 16.9894 5.01058C17.3298 5.35096 17.5 5.7641 17.5 6.25V10.75C17.5 11.2359 17.3298 11.649 16.9894 11.9894C16.649 12.3298 16.2359 12.5 15.75 12.5H14.2596ZM14.2596 11H15.75C15.8205 11 15.8798 10.9759 15.9278 10.9279C15.9759 10.8798 16 10.8205 16 10.75V6.25C16 6.17948 15.9759 6.12018 15.9278 6.0721C15.8798 6.02402 15.8205 5.99998 15.75 5.99998H14.2596C14.1891 5.99998 14.1298 6.02402 14.0817 6.0721C14.0336 6.12018 14.0096 6.17948 14.0096 6.25V10.75C14.0096 10.8205 14.0336 10.8798 14.0817 10.9279C14.1298 10.9759 14.1891 11 14.2596 11ZM9.5673 17.5C9.21345 17.5 8.89678 17.398 8.6173 17.1942C8.33782 16.9903 8.14423 16.7198 8.03655 16.3827L5.5 8.02883V4.5H6.99997V7.99998L9.49997 16H17.7596V17.5H9.5673ZM8.25 20.5V19H17.75V20.5H8.25ZM14.2596 5.99998H16H14.0096H14.2596Z\" />\n ),\n flight_takeoff: (\n <path d=\"M3.77521 20.1498V18.849H20.0748V20.1498H3.77521ZM5.45041 15.2742L2.94961 11.0994L4.05001 10.8246L5.90041 12.399L10.05 11.2998L6.27481 4.89902L7.72561 4.62422L14.1 10.1994L19.4004 8.77382C19.75 8.67462 20.0832 8.72062 20.4 8.91182C20.7168 9.10382 20.9252 9.37462 21.0252 9.72422C21.1084 10.0746 21.0624 10.4038 20.8872 10.7118C20.7128 11.0198 20.4504 11.2242 20.1 11.325L5.45041 15.2742Z\" />\n ),\n galley: (\n <path d=\"M20 3H4v10c0 2.21 1.79 4 4 4h6c2.21 0 4-1.79 4-4v-3h2c1.11 0 2-.9 2-2V5c0-1.11-.89-2-2-2zm0 5h-2V5h2v3zM4 19h16v2H4z\" />\n ),\n lavatory: (\n <path d=\"M5.5 22v-7.5H4V9c0-1.1.9-2 2-2h3c1.1 0 2 .9 2 2v5.5H9.5V22h-4zM18 22v-6h3l-2.54-7.63C18.18 7.55 17.42 7 16.56 7h-.12c-.86 0-1.63.55-1.9 1.37L12 16h3v6h3zM7.5 6c1.11 0 2-.89 2-2s-.89-2-2-2-2 .89-2 2 .89 2 2 2zm9 0c1.11 0 2-.89 2-2s-.89-2-2-2-2 .89-2 2 .89 2 2 2z\" />\n ),\n lie_flat_seat: (\n <path d=\"M6.16667 12.8333C6.81667 12.8333 7.45834 12.5833 7.95001 12.0833C8.91667 11.0916 8.90001 9.51659 7.91667 8.54992C7.42501 8.07492 6.79167 7.83325 6.16667 7.83325C5.51667 7.83325 4.87501 8.08325 4.38334 8.58325C3.41667 9.57492 3.43334 11.1499 4.41667 12.1166C4.90834 12.5916 5.54167 12.8333 6.16667 12.8333ZM5.57501 9.74992C5.73334 9.59159 5.94167 9.49992 6.16667 9.49992C6.38334 9.49992 6.59167 9.58325 6.75001 9.73325C7.08334 10.0583 7.08334 10.5749 6.76667 10.9083C6.60001 11.0749 6.39167 11.1666 6.16667 11.1666C5.95001 11.1666 5.74167 11.0833 5.58334 10.9333C5.25001 10.5999 5.25001 10.0833 5.57501 9.74992ZM17 7.83325H9.50001V12.8333H20.3333V11.1666C20.3333 9.32492 18.8417 7.83325 17 7.83325ZM11.1667 11.1666V9.49992H17C17.9167 9.49992 18.6667 10.2499 18.6667 11.1666H11.1667ZM3.66667 15.3333H8.66667V16.9999H15.3333V15.3333H20.3333V13.6666H3.66667V15.3333Z\" />\n ),\n minus: (\n <path d=\"M18 13H6c-.55 0-1-.45-1-1s.45-1 1-1h12c.55 0 1 .45 1 1s-.45 1-1 1z\" />\n ),\n no_airplane: (\n <path d=\"M14.6674 10.0001V2.66675C14.6674 1.56008 13.7741 0.666748 12.6674 0.666748C11.5607 0.666748 10.6674 1.56008 10.6674 2.66675V7.57341L21.1074 18.0134L25.3341 19.3334V16.6667L14.6674 10.0001ZM1.33407 5.02675L7.9874 11.6801L0.000732422 16.6667V19.3334L10.6674 16.0001V23.3334L8.00073 25.3334V27.3334L12.6674 26.0001L17.3341 27.3334V25.3334L14.6674 23.3334V18.3601L22.3074 26.0001L24.0007 24.3067L3.0274 3.33341L1.33407 5.02675Z\" />\n ),\n no_bag: (\n <path d=\"M16.8992 6.12037H14.9392V3.18101C14.9385 2.92148 14.8351 2.67278 14.6516 2.48926C14.4681 2.30574 14.2194 2.20234 13.9599 2.20166H10.0399C9.78034 2.20234 9.53163 2.30574 9.34811 2.48926C9.16459 2.67278 9.06119 2.92148 9.06051 3.18101V6.12037H8.20711L8.34715 6.25804L14.3973 12.0871V9.06102H15.9676V13.6L17.3022 14.8859L18.8592 16.4748V8.08037C18.8579 7.56096 18.6509 7.06322 18.2836 6.69594C17.9164 6.32867 17.4186 6.12173 16.8992 6.12037ZM5.14051 8.09559L3.77173 6.71825L5.00821 5.48945L7.16586 7.6606L13.9581 14.4953L15.8932 16.4426L19.7441 20.3175L20.2279 20.8043L18.9914 22.0331L17.635 20.6683C17.4035 20.7625 17.154 20.8126 16.8992 20.8133C16.904 20.945 16.8822 21.0763 16.8351 21.1993C16.788 21.3224 16.7166 21.4347 16.6251 21.5296C16.5336 21.6244 16.424 21.6999 16.3027 21.7514C16.1814 21.8029 16.051 21.8295 15.9192 21.8295C15.7874 21.8295 15.657 21.8029 15.5357 21.7514C15.4145 21.6999 15.3048 21.6244 15.2133 21.5296C15.1219 21.4347 15.0504 21.3224 15.0034 21.1993C14.9563 21.0763 14.9344 20.945 14.9392 20.8133H9.06051C9.06529 20.945 9.04348 21.0763 8.99638 21.1993C8.94929 21.3224 8.87787 21.4347 8.7864 21.5296C8.69492 21.6244 8.58527 21.6999 8.46399 21.7514C8.34271 21.8029 8.21229 21.8295 8.08051 21.8295C7.94874 21.8295 7.81832 21.8029 7.69703 21.7514C7.57575 21.6999 7.4661 21.6244 7.37463 21.5296C7.28316 21.4347 7.21174 21.3224 7.16464 21.1993C7.11754 21.0763 7.09573 20.945 7.10051 20.8133C6.58222 20.8119 6.08545 20.6059 5.71835 20.24C5.35126 19.8741 5.14357 19.378 5.14051 18.8597V8.09559ZM14.8632 17.8791L14.3973 17.4103V17.8791H14.8632ZM9.596 12.579V17.8791H8.03083V11.004L9.596 12.579ZM10.5302 3.67134H13.4695V6.12295H10.5302V3.67134Z\" />\n ),\n no_seat: (\n <>\n <path d=\"M25.1667 21.9733L23.4733 23.6667L2.5 2.69333L4.19333 1L7.16667 3.97333L16.5267 13.3333L19.1933 16L24.5 21.3067L25.1667 21.9733Z\" />\n <path d=\"M7.16667 24H3.16667V16H19.1933L24.5 21.3067V24H20.5V20H7.16667V24ZM27.1667 9.33333H23.1667V13.3333H27.1667V9.33333ZM4.5 9.33333H0.5V13.3333H4.5V9.33333ZM20.3333 13.3333H20.5V2.66667C20.5 1.2 19.3 0 17.8333 0H9.83333C9.05784 0 8.3569 0.335483 7.86848 0.868484L20.3333 13.3333ZM16.5267 13.3333L7.16667 3.97333V13.3333H16.5267Z\" />\n </>\n ),\n north_east: (\n <path d=\"M4.69999 19.3C4.51665 19.1167 4.42499 18.8833 4.42499 18.6C4.42499 18.3167 4.51665 18.0833 4.69999 17.9L15.6 7H9.99999C9.71665 7 9.47915 6.90417 9.28749 6.7125C9.09582 6.52083 8.99999 6.28333 8.99999 6C8.99999 5.71667 9.09582 5.47917 9.28749 5.2875C9.47915 5.09583 9.71665 5 9.99999 5H18C18.2833 5 18.5208 5.09583 18.7125 5.2875C18.9042 5.47917 19 5.71667 19 6V14C19 14.2833 18.9042 14.5208 18.7125 14.7125C18.5208 14.9042 18.2833 15 18 15C17.7167 15 17.4792 14.9042 17.2875 14.7125C17.0958 14.5208 17 14.2833 17 14V8.4L6.09999 19.3C5.91665 19.4833 5.68332 19.575 5.39999 19.575C5.11665 19.575 4.88332 19.4833 4.69999 19.3Z\" />\n ),\n seat: (\n <path d=\"M7.59 5.41012C6.81 4.63012 6.81 3.36012 7.59 2.58012C8.37 1.80012 9.64 1.80012 10.42 2.58012C11.2 3.36012 11.2 4.63012 10.42 5.41012C9.63 6.20012 8.37 6.20012 7.59 5.41012ZM6 16.0001V8.00012C6 7.45012 5.55 7.00012 5 7.00012C4.45 7.00012 4 7.45012 4 8.00012V16.0001C4 18.7601 6.24 21.0001 9 21.0001H14C14.55 21.0001 15 20.5501 15 20.0001C15 19.4501 14.55 19.0001 14 19.0001H9C7.34 19.0001 6 17.6601 6 16.0001ZM19.28 19.3501L15.51 15.5801C15.14 15.2101 14.63 15.0001 14.1 15.0001H11.5V11.3201C12.59 12.2101 14.16 13.0201 15.7 13.3401C16.37 13.4801 17 12.9801 17 12.3001C17 11.7701 16.61 11.3401 16.08 11.2501C14.66 11.0101 13.2 10.2401 12.33 9.28012L10.93 7.73012C10.74 7.52012 10.5 7.35012 10.24 7.23012C9.95 7.09012 9.62 7.00012 9.28 7.00012H9.25C8.01 7.00012 7 8.01012 7 9.25012V15.0001C7 16.6601 8.34 18.0001 10 18.0001H15.07L17.85 20.7801C18.24 21.1701 18.89 21.1701 19.28 20.7801C19.68 20.3901 19.68 19.7501 19.28 19.3501Z\" />\n ),\n seat_paid_indicator: (\n <path d=\"M11.7686 0.731368C12.7766 -0.276576 14.5 0.437294 14.5 1.86274V10.8C14.5 12.5673 13.0673 14 11.3 14H2.36274C0.937294 14 0.223427 12.2766 1.23137 11.2686L11.7686 0.731368Z\" />\n ),\n shield_with_moon: (\n <path d=\"M12.525 15.75C13.0814 15.75 13.6269 15.6408 14.1615 15.4222C14.6961 15.2036 15.166 14.8757 15.5711 14.4385C15.6749 14.3244 15.7032 14.2033 15.6557 14.0751C15.6083 13.9469 15.5077 13.8629 15.3538 13.8232C14.7269 13.6783 14.1477 13.4183 13.6163 13.0433C13.0849 12.6683 12.6474 12.1789 12.3038 11.5751C11.9769 11.0046 11.7682 10.393 11.6778 9.74048C11.5874 9.08791 11.6589 8.45458 11.8923 7.84048C11.9525 7.68663 11.9301 7.55586 11.8249 7.44817C11.7198 7.34049 11.5916 7.30332 11.4403 7.33665C10.4442 7.59177 9.65927 8.1142 9.08555 8.90395C8.51185 9.69368 8.225 10.5591 8.225 11.5001C8.225 12.6796 8.64519 13.6828 9.48558 14.5097C10.3259 15.3366 11.3391 15.75 12.525 15.75ZM12 21.4808C9.83716 20.8911 8.04646 19.618 6.62787 17.6616C5.20929 15.7052 4.5 13.518 4.5 11.1001V5.34625L12 2.53857L19.5 5.34625V11.1001C19.5 13.518 18.7907 15.7052 17.3721 17.6616C15.9535 19.618 14.1628 20.8911 12 21.4808ZM12 19.9001C13.7333 19.3501 15.1666 18.2501 16.3 16.6001C17.4333 14.9501 18 13.1167 18 11.1001V6.37507L12 4.1347L5.99997 6.37507V11.1001C5.99997 13.1167 6.56664 14.9501 7.69997 16.6001C8.83331 18.2501 10.2666 19.3501 12 19.9001Z\" />\n ),\n stairs: (\n <path d=\"M19,3H5C3.9,3,3,3.9,3,5v14c0,1.1,0.9,2,2,2h14c1.1,0,2-0.9,2-2V5C21,3.9,20.1,3,19,3z M18,8h-2.42v3.33H13v3.33h-2.58 V18H6v-2h2.42v-3.33H11V9.33h2.58V6H18V8z\" />\n ),\n warning: (\n <path d=\"M20 12C20 16.4183 16.4183 20 12 20C7.58172 20 4 16.4183 4 12C4 7.58172 7.58172 4 12 4C16.4183 4 20 7.58172 20 12ZM8.21071 9.25592L10.9548 12L8.21071 14.7441L9.38922 15.9226L12.1333 13.1785L14.8774 15.9226L16.0559 14.7441L13.3118 12L16.0559 9.25592L14.8774 8.07741L12.1333 10.8215L9.38922 8.07741L8.21071 9.25592Z\" />\n ),\n wifi: (\n <path d=\"M2.83333 9.50005L4.49999 11.1667C8.64166 7.02505 15.3583 7.02505 19.5 11.1667L21.1667 9.50005C16.1083 4.44172 7.89999 4.44172 2.83333 9.50005ZM9.49999 16.1667L12 18.6667L14.5 16.1667C13.125 14.7834 10.8833 14.7834 9.49999 16.1667ZM6.16666 12.8334L7.83333 14.5C10.1333 12.2 13.8667 12.2 16.1667 14.5L17.8333 12.8334C14.6167 9.61672 9.39166 9.61672 6.16666 12.8334Z\" />\n ),\n};\n/* eslint-enable */\n\nexport type IconName = keyof typeof ICON_MAP;\n\nconst getIconPath = (name: IconName) => {\n if (!(name in ICON_MAP)) {\n log(`The icon \"${name}\" is missing from ICON_MAP`);\n return null;\n }\n return ICON_MAP[name];\n};\n\ninterface IconProps {\n name: IconName;\n className?: string;\n size?: number;\n onClick?: (event: React.MouseEvent<SVGSVGElement, MouseEvent>) => void;\n\n ml?: string;\n viewBox?: string;\n style?: React.CSSProperties;\n}\n\nexport const Icon: React.FunctionComponent<IconProps> = ({\n name,\n size,\n className,\n viewBox,\n style,\n}) => (\n <svg\n className={className}\n width={size || 24}\n height={size || 24}\n viewBox={viewBox || \"0 0 24 24\"}\n aria-label={name}\n data-testid={name}\n style={{\n display: \"block\",\n fill: \"currentColor\",\n ...style,\n }}\n >\n {getIconPath(name)}\n </svg>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon, IconName } from \"@components/shared/Icon\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\n\nconst BUTTON_VARIANTS = {\n primary: \"button--primary\",\n outlined: \"button--outlined\",\n destructive: \"button--destructive\",\n};\ntype ButtonVariants = keyof typeof BUTTON_VARIANTS;\n\nconst BUTTON_SIZES = {\n 32: \"button--32\",\n 40: \"button--40\",\n 48: \"button--48\",\n};\n\ntype ButtonSizes = keyof typeof BUTTON_SIZES;\n\ntype NativeButtonProps = React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n>;\n\nexport interface ButtonProps\n extends Pick<\n NativeButtonProps,\n \"id\" | \"onClick\" | \"disabled\" | \"children\" | \"className\" | \"type\"\n > {\n \"data-testid\"?: string;\n iconBefore?: IconName;\n variant?: ButtonVariants;\n size?: ButtonSizes;\n}\n\nexport const Button: React.FC<ButtonProps> = ({\n iconBefore,\n variant = \"primary\",\n size = 40,\n children,\n className,\n type = \"button\",\n ...nativeButtonProps\n}) => (\n <button\n type={type}\n className={classNames(\n \"button\",\n BUTTON_VARIANTS[variant],\n BUTTON_SIZES[size],\n className\n )}\n {...nativeButtonProps}\n >\n {iconBefore && (\n <Icon\n className=\"duffel-button__icon duffel-button__icon--before\"\n name={iconBefore}\n />\n )}\n {children}\n </button>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import React from \"react\";\n\nexport const NonIdealState: React.FC<\n React.PropsWithChildren<{ style?: React.CSSProperties }>\n> = ({ style, children }) => (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n border: \"dashed 1px var(--GREY-300)\",\n borderRadius: \"4px\",\n paddingBlock: \"32px\",\n ...style,\n }}\n >\n <div\n style={{\n display: \"flex\",\n flexDirection: \"column\",\n alignItems: \"center\",\n maxWidth: \"470px\",\n }}\n >\n {children}\n </div>\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import * as React from \"react\";\nimport { Button } from \"./Button\";\nimport { NonIdealState } from \"./NonIdealState\";\n\nexport const FetchOfferErrorState: React.FC<{\n height: string;\n message: string;\n}> = ({ height, message }) => (\n <NonIdealState style={{ minHeight: height }}>\n <p style={{ marginBlock: \"0\" }} className=\"p1--semibold\">\n Failed to load extras\n </p>\n <p\n className=\"p2--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginBlock: \"12px\",\n textAlign: \"center\",\n }}\n >\n {message\n ? message\n : \"Please try reloading. If the problem persists reach out to our support team.\"}\n </p>\n <div>\n <Button\n variant=\"outlined\"\n onClick={() => location.reload()}\n iconBefore=\"autorenew\"\n >\n Try again\n </Button>\n </div>\n </NonIdealState>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferAvailableService } from \"@duffel/api/types\";\n\nexport type ServicePriceMapById = Record<\n OfferAvailableService[\"id\"],\n Pick<OfferAvailableService, \"total_amount\" | \"total_currency\">\n>;\n\nexport const getServicePriceMapById = (\n availableServices: OfferAvailableService[]\n): ServicePriceMapById =>\n availableServices.reduce(\n (all, { id, total_amount, total_currency }) => ({\n [id]: {\n total_amount,\n total_currency,\n },\n ...all,\n }),\n {} as ServicePriceMapById\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder, Offer, SeatMap } from \"@duffel/api/types\";\nimport { captureErrorInSentry } from \"./captureErrorInSentry\";\nimport {\n ServicePriceMapById,\n getServicePriceMapById,\n} from \"./getServicePriceMapById\";\n\nexport const getTotalAmountForServices = (\n offer: Offer,\n selectedServices: CreateOrder[\"services\"],\n seatMaps?: SeatMap[]\n): number => {\n if (!offer || !selectedServices || selectedServices.length === 0) return 0;\n const servicePriceMap = getServicePriceMapById(offer.available_services);\n return getTotalAmountForServicesWithPriceMap(\n servicePriceMap,\n selectedServices,\n seatMaps\n );\n};\n\nexport const getTotalAmountForServicesWithPriceMap = (\n servicePriceMap: ServicePriceMapById,\n selectedServices: CreateOrder[\"services\"],\n seatMaps?: SeatMap[]\n) =>\n (selectedServices || []).reduce(\n (total, { quantity, id }) => {\n let newTotal = total;\n\n if (id in servicePriceMap) {\n newTotal += quantity * +servicePriceMap[id].total_amount;\n } else if (seatMaps) {\n newTotal += quantity * getTotalAmountFromSeatMaps(id, seatMaps);\n } else {\n captureErrorInSentry(\n new Error(\n `The service id (${id}) provided could not be found in neither the offer nor the seat maps.`\n )\n );\n }\n\n return newTotal;\n },\n\n 0\n );\n\nconst getTotalAmountFromSeatMaps = (serviceId: string, seatMaps: SeatMap[]) => {\n for (const seatMap of seatMaps) {\n for (const cabin of seatMap.cabins) {\n for (const row of cabin.rows) {\n for (const section of row.sections) {\n for (const element of section.elements) {\n if (\n element.type === \"seat\" &&\n Array.isArray(element.available_services)\n ) {\n const serviceMatch = element.available_services.find(\n (service) => service.id === serviceId\n );\n if (serviceMatch) return +serviceMatch.total_amount;\n }\n }\n }\n }\n }\n }\n return 0;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder, Offer, SeatMap } from \"@duffel/api/types\";\nimport { getTotalAmountForServices } from \"./getTotalAmountForServices\";\nimport { DuffelAncillariesProps } from \"src/types\";\n\ninterface CompileCreateOrderPayloadInput {\n offer: Offer;\n passengers: DuffelAncillariesProps[\"passengers\"];\n baggageSelectedServices: CreateOrder[\"services\"];\n seatSelectedServices: CreateOrder[\"services\"];\n cfarSelectedServices: CreateOrder[\"services\"];\n seatMaps?: SeatMap[];\n}\n\nexport const compileCreateOrderPayload = ({\n baggageSelectedServices,\n seatSelectedServices,\n cfarSelectedServices,\n offer,\n seatMaps,\n passengers,\n}: CompileCreateOrderPayloadInput): Partial<CreateOrder> => {\n const selectedServicesWithInformation = [\n ...(baggageSelectedServices ? baggageSelectedServices : []),\n ...(seatSelectedServices ? seatSelectedServices : []),\n ...(cfarSelectedServices ? cfarSelectedServices : []),\n ];\n\n const totalAmountWithServices =\n +offer.total_amount +\n getTotalAmountForServices(offer, selectedServicesWithInformation, seatMaps);\n\n return {\n ...(offer && { selected_offers: [offer.id] }),\n passengers,\n services: filterServicesForPayload(selectedServicesWithInformation),\n ...(offer && {\n payments: [\n {\n type: \"balance\",\n amount: `${totalAmountWithServices}`,\n currency: offer.total_currency,\n },\n ],\n }),\n type: \"instant\",\n metadata: { source: `duffel-ancillaries@${process.env.COMPONENT_VERSION}` },\n };\n};\n\nconst filterServicesForPayload = (\n selectedServices: CreateOrder[\"services\"]\n): CreateOrder[\"services\"] => {\n if (!Array.isArray(selectedServices)) return [];\n return selectedServices\n .filter(({ quantity }) => quantity > 0)\n .map(({ id, quantity }) => ({ id, quantity }));\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n DuffelAncillariesMarkup,\n DuffelAncillariesMarkupDefinition,\n DuffelAncillariesPriceFormatters,\n} from \"../types/DuffelAncillariesProps\";\n\nconst convertMarkupIntoPriceFormatter = (\n markup: DuffelAncillariesMarkupDefinition\n) => {\n return (amount: number, currency: string) => {\n const { rate, amount: markupAmount } = markup;\n const newAmount = amount * (1 + rate) + markupAmount;\n return { amount: newAmount, currency };\n };\n};\n\nconst errorMessage =\n \"You cannot supply both markup and priceFormatters for the same service.\";\n\n/**\n * Creates price formatters from the markup and priceFormatters passed in.\n * Throws an error if both are supplied.\n * If neither are supplied, the priceFormatters will be undefined.\n *\n * @param markup The markup to be applied to the prices of the available services of an offer.\n * @param priceFormatters Price formatters to apply to the prices of the available services of an offer.\n * @returns\n */\nconst createPriceFormatters = (\n markup?: DuffelAncillariesMarkup,\n priceFormatters?: DuffelAncillariesPriceFormatters\n): DuffelAncillariesPriceFormatters => {\n const formatters: DuffelAncillariesPriceFormatters = {};\n\n if (priceFormatters) {\n if (priceFormatters.bags) {\n formatters.bags = priceFormatters.bags;\n }\n if (priceFormatters.seats) {\n formatters.seats = priceFormatters.seats;\n }\n if (priceFormatters.cancel_for_any_reason) {\n formatters.cancel_for_any_reason = priceFormatters.cancel_for_any_reason;\n }\n }\n\n // Markup takes precedence over priceFormatters.\n if (markup) {\n if (markup.bags) {\n if (priceFormatters && priceFormatters.bags) {\n throw new Error(errorMessage);\n }\n formatters.bags = convertMarkupIntoPriceFormatter(markup.bags);\n }\n if (markup.seats) {\n if (priceFormatters && priceFormatters.seats) {\n throw new Error(errorMessage);\n }\n formatters.seats = convertMarkupIntoPriceFormatter(markup.seats);\n }\n if (markup.cancel_for_any_reason) {\n if (priceFormatters && priceFormatters.cancel_for_any_reason) {\n throw new Error(errorMessage);\n }\n formatters.cancel_for_any_reason = convertMarkupIntoPriceFormatter(\n markup.cancel_for_any_reason\n );\n }\n }\n return formatters;\n};\n\nexport { createPriceFormatters };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n OfferAvailableService,\n OfferAvailableServiceBaggage,\n} from \"@duffel/api/types\";\n\nexport const isBaggageService = (\n service: OfferAvailableService\n): service is OfferAvailableServiceBaggage => service.type === \"baggage\";\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n OfferAvailableService,\n OfferAvailableServiceCFAR,\n} from \"@duffel/api/types\";\n\nexport const isCancelForAnyReasonService = (\n service: OfferAvailableService\n): service is OfferAvailableServiceCFAR =>\n service.type === \"cancel_for_any_reason\";\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\nimport { DuffelAncillariesPriceFormatters } from \"../types/DuffelAncillariesProps\";\nimport { isBaggageService } from \"./isBaggageService\";\nimport { isCancelForAnyReasonService } from \"./isCancelForAnyReasonService\";\n\nconst multipleCurrenciesErrorMessage = (\n label: string,\n currencies: Set<string>\n) => {\n return `${label} must all have the same currency, but they have ${\n currencies.size\n } different currencies (${[...currencies].join(\n \", \"\n )}). Check the price formatters passed into the component's render function.`;\n};\n\n/**\n * Formats the prices of the available services of an offer according to the\n * priceFormatters passed in.\n *\n * @param offer An offer from the Duffel API\n * @param priceFormatters Optional price formatting functions. If not passed in, the offer will be returned unchanged.\n * @returns An offer with the prices of its available services formatted according to the priceFormatters passed in.\n */\nconst formatAvailableServices = (\n offer: Offer,\n priceFormatters?: DuffelAncillariesPriceFormatters\n): Offer => {\n // If no custom formatters were passed in, don't do anything.\n if (!priceFormatters) {\n return offer;\n }\n\n const availableServices = offer.available_services;\n\n const foundCurrencies = new Set<string>();\n\n const formatters = {\n baggage: priceFormatters?.bags,\n cancel_for_any_reason: priceFormatters?.cancel_for_any_reason,\n };\n\n const servicesWithFormattedPrices = availableServices.map((service) => {\n const serviceWithFormattedPrices = { ...service };\n\n if (service.type in formatters && formatters[service.type]) {\n let { total_amount, total_currency } = service;\n\n if (isBaggageService(service)) {\n const { amount, currency } = formatters[service.type]!(\n +service.total_amount,\n service.total_currency,\n service\n );\n\n total_amount = amount.toString();\n if (currency) {\n total_currency = currency;\n }\n }\n\n if (isCancelForAnyReasonService(service)) {\n const { amount, currency } = formatters[service.type]!(\n +service.total_amount,\n service.total_currency,\n service\n );\n\n total_amount = amount.toString();\n if (currency) {\n total_currency = currency;\n }\n }\n\n // Guard against different currencies being passed in for different services.\n foundCurrencies.add(total_currency);\n if (foundCurrencies.size > 1) {\n throw new Error(\n multipleCurrenciesErrorMessage(service.type, foundCurrencies)\n );\n }\n\n serviceWithFormattedPrices.total_amount = total_amount;\n serviceWithFormattedPrices.total_currency = total_currency;\n }\n return serviceWithFormattedPrices;\n });\n return { ...offer, available_services: servicesWithFormattedPrices };\n};\n\nexport { formatAvailableServices };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n SeatMapCabinRowSectionElement,\n SeatMapCabinRowSectionElementSeat,\n} from \"@duffel/api/types\";\n\nexport function isSeatElement(\n element: SeatMapCabinRowSectionElement\n): element is SeatMapCabinRowSectionElementSeat {\n return element.type === \"seat\";\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap, SeatMapCabinRowSectionElement } from \"@duffel/api/types\";\nimport { DuffelAncillariesPriceFormatterForSeats } from \"../types/DuffelAncillariesProps\";\nimport { isSeatElement } from \"./isSeatElement\";\n\nconst multipleCurrenciesErrorMessage = (currencies: Set<string>) => {\n return `Seats must all have the same currency, but they have ${\n currencies.size\n } different currencies (${[...currencies].join(\n \", \"\n )}). Check the price formatters passed into the component's render function.`;\n};\n\nconst formatElement = (\n element: SeatMapCabinRowSectionElement,\n priceFormatter: DuffelAncillariesPriceFormatterForSeats,\n foundCurrencies: Set<string>\n) => {\n const formattedElement = { ...element };\n if (\n isSeatElement(formattedElement) &&\n formattedElement.available_services.length > 0\n ) {\n const formattedServices = formattedElement.available_services.map(\n (service) => {\n const formattedService = { ...service };\n const { amount, currency } = priceFormatter(\n +service.total_amount,\n service.total_currency,\n service\n );\n\n formattedService.total_amount = amount.toString();\n\n // Guard against different currencies being passed in for different seats.\n if (currency) {\n formattedService.total_currency = currency;\n foundCurrencies.add(currency);\n if (foundCurrencies.size > 1) {\n throw new Error(multipleCurrenciesErrorMessage(foundCurrencies));\n }\n }\n\n return formattedService;\n }\n );\n formattedElement.available_services = formattedServices;\n }\n return formattedElement;\n};\n\nconst formatSeatMaps = (\n seatMaps: SeatMap[],\n priceFormatter?: DuffelAncillariesPriceFormatterForSeats\n): SeatMap[] => {\n // If a custom formatter wasn't passed in, don't do anything.\n if (!priceFormatter) {\n return seatMaps;\n }\n\n const foundCurrencies = new Set<string>();\n\n const formattedSeatMaps: SeatMap[] = seatMaps.map((seatMap) => {\n const formattedCabins = seatMap.cabins.map((cabin) => {\n const formattedRows = cabin.rows.map((row) => {\n const formattedSections = row.sections.map((section) => {\n const formattedElements = section.elements.map((element) => {\n return formatElement(element, priceFormatter, foundCurrencies);\n });\n return { ...section, elements: formattedElements };\n });\n return { ...row, sections: formattedSections };\n });\n return { ...cabin, rows: formattedRows };\n });\n return { ...seatMap, cabins: formattedCabins };\n });\n\n return formattedSeatMaps;\n};\n\nexport { formatSeatMaps };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "/*\n * Use relative-luminance to determine whether the color is dark enough or not.\n * See also: https://www.w3.org/WAI/GL/wiki/Relative_luminance\n */\nexport const hasHighLuminance = (accentColor: string) => {\n const rgb = accentColor.split(\", \").map((x) => parseInt(x));\n const luminance = (0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2]) / 255;\n return luminance > 0.5;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder } from \"@duffel/api/types\";\n\nexport const isPayloadComplete = (\n payload: Partial<CreateOrder>\n): payload is CreateOrder =>\n \"selected_offers\" in payload &&\n \"passengers\" in payload &&\n \"services\" in payload &&\n \"payments\" in payload &&\n \"type\" in payload &&\n \"metadata\" in payload;\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\n\nexport const offerIsExpired = (offer: Offer) => {\n return offer.expires_at && new Date(offer.expires_at) < new Date();\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { logGroup } from \"./logging\";\n\nexport interface ErrorResponse extends Response {\n data: { meta: any; errors: any[] };\n}\nexport const isErrorResponse = (response: any): response is ErrorResponse => {\n return \"data\" in response && Array.isArray(response.data.errors);\n};\n\nconst DUFFEL_API_URL = process.env.DUFFEL_API_URL;\nconst COMPONENT_VERSION = process.env.COMPONENT_VERSION;\n\nexport async function fetchFromDuffelAPI(\n withClientKey: string,\n path: string,\n method = \"GET\",\n body?: string\n) {\n logGroup(\"Making request to the Duffel API\", { path, method });\n const fullUrl = `${DUFFEL_API_URL}/ancillaries-component/${path}`;\n let response: Response | null = null;\n try {\n response = await fetch(fullUrl, {\n method,\n body,\n headers: {\n \"Duffel-Version\": \"v1\",\n Authorization: `Bearer ${withClientKey}`,\n \"User-Agent\": `Duffel/ancillaries-component@${COMPONENT_VERSION}`,\n },\n });\n } catch (error) {\n logGroup(\"Failed to make request to the Duffel API\", { error });\n throw error;\n }\n\n const data = await response.json();\n if (Array.isArray(data.errors)) {\n logGroup(\"Request to the Duffel API failed\", {\n operation: `${method} ${fullUrl}`,\n method,\n request_id: data?.meta?.request_id,\n errors: data.errors,\n status: response.status,\n });\n throw { ...response, data };\n } else {\n logGroup(\"Request to the Duffel succeeded\", {\n request_id: data?.meta?.request_id,\n });\n }\n\n return data;\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer, SeatMap } from \"@duffel/api/types\";\n\nconst COMPONENT_CDN = process.env.COMPONENT_CDN;\n\nexport const importFromOfferFixtures = async (\n offerId: string\n): Promise<Offer> =>\n await (\n await fetch(COMPONENT_CDN + `/fixtures/offers/${offerId}.json`)\n ).json();\n\nexport const importFromSeatMapsFixtures = async (\n offerId: string\n): Promise<SeatMap[]> =>\n await (\n await fetch(COMPONENT_CDN + `/fixtures/seat-maps/${offerId}.json`)\n ).json();\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\n\nexport const isFixtureOfferId = (offerId: Offer[\"id\"]): boolean =>\n offerId.startsWith(\"fixture_off_\");\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { fetchFromDuffelAPI } from \"./fetchFromDuffelAPI\";\n\nexport async function retrieveOfferFromDuffelAPI(\n offer_id: string,\n client_key: string\n) {\n const getOfferResponse = await fetchFromDuffelAPI(\n client_key,\n `offers/${offer_id}?return_available_services=true`\n );\n\n return getOfferResponse.data;\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\nimport { captureErrorInSentry } from \"./captureErrorInSentry\";\nimport { isErrorResponse } from \"./fetchFromDuffelAPI\";\nimport { importFromOfferFixtures } from \"./fetchFromFixtures\";\nimport { isFixtureOfferId } from \"./isFixtureOfferId\";\nimport { retrieveOfferFromDuffelAPI } from \"./retrieveOfferFromDuffelAPI\";\n\nexport async function retrieveOffer(\n offer_id: string,\n client_key: string | null,\n onError: (error: string) => void,\n setIsLoading: (isLoading: boolean) => void,\n onOfferReady: (offer: Offer) => void\n) {\n setIsLoading(true);\n const useFixture = isFixtureOfferId(offer_id);\n offer_id = useFixture ? offer_id.replace(\"fixture_\", \"\") : offer_id;\n\n if (useFixture) {\n return importFromOfferFixtures(offer_id).then((offer) => {\n setIsLoading(false);\n onOfferReady(offer);\n });\n }\n\n if (!client_key) {\n throw new Error(\n \"Attempted to retrieve seat maps but the client key is missing.\"\n );\n }\n\n try {\n const data = await retrieveOfferFromDuffelAPI(offer_id, client_key);\n onOfferReady(data);\n } catch (error) {\n let message = \"An unknown error occurred while retrieving the offer.\";\n if (error instanceof Error) {\n message = error.message;\n if (error.message.includes(\"Load failed\")) {\n message = \"The Duffel API is not available. Please try again later.\";\n }\n } else if (isErrorResponse(error)) {\n if (error.status === 404) {\n message =\n \"The offer you are looking for does not exist or has expired.\";\n }\n }\n\n if (isErrorResponse(error) && error.status >= 500 && error.status < 600) {\n captureErrorInSentry(new Error(message));\n }\n onError(message);\n } finally {\n setIsLoading(false);\n }\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { fetchFromDuffelAPI } from \"./fetchFromDuffelAPI\";\n\nexport async function retrieveSeatMapsFromDuffelAPI(\n offer_id: string,\n client_key: string\n) {\n const getSeatMapResponse = await fetchFromDuffelAPI(\n client_key,\n `offers/${offer_id}/seat_maps`\n );\n\n return getSeatMapResponse.data;\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap } from \"@duffel/api/types\";\nimport { captureErrorInSentry } from \"./captureErrorInSentry\";\nimport { isErrorResponse } from \"./fetchFromDuffelAPI\";\nimport { importFromSeatMapsFixtures } from \"./fetchFromFixtures\";\nimport { isFixtureOfferId } from \"./isFixtureOfferId\";\nimport { retrieveSeatMapsFromDuffelAPI } from \"./retrieveSeatMapsFromDuffelAPI\";\n\nexport async function retrieveSeatMaps(\n offer_id: string,\n client_key: string | null,\n onError: () => void,\n setIsLoading: (isLoading: boolean) => void,\n onSeatMapReady: (seatMaps: SeatMap[]) => void\n) {\n setIsLoading(true);\n\n const useFixture = isFixtureOfferId(offer_id);\n offer_id = useFixture ? offer_id.replace(\"fixture_\", \"\") : offer_id;\n\n if (useFixture) {\n return importFromSeatMapsFixtures(offer_id).then((seatMaps) => {\n setIsLoading(false);\n onSeatMapReady(seatMaps);\n });\n }\n\n if (!client_key) {\n throw new Error(\n \"Attemptted to retrieve seat maps but the client key is missing.\"\n );\n }\n\n try {\n const data = await retrieveSeatMapsFromDuffelAPI(offer_id, client_key);\n onSeatMapReady(data);\n } catch (error) {\n let message = \"An unknown error occurred while retrieving the seat maps.\";\n\n if (error instanceof Error) {\n message = error.message;\n if (error.message.includes(\"Load failed\")) {\n message = \"The Duffel API is not available. Please try again later.\";\n }\n } else if (isErrorResponse(error)) {\n message =\n error.data.errors[0]?.message ||\n \"Received an unknown error from the Duffel API.\";\n }\n\n captureErrorInSentry(new Error(message));\n onError();\n } finally {\n setIsLoading(false);\n }\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n DuffelAncillariesProps,\n DuffelAncillariesPropsWithClientKeyAndOfferId,\n DuffelAncillariesPropsWithOfferIdForFixture,\n DuffelAncillariesPropsWithOffersAndSeatMaps,\n DuffelAncillariesPropWithOfferAndClientKey,\n} from \"../types/DuffelAncillariesProps\";\n\nexport const areDuffelAncillariesPropsValid = (props: DuffelAncillariesProps) =>\n hasCommonRequiredProps(props) &&\n (isDuffelAncillariesPropsWithOfferIdForFixture(props) ||\n isDuffelAncillariesPropsWithClientKeyAndOfferId(props) ||\n isDuffelAncillariesPropsWithOfferAndSeatMaps(props) ||\n isDuffelAncillariesPropsWithOfferAndClientKey(props));\n\nexport const hasCommonRequiredProps = (props: DuffelAncillariesProps) =>\n \"onPayloadReady\" in props && \"passengers\" in props && \"services\" in props;\n\nexport const isDuffelAncillariesPropsWithOfferIdForFixture = (\n props: DuffelAncillariesProps\n): props is DuffelAncillariesPropsWithOfferIdForFixture =>\n \"offer_id\" in props && props.offer_id.startsWith(\"fixture_\");\n\nexport const isDuffelAncillariesPropsWithClientKeyAndOfferId = (\n props: DuffelAncillariesProps\n): props is DuffelAncillariesPropsWithClientKeyAndOfferId =>\n \"offer_id\" in props && \"client_key\" in props;\n\nexport const isDuffelAncillariesPropsWithOfferAndSeatMaps = (\n props: DuffelAncillariesProps\n): props is DuffelAncillariesPropsWithOffersAndSeatMaps =>\n \"offer\" in props && \"seat_maps\" in props;\n\nexport const isDuffelAncillariesPropsWithOfferAndClientKey = (\n props: DuffelAncillariesProps\n): props is DuffelAncillariesPropWithOfferAndClientKey =>\n \"offer\" in props && \"client_key\" in props;\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { ErrorBoundary } from \"@components/shared/ErrorBoundary\";\nimport { FetchOfferErrorState } from \"@components/shared/FetchOfferErrorState\";\nimport { compileCreateOrderPayload } from \"@lib/compileCreateOrderPayload\";\nimport { createPriceFormatters } from \"@lib/createPriceFormatters\";\nimport { formatAvailableServices } from \"@lib/formatAvailableServices\";\nimport { formatSeatMaps } from \"@lib/formatSeatMaps\";\nimport { hasHighLuminance } from \"@lib/hasHighLuminance\";\nimport { isPayloadComplete } from \"@lib/isPayloadComplete\";\nimport { initializeLogger, logGroup } from \"@lib/logging\";\nimport { offerIsExpired } from \"@lib/offerIsExpired\";\nimport { retrieveOffer } from \"@lib/retrieveOffer\";\nimport { retrieveSeatMaps } from \"@lib/retrieveSeatMaps\";\nimport {\n areDuffelAncillariesPropsValid,\n isDuffelAncillariesPropsWithClientKeyAndOfferId,\n isDuffelAncillariesPropsWithOfferAndClientKey,\n isDuffelAncillariesPropsWithOfferAndSeatMaps,\n isDuffelAncillariesPropsWithOfferIdForFixture,\n} from \"@lib/validateProps\";\nimport * as Sentry from \"@sentry/browser\";\nimport * as React from \"react\";\nimport {\n DuffelAncillariesProps,\n WithServiceInformation,\n} from \"../../types/DuffelAncillariesProps\";\nimport { BaggageSelectionCard } from \"./bags/BaggageSelectionCard\";\nimport { CfarSelectionCard } from \"./cancel_for_any_reason/CfarSelectionCard\";\nimport { SeatSelectionCard } from \"./seats/SeatSelectionCard\";\nimport {\n CreateOrder,\n CreateOrderService,\n Offer,\n SeatMap,\n} from \"@duffel/api/types\";\n\nconst COMPONENT_CDN = process.env.COMPONENT_CDN || \"\";\nconst hrefToComponentStyles = `${COMPONENT_CDN}/global.css`;\n\nexport const DuffelAncillaries: React.FC<DuffelAncillariesProps> = (props) => {\n initializeLogger(props.debug || false);\n\n logGroup(\"Properties passed into the component:\", props);\n\n if (!areDuffelAncillariesPropsValid(props)) {\n throw new Error(\n `The props (${Object.keys(\n props\n )}) passed to DuffelAncillaries are invalid. ` +\n \"`onPayloadReady`, `passengers` and `services` are always required. \" +\n \"Then, depending on your use case you may have one of the following combinations of required props: \" +\n \"`offer_id` and `client_key`, `offer` and `seat_maps` or `offer` and `client_key`.\" +\n \"Please refer to the documentation for more information and working examples: \" +\n \"https://duffel.com/docs/guides/ancillaries-component\"\n );\n }\n if (props.services.length === 0) {\n throw new Error(\n `You must provide at least one service in the \"services\" prop. Valid services: [\"bags\", \"seats\", \"cancel_for_any_reason\"]`\n );\n }\n\n const isPropsWithOfferIdForFixture =\n isDuffelAncillariesPropsWithOfferIdForFixture(props);\n\n const isPropsWithClientKeyAndOfferId =\n isDuffelAncillariesPropsWithClientKeyAndOfferId(props);\n\n const isPropsWithOfferAndSeatMaps =\n isDuffelAncillariesPropsWithOfferAndSeatMaps(props);\n\n const isPropsWithOfferAndClientKey =\n isDuffelAncillariesPropsWithOfferAndClientKey(props);\n\n const shouldRetrieveSeatMaps =\n props.services.includes(\"seats\") &&\n !(\"seat_maps\" in props) &&\n (isPropsWithOfferIdForFixture ||\n isPropsWithClientKeyAndOfferId ||\n isPropsWithOfferAndClientKey);\n\n const [passengers, setPassengers] = React.useState<CreateOrder[\"passengers\"]>(\n props.passengers\n );\n\n const [offer, setOffer] = React.useState<Offer | undefined>(\n (props as any).offer\n );\n\n const [isOfferLoading, setIsOfferLoading] = React.useState(\n isPropsWithClientKeyAndOfferId\n );\n\n const [seatMaps, setSeatMaps] = React.useState<SeatMap[] | undefined>(\n isPropsWithOfferAndSeatMaps ? props.seat_maps : undefined\n );\n const [isSeatMapLoading, setIsSeatMapLoading] = React.useState(\n shouldRetrieveSeatMaps\n );\n\n const [error, setError] = React.useState<null | string>(null);\n\n const [baggageSelectedServices, setBaggageSelectedServices] = React.useState<\n WithServiceInformation<CreateOrderService>[]\n >([]);\n const [seatSelectedServices, setSeatSelectedServices] = React.useState<\n WithServiceInformation<CreateOrderService>[]\n >([]);\n const [cfarSelectedServices, setCfarSelectedServices] = React.useState<\n WithServiceInformation<CreateOrderService>[]\n >([]);\n\n const priceFormatters = createPriceFormatters(\n props.markup,\n props.priceFormatters\n );\n\n const updateOffer = (offer: Offer) => {\n const expiryErrorMessage = \"This offer has expired.\";\n if (offerIsExpired(offer)) {\n setError(expiryErrorMessage);\n return;\n } else {\n const msUntilExpiry = new Date(offer?.expires_at)?.getTime() - Date.now();\n\n // Only show the expiry error message if the offer expires in less than a day,\n // to prevent buffer overflows when showing offers for fixtures, which expire in\n // years.\n const milisecondsInOneDay = 1000 * 60 * 60 * 24;\n if (msUntilExpiry < milisecondsInOneDay) {\n setTimeout(() => setError(expiryErrorMessage), msUntilExpiry);\n }\n }\n\n const offerWithFormattedServices = formatAvailableServices(\n offer,\n priceFormatters\n );\n setOffer(offerWithFormattedServices);\n };\n\n const updateSeatMaps = (seatMaps: SeatMap[]) => {\n const formattedSeatMaps = formatSeatMaps(seatMaps, priceFormatters.seats);\n setSeatMaps(formattedSeatMaps);\n };\n\n React.useEffect(() => {\n // whenever the props change, we'll set the sentry context to thse values\n // so that we can see them in the sentry logs and better support the users of the component library\n Sentry.setContext(\"props\", {\n \"props.services\": props.services,\n \"props.passengers.length\": (props as any).passengers.length,\n \"props.offer_id\": (props as any).offer_id,\n \"props.client_key\": (props as any).client_key,\n \"props.offer?.id\": (props as any).offer?.id,\n \"props.seat_maps?.[0]?.id\": (props as any).seat_maps?.[0]?.id,\n });\n\n if (isPropsWithClientKeyAndOfferId || isPropsWithOfferIdForFixture) {\n retrieveOffer(\n props.offer_id,\n !isPropsWithOfferIdForFixture ? props.client_key : null,\n setError,\n setIsOfferLoading,\n (offer) => {\n updateOffer(offer);\n\n if (offer.passengers.length !== passengers.length) {\n throw new Error(\n `The number of passengers given to \\`duffel-ancillaries\\` (${props.passengers.length}) doesn't match ` +\n `the number of passengers on the given offer (${offer.passengers.length}).`\n );\n }\n\n if (isPropsWithOfferIdForFixture) {\n // There's no way the component users will know the passenger IDs for the fixture offer\n // so we'll need to add them here\n setPassengers(\n props.passengers.map((passenger, index) => ({\n ...passenger,\n id: offer.passengers[index].id,\n }))\n );\n }\n }\n );\n }\n\n if (shouldRetrieveSeatMaps) {\n retrieveSeatMaps(\n isPropsWithClientKeyAndOfferId || isPropsWithOfferIdForFixture\n ? props.offer_id\n : props.offer.id,\n !isPropsWithOfferIdForFixture ? props.client_key : null,\n () => updateSeatMaps([]),\n setIsSeatMapLoading,\n updateSeatMaps\n );\n }\n\n if (isPropsWithOfferAndClientKey) {\n updateOffer(props.offer);\n }\n\n if (isPropsWithOfferAndSeatMaps) {\n updateOffer(props.offer);\n updateSeatMaps(props.seat_maps);\n }\n }, [\n // `as any` is needed here because the list\n // of dependencies is different for each combination of props.\n // To satisfy typescript, we'd need to conditionally assign\n // the dependencies to the hook after checking its type,\n // however that is not possible in a react hook.\n (props as any).offer_id,\n (props as any).client_key,\n (props as any).offer?.id,\n (props as any).seat_maps?.[0]?.id,\n ]);\n\n React.useEffect(() => {\n if (!offer) return;\n\n const createOrderPayload = compileCreateOrderPayload({\n baggageSelectedServices,\n seatSelectedServices,\n cfarSelectedServices,\n offer,\n passengers,\n seatMaps,\n });\n\n if (isPayloadComplete(createOrderPayload)) {\n const metadata = {\n offer_total_amount: offer.total_amount,\n offer_total_currency: offer.total_currency,\n offer_tax_amount: offer.tax_amount,\n offer_tax_currency: offer.tax_currency,\n baggage_services: baggageSelectedServices,\n seat_services: seatSelectedServices,\n cancel_for_any_reason_services: cfarSelectedServices,\n };\n\n logGroup(\"Payload ready\", {\n \"Order creation payload\": createOrderPayload,\n \"Services metadata\": metadata,\n });\n\n props.onPayloadReady(createOrderPayload, metadata);\n }\n }, [baggageSelectedServices, seatSelectedServices, cfarSelectedServices]);\n\n if (!areDuffelAncillariesPropsValid(props)) {\n return null;\n }\n\n const nonIdealStateHeight = `${\n // 72 (card height) + 32 gap between cards\n 72 * props.services.length + 32 * (props.services.length - 1)\n }px`;\n\n const duffelComponentsStyle = {\n // Adding inline styles here to avoid the cards jumping down\n // before the css is loaded duet to the missing \"row gap\".\n display: \"flex\",\n width: \"100%\",\n flexDirection: \"column\",\n rowGap: \"12px\",\n ...(props.styles?.accentColor && {\n \"--ACCENT\": props.styles.accentColor,\n }),\n ...(props.styles?.accentColor &&\n hasHighLuminance(props.styles.accentColor) && {\n \"--SECONDARY\": \"var(--GREY-900)\",\n \"--TERTIARY\": \"var(--GREY-400)\",\n }),\n ...(props.styles?.fontFamily && {\n \"--FONT-FAMILY\": props.styles.fontFamily,\n }),\n ...(props.styles?.buttonCornerRadius && {\n \"--BUTTON-RADIUS\": props.styles.buttonCornerRadius,\n }),\n // `as any` is needed here is needed because we want to set css variables\n // that are not part of the css properties type\n } as any;\n\n const state = {\n isOfferLoading,\n isSeatMapLoading,\n baggageSelectedServices,\n seatSelectedServices,\n cfarSelectedServices,\n offer,\n seatMaps,\n error,\n };\n\n logGroup(\"Component's internal state:\", state);\n\n return (\n <>\n <link rel=\"stylesheet\" href={hrefToComponentStyles}></link>\n\n <div className=\"duffel-components\" style={duffelComponentsStyle}>\n <ErrorBoundary>\n {error && (\n <FetchOfferErrorState\n height={nonIdealStateHeight}\n message={error}\n />\n )}\n\n {!error &&\n props.services.map((ancillaryName) => {\n if (ancillaryName === \"bags\")\n return (\n <BaggageSelectionCard\n key=\"bags\"\n isLoading={isOfferLoading}\n offer={offer}\n passengers={passengers}\n selectedServices={baggageSelectedServices}\n setSelectedServices={setBaggageSelectedServices}\n />\n );\n\n if (ancillaryName === \"seats\")\n return (\n <SeatSelectionCard\n key=\"seats\"\n isLoading={isOfferLoading || isSeatMapLoading}\n seatMaps={seatMaps}\n offer={offer}\n passengers={passengers}\n selectedServices={seatSelectedServices}\n setSelectedServices={setSeatSelectedServices}\n />\n );\n\n if (ancillaryName === \"cancel_for_any_reason\")\n return (\n <CfarSelectionCard\n key=\"cancel_for_any_reason\"\n isLoading={isOfferLoading}\n offer={offer}\n selectedServices={cfarSelectedServices}\n setSelectedServices={setCfarSelectedServices}\n />\n );\n })}\n </ErrorBoundary>\n </div>\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import * as React from \"react\";\n\nexport const AnimatedLoaderEllipsis: React.FC = () => (\n <span className=\"textual-loading-indicator\" aria-hidden=\"true\" />\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import React from \"react\";\n\nexport interface StampProps {\n backgroundColor: React.CSSProperties[\"backgroundColor\"];\n color: React.CSSProperties[\"color\"];\n children: React.ReactNode;\n}\n\nexport const Stamp: React.FC<StampProps> = ({\n backgroundColor,\n color,\n children,\n}) => (\n <div\n style={{\n backgroundColor,\n color,\n padding: \"2px 8px\",\n whiteSpace: \"nowrap\",\n borderRadius: \"4px\",\n fontWeight: \"600\",\n fontSize: \"14px\",\n lineHeight: \"20px\",\n textAlign: \"center\",\n }}\n >\n {children}\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer } from \"@duffel/api/types\";\n\n/**\n *\n * Returns the currency of the first service of the given type in the offer.\n *\n * @param offer An offer\n * @returns A string representing the currency of the services in the offer.\n * @throws If there are no services, or none of the services are of the given type.\n */\nconst getCurrencyForServices = (offer: Offer, serviceType: string): string => {\n if (offer.available_services.length === 0) {\n throw new Error(\"No services available\");\n }\n const firstService = offer.available_services.find(\n (service) => service.type === serviceType\n );\n if (!firstService) {\n throw new Error(`No ${serviceType} services available`);\n }\n return firstService.total_currency;\n};\n\nexport { getCurrencyForServices };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder } from \"@duffel/api/types\";\n\nexport const getTotalQuantity = (\n fromSelectedServices: CreateOrder[\"services\"]\n) =>\n (fromSelectedServices || []).reduce(\n (total, { quantity }) => total + quantity,\n 0\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer, OfferAvailableService } from \"@duffel/api/types\";\nimport { isBaggageService } from \"./isBaggageService\";\nimport { isCancelForAnyReasonService } from \"./isCancelForAnyReasonService\";\n\nconst checkFunctionsMap = {\n baggage: isBaggageService,\n cancel_for_any_reason: isCancelForAnyReasonService,\n};\n\nexport const hasService = (\n offer: Offer | undefined,\n type: OfferAvailableService[\"type\"]\n) => {\n const checkFunction = checkFunctionsMap[type];\n if (!checkFunction) throw new Error(`Unknown service type: ${type}`);\n\n return (\n offer &&\n Array.isArray(offer.available_services) &&\n offer.available_services.some(\n (service) => checkFunction(service) && service.maximum_quantity > 0\n )\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "/**\n * Return a function to format a number into a money amount for a given currency\n *\n * @param currency The ISO-4217 currency code to be used by the formatter\n */\nexport const moneyStringFormatter = (\n currency: string,\n locale = \"en-GB\",\n options: { [option: string]: string } = {}\n) => {\n return (value: number) => {\n try {\n const formatter = new Intl.NumberFormat(locale, {\n style: \"currency\",\n currency,\n ...options,\n });\n const numberFormatted = formatter.format(value);\n const signFormatted =\n options &&\n options[\"signDisplay\"] &&\n (options[\"signDisplay\"] === \"always\" ||\n (options[\"signDisplay\"] === \"exceptZero\" && value !== 0))\n ? numberFormatted.replace(/^([+-])/, \"$1 \")\n : numberFormatted;\n\n return signFormatted;\n } catch (error) {\n // If the currency is not supported by the browser, we return the value with the currency code.\n // This allows us to support made-up currencies, like \"1000 Duffel Points\"\n return `${value} ${currency}`;\n }\n };\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "export const withPlural = (\n totalQuantity: number,\n singular: string,\n plural: string\n) => {\n if (totalQuantity == 1) return `${totalQuantity} ${singular}`;\n else return `${totalQuantity} ${plural}`;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { AnimatedLoaderEllipsis } from \"@components/shared/AnimatedLoaderEllipsis\";\nimport { Stamp } from \"@components/shared/Stamp\";\nimport { getCurrencyForServices } from \"@lib/getCurrencyForServices\";\nimport { getTotalAmountForServices } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { hasService } from \"@lib/hasService\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\nimport { Card } from \"../Card\";\nimport { BaggageSelectionModal } from \"./BaggageSelectionModal\";\nimport { CreateOrder, CreateOrderService, Offer } from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface BaggageSelectionCardProps {\n isLoading: boolean;\n offer?: Offer;\n passengers: CreateOrder[\"passengers\"];\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const BaggageSelectionCard: React.FC<BaggageSelectionCardProps> = ({\n isLoading,\n offer,\n passengers,\n selectedServices,\n setSelectedServices,\n}) => {\n const [isOpen, setIsOpen] = React.useState(false);\n\n const containsBaggageService = hasService(offer, \"baggage\");\n const totalQuantity = getTotalQuantity(selectedServices);\n const isBaggageAdded = totalQuantity > 0;\n\n const totalAmount = getTotalAmountForServices(offer!, selectedServices);\n\n let currencyToUse = offer?.base_currency || \"\";\n if (containsBaggageService) {\n currencyToUse = getCurrencyForServices(offer!, \"baggage\");\n }\n\n const totalAmountFormatted = offer\n ? moneyStringFormatter(currencyToUse)(totalAmount)\n : \"0\";\n\n const copy =\n containsBaggageService && isBaggageAdded\n ? `${withPlural(\n totalQuantity,\n \"bag\",\n \"bags\"\n )} added for ${totalAmountFormatted}`\n : \"Add any extra baggage you need for your trip\";\n\n return (\n <>\n <Card\n buttonTitle=\"Select extra baggage\"\n title=\"Extra baggage\"\n copy={copy}\n icon=\"cabin_bag\"\n onClick={containsBaggageService ? () => setIsOpen(true) : null}\n isLoading={isLoading}\n disabled={!isLoading && !containsBaggageService}\n isSelected={isBaggageAdded}\n >\n {isLoading && (\n <Stamp color=\"var(--GREY-900)\" backgroundColor=\"var(--GREY-100)\">\n Loading\n <AnimatedLoaderEllipsis />\n </Stamp>\n )}\n {!isLoading && !containsBaggageService && (\n <Stamp color=\"var(--GREY-700)\" backgroundColor=\"var(--GREY-200)\">\n Not available\n </Stamp>\n )}\n </Card>\n\n <BaggageSelectionModal\n isOpen={Boolean(isOpen && offer)}\n offer={offer}\n passengers={passengers}\n onClose={(newSelectedServices) => {\n // We need to do a deep copy here because otherwise the modal changing the quantity\n // will affect the selected services regardless of whether it's saved or not\n const newSelectedServicesDeepCopy = JSON.parse(\n JSON.stringify(newSelectedServices)\n );\n setSelectedServices(newSelectedServicesDeepCopy);\n setIsOpen(false);\n }}\n selectedServices={selectedServices}\n />\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon, IconName } from \"@components/shared/Icon\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\n\nexport interface CardProps {\n buttonTitle: string;\n title: string;\n icon: IconName;\n onClick?: (() => void) | null;\n children: React.ReactNode;\n copy: string;\n isLoading?: boolean;\n disabled?: boolean;\n isSelected?: boolean;\n}\n\nexport const Card: React.FC<CardProps> = ({\n buttonTitle,\n title,\n icon,\n copy,\n onClick,\n children,\n isLoading,\n disabled,\n isSelected,\n}) => {\n const hasChildren = React.Children.toArray(children).length > 0;\n\n return (\n <button\n type=\"button\"\n title={buttonTitle}\n {...(onClick && { onClick })}\n disabled={disabled}\n className={classNames(\n \"ancillary-card\",\n isLoading && \"ancillary-card--loading\"\n )}\n // We are using inline styles here because\n // we don't want the cards to appear unstyled\n // before the CSS stylesheet loads.\n // This is important for this component since it\n // be on visible on the page when it loads.\n style={{\n cursor: \"pointer\",\n background: \"transparent\",\n color: \"var(--GREY-900)\",\n border: \"solid 1px rgba(226, 226, 232, 1)\",\n display: \"flex\",\n rowGap: \"4px\",\n padding: \"20px\",\n borderRadius: \"8px\",\n justifyContent: \"space-between\",\n flexWrap: \"wrap\",\n flexDirection: \"column\",\n width: \"100%\",\n boxSizing: \"border-box\",\n fontSize: \"16px\",\n fontWeight: \"400\",\n lineHeight: \"24px\",\n letterSpacing: \"0em\",\n transition:\n \"border-color 0.3s var(--TRANSITION-CUBIC-BEZIER) background-color 0.3s var(--TRANSITION-CUBIC-BEZIER)\",\n }}\n >\n <div\n style={{\n display: \"flex\",\n alignItems: \"flex-start\",\n marginBlock: \"0\",\n textAlign: \"start\",\n marginTop: \"2px\",\n columnGap: \"12px\",\n width: \"100%\",\n }}\n >\n <div>\n {isSelected ? (\n <Icon name=\"check\" className=\"ancillary-card__selected-icon\" />\n ) : (\n <Icon name={icon} />\n )}\n </div>\n\n <div\n style={{\n display: \"flex\",\n justifyContent: \"space-between\",\n alignItems: \"start\",\n width: \"100%\",\n }}\n >\n <p\n className=\"p1--semibold\"\n style={{\n marginBlock: \"0\",\n }}\n >\n {title}\n </p>\n <div className=\"ancillary-card__children\">\n {hasChildren ? (\n children\n ) : (\n <Icon\n name=\"expand_content\"\n className=\"ancillary-card__expand-icon\"\n />\n )}\n </div>\n </div>\n </div>\n <p\n className=\"p1--regular\"\n style={{\n textAlign: \"start\",\n color: \"var(--GREY-600)\",\n marginLeft: \"34px\",\n marginBlock: \"0\",\n }}\n >\n {copy}\n </p>\n </button>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "export const setBodyScrollability = (shouldScroll: boolean) => {\n if (shouldScroll) {\n document.body.style.overflow = \"\";\n } else {\n document.body.style.overflow = \"hidden\";\n }\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { setBodyScrollability } from \"@lib/setBodyScrollability\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\nimport { IconButton } from \"./IconButton\";\n\ninterface ModalProps {\n onClose: () => void;\n isOpen: boolean;\n children: React.ReactNode;\n}\n\nexport const Modal: React.FC<ModalProps> = ({ children, onClose, isOpen }) => {\n React.useEffect(() => {\n setBodyScrollability(!isOpen);\n return () => setBodyScrollability(true);\n }, [isOpen]);\n\n return (\n <div\n className={classNames(\"modal\", isOpen && \"modal--open\")}\n // setting inline style to avoid modal content to flash unstyled before stylesheet is loaded\n style={{ opacity: 0 }}\n >\n <div role=\"presentation\" className={\"modal--content\"}>\n {children}\n\n <IconButton\n icon=\"close\"\n onClick={onClose}\n title=\"Close modal\"\n className=\"modal--close-button\"\n />\n </div>\n </div>\n );\n};\n\nexport const ModalBody: React.FC<{ children: React.ReactNode }> = ({\n children,\n}) => <div className={\"modal-body\"}>{children}</div>;\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import classNames from \"classnames\";\nimport * as React from \"react\";\nimport { Icon, IconName } from \"./Icon\";\n\nconst ICON_BUTTON_VARIANTS = {\n primary: \"icon-button--primary\",\n outlined: \"icon-button--outlined\",\n};\n\ntype IconButtonVariants = keyof typeof ICON_BUTTON_VARIANTS;\n\ntype NativeButtonProps = React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n>;\n\nexport interface IconButtonProps\n extends Pick<NativeButtonProps, \"id\" | \"onClick\" | \"disabled\" | \"className\"> {\n \"data-testid\"?: string;\n icon: IconName;\n title: string;\n variant?: IconButtonVariants;\n}\n\nexport const IconButton: React.FC<IconButtonProps> = ({\n icon,\n variant = \"primary\",\n className,\n ...nativeButtonProps\n}) => (\n <button\n type=\"button\"\n className={classNames(\n \"icon-button\",\n ICON_BUTTON_VARIANTS[variant],\n className\n )}\n {...nativeButtonProps}\n >\n <Icon name={icon} />\n </button>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrder, CreateOrderPassenger } from \"@duffel/api/types\";\n\nexport type PassengerMapById = Record<\n CreateOrderPassenger[\"id\"],\n CreateOrderPassenger\n>;\n\nexport const getPassengerMapById = (\n passengers: CreateOrder[\"passengers\"]\n): PassengerMapById =>\n passengers.reduce(\n (all, passenger) => ({ [passenger.id]: passenger, ...all }),\n {} as PassengerMapById\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Offer, OfferSliceSegment } from \"@duffel/api/types\";\n\nexport const getSegmentList = (offer: Offer) =>\n offer.slices.reduce(\n (accumulator, slice) => [...accumulator, ...slice.segments],\n new Array<OfferSliceSegment>()\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Modal } from \"@components/shared/Modal\";\nimport { getCurrencyForServices } from \"@lib/getCurrencyForServices\";\nimport { getPassengerMapById } from \"@lib/getPassengerMapById\";\nimport { getSegmentList } from \"@lib/getSegmentList\";\nimport { getServicePriceMapById } from \"@lib/getServicePriceMapById\";\nimport { hasService } from \"@lib/hasService\";\nimport React, { useState } from \"react\";\nimport { BaggageSelectionModalBody } from \"./BaggageSelectionModalBody\";\nimport { BaggageSelectionModalFooter } from \"./BaggageSelectionModalFooter\";\nimport { BaggageSelectionModalHeader } from \"./BaggageSelectionModalHeader\";\nimport { CreateOrder, CreateOrderService, Offer } from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface BaggageSelectionModalProps {\n isOpen: boolean;\n offer?: Offer;\n passengers: CreateOrder[\"passengers\"];\n selectedServices: WithServiceInformation<CreateOrderService>[];\n onClose: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const BaggageSelectionModal: React.FC<BaggageSelectionModalProps> = ({\n isOpen,\n offer,\n passengers,\n onClose,\n selectedServices,\n}) => {\n const [currentSegmentIndex, setCurrentSegmentIndex] = useState(0);\n\n const [selectedServicesState, setSelectedServicesState] =\n React.useState(selectedServices);\n\n if (!offer) return null;\n\n const segments = getSegmentList(offer);\n const currentSegment = segments[currentSegmentIndex];\n\n const passengerMapById = getPassengerMapById(passengers);\n const servicePricesMap = getServicePriceMapById(offer.available_services);\n\n let currencyToUse = offer.base_currency;\n if (hasService(offer, \"baggage\")) {\n currencyToUse = getCurrencyForServices(offer, \"baggage\");\n }\n\n return (\n <Modal isOpen={isOpen} onClose={() => onClose(selectedServices)}>\n <BaggageSelectionModalHeader\n segmentCount={segments.length}\n currentSegment={currentSegment}\n currentSegmentIndex={currentSegmentIndex}\n setCurrentSegmentIndex={(index) => setCurrentSegmentIndex(index)}\n />\n <BaggageSelectionModalBody\n offer={offer}\n selectedServices={selectedServicesState}\n passengersById={passengerMapById}\n segment={currentSegment}\n setSelectedServices={setSelectedServicesState}\n />\n <BaggageSelectionModalFooter\n currency={currencyToUse}\n selectedServices={selectedServicesState}\n servicePrices={servicePricesMap}\n isFirstSegment={currentSegmentIndex === 0}\n isLastSegment={currentSegmentIndex + 1 === segments.length}\n onNextSegmentButtonClicked={() =>\n setCurrentSegmentIndex(currentSegmentIndex + 1)\n }\n onPreviousSegmentButtonClicked={() =>\n setCurrentSegmentIndex(currentSegmentIndex - 1)\n }\n onClose={() => onClose(selectedServicesState)}\n />\n </Modal>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { CreateOrderPassenger, OfferPassenger } from \"@duffel/api/types\";\n\nexport const getPassengerName = (\n createOrderPayloadPassenger: CreateOrderPassenger,\n offerPassenger: OfferPassenger | undefined,\n fallbackIndex: number\n): string => {\n if (!createOrderPayloadPassenger) {\n return `Passenger ${fallbackIndex}`;\n }\n\n if (\n createOrderPayloadPassenger.given_name &&\n createOrderPayloadPassenger.family_name\n ) {\n return `${createOrderPayloadPassenger.given_name} ${createOrderPayloadPassenger.family_name}`;\n }\n\n if (createOrderPayloadPassenger.given_name) {\n return createOrderPayloadPassenger.given_name;\n }\n\n if (createOrderPayloadPassenger.family_name) {\n return createOrderPayloadPassenger.family_name;\n }\n\n if (offerPassenger?.given_name && offerPassenger?.family_name) {\n return `${offerPassenger.given_name} ${offerPassenger.family_name}`;\n }\n\n if (offerPassenger?.given_name) {\n return offerPassenger.given_name;\n }\n\n if (offerPassenger?.family_name) {\n return offerPassenger.family_name;\n }\n\n return `Passenger ${fallbackIndex}`;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferAvailableServiceBaggageMetadata } from \"@duffel/api/types\";\nimport { captureErrorInSentry } from \"@lib/captureErrorInSentry\";\n\nexport const getBaggageServiceDescription = (\n metadata: OfferAvailableServiceBaggageMetadata\n) => {\n if (!metadata) {\n captureErrorInSentry(\n new Error(\"getBaggageServiceDescription was not given any metadata\")\n );\n return null;\n }\n\n if (\n !metadata.maximum_weight_kg &&\n !metadata.maximum_length_cm &&\n !metadata.maximum_height_cm &&\n !metadata.maximum_depth_cm\n ) {\n return null;\n }\n\n const hasAllDimensions =\n metadata.maximum_length_cm &&\n metadata.maximum_height_cm &&\n metadata.maximum_depth_cm;\n\n let dimensionsLabel = \"\";\n if (hasAllDimensions) {\n dimensionsLabel = ` / ${metadata.maximum_height_cm} x ${metadata.maximum_length_cm} x ${metadata.maximum_depth_cm} cm`;\n }\n\n let weightLabel = \"\";\n if (metadata.maximum_weight_kg) {\n weightLabel = `Up to ${metadata.maximum_weight_kg}kg`;\n }\n\n return `${weightLabel}${dimensionsLabel}`;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n CreateOrderService,\n OfferAvailableServiceBaggage,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport const hasServiceOfSameMetadataTypeAlreadyBeenSelected = (\n selectedServices: WithServiceInformation<CreateOrderService>[],\n segmentId: string,\n passengerId: string,\n availableService: OfferAvailableServiceBaggage\n) =>\n selectedServices.some((selectedService) => {\n if (selectedService.id === availableService.id) {\n // if the selected service is the one on the counter, don't disable it\n // the max quantity will be availableService.maximum_quantity\n return false;\n } else if (\n selectedService.serviceInformation?.type !== \"carry_on\" &&\n selectedService.serviceInformation?.type !== \"checked\"\n ) {\n return false;\n } else if (selectedService.serviceInformation?.segmentId !== segmentId) {\n // if the selected service doesn't belong to the same segment, don't disable it\n return false;\n } else if (\n // if the selected service doesn't belong to the same passenger, don't disable it\n selectedService.serviceInformation?.passengerId !== passengerId\n ) {\n return false;\n } else {\n // if this service selection controller is for the same passenger and segment, disable it\n return (\n selectedService.serviceInformation?.type ===\n availableService.metadata.type\n );\n }\n });\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { IconButton } from \"@components/shared/IconButton\";\nimport * as React from \"react\";\n\ninterface CounterProps {\n id: string;\n min: number;\n max: number;\n value: number;\n onChange: (value: number) => void;\n}\n\nexport const Counter: React.FC<CounterProps> = ({\n id,\n min,\n max,\n value,\n onChange,\n}) => (\n <div className=\"counter\" id={id}>\n <IconButton\n icon=\"minus\"\n title=\"Remove one\"\n id={`${id}-minus`}\n data-testid={`${id}-minus`}\n variant=\"outlined\"\n disabled={value <= min}\n onClick={() => onChange(Math.max(value - 1, min))}\n />\n <div className=\"counter__count-label\">{value}</div>\n <IconButton\n icon=\"add\"\n title=\"Add one\"\n id={`${id}-plus`}\n data-testid={`${id}-plus`}\n variant=\"outlined\"\n disabled={value >= max}\n onClick={() => onChange(Math.min(value + 1, max))}\n />\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n CreateOrderService,\n OfferAvailableServiceBaggage,\n} from \"@duffel/api/types\";\nimport { getBaggageServiceDescription } from \"@lib/getBaggageServiceDescription\";\nimport { hasServiceOfSameMetadataTypeAlreadyBeenSelected } from \"@lib/hasServiceOfSameMetadataTypeAlreadyBeenSelected\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\nimport { Counter } from \"../Counter\";\n\ninterface BaggageSelectionControllerProps {\n segmentId: string;\n passengerId: string;\n availableService: OfferAvailableServiceBaggage;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n quantity: number;\n onQuantityChanged: (quantity: number) => void;\n}\n\nexport const BaggageSelectionController: React.FC<\n BaggageSelectionControllerProps\n> = ({\n segmentId,\n passengerId,\n availableService,\n quantity,\n onQuantityChanged,\n selectedServices,\n}) => {\n const serviceName =\n availableService.metadata.type === \"carry_on\" ? \"Cabin bag\" : \"Checked bag\";\n\n const servicePrice = moneyStringFormatter(availableService.total_currency)(\n +availableService.total_amount\n );\n const serviceDescription = getBaggageServiceDescription(\n availableService.metadata\n );\n\n const shouldDisableController =\n hasServiceOfSameMetadataTypeAlreadyBeenSelected(\n selectedServices,\n segmentId,\n passengerId,\n availableService\n );\n\n return (\n <div\n style={{\n display: \"flex\",\n justifyContent: \"space-between\",\n alignItems: \"center\",\n }}\n >\n <div>\n <p style={{ margin: 0 }} className=\"p2--regular\">\n {serviceName}\n <span\n style={{\n marginInline: \"4px\",\n color: \"var(--GREY-400)\",\n }}\n >\n \u2022\n </span>\n <span\n className=\"p2--semibold\"\n data-testid={`price-label--${availableService.id}--${passengerId}`}\n >\n {servicePrice}\n </span>\n </p>\n <p\n style={{ margin: 0, color: \"var(--GREY-600)\" }}\n className=\"p3--regular\"\n >\n {serviceDescription}\n </p>\n </div>\n <Counter\n id={`counter--${availableService.id}--${passengerId}`}\n min={0}\n value={quantity}\n onChange={onQuantityChanged}\n max={shouldDisableController ? 0 : availableService.maximum_quantity}\n />\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferSliceSegmentPassengerBaggage } from \"@duffel/api/types\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\n\ninterface IncludedBaggageBannerProps {\n includedBaggage: OfferSliceSegmentPassengerBaggage[];\n}\n\nexport const IncludedBaggageBanner: React.FC<IncludedBaggageBannerProps> = ({\n includedBaggage,\n}) => {\n const { carryOnBagsQuantity, checkedBagsQuantity } = includedBaggage.reduce(\n (sum, { type, quantity }) => ({\n carryOnBagsQuantity:\n sum.carryOnBagsQuantity + (type === \"carry_on\" ? quantity : 0),\n checkedBagsQuantity:\n sum.checkedBagsQuantity + (type === \"checked\" ? quantity : 0),\n }),\n {\n carryOnBagsQuantity: 0,\n checkedBagsQuantity: 0,\n }\n );\n\n const baggageLabelStringArray = new Array<string>();\n if (carryOnBagsQuantity > 0) {\n baggageLabelStringArray.push(\n withPlural(carryOnBagsQuantity, \"cabin bag\", \"cabin bags\")\n );\n }\n if (checkedBagsQuantity > 0) {\n baggageLabelStringArray.push(\n withPlural(checkedBagsQuantity, \"checked bag\", \"checked bags\")\n );\n }\n\n return (\n <div\n style={{\n marginBlock: \"8px\",\n padding: \"8px 12px\",\n color: ` var(--GREEN-300)`,\n backgroundColor: ` var(--GREEN-100)`,\n borderRadius: \"6px\",\n }}\n className=\"p2--regular\"\n >\n {baggageLabelStringArray.join(\" and \")} included with ticket\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n CreateOrderService,\n OfferAvailableServiceBaggage,\n OfferSliceSegmentPassengerBaggage,\n} from \"@duffel/api/types\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\nimport { BaggageSelectionController } from \"./BaggageSelectionController\";\nimport { IncludedBaggageBanner } from \"./IncludedBaggageBanner\";\n\nexport interface BaggageSelectionModalBodyPassengerProps {\n segmentId: string;\n passengerId: string;\n passengerName: string;\n includedBaggage: OfferSliceSegmentPassengerBaggage[];\n passengerServicesForSegment: OfferAvailableServiceBaggage[];\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const BaggageSelectionModalBodyPassenger: React.FC<\n BaggageSelectionModalBodyPassengerProps\n> = ({\n segmentId,\n passengerId,\n passengerName,\n includedBaggage,\n passengerServicesForSegment,\n selectedServices,\n setSelectedServices,\n}) => {\n const hasIncludedBaggage = includedBaggage.reduce(\n (sum, bag) => sum + bag.quantity,\n 0\n );\n\n return (\n <div style={{ marginTop: \"24px\" }}>\n <h3 style={{ margin: 0 }} className=\"p1--semibold\">\n {passengerName}\n </h3>\n {hasIncludedBaggage ? (\n <IncludedBaggageBanner includedBaggage={includedBaggage} />\n ) : null}\n\n <div style={{ display: \"flex\", rowGap: \"8px\", flexDirection: \"column\" }}>\n {passengerServicesForSegment.map((availableService) => (\n <BaggageSelectionController\n key={availableService.id}\n passengerId={passengerId}\n segmentId={segmentId}\n availableService={availableService}\n selectedServices={selectedServices}\n quantity={\n selectedServices.find(({ id }) => id == availableService.id)\n ?.quantity || 0\n }\n onQuantityChanged={(newQuantity) =>\n onBaggageQuantityChanged(\n newQuantity,\n segmentId,\n passengerId,\n passengerName,\n availableService,\n selectedServices,\n setSelectedServices\n )\n }\n />\n ))}\n </div>\n\n {passengerServicesForSegment.length === 0 && (\n <p style={{ color: `var(--GREY-700)`, margin: 0 }}>\n Extra baggage is not available for this passenger on this flight\n </p>\n )}\n </div>\n );\n};\n\nconst onBaggageQuantityChanged = (\n newQuantity: number,\n segmentId: string,\n passengerId: string,\n passengerName: string,\n availableService: OfferAvailableServiceBaggage,\n selectedServices: WithServiceInformation<CreateOrderService>[],\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void\n) => {\n // check if the service which had its quantity changed is already in the list\n const changedServiceIndex = selectedServices.findIndex(\n ({ id }) => availableService.id === id\n );\n\n // create a copy of the existing list of selected services\n const newSelectedServices = Array.from(selectedServices);\n\n // if the service is not in the list, add it\n if (changedServiceIndex < 0) {\n newSelectedServices.push({\n id: availableService.id,\n quantity: newQuantity,\n serviceInformation: {\n segmentId,\n passengerId,\n passengerName,\n total_amount: availableService.total_amount,\n total_currency: availableService.total_currency,\n ...availableService.metadata,\n },\n });\n } else {\n // if the service is in the list, update its quantity\n newSelectedServices[changedServiceIndex].quantity = newQuantity;\n }\n\n // remove any services with a quantity of 0\n // and update the list of selected services\n setSelectedServices(\n newSelectedServices.filter(({ quantity }) => quantity !== 0)\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { ModalBody } from \"@components/shared/Modal\";\nimport { getPassengerName } from \"@lib/getPassengerName\";\nimport React from \"react\";\n\nimport {\n CreateOrderPassenger,\n CreateOrderService,\n Offer,\n OfferAvailableServiceBaggage,\n OfferSliceSegment,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\nimport { BaggageSelectionModalBodyPassenger } from \"./BaggageSelectionModalBodyPassenger\";\n\nexport interface BaggageSelectionModalBodyProps {\n offer: Offer;\n segment: OfferSliceSegment;\n passengersById: Record<CreateOrderPassenger[\"id\"], CreateOrderPassenger>;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const BaggageSelectionModalBody: React.FC<\n BaggageSelectionModalBodyProps\n> = ({\n offer,\n segment,\n passengersById,\n selectedServices,\n setSelectedServices,\n}) => (\n <ModalBody>\n {segment.passengers.map(({ passenger_id, baggages }, index) => (\n <BaggageSelectionModalBodyPassenger\n key={passenger_id}\n segmentId={segment.id}\n passengerId={passenger_id}\n passengerName={getPassengerName(\n passengersById[passenger_id],\n offer.passengers.find(({ id }) => id === passenger_id),\n index + 1\n )}\n includedBaggage={baggages}\n passengerServicesForSegment={\n offer.available_services.filter(\n ({ type, passenger_ids, segment_ids }) =>\n type === \"baggage\" &&\n passenger_ids.includes(passenger_id) &&\n segment_ids.includes(segment.id)\n ) as OfferAvailableServiceBaggage[]\n }\n selectedServices={selectedServices}\n setSelectedServices={setSelectedServices}\n />\n ))}\n </ModalBody>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Button } from \"@components/shared/Button\";\nimport { CreateOrder } from \"@duffel/api/types\";\nimport { ServicePriceMapById } from \"@lib/getServicePriceMapById\";\nimport { getTotalAmountForServicesWithPriceMap } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\n\nexport interface BaggageSelectionModalFooterProps {\n currency: string;\n selectedServices: CreateOrder[\"services\"];\n servicePrices: ServicePriceMapById;\n\n isFirstSegment: boolean;\n isLastSegment: boolean;\n\n onNextSegmentButtonClicked: () => void;\n onPreviousSegmentButtonClicked: () => void;\n onClose: () => void;\n}\n\nexport const BaggageSelectionModalFooter: React.FC<\n BaggageSelectionModalFooterProps\n> = ({\n selectedServices,\n servicePrices,\n currency,\n isFirstSegment,\n isLastSegment,\n onNextSegmentButtonClicked,\n onPreviousSegmentButtonClicked,\n onClose,\n}) => {\n const totalQuantity = getTotalQuantity(selectedServices);\n const totalAmount = getTotalAmountForServicesWithPriceMap(\n servicePrices,\n selectedServices\n );\n const totalAmountLabel = moneyStringFormatter(currency)(totalAmount);\n const isOneWay = isFirstSegment && isFirstSegment;\n\n return (\n <div style={{ padding: \"16px 24px 24px\" }}>\n <div className=\"flex--space-between\">\n <div>\n Price for {withPlural(totalQuantity, \"extra bag\", \"extra bags\")}\n </div>\n <div className=\"h3--semibold\" data-testid=\"baggage-total-amount-label\">\n + {totalAmountLabel}\n </div>\n </div>\n\n <div\n style={\n isOneWay\n ? { marginTop: \"16px\", display: \"grid\" }\n : {\n marginTop: \"16px\",\n display: \"grid\",\n columnGap: \"12px\",\n gridTemplateColumns: \"repeat(2, 1fr)\",\n }\n }\n >\n {!isOneWay && (\n <Button\n size={48}\n variant=\"outlined\"\n disabled={isFirstSegment}\n onClick={() => onPreviousSegmentButtonClicked()}\n >\n Back\n </Button>\n )}\n <Button\n size={48}\n data-testid=\"confirm-selection-for-baggage\"\n onClick={() =>\n isLastSegment ? onClose() : onNextSegmentButtonClicked()\n }\n >\n {isLastSegment ? \"Confirm\" : \"Next\"}\n </Button>\n </div>\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { captureErrorInSentry } from \"./captureErrorInSentry\";\n\nexport const formatDateString = (dateString: string) => {\n const date = new Date(dateString);\n if (!isNaN(date.valueOf())) return formatDate(date);\n else {\n captureErrorInSentry(\n new Error(\n `formatDateString attempted to parse an invalid date string: ${dateString}`\n )\n );\n }\n};\n\nexport const formatDate = (date: Date) => {\n const { format } = new Intl.DateTimeFormat(undefined, {\n dateStyle: \"medium\",\n });\n return format(date);\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferSliceSegment } from \"@duffel/api/types\";\nimport { formatDateString } from \"@lib/formatDate\";\nimport React from \"react\";\n\nexport interface BaggageSelectionModalHeaderProps {\n segmentCount: number;\n currentSegmentIndex: number;\n currentSegment: OfferSliceSegment;\n setCurrentSegmentIndex: (index: number) => void;\n}\n\nexport const BaggageSelectionModalHeader: React.FC<\n BaggageSelectionModalHeaderProps\n> = ({\n segmentCount,\n currentSegmentIndex,\n currentSegment,\n setCurrentSegmentIndex,\n}) => (\n <div style={{ padding: \"24px 24px 16px\" }}>\n {segmentCount > 1 && (\n <div style={{ display: \"flex\", columnGap: \"4px\" }}>\n {Array(segmentCount)\n .fill(0)\n .map((_, index) =>\n index === currentSegmentIndex ? (\n <ActiveSegment key={`segment_${index}`} />\n ) : (\n <InactiveSegment\n key={`segment_${index}`}\n onClick={() => setCurrentSegmentIndex(index)}\n />\n )\n )}\n </div>\n )}\n <h2\n className=\"h3--semibold\"\n style={segmentCount > 1 ? { marginTop: \"12px\" } : {}}\n >\n Flight to {currentSegment.destination.iata_code}\n <span\n className=\"p2--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginLeft: \"8px\",\n }}\n >\n {formatDateString(currentSegment.departing_at)}\n </span>\n </h2>\n </div>\n);\n\nconst InactiveSegment: React.FC<{\n style?: React.CSSProperties;\n onClick?: React.MouseEventHandler<HTMLButtonElement>;\n}> = ({ onClick, style }) => (\n <button\n type=\"button\"\n onClick={onClick}\n style={{\n border: \"none\",\n width: \"4px\",\n height: \"4px\",\n padding: \"0\",\n borderRadius: \"4px\",\n backgroundColor:\n \"var(--TERTIARY, rgba(var(--ACCENT), var(--ACCENT-LIGHT-200)))\",\n transition: \"background-color 0.3s var(--TRANSITION-CUBIC-BEZIER)\",\n ...style,\n }}\n />\n);\n\nconst ActiveSegment = () => (\n <InactiveSegment\n onClick={undefined}\n style={{\n backgroundColor: \"var(--SECONDARY, rgb(var(--ACCENT)))\",\n }}\n />\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { AnimatedLoaderEllipsis } from \"@components/shared/AnimatedLoaderEllipsis\";\nimport { Stamp } from \"@components/shared/Stamp\";\nimport { CreateOrderService, Offer } from \"@duffel/api/types\";\nimport { getCurrencyForServices } from \"@lib/getCurrencyForServices\";\nimport { getTotalAmountForServices } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { hasService } from \"@lib/hasService\";\nimport { isCancelForAnyReasonService } from \"@lib/isCancelForAnyReasonService\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\nimport { Card } from \"../Card\";\nimport { CfarSelectionModal } from \"./CfarSelectionModal\";\n\nexport interface CfarSelectionCardProps {\n isLoading: boolean;\n offer?: Offer;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const CfarSelectionCard: React.FC<CfarSelectionCardProps> = ({\n isLoading,\n offer,\n selectedServices,\n setSelectedServices,\n}) => {\n const [isOpen, setIsOpen] = React.useState(false);\n\n const containsCfarService = hasService(offer, \"cancel_for_any_reason\");\n const totalQuantity = getTotalQuantity(selectedServices);\n const isCfarAdded = totalQuantity > 0;\n\n let currencyToUse = offer?.base_currency || \"\";\n if (containsCfarService) {\n currencyToUse = getCurrencyForServices(offer!, \"cancel_for_any_reason\");\n }\n\n const totalAmount = getTotalAmountForServices(offer!, selectedServices);\n const totalAmountFormatted = offer\n ? moneyStringFormatter(currencyToUse)(totalAmount)\n : \"0\";\n\n const cfarService = offer?.available_services.find(\n isCancelForAnyReasonService\n );\n\n const copy =\n containsCfarService && isCfarAdded\n ? `Your trip is protected for ${totalAmountFormatted}`\n : `Protect your purchase if you decide to cancel`;\n\n return (\n <>\n <Card\n buttonTitle=\"Add cancel for any reason\"\n title=\"Cancel for any reason\"\n copy={copy}\n icon=\"shield_with_moon\"\n onClick={containsCfarService ? () => setIsOpen(true) : null}\n isLoading={isLoading}\n disabled={!isLoading && !containsCfarService}\n isSelected={isCfarAdded}\n >\n {isLoading && (\n <Stamp color=\"var(--GREY-900)\" backgroundColor=\"var(--GREY-100)\">\n Loading\n <AnimatedLoaderEllipsis />\n </Stamp>\n )}\n {!isLoading && !containsCfarService && (\n <Stamp color=\"var(--GREY-700)\" backgroundColor=\"var(--GREY-200)\">\n Not available\n </Stamp>\n )}\n </Card>\n\n <CfarSelectionModal\n isOpen={Boolean(isOpen && offer && cfarService)}\n offerCurrency={offer?.base_currency}\n service={cfarService}\n onClose={(newSelectedServices) => {\n setIsOpen(false);\n setSelectedServices(newSelectedServices);\n }}\n selectedServices={selectedServices}\n />\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared/Icon\";\nimport React, { ReactNode } from \"react\";\n\nexport const CfarSelectionModalBodyListItem: React.FC<{\n children: ReactNode;\n}> = ({ children }) => (\n <li className=\"cfar-modal-list-item\">\n <Icon name=\"check\" />\n <p>{children}</p>\n </li>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared//Icon\";\nimport { ModalBody } from \"@components/shared/Modal\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport React from \"react\";\nimport { CfarSelectionModalBodyListItem } from \"./CfarSelectionModalBodyListItem\";\nimport { Offer, OfferAvailableServiceCFAR } from \"@duffel/api/types\";\n\nexport interface CfarSelectionModalBodyProps {\n offerCurrency: Offer[\"base_currency\"];\n service: OfferAvailableServiceCFAR;\n}\n\nexport const CfarSelectionModalBody: React.FC<CfarSelectionModalBodyProps> = ({\n offerCurrency,\n service,\n}) => (\n <ModalBody>\n <ul style={{ padding: 0 }}>\n <CfarSelectionModalBodyListItem>\n Cancel your trip for any reason\n </CfarSelectionModalBodyListItem>\n\n <CfarSelectionModalBodyListItem>\n Guaranteed refund of{\" \"}\n {moneyStringFormatter(offerCurrency)(+service.metadata.refund_amount)}\n </CfarSelectionModalBodyListItem>\n\n <CfarSelectionModalBodyListItem>\n Redeemable up to 24 hours before first flight departure\n </CfarSelectionModalBodyListItem>\n </ul>\n <a\n href={service.metadata.terms_and_conditions_url}\n rel=\"noopener noreferrer\"\n target=\"_blank\"\n className=\"p2--regular\"\n style={{\n color: \"var(--GREY-600)\",\n }}\n >\n Terms and conditions\n <Icon\n name=\"north_east\"\n size={16}\n style={{\n display: \"inline\",\n verticalAlign: \"middle\",\n marginLeft: \"4px\",\n }}\n />\n </a>\n </ModalBody>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Button } from \"@components/shared/Button\";\nimport { Icon } from \"@components/shared/Icon\";\nimport {\n CreateOrderService,\n OfferAvailableServiceCFAR,\n} from \"@duffel/api/types\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface CfarSelectionModalFooterProps {\n service: OfferAvailableServiceCFAR;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n onAddCfarService: () => void;\n onRemoveCfarService: () => void;\n onClose: () => void;\n}\n\nexport const CfarSelectionModalFooter: React.FC<\n CfarSelectionModalFooterProps\n> = ({\n service,\n selectedServices,\n onAddCfarService,\n onRemoveCfarService,\n onClose,\n}) => {\n const serviceIncluded = selectedServices.some(({ id }) => id == service.id);\n const formattedPrice = moneyStringFormatter(service.total_currency)(\n +service.total_amount\n );\n\n return (\n <div className=\"cfar-modal-footer\">\n <Button\n size={48}\n variant={serviceIncluded ? \"destructive\" : \"outlined\"}\n onClick={serviceIncluded ? onRemoveCfarService : onClose}\n >\n {serviceIncluded ? \"Remove protection\" : \"Don\u2019t protect trip\"}\n </Button>\n\n {!serviceIncluded && (\n <Button\n size={48}\n data-testid=\"confirm-selection-for-cfar\"\n onClick={onAddCfarService}\n >\n Add protection for {formattedPrice}\n </Button>\n )}\n\n {serviceIncluded && <ProtectedTripBanner />}\n </div>\n );\n};\n\nconst ProtectedTripBanner: React.FC = () => (\n <div\n style={{\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n columnGap: \"8px\",\n backgroundColor: \"var(--GREY-100)\",\n padding: \"var(--space-12)\",\n borderRadius: \"var(--BUTTON-RADIUS)\",\n }}\n >\n <Icon\n size={20}\n name=\"shield_with_moon\"\n style={{ fill: \"var(--SECONDARY, rgb(var(--ACCENT)))\" }}\n />\n Your trip is protected\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import React from \"react\";\n\nexport const CfarSelectionModalHeader: React.FC = () => (\n <div style={{ padding: \"24px 24px 16px\" }}>\n <h2 className=\"h3--semibold\" style={{ marginBlock: 0 }}>\n Cancel for any reason\n </h2>\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Modal } from \"@components/shared/Modal\";\nimport {\n CreateOrderService,\n Offer,\n OfferAvailableServiceCFAR,\n} from \"@duffel/api/types\";\nimport React from \"react\";\nimport { WithServiceInformation } from \"src/types\";\nimport { CfarSelectionModalBody } from \"./CfarSelectionModalBody\";\nimport { CfarSelectionModalFooter } from \"./CfarSelectionModalFooter\";\nimport { CfarSelectionModalHeader } from \"./CfarSelectionModalHeader\";\n\nexport interface CfarSelectionModalProps {\n isOpen: boolean;\n offerCurrency?: Offer[\"base_currency\"];\n service?: OfferAvailableServiceCFAR;\n selectedServices: WithServiceInformation<CreateOrderService>[];\n onClose: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const CfarSelectionModal: React.FC<CfarSelectionModalProps> = ({\n isOpen,\n offerCurrency,\n service,\n onClose,\n selectedServices,\n}) => {\n return (\n <Modal isOpen={isOpen} onClose={() => onClose(selectedServices)}>\n <CfarSelectionModalHeader />\n {service && offerCurrency && (\n <>\n <CfarSelectionModalBody\n service={service}\n offerCurrency={offerCurrency}\n />\n <CfarSelectionModalFooter\n service={service}\n selectedServices={selectedServices}\n onAddCfarService={() =>\n onClose([\n {\n id: service.id,\n quantity: 1,\n serviceInformation: {\n type: \"cancel_for_any_reason\",\n total_amount: service.total_amount,\n total_currency: service.total_currency,\n ...service.metadata,\n },\n },\n ])\n }\n onRemoveCfarService={() => onClose([])}\n onClose={() => onClose(selectedServices)}\n />\n </>\n )}\n </Modal>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap, SeatMapCabinRowSectionElement } from \"@duffel/api/types\";\n\nconst getFirstSeatElementMatchingCriteria = (\n seatMaps: SeatMap[],\n matcher: (element: SeatMapCabinRowSectionElement) => boolean\n) => {\n for (const seatMap of seatMaps) {\n for (const cabin of seatMap.cabins) {\n for (const row of cabin.rows) {\n for (const section of row.sections) {\n for (const element of section.elements) {\n if (matcher(element)) {\n return element;\n }\n }\n }\n }\n }\n }\n};\n\nexport { getFirstSeatElementMatchingCriteria };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap, SeatMapCabinRowSectionElementSeat } from \"@duffel/api/types\";\nimport { getFirstSeatElementMatchingCriteria } from \"./getFirstSeatElementMatchingCriteria\";\n\n/**\n *\n * Returns the currency of the first service of the given seat maps.\n *\n * @param seatMaps[] Array of seat maps\n * @returns A string representing the currency of the seat maps in the offer.\n */\nconst getCurrencyForSeatMaps = (seatMaps: SeatMap[]): string | undefined => {\n const firstElementWithServices:\n | SeatMapCabinRowSectionElementSeat\n | undefined = getFirstSeatElementMatchingCriteria(\n seatMaps,\n (element) =>\n element.type === \"seat\" && element.available_services.length > 0\n ) as SeatMapCabinRowSectionElementSeat;\n return firstElementWithServices?.available_services[0]?.total_currency;\n};\n\nexport { getCurrencyForSeatMaps };\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { AnimatedLoaderEllipsis } from \"@components/shared/AnimatedLoaderEllipsis\";\nimport { Stamp } from \"@components/shared/Stamp\";\nimport { getCurrencyForSeatMaps } from \"@lib/getCurrencyForSeatMaps\";\nimport { getTotalAmountForServices } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\nimport { Card } from \"../Card\";\nimport { SeatSelectionModal } from \"./SeatSelectionModal\";\nimport {\n CreateOrder,\n CreateOrderService,\n Offer,\n SeatMap,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface SeatSelectionCardProps {\n isLoading: boolean;\n offer?: Offer;\n seatMaps?: SeatMap[];\n passengers: CreateOrder[\"passengers\"];\n selectedServices: WithServiceInformation<CreateOrderService>[];\n setSelectedServices: (\n selectedServices: WithServiceInformation<CreateOrderService>[]\n ) => void;\n}\n\nexport const SeatSelectionCard: React.FC<SeatSelectionCardProps> = ({\n isLoading,\n offer,\n seatMaps,\n passengers,\n selectedServices,\n setSelectedServices,\n}) => {\n const [isOpen, setIsOpen] = React.useState(false);\n\n const containsSeatService = Array.isArray(seatMaps) && seatMaps.length > 0;\n const totalQuantity = getTotalQuantity(selectedServices);\n const areSeatsAdded = totalQuantity > 0;\n\n const totalAmount = getTotalAmountForServices(\n offer!,\n selectedServices,\n seatMaps\n );\n let currencyToUse = offer?.base_currency ?? \"\";\n if (seatMaps) {\n currencyToUse = getCurrencyForSeatMaps(seatMaps) ?? currencyToUse;\n }\n\n const totalAmountFormatted = offer\n ? moneyStringFormatter(currencyToUse)(totalAmount)\n : \"0\";\n\n const copy =\n containsSeatService && areSeatsAdded\n ? `${withPlural(\n totalQuantity,\n \"seat\",\n \"seats\"\n )} selected for ${totalAmountFormatted}`\n : \"Specify where on the plane you\u2019d like to sit\";\n\n return (\n <>\n <Card\n buttonTitle=\"Select seats\"\n title=\"Seat selection\"\n copy={copy}\n icon=\"flight_class\"\n onClick={containsSeatService ? () => setIsOpen(true) : null}\n isLoading={isLoading}\n disabled={isLoading && !containsSeatService}\n isSelected={areSeatsAdded}\n >\n {isLoading && (\n <Stamp color=\"var(--GREY-900)\" backgroundColor=\"var(--GREY-100)\">\n Loading\n <AnimatedLoaderEllipsis />\n </Stamp>\n )}\n {!isLoading && !containsSeatService && (\n <Stamp color=\"var(--GREY-700)\" backgroundColor=\"var(--GREY-200)\">\n Not available\n </Stamp>\n )}\n </Card>\n\n <SeatSelectionModal\n isOpen={Boolean(offer && seatMaps && isOpen)}\n seatMaps={seatMaps}\n offer={offer}\n passengers={passengers}\n selectedServices={selectedServices}\n onClose={(services) => {\n setSelectedServices(services);\n setIsOpen(false);\n }}\n />\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferSliceSegment } from \"@duffel/api/types\";\n\nexport const getPassengerBySegmentList = (segments: OfferSliceSegment[]) =>\n segments.flatMap((segment) =>\n segment.passengers.map((passenger, passengerIndex) => ({\n passenger,\n passengerIndex,\n segment,\n }))\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Modal } from \"@components/shared/Modal\";\nimport { getCurrencyForSeatMaps } from \"@lib/getCurrencyForSeatMaps\";\nimport { getPassengerBySegmentList } from \"@lib/getPassengerBySegmentList\";\nimport { getPassengerMapById } from \"@lib/getPassengerMapById\";\nimport { getPassengerName } from \"@lib/getPassengerName\";\nimport { getSegmentList } from \"@lib/getSegmentList\";\nimport { getServicePriceMapById } from \"@lib/getServicePriceMapById\";\nimport React from \"react\";\nimport { SeatSelectionModalBody } from \"./SeatSelectionModalBody\";\nimport { SeatSelectionModalFooter } from \"./SeatSelectionModalFooter\";\nimport { SeatSelectionModalHeader } from \"./SeatSelectionModalHeader\";\nimport {\n CreateOrder,\n CreateOrderService,\n Offer,\n SeatMap,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\ntype CreateOrderServiceWithInformation =\n WithServiceInformation<CreateOrderService>;\n\nexport interface SeatSelectionModalProps {\n isOpen: boolean;\n offer?: Offer;\n seatMaps?: SeatMap[];\n selectedServices: CreateOrderServiceWithInformation[];\n passengers: CreateOrder[\"passengers\"];\n onClose: (selectedServices: CreateOrderServiceWithInformation[]) => void;\n}\n\nexport const SeatSelectionModal: React.FC<SeatSelectionModalProps> = ({\n isOpen,\n offer,\n passengers,\n seatMaps,\n selectedServices,\n onClose,\n}) => {\n const [currentPermutationIndex, setCurrentPermutationIndex] =\n React.useState(0);\n\n const [selectedServicesState, setSelectedServicesState] =\n React.useState<CreateOrderServiceWithInformation[]>(selectedServices);\n const selectedServicesStateMap = selectedServicesState.reduce(\n (all, service) => ({ ...all, [service.id]: service }),\n {} as Record<string, CreateOrderServiceWithInformation>\n );\n\n if (!offer || !seatMaps) return null;\n\n const segments = getSegmentList(offer);\n const passengerMapById = getPassengerMapById(passengers);\n const servicePricesMap = getServicePriceMapById(offer.available_services);\n const segmentAndPassengerPermutations = getPassengerBySegmentList(segments);\n const {\n passenger: { passenger_id: currentPassengerId },\n passengerIndex: currentPassengerIndex,\n segment: { id: currentSegmentId },\n } = segmentAndPassengerPermutations[currentPermutationIndex];\n\n const currentSegment = segments.find(({ id }) => id === currentSegmentId)!;\n const currentPassenger = passengerMapById[currentPassengerId];\n const currentSeatMap = seatMaps.find(\n (seatMap) => seatMap.segment_id === currentSegmentId\n )!;\n\n const currentPassengerName = getPassengerName(\n currentPassenger,\n offer.passengers[currentPassengerIndex],\n currentPassengerIndex + 1\n );\n\n const onSeatToggle = (\n seatServiceToToggle: CreateOrderServiceWithInformation\n ) => {\n let newSeatServices = new Array<CreateOrderServiceWithInformation>();\n\n for (const selectedServiceFromState of selectedServicesState) {\n const hasClickedSeatToToggleOff =\n selectedServiceFromState.id === seatServiceToToggle.id &&\n seatServiceToToggle.quantity === 0;\n\n const isSelectedServiceFromStateForTheSameSegmentAndPassengerPermutation =\n selectedServiceFromState.serviceInformation?.segmentId ===\n currentSegmentId &&\n selectedServiceFromState.serviceInformation?.passengerId ===\n currentPassengerId;\n\n if (\n !hasClickedSeatToToggleOff &&\n !isSelectedServiceFromStateForTheSameSegmentAndPassengerPermutation\n ) {\n newSeatServices = [...newSeatServices, selectedServiceFromState];\n }\n }\n\n if (seatServiceToToggle.quantity > 0) {\n newSeatServices = [...newSeatServices, seatServiceToToggle];\n }\n\n setSelectedServicesState(newSeatServices);\n };\n\n const currencyToUse =\n getCurrencyForSeatMaps(seatMaps) ?? offer.total_currency;\n\n return (\n <Modal isOpen={isOpen} onClose={() => onClose(selectedServices)}>\n <SeatSelectionModalHeader\n segmentAndPassengerPermutationsCount={\n segmentAndPassengerPermutations.length\n }\n currentSegment={currentSegment}\n currentPassengerName={currentPassengerName}\n currentSegmentAndPassengerPermutationsIndex={currentPermutationIndex}\n setCurrentSegmentAndPassengerPermutationsIndex={\n setCurrentPermutationIndex\n }\n />\n <SeatSelectionModalBody\n selectedServicesMap={selectedServicesStateMap}\n seatMap={currentSeatMap}\n onSeatToggled={onSeatToggle}\n currentPassengerId={currentPassengerId}\n currentPassengerName={currentPassengerName}\n currentSegmentId={currentSegmentId}\n />\n <SeatSelectionModalFooter\n seatMaps={seatMaps}\n currency={currencyToUse}\n selectedServices={selectedServicesState}\n servicePrices={servicePricesMap}\n isFirstSegment={currentPermutationIndex === 0}\n isLastSegment={\n currentPermutationIndex + 1 === segmentAndPassengerPermutations.length\n }\n onNextSegmentButtonClicked={() => {\n setCurrentPermutationIndex(currentPermutationIndex + 1);\n }}\n onPreviousSegmentButtonClicked={() => {\n setCurrentPermutationIndex(currentPermutationIndex - 1);\n }}\n onClose={() => onClose(selectedServicesState)}\n />\n </Modal>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMap } from \"@duffel/api/types\";\n\nexport const getCabinsForSegmentAndDeck = (forDeck: number, seatMap: SeatMap) =>\n seatMap.cabins.filter((cabin) => cabin.deck === forDeck);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n SeatMapCabin,\n SeatMapCabinRowSectionElementAmenity,\n} from \"@duffel/api/types\";\n\nexport const getSymbols = (\n cabins: SeatMapCabin[]\n): Set<SeatMapCabinRowSectionElementAmenity> => {\n const results: Set<SeatMapCabinRowSectionElementAmenity> = new Set();\n for (const cabin of cabins) {\n for (const row of cabin.rows) {\n for (const section of row.sections) {\n for (const element of section.elements) {\n if (element.type !== \"seat\" && element.type !== \"empty\") {\n results.add(element.type);\n }\n }\n }\n }\n }\n return results;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { SeatMapCabin } from \"@duffel/api/types\";\n\nexport const hasWings = (cabin: SeatMapCabin, rowIndex: number) =>\n Boolean(\n cabin.wings &&\n cabin.wings.first_row_index <= rowIndex &&\n cabin.wings.last_row_index >= rowIndex\n );\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { getCabinsForSegmentAndDeck } from \"@lib/getCabinsForSegmentAndDeck\";\nimport { getSymbols } from \"@lib/getSymbols\";\nimport { hasWings } from \"@lib/hasWings\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\nimport { CreateOrderService, SeatMap as SeatMapType } from \"@duffel/api/types\";\nimport { DeckSelect } from \"./DeckSelect\";\nimport { Legend } from \"./Legend\";\nimport { Row } from \"./Row\";\nimport { SeatMapUnavailable } from \"./SeatMapUnavailable\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface SeatMapProps {\n seatMap: SeatMapType;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n currentPassengerId: string;\n currentPassengerName: string;\n currentSegmentId: string;\n}\n\nexport const SeatMap: React.FC<SeatMapProps> = ({\n seatMap,\n onSeatToggled,\n selectedServicesMap,\n currentPassengerId,\n currentPassengerName,\n currentSegmentId,\n}) => {\n const [selectedDeck, setSelectedDeck] = React.useState(0);\n\n if (!seatMap || !seatMap.cabins || !seatMap.cabins.length) {\n return <SeatMapUnavailable />;\n }\n\n const cabins = getCabinsForSegmentAndDeck(selectedDeck, seatMap);\n const hasMultipleDecks = cabins.length !== seatMap.cabins.length;\n const anyHasWings = seatMap.cabins.some((cabin) => cabin.wings);\n\n if (!cabins || !cabins.length) {\n return <SeatMapUnavailable />;\n }\n\n const symbols = getSymbols(cabins);\n\n return (\n <div\n className={classNames(\"seat-map\", {\n \"seat-map--wings\": anyHasWings,\n })}\n >\n {hasMultipleDecks && (\n <DeckSelect\n value={selectedDeck}\n setValue={(value) => {\n setSelectedDeck(value);\n }}\n />\n )}\n <div className=\"seat-map__legend-container\">\n <Legend symbols={symbols} />\n </div>\n {cabins.map((cabin, cabinIndex) => (\n <div\n key={`cabin-${cabinIndex}`}\n className=\"seat-map__map-container\"\n style={{ \"--CABIN-AISLES\": cabin.aisles } as React.CSSProperties}\n >\n {cabin.rows.map((row, rowIndex) => (\n <Row\n key={rowIndex}\n row={row}\n hasWings={hasWings(cabin, rowIndex)}\n onSeatToggled={onSeatToggled}\n selectedServicesMap={selectedServicesMap}\n currentPassengerId={currentPassengerId}\n currentPassengerName={currentPassengerName}\n currentSegmentId={currentSegmentId}\n />\n ))}\n </div>\n ))}\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import classNames from \"classnames\";\nimport React from \"react\";\n\nexport interface TabsProps {\n /**\n * The currently selected tab option\n */\n value: string;\n\n /**\n * Callback for when a new tab option is selected\n */\n onChange: (value: string) => void;\n\n /**\n * The options you want to render on the tabs\n */\n options: string[];\n}\n\nexport const Tabs: React.FC<TabsProps> = ({ value, onChange, options }) => (\n <div className=\"seat-map__tab-select\">\n {options.map((option) => (\n <button\n key={option}\n type=\"button\"\n className={classNames(\"seat-map__tab-select-option\", {\n \"seat-map__tab-select-option--selected\": option === value,\n })}\n onClick={() => value !== option && onChange(option)}\n >\n {option}\n </button>\n ))}\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Tabs } from \"@components/shared/Tabs\";\nimport * as React from \"react\";\n\nexport interface DeckSelectProps {\n /**\n * The currently selected deck number\n */\n value: number;\n /**\n * What to do when the user selects a deck\n */\n setValue: (value: number) => void;\n}\n\n/**\n * The deck selection component for the seat map.\n */\nexport const DeckSelect: React.FC<DeckSelectProps> = ({ value, setValue }) => {\n const options = [\"Lower deck\", \"Upper deck\"];\n return (\n <Tabs\n options={options}\n value={options[value]}\n onChange={(item) => setValue(options.indexOf(item))}\n />\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon, IconName } from \"@components/shared/Icon\";\nimport { SeatMapCabinRowSectionElementAmenity } from \"@duffel/api/types\";\nimport * as React from \"react\";\n\nexport interface LegendProps {\n /**\n * The set of additional symbols to display\n */\n symbols: Set<SeatMapCabinRowSectionElementAmenity>;\n}\n\n/**\n * The legend for the seat map.\n */\nexport const Legend: React.FC<LegendProps> = ({ symbols }) => (\n <div className=\"seat-map__legend\">\n <span className=\"seat-map__legend-item\">\n <span\n className=\"seat-map__legend-seat seat-map__legend-seat--fee-payable\"\n aria-label=\"Additional cost for seat\"\n >\n <Icon\n name=\"seat_paid_indicator\"\n className=\"seat-map__legend-seat--fee-payable-indicator\"\n size={12}\n />\n </span>\n Additional Cost\n </span>\n <span className=\"seat-map__legend-item\">\n <span\n className=\"seat-map__legend-seat seat-map__legend-seat--included\"\n aria-label=\"Included seat\"\n />\n Included\n </span>\n <span className=\"seat-map__legend-item\">\n <span\n className=\"seat-map__legend-seat seat-map__legend-seat--selected\"\n aria-label=\"Selected seat\"\n />\n Selected\n </span>\n <span className=\"seat-map__legend-item\">\n <span className=\"seat-map__legend-seat\" aria-label=\"Unavailable seat\">\n <Icon name=\"close\" size={14} />\n </span>\n Unavailable\n </span>\n {[...symbols].map((symbol) => (\n <span\n key={symbol}\n className=\"seat-map__legend-item seat-map__legend-item--symbol\"\n >\n <Icon name={symbol as IconName} size={20} />\n {symbol.split(\"_\")[0]}\n </span>\n ))}\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n SeatMapCabinRow,\n SeatMapCabinRowSectionElementSeat,\n} from \"@duffel/api/types\";\n\nexport const getRowNumber = (row: SeatMapCabinRow): string | null => {\n const seats = Object.values(row.sections)\n .map((section) => section.elements)\n .reduce((acc, val) => acc.concat(val), [])\n .filter(\n (element) => element.type === \"seat\"\n ) as SeatMapCabinRowSectionElementSeat[];\n\n return seats.length > 0\n ? seats[0].designator.substring(0, seats[0].designator.length - 1)\n : null;\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import classNames from \"classnames\";\nimport * as React from \"react\";\nimport { Element } from \"./Element\";\nimport { EmptyElement } from \"./EmptyElement\";\nimport {\n CreateOrderService,\n SeatMapCabinRow,\n SeatMapCabinRowSection,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\ninterface RowSectionProps {\n row: SeatMapCabinRow;\n rowNumber: string | null;\n hasWings: boolean;\n section: SeatMapCabinRowSection;\n sectionIndex: number;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n currentPassengerId: string;\n currentPassengerName: string;\n currentSegmentId: string;\n}\n\nexport const RowSection: React.FC<RowSectionProps> = ({\n row,\n rowNumber,\n hasWings,\n section,\n sectionIndex,\n onSeatToggled,\n selectedServicesMap,\n currentPassengerId,\n currentPassengerName,\n currentSegmentId,\n}) => {\n const rowLength = Object.keys(row.sections).length;\n const isOneSectionRow = rowLength === 1;\n\n return (\n <React.Fragment key={sectionIndex}>\n <div\n className={classNames(\"map-section\", {\n \"map-section--left\": sectionIndex === 0,\n \"map-section--right\": !isOneSectionRow\n ? sectionIndex === rowLength - 1\n : false,\n \"map-section--wing\": hasWings,\n })}\n >\n {section.elements.length > 0 ? (\n section.elements.map((element, elementIndex) => (\n <React.Fragment key={elementIndex}>\n <Element\n sectionIndex={sectionIndex}\n elementIndex={elementIndex}\n element={element}\n selectedServicesMap={selectedServicesMap}\n onSeatToggled={onSeatToggled}\n currentPassengerId={currentPassengerId}\n currentSegmentId={currentSegmentId}\n currentPassengerName={currentPassengerName}\n />\n </React.Fragment>\n ))\n ) : (\n <EmptyElement />\n )}\n </div>\n {(sectionIndex < rowLength - 1 ||\n (isOneSectionRow && sectionIndex < rowLength)) && (\n <span className=\"map-section__aisle\">{rowNumber}</span>\n )}\n {isOneSectionRow && sectionIndex === row.sections.length - 1 && (\n <EmptyElement />\n )}\n </React.Fragment>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon, IconName } from \"@components/shared/Icon\";\nimport { SeatMapCabinRowSectionElementAmenity } from \"@duffel/api/types\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\n\nconst amenitiesWithoutWrapper = [\"bassinet\", \"exit_row\"];\n\nexport interface AmenityProps {\n type: SeatMapCabinRowSectionElementAmenity;\n}\n\nexport const Amenity: React.FC<AmenityProps> = ({ type }) => (\n <div\n className={classNames(\"map-element map-element--amenity\", {\n \"map-element--wrapped\": !amenitiesWithoutWrapper.includes(type),\n })}\n aria-label={type.toString()}\n >\n <Icon name={type as IconName} size={16} />\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import * as React from \"react\";\n\nexport const EmptyElement: React.FC = () => (\n <div className=\"map-element map-element--empty\" />\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared/Icon\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\n\ninterface ExitElementProps {\n isRight: boolean;\n}\n\nexport const ExitElement: React.FC<ExitElementProps> = ({ isRight }) => (\n <div\n className={classNames(\"map-element map-element--exit\", {\n \"map-element--exit--right\": isRight,\n })}\n >\n {isRight ? <Icon name=\"exit_row_right\" /> : <Icon name=\"exit_row\" />}\n </div>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "export const getPassengerInitials = (passengerName = \"\") =>\n passengerName\n .split(\" \")\n .map((partOfTheName) => partOfTheName[0])\n .slice(0, 2)\n .join(\"\");\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared/Icon\";\nimport {\n CreateOrderService,\n SeatMapCabinRowSectionElementSeat,\n} from \"@duffel/api/types\";\nimport { getPassengerInitials } from \"@lib/getPassengerInitials\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport classNames from \"classnames\";\nimport * as React from \"react\";\nimport { SeatInfo } from \"./SeatInfo\";\nimport { SeatUnavailable } from \"./SeatUnavailable\";\nimport { WithServiceInformation } from \"src/types\";\n\ninterface SeatElementProps {\n element: SeatMapCabinRowSectionElementSeat;\n currentSegmentId: string;\n currentPassengerId: string;\n currentPassengerName: string;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n}\n\nexport const SeatElement: React.FC<SeatElementProps> = ({\n element,\n currentPassengerId,\n currentSegmentId,\n currentPassengerName,\n onSeatToggled,\n selectedServicesMap,\n}) => {\n const seatServiceFromElement = element.available_services.find(\n (service) => service.passenger_id === currentPassengerId\n );\n if (!seatServiceFromElement) return <SeatUnavailable seat={element} />;\n\n const selectedServiceFromMap = Object.values(selectedServicesMap).find(\n (service) =>\n service.serviceInformation?.designator === element.designator &&\n service.serviceInformation?.segmentId === currentSegmentId\n );\n\n const isSeatSelected = selectedServiceFromMap != undefined;\n\n const seatLabel = isSeatSelected\n ? getPassengerInitials(\n selectedServiceFromMap.serviceInformation?.passengerName\n )\n : element.designator.charAt(element.designator.length - 1);\n\n const isFeePayable =\n !isNaN(+seatServiceFromElement?.total_amount) &&\n +seatServiceFromElement?.total_amount !== 0;\n\n const isSeatSelectionAvaiable =\n !isSeatSelected &&\n seatServiceFromElement.passenger_id === currentPassengerId;\n\n const isActionable =\n !isSeatSelected ||\n (isSeatSelected &&\n currentSegmentId ===\n selectedServiceFromMap.serviceInformation?.segmentId &&\n currentPassengerId ===\n selectedServiceFromMap.serviceInformation?.passengerId);\n\n const seatClassName = classNames(\"map-element\", \"map-element__seat\", {\n \"map-element--available\": isSeatSelectionAvaiable,\n \"map-element--selected\": isSeatSelected,\n \"map-element--actionable\": isActionable,\n });\n\n const priceLabel = moneyStringFormatter(\n seatServiceFromElement.total_currency\n )(+seatServiceFromElement.total_amount);\n\n const isSeatInfoDisplayed =\n isSeatSelected &&\n currentSegmentId === selectedServiceFromMap.serviceInformation?.segmentId &&\n currentPassengerId ===\n selectedServiceFromMap.serviceInformation?.passengerId;\n\n return (\n <>\n <button\n type=\"button\"\n data-testid={`seat-${element.designator}`}\n id={element.designator}\n className={seatClassName}\n onClick={() => {\n if (!isActionable) return;\n onSeatToggled({\n quantity: isSeatSelected ? 0 : 1,\n id: seatServiceFromElement.id,\n serviceInformation: {\n type: \"seat\",\n segmentId: currentSegmentId,\n passengerId: currentPassengerId,\n passengerName: currentPassengerName,\n designator: element.designator,\n disclosures: element.disclosures,\n total_amount: seatServiceFromElement.total_amount,\n total_currency: seatServiceFromElement.total_currency,\n },\n });\n }}\n aria-label={`${element.designator} ${\n element.name || \"Seat\"\n } ${priceLabel}`}\n >\n {isFeePayable && (\n <Icon\n name=\"seat_paid_indicator\"\n className=\"map-element--fee-payable\"\n size={16}\n />\n )}\n {seatLabel}\n </button>\n {isSeatInfoDisplayed && (\n <SeatInfo seat={element} service={seatServiceFromElement} />\n )}\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import {\n SeatMapCabinRowSectionAvailableService,\n SeatMapCabinRowSectionElementSeat,\n} from \"@duffel/api/types\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport * as React from \"react\";\n\nexport interface SeatInfoProps {\n seat: SeatMapCabinRowSectionElementSeat | null;\n service: SeatMapCabinRowSectionAvailableService | undefined;\n}\n\nexport const SeatInfo: React.FC<SeatInfoProps> = ({ seat, service }) => {\n const price = service\n ? moneyStringFormatter(service.total_currency)(+service.total_amount)\n : \"\";\n\n return (\n <div className=\"seat-info\">\n <div className=\"seat-info__details\">\n <strong>{seat?.designator}</strong>\n <span>{seat?.name || \"Seat\"} </span>\n <strong>{price}</strong>\n </div>\n {seat?.disclosures.map((disclosure, index) => (\n <div key={index} className=\"seat-info__disclosure\">\n {disclosure}\n </div>\n ))}\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Icon } from \"@components/shared/Icon\";\nimport { SeatMapCabinRowSectionElementSeat } from \"@duffel/api/types\";\nimport * as React from \"react\";\n\nexport const SeatUnavailable: React.FC<{\n seat: SeatMapCabinRowSectionElementSeat;\n}> = ({ seat }) => (\n <span\n className=\"map-element map-element__seat\"\n aria-label={`${seat.designator} ${seat.name || \"Seat\"} Unavailable`}\n >\n <Icon name=\"close\" size={14} />\n </span>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { isSeatElement } from \"@lib/isSeatElement\";\nimport * as React from \"react\";\nimport { Amenity } from \"./Amenity\";\nimport { EmptyElement } from \"./EmptyElement\";\nimport { ExitElement } from \"./ExitElement\";\nimport { SeatElement } from \"./SeatElement\";\nimport {\n CreateOrderService,\n SeatMapCabinRowSectionElement,\n} from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\ninterface ElementProps {\n sectionIndex: number;\n elementIndex: number;\n element: SeatMapCabinRowSectionElement;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n currentPassengerId: string;\n currentSegmentId: string;\n currentPassengerName: string;\n}\n\nexport const Element: React.FC<ElementProps> = ({\n element,\n elementIndex,\n sectionIndex,\n onSeatToggled,\n selectedServicesMap,\n currentPassengerId,\n currentSegmentId,\n currentPassengerName,\n}) => {\n return (\n <>\n {isSeatElement(element) ? (\n <SeatElement\n currentSegmentId={currentSegmentId}\n currentPassengerId={currentPassengerId}\n currentPassengerName={currentPassengerName}\n selectedServicesMap={selectedServicesMap}\n key={elementIndex}\n element={element}\n onSeatToggled={onSeatToggled}\n />\n ) : element.type === \"empty\" ? (\n <EmptyElement key={elementIndex} />\n ) : element.type === \"exit_row\" ? (\n <ExitElement key={elementIndex} isRight={sectionIndex > 0} />\n ) : (\n <Amenity key={elementIndex} type={element.type} />\n )}\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { getRowNumber } from \"@lib/getRowNumber\";\nimport * as React from \"react\";\nimport { RowSection } from \"./RowSection\";\nimport { CreateOrderService, SeatMapCabinRow } from \"@duffel/api/types\";\nimport { WithServiceInformation } from \"src/types\";\n\nexport interface RowProps {\n row: SeatMapCabinRow;\n hasWings: boolean;\n selectedServicesMap: Record<\n string,\n WithServiceInformation<CreateOrderService>\n >;\n onSeatToggled: (\n seatService: WithServiceInformation<CreateOrderService>\n ) => void;\n currentPassengerId: string;\n currentPassengerName: string;\n currentSegmentId: string;\n}\n\nexport const Row: React.FC<RowProps> = ({\n row,\n hasWings,\n onSeatToggled,\n selectedServicesMap,\n currentPassengerId,\n currentPassengerName,\n currentSegmentId,\n}) => {\n const rowNumber = getRowNumber(row);\n\n return (\n <>\n {row.sections.map((section, sectionIndex) => (\n <RowSection\n key={sectionIndex}\n row={row}\n rowNumber={rowNumber}\n hasWings={hasWings}\n section={section}\n sectionIndex={sectionIndex}\n selectedServicesMap={selectedServicesMap}\n onSeatToggled={onSeatToggled}\n currentPassengerId={currentPassengerId}\n currentPassengerName={currentPassengerName}\n currentSegmentId={currentSegmentId}\n />\n ))}\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { NonIdealState } from \"@components/shared/NonIdealState\";\nimport * as React from \"react\";\n\nexport const SeatMapUnavailable: React.FC = () => (\n <NonIdealState>\n <p style={{ marginBlock: \"0\" }} className=\"p1--semibold\">\n Seat selection unavailable\n </p>\n <p\n className=\"p1--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginBlock: \"12px\",\n textAlign: \"center\",\n }}\n >\n Unfortunately seat selection is not available for this flight. A seat will\n be allocated by the airline.\n </p>\n </NonIdealState>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { ModalBody } from \"@components/shared/Modal\";\nimport React from \"react\";\nimport { SeatMap, SeatMapProps } from \"./SeatMap\";\n\nexport type SeatSelectionModalBodyProps = SeatMapProps;\n\nexport const SeatSelectionModalBody: React.FC<SeatSelectionModalBodyProps> = (\n props\n) => (\n <ModalBody>\n <SeatMap {...props} />\n </ModalBody>\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { Button } from \"@components/shared/Button\";\nimport { ServicePriceMapById } from \"@lib/getServicePriceMapById\";\nimport { getTotalAmountForServicesWithPriceMap } from \"@lib/getTotalAmountForServices\";\nimport { getTotalQuantity } from \"@lib/getTotalQuantity\";\nimport { moneyStringFormatter } from \"@lib/moneyStringFormatter\";\nimport { withPlural } from \"@lib/withPlural\";\nimport React from \"react\";\nimport { CreateOrder, SeatMap } from \"@duffel/api/types\";\n\nexport interface SeatSelectionModalFooterProps {\n currency: string;\n selectedServices: CreateOrder[\"services\"];\n servicePrices: ServicePriceMapById;\n\n isFirstSegment: boolean;\n isLastSegment: boolean;\n\n onNextSegmentButtonClicked: () => void;\n onPreviousSegmentButtonClicked: () => void;\n onClose: () => void;\n seatMaps: SeatMap[];\n}\n\nexport const SeatSelectionModalFooter: React.FC<\n SeatSelectionModalFooterProps\n> = ({\n selectedServices,\n servicePrices,\n currency,\n isFirstSegment,\n isLastSegment,\n onNextSegmentButtonClicked,\n onPreviousSegmentButtonClicked,\n onClose,\n seatMaps,\n}) => {\n const totalQuantity = getTotalQuantity(selectedServices);\n const totalAmount = getTotalAmountForServicesWithPriceMap(\n servicePrices,\n selectedServices,\n seatMaps\n );\n const totalAmountLabel = moneyStringFormatter(currency)(totalAmount);\n const isOneWay = isFirstSegment && isLastSegment;\n\n return (\n <div style={{ padding: \"16px 24px 24px\" }}>\n <div className=\"flex--space-between\">\n <div>Price for {withPlural(totalQuantity, \"seat\", \"seats\")}</div>\n <div className=\"h3--semibold\">+ {totalAmountLabel}</div>\n </div>\n\n <div\n style={\n isOneWay\n ? { marginTop: \"16px\", display: \"grid\" }\n : {\n marginTop: \"16px\",\n display: \"grid\",\n columnGap: \"12px\",\n gridTemplateColumns: \"repeat(2, 1fr)\",\n }\n }\n >\n {!isOneWay && (\n <Button\n size={48}\n disabled={isFirstSegment}\n variant=\"outlined\"\n onClick={() => onPreviousSegmentButtonClicked()}\n >\n Back\n </Button>\n )}\n\n <Button\n size={48}\n data-testid=\"confirm-selection-for-seats\"\n onClick={() =>\n isLastSegment ? onClose() : onNextSegmentButtonClicked()\n }\n >\n {isLastSegment ? \"Confirm\" : \"Next\"}\n </Button>\n </div>\n </div>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { OfferSliceSegment } from \"@duffel/api/types\";\nimport { formatDateString } from \"@lib/formatDate\";\nimport React from \"react\";\n\nexport interface SeatSelectionModalHeaderProps {\n segmentAndPassengerPermutationsCount: number;\n currentSegment: OfferSliceSegment;\n currentPassengerName: string;\n\n currentSegmentAndPassengerPermutationsIndex: number;\n setCurrentSegmentAndPassengerPermutationsIndex: (index: number) => void;\n}\n\nexport const SeatSelectionModalHeader: React.FC<\n SeatSelectionModalHeaderProps\n> = ({\n segmentAndPassengerPermutationsCount,\n currentSegmentAndPassengerPermutationsIndex,\n currentSegment,\n currentPassengerName,\n setCurrentSegmentAndPassengerPermutationsIndex,\n}) => (\n <div style={{ padding: \"24px 24px 16px\" }}>\n {segmentAndPassengerPermutationsCount > 1 && (\n <div style={{ display: \"flex\", columnGap: \"4px\" }}>\n {Array(segmentAndPassengerPermutationsCount)\n .fill(0)\n .map((_, index) =>\n index === currentSegmentAndPassengerPermutationsIndex ? (\n <ActiveSegment key={`segment_${index}`} />\n ) : (\n <InactiveSegment\n key={`segment_${index}`}\n onClick={() =>\n setCurrentSegmentAndPassengerPermutationsIndex(index)\n }\n />\n )\n )}\n </div>\n )}\n <h2\n className=\"h3--semibold\"\n style={\n segmentAndPassengerPermutationsCount > 1\n ? { marginBlock: \"12px 0px\" }\n : {}\n }\n >\n Flight to {currentSegment.destination.iata_code}\n <span\n className=\"p2--regular\"\n style={{\n color: \"var(--GREY-600)\",\n marginLeft: \"8px\",\n }}\n >\n {formatDateString(currentSegment.departing_at)}\n </span>\n </h2>\n <p\n className=\"h3--semibold\"\n style={{ color: `var(--GREY-600)`, marginBlock: \"0 4px\" }}\n >\n {currentPassengerName}\n </p>\n </div>\n);\n\nconst InactiveSegment: React.FC<{\n style?: React.CSSProperties;\n onClick?: React.MouseEventHandler<HTMLButtonElement>;\n}> = ({ onClick, style }) => (\n <button\n type=\"button\"\n onClick={onClick}\n style={{\n border: \"none\",\n width: \"4px\",\n height: \"4px\",\n padding: \"0\",\n borderRadius: \"4px\",\n backgroundColor:\n \"var(--TERTIARY, rgba(var(--ACCENT), var(--ACCENT-LIGHT-200)))\",\n transition: \"background-color 0.3s var(--TRANSITION-CUBIC-BEZIER)\",\n ...style,\n }}\n />\n);\n\nconst ActiveSegment = () => (\n <InactiveSegment\n onClick={undefined}\n style={{\n backgroundColor: \"var(--SECONDARY, rgb(var(--ACCENT)))\",\n }}\n />\n);\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { StripeError } from \"@stripe/stripe-js\";\nimport { createRoot, Root } from \"react-dom/client\";\nimport { DuffelPayments, DuffelPaymentsProps } from \"./DuffelPayments\";\n\ndeclare global {\n // eslint-disable-next-line @typescript-eslint/no-namespace\n namespace JSX {\n interface IntrinsicElements {\n \"duffel-payments\": React.DetailedHTMLProps<\n React.HTMLAttributes<HTMLElement>,\n HTMLElement\n >;\n }\n }\n}\n\nconst CUSTOM_ELEMENT_TAG = \"duffel-payments\";\n\ntype DuffelPaymentsCustomElementRenderArguments = Pick<\n DuffelPaymentsProps,\n \"paymentIntentClientToken\" | \"styles\"\n>;\n\nclass DuffelPaymentsCustomElement extends HTMLElement {\n /**\n * The React root for displaying content inside a browser DOM element.\n */\n private root!: Root;\n\n /**\n * `connectedCallback` is called to initialise the custom element\n */\n connectedCallback() {\n const container = document.createElement(\"div\");\n this.appendChild(container);\n\n this.root = createRoot(container);\n }\n\n /**\n * When this function is called, it will render/re-render\n * the `DuffelPayments` component with the given props.\n */\n public render(withProps: DuffelPaymentsCustomElementRenderArguments) {\n if (!this.root) {\n throw \"It was not possible to render `duffel-payments` because `this.root` is missing.\";\n }\n\n this.root.render(\n <DuffelPayments\n {...withProps}\n onSuccessfulPayment={() => {\n this.dispatchEvent(\n new CustomEvent(\"onSuccessfulPayment\", {\n composed: true,\n })\n );\n }}\n onFailedPayment={(error: StripeError) => {\n this.dispatchEvent(\n new CustomEvent(\"onFailedPayment\", {\n detail: { error },\n composed: true,\n })\n );\n }}\n />\n );\n }\n}\n\nwindow.customElements.get(CUSTOM_ELEMENT_TAG) ||\n window.customElements.define(CUSTOM_ELEMENT_TAG, DuffelPaymentsCustomElement);\n\nfunction tryToGetDuffelPaymentsCustomElement(\n caller: string\n): DuffelPaymentsCustomElement {\n const element =\n document.querySelector<DuffelPaymentsCustomElement>(CUSTOM_ELEMENT_TAG);\n if (!element) {\n throw new Error(\n `Could not find duffel-payments element in the DOM. Maybe you need to call ${caller} after 'window.onload'?`\n );\n }\n return element;\n}\n\nexport function renderDuffelPaymentsCustomElement(\n props: DuffelPaymentsCustomElementRenderArguments\n) {\n const element = tryToGetDuffelPaymentsCustomElement(\n \"renderDuffelPaymentsCustomElement\"\n );\n element.render(props);\n}\n\nexport function onDuffelPaymentsSuccessfulPayment(\n onSuccessfulPayment: DuffelPaymentsProps[\"onSuccessfulPayment\"]\n) {\n const element = tryToGetDuffelPaymentsCustomElement(\n \"onDuffelPaymentsSuccessfulPayment\"\n );\n\n // using `as EventListener` here because typescript doesn't know the event type for `onPayloadReady`\n // There's a few different suggestions to resolve this seemed good enough\n // You can learn more here: https://github.com/microsoft/TypeScript/issues/28357\n element.addEventListener(\n \"onSuccessfulPayment\",\n onSuccessfulPayment as EventListener\n );\n}\n\ntype OnFailedPaymentCustomEvent = CustomEvent<{\n error: StripeError;\n}>;\nexport function onDuffelPaymentsFailedPayment(\n onFailedPayment: DuffelPaymentsProps[\"onFailedPayment\"]\n) {\n const element = tryToGetDuffelPaymentsCustomElement(\n \"onDuffelPaymentsFailedPayment\"\n );\n const eventListener = (event: OnFailedPaymentCustomEvent) => {\n onFailedPayment(event.detail.error);\n };\n\n // using `as EventListener` here because typescript doesn't know the event type for `onPayloadReady`\n // There's a few different suggestions to resolve this seemed good enough\n // You can learn more here: https://github.com/microsoft/TypeScript/issues/28357\n element.addEventListener(\"onFailedPayment\", eventListener as EventListener);\n}\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "import { ErrorBoundary } from \"@components/shared/ErrorBoundary\";\nimport { hasHighLuminance } from \"@lib/hasHighLuminance\";\nimport { initializeLogger } from \"@lib/logging\";\nimport {\n CardElement,\n Elements,\n useElements,\n useStripe,\n} from \"@stripe/react-stripe-js\";\nimport { StripeCardElement, StripeError, loadStripe } from \"@stripe/stripe-js\";\nimport * as React from \"react\";\nimport { CustomStyles } from \"../../types\";\nimport { Button } from \"../shared/Button\";\n\nconst COMPONENT_CDN = process.env.COMPONENT_CDN || \"\";\nconst hrefToComponentStyles = `${COMPONENT_CDN}/global.css`;\n\nconst STRIPE_CARD_ELEMENT = \"card\";\nconst COMPONENT_VERSION = process.env.COMPONENT_VERSION;\n\nexport interface DuffelPaymentsProps {\n paymentIntentClientToken: string;\n onSuccessfulPayment: () => void;\n onFailedPayment: (error: StripeError) => void;\n\n styles?: CustomStyles;\n debug?: boolean;\n}\n\nconst CARD_ELEMENT_STYLE_BASE = {\n color: \"var(--GREY-900)\",\n fontFamily:\n '\"-apple-system\", \"BlinkMacSystemFont\", \"Segoe UI\", \"Roboto\", \"Oxygen\", \"Ubuntu\", \"Cantarell\", \"Fira Sans\", \"Droid Sans\", \"Helvetica Neue\", \"sans-serif\"',\n fontSmoothing: \"antialiased\",\n fontSize: \"16px\",\n \"::placeholder\": {\n color: \"#ababb4\",\n },\n};\n\nconst CARD_ELEMENT_STYLE_INVALID = {\n color: \"#ef4444\",\n iconColor: \"#ef4444\",\n};\n\nconst CardPaymentComponent: React.FC<DuffelPaymentsProps> = ({\n styles,\n paymentIntentClientToken,\n onSuccessfulPayment,\n onFailedPayment,\n}) => {\n const [cardElement, setCardElement] =\n React.useState<StripeCardElement | null>(null);\n const [isComplete, setIsComplete] = React.useState<boolean>(false);\n const [isInvalid, setIsInvalid] = React.useState<boolean>(false);\n const [isProcessing, setIsProcessing] = React.useState<boolean>(false);\n const [errorMessage, setErrorMessage] = React.useState<string>(\"\");\n const stripe = useStripe();\n const elements = useElements();\n\n React.useEffect(() => {\n if (elements && !cardElement) {\n const maybeCard = elements?.getElement(STRIPE_CARD_ELEMENT);\n maybeCard && setCardElement(maybeCard as StripeCardElement);\n }\n }, [elements, cardElement]);\n\n React.useEffect(() => {\n if (cardElement) {\n cardElement.on(\"change\", (event) => {\n const { error, complete } = event;\n\n if (error) {\n setIsInvalid(true);\n setErrorMessage(error.message);\n } else {\n setIsInvalid(false);\n }\n complete ? setIsComplete(true) : setIsComplete(false);\n });\n }\n }, [cardElement]);\n\n // User is responsible for handling outcome of payment.\n const handleSubmit = async (\n e: React.MouseEvent<HTMLFormElement, MouseEvent>\n ) => {\n e.preventDefault();\n if (!stripe || !elements) {\n return;\n }\n\n if (cardElement) {\n setIsProcessing(true);\n const decodedDuffelPaymentIntentClientToken = atob(\n paymentIntentClientToken\n );\n const parsedDuffelPaymentIntentClientToken = JSON.parse(\n decodedDuffelPaymentIntentClientToken\n );\n const { client_secret: clientSecret } =\n parsedDuffelPaymentIntentClientToken;\n\n const result = await stripe.confirmCardPayment(clientSecret, {\n payment_method: {\n card: cardElement,\n metadata: {\n duffel_components_version:\n COMPONENT_VERSION || \"failed-to-get-version\",\n },\n },\n });\n\n setIsProcessing(false);\n if (result.error) {\n const { error } = result;\n onFailedPayment(error);\n } else {\n onSuccessfulPayment();\n }\n }\n };\n\n return paymentIntentClientToken ? (\n <div className=\"card-payment__container\">\n <form onSubmit={handleSubmit}>\n {isProcessing && (\n <div\n className=\"card-payment--in-progress\"\n aria-live=\"polite\"\n aria-busy=\"true\"\n />\n )}\n <CardElement\n className=\"card-details\"\n options={{\n style: {\n base: {\n ...CARD_ELEMENT_STYLE_BASE,\n ...(styles?.fontFamily && {\n fontFamily: styles.fontFamily,\n }),\n },\n invalid: { ...CARD_ELEMENT_STYLE_INVALID },\n },\n }}\n />\n <div className=\"card-payment__container--invalid\" role=\"alert\">\n {isInvalid && errorMessage}\n </div>\n <Button\n className=\"card-payment__pay-button\"\n type=\"submit\"\n disabled={!isComplete || isProcessing}\n aria-label=\"Pay\"\n >\n {isProcessing ? \"Processing...\" : \"Pay\"}\n </Button>\n </form>\n </div>\n ) : null;\n};\n\nexport const DuffelPayments: React.FC<DuffelPaymentsProps> = (props) => {\n const [stripe, setStripe] = React.useState<Promise<any> | null>(null);\n initializeLogger(props.debug || false);\n\n const decodedDuffelPaymentIntentClientToken = atob(\n props.paymentIntentClientToken\n );\n\n let parsedDuffelPaymentIntentClientToken;\n\n try {\n parsedDuffelPaymentIntentClientToken = JSON.parse(\n decodedDuffelPaymentIntentClientToken\n );\n } catch (error) {\n throw new Error(\"Invalid Duffel payment intent client token provided\");\n }\n\n const { publishable_key: duffelPublishableKey } =\n parsedDuffelPaymentIntentClientToken;\n\n React.useEffect(() => {\n if (!stripe && duffelPublishableKey) {\n const stripe = loadStripe(duffelPublishableKey);\n stripe && setStripe(stripe);\n }\n }, [stripe, duffelPublishableKey]);\n\n const duffelComponentsStyle: React.CSSProperties = {\n ...(props.styles?.accentColor && {\n \"--ACCENT\": props.styles.accentColor,\n }),\n ...(props.styles?.accentColor &&\n hasHighLuminance(props.styles.accentColor) && {\n \"--SECONDARY\": \"black\",\n \"--TERTIARY\": \"grey\",\n }),\n ...(props.styles?.fontFamily && {\n \"--FONT-FAMILY\": props.styles.fontFamily,\n }),\n ...(props.styles?.buttonCornerRadius && {\n \"--BUTTON-RADIUS\": props.styles.buttonCornerRadius,\n }),\n // `as any` is needed here is needed because we want to set css variables\n // that are not part of the css properties type\n } as any;\n\n return (\n <>\n <link rel=\"stylesheet\" href={hrefToComponentStyles}></link>\n\n <div className=\"duffel-components\" style={duffelComponentsStyle}>\n <ErrorBoundary>\n <Elements stripe={stripe}>\n <CardPaymentComponent {...props} />\n </Elements>\n </ErrorBoundary>\n </div>\n </>\n );\n};\n;\nimport \"/Users/igor/.yarn/berry/cache/@sentry-bundler-plugin-core-npm-0.7.2-054e3436fd-10c0.zip/node_modules/@sentry/bundler-plugin-core/sentry-release-injection-file.js\";", "var V3_URL = 'https://js.stripe.com/v3';\nvar V3_URL_REGEX = /^https:\\/\\/js\\.stripe\\.com\\/v3\\/?(\\?.*)?$/;\nvar EXISTING_SCRIPT_MESSAGE = 'loadStripe.setLoadParameters was called but an existing Stripe.js script already exists in the document; existing script parameters will be used';\nvar findScript = function findScript() {\n var scripts = document.querySelectorAll(\"script[src^=\\\"\".concat(V3_URL, \"\\\"]\"));\n\n for (var i = 0; i < scripts.length; i++) {\n var script = scripts[i];\n\n if (!V3_URL_REGEX.test(script.src)) {\n continue;\n }\n\n return script;\n }\n\n return null;\n};\n\nvar injectScript = function injectScript(params) {\n var queryString = params && !params.advancedFraudSignals ? '?advancedFraudSignals=false' : '';\n var script = document.createElement('script');\n script.src = \"\".concat(V3_URL).concat(queryString);\n var headOrBody = document.head || document.body;\n\n if (!headOrBody) {\n throw new Error('Expected document.body not to be null. Stripe.js requires a <body> element.');\n }\n\n headOrBody.appendChild(script);\n return script;\n};\n\nvar registerWrapper = function registerWrapper(stripe, startTime) {\n if (!stripe || !stripe._registerWrapper) {\n return;\n }\n\n stripe._registerWrapper({\n name: 'stripe-js',\n version: \"1.54.0\",\n startTime: startTime\n });\n};\n\nvar stripePromise = null;\nvar loadScript = function loadScript(params) {\n // Ensure that we only attempt to load Stripe.js at most once\n if (stripePromise !== null) {\n return stripePromise;\n }\n\n stripePromise = new Promise(function (resolve, reject) {\n if (typeof window === 'undefined' || typeof document === 'undefined') {\n // Resolve to null when imported server side. This makes the module\n // safe to import in an isomorphic code base.\n resolve(null);\n return;\n }\n\n if (window.Stripe && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n }\n\n if (window.Stripe) {\n resolve(window.Stripe);\n return;\n }\n\n try {\n var script = findScript();\n\n if (script && params) {\n console.warn(EXISTING_SCRIPT_MESSAGE);\n } else if (!script) {\n script = injectScript(params);\n }\n\n script.addEventListener('load', function () {\n if (window.Stripe) {\n resolve(window.Stripe);\n } else {\n reject(new Error('Stripe.js not available'));\n }\n });\n script.addEventListener('error', function () {\n reject(new Error('Failed to load Stripe.js'));\n });\n } catch (error) {\n reject(error);\n return;\n }\n });\n return stripePromise;\n};\nvar initStripe = function initStripe(maybeStripe, args, startTime) {\n if (maybeStripe === null) {\n return null;\n }\n\n var stripe = maybeStripe.apply(undefined, args);\n registerWrapper(stripe, startTime);\n return stripe;\n}; // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n\n// own script injection.\n\nvar stripePromise$1 = Promise.resolve().then(function () {\n return loadScript(null);\n});\nvar loadCalled = false;\nstripePromise$1[\"catch\"](function (err) {\n if (!loadCalled) {\n console.warn(err);\n }\n});\nvar loadStripe = function loadStripe() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n loadCalled = true;\n var startTime = Date.now();\n return stripePromise$1.then(function (maybeStripe) {\n return initStripe(maybeStripe, args, startTime);\n });\n};\n\nexport { loadStripe };\n"],
5
+ "mappings": "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",
6
6
  "names": ["require_classnames", "__commonJSMin", "exports", "module", "hasOwn", "nativeCodeString", "classNames", "classes", "i", "arg", "argType", "inner", "key", "require_react_stripe_umd", "__commonJSMin", "exports", "module", "global", "factory", "React", "ownKeys", "object", "enumerableOnly", "keys", "symbols", "sym", "_objectSpread2", "target", "i", "source", "key", "_defineProperty", "_typeof", "obj", "value", "_slicedToArray", "arr", "_arrayWithHoles", "_iterableToArrayLimit", "_unsupportedIterableToArray", "_nonIterableRest", "_i", "_arr", "_n", "_d", "_s", "_e", "err", "o", "minLen", "_arrayLikeToArray", "n", "len", "arr2", "createCommonjsModule", "fn", "ReactPropTypesSecret", "ReactPropTypesSecret_1", "emptyFunction", "emptyFunctionWithReset", "factoryWithThrowingShims", "shim", "props", "propName", "componentName", "location", "propFullName", "secret", "getShim", "ReactPropTypes", "propTypes", "usePrevious", "ref", "isUnknownObject", "raw", "isPromise", "isStripe", "PLAIN_OBJECT_STR", "isEqual", "left", "right", "leftArray", "rightArray", "leftPlainObject", "rightPlainObject", "leftKeys", "rightKeys", "keySet", "allKeys", "l", "r", "pred", "extractAllowedOptionsUpdates", "options", "prevOptions", "immutableKeys", "newOptions", "isUpdated", "INVALID_STRIPE_ERROR", "validateStripe", "maybeStripe", "parseStripeProp", "stripe", "ElementsContext", "parseElementsContext", "ctx", "useCase", "CartElementContext", "parseCartElementContext", "Elements", "_ref", "rawStripeProp", "children", "parsed", "_React$useState", "_React$useState2", "cart", "setCart", "_React$useState3", "_React$useState4", "cartState", "setCartState", "_React$useState5", "_React$useState6", "setContext", "isMounted", "safeSetContext", "prevStripe", "updates", "anyStripe", "useElementsContextWithUseCase", "useCaseMessage", "useCartElementContextWithUseCase", "useElements", "_useElementsContextWi", "elements", "useStripe", "_useElementsContextWi2", "useCartElement", "_useCartElementContex", "useCartElementState", "_useCartElementContex2", "ElementsConsumer", "_ref2", "useAttachEvent", "element", "event", "cb", "cbDefined", "cbRef", "decoratedCb", "capitalized", "str", "createElementComponent", "type", "isServer", "displayName", "ClientElement", "id", "className", "_ref$options", "onBlur", "onFocus", "onReady", "onChange", "onEscape", "onClick", "onLoadError", "onLoaderStart", "onNetworksChange", "onCheckout", "onLineItemClick", "onConfirm", "onCancel", "onShippingAddressChange", "onShippingRateChange", "setElement", "elementRef", "domNode", "readyCallback", "changeCallback", "checkoutCallback", "newElement", "ServerElement", "Element", "AuBankAccountElement", "CardElement", "CardNumberElement", "CardExpiryElement", "CardCvcElement", "FpxBankElement", "IbanElement", "IdealBankElement", "P24BankElement", "EpsBankElement", "PaymentElement", "ExpressCheckoutElement", "PaymentRequestButtonElement", "LinkAuthenticationElement", "AddressElement", "ShippingAddressElement", "CartElement", "PaymentMethodMessagingElement", "AffirmMessageElement", "AfterpayClearpayMessageElement", "custom_elements_exports", "__export", "onDuffelAncillariesPayloadReady", "onDuffelPaymentsFailedPayment", "onDuffelPaymentsSuccessfulPayment", "renderDuffelAncillariesCustomElement", "renderDuffelPaymentsCustomElement", "__toCommonJS", "import_client", "objectToString", "isError", "wat", "isInstanceOf", "isBuiltin", "className", "isErrorEvent", "isDOMError", "isDOMException", "isString", "isPrimitive", "isPlainObject", "isEvent", "isElement", "isRegExp", "isThenable", "isSyntheticEvent", "isNaN", "base", "isVueViewModel", "truncate", "str", "max", "safeJoin", "input", "delimiter", "output", "i", "value", "isVueViewModel", "isMatchingPattern", "pattern", "requireExactStringMatch", "isString", "isRegExp", "stringMatchesSomePattern", "testString", "patterns", "applyAggregateErrorsToEvent", "exceptionFromErrorImplementation", "parser", "maxValueLimit", "key", "limit", "event", "hint", "isInstanceOf", "originalException", "truncateAggregateExceptions", "aggregateExceptionsFromError", "error", "prevExceptions", "exception", "exceptionId", "newExceptions", "applyExceptionGroupFieldsForParentException", "newException", "newExceptionId", "applyExceptionGroupFieldsForChildException", "childError", "i", "source", "parentId", "exceptions", "maxValueLength", "truncate", "isGlobalObj", "obj", "GLOBAL_OBJ", "getGlobalObject", "getGlobalSingleton", "name", "creator", "gbl", "__SENTRY__", "WINDOW", "getGlobalObject", "DEFAULT_MAX_STRING_LENGTH", "htmlTreeAsString", "elem", "options", "currentElem", "MAX_TRAVERSE_HEIGHT", "out", "height", "len", "separator", "sepLength", "nextStr", "keyAttrs", "maxStringLength", "_htmlElementAsString", "el", "className", "classes", "key", "attr", "i", "keyAttrPairs", "keyAttr", "keyAttrPair", "isString", "allowedAttrs", "getLocationHref", "getDomElement", "selector", "PREFIX", "CONSOLE_LEVELS", "originalConsoleMethods", "consoleSandbox", "callback", "GLOBAL_OBJ", "console", "wrappedFuncs", "wrappedLevels", "level", "originalConsoleMethod", "makeLogger", "enabled", "logger", "name", "args", "DSN_REGEX", "isValidProtocol", "protocol", "dsnToString", "dsn", "withPassword", "host", "path", "pass", "port", "projectId", "publicKey", "dsnFromString", "str", "match", "lastPath", "split", "projectMatch", "dsnFromComponents", "components", "validateDsn", "component", "logger", "makeDsn", "from", "SentryError", "message", "logLevel", "fill", "source", "name", "replacementFactory", "original", "wrapped", "markFunctionWrapped", "addNonEnumerableProperty", "obj", "value", "logger", "proto", "getOriginalFunction", "func", "urlEncode", "object", "key", "convertToPlainObject", "isError", "getOwnProperties", "isEvent", "newObj", "serializeEventTarget", "isInstanceOf", "target", "isElement", "htmlTreeAsString", "extractedProps", "property", "extractExceptionKeysForMessage", "exception", "maxLength", "keys", "truncate", "includedKeys", "serialized", "dropUndefinedKeys", "inputValue", "_dropUndefinedKeys", "memoizationMap", "isPlainObject", "memoVal", "returnValue", "item", "uuid4", "gbl", "GLOBAL_OBJ", "crypto", "getRandomByte", "c", "getFirstException", "event", "getEventDescription", "message", "eventId", "firstException", "addExceptionTypeValue", "value", "type", "exception", "values", "addExceptionMechanism", "newMechanism", "defaultMechanism", "currentMechanism", "mergedData", "checkOrSetAlreadyCaught", "exception", "addNonEnumerableProperty", "arrayify", "maybeArray", "STACKTRACE_FRAME_LIMIT", "WEBPACK_ERROR_REGEXP", "STRIP_FRAME_REGEXP", "createStackParser", "parsers", "sortedParsers", "a", "b", "p", "stack", "skipFirst", "frames", "lines", "i", "line", "cleanedLine", "parser", "frame", "stripSentryFramesAndReverse", "stackParserFromStackParserOptions", "stackParser", "localStack", "defaultFunctionName", "getFunctionName", "fn", "WINDOW", "getGlobalObject", "supportsFetch", "WINDOW", "isNativeFetch", "func", "supportsNativeFetch", "result", "doc", "sandbox", "err", "logger", "WINDOW", "getGlobalObject", "supportsHistory", "chrome", "isChromePackagedApp", "hasHistoryApi", "WINDOW", "getGlobalObject", "SENTRY_XHR_DATA_KEY", "handlers", "instrumented", "instrument", "type", "instrumentConsole", "instrumentDOM", "instrumentXHR", "instrumentFetch", "instrumentHistory", "instrumentError", "instrumentUnhandledRejection", "logger", "addInstrumentationHandler", "callback", "triggerHandlers", "type", "data", "handlers", "handler", "e", "logger", "getFunctionName", "instrumentConsole", "GLOBAL_OBJ", "CONSOLE_LEVELS", "level", "fill", "originalConsoleMethod", "originalConsoleMethods", "args", "log", "instrumentFetch", "supportsNativeFetch", "originalFetch", "method", "url", "parseFetchArgs", "handlerData", "response", "error", "hasProp", "obj", "prop", "getUrlFromResource", "resource", "fetchArgs", "options", "arg", "instrumentXHR", "WINDOW", "xhrproto", "originalOpen", "startTimestamp", "xhrInfo", "SENTRY_XHR_DATA_KEY", "isString", "onreadystatechangeHandler", "original", "readyStateArgs", "setRequestHeaderArgs", "header", "value", "originalSend", "sentryXhrData", "lastHref", "instrumentHistory", "supportsHistory", "oldOnPopState", "to", "from", "historyReplacementFunction", "originalHistoryFunction", "DEBOUNCE_DURATION", "debounceTimerID", "lastCapturedEventType", "lastCapturedEventTargetId", "isSimilarToLastCapturedEvent", "event", "shouldSkipDOMEvent", "eventType", "target", "getEventTarget", "makeDOMEventHandler", "globalListener", "addNonEnumerableProperty", "uuid4", "name", "instrumentDOM", "triggerDOMHandler", "globalDOMEventHandler", "proto", "originalAddEventListener", "listener", "el", "handlerForType", "originalRemoveEventListener", "_oldOnErrorHandler", "instrumentError", "msg", "line", "column", "_oldOnUnhandledRejectionHandler", "instrumentUnhandledRejection", "isBrowserBundle", "getSDKSource", "isNodeEnv", "isBrowserBundle", "dynamicRequire", "mod", "request", "memoBuilder", "hasWeakSet", "inner", "memoize", "obj", "unmemoize", "normalize", "input", "depth", "maxProperties", "visit", "err", "normalizeToSize", "object", "maxSize", "normalized", "jsonSize", "key", "value", "memo", "memoBuilder", "memoize", "unmemoize", "isNaN", "stringified", "stringifyValue", "remainingDepth", "valueWithToJSON", "jsonValue", "numAdded", "visitable", "convertToPlainObject", "visitKey", "visitValue", "isVueViewModel", "isSyntheticEvent", "getFunctionName", "objName", "getConstructorName", "prototype", "utf8Length", "States", "RESOLVED", "REJECTED", "resolvedSyncPromise", "value", "SyncPromise", "resolve", "rejectedSyncPromise", "reason", "_", "reject", "executor", "e", "onfulfilled", "onrejected", "result", "val", "onfinally", "isRejected", "state", "isThenable", "cachedHandlers", "handler", "makePromiseBuffer", "limit", "buffer", "isReady", "remove", "task", "add", "taskProducer", "rejectedSyncPromise", "SentryError", "drain", "timeout", "SyncPromise", "resolve", "reject", "counter", "capturedSetTimeout", "item", "resolvedSyncPromise", "parseUrl", "url", "match", "query", "fragment", "validSeverityLevels", "severityLevelFromString", "level", "validSeverityLevels", "WINDOW", "getGlobalObject", "dateTimestampSource", "getBrowserPerformance", "performance", "timeOrigin", "getNodePerformance", "dynamicRequire", "platformPerformance", "isNodeEnv", "timestampSource", "dateTimestampInSeconds", "timestampInSeconds", "_browserPerformanceTimeOriginMode", "browserPerformanceTimeOrigin", "performance", "WINDOW", "threshold", "performanceNow", "dateNow", "timeOriginDelta", "timeOriginIsReliable", "navigationStart", "navigationStartDelta", "navigationStartIsReliable", "BAGGAGE_HEADER_NAME", "SENTRY_BAGGAGE_KEY_PREFIX", "SENTRY_BAGGAGE_KEY_PREFIX_REGEX", "MAX_BAGGAGE_STRING_LENGTH", "baggageHeaderToDynamicSamplingContext", "baggageHeader", "isString", "baggageObject", "acc", "curr", "currBaggageObject", "baggageHeaderToObject", "dynamicSamplingContext", "key", "value", "nonPrefixedKey", "dynamicSamplingContextToSentryBaggageHeader", "sentryPrefixedDSC", "dscKey", "dscValue", "objectToBaggageHeader", "baggageEntry", "keyOrValue", "object", "objectKey", "objectValue", "currentIndex", "newBaggageHeader", "logger", "TRACEPARENT_REGEXP", "extractTraceparentData", "traceparent", "matches", "parentSampled", "tracingContextFromHeaders", "sentryTrace", "baggage", "traceparentData", "dynamicSamplingContext", "baggageHeaderToDynamicSamplingContext", "traceId", "parentSpanId", "propagationContext", "uuid4", "generateSentryTraceHeader", "spanId", "sampled", "sampledString", "createEnvelope", "headers", "items", "addItemToEnvelope", "envelope", "newItem", "forEachEnvelopeItem", "callback", "envelopeItems", "envelopeItem", "envelopeItemType", "encodeUTF8", "input", "textEncoder", "serializeEnvelope", "envelope", "envHeaders", "items", "parts", "append", "next", "item", "itemHeaders", "payload", "stringifiedPayload", "normalize", "concatBuffers", "buffers", "totalLength", "acc", "buf", "merged", "offset", "buffer", "createAttachmentEnvelopeItem", "attachment", "textEncoder", "buffer", "encodeUTF8", "dropUndefinedKeys", "ITEM_TYPE_TO_DATA_CATEGORY_MAP", "envelopeItemTypeToDataCategory", "type", "getSdkMetadataForEnvelopeHeader", "metadataOrEvent", "name", "version", "createEventEnvelopeHeaders", "event", "sdkInfo", "tunnel", "dsn", "dynamicSamplingContext", "dsnToString", "createClientReportEnvelope", "discarded_events", "dsn", "timestamp", "clientReportItem", "dateTimestampInSeconds", "createEnvelope", "parseRetryAfterHeader", "header", "now", "headerDelay", "headerDate", "disabledUntil", "limits", "category", "isRateLimited", "updateRateLimits", "statusCode", "headers", "updatedRateLimits", "rateLimitHeader", "retryAfterHeader", "limit", "retryAfter", "categories", "delay", "parseStackFrames", "stackParser", "error", "exceptionFromError", "exception", "frames", "DEFAULT_ENVIRONMENT", "getGlobalEventProcessors", "getGlobalSingleton", "addGlobalEventProcessor", "callback", "notifyEventProcessors", "processors", "event", "hint", "index", "SyncPromise", "resolve", "reject", "processor", "result", "logger", "isThenable", "final", "makeSession", "context", "startingTime", "timestampInSeconds", "session", "uuid4", "sessionToJSON", "updateSession", "duration", "closeSession", "status", "dropUndefinedKeys", "DEFAULT_MAX_BREADCRUMBS", "Scope", "generatePropagationContext", "scope", "newScope", "callback", "user", "updateSession", "requestSession", "tags", "key", "value", "extras", "extra", "fingerprint", "level", "name", "context", "span", "session", "captureContext", "updatedScope", "isPlainObject", "breadcrumb", "maxBreadcrumbs", "maxCrumbs", "mergedBreadcrumb", "dateTimestampInSeconds", "breadcrumbs", "attachment", "event", "hint", "additionalEventProcessors", "transaction", "transactionName", "scopeBreadcrumbs", "notifyEventProcessors", "getGlobalEventProcessors", "newData", "arrayify", "uuid4", "API_VERSION", "DEFAULT_BREADCRUMBS", "Hub", "client", "scope", "Scope", "_version", "version", "top", "callback", "exception", "hint", "eventId", "uuid4", "syntheticException", "message", "level", "event", "breadcrumb", "beforeBreadcrumb", "maxBreadcrumbs", "mergedBreadcrumb", "dateTimestampInSeconds", "finalBreadcrumb", "consoleSandbox", "user", "tags", "extras", "key", "value", "extra", "name", "context", "oldHub", "makeMain", "integration", "logger", "customSamplingContext", "result", "endSession", "session", "closeSession", "release", "environment", "DEFAULT_ENVIRONMENT", "userAgent", "GLOBAL_OBJ", "makeSession", "currentSession", "updateSession", "options", "method", "args", "sentry", "getMainCarrier", "hub", "registry", "getHubFromCarrier", "setHubOnCarrier", "getCurrentHub", "getGlobalHub", "hasHubOnCarrier", "hasHubOnCarrier", "carrier", "getHubFromCarrier", "getGlobalSingleton", "Hub", "setHubOnCarrier", "hub", "__SENTRY__", "getActiveTransaction", "maybeHub", "getCurrentHub", "errorsInstrumented", "registerErrorInstrumentation", "addInstrumentationHandler", "errorCallback", "activeTransaction", "getActiveTransaction", "status", "logger", "SpanRecorder", "maxlen", "span", "Span", "spanContext", "uuid4", "timestampInSeconds", "name", "childSpan", "opStr", "nameStr", "idStr", "logMessage", "logger", "key", "value", "httpStatus", "spanStatus", "spanStatusfromHttpCode", "endTimestamp", "generateSentryTraceHeader", "dropUndefinedKeys", "getDynamicSamplingContextFromClient", "trace_id", "client", "scope", "options", "public_key", "user_segment", "dsc", "dropUndefinedKeys", "DEFAULT_ENVIRONMENT", "Transaction", "SpanClass", "transactionContext", "hub", "getCurrentHub", "incomingDynamicSamplingContext", "newName", "name", "source", "maxlen", "SpanRecorder", "key", "context", "value", "unit", "newMetadata", "endTimestamp", "transaction", "spanContext", "dropUndefinedKeys", "client", "scope", "dsc", "getDynamicSamplingContextFromClient", "maybeSampleRate", "logger", "finishedSpans", "prev", "current", "metadata", "TRACING_DEFAULTS", "FINISH_REASON_TAG", "IDLE_TRANSACTION_FINISH_REASONS", "IdleTransactionSpanRecorder", "SpanRecorder", "_pushActivity", "_popActivity", "transactionSpanId", "maxlen", "span", "endTimestamp", "timestampInSeconds", "IdleTransaction", "Transaction", "transactionContext", "_idleHub", "_idleTimeout", "_finalTimeout", "_heartbeatInterval", "_onScope", "logger", "scope", "callback", "spanStartedBeforeTransactionFinish", "timeoutWithMarginOfError", "spanEndedBeforeFinalTimeout", "stringifiedSpan", "pushActivity", "id", "popActivity", "restartOnChildSpanChange", "reason", "spanId", "heartbeatString", "hasTracingEnabled", "maybeOptions", "client", "getCurrentHub", "options", "sampleTransaction", "transaction", "options", "samplingContext", "hasTracingEnabled", "sampleRate", "isValidSampleRate", "logger", "rate", "isNaN", "traceHeaders", "span", "_startTransaction", "transactionContext", "customSamplingContext", "client", "options", "configInstrumenter", "transactionInstrumenter", "logger", "transaction", "Transaction", "sampleTransaction", "startIdleTransaction", "hub", "idleTimeout", "finalTimeout", "onScope", "heartbeatInterval", "IdleTransaction", "addTracingExtensions", "carrier", "getMainCarrier", "registerErrorInstrumentation", "captureException", "exception", "captureContext", "getCurrentHub", "addBreadcrumb", "breadcrumb", "getCurrentHub", "setContext", "name", "context", "withScope", "callback", "getCurrentHub", "SENTRY_API_VERSION", "getBaseApiEndpoint", "dsn", "protocol", "port", "_getIngestEndpoint", "_encodedAuth", "sdkInfo", "urlEncode", "getEnvelopeEndpointWithUrlEncodedAuth", "tunnelOrOptions", "tunnel", "enhanceEventWithSdkInfo", "event", "sdkInfo", "createSessionEnvelope", "session", "dsn", "metadata", "tunnel", "getSdkMetadataForEnvelopeHeader", "envelopeHeaders", "dsnToString", "envelopeItem", "createEnvelope", "createEventEnvelope", "eventType", "createEventEnvelopeHeaders", "installedIntegrations", "filterDuplicates", "integrations", "integrationsByName", "currentInstance", "name", "existingInstance", "k", "getIntegrationsToSetup", "options", "defaultIntegrations", "userIntegrations", "integration", "arrayify", "finalIntegrations", "debugIndex", "findIndex", "debugInstance", "setupIntegrations", "client", "integrationIndex", "setupIntegration", "addGlobalEventProcessor", "getCurrentHub", "callback", "event", "hint", "processor", "logger", "findIndex", "arr", "callback", "i", "prepareEvent", "options", "event", "hint", "scope", "client", "normalizeDepth", "normalizeMaxBreadth", "prepared", "uuid4", "dateTimestampInSeconds", "integrations", "i", "applyClientOptions", "applyIntegrationsMetadata", "applyDebugIds", "finalScope", "Scope", "result", "resolvedSyncPromise", "clientEventProcessors", "attachments", "notifyEventProcessors", "getGlobalEventProcessors", "evt", "applyDebugMeta", "normalizeEvent", "environment", "release", "dist", "maxValueLength", "DEFAULT_ENVIRONMENT", "truncate", "exception", "request", "debugIdStackParserCache", "stackParser", "debugIdMap", "GLOBAL_OBJ", "debugIdStackFramesCache", "cachedDebugIdStackFrameCache", "filenameDebugIdMap", "acc", "debugIdStackTrace", "parsedStack", "cachedParsedStack", "stackFrame", "frame", "images", "filename", "integrationNames", "depth", "maxBreadth", "normalized", "b", "normalize", "span", "ALREADY_SEEN_ERROR", "BaseClient", "options", "makeDsn", "logger", "url", "getEnvelopeEndpointWithUrlEncodedAuth", "exception", "hint", "scope", "checkOrSetAlreadyCaught", "eventId", "event", "result", "message", "level", "promisedEvent", "isPrimitive", "session", "updateSession", "timeout", "transport", "clientFinished", "transportFlushed", "resolvedSyncPromise", "eventProcessor", "forceInitialize", "setupIntegrations", "integrationId", "integration", "setupIntegration", "env", "createEventEnvelope", "attachment", "addItemToEnvelope", "createAttachmentEnvelopeItem", "promise", "sendResponse", "createSessionEnvelope", "reason", "category", "_event", "key", "hook", "callback", "rest", "crashed", "errored", "exceptions", "ex", "mechanism", "sessionNonTerminal", "SyncPromise", "resolve", "ticked", "tick", "interval", "integrations", "prepareEvent", "evt", "propagationContext", "trace_id", "spanId", "parentSpanId", "dsc", "dynamicSamplingContext", "getDynamicSamplingContextFromClient", "finalEvent", "sentryError", "sampleRate", "isTransaction", "isTransactionEvent", "isError", "isErrorEvent", "eventType", "beforeSendLabel", "rejectedSyncPromise", "SentryError", "dataCategory", "prepared", "processBeforeSend", "_validateBeforeSendResult", "processedEvent", "transactionInfo", "source", "value", "envelope", "outcomes", "beforeSendResult", "invalidValueError", "isThenable", "isPlainObject", "e", "beforeSend", "beforeSendTransaction", "initAndBind", "clientClass", "options", "logger", "hub", "getCurrentHub", "client", "DEFAULT_TRANSPORT_BUFFER_SIZE", "createTransport", "options", "makeRequest", "buffer", "makePromiseBuffer", "rateLimits", "flush", "timeout", "send", "envelope", "filteredEnvelopeItems", "forEachEnvelopeItem", "item", "type", "envelopeItemDataCategory", "envelopeItemTypeToDataCategory", "isRateLimited", "event", "getEventForEnvelopeItem", "resolvedSyncPromise", "filteredEnvelope", "createEnvelope", "recordEnvelopeLoss", "reason", "requestTask", "serializeEnvelope", "response", "logger", "updateRateLimits", "error", "result", "SentryError", "SDK_VERSION", "integrations_exports", "__export", "FunctionToString", "InboundFilters", "LinkedErrors", "originalFunctionToString", "FunctionToString", "args", "context", "getOriginalFunction", "DEFAULT_IGNORE_ERRORS", "DEFAULT_IGNORE_TRANSACTIONS", "InboundFilters", "options", "_addGlobaleventProcessor", "_getCurrentHub", "event", "_eventHint", "client", "clientOptions", "_mergeOptions", "_shouldDropEvent", "internalOptions", "_isSentryError", "logger", "getEventDescription", "_isIgnoredError", "_isIgnoredTransaction", "_isDeniedUrl", "_getEventFilterUrl", "_isAllowedUrl", "ignoreErrors", "_getPossibleEventMessages", "message", "stringMatchesSomePattern", "ignoreTransactions", "name", "denyUrls", "url", "allowUrls", "possibleMessages", "lastException", "_getLastValidUrl", "frames", "i", "frame", "DEFAULT_KEY", "DEFAULT_LIMIT", "LinkedErrors", "options", "event", "hint", "client", "applyAggregateErrorsToEvent", "exceptionFromError", "WINDOW", "GLOBAL_OBJ", "ignoreOnError", "shouldIgnoreOnError", "ignoreNextOnError", "wrap", "fn", "options", "before", "wrapper", "getOriginalFunction", "sentryWrapped", "args", "wrappedArguments", "arg", "ex", "withScope", "scope", "event", "addExceptionTypeValue", "addExceptionMechanism", "captureException", "property", "markFunctionWrapped", "addNonEnumerableProperty", "exceptionFromError", "stackParser", "ex", "frames", "parseStackFrames", "exception", "extractMessage", "eventFromPlainObject", "syntheticException", "isUnhandledRejection", "client", "getCurrentHub", "normalizeDepth", "event", "isEvent", "getNonErrorObjectExceptionValue", "normalizeToSize", "eventFromError", "stacktrace", "popSize", "getPopSize", "reactMinifiedRegexp", "message", "eventFromException", "hint", "attachStacktrace", "eventFromUnknownInput", "addExceptionMechanism", "resolvedSyncPromise", "eventFromMessage", "level", "eventFromString", "isErrorEvent", "isDOMError", "isDOMException", "domException", "name", "addExceptionTypeValue", "isError", "isPlainObject", "input", "keys", "extractExceptionKeysForMessage", "captureType", "getObjectClassName", "obj", "prototype", "createUserFeedbackEnvelope", "feedback", "metadata", "tunnel", "dsn", "headers", "dsnToString", "item", "createUserFeedbackEnvelopeItem", "createEnvelope", "BrowserClient", "BaseClient", "options", "sdkSource", "WINDOW", "getSDKSource", "SDK_VERSION", "exception", "hint", "eventFromException", "message", "level", "eventFromMessage", "feedback", "logger", "envelope", "createUserFeedbackEnvelope", "event", "scope", "outcomes", "createClientReportEnvelope", "dsnToString", "cachedFetchImpl", "getNativeFetchImplementation", "isNativeFetch", "WINDOW", "document", "fetchImpl", "sandbox", "contentWindow", "e", "logger", "clearCachedFetchImplementation", "makeFetchTransport", "options", "nativeFetch", "getNativeFetchImplementation", "pendingBodySize", "pendingCount", "makeRequest", "request", "requestSize", "requestOptions", "response", "e", "clearCachedFetchImplementation", "rejectedSyncPromise", "createTransport", "XHR_READYSTATE_DONE", "makeXHRTransport", "options", "makeRequest", "request", "SyncPromise", "resolve", "reject", "xhr", "header", "createTransport", "UNKNOWN_FUNCTION", "CHROME_PRIORITY", "WINJS_PRIORITY", "GECKO_PRIORITY", "createFrame", "filename", "func", "lineno", "colno", "frame", "chromeRegex", "chromeEvalRegex", "chrome", "line", "parts", "subMatch", "extractSafariExtensionDetails", "UNKNOWN_FUNCTION", "chromeStackLineParser", "geckoREgex", "geckoEvalRegex", "gecko", "geckoStackLineParser", "winjsRegex", "winjs", "winjsStackLineParser", "defaultStackLineParsers", "chromeStackLineParser", "geckoStackLineParser", "winjsStackLineParser", "defaultStackParser", "createStackParser", "extractSafariExtensionDetails", "func", "filename", "isSafariExtension", "isSafariWebExtension", "UNKNOWN_FUNCTION", "GlobalHandlers", "options", "_installGlobalOnErrorHandler", "_installGlobalOnUnhandledRejectionHandler", "key", "installFunc", "globalHandlerLog", "addInstrumentationHandler", "data", "hub", "stackParser", "attachStacktrace", "getHubAndOptions", "msg", "url", "line", "column", "error", "shouldIgnoreOnError", "event", "isString", "_eventFromIncompleteOnError", "_enhanceEventWithInitialFrame", "eventFromUnknownInput", "addMechanismAndCapture", "e", "isPrimitive", "_eventFromRejectionWithPrimitive", "reason", "ERROR_TYPES_RE", "message", "isErrorEvent", "name", "groups", "ev", "ev0", "ev0s", "ev0sf", "colno", "lineno", "filename", "getLocationHref", "type", "logger", "addExceptionMechanism", "getCurrentHub", "client", "DEFAULT_EVENT_TARGET", "TryCatch", "options", "fill", "WINDOW", "_wrapTimeFunction", "_wrapRAF", "_wrapXHR", "eventTargetOption", "_wrapEventTarget", "original", "args", "originalCallback", "wrap", "getFunctionName", "callback", "originalSend", "xhr", "prop", "wrapOptions", "originalFunction", "getOriginalFunction", "target", "globalObject", "proto", "eventName", "fn", "originalRemoveEventListener", "wrappedEventHandler", "originalEventHandler", "MAX_ALLOWED_STRING_LENGTH", "Breadcrumbs", "options", "addInstrumentationHandler", "_consoleBreadcrumb", "_domBreadcrumb", "_xhrBreadcrumb", "_fetchBreadcrumb", "_historyBreadcrumb", "client", "getCurrentHub", "addSentryBreadcrumb", "event", "getEventDescription", "dom", "_innerDomBreadcrumb", "handlerData", "target", "keyAttrs", "maxStringLength", "logger", "_isEvent", "htmlTreeAsString", "breadcrumb", "severityLevelFromString", "safeJoin", "startTimestamp", "endTimestamp", "sentryXhrData", "SENTRY_XHR_DATA_KEY", "method", "url", "status_code", "body", "data", "hint", "from", "to", "parsedLoc", "parseUrl", "WINDOW", "parsedFrom", "parsedTo", "DEFAULT_KEY", "DEFAULT_LIMIT", "LinkedErrors", "options", "event", "hint", "client", "applyAggregateErrorsToEvent", "exceptionFromError", "HttpContext", "event", "WINDOW", "url", "referrer", "userAgent", "headers", "request", "Dedupe", "_addGlobaleventProcessor", "_getCurrentHub", "currentEvent", "_shouldDropEvent", "logger", "previousEvent", "_isSameMessageEvent", "_isSameExceptionEvent", "currentMessage", "previousMessage", "_isSameFingerprint", "_isSameStacktrace", "previousException", "_getExceptionFromEvent", "currentException", "currentFrames", "_getFramesFromEvent", "previousFrames", "i", "frameA", "frameB", "currentFingerprint", "previousFingerprint", "event", "exception", "defaultIntegrations", "CoreIntegrations", "TryCatch", "Breadcrumbs", "GlobalHandlers", "LinkedErrors", "Dedupe", "HttpContext", "init", "options", "WINDOW", "clientOptions", "stackParserFromStackParserOptions", "defaultStackParser", "getIntegrationsToSetup", "supportsFetch", "makeFetchTransport", "makeXHRTransport", "initAndBind", "BrowserClient", "startSessionTracking", "startSessionOnHub", "hub", "startSessionTracking", "WINDOW", "logger", "getCurrentHub", "addInstrumentationHandler", "from", "to", "integrations_exports", "__export", "Breadcrumbs", "Dedupe", "GlobalHandlers", "HttpContext", "LinkedErrors", "TryCatch", "WINDOW", "GLOBAL_OBJ", "registerBackgroundTabDetection", "WINDOW", "activeTransaction", "getActiveTransaction", "statusType", "logger", "bindReporter", "callback", "metric", "reportAllChanges", "prevValue", "delta", "forceReport", "generateUniqueID", "getNavigationEntryFromPerformanceTiming", "timing", "WINDOW", "type", "navigationEntry", "key", "getNavigationEntry", "getActivationStart", "navEntry", "getNavigationEntry", "initMetric", "name", "value", "navEntry", "getNavigationEntry", "navigationType", "WINDOW", "getActivationStart", "generateUniqueID", "observe", "type", "callback", "opts", "po", "list", "onHidden", "cb", "once", "onHiddenOrPageHide", "event", "WINDOW", "onCLS", "onReport", "metric", "initMetric", "report", "sessionValue", "sessionEntries", "handleEntries", "entries", "entry", "firstSessionEntry", "lastSessionEntry", "po", "observe", "bindReporter", "stopListening", "onHidden", "firstHiddenTime", "initHiddenTime", "WINDOW", "trackChanges", "onHidden", "timeStamp", "getVisibilityWatcher", "onFID", "onReport", "visibilityWatcher", "getVisibilityWatcher", "metric", "initMetric", "report", "handleEntry", "entry", "handleEntries", "entries", "po", "observe", "bindReporter", "onHidden", "reportedMetricIDs", "onLCP", "onReport", "visibilityWatcher", "getVisibilityWatcher", "metric", "initMetric", "report", "handleEntries", "entries", "lastEntry", "value", "getActivationStart", "po", "observe", "bindReporter", "stopListening", "type", "onHidden", "handlers", "instrumented", "_previousCls", "_previousFid", "_previousLcp", "addClsInstrumentationHandler", "callback", "addMetricObserver", "instrumentCls", "addLcpInstrumentationHandler", "instrumentLcp", "addFidInstrumentationHandler", "instrumentFid", "addPerformanceInstrumentationHandler", "type", "addHandler", "instrumentPerformanceObserver", "getCleanupCallback", "triggerHandlers", "data", "typeHandlers", "handler", "e", "logger", "getFunctionName", "onCLS", "metric", "onFID", "onLCP", "instrumentFn", "previousValue", "options", "observe", "entries", "index", "isMeasurementValue", "value", "_startChild", "transaction", "startTimestamp", "ctx", "msToSec", "time", "getBrowserPerformanceAPI", "WINDOW", "_performanceCursor", "_measurements", "_lcpEntry", "_clsEntry", "startTrackingWebVitals", "performance", "browserPerformanceTimeOrigin", "fidCallback", "_trackFID", "clsCallback", "_trackCLS", "lcpCallback", "_trackLCP", "startTrackingLongTasks", "addPerformanceInstrumentationHandler", "entries", "entry", "transaction", "getActiveTransaction", "startTime", "duration", "startTrackingInteractions", "htmlTreeAsString", "addClsInstrumentationHandler", "metric", "logger", "addLcpInstrumentationHandler", "addFidInstrumentationHandler", "timeOrigin", "addPerformanceEntries", "performanceEntries", "responseStartTimestamp", "requestStartTimestamp", "_addNavigationSpans", "_addMeasureSpans", "firstHidden", "getVisibilityWatcher", "shouldRecord", "resourceName", "_addResourceSpans", "_trackNavigator", "name", "oldValue", "measurementTimestamp", "normalizedValue", "delta", "fidMark", "_startChild", "measurementName", "_tagMetricInfo", "measureStartTimestamp", "measureEndTimestamp", "event", "_addPerformanceNavigationTiming", "_addRequest", "description", "eventEnd", "end", "start", "data", "startTimestamp", "endTimestamp", "navigator", "connection", "isMeasurementValue", "source", "index", "DEFAULT_TRACE_PROPAGATION_TARGETS", "defaultRequestInstrumentationOptions", "instrumentOutgoingRequests", "_options", "traceFetch", "traceXHR", "tracePropagationTargets", "tracingOrigins", "shouldCreateSpanForRequest", "enableHTTPTimings", "shouldCreateSpan", "_", "shouldAttachHeadersWithTargets", "url", "shouldAttachHeaders", "spans", "addInstrumentationHandler", "handlerData", "createdSpan", "fetchCallback", "addHTTPTimings", "xhrCallback", "isPerformanceResourceTiming", "entry", "span", "cleanup", "addPerformanceInstrumentationHandler", "entries", "resourceTimingEntryToSpanData", "data", "extractNetworkProtocol", "nextHopProtocol", "name", "version", "_name", "char", "getAbsoluteTime", "time", "browserPerformanceTimeOrigin", "resourceTiming", "timingSpanData", "stringMatchesSomePattern", "hasTracingEnabled", "shouldCreateSpanResult", "spanId", "contentLength", "contentLengthNum", "hub", "getCurrentHub", "scope", "client", "parentSpan", "method", "request", "options", "addTracingHeadersToFetchRequest", "requestSpan", "transaction", "traceId", "sampled", "dsc", "sentryTraceHeader", "generateSentryTraceHeader", "dynamicSamplingContext", "getDynamicSamplingContextFromClient", "sentryBaggageHeader", "dynamicSamplingContextToSentryBaggageHeader", "headers", "isInstanceOf", "newHeaders", "BAGGAGE_HEADER_NAME", "existingBaggageHeader", "newBaggageHeaders", "xhr", "sentryXhrData", "SENTRY_XHR_DATA_KEY", "setHeaderOnXhr", "instrumentRoutingWithDefaults", "customStartTransaction", "startTransactionOnPageLoad", "startTransactionOnLocationChange", "WINDOW", "logger", "startingUrl", "activeTransaction", "browserPerformanceTimeOrigin", "addInstrumentationHandler", "to", "from", "BROWSER_TRACING_INTEGRATION_ID", "DEFAULT_BROWSER_TRACING_OPTIONS", "TRACING_DEFAULTS", "instrumentRoutingWithDefaults", "defaultRequestInstrumentationOptions", "BrowserTracing", "_options", "addTracingExtensions", "startTrackingWebVitals", "startTrackingLongTasks", "startTrackingInteractions", "_", "getCurrentHub", "client", "clientOptions", "instrumentRouting", "startTransactionOnLocationChange", "startTransactionOnPageLoad", "markBackgroundTransactions", "traceFetch", "traceXHR", "shouldCreateSpanForRequest", "enableHTTPTimings", "_experiments", "clientOptionsTracePropagationTargets", "tracePropagationTargets", "logger", "context", "transaction", "registerBackgroundTabDetection", "instrumentOutgoingRequests", "hub", "beforeNavigate", "idleTimeout", "finalTimeout", "heartbeatInterval", "isPageloadTransaction", "sentryTrace", "getMetaContent", "baggage", "traceparentData", "dynamicSamplingContext", "propagationContext", "tracingContextFromHeaders", "expandedContext", "modifiedContext", "finalContext", "location", "WINDOW", "idleTransaction", "startIdleTransaction", "scope", "addPerformanceEntries", "inflightInteractionTransaction", "registerInteractionTransaction", "op", "currentTransaction", "getActiveTransaction", "type", "metaName", "metaTag", "getDomElement", "windowIntegrations", "WINDOW", "INTEGRATIONS", "CoreIntegrations", "BrowserIntegrations", "_global", "hasSentryInitiated", "initiateSentry", "init", "BrowserTracing", "captureErrorInSentry", "error", "captureException", "import_react", "MESSAGE_PREFIX", "LOCAL_STORAGE_KEY", "LOG_INITIALISED", "storeLoggerState", "shouldLog", "initializeLogger", "debugMode", "log", "message", "addBreadcrumb", "logGroup", "groupName", "messagesOrObject", "transformedMessagesOrObject", "key", "value", "import_jsx_runtime", "ICON_MAP", "getIconPath", "name", "log", "Icon", "size", "className", "viewBox", "style", "import_classnames", "import_jsx_runtime", "BUTTON_VARIANTS", "BUTTON_SIZES", "Button", "iconBefore", "variant", "size", "children", "className", "type", "nativeButtonProps", "classNames", "Icon", "import_jsx_runtime", "NonIdealState", "style", "children", "import_jsx_runtime", "ErrorBoundary", "React", "error", "captureErrorInSentry", "NonIdealState", "Button", "import_jsx_runtime", "FetchOfferErrorState", "height", "message", "NonIdealState", "Button", "getServicePriceMapById", "availableServices", "all", "id", "total_amount", "total_currency", "getTotalAmountForServices", "offer", "selectedServices", "seatMaps", "servicePriceMap", "getServicePriceMapById", "getTotalAmountForServicesWithPriceMap", "total", "quantity", "id", "newTotal", "getTotalAmountFromSeatMaps", "captureErrorInSentry", "serviceId", "seatMap", "cabin", "row", "section", "element", "serviceMatch", "service", "compileCreateOrderPayload", "baggageSelectedServices", "seatSelectedServices", "cfarSelectedServices", "offer", "seatMaps", "passengers", "selectedServicesWithInformation", "totalAmountWithServices", "getTotalAmountForServices", "filterServicesForPayload", "selectedServices", "quantity", "id", "convertMarkupIntoPriceFormatter", "markup", "amount", "currency", "rate", "markupAmount", "errorMessage", "createPriceFormatters", "priceFormatters", "formatters", "isBaggageService", "service", "isCancelForAnyReasonService", "service", "multipleCurrenciesErrorMessage", "label", "currencies", "formatAvailableServices", "offer", "priceFormatters", "availableServices", "foundCurrencies", "formatters", "servicesWithFormattedPrices", "service", "serviceWithFormattedPrices", "total_amount", "total_currency", "isBaggageService", "amount", "currency", "isCancelForAnyReasonService", "isSeatElement", "element", "multipleCurrenciesErrorMessage", "currencies", "formatElement", "element", "priceFormatter", "foundCurrencies", "formattedElement", "isSeatElement", "formattedServices", "service", "formattedService", "amount", "currency", "formatSeatMaps", "seatMaps", "seatMap", "formattedCabins", "cabin", "formattedRows", "row", "formattedSections", "section", "formattedElements", "hasHighLuminance", "accentColor", "rgb", "x", "isPayloadComplete", "payload", "offerIsExpired", "offer", "isErrorResponse", "response", "DUFFEL_API_URL", "COMPONENT_VERSION", "fetchFromDuffelAPI", "withClientKey", "path", "method", "body", "logGroup", "fullUrl", "error", "data", "COMPONENT_CDN", "importFromOfferFixtures", "offerId", "importFromSeatMapsFixtures", "isFixtureOfferId", "offerId", "retrieveOfferFromDuffelAPI", "offer_id", "client_key", "fetchFromDuffelAPI", "retrieveOffer", "offer_id", "client_key", "onError", "setIsLoading", "onOfferReady", "useFixture", "isFixtureOfferId", "importFromOfferFixtures", "offer", "data", "retrieveOfferFromDuffelAPI", "error", "message", "isErrorResponse", "captureErrorInSentry", "retrieveSeatMapsFromDuffelAPI", "offer_id", "client_key", "fetchFromDuffelAPI", "retrieveSeatMaps", "offer_id", "client_key", "onError", "setIsLoading", "onSeatMapReady", "useFixture", "isFixtureOfferId", "importFromSeatMapsFixtures", "seatMaps", "data", "retrieveSeatMapsFromDuffelAPI", "error", "message", "isErrorResponse", "captureErrorInSentry", "areDuffelAncillariesPropsValid", "props", "hasCommonRequiredProps", "isDuffelAncillariesPropsWithOfferIdForFixture", "isDuffelAncillariesPropsWithClientKeyAndOfferId", "isDuffelAncillariesPropsWithOfferAndSeatMaps", "isDuffelAncillariesPropsWithOfferAndClientKey", "React", "import_jsx_runtime", "AnimatedLoaderEllipsis", "import_jsx_runtime", "Stamp", "backgroundColor", "color", "children", "getCurrencyForServices", "offer", "serviceType", "firstService", "service", "getTotalQuantity", "fromSelectedServices", "total", "quantity", "checkFunctionsMap", "isBaggageService", "isCancelForAnyReasonService", "hasService", "offer", "type", "checkFunction", "service", "moneyStringFormatter", "currency", "locale", "options", "value", "numberFormatted", "withPlural", "totalQuantity", "singular", "plural", "import_react", "import_classnames", "React", "import_jsx_runtime", "Card", "buttonTitle", "title", "icon", "copy", "onClick", "children", "isLoading", "disabled", "isSelected", "hasChildren", "classNames", "Icon", "setBodyScrollability", "shouldScroll", "import_classnames", "React", "import_classnames", "import_jsx_runtime", "ICON_BUTTON_VARIANTS", "IconButton", "icon", "variant", "className", "nativeButtonProps", "classNames", "Icon", "import_jsx_runtime", "Modal", "children", "onClose", "isOpen", "setBodyScrollability", "classNames", "IconButton", "ModalBody", "getPassengerMapById", "passengers", "all", "passenger", "getSegmentList", "offer", "accumulator", "slice", "import_react", "getPassengerName", "createOrderPayloadPassenger", "offerPassenger", "fallbackIndex", "getBaggageServiceDescription", "metadata", "captureErrorInSentry", "hasAllDimensions", "dimensionsLabel", "weightLabel", "hasServiceOfSameMetadataTypeAlreadyBeenSelected", "selectedServices", "segmentId", "passengerId", "availableService", "selectedService", "import_jsx_runtime", "Counter", "id", "min", "max", "value", "onChange", "IconButton", "import_jsx_runtime", "BaggageSelectionController", "segmentId", "passengerId", "availableService", "quantity", "onQuantityChanged", "selectedServices", "serviceName", "servicePrice", "moneyStringFormatter", "serviceDescription", "getBaggageServiceDescription", "shouldDisableController", "hasServiceOfSameMetadataTypeAlreadyBeenSelected", "Counter", "import_jsx_runtime", "IncludedBaggageBanner", "includedBaggage", "carryOnBagsQuantity", "checkedBagsQuantity", "sum", "type", "quantity", "baggageLabelStringArray", "withPlural", "import_jsx_runtime", "BaggageSelectionModalBodyPassenger", "segmentId", "passengerId", "passengerName", "includedBaggage", "passengerServicesForSegment", "selectedServices", "setSelectedServices", "hasIncludedBaggage", "sum", "bag", "IncludedBaggageBanner", "availableService", "BaggageSelectionController", "id", "newQuantity", "onBaggageQuantityChanged", "changedServiceIndex", "newSelectedServices", "quantity", "import_jsx_runtime", "BaggageSelectionModalBody", "offer", "segment", "passengersById", "selectedServices", "setSelectedServices", "ModalBody", "passenger_id", "baggages", "index", "BaggageSelectionModalBodyPassenger", "getPassengerName", "id", "type", "passenger_ids", "segment_ids", "import_jsx_runtime", "BaggageSelectionModalFooter", "selectedServices", "servicePrices", "currency", "isFirstSegment", "isLastSegment", "onNextSegmentButtonClicked", "onPreviousSegmentButtonClicked", "onClose", "totalQuantity", "getTotalQuantity", "totalAmount", "getTotalAmountForServicesWithPriceMap", "totalAmountLabel", "moneyStringFormatter", "isOneWay", "withPlural", "Button", "formatDateString", "dateString", "date", "captureErrorInSentry", "formatDate", "format", "import_jsx_runtime", "BaggageSelectionModalHeader", "segmentCount", "currentSegmentIndex", "currentSegment", "setCurrentSegmentIndex", "_", "index", "ActiveSegment", "InactiveSegment", "formatDateString", "onClick", "style", "import_jsx_runtime", "BaggageSelectionModal", "isOpen", "offer", "passengers", "onClose", "selectedServices", "currentSegmentIndex", "setCurrentSegmentIndex", "selectedServicesState", "setSelectedServicesState", "React", "segments", "getSegmentList", "currentSegment", "passengerMapById", "getPassengerMapById", "servicePricesMap", "getServicePriceMapById", "currencyToUse", "hasService", "getCurrencyForServices", "Modal", "BaggageSelectionModalHeader", "index", "BaggageSelectionModalBody", "BaggageSelectionModalFooter", "import_jsx_runtime", "BaggageSelectionCard", "isLoading", "offer", "passengers", "selectedServices", "setSelectedServices", "isOpen", "setIsOpen", "React", "containsBaggageService", "hasService", "totalQuantity", "getTotalQuantity", "isBaggageAdded", "totalAmount", "getTotalAmountForServices", "currencyToUse", "getCurrencyForServices", "totalAmountFormatted", "moneyStringFormatter", "copy", "withPlural", "Card", "Stamp", "AnimatedLoaderEllipsis", "BaggageSelectionModal", "newSelectedServices", "newSelectedServicesDeepCopy", "import_react", "import_jsx_runtime", "CfarSelectionModalBodyListItem", "children", "Icon", "import_jsx_runtime", "CfarSelectionModalBody", "offerCurrency", "service", "ModalBody", "CfarSelectionModalBodyListItem", "moneyStringFormatter", "Icon", "import_jsx_runtime", "CfarSelectionModalFooter", "service", "selectedServices", "onAddCfarService", "onRemoveCfarService", "onClose", "serviceIncluded", "id", "formattedPrice", "moneyStringFormatter", "Button", "ProtectedTripBanner", "Icon", "import_jsx_runtime", "CfarSelectionModalHeader", "import_jsx_runtime", "CfarSelectionModal", "isOpen", "offerCurrency", "service", "onClose", "selectedServices", "Modal", "CfarSelectionModalHeader", "CfarSelectionModalBody", "CfarSelectionModalFooter", "import_jsx_runtime", "CfarSelectionCard", "isLoading", "offer", "selectedServices", "setSelectedServices", "isOpen", "setIsOpen", "React", "containsCfarService", "hasService", "isCfarAdded", "getTotalQuantity", "currencyToUse", "getCurrencyForServices", "totalAmount", "getTotalAmountForServices", "totalAmountFormatted", "moneyStringFormatter", "cfarService", "isCancelForAnyReasonService", "copy", "Card", "Stamp", "AnimatedLoaderEllipsis", "CfarSelectionModal", "newSelectedServices", "getFirstSeatElementMatchingCriteria", "seatMaps", "matcher", "seatMap", "cabin", "row", "section", "element", "getCurrencyForSeatMaps", "seatMaps", "getFirstSeatElementMatchingCriteria", "element", "import_react", "getPassengerBySegmentList", "segments", "segment", "passenger", "passengerIndex", "import_react", "getCabinsForSegmentAndDeck", "forDeck", "seatMap", "cabin", "getSymbols", "cabins", "results", "cabin", "row", "section", "element", "hasWings", "cabin", "rowIndex", "import_classnames", "React", "import_classnames", "import_jsx_runtime", "Tabs", "value", "onChange", "options", "option", "classNames", "import_jsx_runtime", "DeckSelect", "value", "setValue", "options", "Tabs", "item", "import_jsx_runtime", "Legend", "symbols", "Icon", "symbol", "getRowNumber", "row", "seats", "section", "acc", "val", "element", "import_classnames", "React", "import_classnames", "import_jsx_runtime", "amenitiesWithoutWrapper", "Amenity", "type", "classNames", "Icon", "import_jsx_runtime", "EmptyElement", "import_classnames", "import_jsx_runtime", "ExitElement", "isRight", "classNames", "Icon", "getPassengerInitials", "passengerName", "partOfTheName", "import_classnames", "import_jsx_runtime", "SeatInfo", "seat", "service", "price", "moneyStringFormatter", "disclosure", "index", "import_jsx_runtime", "SeatUnavailable", "seat", "Icon", "import_jsx_runtime", "SeatElement", "element", "currentPassengerId", "currentSegmentId", "currentPassengerName", "onSeatToggled", "selectedServicesMap", "seatServiceFromElement", "service", "SeatUnavailable", "selectedServiceFromMap", "isSeatSelected", "seatLabel", "getPassengerInitials", "isFeePayable", "isSeatSelectionAvaiable", "isActionable", "seatClassName", "classNames", "priceLabel", "moneyStringFormatter", "isSeatInfoDisplayed", "Icon", "SeatInfo", "import_jsx_runtime", "Element", "element", "elementIndex", "sectionIndex", "onSeatToggled", "selectedServicesMap", "currentPassengerId", "currentSegmentId", "currentPassengerName", "isSeatElement", "SeatElement", "EmptyElement", "ExitElement", "Amenity", "import_jsx_runtime", "RowSection", "row", "rowNumber", "hasWings", "section", "sectionIndex", "onSeatToggled", "selectedServicesMap", "currentPassengerId", "currentPassengerName", "currentSegmentId", "rowLength", "isOneSectionRow", "classNames", "element", "elementIndex", "Element", "EmptyElement", "import_jsx_runtime", "Row", "row", "hasWings", "onSeatToggled", "selectedServicesMap", "currentPassengerId", "currentPassengerName", "currentSegmentId", "rowNumber", "getRowNumber", "section", "sectionIndex", "RowSection", "import_jsx_runtime", "SeatMapUnavailable", "NonIdealState", "import_jsx_runtime", "SeatMap", "seatMap", "onSeatToggled", "selectedServicesMap", "currentPassengerId", "currentPassengerName", "currentSegmentId", "selectedDeck", "setSelectedDeck", "SeatMapUnavailable", "cabins", "getCabinsForSegmentAndDeck", "hasMultipleDecks", "anyHasWings", "cabin", "symbols", "getSymbols", "classNames", "DeckSelect", "value", "Legend", "cabinIndex", "row", "rowIndex", "Row", "hasWings", "import_jsx_runtime", "SeatSelectionModalBody", "props", "ModalBody", "SeatMap", "import_jsx_runtime", "SeatSelectionModalFooter", "selectedServices", "servicePrices", "currency", "isFirstSegment", "isLastSegment", "onNextSegmentButtonClicked", "onPreviousSegmentButtonClicked", "onClose", "seatMaps", "totalQuantity", "getTotalQuantity", "totalAmount", "getTotalAmountForServicesWithPriceMap", "totalAmountLabel", "moneyStringFormatter", "isOneWay", "withPlural", "Button", "import_jsx_runtime", "SeatSelectionModalHeader", "segmentAndPassengerPermutationsCount", "currentSegmentAndPassengerPermutationsIndex", "currentSegment", "currentPassengerName", "setCurrentSegmentAndPassengerPermutationsIndex", "_", "index", "ActiveSegment", "InactiveSegment", "formatDateString", "onClick", "style", "import_jsx_runtime", "SeatSelectionModal", "isOpen", "offer", "passengers", "seatMaps", "selectedServices", "onClose", "currentPermutationIndex", "setCurrentPermutationIndex", "React", "selectedServicesState", "setSelectedServicesState", "selectedServicesStateMap", "all", "service", "segments", "getSegmentList", "passengerMapById", "getPassengerMapById", "servicePricesMap", "getServicePriceMapById", "segmentAndPassengerPermutations", "getPassengerBySegmentList", "currentPassengerId", "currentPassengerIndex", "currentSegmentId", "currentSegment", "id", "currentPassenger", "currentSeatMap", "seatMap", "currentPassengerName", "getPassengerName", "onSeatToggle", "seatServiceToToggle", "newSeatServices", "selectedServiceFromState", "hasClickedSeatToToggleOff", "isSelectedServiceFromStateForTheSameSegmentAndPassengerPermutation", "currencyToUse", "getCurrencyForSeatMaps", "Modal", "SeatSelectionModalHeader", "SeatSelectionModalBody", "SeatSelectionModalFooter", "import_jsx_runtime", "SeatSelectionCard", "isLoading", "offer", "seatMaps", "passengers", "selectedServices", "setSelectedServices", "isOpen", "setIsOpen", "React", "containsSeatService", "totalQuantity", "getTotalQuantity", "areSeatsAdded", "totalAmount", "getTotalAmountForServices", "currencyToUse", "getCurrencyForSeatMaps", "totalAmountFormatted", "moneyStringFormatter", "copy", "withPlural", "Card", "Stamp", "AnimatedLoaderEllipsis", "SeatSelectionModal", "services", "import_jsx_runtime", "COMPONENT_CDN", "hrefToComponentStyles", "DuffelAncillaries", "props", "initializeLogger", "logGroup", "areDuffelAncillariesPropsValid", "isPropsWithOfferIdForFixture", "isDuffelAncillariesPropsWithOfferIdForFixture", "isPropsWithClientKeyAndOfferId", "isDuffelAncillariesPropsWithClientKeyAndOfferId", "isPropsWithOfferAndSeatMaps", "isDuffelAncillariesPropsWithOfferAndSeatMaps", "isPropsWithOfferAndClientKey", "isDuffelAncillariesPropsWithOfferAndClientKey", "shouldRetrieveSeatMaps", "passengers", "setPassengers", "offer", "setOffer", "isOfferLoading", "setIsOfferLoading", "seatMaps", "setSeatMaps", "isSeatMapLoading", "setIsSeatMapLoading", "error", "setError", "baggageSelectedServices", "setBaggageSelectedServices", "seatSelectedServices", "setSeatSelectedServices", "cfarSelectedServices", "setCfarSelectedServices", "priceFormatters", "createPriceFormatters", "updateOffer", "expiryErrorMessage", "offerIsExpired", "msUntilExpiry", "milisecondsInOneDay", "offerWithFormattedServices", "formatAvailableServices", "updateSeatMaps", "formattedSeatMaps", "formatSeatMaps", "setContext", "retrieveOffer", "passenger", "index", "retrieveSeatMaps", "createOrderPayload", "compileCreateOrderPayload", "isPayloadComplete", "metadata", "nonIdealStateHeight", "duffelComponentsStyle", "hasHighLuminance", "ErrorBoundary", "FetchOfferErrorState", "ancillaryName", "BaggageSelectionCard", "SeatSelectionCard", "CfarSelectionCard", "import_jsx_runtime", "CUSTOM_ELEMENT_TAG", "DuffelAncillariesCustomElement", "container", "withProps", "DuffelAncillaries", "data", "metadata", "tryToGetDuffelAncillariesCustomElement", "caller", "element", "renderDuffelAncillariesCustomElement", "props", "onDuffelAncillariesPayloadReady", "onPayloadReady", "eventListener", "event", "import_client", "import_react_stripe_js", "V3_URL", "V3_URL_REGEX", "EXISTING_SCRIPT_MESSAGE", "findScript", "scripts", "i", "script", "injectScript", "params", "queryString", "headOrBody", "registerWrapper", "stripe", "startTime", "stripePromise", "loadScript", "resolve", "reject", "error", "initStripe", "maybeStripe", "args", "stripePromise$1", "loadCalled", "err", "loadStripe", "_len", "_key", "React", "import_jsx_runtime", "COMPONENT_CDN", "hrefToComponentStyles", "STRIPE_CARD_ELEMENT", "COMPONENT_VERSION", "CARD_ELEMENT_STYLE_BASE", "CARD_ELEMENT_STYLE_INVALID", "CardPaymentComponent", "styles", "paymentIntentClientToken", "onSuccessfulPayment", "onFailedPayment", "cardElement", "setCardElement", "isComplete", "setIsComplete", "isInvalid", "setIsInvalid", "isProcessing", "setIsProcessing", "errorMessage", "setErrorMessage", "stripe", "elements", "maybeCard", "event", "error", "complete", "e", "decodedDuffelPaymentIntentClientToken", "parsedDuffelPaymentIntentClientToken", "clientSecret", "result", "Button", "DuffelPayments", "props", "setStripe", "initializeLogger", "duffelPublishableKey", "loadStripe", "duffelComponentsStyle", "hasHighLuminance", "ErrorBoundary", "import_jsx_runtime", "CUSTOM_ELEMENT_TAG", "DuffelPaymentsCustomElement", "container", "withProps", "DuffelPayments", "error", "tryToGetDuffelPaymentsCustomElement", "caller", "element", "renderDuffelPaymentsCustomElement", "props", "onDuffelPaymentsSuccessfulPayment", "onSuccessfulPayment", "onDuffelPaymentsFailedPayment", "onFailedPayment", "eventListener", "event"]
7
7
  }