@depup/sentry__react 10.44.0-depup.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.
Files changed (140) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +25 -0
  3. package/build/cjs/constants.js +12 -0
  4. package/build/cjs/constants.js.map +1 -0
  5. package/build/cjs/debug-build.js +11 -0
  6. package/build/cjs/debug-build.js.map +1 -0
  7. package/build/cjs/error.js +113 -0
  8. package/build/cjs/error.js.map +1 -0
  9. package/build/cjs/errorboundary.js +170 -0
  10. package/build/cjs/errorboundary.js.map +1 -0
  11. package/build/cjs/hoist-non-react-statics.js +159 -0
  12. package/build/cjs/hoist-non-react-statics.js.map +1 -0
  13. package/build/cjs/index.js +51 -0
  14. package/build/cjs/index.js.map +1 -0
  15. package/build/cjs/profiler.js +226 -0
  16. package/build/cjs/profiler.js.map +1 -0
  17. package/build/cjs/reactrouter-compat-utils/instrumentation.js +1295 -0
  18. package/build/cjs/reactrouter-compat-utils/instrumentation.js.map +1 -0
  19. package/build/cjs/reactrouter-compat-utils/lazy-routes.js +160 -0
  20. package/build/cjs/reactrouter-compat-utils/lazy-routes.js.map +1 -0
  21. package/build/cjs/reactrouter-compat-utils/route-manifest.js +194 -0
  22. package/build/cjs/reactrouter-compat-utils/route-manifest.js.map +1 -0
  23. package/build/cjs/reactrouter-compat-utils/utils.js +336 -0
  24. package/build/cjs/reactrouter-compat-utils/utils.js.map +1 -0
  25. package/build/cjs/reactrouter.js +236 -0
  26. package/build/cjs/reactrouter.js.map +1 -0
  27. package/build/cjs/reactrouterv3.js +130 -0
  28. package/build/cjs/reactrouterv3.js.map +1 -0
  29. package/build/cjs/reactrouterv6.js +61 -0
  30. package/build/cjs/reactrouterv6.js.map +1 -0
  31. package/build/cjs/reactrouterv7.js +61 -0
  32. package/build/cjs/reactrouterv7.js.map +1 -0
  33. package/build/cjs/redux.js +106 -0
  34. package/build/cjs/redux.js.map +1 -0
  35. package/build/cjs/sdk.js +21 -0
  36. package/build/cjs/sdk.js.map +1 -0
  37. package/build/cjs/tanstackrouter.js +134 -0
  38. package/build/cjs/tanstackrouter.js.map +1 -0
  39. package/build/esm/constants.js +8 -0
  40. package/build/esm/constants.js.map +1 -0
  41. package/build/esm/debug-build.js +9 -0
  42. package/build/esm/debug-build.js.map +1 -0
  43. package/build/esm/error.js +108 -0
  44. package/build/esm/error.js.map +1 -0
  45. package/build/esm/errorboundary.js +166 -0
  46. package/build/esm/errorboundary.js.map +1 -0
  47. package/build/esm/hoist-non-react-statics.js +157 -0
  48. package/build/esm/hoist-non-react-statics.js.map +1 -0
  49. package/build/esm/index.js +12 -0
  50. package/build/esm/index.js.map +1 -0
  51. package/build/esm/package.json +1 -0
  52. package/build/esm/profiler.js +221 -0
  53. package/build/esm/profiler.js.map +1 -0
  54. package/build/esm/reactrouter-compat-utils/instrumentation.js +1281 -0
  55. package/build/esm/reactrouter-compat-utils/instrumentation.js.map +1 -0
  56. package/build/esm/reactrouter-compat-utils/lazy-routes.js +156 -0
  57. package/build/esm/reactrouter-compat-utils/lazy-routes.js.map +1 -0
  58. package/build/esm/reactrouter-compat-utils/route-manifest.js +191 -0
  59. package/build/esm/reactrouter-compat-utils/route-manifest.js.map +1 -0
  60. package/build/esm/reactrouter-compat-utils/utils.js +320 -0
  61. package/build/esm/reactrouter-compat-utils/utils.js.map +1 -0
  62. package/build/esm/reactrouter.js +232 -0
  63. package/build/esm/reactrouter.js.map +1 -0
  64. package/build/esm/reactrouterv3.js +128 -0
  65. package/build/esm/reactrouterv3.js.map +1 -0
  66. package/build/esm/reactrouterv6.js +55 -0
  67. package/build/esm/reactrouterv6.js.map +1 -0
  68. package/build/esm/reactrouterv7.js +55 -0
  69. package/build/esm/reactrouterv7.js.map +1 -0
  70. package/build/esm/redux.js +104 -0
  71. package/build/esm/redux.js.map +1 -0
  72. package/build/esm/sdk.js +19 -0
  73. package/build/esm/sdk.js.map +1 -0
  74. package/build/esm/tanstackrouter.js +132 -0
  75. package/build/esm/tanstackrouter.js.map +1 -0
  76. package/build/types/constants.d.ts +4 -0
  77. package/build/types/constants.d.ts.map +1 -0
  78. package/build/types/debug-build.d.ts +7 -0
  79. package/build/types/debug-build.d.ts.map +1 -0
  80. package/build/types/error.d.ts +41 -0
  81. package/build/types/error.d.ts.map +1 -0
  82. package/build/types/errorboundary.d.ts +87 -0
  83. package/build/types/errorboundary.d.ts.map +1 -0
  84. package/build/types/hoist-non-react-statics.d.ts +21 -0
  85. package/build/types/hoist-non-react-statics.d.ts.map +1 -0
  86. package/build/types/index.d.ts +13 -0
  87. package/build/types/index.d.ts.map +1 -0
  88. package/build/types/profiler.d.ts +56 -0
  89. package/build/types/profiler.d.ts.map +1 -0
  90. package/build/types/reactrouter-compat-utils/index.d.ts +5 -0
  91. package/build/types/reactrouter-compat-utils/index.d.ts.map +1 -0
  92. package/build/types/reactrouter-compat-utils/instrumentation.d.ts +117 -0
  93. package/build/types/reactrouter-compat-utils/instrumentation.d.ts.map +1 -0
  94. package/build/types/reactrouter-compat-utils/lazy-routes.d.ts +18 -0
  95. package/build/types/reactrouter-compat-utils/lazy-routes.d.ts.map +1 -0
  96. package/build/types/reactrouter-compat-utils/route-manifest.d.ts +13 -0
  97. package/build/types/reactrouter-compat-utils/route-manifest.d.ts.map +1 -0
  98. package/build/types/reactrouter-compat-utils/utils.d.ts +71 -0
  99. package/build/types/reactrouter-compat-utils/utils.d.ts.map +1 -0
  100. package/build/types/reactrouter.d.ts +41 -0
  101. package/build/types/reactrouter.d.ts.map +1 -0
  102. package/build/types/reactrouterv3.d.ts +29 -0
  103. package/build/types/reactrouterv3.d.ts.map +1 -0
  104. package/build/types/reactrouterv6.d.ts +32 -0
  105. package/build/types/reactrouterv6.d.ts.map +1 -0
  106. package/build/types/reactrouterv7.d.ts +32 -0
  107. package/build/types/reactrouterv7.d.ts.map +1 -0
  108. package/build/types/redux.d.ts +38 -0
  109. package/build/types/redux.d.ts.map +1 -0
  110. package/build/types/sdk.d.ts +7 -0
  111. package/build/types/sdk.d.ts.map +1 -0
  112. package/build/types/tanstackrouter.d.ts +13 -0
  113. package/build/types/tanstackrouter.d.ts.map +1 -0
  114. package/build/types/types.d.ts +163 -0
  115. package/build/types/types.d.ts.map +1 -0
  116. package/build/types/vendor/tanstackrouter-types.d.ts +36 -0
  117. package/build/types/vendor/tanstackrouter-types.d.ts.map +1 -0
  118. package/build/types-ts3.8/constants.d.ts +4 -0
  119. package/build/types-ts3.8/debug-build.d.ts +7 -0
  120. package/build/types-ts3.8/error.d.ts +41 -0
  121. package/build/types-ts3.8/errorboundary.d.ts +87 -0
  122. package/build/types-ts3.8/hoist-non-react-statics.d.ts +21 -0
  123. package/build/types-ts3.8/index.d.ts +13 -0
  124. package/build/types-ts3.8/profiler.d.ts +56 -0
  125. package/build/types-ts3.8/reactrouter-compat-utils/index.d.ts +5 -0
  126. package/build/types-ts3.8/reactrouter-compat-utils/instrumentation.d.ts +117 -0
  127. package/build/types-ts3.8/reactrouter-compat-utils/lazy-routes.d.ts +18 -0
  128. package/build/types-ts3.8/reactrouter-compat-utils/route-manifest.d.ts +13 -0
  129. package/build/types-ts3.8/reactrouter-compat-utils/utils.d.ts +77 -0
  130. package/build/types-ts3.8/reactrouter.d.ts +41 -0
  131. package/build/types-ts3.8/reactrouterv3.d.ts +29 -0
  132. package/build/types-ts3.8/reactrouterv6.d.ts +32 -0
  133. package/build/types-ts3.8/reactrouterv7.d.ts +32 -0
  134. package/build/types-ts3.8/redux.d.ts +38 -0
  135. package/build/types-ts3.8/sdk.d.ts +7 -0
  136. package/build/types-ts3.8/tanstackrouter.d.ts +13 -0
  137. package/build/types-ts3.8/types.d.ts +163 -0
  138. package/build/types-ts3.8/vendor/tanstackrouter-types.d.ts +36 -0
  139. package/changes.json +5 -0
  140. package/package.json +108 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instrumentation.js","sources":["../../../src/reactrouter-compat-utils/instrumentation.tsx"],"sourcesContent":["/* eslint-disable max-lines */\n// Inspired from Donnie McNeal's solution:\n// https://gist.github.com/wontondon/e8c4bdf2888875e4c755712e99279536\n\nimport {\n browserTracingIntegration,\n startBrowserTracingNavigationSpan,\n startBrowserTracingPageLoadSpan,\n WINDOW,\n} from '@sentry/browser';\nimport type { Client, Integration, Span } from '@sentry/core';\nimport {\n addNonEnumerableProperty,\n debug,\n getClient,\n getCurrentScope,\n SEMANTIC_ATTRIBUTE_SENTRY_OP,\n SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN,\n SEMANTIC_ATTRIBUTE_SENTRY_SOURCE,\n spanToJSON,\n} from '@sentry/core';\nimport * as React from 'react';\nimport { DEBUG_BUILD } from '../debug-build';\nimport { hoistNonReactStatics } from '../hoist-non-react-statics';\nimport type {\n Action,\n AgnosticDataRouteMatch,\n CreateRouterFunction,\n CreateRoutesFromChildren,\n Location,\n MatchRoutes,\n RouteMatch,\n RouteObject,\n Router,\n RouterState,\n UseEffect,\n UseLocation,\n UseNavigationType,\n UseRoutes,\n} from '../types';\nimport { checkRouteForAsyncHandler } from './lazy-routes';\nimport {\n clearNavigationContext,\n getActiveRootSpan,\n initializeRouterUtils,\n resolveRouteNameAndSource,\n setNavigationContext,\n transactionNameHasWildcard,\n} from './utils';\n\nlet _useEffect: UseEffect;\nlet _useLocation: UseLocation;\nlet _useNavigationType: UseNavigationType;\nlet _createRoutesFromChildren: CreateRoutesFromChildren;\nlet _matchRoutes: MatchRoutes;\n\nlet _enableAsyncRouteHandlers: boolean = false;\nlet _lazyRouteTimeout = 3000;\nlet _lazyRouteManifest: string[] | undefined;\nlet _basename: string = '';\n\nconst CLIENTS_WITH_INSTRUMENT_NAVIGATION = new WeakSet<Client>();\n\n// Prevents duplicate spans when router.subscribe fires multiple times\nconst activeNavigationSpans = new WeakMap<\n Client,\n { span: Span; routeName: string; pathname: string; locationKey: string; isPlaceholder?: boolean }\n>();\n\n// Exported for testing only\nexport const allRoutes = new Set<RouteObject>();\n\n// Tracks lazy route loads to wait before finalizing span names\nconst pendingLazyRouteLoads = new WeakMap<Span, Set<Promise<unknown>>>();\n\n// Tracks deferred lazy route promises that can be resolved when patchRoutesOnNavigation is called\nconst deferredLazyRouteResolvers = new WeakMap<Span, () => void>();\n\n/**\n * Schedules a callback using requestAnimationFrame when available (browser),\n * or falls back to setTimeout for SSR environments (Node.js, createMemoryRouter tests).\n */\nfunction scheduleCallback(callback: () => void): number {\n if (WINDOW?.requestAnimationFrame) {\n return WINDOW.requestAnimationFrame(callback);\n }\n return setTimeout(callback, 0) as unknown as number;\n}\n\n/**\n * Cancels a scheduled callback, handling both RAF (browser) and timeout (SSR) IDs.\n */\nfunction cancelScheduledCallback(id: number): void {\n if (WINDOW?.cancelAnimationFrame) {\n WINDOW.cancelAnimationFrame(id);\n } else {\n clearTimeout(id);\n }\n}\n\n/**\n * Computes location key for duplicate detection. Normalizes undefined/null to empty strings.\n * Exported for testing.\n */\nexport function computeLocationKey(location: Location): string {\n return `${location.pathname}${location.search || ''}${location.hash || ''}`;\n}\n\n/**\n * Checks if a route name is parameterized (contains route parameters like :id or wildcards like *)\n * vs a raw URL path.\n */\nfunction isParameterizedRoute(routeName: string): boolean {\n return routeName.includes(':') || routeName.includes('*');\n}\n\n/**\n * Determines if a navigation should be skipped as a duplicate, and if an existing span should be updated.\n * Exported for testing.\n *\n * @returns An object with:\n * - skip: boolean - Whether to skip creating a new span\n * - shouldUpdate: boolean - Whether to update the existing span name (wildcard upgrade)\n */\nexport function shouldSkipNavigation(\n trackedNav:\n | { span: Span; routeName: string; pathname: string; locationKey: string; isPlaceholder?: boolean }\n | undefined,\n locationKey: string,\n proposedName: string,\n spanHasEnded: boolean,\n): { skip: boolean; shouldUpdate: boolean } {\n if (!trackedNav) {\n return { skip: false, shouldUpdate: false };\n }\n\n // Check if this is a duplicate navigation (same location)\n // 1. If it's a placeholder, it's always a duplicate (we're waiting for the real one)\n // 2. If it's a real span, it's a duplicate only if it hasn't ended yet\n const isDuplicate = trackedNav.locationKey === locationKey && (trackedNav.isPlaceholder || !spanHasEnded);\n\n if (isDuplicate) {\n // Check if we should update the span name with a better route\n // Allow updates if:\n // 1. Current has wildcard and new doesn't (wildcard → parameterized upgrade)\n // 2. Current is raw path and new is parameterized (raw → parameterized upgrade)\n // 3. New name is different and more specific (longer, indicating nested routes resolved)\n const currentHasWildcard = !!trackedNav.routeName && transactionNameHasWildcard(trackedNav.routeName);\n const proposedHasWildcard = transactionNameHasWildcard(proposedName);\n const currentIsParameterized = !!trackedNav.routeName && isParameterizedRoute(trackedNav.routeName);\n const proposedIsParameterized = isParameterizedRoute(proposedName);\n\n const isWildcardUpgrade = currentHasWildcard && !proposedHasWildcard;\n const isRawToParameterized = !currentIsParameterized && proposedIsParameterized;\n const isMoreSpecific =\n proposedName !== trackedNav.routeName &&\n proposedName.length > (trackedNav.routeName?.length || 0) &&\n !proposedHasWildcard;\n\n const shouldUpdate = !!(trackedNav.routeName && (isWildcardUpgrade || isRawToParameterized || isMoreSpecific));\n\n return { skip: true, shouldUpdate };\n }\n\n return { skip: false, shouldUpdate: false };\n}\n\nexport interface ReactRouterOptions {\n useEffect: UseEffect;\n useLocation: UseLocation;\n useNavigationType: UseNavigationType;\n createRoutesFromChildren: CreateRoutesFromChildren;\n matchRoutes: MatchRoutes;\n /**\n * Whether to strip the basename from the pathname when creating transactions.\n *\n * This is useful for applications that use a basename in their routing setup.\n * @default false\n */\n stripBasename?: boolean;\n /**\n * Enables support for async route handlers.\n *\n * This allows Sentry to track and instrument routes dynamically resolved from async handlers.\n * @default false\n */\n enableAsyncRouteHandlers?: boolean;\n\n /**\n * Maximum time (in milliseconds) to wait for lazy routes to load before finalizing span names.\n *\n * - Set to `0` to not wait at all (immediate finalization)\n * - Set to `Infinity` to wait as long as possible (capped at `finalTimeout` to prevent indefinite hangs)\n * - Negative values will fall back to the default\n *\n * Defaults to 3× the configured `idleTimeout` (default: 3000ms).\n *\n * @default idleTimeout * 3\n */\n lazyRouteTimeout?: number;\n\n /**\n * Static route manifest for resolving parameterized route names with lazy routes.\n *\n * Requires `enableAsyncRouteHandlers: true`. When provided, the manifest is used\n * as the primary source for determining transaction names. This is more reliable\n * than depending on React Router's lazy route resolution timing.\n *\n * @example\n * ```ts\n * lazyRouteManifest: [\n * '/',\n * '/users',\n * '/users/:userId',\n * '/org/:orgSlug/projects/:projectId',\n * ]\n * ```\n */\n lazyRouteManifest?: string[];\n}\n\ntype V6CompatibleVersion = '6' | '7';\n\nexport function addResolvedRoutesToParent(resolvedRoutes: RouteObject[], parentRoute: RouteObject): void {\n const existingChildren = parentRoute.children || [];\n\n const newRoutes = resolvedRoutes.filter(\n newRoute =>\n !existingChildren.some(\n existing =>\n existing === newRoute ||\n (newRoute.path && existing.path === newRoute.path) ||\n (newRoute.id && existing.id === newRoute.id),\n ),\n );\n\n if (newRoutes.length > 0) {\n parentRoute.children = [...existingChildren, ...newRoutes];\n }\n}\n\n/** Registers a pending lazy route load promise for a span. */\nfunction trackLazyRouteLoad(span: Span, promise: Promise<unknown>): void {\n let promises = pendingLazyRouteLoads.get(span);\n if (!promises) {\n promises = new Set();\n pendingLazyRouteLoads.set(span, promises);\n }\n promises.add(promise);\n\n // Clean up when promise resolves/rejects\n // oxlint-disable-next-line typescript/no-floating-promises\n promise.finally(() => {\n const currentPromises = pendingLazyRouteLoads.get(span);\n if (currentPromises) {\n currentPromises.delete(promise);\n }\n });\n}\n\n/**\n * Creates a deferred promise for a span that will be resolved when patchRoutesOnNavigation is called.\n * This ensures that patchedEnd waits for patchRoutesOnNavigation to be called before ending the span.\n */\nfunction createDeferredLazyRoutePromise(span: Span): void {\n const deferredPromise = new Promise<void>(resolve => {\n deferredLazyRouteResolvers.set(span, resolve);\n });\n\n trackLazyRouteLoad(span, deferredPromise);\n}\n\n/**\n * Resolves the deferred lazy route promise for a span.\n * Called when patchRoutesOnNavigation is invoked.\n */\nfunction resolveDeferredLazyRoutePromise(span: Span): void {\n const resolver = deferredLazyRouteResolvers.get(span);\n if (resolver) {\n resolver();\n deferredLazyRouteResolvers.delete(span);\n // Clear the flag so patchSpanEnd doesn't wait unnecessarily for routes that have already loaded\n if ((span as unknown as Record<string, boolean>).__sentry_may_have_lazy_routes__) {\n (span as unknown as Record<string, boolean>).__sentry_may_have_lazy_routes__ = false;\n }\n }\n}\n\n/**\n * Processes resolved routes by adding them to allRoutes and checking for nested async handlers.\n * When capturedSpan is provided, updates that specific span instead of the current active span.\n * This prevents race conditions where a lazy handler resolves after the user has navigated away.\n */\nexport function processResolvedRoutes(\n resolvedRoutes: RouteObject[],\n parentRoute?: RouteObject,\n currentLocation: Location | null = null,\n capturedSpan?: Span,\n): void {\n resolvedRoutes.forEach(child => {\n allRoutes.add(child);\n // Only check for async handlers if the feature is enabled\n if (_enableAsyncRouteHandlers) {\n checkRouteForAsyncHandler(child, processResolvedRoutes);\n }\n });\n\n if (parentRoute) {\n // If a parent route is provided, add the resolved routes as children to the parent route\n addResolvedRoutesToParent(resolvedRoutes, parentRoute);\n }\n\n // Use captured span if provided, otherwise fall back to current active span\n const targetSpan = capturedSpan ?? getActiveRootSpan();\n if (targetSpan) {\n const spanJson = spanToJSON(targetSpan);\n\n // Skip update if span has already ended (timestamp is set when span.end() is called)\n if (spanJson.timestamp) {\n DEBUG_BUILD && debug.warn('[React Router] Lazy handler resolved after span ended - skipping update');\n return;\n }\n\n const spanOp = spanJson.op;\n\n // Use captured location for route matching (ensures we match against the correct route)\n // Fall back to window.location only if no captured location and no captured span\n // (i.e., this is not from an async handler)\n let location = currentLocation;\n if (!location && !capturedSpan) {\n if (typeof WINDOW !== 'undefined') {\n const globalLocation = WINDOW.location;\n if (globalLocation?.pathname) {\n location = { pathname: globalLocation.pathname };\n }\n }\n }\n\n if (location) {\n if (spanOp === 'pageload') {\n // Re-run the pageload transaction update with the newly loaded routes\n updatePageloadTransaction({\n activeRootSpan: targetSpan,\n location: { pathname: location.pathname },\n routes: Array.from(allRoutes),\n allRoutes: Array.from(allRoutes),\n });\n } else if (spanOp === 'navigation') {\n // For navigation spans, update the name with the newly loaded routes\n updateNavigationSpan(targetSpan, location, Array.from(allRoutes), false, _matchRoutes);\n }\n }\n }\n}\n\n/**\n * Updates a navigation span with the correct route name after lazy routes have been loaded.\n */\nexport function updateNavigationSpan(\n activeRootSpan: Span,\n location: Location,\n allRoutes: RouteObject[],\n forceUpdate = false,\n matchRoutes: MatchRoutes,\n): void {\n const spanJson = spanToJSON(activeRootSpan);\n const currentName = spanJson.description;\n\n const hasBeenNamed = (activeRootSpan as { __sentry_navigation_name_set__?: boolean })?.__sentry_navigation_name_set__;\n const currentNameHasWildcard = currentName && transactionNameHasWildcard(currentName);\n const shouldUpdate = !hasBeenNamed || forceUpdate || currentNameHasWildcard;\n\n if (shouldUpdate && !spanJson.timestamp) {\n const currentBranches = matchRoutes(allRoutes, location);\n const [name, source] = resolveRouteNameAndSource(\n location,\n allRoutes,\n allRoutes,\n (currentBranches as RouteMatch[]) || [],\n _basename,\n _lazyRouteManifest,\n _enableAsyncRouteHandlers,\n );\n\n const currentSource = spanJson.data?.[SEMANTIC_ATTRIBUTE_SENTRY_SOURCE];\n const isImprovement =\n name &&\n (!currentName || // No current name - always set\n (!hasBeenNamed && (currentSource !== 'route' || source === 'route')) || // Not finalized - allow unless downgrading route→url\n (currentSource !== 'route' && source === 'route') || // URL → route upgrade\n (currentSource === 'route' && source === 'route' && currentNameHasWildcard)); // Route → better route (only if current has wildcard)\n if (isImprovement) {\n activeRootSpan.updateName(name);\n activeRootSpan.setAttribute(SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, source);\n\n // Only mark as finalized for non-wildcard route names (allows URL→route upgrades).\n if (!transactionNameHasWildcard(name) && source === 'route') {\n addNonEnumerableProperty(\n activeRootSpan as { __sentry_navigation_name_set__?: boolean },\n '__sentry_navigation_name_set__',\n true,\n );\n }\n }\n }\n}\n\nfunction setupRouterSubscription(\n router: Router,\n routes: RouteObject[],\n version: V6CompatibleVersion,\n basename: string | undefined,\n activeRootSpan: Span | undefined,\n): void {\n let isInitialPageloadComplete = false;\n let hasSeenPageloadSpan = !!activeRootSpan && spanToJSON(activeRootSpan).op === 'pageload';\n let hasSeenPopAfterPageload = false;\n let scheduledNavigationHandler: number | null = null;\n let lastHandledPathname: string | null = null;\n\n router.subscribe((state: RouterState) => {\n if (!isInitialPageloadComplete) {\n const currentRootSpan = getActiveRootSpan();\n const isCurrentlyInPageload = currentRootSpan && spanToJSON(currentRootSpan).op === 'pageload';\n\n if (isCurrentlyInPageload) {\n hasSeenPageloadSpan = true;\n } else if (hasSeenPageloadSpan) {\n if (state.historyAction === 'POP' && !hasSeenPopAfterPageload) {\n hasSeenPopAfterPageload = true;\n } else {\n isInitialPageloadComplete = true;\n }\n }\n }\n\n const shouldHandleNavigation =\n state.historyAction === 'PUSH' || (state.historyAction === 'POP' && isInitialPageloadComplete);\n\n if (shouldHandleNavigation) {\n // Include search and hash to allow query/hash-only navigations\n // Use computeLocationKey() to ensure undefined/null values are normalized to empty strings\n const currentLocationKey = computeLocationKey(state.location);\n const navigationHandler = (): void => {\n // Prevent multiple calls for the same location within the same navigation cycle\n if (lastHandledPathname === currentLocationKey) {\n return;\n }\n lastHandledPathname = currentLocationKey;\n scheduledNavigationHandler = null;\n handleNavigation({\n location: state.location,\n routes,\n navigationType: state.historyAction,\n version,\n basename,\n allRoutes: Array.from(allRoutes),\n });\n };\n\n if (state.navigation.state !== 'idle') {\n // Navigation in progress - reset if location changed\n if (lastHandledPathname !== currentLocationKey) {\n lastHandledPathname = null;\n }\n // Cancel any previously scheduled handler to avoid duplicates\n if (scheduledNavigationHandler !== null) {\n cancelScheduledCallback(scheduledNavigationHandler);\n }\n scheduledNavigationHandler = scheduleCallback(navigationHandler);\n } else {\n // Navigation completed - cancel scheduled handler if any, then call immediately\n if (scheduledNavigationHandler !== null) {\n cancelScheduledCallback(scheduledNavigationHandler);\n scheduledNavigationHandler = null;\n }\n navigationHandler();\n // Don't reset - next navigation cycle resets to prevent duplicates within same cycle.\n }\n }\n });\n}\n\n/**\n * Creates a wrapCreateBrowserRouter function that can be used with all React Router v6 compatible versions.\n */\nexport function createV6CompatibleWrapCreateBrowserRouter<\n TState extends RouterState = RouterState,\n TRouter extends Router<TState> = Router<TState>,\n>(\n createRouterFunction: CreateRouterFunction<TState, TRouter>,\n version: V6CompatibleVersion,\n): CreateRouterFunction<TState, TRouter> {\n if (!_useEffect || !_useLocation || !_useNavigationType || !_matchRoutes) {\n DEBUG_BUILD &&\n debug.warn(\n `reactRouterV${version}Instrumentation was unable to wrap the \\`createRouter\\` function because of one or more missing parameters.`,\n );\n\n return createRouterFunction;\n }\n\n return function (routes: RouteObject[], opts?: Record<string, unknown> & { basename?: string }): TRouter {\n addRoutesToAllRoutes(routes);\n\n if (_enableAsyncRouteHandlers) {\n for (const route of routes) {\n checkRouteForAsyncHandler(route, processResolvedRoutes);\n }\n }\n\n // Capture the active span BEFORE creating the router.\n // This is important because the span might end (due to idle timeout) before\n // patchRoutesOnNavigation is called by React Router.\n const activeRootSpan = getActiveRootSpan();\n\n // If patchRoutesOnNavigation is provided and we have an active span,\n // mark the span as having potential lazy routes and create a deferred promise.\n const hasPatchRoutesOnNavigation =\n opts && 'patchRoutesOnNavigation' in opts && typeof opts.patchRoutesOnNavigation === 'function';\n if (hasPatchRoutesOnNavigation && activeRootSpan) {\n // Mark the span as potentially having lazy routes\n addNonEnumerableProperty(\n activeRootSpan as unknown as Record<string, boolean>,\n '__sentry_may_have_lazy_routes__',\n true,\n );\n createDeferredLazyRoutePromise(activeRootSpan);\n }\n\n // Pass the captured span to wrapPatchRoutesOnNavigation so it uses the same span\n // even if the span has ended by the time patchRoutesOnNavigation is called.\n const wrappedOpts = wrapPatchRoutesOnNavigation(opts, false, activeRootSpan);\n const router = createRouterFunction(routes, wrappedOpts);\n const basename = opts?.basename;\n\n if (router.state.historyAction === 'POP' && activeRootSpan) {\n updatePageloadTransaction({\n activeRootSpan,\n location: router.state.location,\n routes,\n basename,\n allRoutes: Array.from(allRoutes),\n });\n }\n\n // Store basename for use in updateNavigationSpan\n _basename = basename || '';\n\n setupRouterSubscription(router, routes, version, basename, activeRootSpan);\n\n return router;\n };\n}\n\n/**\n * Creates a wrapCreateMemoryRouter function that can be used with all React Router v6 compatible versions.\n */\nexport function createV6CompatibleWrapCreateMemoryRouter<\n TState extends RouterState = RouterState,\n TRouter extends Router<TState> = Router<TState>,\n>(\n createRouterFunction: CreateRouterFunction<TState, TRouter>,\n version: V6CompatibleVersion,\n): CreateRouterFunction<TState, TRouter> {\n if (!_useEffect || !_useLocation || !_useNavigationType || !_matchRoutes) {\n DEBUG_BUILD &&\n debug.warn(\n `reactRouterV${version}Instrumentation was unable to wrap the \\`createMemoryRouter\\` function because of one or more missing parameters.`,\n );\n\n return createRouterFunction;\n }\n\n return function (\n routes: RouteObject[],\n opts?: Record<string, unknown> & {\n basename?: string;\n initialEntries?: (string | { pathname: string })[];\n initialIndex?: number;\n },\n ): TRouter {\n addRoutesToAllRoutes(routes);\n\n if (_enableAsyncRouteHandlers) {\n for (const route of routes) {\n checkRouteForAsyncHandler(route, processResolvedRoutes);\n }\n }\n\n // Capture the active span BEFORE creating the router (same as browser router)\n const memoryActiveRootSpanEarly = getActiveRootSpan();\n\n // If patchRoutesOnNavigation is provided and we have an active span,\n // mark the span as having potential lazy routes and create a deferred promise.\n const hasPatchRoutesOnNavigation =\n opts && 'patchRoutesOnNavigation' in opts && typeof opts.patchRoutesOnNavigation === 'function';\n if (hasPatchRoutesOnNavigation && memoryActiveRootSpanEarly) {\n addNonEnumerableProperty(\n memoryActiveRootSpanEarly as unknown as Record<string, boolean>,\n '__sentry_may_have_lazy_routes__',\n true,\n );\n createDeferredLazyRoutePromise(memoryActiveRootSpanEarly);\n }\n\n const wrappedOpts = wrapPatchRoutesOnNavigation(opts, true, memoryActiveRootSpanEarly);\n\n const router = createRouterFunction(routes, wrappedOpts);\n const basename = opts?.basename;\n\n let initialEntry = undefined;\n\n const initialEntries = opts?.initialEntries;\n const initialIndex = opts?.initialIndex;\n\n const hasOnlyOneInitialEntry = initialEntries?.length === 1;\n const hasIndexedEntry = initialIndex !== undefined && initialEntries?.[initialIndex];\n\n initialEntry = hasOnlyOneInitialEntry\n ? initialEntries[0]\n : hasIndexedEntry\n ? initialEntries[initialIndex]\n : undefined;\n\n const location = initialEntry\n ? typeof initialEntry === 'string'\n ? { pathname: initialEntry }\n : initialEntry\n : router.state.location;\n\n const memoryActiveRootSpan = getActiveRootSpan();\n\n if (router.state.historyAction === 'POP' && memoryActiveRootSpan) {\n updatePageloadTransaction({\n activeRootSpan: memoryActiveRootSpan,\n location,\n routes,\n basename,\n allRoutes: Array.from(allRoutes),\n });\n }\n\n // Store basename for use in updateNavigationSpan\n _basename = basename || '';\n\n setupRouterSubscription(router, routes, version, basename, memoryActiveRootSpan);\n\n return router;\n };\n}\n\n/**\n * Creates a browser tracing integration that can be used with all React Router v6 compatible versions.\n */\nexport function createReactRouterV6CompatibleTracingIntegration(\n options: Parameters<typeof browserTracingIntegration>[0] & ReactRouterOptions,\n version: V6CompatibleVersion,\n): Integration {\n const integration = browserTracingIntegration({ ...options, instrumentPageLoad: false, instrumentNavigation: false });\n\n const {\n useEffect,\n useLocation,\n useNavigationType,\n createRoutesFromChildren,\n matchRoutes,\n stripBasename,\n enableAsyncRouteHandlers = false,\n instrumentPageLoad = true,\n instrumentNavigation = true,\n lazyRouteTimeout,\n lazyRouteManifest,\n } = options;\n\n return {\n ...integration,\n setup(client) {\n integration.setup(client);\n\n const finalTimeout = options.finalTimeout ?? 30000;\n const defaultMaxWait = (options.idleTimeout ?? 1000) * 3;\n const configuredMaxWait = lazyRouteTimeout ?? defaultMaxWait;\n\n // Cap Infinity at finalTimeout to prevent indefinite hangs\n if (configuredMaxWait === Infinity) {\n _lazyRouteTimeout = finalTimeout;\n DEBUG_BUILD &&\n debug.log(\n '[React Router] lazyRouteTimeout set to Infinity, capping at finalTimeout:',\n finalTimeout,\n 'ms to prevent indefinite hangs',\n );\n } else if (Number.isNaN(configuredMaxWait)) {\n DEBUG_BUILD &&\n debug.warn('[React Router] lazyRouteTimeout must be a number, falling back to default:', defaultMaxWait);\n _lazyRouteTimeout = defaultMaxWait;\n } else if (configuredMaxWait < 0) {\n DEBUG_BUILD &&\n debug.warn(\n '[React Router] lazyRouteTimeout must be non-negative or Infinity, got:',\n configuredMaxWait,\n 'falling back to:',\n defaultMaxWait,\n );\n _lazyRouteTimeout = defaultMaxWait;\n } else {\n _lazyRouteTimeout = configuredMaxWait;\n }\n\n _useEffect = useEffect;\n _useLocation = useLocation;\n _useNavigationType = useNavigationType;\n _matchRoutes = matchRoutes;\n _createRoutesFromChildren = createRoutesFromChildren;\n _enableAsyncRouteHandlers = enableAsyncRouteHandlers;\n _lazyRouteManifest = lazyRouteManifest;\n\n // Initialize the router utils with the required dependencies\n initializeRouterUtils(matchRoutes, stripBasename || false);\n },\n afterAllSetup(client) {\n integration.afterAllSetup(client);\n\n const initPathName = WINDOW.location?.pathname;\n if (instrumentPageLoad && initPathName) {\n startBrowserTracingPageLoadSpan(client, {\n name: initPathName,\n attributes: {\n [SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: 'url',\n [SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'pageload',\n [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: `auto.pageload.react.reactrouter_v${version}`,\n },\n });\n }\n\n if (instrumentNavigation) {\n CLIENTS_WITH_INSTRUMENT_NAVIGATION.add(client);\n }\n },\n };\n}\n\nexport function createV6CompatibleWrapUseRoutes(origUseRoutes: UseRoutes, version: V6CompatibleVersion): UseRoutes {\n if (!_useEffect || !_useLocation || !_useNavigationType || !_matchRoutes) {\n DEBUG_BUILD &&\n debug.warn(\n 'reactRouterV6Instrumentation was unable to wrap `useRoutes` because of one or more missing parameters.',\n );\n\n return origUseRoutes;\n }\n\n const SentryRoutes: React.FC<{\n children?: React.ReactNode;\n routes: RouteObject[];\n locationArg?: Partial<Location> | string;\n }> = (props: { children?: React.ReactNode; routes: RouteObject[]; locationArg?: Partial<Location> | string }) => {\n const isMountRenderPass = React.useRef(true);\n const { routes, locationArg } = props;\n\n const Routes = origUseRoutes(routes, locationArg);\n\n const location = _useLocation();\n const navigationType = _useNavigationType();\n\n // A value with stable identity to either pick `locationArg` if available or `location` if not\n const stableLocationParam =\n typeof locationArg === 'string' || locationArg?.pathname ? (locationArg as { pathname: string }) : location;\n\n _useEffect(() => {\n const normalizedLocation =\n typeof stableLocationParam === 'string' ? { pathname: stableLocationParam } : stableLocationParam;\n\n if (isMountRenderPass.current) {\n addRoutesToAllRoutes(routes);\n\n updatePageloadTransaction({\n activeRootSpan: getActiveRootSpan(),\n location: normalizedLocation,\n routes,\n allRoutes: Array.from(allRoutes),\n });\n isMountRenderPass.current = false;\n } else {\n // Note: Component-based routes don't support lazy route tracking via lazyRouteTimeout\n // because React.lazy() loads happen at the component level, not the router level.\n // Use createBrowserRouter with patchRoutesOnNavigation for lazy route tracking.\n handleNavigation({\n location: normalizedLocation,\n routes,\n navigationType,\n version,\n allRoutes: Array.from(allRoutes),\n });\n }\n }, [navigationType, stableLocationParam]);\n\n return Routes;\n };\n\n // eslint-disable-next-line react/display-name\n return (routes: RouteObject[], locationArg?: Partial<Location> | string): React.ReactElement | null => {\n return <SentryRoutes routes={routes} locationArg={locationArg} />;\n };\n}\nfunction wrapPatchRoutesOnNavigation(\n opts: Record<string, unknown> | undefined,\n isMemoryRouter = false,\n capturedSpan?: Span,\n): Record<string, unknown> {\n if (!opts || !('patchRoutesOnNavigation' in opts) || typeof opts.patchRoutesOnNavigation !== 'function') {\n return opts || {};\n }\n\n const originalPatchRoutes = opts.patchRoutesOnNavigation;\n return {\n ...opts,\n patchRoutesOnNavigation: async (args: unknown) => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n const targetPath = (args as any)?.path;\n\n // Use current active span if available, otherwise fall back to captured span (from router creation time).\n // This ensures navigation spans use their own span (not the stale pageload span), while still\n // supporting pageload spans that may have ended before patchRoutesOnNavigation is called.\n const activeRootSpan = getActiveRootSpan() ?? capturedSpan;\n\n if (!isMemoryRouter) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n const originalPatch = (args as any)?.patch;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n const matches = (args as any)?.matches as Array<{ route: RouteObject }> | undefined;\n if (originalPatch) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-member-access\n (args as any).patch = (routeId: string, children: RouteObject[]) => {\n addRoutesToAllRoutes(children);\n\n // Find the parent route from matches and attach children to it in allRoutes.\n // React Router's patch attaches children to its internal route copies, but we need\n // to update the route objects in our allRoutes Set for proper route matching.\n if (matches && matches.length > 0) {\n const leafMatch = matches[matches.length - 1];\n const leafRoute = leafMatch?.route;\n if (leafRoute) {\n // Find the matching route in allRoutes by id, reference, or path\n const matchingRoute = Array.from(allRoutes).find(route => {\n const idMatches = route.id !== undefined && route.id === routeId;\n const referenceMatches = route === leafRoute;\n const pathMatches =\n route.path !== undefined && leafRoute.path !== undefined && route.path === leafRoute.path;\n\n return idMatches || referenceMatches || pathMatches;\n });\n\n if (matchingRoute) {\n addResolvedRoutesToParent(children, matchingRoute);\n }\n }\n }\n\n // Use the captured activeRootSpan instead of getActiveRootSpan() to avoid race conditions\n // where user navigates away during lazy route loading and we'd update the wrong span\n const spanJson = activeRootSpan ? spanToJSON(activeRootSpan) : undefined;\n // Only update if we have a valid targetPath (patchRoutesOnNavigation can be called without path),\n // the captured span exists, hasn't ended, and is a navigation span\n if (\n targetPath &&\n activeRootSpan &&\n spanJson &&\n !spanJson.timestamp && // Span hasn't ended yet\n spanJson.op === 'navigation'\n ) {\n updateNavigationSpan(\n activeRootSpan,\n { pathname: targetPath, search: '', hash: '', state: null, key: 'default' },\n Array.from(allRoutes),\n true,\n _matchRoutes,\n );\n }\n return originalPatch(routeId, children);\n };\n }\n }\n\n const lazyLoadPromise = (async () => {\n // Set context so async handlers can access correct targetPath and span\n const contextToken = setNavigationContext(targetPath, activeRootSpan);\n let result;\n try {\n result = await originalPatchRoutes(args);\n } finally {\n clearNavigationContext(contextToken);\n // Resolve the deferred promise now that patchRoutesOnNavigation has completed.\n // This ensures patchedEnd has waited long enough for the lazy routes to load.\n if (activeRootSpan) {\n resolveDeferredLazyRoutePromise(activeRootSpan);\n }\n }\n\n // Use the captured activeRootSpan instead of getActiveRootSpan() to avoid race conditions\n // where user navigates away during lazy route loading and we'd update the wrong span\n const spanJson = activeRootSpan ? spanToJSON(activeRootSpan) : undefined;\n if (\n activeRootSpan &&\n spanJson &&\n !spanJson.timestamp && // Span hasn't ended yet\n spanJson.op === 'navigation'\n ) {\n // Use targetPath consistently - don't fall back to WINDOW.location which may have changed\n // if the user navigated away during async loading\n const pathname = targetPath;\n\n if (pathname) {\n updateNavigationSpan(\n activeRootSpan,\n { pathname, search: '', hash: '', state: null, key: 'default' },\n Array.from(allRoutes),\n false,\n _matchRoutes,\n );\n }\n }\n\n return result;\n })();\n\n if (activeRootSpan) {\n trackLazyRouteLoad(activeRootSpan, lazyLoadPromise);\n }\n\n return lazyLoadPromise;\n },\n };\n}\n\n// eslint-disable-next-line complexity\nexport function handleNavigation(opts: {\n location: Location;\n routes: RouteObject[];\n navigationType: Action;\n version: V6CompatibleVersion;\n matches?: AgnosticDataRouteMatch;\n basename?: string;\n allRoutes?: RouteObject[];\n}): void {\n const { location, routes, navigationType, version, matches, basename, allRoutes } = opts;\n const branches = Array.isArray(matches) ? matches : _matchRoutes(allRoutes || routes, location, basename);\n\n const client = getClient();\n if (!client || !CLIENTS_WITH_INSTRUMENT_NAVIGATION.has(client)) {\n return;\n }\n\n const activeRootSpan = getActiveRootSpan();\n if (activeRootSpan && spanToJSON(activeRootSpan).op === 'pageload' && navigationType === 'POP') {\n return;\n }\n\n if ((navigationType === 'PUSH' || navigationType === 'POP') && branches) {\n const [name, source] = resolveRouteNameAndSource(\n location,\n allRoutes || routes,\n allRoutes || routes,\n branches as RouteMatch[],\n basename,\n _lazyRouteManifest,\n _enableAsyncRouteHandlers,\n );\n\n const locationKey = computeLocationKey(location);\n const trackedNav = activeNavigationSpans.get(client);\n\n // Determine if this navigation should be skipped as a duplicate\n const trackedSpanHasEnded =\n trackedNav && !trackedNav.isPlaceholder ? !!spanToJSON(trackedNav.span).timestamp : false;\n const { skip, shouldUpdate } = shouldSkipNavigation(trackedNav, locationKey, name, trackedSpanHasEnded);\n\n if (skip) {\n if (shouldUpdate && trackedNav) {\n const oldName = trackedNav.routeName;\n\n if (trackedNav.isPlaceholder) {\n // Update placeholder's route name - the real span will be created with this name\n trackedNav.routeName = name;\n DEBUG_BUILD &&\n debug.log(\n `[Tracing] Updated placeholder navigation name from \"${oldName}\" to \"${name}\" (will apply to real span)`,\n );\n } else {\n // Update existing real span from wildcard to parameterized route name\n trackedNav.span.updateName(name);\n trackedNav.span.setAttribute(SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, source as 'route' | 'url' | 'custom');\n addNonEnumerableProperty(\n trackedNav.span as { __sentry_navigation_name_set__?: boolean },\n '__sentry_navigation_name_set__',\n true,\n );\n trackedNav.routeName = name;\n DEBUG_BUILD && debug.log(`[Tracing] Updated navigation span name from \"${oldName}\" to \"${name}\"`);\n }\n } else {\n DEBUG_BUILD && debug.log(`[Tracing] Skipping duplicate navigation for location: ${locationKey}`);\n }\n return;\n }\n\n // Create new navigation span (first navigation or legitimate new navigation)\n // Reserve the spot in the map first to prevent race conditions\n // Mark as placeholder to prevent concurrent handleNavigation calls from creating duplicates\n const placeholderSpan = { end: () => {} } as unknown as Span;\n const placeholderEntry = {\n span: placeholderSpan,\n routeName: name,\n pathname: location.pathname,\n locationKey,\n isPlaceholder: true as const,\n };\n activeNavigationSpans.set(client, placeholderEntry);\n\n let navigationSpan: Span | undefined;\n try {\n navigationSpan = startBrowserTracingNavigationSpan(client, {\n name: placeholderEntry.routeName, // Use placeholder's routeName in case it was updated\n attributes: {\n [SEMANTIC_ATTRIBUTE_SENTRY_SOURCE]: source,\n [SEMANTIC_ATTRIBUTE_SENTRY_OP]: 'navigation',\n [SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN]: `auto.navigation.react.reactrouter_v${version}`,\n },\n });\n } catch (e) {\n // If span creation fails, remove the placeholder so we don't block future navigations\n activeNavigationSpans.delete(client);\n throw e;\n }\n\n if (navigationSpan) {\n // Update the map with the real span (isPlaceholder omitted, defaults to false)\n activeNavigationSpans.set(client, {\n span: navigationSpan,\n routeName: placeholderEntry.routeName, // Use the (potentially updated) placeholder routeName\n pathname: location.pathname,\n locationKey,\n });\n patchSpanEnd(navigationSpan, location, routes, basename, 'navigation');\n } else {\n // If no span was created, remove the placeholder\n activeNavigationSpans.delete(client);\n }\n }\n}\n\n/* Only exported for testing purposes */\nexport function addRoutesToAllRoutes(routes: RouteObject[]): void {\n routes.forEach(route => {\n const extractedChildRoutes = getChildRoutesRecursively(route);\n\n extractedChildRoutes.forEach(r => {\n allRoutes.add(r);\n });\n });\n}\n\nfunction getChildRoutesRecursively(route: RouteObject, allRoutes: Set<RouteObject> = new Set()): Set<RouteObject> {\n if (!allRoutes.has(route)) {\n allRoutes.add(route);\n\n if (route.children && !route.index) {\n route.children.forEach(child => {\n const childRoutes = getChildRoutesRecursively(child, allRoutes);\n\n childRoutes.forEach(r => {\n allRoutes.add(r);\n });\n });\n }\n }\n\n return allRoutes;\n}\n\nfunction updatePageloadTransaction({\n activeRootSpan,\n location,\n routes,\n matches,\n basename,\n allRoutes,\n}: {\n activeRootSpan: Span | undefined;\n location: Location;\n routes: RouteObject[];\n matches?: AgnosticDataRouteMatch;\n basename?: string;\n allRoutes?: RouteObject[];\n}): void {\n const branches = Array.isArray(matches)\n ? matches\n : (_matchRoutes(allRoutes || routes, location, basename) as unknown as RouteMatch[]);\n\n if (branches) {\n const [name, source] = resolveRouteNameAndSource(\n location,\n allRoutes || routes,\n allRoutes || routes,\n branches,\n basename,\n _lazyRouteManifest,\n _enableAsyncRouteHandlers,\n );\n\n getCurrentScope().setTransactionName(name || '/');\n\n if (activeRootSpan) {\n activeRootSpan.updateName(name);\n activeRootSpan.setAttribute(SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, source);\n\n // Patch span.end() to ensure we update the name one last time before the span is sent\n patchSpanEnd(activeRootSpan, location, routes, basename, 'pageload');\n }\n } else if (activeRootSpan) {\n // Even if branches is null (can happen when lazy routes haven't loaded yet),\n // we still need to patch span.end() so that when lazy routes load and the span ends,\n // we can update the transaction name correctly.\n patchSpanEnd(activeRootSpan, location, routes, basename, 'pageload');\n }\n}\n\n/**\n * Determines if a span name should be updated during wildcard route resolution.\n *\n * Update conditions (in priority order):\n * 1. No current name + allowNoCurrentName: true → always update (pageload spans)\n * 2. Current name has wildcard + new is route without wildcard → upgrade (e.g., \"/users/*\" → \"/users/:id\")\n * 3. Current source is not 'route' + new source is 'route' → upgrade (e.g., URL → parameterized route)\n *\n * @param currentName - The current span name (may be undefined)\n * @param currentSource - The current span source ('route', 'url', or undefined)\n * @param newName - The proposed new span name\n * @param newSource - The proposed new span source\n * @param allowNoCurrentName - If true, allow updates when there's no current name (for pageload spans)\n * @returns true if the span name should be updated\n */\nfunction shouldUpdateWildcardSpanName(\n currentName: string | undefined,\n currentSource: string | undefined,\n newName: string,\n newSource: string,\n allowNoCurrentName = false,\n): boolean {\n if (!newName) {\n return false;\n }\n\n if (!currentName && allowNoCurrentName) {\n return true;\n }\n\n const hasWildcard = currentName && transactionNameHasWildcard(currentName);\n\n if (hasWildcard && newSource === 'route' && !transactionNameHasWildcard(newName)) {\n return true;\n }\n\n if (currentSource !== 'route' && newSource === 'route') {\n return true;\n }\n\n return false;\n}\n\nfunction tryUpdateSpanNameBeforeEnd(\n span: Span,\n spanJson: ReturnType<typeof spanToJSON>,\n currentName: string | undefined,\n location: Location,\n routes: RouteObject[],\n basename: string | undefined,\n spanType: 'pageload' | 'navigation',\n allRoutes: Set<RouteObject>,\n): void {\n try {\n const currentSource = spanJson.data?.[SEMANTIC_ATTRIBUTE_SENTRY_SOURCE];\n\n if (currentSource === 'route' && currentName && !transactionNameHasWildcard(currentName)) {\n return;\n }\n\n const currentAllRoutes = Array.from(allRoutes);\n const routesToUse = currentAllRoutes.length > 0 ? currentAllRoutes : routes;\n const branches = _matchRoutes(routesToUse, location, basename) as unknown as RouteMatch[];\n\n if (!branches) {\n return;\n }\n\n const [name, source] = resolveRouteNameAndSource(\n location,\n routesToUse,\n routesToUse,\n branches,\n basename,\n _lazyRouteManifest,\n _enableAsyncRouteHandlers,\n );\n\n const isImprovement = shouldUpdateWildcardSpanName(currentName, currentSource, name, source, true);\n const spanNotEnded = spanType === 'pageload' || !spanJson.timestamp;\n\n if (isImprovement && spanNotEnded) {\n span.updateName(name);\n span.setAttribute(SEMANTIC_ATTRIBUTE_SENTRY_SOURCE, source);\n }\n } catch (error) {\n DEBUG_BUILD && debug.warn(`Error updating span details before ending: ${error}`);\n }\n}\n\n/**\n * Patches the span.end() method to update the transaction name one last time before the span is sent.\n * This handles cases where the span is cancelled early (e.g., document.hidden) before lazy routes have finished loading.\n */\nfunction patchSpanEnd(\n span: Span,\n location: Location,\n routes: RouteObject[],\n basename: string | undefined,\n spanType: 'pageload' | 'navigation',\n): void {\n const patchedPropertyName = `__sentry_${spanType}_end_patched__` as const;\n const hasEndBeenPatched = (span as unknown as Record<string, boolean | undefined>)?.[patchedPropertyName];\n\n if (hasEndBeenPatched || !span.end) {\n return;\n }\n\n // Uses global allRoutes to access lazy-loaded routes added after this function was called.\n\n const originalEnd = span.end.bind(span);\n let endCalled = false;\n\n span.end = function patchedEnd(...args) {\n if (endCalled) {\n return;\n }\n endCalled = true;\n\n // Capture timestamp immediately to avoid delay from async operations\n // If no timestamp was provided, capture the current time now\n const endTimestamp = args.length > 0 ? args[0] : Date.now() / 1000;\n\n const spanJson = spanToJSON(span);\n const currentName = spanJson.description;\n const currentSource = spanJson.data?.[SEMANTIC_ATTRIBUTE_SENTRY_SOURCE];\n\n // Helper to clean up activeNavigationSpans after span ends\n const cleanupNavigationSpan = (): void => {\n const client = getClient();\n if (client && spanType === 'navigation') {\n const trackedNav = activeNavigationSpans.get(client);\n if (trackedNav && trackedNav.span === span) {\n activeNavigationSpans.delete(client);\n }\n }\n };\n\n const pendingPromises = pendingLazyRouteLoads.get(span);\n const mayHaveLazyRoutes = (span as unknown as Record<string, boolean>).__sentry_may_have_lazy_routes__;\n\n // Wait for lazy routes if:\n // 1. (There are pending promises OR the span was marked as potentially having lazy routes) AND\n // 2. Current name exists AND\n // 3. Either the name has a wildcard OR the source is not 'route' (URL-based names)\n const hasPendingOrMayHaveLazyRoutes = (pendingPromises && pendingPromises.size > 0) || mayHaveLazyRoutes;\n const shouldWaitForLazyRoutes =\n hasPendingOrMayHaveLazyRoutes &&\n currentName &&\n (transactionNameHasWildcard(currentName) || currentSource !== 'route');\n\n if (shouldWaitForLazyRoutes) {\n if (_lazyRouteTimeout === 0) {\n tryUpdateSpanNameBeforeEnd(span, spanJson, currentName, location, routes, basename, spanType, allRoutes);\n cleanupNavigationSpan();\n originalEnd(endTimestamp);\n return;\n }\n\n // If we have pending promises, wait for them. Otherwise, just wait for the timeout.\n // This handles the case where we know lazy routes might load but patchRoutesOnNavigation\n // hasn't been called yet.\n const timeoutPromise = new Promise<void>(r => setTimeout(r, _lazyRouteTimeout));\n let waitPromise: Promise<void>;\n\n if (pendingPromises && pendingPromises.size > 0) {\n const allSettled = Promise.allSettled(pendingPromises).then(() => {});\n waitPromise = _lazyRouteTimeout === Infinity ? allSettled : Promise.race([allSettled, timeoutPromise]);\n } else {\n // No pending promises yet, but we know lazy routes might load\n // Wait for the timeout to give React Router time to call patchRoutesOnNavigation\n waitPromise = timeoutPromise;\n }\n\n waitPromise\n .then(() => {\n const updatedSpanJson = spanToJSON(span);\n tryUpdateSpanNameBeforeEnd(\n span,\n updatedSpanJson,\n updatedSpanJson.description,\n location,\n routes,\n basename,\n spanType,\n allRoutes,\n );\n cleanupNavigationSpan();\n originalEnd(endTimestamp);\n })\n .catch(() => {\n cleanupNavigationSpan();\n originalEnd(endTimestamp);\n });\n return;\n }\n\n tryUpdateSpanNameBeforeEnd(span, spanJson, currentName, location, routes, basename, spanType, allRoutes);\n cleanupNavigationSpan();\n originalEnd(endTimestamp);\n };\n\n addNonEnumerableProperty(span as unknown as Record<string, boolean>, patchedPropertyName, true);\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function createV6CompatibleWithSentryReactRouterRouting<P extends Record<string, any>, R extends React.FC<P>>(\n Routes: R,\n version: V6CompatibleVersion,\n): R {\n if (!_useEffect || !_useLocation || !_useNavigationType || !_createRoutesFromChildren || !_matchRoutes) {\n DEBUG_BUILD &&\n debug.warn(`reactRouterV6Instrumentation was unable to wrap Routes because of one or more missing parameters.\n useEffect: ${_useEffect}. useLocation: ${_useLocation}. useNavigationType: ${_useNavigationType}.\n createRoutesFromChildren: ${_createRoutesFromChildren}. matchRoutes: ${_matchRoutes}.`);\n\n return Routes;\n }\n\n const SentryRoutes: React.FC<P> = (props: P) => {\n const isMountRenderPass = React.useRef(true);\n\n const location = _useLocation();\n const navigationType = _useNavigationType();\n\n _useEffect(\n () => {\n const routes = _createRoutesFromChildren(props.children) as RouteObject[];\n\n if (isMountRenderPass.current) {\n addRoutesToAllRoutes(routes);\n\n updatePageloadTransaction({\n activeRootSpan: getActiveRootSpan(),\n location,\n routes,\n allRoutes: Array.from(allRoutes),\n });\n isMountRenderPass.current = false;\n } else {\n // Note: Component-based routes don't support lazy route tracking via lazyRouteTimeout\n // because React.lazy() loads happen at the component level, not the router level.\n // Use createBrowserRouter with patchRoutesOnNavigation for lazy route tracking.\n handleNavigation({ location, routes, navigationType, version, allRoutes: Array.from(allRoutes) });\n }\n },\n // Re-run only on location/navigation changes, not children changes\n [location, navigationType],\n );\n\n // @ts-expect-error Setting more specific React Component typing for `R` generic above\n // will break advanced type inference done by react router params\n return <Routes {...props} />;\n };\n\n hoistNonReactStatics(SentryRoutes, Routes);\n\n // @ts-expect-error Setting more specific React Component typing for `R` generic above\n // will break advanced type inference done by react router params\n return SentryRoutes;\n}\n"],"names":["WINDOW","transactionNameHasWildcard","checkRouteForAsyncHandler","getActiveRootSpan","spanToJSON","DEBUG_BUILD","debug","resolveRouteNameAndSource","SEMANTIC_ATTRIBUTE_SENTRY_SOURCE","addNonEnumerableProperty","browserTracingIntegration","initializeRouterUtils","startBrowserTracingPageLoadSpan","SEMANTIC_ATTRIBUTE_SENTRY_OP","SEMANTIC_ATTRIBUTE_SENTRY_ORIGIN","setNavigationContext","clearNavigationContext","getClient","startBrowserTracingNavigationSpan","getCurrentScope","hoistNonReactStatics"],"mappings":"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"}
@@ -0,0 +1,160 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+
3
+ const browser = require('@sentry/browser');
4
+ const core = require('@sentry/core');
5
+ const debugBuild = require('../debug-build.js');
6
+ const utils = require('./utils.js');
7
+
8
+ /**
9
+ * Captures location at invocation time. Prefers navigation context over window.location
10
+ * since window.location hasn't updated yet when async handlers are invoked.
11
+ *
12
+ * When inside a patchRoutesOnNavigation call, uses the captured targetPath. If targetPath
13
+ * is undefined (patchRoutesOnNavigation can be invoked without a path argument), returns
14
+ * null rather than falling back to WINDOW.location which could be stale/wrong after the
15
+ * user navigated away during async loading. Returning null causes the span name update
16
+ * to be skipped, which is safer than using incorrect location data.
17
+ */
18
+ function captureCurrentLocation() {
19
+ const navContext = utils.getNavigationContext();
20
+
21
+ if (navContext) {
22
+ if (navContext.targetPath) {
23
+ return {
24
+ pathname: navContext.targetPath,
25
+ search: '',
26
+ hash: '',
27
+ state: null,
28
+ key: 'default',
29
+ };
30
+ }
31
+ // Don't fall back to potentially stale WINDOW.location
32
+ return null;
33
+ }
34
+
35
+ if (typeof browser.WINDOW !== 'undefined') {
36
+ try {
37
+ const windowLocation = browser.WINDOW.location;
38
+ if (windowLocation) {
39
+ return {
40
+ pathname: windowLocation.pathname,
41
+ search: windowLocation.search || '',
42
+ hash: windowLocation.hash || '',
43
+ state: null,
44
+ key: 'default',
45
+ };
46
+ }
47
+ } catch {
48
+ debugBuild.DEBUG_BUILD && core.debug.warn('[React Router] Could not access window.location');
49
+ }
50
+ }
51
+ return null;
52
+ }
53
+
54
+ /**
55
+ * Captures the active span at invocation time. Prefers navigation context span
56
+ * to ensure we update the correct span even if another navigation starts.
57
+ */
58
+ function captureActiveSpan() {
59
+ const navContext = utils.getNavigationContext();
60
+ if (navContext) {
61
+ return navContext.span;
62
+ }
63
+ return utils.getActiveRootSpan();
64
+ }
65
+
66
+ /**
67
+ * Creates a proxy wrapper for an async handler function.
68
+ * Captures both the location and the active span at invocation time to ensure
69
+ * the correct span is updated when the handler resolves.
70
+ */
71
+ function createAsyncHandlerProxy(
72
+ originalFunction,
73
+ route,
74
+ handlerKey,
75
+ processResolvedRoutes
76
+
77
+ ,
78
+ ) {
79
+ const proxy = new Proxy(originalFunction, {
80
+ apply(target, thisArg, argArray) {
81
+ const locationAtInvocation = captureCurrentLocation();
82
+ const spanAtInvocation = captureActiveSpan();
83
+ const result = target.apply(thisArg, argArray);
84
+ handleAsyncHandlerResult(
85
+ result,
86
+ route,
87
+ handlerKey,
88
+ processResolvedRoutes,
89
+ locationAtInvocation,
90
+ spanAtInvocation,
91
+ );
92
+ return result;
93
+ },
94
+ });
95
+
96
+ core.addNonEnumerableProperty(proxy, '__sentry_proxied__', true);
97
+
98
+ return proxy;
99
+ }
100
+
101
+ /**
102
+ * Handles the result of an async handler function call.
103
+ * Passes the captured span through to ensure the correct span is updated.
104
+ */
105
+ function handleAsyncHandlerResult(
106
+ result,
107
+ route,
108
+ handlerKey,
109
+ processResolvedRoutes
110
+
111
+ ,
112
+ currentLocation,
113
+ capturedSpan,
114
+ ) {
115
+ if (core.isThenable(result)) {
116
+ (result )
117
+ .then((resolvedRoutes) => {
118
+ if (Array.isArray(resolvedRoutes)) {
119
+ processResolvedRoutes(resolvedRoutes, route, currentLocation ?? undefined, capturedSpan);
120
+ }
121
+ })
122
+ .catch((e) => {
123
+ debugBuild.DEBUG_BUILD && core.debug.warn(`Error resolving async handler '${handlerKey}' for route`, route, e);
124
+ });
125
+ } else if (Array.isArray(result)) {
126
+ processResolvedRoutes(result, route, currentLocation ?? undefined, capturedSpan);
127
+ }
128
+ }
129
+
130
+ /**
131
+ * Recursively checks a route for async handlers and sets up Proxies to add discovered child routes to allRoutes when called.
132
+ */
133
+ function checkRouteForAsyncHandler(
134
+ route,
135
+ processResolvedRoutes
136
+
137
+ ,
138
+ ) {
139
+ // Set up proxies for any functions in the route's handle
140
+ if (route.handle && typeof route.handle === 'object') {
141
+ for (const key of Object.keys(route.handle)) {
142
+ const maybeFn = route.handle[key];
143
+ if (typeof maybeFn === 'function' && !(maybeFn ).__sentry_proxied__) {
144
+ route.handle[key] = createAsyncHandlerProxy(maybeFn, route, key, processResolvedRoutes);
145
+ }
146
+ }
147
+ }
148
+
149
+ // Recursively check child routes
150
+ if (Array.isArray(route.children)) {
151
+ for (const child of route.children) {
152
+ checkRouteForAsyncHandler(child, processResolvedRoutes);
153
+ }
154
+ }
155
+ }
156
+
157
+ exports.checkRouteForAsyncHandler = checkRouteForAsyncHandler;
158
+ exports.createAsyncHandlerProxy = createAsyncHandlerProxy;
159
+ exports.handleAsyncHandlerResult = handleAsyncHandlerResult;
160
+ //# sourceMappingURL=lazy-routes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lazy-routes.js","sources":["../../../src/reactrouter-compat-utils/lazy-routes.tsx"],"sourcesContent":["import { WINDOW } from '@sentry/browser';\nimport type { Span } from '@sentry/core';\nimport { addNonEnumerableProperty, debug, isThenable } from '@sentry/core';\nimport { DEBUG_BUILD } from '../debug-build';\nimport type { Location, RouteObject } from '../types';\nimport { getActiveRootSpan, getNavigationContext } from './utils';\n\n/**\n * Captures location at invocation time. Prefers navigation context over window.location\n * since window.location hasn't updated yet when async handlers are invoked.\n *\n * When inside a patchRoutesOnNavigation call, uses the captured targetPath. If targetPath\n * is undefined (patchRoutesOnNavigation can be invoked without a path argument), returns\n * null rather than falling back to WINDOW.location which could be stale/wrong after the\n * user navigated away during async loading. Returning null causes the span name update\n * to be skipped, which is safer than using incorrect location data.\n */\nfunction captureCurrentLocation(): Location | null {\n const navContext = getNavigationContext();\n\n if (navContext) {\n if (navContext.targetPath) {\n return {\n pathname: navContext.targetPath,\n search: '',\n hash: '',\n state: null,\n key: 'default',\n };\n }\n // Don't fall back to potentially stale WINDOW.location\n return null;\n }\n\n if (typeof WINDOW !== 'undefined') {\n try {\n const windowLocation = WINDOW.location;\n if (windowLocation) {\n return {\n pathname: windowLocation.pathname,\n search: windowLocation.search || '',\n hash: windowLocation.hash || '',\n state: null,\n key: 'default',\n };\n }\n } catch {\n DEBUG_BUILD && debug.warn('[React Router] Could not access window.location');\n }\n }\n return null;\n}\n\n/**\n * Captures the active span at invocation time. Prefers navigation context span\n * to ensure we update the correct span even if another navigation starts.\n */\nfunction captureActiveSpan(): Span | undefined {\n const navContext = getNavigationContext();\n if (navContext) {\n return navContext.span;\n }\n return getActiveRootSpan();\n}\n\n/**\n * Creates a proxy wrapper for an async handler function.\n * Captures both the location and the active span at invocation time to ensure\n * the correct span is updated when the handler resolves.\n */\nexport function createAsyncHandlerProxy(\n originalFunction: (...args: unknown[]) => unknown,\n route: RouteObject,\n handlerKey: string,\n processResolvedRoutes: (\n resolvedRoutes: RouteObject[],\n parentRoute?: RouteObject,\n currentLocation?: Location,\n capturedSpan?: Span,\n ) => void,\n): (...args: unknown[]) => unknown {\n const proxy = new Proxy(originalFunction, {\n apply(target: (...args: unknown[]) => unknown, thisArg, argArray) {\n const locationAtInvocation = captureCurrentLocation();\n const spanAtInvocation = captureActiveSpan();\n const result = target.apply(thisArg, argArray);\n handleAsyncHandlerResult(\n result,\n route,\n handlerKey,\n processResolvedRoutes,\n locationAtInvocation,\n spanAtInvocation,\n );\n return result;\n },\n });\n\n addNonEnumerableProperty(proxy, '__sentry_proxied__', true);\n\n return proxy;\n}\n\n/**\n * Handles the result of an async handler function call.\n * Passes the captured span through to ensure the correct span is updated.\n */\nexport function handleAsyncHandlerResult(\n result: unknown,\n route: RouteObject,\n handlerKey: string,\n processResolvedRoutes: (\n resolvedRoutes: RouteObject[],\n parentRoute?: RouteObject,\n currentLocation?: Location,\n capturedSpan?: Span,\n ) => void,\n currentLocation: Location | null,\n capturedSpan: Span | undefined,\n): void {\n if (isThenable(result)) {\n (result as Promise<unknown>)\n .then((resolvedRoutes: unknown) => {\n if (Array.isArray(resolvedRoutes)) {\n processResolvedRoutes(resolvedRoutes, route, currentLocation ?? undefined, capturedSpan);\n }\n })\n .catch((e: unknown) => {\n DEBUG_BUILD && debug.warn(`Error resolving async handler '${handlerKey}' for route`, route, e);\n });\n } else if (Array.isArray(result)) {\n processResolvedRoutes(result, route, currentLocation ?? undefined, capturedSpan);\n }\n}\n\n/**\n * Recursively checks a route for async handlers and sets up Proxies to add discovered child routes to allRoutes when called.\n */\nexport function checkRouteForAsyncHandler(\n route: RouteObject,\n processResolvedRoutes: (\n resolvedRoutes: RouteObject[],\n parentRoute?: RouteObject,\n currentLocation?: Location,\n capturedSpan?: Span,\n ) => void,\n): void {\n // Set up proxies for any functions in the route's handle\n if (route.handle && typeof route.handle === 'object') {\n for (const key of Object.keys(route.handle)) {\n const maybeFn = route.handle[key];\n if (typeof maybeFn === 'function' && !(maybeFn as { __sentry_proxied__?: boolean }).__sentry_proxied__) {\n route.handle[key] = createAsyncHandlerProxy(maybeFn, route, key, processResolvedRoutes);\n }\n }\n }\n\n // Recursively check child routes\n if (Array.isArray(route.children)) {\n for (const child of route.children) {\n checkRouteForAsyncHandler(child, processResolvedRoutes);\n }\n }\n}\n"],"names":["getNavigationContext","WINDOW","DEBUG_BUILD","debug","getActiveRootSpan","addNonEnumerableProperty","isThenable"],"mappings":";;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,sBAAsB,GAAoB;AACnD,EAAE,MAAM,UAAA,GAAaA,0BAAoB,EAAE;;AAE3C,EAAE,IAAI,UAAU,EAAE;AAClB,IAAI,IAAI,UAAU,CAAC,UAAU,EAAE;AAC/B,MAAM,OAAO;AACb,QAAQ,QAAQ,EAAE,UAAU,CAAC,UAAU;AACvC,QAAQ,MAAM,EAAE,EAAE;AAClB,QAAQ,IAAI,EAAE,EAAE;AAChB,QAAQ,KAAK,EAAE,IAAI;AACnB,QAAQ,GAAG,EAAE,SAAS;AACtB,OAAO;AACP,IAAI;AACJ;AACA,IAAI,OAAO,IAAI;AACf,EAAE;;AAEF,EAAE,IAAI,OAAOC,cAAA,KAAW,WAAW,EAAE;AACrC,IAAI,IAAI;AACR,MAAM,MAAM,cAAA,GAAiBA,cAAM,CAAC,QAAQ;AAC5C,MAAM,IAAI,cAAc,EAAE;AAC1B,QAAQ,OAAO;AACf,UAAU,QAAQ,EAAE,cAAc,CAAC,QAAQ;AAC3C,UAAU,MAAM,EAAE,cAAc,CAAC,MAAA,IAAU,EAAE;AAC7C,UAAU,IAAI,EAAE,cAAc,CAAC,IAAA,IAAQ,EAAE;AACzC,UAAU,KAAK,EAAE,IAAI;AACrB,UAAU,GAAG,EAAE,SAAS;AACxB,SAAS;AACT,MAAM;AACN,IAAI,EAAE,MAAM;AACZ,MAAMC,0BAAeC,UAAK,CAAC,IAAI,CAAC,iDAAiD,CAAC;AAClF,IAAI;AACJ,EAAE;AACF,EAAE,OAAO,IAAI;AACb;;AAEA;AACA;AACA;AACA;AACA,SAAS,iBAAiB,GAAqB;AAC/C,EAAE,MAAM,UAAA,GAAaH,0BAAoB,EAAE;AAC3C,EAAE,IAAI,UAAU,EAAE;AAClB,IAAI,OAAO,UAAU,CAAC,IAAI;AAC1B,EAAE;AACF,EAAE,OAAOI,uBAAiB,EAAE;AAC5B;;AAEA;AACA;AACA;AACA;AACA;AACO,SAAS,uBAAuB;AACvC,EAAE,gBAAgB;AAClB,EAAE,KAAK;AACP,EAAE,UAAU;AACZ,EAAE;;AAKA;AACF,EAAmC;AACnC,EAAE,MAAM,KAAA,GAAQ,IAAI,KAAK,CAAC,gBAAgB,EAAE;AAC5C,IAAI,KAAK,CAAC,MAAM,EAAmC,OAAO,EAAE,QAAQ,EAAE;AACtE,MAAM,MAAM,oBAAA,GAAuB,sBAAsB,EAAE;AAC3D,MAAM,MAAM,gBAAA,GAAmB,iBAAiB,EAAE;AAClD,MAAM,MAAM,MAAA,GAAS,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,QAAQ,CAAC;AACpD,MAAM,wBAAwB;AAC9B,QAAQ,MAAM;AACd,QAAQ,KAAK;AACb,QAAQ,UAAU;AAClB,QAAQ,qBAAqB;AAC7B,QAAQ,oBAAoB;AAC5B,QAAQ,gBAAgB;AACxB,OAAO;AACP,MAAM,OAAO,MAAM;AACnB,IAAI,CAAC;AACL,GAAG,CAAC;;AAEJ,EAAEC,6BAAwB,CAAC,KAAK,EAAE,oBAAoB,EAAE,IAAI,CAAC;;AAE7D,EAAE,OAAO,KAAK;AACd;;AAEA;AACA;AACA;AACA;AACO,SAAS,wBAAwB;AACxC,EAAE,MAAM;AACR,EAAE,KAAK;AACP,EAAE,UAAU;AACZ,EAAE;;AAKA;AACF,EAAE,eAAe;AACjB,EAAE,YAAY;AACd,EAAQ;AACR,EAAE,IAAIC,eAAU,CAAC,MAAM,CAAC,EAAE;AAC1B,IAAI,CAAC,MAAA;AACL,OAAO,IAAI,CAAC,CAAC,cAAc,KAAc;AACzC,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE;AAC3C,UAAU,qBAAqB,CAAC,cAAc,EAAE,KAAK,EAAE,eAAA,IAAmB,SAAS,EAAE,YAAY,CAAC;AAClG,QAAQ;AACR,MAAM,CAAC;AACP,OAAO,KAAK,CAAC,CAAC,CAAC,KAAc;AAC7B,QAAQJ,0BAAeC,UAAK,CAAC,IAAI,CAAC,CAAC,+BAA+B,EAAE,UAAU,CAAC,WAAW,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;AACtG,MAAM,CAAC,CAAC;AACR,EAAE,CAAA,MAAO,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;AACpC,IAAI,qBAAqB,CAAC,MAAM,EAAE,KAAK,EAAE,eAAA,IAAmB,SAAS,EAAE,YAAY,CAAC;AACpF,EAAE;AACF;;AAEA;AACA;AACA;AACO,SAAS,yBAAyB;AACzC,EAAE,KAAK;AACP,EAAE;;AAKA;AACF,EAAQ;AACR;AACA,EAAE,IAAI,KAAK,CAAC,MAAA,IAAU,OAAO,KAAK,CAAC,MAAA,KAAW,QAAQ,EAAE;AACxD,IAAI,KAAK,MAAM,GAAA,IAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;AACjD,MAAM,MAAM,UAAU,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC;AACvC,MAAM,IAAI,OAAO,OAAA,KAAY,UAAA,IAAc,CAAC,CAAC,OAAA,GAA6C,kBAAkB,EAAE;AAC9G,QAAQ,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI,uBAAuB,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,qBAAqB,CAAC;AAC/F,MAAM;AACN,IAAI;AACJ,EAAE;;AAEF;AACA,EAAE,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE;AACrC,IAAI,KAAK,MAAM,KAAA,IAAS,KAAK,CAAC,QAAQ,EAAE;AACxC,MAAM,yBAAyB,CAAC,KAAK,EAAE,qBAAqB,CAAC;AAC7D,IAAI;AACJ,EAAE;AACF;;;;;;"}
@@ -0,0 +1,194 @@
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+
3
+ const core = require('@sentry/core');
4
+ const debugBuild = require('../debug-build.js');
5
+
6
+ /**
7
+ * Strip the basename from a pathname if exists.
8
+ *
9
+ * Vendored and modified from `react-router`
10
+ * https://github.com/remix-run/react-router/blob/462bb712156a3f739d6139a0f14810b76b002df6/packages/router/utils.ts#L1038
11
+ */
12
+ function stripBasenameFromPathname(pathname, basename) {
13
+ if (!basename || basename === '/') {
14
+ return pathname;
15
+ }
16
+
17
+ if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {
18
+ return pathname;
19
+ }
20
+
21
+ // We want to leave trailing slash behavior in the user's control, so if they
22
+ // specify a basename with a trailing slash, we should support it
23
+ const startIndex = basename.endsWith('/') ? basename.length - 1 : basename.length;
24
+ const nextChar = pathname.charAt(startIndex);
25
+ if (nextChar && nextChar !== '/') {
26
+ // pathname does not start with basename/
27
+ return pathname;
28
+ }
29
+
30
+ return pathname.slice(startIndex) || '/';
31
+ }
32
+
33
+ // Cache for sorted manifests - keyed by manifest array reference
34
+ const SORTED_MANIFEST_CACHE = new WeakMap();
35
+
36
+ /**
37
+ * Matches a pathname against a route manifest and returns the matching pattern.
38
+ * Optionally strips a basename prefix before matching.
39
+ */
40
+ function matchRouteManifest(pathname, manifest, basename) {
41
+ if (!pathname || !manifest?.length) {
42
+ return null;
43
+ }
44
+
45
+ const normalizedPathname = basename ? stripBasenameFromPathname(pathname, basename) : pathname;
46
+
47
+ let sorted = SORTED_MANIFEST_CACHE.get(manifest);
48
+ if (!sorted) {
49
+ sorted = sortBySpecificity(manifest);
50
+ SORTED_MANIFEST_CACHE.set(manifest, sorted);
51
+ debugBuild.DEBUG_BUILD && core.debug.log('[React Router] Sorted route manifest by specificity:', sorted.length, 'patterns');
52
+ }
53
+
54
+ for (const pattern of sorted) {
55
+ if (matchesPattern(normalizedPathname, pattern)) {
56
+ debugBuild.DEBUG_BUILD && core.debug.log('[React Router] Matched pathname', normalizedPathname, 'to pattern', pattern);
57
+ return pattern;
58
+ }
59
+ }
60
+
61
+ debugBuild.DEBUG_BUILD && core.debug.log('[React Router] No manifest match found for pathname:', normalizedPathname);
62
+ return null;
63
+ }
64
+
65
+ /**
66
+ * Checks if a pathname matches a route pattern.
67
+ */
68
+ function matchesPattern(pathname, pattern) {
69
+ // Handle root path special case
70
+ if (pattern === '/') {
71
+ return pathname === '/' || pathname === '';
72
+ }
73
+
74
+ const pathSegments = splitPath(pathname);
75
+ const patternSegments = splitPath(pattern);
76
+
77
+ // Handle wildcard at end
78
+ const hasWildcard = patternSegments.length > 0 && patternSegments[patternSegments.length - 1] === '*';
79
+
80
+ if (hasWildcard) {
81
+ // Pattern with wildcard: path must have at least as many segments as pattern (minus wildcard)
82
+ const patternSegmentsWithoutWildcard = patternSegments.slice(0, -1);
83
+ if (pathSegments.length < patternSegmentsWithoutWildcard.length) {
84
+ return false;
85
+ }
86
+ for (const [i, patternSegment] of patternSegmentsWithoutWildcard.entries()) {
87
+ if (!segmentMatches(pathSegments[i], patternSegment)) {
88
+ return false;
89
+ }
90
+ }
91
+ return true;
92
+ }
93
+
94
+ // Exact segment count match required
95
+ if (pathSegments.length !== patternSegments.length) {
96
+ return false;
97
+ }
98
+
99
+ for (const [i, patternSegment] of patternSegments.entries()) {
100
+ if (!segmentMatches(pathSegments[i], patternSegment)) {
101
+ return false;
102
+ }
103
+ }
104
+
105
+ return true;
106
+ }
107
+
108
+ /**
109
+ * Checks if a path segment matches a pattern segment.
110
+ */
111
+ function segmentMatches(pathSegment, patternSegment) {
112
+ if (pathSegment === undefined || patternSegment === undefined) {
113
+ return false;
114
+ }
115
+ // Parameter matches anything
116
+ if (PARAM_RE.test(patternSegment)) {
117
+ return true;
118
+ }
119
+ // Literal must match exactly
120
+ return pathSegment === patternSegment;
121
+ }
122
+
123
+ /**
124
+ * Splits a path into segments, filtering out empty strings.
125
+ */
126
+ function splitPath(path) {
127
+ return path.split('/').filter(Boolean);
128
+ }
129
+
130
+ /**
131
+ * React Router scoring weights and param detection.
132
+ * https://github.com/remix-run/react-router/blob/main/packages/react-router/lib/router/utils.ts
133
+ */
134
+ const PARAM_RE = /^:[\w-]+$/;
135
+ const STATIC_SEGMENT_SCORE = 10;
136
+ const DYNAMIC_SEGMENT_SCORE = 3;
137
+ const EMPTY_SEGMENT_SCORE = 1;
138
+ const SPLAT_PENALTY = -2;
139
+
140
+ /**
141
+ * Computes a specificity score for a route pattern.
142
+ * Matches React Router's computeScore() algorithm exactly.
143
+ */
144
+ function computeScore(pattern) {
145
+ const segments = pattern.split('/');
146
+
147
+ // Base score is segment count (including empty segment from leading slash)
148
+ let score = segments.length;
149
+
150
+ // Apply splat penalty once if pattern contains wildcard
151
+ if (segments.includes('*')) {
152
+ score += SPLAT_PENALTY;
153
+ }
154
+
155
+ for (const segment of segments) {
156
+ if (segment === '*') {
157
+ // Splat penalty already applied globally above
158
+ continue;
159
+ } else if (PARAM_RE.test(segment)) {
160
+ score += DYNAMIC_SEGMENT_SCORE;
161
+ } else if (segment === '') {
162
+ score += EMPTY_SEGMENT_SCORE;
163
+ } else {
164
+ score += STATIC_SEGMENT_SCORE;
165
+ }
166
+ }
167
+
168
+ return score;
169
+ }
170
+
171
+ /**
172
+ * Sorts route patterns by specificity (most specific first).
173
+ * Implements React Router's ranking algorithm from computeScore():
174
+ * https://github.com/remix-run/react-router/blob/main/packages/react-router/lib/router/utils.ts
175
+ *
176
+ * React Router scoring: base=segments.length, static=+10, dynamic=+3, empty=+1, splat=-2 (once)
177
+ * Higher score = more specific pattern.
178
+ * Equal scores preserve manifest order (same as React Router).
179
+ *
180
+ * Note: Users should order their manifest from most specific to least specific
181
+ * when patterns have equal specificity (e.g., `/users/:id/settings` and `/:type/123/settings`).
182
+ */
183
+ function sortBySpecificity(manifest) {
184
+ return [...manifest].sort((a, b) => {
185
+ const aScore = computeScore(a);
186
+ const bScore = computeScore(b);
187
+
188
+ return bScore - aScore;
189
+ });
190
+ }
191
+
192
+ exports.matchRouteManifest = matchRouteManifest;
193
+ exports.stripBasenameFromPathname = stripBasenameFromPathname;
194
+ //# sourceMappingURL=route-manifest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"route-manifest.js","sources":["../../../src/reactrouter-compat-utils/route-manifest.ts"],"sourcesContent":["import { debug } from '@sentry/core';\nimport { DEBUG_BUILD } from '../debug-build';\n\n/**\n * Strip the basename from a pathname if exists.\n *\n * Vendored and modified from `react-router`\n * https://github.com/remix-run/react-router/blob/462bb712156a3f739d6139a0f14810b76b002df6/packages/router/utils.ts#L1038\n */\nexport function stripBasenameFromPathname(pathname: string, basename: string): string {\n if (!basename || basename === '/') {\n return pathname;\n }\n\n if (!pathname.toLowerCase().startsWith(basename.toLowerCase())) {\n return pathname;\n }\n\n // We want to leave trailing slash behavior in the user's control, so if they\n // specify a basename with a trailing slash, we should support it\n const startIndex = basename.endsWith('/') ? basename.length - 1 : basename.length;\n const nextChar = pathname.charAt(startIndex);\n if (nextChar && nextChar !== '/') {\n // pathname does not start with basename/\n return pathname;\n }\n\n return pathname.slice(startIndex) || '/';\n}\n\n// Cache for sorted manifests - keyed by manifest array reference\nconst SORTED_MANIFEST_CACHE = new WeakMap<string[], string[]>();\n\n/**\n * Matches a pathname against a route manifest and returns the matching pattern.\n * Optionally strips a basename prefix before matching.\n */\nexport function matchRouteManifest(pathname: string, manifest: string[], basename?: string): string | null {\n if (!pathname || !manifest?.length) {\n return null;\n }\n\n const normalizedPathname = basename ? stripBasenameFromPathname(pathname, basename) : pathname;\n\n let sorted = SORTED_MANIFEST_CACHE.get(manifest);\n if (!sorted) {\n sorted = sortBySpecificity(manifest);\n SORTED_MANIFEST_CACHE.set(manifest, sorted);\n DEBUG_BUILD && debug.log('[React Router] Sorted route manifest by specificity:', sorted.length, 'patterns');\n }\n\n for (const pattern of sorted) {\n if (matchesPattern(normalizedPathname, pattern)) {\n DEBUG_BUILD && debug.log('[React Router] Matched pathname', normalizedPathname, 'to pattern', pattern);\n return pattern;\n }\n }\n\n DEBUG_BUILD && debug.log('[React Router] No manifest match found for pathname:', normalizedPathname);\n return null;\n}\n\n/**\n * Checks if a pathname matches a route pattern.\n */\nfunction matchesPattern(pathname: string, pattern: string): boolean {\n // Handle root path special case\n if (pattern === '/') {\n return pathname === '/' || pathname === '';\n }\n\n const pathSegments = splitPath(pathname);\n const patternSegments = splitPath(pattern);\n\n // Handle wildcard at end\n const hasWildcard = patternSegments.length > 0 && patternSegments[patternSegments.length - 1] === '*';\n\n if (hasWildcard) {\n // Pattern with wildcard: path must have at least as many segments as pattern (minus wildcard)\n const patternSegmentsWithoutWildcard = patternSegments.slice(0, -1);\n if (pathSegments.length < patternSegmentsWithoutWildcard.length) {\n return false;\n }\n for (const [i, patternSegment] of patternSegmentsWithoutWildcard.entries()) {\n if (!segmentMatches(pathSegments[i], patternSegment)) {\n return false;\n }\n }\n return true;\n }\n\n // Exact segment count match required\n if (pathSegments.length !== patternSegments.length) {\n return false;\n }\n\n for (const [i, patternSegment] of patternSegments.entries()) {\n if (!segmentMatches(pathSegments[i], patternSegment)) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Checks if a path segment matches a pattern segment.\n */\nfunction segmentMatches(pathSegment: string | undefined, patternSegment: string | undefined): boolean {\n if (pathSegment === undefined || patternSegment === undefined) {\n return false;\n }\n // Parameter matches anything\n if (PARAM_RE.test(patternSegment)) {\n return true;\n }\n // Literal must match exactly\n return pathSegment === patternSegment;\n}\n\n/**\n * Splits a path into segments, filtering out empty strings.\n */\nfunction splitPath(path: string): string[] {\n return path.split('/').filter(Boolean);\n}\n\n/**\n * React Router scoring weights and param detection.\n * https://github.com/remix-run/react-router/blob/main/packages/react-router/lib/router/utils.ts\n */\nconst PARAM_RE = /^:[\\w-]+$/;\nconst STATIC_SEGMENT_SCORE = 10;\nconst DYNAMIC_SEGMENT_SCORE = 3;\nconst EMPTY_SEGMENT_SCORE = 1;\nconst SPLAT_PENALTY = -2;\n\n/**\n * Computes a specificity score for a route pattern.\n * Matches React Router's computeScore() algorithm exactly.\n */\nfunction computeScore(pattern: string): number {\n const segments = pattern.split('/');\n\n // Base score is segment count (including empty segment from leading slash)\n let score = segments.length;\n\n // Apply splat penalty once if pattern contains wildcard\n if (segments.includes('*')) {\n score += SPLAT_PENALTY;\n }\n\n for (const segment of segments) {\n if (segment === '*') {\n // Splat penalty already applied globally above\n continue;\n } else if (PARAM_RE.test(segment)) {\n score += DYNAMIC_SEGMENT_SCORE;\n } else if (segment === '') {\n score += EMPTY_SEGMENT_SCORE;\n } else {\n score += STATIC_SEGMENT_SCORE;\n }\n }\n\n return score;\n}\n\n/**\n * Sorts route patterns by specificity (most specific first).\n * Implements React Router's ranking algorithm from computeScore():\n * https://github.com/remix-run/react-router/blob/main/packages/react-router/lib/router/utils.ts\n *\n * React Router scoring: base=segments.length, static=+10, dynamic=+3, empty=+1, splat=-2 (once)\n * Higher score = more specific pattern.\n * Equal scores preserve manifest order (same as React Router).\n *\n * Note: Users should order their manifest from most specific to least specific\n * when patterns have equal specificity (e.g., `/users/:id/settings` and `/:type/123/settings`).\n */\nfunction sortBySpecificity(manifest: string[]): string[] {\n return [...manifest].sort((a, b) => {\n const aScore = computeScore(a);\n const bScore = computeScore(b);\n\n return bScore - aScore;\n });\n}\n"],"names":["DEBUG_BUILD","debug"],"mappings":"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"}