@atlaskit/react-ufo 1.1.0 → 2.0.1

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 (486) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/README.md +5 -0
  3. package/additional-payload/package.json +15 -0
  4. package/bundle-eval-timing/package.json +15 -0
  5. package/coinflip/package.json +15 -0
  6. package/common/package.json +5 -5
  7. package/config/package.json +15 -0
  8. package/create-payload/package.json +15 -0
  9. package/create-post-interaction-log-payload/package.json +15 -0
  10. package/custom-data/package.json +15 -0
  11. package/custom-mark/package.json +15 -0
  12. package/custom-spans/package.json +15 -0
  13. package/custom-timings/package.json +15 -0
  14. package/dist/cjs/additional-payload/index.js +25 -0
  15. package/dist/cjs/additional-payload/utils/cache-hit-ratio/index.js +69 -0
  16. package/dist/cjs/additional-payload/utils/lighthouse-metrics/cls/index.js +53 -0
  17. package/dist/cjs/additional-payload/utils/lighthouse-metrics/const.js +10 -0
  18. package/dist/cjs/additional-payload/utils/lighthouse-metrics/index.js +29 -0
  19. package/dist/cjs/additional-payload/utils/lighthouse-metrics/tbt/index.js +25 -0
  20. package/dist/cjs/additional-payload/utils/lighthouse-metrics/utils/buffer/index.js +38 -0
  21. package/dist/cjs/additional-payload/utils/lighthouse-metrics/utils/observer/index.js +37 -0
  22. package/dist/cjs/bundle-eval-timing/index.js +48 -0
  23. package/dist/cjs/coinflip/index.js +22 -0
  24. package/dist/cjs/common/common/types.js +5 -0
  25. package/dist/cjs/common/constants.js +7 -0
  26. package/dist/cjs/common/index.js +1 -0
  27. package/dist/cjs/common/vc/types.js +11 -0
  28. package/dist/cjs/config/index.js +222 -0
  29. package/dist/cjs/create-payload/common/types.js +1 -0
  30. package/dist/cjs/create-payload/common/utils/index.js +15 -0
  31. package/dist/cjs/create-payload/index.js +784 -0
  32. package/dist/cjs/create-post-interaction-log-payload/index.js +207 -0
  33. package/dist/cjs/custom-data/index.js +31 -0
  34. package/dist/cjs/custom-data/types.js +5 -0
  35. package/dist/cjs/custom-mark/index.js +45 -0
  36. package/dist/cjs/custom-spans/index.js +14 -0
  37. package/dist/cjs/custom-timings/index.js +65 -0
  38. package/dist/cjs/experience-trace-id-context/index.js +40 -0
  39. package/dist/cjs/experience-trace-id-context/types.js +1 -0
  40. package/dist/cjs/experience-trace-id-context/utils/make-trace-http-request-headers/index.js +12 -0
  41. package/dist/cjs/feature-flags-accessed/common/constants.js +7 -0
  42. package/dist/cjs/feature-flags-accessed/common/types.js +5 -0
  43. package/dist/cjs/feature-flags-accessed/common/utils/index.js +38 -0
  44. package/dist/cjs/feature-flags-accessed/index.js +32 -0
  45. package/dist/cjs/generate-id/index.js +12 -0
  46. package/dist/cjs/global-error-handler/index.js +74 -0
  47. package/dist/cjs/hidden-timing/index.js +94 -0
  48. package/dist/cjs/initial-page-load-extra-timing/index.js +49 -0
  49. package/dist/cjs/interaction-context/index.js +14 -0
  50. package/dist/cjs/interaction-id-context/index.js +27 -0
  51. package/dist/cjs/interaction-metrics/common/constants.js +8 -0
  52. package/dist/cjs/interaction-metrics/index.js +810 -1
  53. package/dist/cjs/interaction-metrics/post-interaction-log.js +190 -0
  54. package/dist/cjs/interaction-metrics-init/index.js +89 -0
  55. package/dist/cjs/label/UFOLabel.js +45 -0
  56. package/dist/cjs/label/index.js +9 -0
  57. package/dist/cjs/load-hold/UFOLoadHold.js +76 -0
  58. package/dist/cjs/load-hold/index.js +9 -0
  59. package/dist/cjs/placeholder/Placeholder.js +34 -0
  60. package/dist/cjs/placeholder/index.js +9 -0
  61. package/dist/cjs/placeholder/loosely-lazy/index.js +19 -0
  62. package/dist/cjs/placeholder/loosely-lazy/lazy-suspense.js +80 -0
  63. package/dist/cjs/placeholder/loosely-lazy/types.js +5 -0
  64. package/dist/cjs/placeholder/loosely-lazy/wait-context.js +15 -0
  65. package/dist/cjs/resource-timing/common/types.js +1 -0
  66. package/dist/cjs/resource-timing/common/utils/config.js +70 -0
  67. package/dist/cjs/resource-timing/common/utils/resource-timing-buffer.js +111 -0
  68. package/dist/cjs/resource-timing/index.js +26 -0
  69. package/dist/cjs/resource-timing/main.js +141 -0
  70. package/dist/cjs/resource-timing/utils.js +10 -0
  71. package/dist/cjs/round-number/index.js +11 -0
  72. package/dist/cjs/route-name/index.js +12 -0
  73. package/dist/cjs/route-name-context/index.js +11 -0
  74. package/dist/cjs/segment/index.js +9 -0
  75. package/dist/cjs/segment/segment-highlight.js +40 -0
  76. package/dist/cjs/segment/segment.js +247 -0
  77. package/dist/cjs/set-interaction-error/index.js +17 -0
  78. package/dist/cjs/short-id/index.js +15 -0
  79. package/dist/cjs/ssr/index.js +70 -0
  80. package/dist/cjs/trace-interaction/index.js +48 -0
  81. package/dist/cjs/trace-pageload/index.js +58 -0
  82. package/dist/cjs/trace-press/index.js +34 -0
  83. package/dist/cjs/trace-redirect/index.js +17 -0
  84. package/dist/cjs/trace-transition/index.js +60 -0
  85. package/dist/cjs/trace-transition/utils/generate-span-id/index.js +11 -0
  86. package/dist/cjs/trace-transition/utils/set-interaction-active-trace/index.js +11 -0
  87. package/dist/cjs/typing-performance-tracing/index.js +262 -0
  88. package/dist/cjs/use-press-tracing/index.js +19 -0
  89. package/dist/cjs/vc/index.js +15 -0
  90. package/dist/cjs/vc/vc-observer/attachAbortListeners.js +40 -0
  91. package/dist/cjs/vc/vc-observer/getViewport.js +27 -0
  92. package/dist/cjs/vc/vc-observer/index.js +562 -0
  93. package/dist/cjs/vc/vc-observer/media-wrapper/index.js +15 -0
  94. package/dist/cjs/vc/vc-observer/media-wrapper/vc-utils.js +16 -0
  95. package/dist/cjs/vc/vc-observer/observers/index.js +270 -0
  96. package/dist/cjs/vc/vc-observer/observers/ssr-placeholders/index.js +183 -0
  97. package/dist/cjs/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/bindAbortListeners.js +22 -0
  98. package/dist/cjs/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/collectSSRPlaceholderDimensions.js +20 -0
  99. package/dist/cjs/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/index.js +19 -0
  100. package/dist/cjs/vc/vc-observer/observers/types.js +5 -0
  101. package/dist/es2019/additional-payload/index.js +2 -0
  102. package/dist/es2019/additional-payload/utils/cache-hit-ratio/index.js +63 -0
  103. package/dist/es2019/additional-payload/utils/lighthouse-metrics/cls/index.js +33 -0
  104. package/dist/es2019/additional-payload/utils/lighthouse-metrics/const.js +4 -0
  105. package/dist/es2019/additional-payload/utils/lighthouse-metrics/index.js +23 -0
  106. package/dist/es2019/additional-payload/utils/lighthouse-metrics/tbt/index.js +15 -0
  107. package/dist/es2019/additional-payload/utils/lighthouse-metrics/utils/buffer/index.js +23 -0
  108. package/dist/es2019/additional-payload/utils/lighthouse-metrics/utils/observer/index.js +31 -0
  109. package/dist/es2019/bundle-eval-timing/index.js +43 -0
  110. package/dist/es2019/coinflip/index.js +16 -0
  111. package/dist/es2019/common/common/types.js +1 -0
  112. package/dist/es2019/common/constants.js +1 -0
  113. package/dist/es2019/common/vc/types.js +5 -0
  114. package/dist/es2019/config/index.js +215 -0
  115. package/dist/es2019/create-payload/common/types.js +0 -0
  116. package/dist/es2019/create-payload/common/utils/index.js +8 -0
  117. package/dist/es2019/create-payload/index.js +792 -0
  118. package/dist/es2019/create-post-interaction-log-payload/index.js +188 -0
  119. package/dist/es2019/custom-data/index.js +24 -0
  120. package/dist/es2019/custom-data/types.js +1 -0
  121. package/dist/es2019/custom-mark/index.js +38 -0
  122. package/dist/es2019/custom-spans/index.js +6 -0
  123. package/dist/es2019/custom-timings/index.js +57 -0
  124. package/dist/es2019/experience-trace-id-context/index.js +31 -0
  125. package/dist/es2019/experience-trace-id-context/types.js +0 -0
  126. package/dist/es2019/experience-trace-id-context/utils/make-trace-http-request-headers/index.js +4 -0
  127. package/dist/es2019/feature-flags-accessed/common/constants.js +1 -0
  128. package/dist/es2019/feature-flags-accessed/common/types.js +1 -0
  129. package/dist/es2019/feature-flags-accessed/common/utils/index.js +24 -0
  130. package/dist/es2019/feature-flags-accessed/index.js +21 -0
  131. package/dist/es2019/generate-id/index.js +6 -0
  132. package/dist/es2019/global-error-handler/index.js +64 -0
  133. package/dist/es2019/hidden-timing/index.js +87 -0
  134. package/dist/es2019/initial-page-load-extra-timing/index.js +43 -0
  135. package/dist/es2019/interaction-context/index.js +6 -0
  136. package/dist/es2019/interaction-id-context/index.js +18 -0
  137. package/dist/es2019/interaction-metrics/common/constants.js +2 -0
  138. package/dist/es2019/interaction-metrics/index.js +736 -0
  139. package/dist/es2019/interaction-metrics/post-interaction-log.js +158 -0
  140. package/dist/es2019/interaction-metrics-init/index.js +72 -0
  141. package/dist/es2019/label/UFOLabel.js +34 -0
  142. package/dist/es2019/label/index.js +2 -0
  143. package/dist/es2019/load-hold/UFOLoadHold.js +66 -0
  144. package/dist/es2019/load-hold/index.js +2 -0
  145. package/dist/es2019/placeholder/Placeholder.js +25 -0
  146. package/dist/es2019/placeholder/index.js +2 -0
  147. package/dist/es2019/placeholder/loosely-lazy/index.js +2 -0
  148. package/dist/es2019/placeholder/loosely-lazy/lazy-suspense.js +63 -0
  149. package/dist/es2019/placeholder/loosely-lazy/types.js +1 -0
  150. package/dist/es2019/placeholder/loosely-lazy/wait-context.js +5 -0
  151. package/dist/es2019/resource-timing/common/types.js +0 -0
  152. package/dist/es2019/resource-timing/common/utils/config.js +44 -0
  153. package/dist/es2019/resource-timing/common/utils/resource-timing-buffer.js +88 -0
  154. package/dist/es2019/resource-timing/index.js +3 -0
  155. package/dist/es2019/resource-timing/main.js +130 -0
  156. package/dist/es2019/resource-timing/utils.js +4 -0
  157. package/dist/es2019/round-number/index.js +4 -0
  158. package/dist/es2019/route-name/index.js +6 -0
  159. package/dist/es2019/route-name-context/index.js +5 -0
  160. package/dist/es2019/segment/index.js +2 -0
  161. package/dist/es2019/segment/segment-highlight.js +27 -0
  162. package/dist/es2019/segment/segment.js +218 -0
  163. package/dist/es2019/set-interaction-error/index.js +11 -0
  164. package/dist/es2019/short-id/index.js +8 -0
  165. package/dist/es2019/ssr/index.js +54 -0
  166. package/dist/es2019/trace-interaction/index.js +41 -0
  167. package/dist/es2019/trace-pageload/index.js +48 -0
  168. package/dist/es2019/trace-press/index.js +27 -0
  169. package/dist/es2019/trace-redirect/index.js +10 -0
  170. package/dist/es2019/trace-transition/index.js +48 -0
  171. package/dist/es2019/trace-transition/utils/generate-span-id/index.js +1 -0
  172. package/dist/es2019/trace-transition/utils/set-interaction-active-trace/index.js +5 -0
  173. package/dist/es2019/typing-performance-tracing/index.js +255 -0
  174. package/dist/es2019/use-press-tracing/index.js +12 -0
  175. package/dist/es2019/vc/index.js +8 -0
  176. package/dist/es2019/vc/vc-observer/attachAbortListeners.js +34 -0
  177. package/dist/es2019/vc/vc-observer/getViewport.js +18 -0
  178. package/dist/es2019/vc/vc-observer/index.js +522 -0
  179. package/dist/es2019/vc/vc-observer/media-wrapper/index.js +9 -0
  180. package/dist/es2019/vc/vc-observer/media-wrapper/vc-utils.js +10 -0
  181. package/dist/es2019/vc/vc-observer/observers/index.js +231 -0
  182. package/dist/es2019/vc/vc-observer/observers/ssr-placeholders/index.js +146 -0
  183. package/dist/es2019/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/bindAbortListeners.js +16 -0
  184. package/dist/es2019/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/collectSSRPlaceholderDimensions.js +14 -0
  185. package/dist/es2019/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/index.js +2 -0
  186. package/dist/es2019/vc/vc-observer/observers/types.js +1 -0
  187. package/dist/esm/additional-payload/index.js +2 -0
  188. package/dist/esm/additional-payload/utils/cache-hit-ratio/index.js +63 -0
  189. package/dist/esm/additional-payload/utils/lighthouse-metrics/cls/index.js +47 -0
  190. package/dist/esm/additional-payload/utils/lighthouse-metrics/cls/types.js +0 -0
  191. package/dist/esm/additional-payload/utils/lighthouse-metrics/const.js +4 -0
  192. package/dist/esm/additional-payload/utils/lighthouse-metrics/index.js +22 -0
  193. package/dist/esm/additional-payload/utils/lighthouse-metrics/tbt/index.js +19 -0
  194. package/dist/esm/additional-payload/utils/lighthouse-metrics/utils/buffer/index.js +31 -0
  195. package/dist/esm/additional-payload/utils/lighthouse-metrics/utils/observer/index.js +31 -0
  196. package/dist/esm/bundle-eval-timing/index.js +41 -0
  197. package/dist/esm/coinflip/index.js +16 -0
  198. package/dist/esm/common/common/types.js +1 -0
  199. package/dist/esm/common/constants.js +1 -0
  200. package/dist/esm/common/index.js +0 -0
  201. package/dist/esm/common/vc/types.js +5 -0
  202. package/dist/esm/config/index.js +206 -0
  203. package/dist/esm/create-payload/common/types.js +0 -0
  204. package/dist/esm/create-payload/common/utils/index.js +8 -0
  205. package/dist/esm/create-payload/index.js +774 -0
  206. package/dist/esm/create-post-interaction-log-payload/index.js +200 -0
  207. package/dist/esm/custom-data/index.js +23 -0
  208. package/dist/esm/custom-data/types.js +1 -0
  209. package/dist/esm/custom-mark/index.js +36 -0
  210. package/dist/esm/custom-spans/index.js +8 -0
  211. package/dist/esm/custom-timings/index.js +56 -0
  212. package/dist/esm/experience-trace-id-context/index.js +34 -0
  213. package/dist/esm/experience-trace-id-context/types.js +0 -0
  214. package/dist/esm/experience-trace-id-context/utils/make-trace-http-request-headers/index.js +6 -0
  215. package/dist/esm/feature-flags-accessed/common/constants.js +1 -0
  216. package/dist/esm/feature-flags-accessed/common/types.js +1 -0
  217. package/dist/esm/feature-flags-accessed/common/utils/index.js +31 -0
  218. package/dist/esm/feature-flags-accessed/index.js +21 -0
  219. package/dist/esm/generate-id/index.js +6 -0
  220. package/dist/esm/global-error-handler/index.js +67 -0
  221. package/dist/esm/hidden-timing/index.js +87 -0
  222. package/dist/esm/initial-page-load-extra-timing/index.js +42 -0
  223. package/dist/esm/interaction-context/index.js +6 -0
  224. package/dist/esm/interaction-id-context/index.js +22 -0
  225. package/dist/esm/interaction-metrics/common/constants.js +2 -0
  226. package/dist/esm/interaction-metrics/index.js +773 -0
  227. package/dist/esm/interaction-metrics/post-interaction-log.js +184 -0
  228. package/dist/esm/interaction-metrics-init/index.js +77 -0
  229. package/dist/esm/label/UFOLabel.js +36 -0
  230. package/dist/esm/label/index.js +2 -0
  231. package/dist/esm/load-hold/UFOLoadHold.js +66 -0
  232. package/dist/esm/load-hold/index.js +2 -0
  233. package/dist/esm/placeholder/Placeholder.js +25 -0
  234. package/dist/esm/placeholder/index.js +2 -0
  235. package/dist/esm/placeholder/loosely-lazy/index.js +2 -0
  236. package/dist/esm/placeholder/loosely-lazy/lazy-suspense.js +70 -0
  237. package/dist/esm/placeholder/loosely-lazy/types.js +1 -0
  238. package/dist/esm/placeholder/loosely-lazy/wait-context.js +9 -0
  239. package/dist/esm/resource-timing/common/types.js +0 -0
  240. package/dist/esm/resource-timing/common/utils/config.js +62 -0
  241. package/dist/esm/resource-timing/common/utils/resource-timing-buffer.js +104 -0
  242. package/dist/esm/resource-timing/index.js +3 -0
  243. package/dist/esm/resource-timing/main.js +134 -0
  244. package/dist/esm/resource-timing/utils.js +4 -0
  245. package/dist/esm/round-number/index.js +5 -0
  246. package/dist/esm/route-name/index.js +6 -0
  247. package/dist/esm/route-name-context/index.js +5 -0
  248. package/dist/esm/segment/index.js +2 -0
  249. package/dist/esm/segment/segment-highlight.js +30 -0
  250. package/dist/esm/segment/segment.js +235 -0
  251. package/dist/esm/set-interaction-error/index.js +11 -0
  252. package/dist/esm/short-id/index.js +9 -0
  253. package/dist/esm/ssr/index.js +59 -0
  254. package/dist/esm/trace-interaction/index.js +41 -0
  255. package/dist/esm/trace-pageload/index.js +50 -0
  256. package/dist/esm/trace-press/index.js +27 -0
  257. package/dist/esm/trace-redirect/index.js +10 -0
  258. package/dist/esm/trace-transition/index.js +49 -0
  259. package/dist/esm/trace-transition/utils/generate-span-id/index.js +5 -0
  260. package/dist/esm/trace-transition/utils/set-interaction-active-trace/index.js +5 -0
  261. package/dist/esm/typing-performance-tracing/index.js +255 -0
  262. package/dist/esm/use-press-tracing/index.js +12 -0
  263. package/dist/esm/vc/index.js +9 -0
  264. package/dist/esm/vc/vc-observer/attachAbortListeners.js +34 -0
  265. package/dist/esm/vc/vc-observer/getViewport.js +20 -0
  266. package/dist/esm/vc/vc-observer/index.js +555 -0
  267. package/dist/esm/vc/vc-observer/media-wrapper/index.js +7 -0
  268. package/dist/esm/vc/vc-observer/media-wrapper/vc-utils.js +10 -0
  269. package/dist/esm/vc/vc-observer/observers/index.js +263 -0
  270. package/dist/esm/vc/vc-observer/observers/ssr-placeholders/index.js +176 -0
  271. package/dist/esm/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/bindAbortListeners.js +16 -0
  272. package/dist/esm/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/collectSSRPlaceholderDimensions.js +14 -0
  273. package/dist/esm/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/index.js +2 -0
  274. package/dist/esm/vc/vc-observer/observers/types.js +1 -0
  275. package/dist/types/additional-payload/index.d.ts +2 -0
  276. package/dist/types/additional-payload/utils/cache-hit-ratio/index.d.ts +8 -0
  277. package/dist/types/additional-payload/utils/lighthouse-metrics/cls/index.d.ts +2 -0
  278. package/dist/types/additional-payload/utils/lighthouse-metrics/cls/types.d.ts +3 -0
  279. package/dist/types/additional-payload/utils/lighthouse-metrics/const.d.ts +5 -0
  280. package/dist/types/additional-payload/utils/lighthouse-metrics/index.d.ts +7 -0
  281. package/dist/types/additional-payload/utils/lighthouse-metrics/tbt/index.d.ts +5 -0
  282. package/dist/types/additional-payload/utils/lighthouse-metrics/utils/buffer/index.d.ts +13 -0
  283. package/dist/types/additional-payload/utils/lighthouse-metrics/utils/observer/index.d.ts +2 -0
  284. package/dist/types/bundle-eval-timing/index.d.ts +16 -0
  285. package/dist/types/coinflip/index.d.ts +8 -0
  286. package/dist/types/common/common/types.d.ts +201 -0
  287. package/dist/types/common/constants.d.ts +1 -0
  288. package/dist/types/common/index.d.ts +5 -0
  289. package/dist/types/common/vc/types.d.ts +91 -0
  290. package/dist/types/config/index.d.ts +91 -0
  291. package/dist/types/create-payload/common/types.d.ts +4 -0
  292. package/dist/types/create-payload/common/utils/index.d.ts +3 -0
  293. package/dist/types/create-payload/index.d.ts +2969 -0
  294. package/dist/types/create-post-interaction-log-payload/index.d.ts +45 -0
  295. package/dist/types/custom-data/index.d.ts +5 -0
  296. package/dist/types/custom-data/types.d.ts +4 -0
  297. package/dist/types/custom-mark/index.d.ts +10 -0
  298. package/dist/types/custom-spans/index.d.ts +1 -0
  299. package/dist/types/custom-timings/index.d.ts +19 -0
  300. package/dist/types/experience-trace-id-context/index.d.ts +10 -0
  301. package/dist/types/experience-trace-id-context/types.d.ts +8 -0
  302. package/dist/types/experience-trace-id-context/utils/make-trace-http-request-headers/index.d.ts +4 -0
  303. package/dist/types/feature-flags-accessed/common/constants.d.ts +1 -0
  304. package/dist/types/feature-flags-accessed/common/types.d.ts +2 -0
  305. package/dist/types/feature-flags-accessed/common/utils/index.d.ts +3 -0
  306. package/dist/types/feature-flags-accessed/index.d.ts +14 -0
  307. package/dist/types/generate-id/index.d.ts +2 -0
  308. package/dist/types/global-error-handler/index.d.ts +3 -0
  309. package/dist/types/hidden-timing/index.d.ts +7 -0
  310. package/dist/types/initial-page-load-extra-timing/index.d.ts +9 -0
  311. package/dist/types/interaction-context/index.d.ts +33 -0
  312. package/dist/types/interaction-id-context/index.d.ts +9 -0
  313. package/dist/types/interaction-metrics/common/constants.d.ts +3 -0
  314. package/dist/types/interaction-metrics/index.d.ts +65 -1
  315. package/dist/types/interaction-metrics/post-interaction-log.d.ts +69 -0
  316. package/dist/types/interaction-metrics-init/index.d.ts +11 -0
  317. package/dist/types/label/UFOLabel.d.ts +13 -0
  318. package/dist/types/label/index.d.ts +2 -0
  319. package/dist/types/load-hold/UFOLoadHold.d.ts +53 -0
  320. package/dist/types/load-hold/index.d.ts +2 -0
  321. package/dist/types/placeholder/Placeholder.d.ts +13 -0
  322. package/dist/types/placeholder/index.d.ts +2 -0
  323. package/dist/types/placeholder/loosely-lazy/index.d.ts +3 -0
  324. package/dist/types/placeholder/loosely-lazy/lazy-suspense.d.ts +6 -0
  325. package/dist/types/placeholder/loosely-lazy/types.d.ts +20 -0
  326. package/dist/types/placeholder/loosely-lazy/wait-context.d.ts +3 -0
  327. package/dist/types/resource-timing/common/types.d.ts +41 -0
  328. package/dist/types/resource-timing/common/utils/config.d.ts +3 -0
  329. package/dist/types/resource-timing/common/utils/resource-timing-buffer.d.ts +11 -0
  330. package/dist/types/resource-timing/index.d.ts +4 -0
  331. package/dist/types/resource-timing/main.d.ts +2 -0
  332. package/dist/types/resource-timing/utils.d.ts +1 -0
  333. package/dist/types/round-number/index.d.ts +1 -0
  334. package/dist/types/route-name/index.d.ts +4 -0
  335. package/dist/types/route-name-context/index.d.ts +5 -0
  336. package/dist/types/segment/index.d.ts +2 -0
  337. package/dist/types/segment/segment-highlight.d.ts +6 -0
  338. package/dist/types/segment/segment.d.ts +8 -0
  339. package/dist/types/set-interaction-error/index.d.ts +4 -0
  340. package/dist/types/short-id/index.d.ts +1 -0
  341. package/dist/types/ssr/index.d.ts +21 -0
  342. package/dist/types/trace-interaction/index.d.ts +2 -0
  343. package/dist/types/trace-pageload/index.d.ts +2 -0
  344. package/dist/types/trace-press/index.d.ts +1 -0
  345. package/dist/types/trace-redirect/index.d.ts +1 -0
  346. package/dist/types/trace-transition/index.d.ts +2 -0
  347. package/dist/types/trace-transition/utils/generate-span-id/index.d.ts +1 -0
  348. package/dist/types/trace-transition/utils/set-interaction-active-trace/index.d.ts +1 -0
  349. package/dist/types/typing-performance-tracing/index.d.ts +2 -0
  350. package/dist/types/use-press-tracing/index.d.ts +1 -0
  351. package/dist/types/vc/index.d.ts +2 -0
  352. package/dist/types/vc/vc-observer/attachAbortListeners.d.ts +6 -0
  353. package/dist/types/vc/vc-observer/getViewport.d.ts +2 -0
  354. package/dist/types/vc/vc-observer/index.d.ts +98 -0
  355. package/dist/types/vc/vc-observer/media-wrapper/index.d.ts +7 -0
  356. package/dist/types/vc/vc-observer/media-wrapper/vc-utils.d.ts +1 -0
  357. package/dist/types/vc/vc-observer/observers/index.d.ts +39 -0
  358. package/dist/types/vc/vc-observer/observers/ssr-placeholders/index.d.ts +23 -0
  359. package/dist/types/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/bindAbortListeners.d.ts +1 -0
  360. package/dist/types/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/collectSSRPlaceholderDimensions.d.ts +1 -0
  361. package/dist/types/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/index.d.ts +2 -0
  362. package/dist/types/vc/vc-observer/observers/types.d.ts +11 -0
  363. package/dist/types-ts4.5/additional-payload/index.d.ts +2 -0
  364. package/dist/types-ts4.5/additional-payload/utils/cache-hit-ratio/index.d.ts +8 -0
  365. package/dist/types-ts4.5/additional-payload/utils/lighthouse-metrics/cls/index.d.ts +2 -0
  366. package/dist/types-ts4.5/additional-payload/utils/lighthouse-metrics/cls/types.d.ts +3 -0
  367. package/dist/types-ts4.5/additional-payload/utils/lighthouse-metrics/const.d.ts +5 -0
  368. package/dist/types-ts4.5/additional-payload/utils/lighthouse-metrics/index.d.ts +7 -0
  369. package/dist/types-ts4.5/additional-payload/utils/lighthouse-metrics/tbt/index.d.ts +5 -0
  370. package/dist/types-ts4.5/additional-payload/utils/lighthouse-metrics/utils/buffer/index.d.ts +13 -0
  371. package/dist/types-ts4.5/additional-payload/utils/lighthouse-metrics/utils/observer/index.d.ts +2 -0
  372. package/dist/types-ts4.5/bundle-eval-timing/index.d.ts +16 -0
  373. package/dist/types-ts4.5/coinflip/index.d.ts +8 -0
  374. package/dist/types-ts4.5/common/common/types.d.ts +201 -0
  375. package/dist/types-ts4.5/common/constants.d.ts +1 -0
  376. package/dist/types-ts4.5/common/index.d.ts +5 -0
  377. package/dist/types-ts4.5/common/vc/types.d.ts +91 -0
  378. package/dist/types-ts4.5/config/index.d.ts +95 -0
  379. package/dist/types-ts4.5/create-payload/common/types.d.ts +4 -0
  380. package/dist/types-ts4.5/create-payload/common/utils/index.d.ts +3 -0
  381. package/dist/types-ts4.5/create-payload/index.d.ts +2969 -0
  382. package/dist/types-ts4.5/create-post-interaction-log-payload/index.d.ts +45 -0
  383. package/dist/types-ts4.5/custom-data/index.d.ts +5 -0
  384. package/dist/types-ts4.5/custom-data/types.d.ts +4 -0
  385. package/dist/types-ts4.5/custom-mark/index.d.ts +10 -0
  386. package/dist/types-ts4.5/custom-spans/index.d.ts +1 -0
  387. package/dist/types-ts4.5/custom-timings/index.d.ts +19 -0
  388. package/dist/types-ts4.5/experience-trace-id-context/index.d.ts +10 -0
  389. package/dist/types-ts4.5/experience-trace-id-context/types.d.ts +8 -0
  390. package/dist/types-ts4.5/experience-trace-id-context/utils/make-trace-http-request-headers/index.d.ts +4 -0
  391. package/dist/types-ts4.5/feature-flags-accessed/common/constants.d.ts +1 -0
  392. package/dist/types-ts4.5/feature-flags-accessed/common/types.d.ts +2 -0
  393. package/dist/types-ts4.5/feature-flags-accessed/common/utils/index.d.ts +3 -0
  394. package/dist/types-ts4.5/feature-flags-accessed/index.d.ts +14 -0
  395. package/dist/types-ts4.5/generate-id/index.d.ts +2 -0
  396. package/dist/types-ts4.5/global-error-handler/index.d.ts +3 -0
  397. package/dist/types-ts4.5/hidden-timing/index.d.ts +7 -0
  398. package/dist/types-ts4.5/initial-page-load-extra-timing/index.d.ts +9 -0
  399. package/dist/types-ts4.5/interaction-context/index.d.ts +33 -0
  400. package/dist/types-ts4.5/interaction-id-context/index.d.ts +9 -0
  401. package/dist/types-ts4.5/interaction-metrics/common/constants.d.ts +3 -0
  402. package/dist/types-ts4.5/interaction-metrics/index.d.ts +65 -1
  403. package/dist/types-ts4.5/interaction-metrics/post-interaction-log.d.ts +69 -0
  404. package/dist/types-ts4.5/interaction-metrics-init/index.d.ts +11 -0
  405. package/dist/types-ts4.5/label/UFOLabel.d.ts +13 -0
  406. package/dist/types-ts4.5/label/index.d.ts +2 -0
  407. package/dist/types-ts4.5/load-hold/UFOLoadHold.d.ts +53 -0
  408. package/dist/types-ts4.5/load-hold/index.d.ts +2 -0
  409. package/dist/types-ts4.5/placeholder/Placeholder.d.ts +13 -0
  410. package/dist/types-ts4.5/placeholder/index.d.ts +2 -0
  411. package/dist/types-ts4.5/placeholder/loosely-lazy/index.d.ts +3 -0
  412. package/dist/types-ts4.5/placeholder/loosely-lazy/lazy-suspense.d.ts +6 -0
  413. package/dist/types-ts4.5/placeholder/loosely-lazy/types.d.ts +20 -0
  414. package/dist/types-ts4.5/placeholder/loosely-lazy/wait-context.d.ts +3 -0
  415. package/dist/types-ts4.5/resource-timing/common/types.d.ts +41 -0
  416. package/dist/types-ts4.5/resource-timing/common/utils/config.d.ts +3 -0
  417. package/dist/types-ts4.5/resource-timing/common/utils/resource-timing-buffer.d.ts +11 -0
  418. package/dist/types-ts4.5/resource-timing/index.d.ts +4 -0
  419. package/dist/types-ts4.5/resource-timing/main.d.ts +2 -0
  420. package/dist/types-ts4.5/resource-timing/utils.d.ts +1 -0
  421. package/dist/types-ts4.5/round-number/index.d.ts +1 -0
  422. package/dist/types-ts4.5/route-name/index.d.ts +4 -0
  423. package/dist/types-ts4.5/route-name-context/index.d.ts +5 -0
  424. package/dist/types-ts4.5/segment/index.d.ts +2 -0
  425. package/dist/types-ts4.5/segment/segment-highlight.d.ts +6 -0
  426. package/dist/types-ts4.5/segment/segment.d.ts +8 -0
  427. package/dist/types-ts4.5/set-interaction-error/index.d.ts +4 -0
  428. package/dist/types-ts4.5/short-id/index.d.ts +1 -0
  429. package/dist/types-ts4.5/ssr/index.d.ts +21 -0
  430. package/dist/types-ts4.5/trace-interaction/index.d.ts +2 -0
  431. package/dist/types-ts4.5/trace-pageload/index.d.ts +2 -0
  432. package/dist/types-ts4.5/trace-press/index.d.ts +1 -0
  433. package/dist/types-ts4.5/trace-redirect/index.d.ts +1 -0
  434. package/dist/types-ts4.5/trace-transition/index.d.ts +2 -0
  435. package/dist/types-ts4.5/trace-transition/utils/generate-span-id/index.d.ts +1 -0
  436. package/dist/types-ts4.5/trace-transition/utils/set-interaction-active-trace/index.d.ts +1 -0
  437. package/dist/types-ts4.5/typing-performance-tracing/index.d.ts +2 -0
  438. package/dist/types-ts4.5/use-press-tracing/index.d.ts +1 -0
  439. package/dist/types-ts4.5/vc/index.d.ts +2 -0
  440. package/dist/types-ts4.5/vc/vc-observer/attachAbortListeners.d.ts +6 -0
  441. package/dist/types-ts4.5/vc/vc-observer/getViewport.d.ts +2 -0
  442. package/dist/types-ts4.5/vc/vc-observer/index.d.ts +98 -0
  443. package/dist/types-ts4.5/vc/vc-observer/media-wrapper/index.d.ts +7 -0
  444. package/dist/types-ts4.5/vc/vc-observer/media-wrapper/vc-utils.d.ts +1 -0
  445. package/dist/types-ts4.5/vc/vc-observer/observers/index.d.ts +39 -0
  446. package/dist/types-ts4.5/vc/vc-observer/observers/ssr-placeholders/index.d.ts +23 -0
  447. package/dist/types-ts4.5/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/bindAbortListeners.d.ts +1 -0
  448. package/dist/types-ts4.5/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/collectSSRPlaceholderDimensions.d.ts +1 -0
  449. package/dist/types-ts4.5/vc/vc-observer/observers/ssr-placeholders/ssr-scripts/index.d.ts +2 -0
  450. package/dist/types-ts4.5/vc/vc-observer/observers/types.d.ts +11 -0
  451. package/experience-trace-id-context/package.json +15 -0
  452. package/feature-flags-accessed/package.json +15 -0
  453. package/generate-id/package.json +15 -0
  454. package/global-error-handler/package.json +15 -0
  455. package/hidden-timing/package.json +15 -0
  456. package/initial-page-load-extra-timing/package.json +15 -0
  457. package/interaction-context/package.json +15 -0
  458. package/interaction-id-context/package.json +15 -0
  459. package/interaction-metrics-init/package.json +15 -0
  460. package/label/package.json +15 -0
  461. package/load-hold/package.json +15 -0
  462. package/package.json +55 -3
  463. package/placeholder/package.json +15 -0
  464. package/resource-timing/package.json +15 -0
  465. package/round-number/package.json +15 -0
  466. package/route-name/package.json +15 -0
  467. package/route-name-context/package.json +15 -0
  468. package/segment/package.json +15 -0
  469. package/set-interaction-error/package.json +15 -0
  470. package/short-id/package.json +15 -0
  471. package/ssr/package.json +15 -0
  472. package/ssr-scripts/package.json +15 -0
  473. package/trace-interaction/package.json +15 -0
  474. package/trace-pageload/package.json +15 -0
  475. package/trace-press/package.json +15 -0
  476. package/trace-redirect/package.json +15 -0
  477. package/trace-transition/package.json +15 -0
  478. package/typing-performance-tracing/package.json +15 -0
  479. package/use-press-tracing/package.json +15 -0
  480. package/vc/media/package.json +15 -0
  481. package/vc/package.json +15 -0
  482. package/dist/types/common/types.d.ts +0 -17
  483. package/dist/types-ts4.5/common/types.d.ts +0 -17
  484. /package/dist/cjs/{common → additional-payload/utils/lighthouse-metrics/cls}/types.js +0 -0
  485. /package/dist/es2019/{common → additional-payload/utils/lighthouse-metrics/cls}/types.js +0 -0
  486. /package/dist/{esm/common/types.js → es2019/common/index.js} +0 -0
@@ -0,0 +1,130 @@
1
+ import { getConfig as getConfigUFO } from '../config';
2
+ import { roundEpsilon } from '../round-number';
3
+ import { getConfig } from './common/utils/config';
4
+ import { filterResourceTimings } from './common/utils/resource-timing-buffer';
5
+ const cacheableTypes = ['script', 'link'];
6
+ const resourceTypes = ['fetch', 'xmlhttprequest'];
7
+ const CACHE_NETWORK = 'network';
8
+ const CACHE_MEMORY = 'memory';
9
+ const CACHE_DISK = 'disk';
10
+
11
+ // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
12
+ const calculateTransferType = (type, duration, size) => {
13
+ if (!cacheableTypes.includes(type)) {
14
+ return CACHE_NETWORK;
15
+ }
16
+ if ((size === undefined || size === 0) && duration === 0) {
17
+ return CACHE_MEMORY;
18
+ }
19
+ if (size === 0 && duration > 0) {
20
+ return CACHE_DISK;
21
+ }
22
+ if (size === undefined) {
23
+ return null;
24
+ }
25
+ return CACHE_NETWORK;
26
+ };
27
+ const getWindowObject = () => typeof window !== 'undefined' && !!window ? window : undefined;
28
+ const hasAccessToResourceSize = (url, type, entry, hasTimingHeaders) => !cacheableTypes.includes(type) || url.includes('localhost') || !!getWindowObject() && url.includes(window.location.hostname) || hasTimingHeaders(url, entry);
29
+ const getReportedInitiatorTypes = xhrEnabled => {
30
+ const ufoConfig = getConfigUFO();
31
+ if (!(ufoConfig !== null && ufoConfig !== void 0 && ufoConfig.allowedResources)) {
32
+ if (xhrEnabled) {
33
+ return ['script', 'link', 'fetch', 'xmlhttprequest'];
34
+ }
35
+ return ['script', 'link', 'fetch'];
36
+ }
37
+ return ufoConfig.allowedResources;
38
+ };
39
+ const evaluateAccessToResourceTimings = (url, entry) => !(entry.responseStart === 0 && entry.startTime > entry.responseStart);
40
+
41
+ // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
42
+ const getSizeObject = size => size !== undefined ? {
43
+ size
44
+ } : null;
45
+ const getNetworkData = (item, eventStart, hasTimingHeaders = evaluateAccessToResourceTimings) => {
46
+ const {
47
+ name,
48
+ duration,
49
+ transferSize,
50
+ initiatorType,
51
+ responseStart,
52
+ requestStart,
53
+ serverTime,
54
+ networkTime,
55
+ encodedSize,
56
+ decodedSize
57
+ } = item;
58
+ const ttfb = roundEpsilon(responseStart - eventStart);
59
+ if (!hasAccessToResourceSize(name, initiatorType, item, hasTimingHeaders)) {
60
+ return {};
61
+ }
62
+ if (cacheableTypes.includes(initiatorType)) {
63
+ const transferType = calculateTransferType(initiatorType, duration, transferSize);
64
+ return {
65
+ ttfb,
66
+ transferType,
67
+ serverTime,
68
+ networkTime,
69
+ encodedSize,
70
+ decodedSize,
71
+ ...getSizeObject(transferSize)
72
+ };
73
+ }
74
+ return {
75
+ ttfb,
76
+ serverTime,
77
+ networkTime,
78
+ requestStart,
79
+ ...getSizeObject(transferSize)
80
+ };
81
+ };
82
+ export const getResourceTimings = (interactionStart, interactionEnd) => {
83
+ const resourceTiming = {};
84
+ if (interactionStart === null) {
85
+ return resourceTiming;
86
+ }
87
+ const resources = filterResourceTimings(interactionStart, interactionEnd);
88
+ if (!(resources !== null && resources !== void 0 && resources.length)) {
89
+ return resourceTiming;
90
+ }
91
+ const {
92
+ xhrFilter,
93
+ sanitiseEndpoints,
94
+ mapResources,
95
+ hasTimingHeaders
96
+ } = getConfig();
97
+ const reportedInitiatorTypes = getReportedInitiatorTypes(!!xhrFilter);
98
+ resources.forEach(item => {
99
+ if (!reportedInitiatorTypes.includes(item.initiatorType)) {
100
+ return;
101
+ }
102
+ const {
103
+ name,
104
+ startTime,
105
+ duration,
106
+ workerStart,
107
+ fetchStart,
108
+ initiatorType
109
+ } = item;
110
+ if (!name) {
111
+ return;
112
+ }
113
+ if (initiatorType === 'xmlhttprequest' && (xhrFilter === undefined || xhrFilter(name) === false)) {
114
+ return;
115
+ }
116
+ const url = resourceTypes.includes(initiatorType) ? sanitiseEndpoints(name) : mapResources(name);
117
+ if (!url || resourceTiming[url]) {
118
+ return;
119
+ }
120
+ resourceTiming[url] = {
121
+ startTime: roundEpsilon(startTime - interactionStart),
122
+ duration: roundEpsilon(duration),
123
+ workerStart: Math.max(roundEpsilon(workerStart - interactionStart), 0),
124
+ fetchStart: Math.max(roundEpsilon(fetchStart - interactionStart), 0),
125
+ type: initiatorType,
126
+ ...getNetworkData(item, interactionStart, hasTimingHeaders)
127
+ };
128
+ });
129
+ return resourceTiming;
130
+ };
@@ -0,0 +1,4 @@
1
+ import { resourceTimingBuffer } from './common/utils/resource-timing-buffer';
2
+ export function startResourceTimingBuffer() {
3
+ resourceTimingBuffer.start();
4
+ }
@@ -0,0 +1,4 @@
1
+ export const roundEpsilon = (num, places = 3) => {
2
+ const factor = Math.pow(10, places);
3
+ return Math.round((num + Number.EPSILON) * factor) / factor;
4
+ };
@@ -0,0 +1,6 @@
1
+ export default function getUFORouteName(route) {
2
+ if (route.ufoName != null) {
3
+ return route.ufoName;
4
+ }
5
+ return route.name;
6
+ }
@@ -0,0 +1,5 @@
1
+ // The UFORouteName object is a global singleton
2
+ const UFORouteName = {
3
+ current: null
4
+ };
5
+ export default UFORouteName;
@@ -0,0 +1,2 @@
1
+ import UFOSegment from './segment';
2
+ export default UFOSegment;
@@ -0,0 +1,27 @@
1
+ import React, { useEffect, useState } from 'react';
2
+ export function SegmentHighlight({
3
+ segmentName
4
+ }) {
5
+ const [segmentHighlight, setSegmentHighlight] = useState(false);
6
+ useEffect(() => {
7
+ try {
8
+ const shouldHighlightSegments = sessionStorage.getItem('segmentsHighlight') === 'true';
9
+ setSegmentHighlight(shouldHighlightSegments);
10
+ } catch (err) {
11
+ /* do nothing */
12
+ }
13
+ }, []);
14
+ if (segmentHighlight) {
15
+ return (
16
+ /*#__PURE__*/
17
+ // eslint-disable-next-line @atlaskit/ui-styling-standard/enforce-style-prop
18
+ React.createElement("span", {
19
+ "data-segment-name": segmentName,
20
+ style: {
21
+ display: 'none'
22
+ }
23
+ })
24
+ );
25
+ }
26
+ return null;
27
+ }
@@ -0,0 +1,218 @@
1
+ import React, { lazy, Profiler, Suspense, useCallback, useContext, useEffect, useMemo } from 'react';
2
+ import { unstable_NormalPriority as NormalPriority, unstable_scheduleCallback as scheduleCallback } from 'scheduler';
3
+ import { v4 as createUUID } from 'uuid';
4
+ import coinflip from '../coinflip';
5
+ import { getConfig, getInteractionRate } from '../config';
6
+ import { getActiveTrace, setInteractionActiveTrace } from '../experience-trace-id-context';
7
+ import UFOInteractionContext from '../interaction-context';
8
+ import UFOInteractionIDContext from '../interaction-id-context';
9
+ import { abortByNewInteraction, addApdex, addCustomData, addCustomTiming, addHold, addHoldByID, addMark, addNewInteraction, addProfilerTimings, addRequestInfo, addSegment, addSpan, removeHoldByID, removeSegment, tryComplete } from '../interaction-metrics';
10
+ import UFORouteName from '../route-name-context';
11
+ import generateId from '../short-id';
12
+ let tryCompleteHandle;
13
+ const AsyncSegmentHighlight = /*#__PURE__*/lazy(() => import( /* webpackChunkName: "@atlaskit-internal_ufo-segment-highlight" */'./segment-highlight').then(module => ({
14
+ default: module.SegmentHighlight
15
+ })));
16
+
17
+ /** A portion of the page we apply measurement to */
18
+ export default function UFOSegment({
19
+ name: segmentName,
20
+ children
21
+ }) {
22
+ var _getConfig;
23
+ const parentContext = useContext(UFOInteractionContext);
24
+ const segmentId = useMemo(() => generateId(), []);
25
+ const labelStack = useMemo(() => parentContext !== null && parentContext !== void 0 && parentContext.labelStack ? [...parentContext.labelStack, {
26
+ name: segmentName,
27
+ segmentId
28
+ }] : [{
29
+ name: segmentName,
30
+ segmentId
31
+ }], [parentContext, segmentName, segmentId]);
32
+ const interactionId = useContext(UFOInteractionIDContext);
33
+ const interactionContext = useMemo(() => {
34
+ addSegment(labelStack);
35
+ let lastCompleteEndTime = 0;
36
+ function complete(endTime = performance.now()) {
37
+ if (interactionId.current) {
38
+ if (parentContext) {
39
+ parentContext.complete();
40
+ } else {
41
+ const capturedInteractionId = interactionId.current;
42
+ if (endTime > lastCompleteEndTime) {
43
+ lastCompleteEndTime = endTime;
44
+ }
45
+ if (tryCompleteHandle) {
46
+ var _cancelAnimationFrame;
47
+ (_cancelAnimationFrame = cancelAnimationFrame) === null || _cancelAnimationFrame === void 0 ? void 0 : _cancelAnimationFrame(tryCompleteHandle);
48
+ }
49
+ scheduleCallback(NormalPriority, () => {
50
+ if (capturedInteractionId === interactionId.current) {
51
+ var _document;
52
+ const isPageVisible = ((_document = document) === null || _document === void 0 ? void 0 : _document.visibilityState) === 'visible';
53
+ const canDoRAF = typeof requestAnimationFrame !== 'undefined';
54
+ if (isPageVisible && canDoRAF) {
55
+ tryCompleteHandle = requestAnimationFrame(() => {
56
+ tryCompleteHandle = requestAnimationFrame(() => {
57
+ if (capturedInteractionId === interactionId.current) {
58
+ tryComplete(interactionId.current, lastCompleteEndTime);
59
+ }
60
+ });
61
+ });
62
+ } else {
63
+ tryComplete(interactionId.current, lastCompleteEndTime);
64
+ }
65
+ }
66
+ });
67
+ }
68
+ }
69
+ }
70
+ function _internalHold(labelStack, name
71
+ // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
72
+ ) {
73
+ if (interactionId.current != null) {
74
+ if (parentContext) {
75
+ return parentContext._internalHold(labelStack, name);
76
+ } else {
77
+ const capturedInteractionId = interactionId.current;
78
+ const disposeHold = addHold(interactionId.current, labelStack, name);
79
+ return () => {
80
+ if (capturedInteractionId === interactionId.current) {
81
+ disposeHold();
82
+ }
83
+ };
84
+ }
85
+ }
86
+ }
87
+ function _internalHoldByID(labelStack, id, name, remove
88
+ // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
89
+ ) {
90
+ if (interactionId.current != null) {
91
+ if (parentContext) {
92
+ parentContext._internalHoldByID(labelStack, name, id, remove);
93
+ return;
94
+ }
95
+ if (!remove) {
96
+ addHoldByID(interactionId.current, labelStack, name, id);
97
+ } else {
98
+ removeHoldByID(interactionId.current, id);
99
+ }
100
+ }
101
+ }
102
+ if (parentContext) {
103
+ return {
104
+ ...parentContext,
105
+ labelStack,
106
+ complete
107
+ };
108
+ }
109
+ return {
110
+ labelStack,
111
+ hold(name = 'unknown'
112
+ // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
113
+ ) {
114
+ return this._internalHold(this.labelStack, name);
115
+ },
116
+ addHoldByID(labelStack, id, name = 'unknown') {
117
+ this._internalHoldByID(labelStack, id, name, false);
118
+ },
119
+ removeHoldByID(labelStack, id, name = 'unknown') {
120
+ this._internalHoldByID(labelStack, id, name, true);
121
+ },
122
+ tracePress(name = 'unknown', timestamp) {
123
+ if (interactionId.current != null) {
124
+ abortByNewInteraction(interactionId.current, name);
125
+ }
126
+ const rate = getInteractionRate(name, 'press');
127
+ if (coinflip(rate)) {
128
+ const startTimestamp = timestamp !== null && timestamp !== void 0 ? timestamp : performance.now();
129
+ const newId = createUUID();
130
+ interactionId.current = newId;
131
+ // covered experiences with tracing instrumentation:
132
+ // inline-result.global-issue.create-modal.submit
133
+ // inline-result.global-issue.create-modal-subsequent
134
+ setInteractionActiveTrace(newId, 'press');
135
+ addNewInteraction(newId, name, 'press', startTimestamp, rate, this.labelStack, UFORouteName.current, getActiveTrace());
136
+ }
137
+ },
138
+ retainQuery(info) {
139
+ if (interactionId.current != null) {
140
+ addRequestInfo(interactionId.current, this.labelStack, info);
141
+ }
142
+ },
143
+ addPreload(moduleId, timestamp) {
144
+ if (interactionId.current != null) {
145
+ addMark(interactionId.current, 'bundle_preload', moduleId, this.labelStack, timestamp);
146
+ }
147
+ },
148
+ addLoad(identifier, start, end) {
149
+ if (interactionId.current != null) {
150
+ const {
151
+ labelStack = []
152
+ } = this;
153
+ addSpan(interactionId.current, 'bundle_load', identifier, labelStack, start, end);
154
+ }
155
+ },
156
+ addMark(name, timestamp
157
+ // eslint-disable-next-line @typescript-eslint/no-invalid-void-type
158
+ ) {
159
+ if (interactionId.current != null) {
160
+ const time = timestamp !== null && timestamp !== void 0 ? timestamp : performance.now();
161
+ addMark(interactionId.current, 'custom', name, this.labelStack, time);
162
+ }
163
+ },
164
+ addCustomData(customData) {
165
+ if (interactionId.current != null) {
166
+ addCustomData(interactionId.current, this.labelStack, customData);
167
+ }
168
+ },
169
+ addCustomTimings(customTimings) {
170
+ if (interactionId.current != null) {
171
+ addCustomTiming(interactionId.current, this.labelStack, customTimings);
172
+ }
173
+ },
174
+ addApdex(apdexInfo) {
175
+ if (interactionId.current != null) {
176
+ const {
177
+ key,
178
+ stopTime,
179
+ startTime
180
+ } = apdexInfo;
181
+ addApdex(interactionId.current, {
182
+ key,
183
+ stopTime,
184
+ startTime,
185
+ labelStack: this.labelStack
186
+ });
187
+ }
188
+ },
189
+ onRender(phase, actualDuration, baseDuration, startTime, commitTime) {
190
+ if (interactionId.current !== null) {
191
+ addProfilerTimings(interactionId.current, this.labelStack, phase, actualDuration, baseDuration, startTime, commitTime);
192
+ this.complete(commitTime);
193
+ }
194
+ },
195
+ _internalHold,
196
+ _internalHoldByID,
197
+ complete
198
+ };
199
+ }, [parentContext, labelStack, interactionId]);
200
+ const onRender = useCallback((_id, phase, actualDuration, baseDuration, startTime, commitTime) => {
201
+ interactionContext.onRender(phase, actualDuration, baseDuration, startTime, commitTime);
202
+ }, [interactionContext]);
203
+ useEffect(() => () => {
204
+ removeSegment(labelStack);
205
+ }, [interactionId, parentContext, interactionContext, labelStack]);
206
+ const reactProfilerId = useMemo(() => labelStack.map(l => l.name).join('/'), [labelStack]);
207
+ const enableSegmentHighlighting = (_getConfig = getConfig()) === null || _getConfig === void 0 ? void 0 : _getConfig.enableSegmentHighlighting;
208
+ return /*#__PURE__*/React.createElement(UFOInteractionContext.Provider, {
209
+ value: interactionContext
210
+ }, /*#__PURE__*/React.createElement(Profiler, {
211
+ id: reactProfilerId,
212
+ onRender: onRender
213
+ }, children, enableSegmentHighlighting && /*#__PURE__*/React.createElement(Suspense, {
214
+ fallback: null
215
+ }, /*#__PURE__*/React.createElement(AsyncSegmentHighlight, {
216
+ segmentName: segmentName
217
+ }))));
218
+ }
@@ -0,0 +1,11 @@
1
+ import { addError, getActiveInteraction } from '../interaction-metrics';
2
+ export function setInteractionError(interactionName, error) {
3
+ const interaction = getActiveInteraction();
4
+ if (!interaction) {
5
+ return;
6
+ }
7
+ if (interaction.ufoName !== interactionName) {
8
+ return;
9
+ }
10
+ addError(interaction.id, error.name, null, 'Manual interaction error', error.errorMessage, undefined, true);
11
+ }
@@ -0,0 +1,8 @@
1
+ export default function generateId(length = 7) {
2
+ const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
3
+ let result = '';
4
+ for (let i = 0; i < length; i++) {
5
+ result += characters.charAt(Math.floor(Math.random() * characters.length));
6
+ }
7
+ return result;
8
+ }
@@ -0,0 +1,54 @@
1
+ const NESTED_METRIC_SEPARATOR = '/';
2
+ const filterEntry = entry => !(!entry || typeof entry !== 'object' || entry.startTime < 0 || entry.duration < 0);
3
+ const mapEntry = entry => ({
4
+ startTime: Math.round(entry.startTime),
5
+ duration: Math.round(entry.duration)
6
+ });
7
+ const SSR_PREFIX = 'ssr';
8
+ const mapKey = key => {
9
+ if (key === 'total') {
10
+ return SSR_PREFIX;
11
+ }
12
+ return `${SSR_PREFIX}${NESTED_METRIC_SEPARATOR}${key}`;
13
+ };
14
+ let config;
15
+ export function configure(ssrConfig) {
16
+ config = ssrConfig;
17
+ }
18
+ export function getSSRTimings() {
19
+ var _config;
20
+ if (!((_config = config) !== null && _config !== void 0 && _config.getTimings)) {
21
+ return {};
22
+ }
23
+ const timings = config.getTimings();
24
+ if (!timings) {
25
+ return {};
26
+ }
27
+ const ssrTimings = Object.entries(timings).reduce((acc, entry) => {
28
+ if (filterEntry(entry[1])) {
29
+ acc[mapKey(entry[0])] = mapEntry(entry[1]);
30
+ }
31
+ return acc;
32
+ }, {});
33
+ return ssrTimings;
34
+ }
35
+ export function getSSRSuccess() {
36
+ var _config2;
37
+ return !!((_config2 = config) !== null && _config2 !== void 0 && _config2.getDoneMark());
38
+ }
39
+ export function getSSRDoneTime() {
40
+ var _config$getDoneMark, _config3;
41
+ return (_config$getDoneMark = (_config3 = config) === null || _config3 === void 0 ? void 0 : _config3.getDoneMark()) !== null && _config$getDoneMark !== void 0 ? _config$getDoneMark : undefined;
42
+ }
43
+ export function getSSRFeatureFlags() {
44
+ var _config4;
45
+ if (!((_config4 = config) !== null && _config4 !== void 0 && _config4.getFeatureFlags)) {
46
+ return undefined;
47
+ }
48
+ try {
49
+ var _config$getFeatureFla;
50
+ return (_config$getFeatureFla = config.getFeatureFlags()) !== null && _config$getFeatureFla !== void 0 ? _config$getFeatureFla : undefined;
51
+ // eslint-disable-next-line no-empty
52
+ } catch (e) {}
53
+ return undefined;
54
+ }
@@ -0,0 +1,41 @@
1
+ import { v4 as createUUID } from 'uuid';
2
+ import coinflip from '../coinflip';
3
+ import { getDoNotAbortActivePressInteraction, getInteractionRate } from '../config';
4
+ import { DefaultInteractionID } from '../interaction-id-context';
5
+ import { abortAll, addNewInteraction, getActiveInteraction } from '../interaction-metrics';
6
+ import UFORouteName from '../route-name-context';
7
+ function mapToInteractionType(eventType) {
8
+ if (eventType === 'click' || eventType === 'dblclick' || eventType === 'mousedown') {
9
+ return 'press';
10
+ }
11
+ if (eventType === 'mouseenter' || eventType === 'mouseover') {
12
+ return 'hover';
13
+ }
14
+ return undefined;
15
+ }
16
+ export default function traceUFOInteraction(name, event) {
17
+ if (!event || !event.isTrusted) {
18
+ return;
19
+ }
20
+ const interactionType = mapToInteractionType(event.type);
21
+ if (!interactionType) {
22
+ // when interactionType is falsy we do not yet support this type of event. should we blow up with throwing error instead?
23
+ return;
24
+ }
25
+ const rate = getInteractionRate(name, interactionType);
26
+ const pressInteractionsList = getDoNotAbortActivePressInteraction();
27
+ if (pressInteractionsList !== null && pressInteractionsList !== void 0 && pressInteractionsList.includes(name)) {
28
+ const interaction = getActiveInteraction();
29
+ if ((interaction === null || interaction === void 0 ? void 0 : interaction.ufoName) !== 'unknown' && (interaction === null || interaction === void 0 ? void 0 : interaction.type) === 'press') {
30
+ return;
31
+ }
32
+ }
33
+ if (coinflip(rate)) {
34
+ var _event$timeStamp;
35
+ abortAll('new_interaction', name);
36
+ const startTimestamp = (_event$timeStamp = event.timeStamp) !== null && _event$timeStamp !== void 0 ? _event$timeStamp : performance.now();
37
+ const newId = createUUID();
38
+ DefaultInteractionID.current = newId;
39
+ addNewInteraction(newId, name, 'press', startTimestamp, rate, [], UFORouteName.current);
40
+ }
41
+ }
@@ -0,0 +1,48 @@
1
+ import { v4 as createUUID } from 'uuid';
2
+ import coinflip from '../coinflip';
3
+ import { getInteractionRate } from '../config';
4
+ import { getActiveTrace } from '../experience-trace-id-context';
5
+ import { DefaultInteractionID } from '../interaction-id-context';
6
+ import { abort, addHoldByID, addNewInteraction, getActiveInteraction, removeHoldByID, updatePageLoadInteractionName } from '../interaction-metrics';
7
+ import UFORouteName from '../route-name-context';
8
+ const AWAITING_PAGELOAD_NAME = 'awaiting_pageload_name';
9
+ export default function traceUFOPageLoad(ufoName, routeName = ufoName) {
10
+ const activeInteraction = getActiveInteraction();
11
+ if (activeInteraction && !ufoName) {
12
+ return;
13
+ }
14
+ UFORouteName.current = routeName || null;
15
+ const rate = ufoName ? getInteractionRate(ufoName, 'page_load') : 1;
16
+ const enabledBySamplingRate = coinflip(rate);
17
+ if (enabledBySamplingRate && !activeInteraction) {
18
+ const newId = createUUID();
19
+ DefaultInteractionID.current = newId;
20
+ addNewInteraction(newId, ufoName || '', 'page_load', 0, rate, null, routeName, getActiveTrace());
21
+ if (!ufoName) {
22
+ // if no name is provided we add a hold to the interaction, it is removed if the name is provided while the interaction is holding
23
+ addHoldByID(newId, [], AWAITING_PAGELOAD_NAME, AWAITING_PAGELOAD_NAME, true);
24
+ }
25
+ } else if (!enabledBySamplingRate && activeInteraction && activeInteraction.type === 'page_load') {
26
+ // if there is an active interaction it will be aborted without initialising a new one because the coinflip returned false
27
+ abort(activeInteraction.id, 'excluded_by_sampling');
28
+ } else if (ufoName && activeInteraction && !activeInteraction.ufoName && activeInteraction.type === 'page_load') {
29
+ updatePageLoadInteractionName(ufoName, routeName);
30
+ removeHoldByID(activeInteraction.id, AWAITING_PAGELOAD_NAME);
31
+ }
32
+ }
33
+ export function updatePageloadName(ufoName, routeName = ufoName) {
34
+ const interaction = getActiveInteraction();
35
+ if (!interaction || interaction.type !== 'page_load' && interaction.type !== 'transition') {
36
+ return;
37
+ }
38
+ if (ufoName) {
39
+ const rate = getInteractionRate(ufoName, 'page_load');
40
+ updatePageLoadInteractionName(ufoName, routeName);
41
+ if (coinflip(rate)) {
42
+ UFORouteName.current = ufoName;
43
+ } else {
44
+ abort(interaction.id, 'excluded_by_sampling');
45
+ }
46
+ }
47
+ removeHoldByID(interaction.id, AWAITING_PAGELOAD_NAME);
48
+ }
@@ -0,0 +1,27 @@
1
+ import { v4 as createUUID } from 'uuid';
2
+ import coinflip from '../coinflip';
3
+ import { getDoNotAbortActivePressInteraction, getInteractionRate } from '../config';
4
+ import { getActiveTrace, setInteractionActiveTrace } from '../experience-trace-id-context';
5
+ import { DefaultInteractionID } from '../interaction-id-context';
6
+ import { abortAll, addNewInteraction, getActiveInteraction } from '../interaction-metrics';
7
+ import UFORouteName from '../route-name-context';
8
+ export default function traceUFOPress(name, timestamp) {
9
+ const rate = getInteractionRate(name, 'press');
10
+ const pressInteractionsList = getDoNotAbortActivePressInteraction();
11
+ if (pressInteractionsList !== null && pressInteractionsList !== void 0 && pressInteractionsList.includes(name)) {
12
+ const interaction = getActiveInteraction();
13
+ if ((interaction === null || interaction === void 0 ? void 0 : interaction.ufoName) !== 'unknown' && (interaction === null || interaction === void 0 ? void 0 : interaction.type) === 'press') {
14
+ return;
15
+ }
16
+ }
17
+ if (coinflip(rate)) {
18
+ abortAll('new_interaction', name);
19
+ const startTimestamp = timestamp !== null && timestamp !== void 0 ? timestamp : performance.now();
20
+ const newId = createUUID();
21
+ // covered experiences with tracing instrumentation:
22
+ // inline-result.inline-card-create-submit
23
+ setInteractionActiveTrace(newId, 'press');
24
+ DefaultInteractionID.current = newId;
25
+ addNewInteraction(newId, name, 'press', startTimestamp, rate, [], UFORouteName.current, getActiveTrace());
26
+ }
27
+ }
@@ -0,0 +1,10 @@
1
+ import { DefaultInteractionID } from '../interaction-id-context';
2
+ import { addRedirect } from '../interaction-metrics';
3
+ import UFORouteName from '../route-name-context';
4
+ export default function traceUFORedirect(fromUfoName, nextUfoName, nextRouteName, time) {
5
+ UFORouteName.current = nextUfoName;
6
+ const interactionId = DefaultInteractionID.current;
7
+ if (interactionId) {
8
+ addRedirect(interactionId, fromUfoName, nextUfoName, nextRouteName, time);
9
+ }
10
+ }
@@ -0,0 +1,48 @@
1
+ import { useContext, useEffect } from 'react';
2
+ import { v4 as createUUID } from 'uuid';
3
+ import coinflip from '../coinflip';
4
+ import { getDoNotAbortActivePressInteractionOnTransition, getInteractionRate } from '../config';
5
+ import { getActiveTrace } from '../experience-trace-id-context';
6
+ import UFOInteractionIDContext, { DefaultInteractionID } from '../interaction-id-context';
7
+ import { abortAll, addNewInteraction, addOnCancelCallback, getActiveInteraction, tryComplete } from '../interaction-metrics';
8
+ import UFORouteName from '../route-name-context';
9
+ import { setInteractionActiveTrace } from './utils/set-interaction-active-trace';
10
+ export default function traceUFOTransition(ufoName, routeName = ufoName) {
11
+ const pressInteractionsList = getDoNotAbortActivePressInteractionOnTransition();
12
+ const interaction = getActiveInteraction();
13
+ if (pressInteractionsList && interaction) {
14
+ if (pressInteractionsList.includes(interaction.ufoName)) {
15
+ return;
16
+ }
17
+ }
18
+ abortAll('transition', ufoName !== null && ufoName !== void 0 ? ufoName : undefined);
19
+ if (ufoName) {
20
+ UFORouteName.current = ufoName;
21
+ const rate = getInteractionRate(ufoName, 'transition');
22
+ if (coinflip(rate)) {
23
+ const newId = createUUID();
24
+ setInteractionActiveTrace(newId);
25
+ DefaultInteractionID.current = newId;
26
+ addNewInteraction(newId, ufoName, 'transition', performance.now(), rate, null, routeName, getActiveTrace());
27
+ }
28
+ }
29
+ }
30
+ export function useUFOTransitionCompleter() {
31
+ const interactionId = useContext(UFOInteractionIDContext);
32
+ const capturedInteractionId = interactionId.current;
33
+ useEffect(() => {
34
+ // If we have a current interaction set...
35
+ if (capturedInteractionId != null) {
36
+ let cancel = requestAnimationFrame(() => {
37
+ cancel = requestAnimationFrame(() => {
38
+ if (capturedInteractionId === interactionId.current) {
39
+ tryComplete(capturedInteractionId);
40
+ }
41
+ });
42
+ });
43
+ addOnCancelCallback(capturedInteractionId, () => {
44
+ cancelAnimationFrame(cancel);
45
+ });
46
+ }
47
+ }, [capturedInteractionId, interactionId]);
48
+ }
@@ -0,0 +1 @@
1
+ export const generateSpanId = () => Array.from(new Array(16), () => Math.floor(Math.random() * 16).toString(16)).join('');
@@ -0,0 +1,5 @@
1
+ import { setActiveTrace } from '../../../experience-trace-id-context';
2
+ import { generateSpanId } from '../generate-span-id';
3
+ export const setInteractionActiveTrace = newId => {
4
+ setActiveTrace(newId.replace(/-/g, ''), generateSpanId(), 'transition');
5
+ };