@atlaskit/react-ufo 1.1.0 → 2.0.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 (486) hide show
  1. package/CHANGELOG.md +24 -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,555 @@
1
+ import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
2
+ import _createClass from "@babel/runtime/helpers/createClass";
3
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
4
+ import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
5
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
6
+ var _excluded = ["__debug__element"];
7
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
8
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
9
+ import { attachAbortListeners } from './attachAbortListeners';
10
+ import { getViewportHeight, getViewportWidth } from './getViewport';
11
+ import { Observers } from './observers';
12
+ var abortReason = {
13
+ scroll: 'scroll',
14
+ keypress: 'keypress',
15
+ resize: 'resize',
16
+ error: 'error'
17
+ };
18
+ var UNUSED_SECTOR = 0;
19
+ function filterComponentsLog(log) {
20
+ return Object.fromEntries(Object.entries(log).map(function (_ref) {
21
+ var _ref2 = _slicedToArray(_ref, 2),
22
+ timestamp = _ref2[0],
23
+ entries = _ref2[1];
24
+ return [Number(timestamp), entries.map(function (entry) {
25
+ var __debug__element = entry.__debug__element,
26
+ rest = _objectWithoutProperties(entry, _excluded);
27
+ return rest;
28
+ })];
29
+ }));
30
+ }
31
+ export var VCObserver = /*#__PURE__*/function () {
32
+ function VCObserver(options) {
33
+ var _this = this;
34
+ _classCallCheck(this, VCObserver);
35
+ /* abort logic */
36
+ _defineProperty(this, "abortReason", {
37
+ reason: null,
38
+ info: '',
39
+ timestamp: -1,
40
+ blocking: false
41
+ });
42
+ _defineProperty(this, "outOfBoundaryInfo", '');
43
+ _defineProperty(this, "viewport", {
44
+ w: 0,
45
+ h: 0
46
+ });
47
+ /* heatmap */
48
+ _defineProperty(this, "arraySize", 0);
49
+ _defineProperty(this, "componentsLog", {});
50
+ _defineProperty(this, "vcRatios", {});
51
+ _defineProperty(this, "active", false);
52
+ _defineProperty(this, "totalTime", 0);
53
+ _defineProperty(this, "startTime", 0);
54
+ _defineProperty(this, "_startMeasureTimestamp", -1);
55
+ _defineProperty(this, "ssr", {
56
+ reactRendered: -1
57
+ });
58
+ _defineProperty(this, "unbind", []);
59
+ _defineProperty(this, "getAbortReasonInfo", function () {
60
+ if (_this.abortReason.reason === null) {
61
+ return null;
62
+ }
63
+ var info = _this.abortReason.info !== '' ? " ".concat(_this.abortReason.info) : '';
64
+ return "".concat(_this.abortReason.reason).concat(info);
65
+ });
66
+ _defineProperty(this, "getVCRawData", function () {
67
+ _this.measureStart();
68
+ if (!_this.active) {
69
+ _this.measureStop();
70
+ return null;
71
+ }
72
+ _this.stop();
73
+ var abortReasonInfo = _this.getAbortReasonInfo();
74
+ _this.measureStop();
75
+ return {
76
+ abortReasonInfo: abortReasonInfo,
77
+ abortReason: _objectSpread({}, _this.abortReason),
78
+ heatmap: _this.ssrInclusiveHeatmap,
79
+ oldHeatmap: _this.heatmap,
80
+ outOfBoundaryInfo: _this.outOfBoundaryInfo,
81
+ totalTime: Math.round(_this.totalTime + _this.observers.getTotalTime()),
82
+ componentsLog: _objectSpread({}, _this.componentsLog),
83
+ viewport: _objectSpread({}, _this.viewport),
84
+ oldDomUpdatesEnabled: _this.oldDomUpdatesEnabled,
85
+ devToolsEnabled: _this.devToolsEnabled,
86
+ ratios: _this.vcRatios
87
+ };
88
+ });
89
+ _defineProperty(this, "getVCResult", function (_ref3) {
90
+ var _objectSpread2;
91
+ var start = _ref3.start,
92
+ stop = _ref3.stop,
93
+ tti = _ref3.tti,
94
+ prefix = _ref3.prefix,
95
+ ssr = _ref3.ssr,
96
+ vc = _ref3.vc;
97
+ var startTime = performance.now();
98
+ // add local measurement
99
+ var fullPrefix = prefix !== undefined && prefix !== '' ? "".concat(prefix, ":") : '';
100
+ var rawData = vc !== undefined ? vc : _this.getVCRawData();
101
+ if (rawData === null) {
102
+ return {};
103
+ }
104
+ var abortReason = rawData.abortReason,
105
+ abortReasonInfo = rawData.abortReasonInfo,
106
+ heatmap = rawData.heatmap,
107
+ oldHeatmap = rawData.oldHeatmap,
108
+ outOfBoundaryInfo = rawData.outOfBoundaryInfo,
109
+ totalTime = rawData.totalTime,
110
+ componentsLog = rawData.componentsLog,
111
+ viewport = rawData.viewport,
112
+ oldDomUpdatesEnabled = rawData.oldDomUpdatesEnabled,
113
+ devToolsEnabled = rawData.devToolsEnabled,
114
+ ratios = rawData.ratios;
115
+ if (abortReasonInfo !== null && abortReason.blocking) {
116
+ var _ref4;
117
+ // exposing data to devtools
118
+ try {
119
+ if (devToolsEnabled && !_this.isPostInteraction) {
120
+ window.__vcNotAvailableReason = abortReasonInfo;
121
+ }
122
+ } catch (e) {}
123
+ return _ref4 = {}, _defineProperty(_ref4, "".concat(fullPrefix, "vc:state"), false), _defineProperty(_ref4, "".concat(fullPrefix, "vc:abort:reason"), abortReasonInfo), _defineProperty(_ref4, "".concat(fullPrefix, "vc:abort:timestamp"), abortReason.timestamp), _ref4;
124
+ }
125
+ var _VCObserver$calculate = VCObserver.calculateVC({
126
+ heatmap: heatmap,
127
+ ssr: ssr,
128
+ componentsLog: _objectSpread({}, componentsLog),
129
+ viewport: viewport
130
+ }),
131
+ VC = _VCObserver$calculate.VC,
132
+ VCBox = _VCObserver$calculate.VCBox,
133
+ VCEntries = _VCObserver$calculate.VCEntries,
134
+ totalPainted = _VCObserver$calculate.totalPainted;
135
+ try {
136
+ if (!_this.isPostInteraction) {
137
+ VCObserver.VCParts.forEach(function (key) {
138
+ var duration = VC[key];
139
+ if (duration !== null && duration !== undefined) {
140
+ performance.measure("VC".concat(key), {
141
+ start: start,
142
+ duration: duration
143
+ });
144
+ }
145
+ });
146
+ }
147
+ } catch (e) {
148
+ /* empty */
149
+ }
150
+ var ssrVC = VCObserver.calculateVC({
151
+ heatmap: oldHeatmap,
152
+ ssr: ssr,
153
+ componentsLog: _objectSpread({}, componentsLog),
154
+ viewport: viewport
155
+ });
156
+ var outOfBoundary = outOfBoundaryInfo ? _defineProperty({}, "".concat(fullPrefix, "vc:oob"), outOfBoundaryInfo) : {};
157
+ var oldDomUpdates = oldDomUpdatesEnabled ? _defineProperty({}, "".concat(fullPrefix, "vc:old:dom"), ssrVC.VCBox) : {};
158
+ var stopTime = performance.now();
159
+
160
+ // exposing data to devtools
161
+ try {
162
+ if (!_this.isPostInteraction && devToolsEnabled) {
163
+ window.__vc = {
164
+ entries: VCEntries.rel,
165
+ log: componentsLog,
166
+ metrics: {
167
+ '75': VC['75'],
168
+ '80': VC['80'],
169
+ '85': VC['85'],
170
+ '90': VC['90'],
171
+ '95': VC['95'],
172
+ '98': VC['98'],
173
+ '99': VC['99'],
174
+ tti: tti,
175
+ ttai: stop - start
176
+ },
177
+ heatmap: heatmap,
178
+ ratios: ratios
179
+ };
180
+
181
+ // Emitting a custom event to make it available in the Chrome extension
182
+ window.dispatchEvent(new CustomEvent('vcReady', {
183
+ detail: {
184
+ log: filterComponentsLog(componentsLog),
185
+ entries: VCEntries.rel
186
+ }
187
+ }));
188
+ }
189
+ } catch (e) {
190
+ /* do nothing */
191
+ }
192
+ return _objectSpread(_objectSpread(_objectSpread((_objectSpread2 = {
193
+ 'metrics:vc': VC
194
+ }, _defineProperty(_objectSpread2, "".concat(fullPrefix, "vc:state"), true), _defineProperty(_objectSpread2, "".concat(fullPrefix, "vc:clean"), !abortReasonInfo), _defineProperty(_objectSpread2, "".concat(fullPrefix, "vc:dom"), VCBox), _defineProperty(_objectSpread2, "".concat(fullPrefix, "vc:updates"), VCEntries.rel.slice(0, 50)), _defineProperty(_objectSpread2, "".concat(fullPrefix, "vc:size"), viewport), _defineProperty(_objectSpread2, "".concat(fullPrefix, "vc:time"), Math.round(totalTime + (stopTime - startTime))), _defineProperty(_objectSpread2, "".concat(fullPrefix, "vc:total"), totalPainted), _defineProperty(_objectSpread2, "".concat(fullPrefix, "vc:ratios"), ratios), _objectSpread2), outOfBoundary), {}, _defineProperty({}, "".concat(fullPrefix, "vc:old"), ssrVC.VC), oldDomUpdates), {}, _defineProperty({}, "".concat(fullPrefix, "vc:ignored"), _this.getIgnoredElements(componentsLog)));
195
+ });
196
+ _defineProperty(this, "handleUpdate", function (rawTime, intersectionRect, targetName, element, ignoreReason) {
197
+ _this.measureStart();
198
+ if (_this.abortReason.reason === null || _this.abortReason.blocking === false) {
199
+ var time = Math.round(rawTime - _this.startTime);
200
+ var mappedValues = _this.mapPixelsToHeatmap(intersectionRect.left, intersectionRect.top, intersectionRect.width, intersectionRect.height);
201
+ _this.vcRatios[targetName] = _this.getElementRatio(mappedValues);
202
+ _this.applyChangesToHeatMap(mappedValues, time, _this.heatmap);
203
+ if (!ignoreReason) {
204
+ _this.applyChangesToHeatMap(mappedValues, time, _this.ssrInclusiveHeatmap);
205
+ }
206
+ if (!_this.componentsLog[time]) {
207
+ _this.componentsLog[time] = [];
208
+ }
209
+ _this.componentsLog[time].push({
210
+ __debug__element: _this.devToolsEnabled ? element : null,
211
+ intersectionRect: intersectionRect,
212
+ targetName: targetName,
213
+ ignoreReason: ignoreReason
214
+ });
215
+ }
216
+ // devtools export
217
+ _this.measureStop();
218
+ });
219
+ _defineProperty(this, "mapPixelsToHeatmap", function (left, top, width, height) {
220
+ var _this$viewport = _this.viewport,
221
+ w = _this$viewport.w,
222
+ h = _this$viewport.h;
223
+ var l = Math.floor(left / w * _this.arraySize);
224
+ var t = Math.floor(top / h * _this.arraySize);
225
+ var r = Math.ceil((left + width) / w * _this.arraySize);
226
+ var b = Math.ceil((top + height) / h * _this.arraySize);
227
+
228
+ // that info is temporary to get info why it goes over boundary
229
+ if (_this.outOfBoundaryInfo === '') {
230
+ var outOfBoundaryInfo = '';
231
+ if (r > _this.arraySize) {
232
+ outOfBoundaryInfo += " r ".concat(r, " ! ").concat(left, " ").concat(width);
233
+ }
234
+ if (b > _this.arraySize) {
235
+ outOfBoundaryInfo += " r ".concat(r, " ! ").concat(top, " ").concat(height);
236
+ }
237
+ _this.outOfBoundaryInfo = outOfBoundaryInfo;
238
+ }
239
+
240
+ // correct values to min - 0, max - arraySize
241
+ var result = {
242
+ l: Math.max(0, l),
243
+ t: Math.max(0, t),
244
+ r: Math.min(_this.arraySize, r),
245
+ b: Math.min(_this.arraySize, b)
246
+ };
247
+ return result;
248
+ });
249
+ _defineProperty(this, "getElementRatio", function (mappedValues) {
250
+ var r = mappedValues.r,
251
+ l = mappedValues.l,
252
+ b = mappedValues.b,
253
+ t = mappedValues.t;
254
+ return (r - l) * (b - t) / (_this.arraySize * _this.arraySize);
255
+ });
256
+ _defineProperty(this, "abortReasonCallback", function (key, time) {
257
+ switch (key) {
258
+ case 'wheel':
259
+ _this.setAbortReason(abortReason.scroll, time);
260
+ break;
261
+ case 'keydown':
262
+ _this.setAbortReason(abortReason.keypress, time);
263
+ break;
264
+ case 'resize':
265
+ _this.setAbortReason(abortReason.resize, time);
266
+ break;
267
+ }
268
+ });
269
+ _defineProperty(this, "attachAbortListeners", function () {
270
+ var _window;
271
+ _this.detachAbortListeners();
272
+ var unbinds = attachAbortListeners(window, _this.viewport, _this.abortReasonCallback);
273
+ if ((_window = window) !== null && _window !== void 0 && _window.__SSR_ABORT_LISTENERS__) {
274
+ var _window2;
275
+ Object.entries(window.__SSR_ABORT_LISTENERS__.aborts).forEach(function (_ref7) {
276
+ var _ref8 = _slicedToArray(_ref7, 2),
277
+ key = _ref8[0],
278
+ time = _ref8[1];
279
+ if (time) {
280
+ _this.abortReasonCallback(key, time);
281
+ }
282
+ });
283
+ unbinds = unbinds.concat(window.__SSR_ABORT_LISTENERS__.unbinds);
284
+ (_window2 = window) === null || _window2 === void 0 || delete _window2.__SSR_ABORT_LISTENERS__;
285
+ }
286
+ _this.unbind = unbinds;
287
+ });
288
+ this.arraySize = options.heatmapSize || 200;
289
+ this.devToolsEnabled = options.devToolsEnabled || false;
290
+ this.oldDomUpdatesEnabled = options.oldDomUpdates || false;
291
+ this.observers = new Observers({
292
+ selectorConfig: options.selectorConfig || {
293
+ id: false,
294
+ testId: false,
295
+ role: false,
296
+ className: true,
297
+ dataVC: true
298
+ }
299
+ });
300
+ this.heatmap = this.getCleanHeatmap();
301
+ this.ssrInclusiveHeatmap = this.getCleanHeatmap();
302
+ this.isPostInteraction = options.isPostInteraction || false;
303
+ }
304
+ _createClass(VCObserver, [{
305
+ key: "start",
306
+ value: function start(_ref9) {
307
+ var startTime = _ref9.startTime;
308
+ this.active = true;
309
+ if (this.observers.isBrowserSupported()) {
310
+ this.setViewportSize();
311
+ this.resetState();
312
+ this.startTime = startTime;
313
+ this.attachAbortListeners();
314
+ this.observers.subscribeResults(this.handleUpdate);
315
+ this.observers.observe();
316
+ } else {
317
+ this.setAbortReason('not-supported', startTime);
318
+ }
319
+ }
320
+ }, {
321
+ key: "stop",
322
+ value: function stop() {
323
+ this.observers.disconnect();
324
+ this.detachAbortListeners();
325
+ }
326
+ }, {
327
+ key: "getIgnoredElements",
328
+ value: function getIgnoredElements(componentsLog) {
329
+ return Object.values(componentsLog).flat().filter(function (_ref10) {
330
+ var ignoreReason = _ref10.ignoreReason;
331
+ return Boolean(ignoreReason);
332
+ }).map(function (_ref11) {
333
+ var targetName = _ref11.targetName,
334
+ ignoreReason = _ref11.ignoreReason;
335
+ return {
336
+ targetName: targetName,
337
+ ignoreReason: ignoreReason
338
+ };
339
+ });
340
+ }
341
+ }, {
342
+ key: "setSSRElement",
343
+ value: function setSSRElement(element) {
344
+ this.observers.setReactRootElement(element);
345
+ }
346
+ }, {
347
+ key: "setReactRootRenderStart",
348
+ value: function setReactRootRenderStart() {
349
+ var startTime = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : performance.now();
350
+ this.observers.setReactRootRenderStart(startTime);
351
+ }
352
+ }, {
353
+ key: "setReactRootRenderStop",
354
+ value: function setReactRootRenderStop() {
355
+ var stopTime = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : performance.now();
356
+ this.observers.setReactRootRenderStop(stopTime);
357
+ }
358
+ }, {
359
+ key: "setAbortReason",
360
+ value: function setAbortReason(abort, timestamp) {
361
+ var info = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';
362
+ if (this.abortReason.reason === null || this.abortReason.blocking === false) {
363
+ this.abortReason.reason = abort;
364
+ this.abortReason.info = info;
365
+ this.abortReason.timestamp = timestamp;
366
+ this.abortReason.blocking = abort !== abortReason.scroll;
367
+ if (this.abortReason.blocking) {
368
+ this.detachAbortListeners();
369
+ }
370
+ }
371
+ }
372
+ }, {
373
+ key: "resetState",
374
+ value: function resetState() {
375
+ this.abortReason = {
376
+ reason: null,
377
+ info: '',
378
+ timestamp: -1,
379
+ blocking: false
380
+ };
381
+ this.detachAbortListeners();
382
+ this.heatmap = this.getCleanHeatmap();
383
+ this.ssrInclusiveHeatmap = this.getCleanHeatmap();
384
+ this.totalTime = 0;
385
+ this.componentsLog = {};
386
+ this.vcRatios = {};
387
+ }
388
+ }, {
389
+ key: "getCleanHeatmap",
390
+ value: function getCleanHeatmap() {
391
+ var _this2 = this;
392
+ return Array(this.arraySize).fill('').map(function () {
393
+ return Array(_this2.arraySize).fill(UNUSED_SECTOR);
394
+ });
395
+ }
396
+ }, {
397
+ key: "setViewportSize",
398
+ value: function setViewportSize() {
399
+ this.viewport.w = getViewportWidth();
400
+ this.viewport.h = getViewportHeight();
401
+ }
402
+ }, {
403
+ key: "applyChangesToHeatMap",
404
+ value: function applyChangesToHeatMap(a, time, heatmap) {
405
+ var l = a.l,
406
+ t = a.t,
407
+ r = a.r,
408
+ b = a.b;
409
+ var localHeatmap = heatmap;
410
+ for (var row = t; row < b; row++) {
411
+ for (var col = l; col < r; col++) {
412
+ if (localHeatmap[row] === undefined) {
413
+ try {
414
+ this.setAbortReason(abortReason.error, time, "index - ".concat(row));
415
+ } catch (e) {
416
+ this.setAbortReason(abortReason.error, time, 'row error');
417
+ }
418
+ return;
419
+ } else {
420
+ localHeatmap[row][col] = time;
421
+ }
422
+ }
423
+ }
424
+ }
425
+ }, {
426
+ key: "detachAbortListeners",
427
+ value: function detachAbortListeners() {
428
+ this.unbind.forEach(function (fn) {
429
+ return fn();
430
+ });
431
+ this.unbind = [];
432
+ }
433
+ }, {
434
+ key: "measureStart",
435
+ value: function measureStart() {
436
+ this._startMeasureTimestamp = performance.now();
437
+ }
438
+ }, {
439
+ key: "measureStop",
440
+ value: function measureStop() {
441
+ if (this._startMeasureTimestamp === -1) {
442
+ return;
443
+ }
444
+ this.totalTime += performance.now() - this._startMeasureTimestamp;
445
+ this._startMeasureTimestamp = -1;
446
+ }
447
+ }], [{
448
+ key: "calculateVC",
449
+ value: function calculateVC(_ref12) {
450
+ var heatmap = _ref12.heatmap,
451
+ _ref12$ssr = _ref12.ssr,
452
+ ssr = _ref12$ssr === void 0 ? UNUSED_SECTOR : _ref12$ssr,
453
+ componentsLog = _ref12.componentsLog,
454
+ viewport = _ref12.viewport;
455
+ var lastUpdate = {};
456
+ var totalPainted = 0;
457
+ if (ssr !== UNUSED_SECTOR) {
458
+ var _window$document;
459
+ var element = {
460
+ __debug__element: (_window$document = window.document) === null || _window$document === void 0 ? void 0 : _window$document.body,
461
+ intersectionRect: {
462
+ top: 0,
463
+ left: 0,
464
+ right: 0,
465
+ bottom: 0,
466
+ x: 0,
467
+ y: 0,
468
+ width: viewport.w,
469
+ height: viewport.h,
470
+ toJSON: function toJSON() {
471
+ return {};
472
+ }
473
+ },
474
+ targetName: 'SSR'
475
+ };
476
+ if (!componentsLog[ssr]) {
477
+ componentsLog[ssr] = [];
478
+ }
479
+ componentsLog[ssr].push(element);
480
+ }
481
+ heatmap.forEach(function (line) {
482
+ line.forEach(function (entry) {
483
+ var rounded = Math.floor(entry === UNUSED_SECTOR && ssr !== UNUSED_SECTOR ? ssr : entry);
484
+ totalPainted += rounded !== UNUSED_SECTOR ? 1 : 0;
485
+ if (rounded !== UNUSED_SECTOR) {
486
+ lastUpdate[rounded] = lastUpdate[rounded] ? lastUpdate[rounded] + 1 : 1;
487
+ }
488
+ });
489
+ });
490
+ var entries = Object.entries(lastUpdate).map(function (a) {
491
+ return [parseInt(a[0], 10), a[1]];
492
+ }).sort(function (a, b) {
493
+ return a[0] > b[0] ? 1 : -1;
494
+ });
495
+ var VC = VCObserver.makeVCReturnObj();
496
+ var VCBox = VCObserver.makeVCReturnObj();
497
+ entries.reduce(function () {
498
+ var acc = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
499
+ var v = arguments.length > 1 ? arguments[1] : undefined;
500
+ var VCRatio = v[1] / totalPainted + acc;
501
+ var time = v[0];
502
+ VCObserver.VCParts.forEach(function (key) {
503
+ var value = parseInt(key, 10);
504
+ if ((VC[key] === null || VC[key] === undefined) && VCRatio >= value / 100) {
505
+ var _componentsLog$time;
506
+ VC[key] = time;
507
+ VCBox[key] = (_componentsLog$time = componentsLog[time]) === null || _componentsLog$time === void 0 ? void 0 : _componentsLog$time.map(function (v) {
508
+ return v.targetName;
509
+ });
510
+ }
511
+ });
512
+ return VCRatio;
513
+ }, 0);
514
+ var VCEntries = entries.reduce(function (acc, _ref13, i) {
515
+ var _acc$abs, _componentsLog$timest;
516
+ var _ref14 = _slicedToArray(_ref13, 2),
517
+ timestamp = _ref14[0],
518
+ entryPainted = _ref14[1];
519
+ var currentlyPainted = entryPainted + (((_acc$abs = acc.abs[i - 1]) === null || _acc$abs === void 0 ? void 0 : _acc$abs[1]) || 0);
520
+ var currentlyPaintedRatio = Math.round(currentlyPainted / totalPainted * 1000) / 10;
521
+ var logEntry = (_componentsLog$timest = componentsLog[timestamp]) === null || _componentsLog$timest === void 0 ? void 0 : _componentsLog$timest.map(function (v) {
522
+ return v.targetName;
523
+ });
524
+ acc.abs.push([timestamp, currentlyPainted]);
525
+ acc.rel.push({
526
+ time: timestamp,
527
+ vc: currentlyPaintedRatio,
528
+ elements: logEntry
529
+ });
530
+ return acc;
531
+ }, {
532
+ abs: [],
533
+ rel: []
534
+ });
535
+ return {
536
+ VC: VC,
537
+ VCBox: VCBox,
538
+ VCEntries: VCEntries,
539
+ totalPainted: totalPainted
540
+ };
541
+ }
542
+ }, {
543
+ key: "makeVCReturnObj",
544
+ value: function makeVCReturnObj() {
545
+ var vc = {};
546
+ VCObserver.VCParts.forEach(function (v) {
547
+ vc[v] = null;
548
+ });
549
+ return vc;
550
+ }
551
+ }]);
552
+ return VCObserver;
553
+ }();
554
+ /** config * */
555
+ _defineProperty(VCObserver, "VCParts", ['25', '50', '75', '80', '85', '90', '95', '98', '99']);
@@ -0,0 +1,7 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import React from 'react';
3
+ export var MEDIA_WRAPPER_TAG = 'data-media-vc-wrapper';
4
+ export default function MediaWrapper(_ref) {
5
+ var children = _ref.children;
6
+ return /*#__PURE__*/React.createElement("div", _defineProperty({}, MEDIA_WRAPPER_TAG, true), children);
7
+ }
@@ -0,0 +1,10 @@
1
+ import { MEDIA_WRAPPER_TAG } from './index';
2
+ export var isContainedWithinMediaWrapper = function isContainedWithinMediaWrapper(node) {
3
+ while (node) {
4
+ if (node instanceof Element && node.hasAttribute(MEDIA_WRAPPER_TAG)) {
5
+ return true;
6
+ }
7
+ node = node.parentNode;
8
+ }
9
+ return false;
10
+ };