@google-psat/design-system 0.14.1 → 1.2.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 (422) hide show
  1. package/dist/components/breadcrumbs/index.jsx +10 -15
  2. package/dist/components/breadcrumbs/index.jsx.map +1 -1
  3. package/dist/components/bulletList/index.jsx +6 -14
  4. package/dist/components/bulletList/index.jsx.map +1 -1
  5. package/dist/components/bulletList/listRow.jsx +19 -40
  6. package/dist/components/bulletList/listRow.jsx.map +1 -1
  7. package/dist/components/button/index.jsx +17 -16
  8. package/dist/components/button/index.jsx.map +1 -1
  9. package/dist/components/chipsBar/chip.jsx +5 -10
  10. package/dist/components/chipsBar/chip.jsx.map +1 -1
  11. package/dist/components/chipsBar/chipsList.jsx +4 -9
  12. package/dist/components/chipsBar/chipsList.jsx.map +1 -1
  13. package/dist/components/chipsBar/index.jsx +12 -14
  14. package/dist/components/chipsBar/index.jsx.map +1 -1
  15. package/dist/components/circle/circleEmpty.jsx +4 -9
  16. package/dist/components/circle/circleEmpty.jsx.map +1 -1
  17. package/dist/components/circle/index.jsx +3 -8
  18. package/dist/components/circle/index.jsx.map +1 -1
  19. package/dist/components/circlePieChart/emptyCirclePieChart.jsx +9 -12
  20. package/dist/components/circlePieChart/emptyCirclePieChart.jsx.map +1 -1
  21. package/dist/components/circlePieChart/index.jsx +18 -21
  22. package/dist/components/circlePieChart/index.jsx.map +1 -1
  23. package/dist/components/circlePieChart/tooltip.jsx +26 -0
  24. package/dist/components/circlePieChart/tooltip.jsx.map +1 -0
  25. package/dist/components/cookieDetails/details.jsx +76 -105
  26. package/dist/components/cookieDetails/details.jsx.map +1 -1
  27. package/dist/components/cookieDetails/index.jsx +8 -13
  28. package/dist/components/cookieDetails/index.jsx.map +1 -1
  29. package/dist/components/cookieTable/index.jsx +32 -57
  30. package/dist/components/cookieTable/index.jsx.map +1 -1
  31. package/dist/components/cookieTable/utils/conditionalTableRowClassesHandler.js +14 -19
  32. package/dist/components/cookieTable/utils/conditionalTableRowClassesHandler.js.map +1 -1
  33. package/dist/components/cookieTable/utils/exportCookies.js +6 -8
  34. package/dist/components/cookieTable/utils/exportCookies.js.map +1 -1
  35. package/dist/components/cookieTable/utils/index.js +2 -10
  36. package/dist/components/cookieTable/utils/index.js.map +1 -1
  37. package/dist/components/cookiesLanding/cookiesLandingWrapper.jsx +6 -11
  38. package/dist/components/cookiesLanding/cookiesLandingWrapper.jsx.map +1 -1
  39. package/dist/components/cookiesLanding/cookiesMatrix/index.jsx +19 -20
  40. package/dist/components/cookiesLanding/cookiesMatrix/index.jsx.map +1 -1
  41. package/dist/components/cookiesLanding/index.jsx +2 -7
  42. package/dist/components/cookiesLanding/index.jsx.map +1 -1
  43. package/dist/components/cookiesLanding/landingHeader/index.jsx +11 -18
  44. package/dist/components/cookiesLanding/landingHeader/index.jsx.map +1 -1
  45. package/dist/components/cookiesLanding/useFiltersMapping.jsx +13 -11
  46. package/dist/components/cookiesLanding/useFiltersMapping.jsx.map +1 -1
  47. package/dist/components/cookiesLanding/useGlobalFiltering.jsx +77 -83
  48. package/dist/components/cookiesLanding/useGlobalFiltering.jsx.map +1 -1
  49. package/dist/components/draggableTray/index.jsx +36 -52
  50. package/dist/components/draggableTray/index.jsx.map +1 -1
  51. package/dist/components/dropdown/index.jsx +30 -0
  52. package/dist/components/dropdown/index.jsx.map +1 -0
  53. package/dist/components/dropdown/options.jsx +41 -0
  54. package/dist/components/dropdown/options.jsx.map +1 -0
  55. package/dist/components/errorFallback/extensionReloadNotification.jsx +5 -11
  56. package/dist/components/errorFallback/extensionReloadNotification.jsx.map +1 -1
  57. package/dist/components/errorFallback/index.jsx +6 -11
  58. package/dist/components/errorFallback/index.jsx.map +1 -1
  59. package/dist/components/exportButton/index.jsx +7 -12
  60. package/dist/components/exportButton/index.jsx.map +1 -1
  61. package/dist/components/filtersSidebar/index.jsx +14 -42
  62. package/dist/components/filtersSidebar/index.jsx.map +1 -1
  63. package/dist/components/filtersSidebar/listItem.jsx +20 -50
  64. package/dist/components/filtersSidebar/listItem.jsx.map +1 -1
  65. package/dist/components/filtersSidebar/option.jsx +6 -34
  66. package/dist/components/filtersSidebar/option.jsx.map +1 -1
  67. package/dist/components/filtersSidebar/subList.jsx +9 -37
  68. package/dist/components/filtersSidebar/subList.jsx.map +1 -1
  69. package/dist/components/frameContent/index.jsx +5 -10
  70. package/dist/components/frameContent/index.jsx.map +1 -1
  71. package/dist/components/index.js +60 -119
  72. package/dist/components/index.js.map +1 -1
  73. package/dist/components/inspectButton/index.jsx +7 -12
  74. package/dist/components/inspectButton/index.jsx.map +1 -1
  75. package/dist/components/jsonView/index.js +1 -8
  76. package/dist/components/jsonView/index.js.map +1 -1
  77. package/dist/components/jsonView/jsonTheme.js +1 -5
  78. package/dist/components/jsonView/jsonTheme.js.map +1 -1
  79. package/dist/components/jsonView/jsonView.jsx +11 -41
  80. package/dist/components/jsonView/jsonView.jsx.map +1 -1
  81. package/dist/components/landingPage/LandingPage.jsx +32 -64
  82. package/dist/components/landingPage/LandingPage.jsx.map +1 -1
  83. package/dist/components/landingPage/cardsPanel.jsx +33 -44
  84. package/dist/components/landingPage/cardsPanel.jsx.map +1 -1
  85. package/dist/components/landingPage/constants.js +1 -4
  86. package/dist/components/landingPage/constants.js.map +1 -1
  87. package/dist/components/landingPage/contentPanel.jsx +27 -28
  88. package/dist/components/landingPage/contentPanel.jsx.map +1 -1
  89. package/dist/components/landingPage/getStoryPlayerMarkup.js +3 -8
  90. package/dist/components/landingPage/getStoryPlayerMarkup.js.map +1 -1
  91. package/dist/components/landingPage/index.jsx +23 -47
  92. package/dist/components/landingPage/index.jsx.map +1 -1
  93. package/dist/components/landingPage/infoCard/fetchPSInfo.js +7 -21
  94. package/dist/components/landingPage/infoCard/fetchPSInfo.js.map +1 -1
  95. package/dist/components/landingPage/infoCard/index.jsx +28 -58
  96. package/dist/components/landingPage/infoCard/index.jsx.map +1 -1
  97. package/dist/components/landingPage/infoCard/learnMoreDropdown.jsx +13 -17
  98. package/dist/components/landingPage/infoCard/learnMoreDropdown.jsx.map +1 -1
  99. package/dist/components/landingPage/infoCard/renderLink.jsx +5 -10
  100. package/dist/components/landingPage/infoCard/renderLink.jsx.map +1 -1
  101. package/dist/components/landingPage/quickLinksList.jsx +29 -64
  102. package/dist/components/landingPage/quickLinksList.jsx.map +1 -1
  103. package/dist/components/landingPage/supportLink.jsx +8 -13
  104. package/dist/components/landingPage/supportLink.jsx.map +1 -1
  105. package/dist/components/link/index.jsx +7 -41
  106. package/dist/components/link/index.jsx.map +1 -1
  107. package/dist/components/linkProcessor/index.jsx +13 -41
  108. package/dist/components/linkProcessor/index.jsx.map +1 -1
  109. package/dist/components/matrix/index.jsx +10 -13
  110. package/dist/components/matrix/index.jsx.map +1 -1
  111. package/dist/components/matrix/matrixComponent/index.jsx +6 -11
  112. package/dist/components/matrix/matrixComponent/index.jsx.map +1 -1
  113. package/dist/components/matrix/matrixComponent/matrixComponentHorizontal.jsx +4 -9
  114. package/dist/components/matrix/matrixComponent/matrixComponentHorizontal.jsx.map +1 -1
  115. package/dist/components/matrixContainer/index.jsx +15 -43
  116. package/dist/components/matrixContainer/index.jsx.map +1 -1
  117. package/dist/components/menuBar/index.jsx +31 -69
  118. package/dist/components/menuBar/index.jsx.map +1 -1
  119. package/dist/components/menuBar/utils/index.js +1 -8
  120. package/dist/components/menuBar/utils/index.js.map +1 -1
  121. package/dist/components/menuBar/utils/isElementInView.js +1 -4
  122. package/dist/components/menuBar/utils/isElementInView.js.map +1 -1
  123. package/dist/components/messageBox/index.jsx +8 -11
  124. package/dist/components/messageBox/index.jsx.map +1 -1
  125. package/dist/components/multiSelectDropDown/index.jsx +143 -0
  126. package/dist/components/multiSelectDropDown/index.jsx.map +1 -0
  127. package/dist/components/pill/index.jsx +2 -7
  128. package/dist/components/pill/index.jsx.map +1 -1
  129. package/dist/components/pillToggle/index.jsx +60 -24
  130. package/dist/components/pillToggle/index.jsx.map +1 -1
  131. package/dist/components/progressBar/borderProgressbar.jsx +2 -7
  132. package/dist/components/progressBar/borderProgressbar.jsx.map +1 -1
  133. package/dist/components/progressBar/index.jsx +2 -7
  134. package/dist/components/progressBar/index.jsx.map +1 -1
  135. package/dist/components/refreshButton/index.jsx +5 -10
  136. package/dist/components/refreshButton/index.jsx.map +1 -1
  137. package/dist/components/resizableTray/index.jsx +74 -0
  138. package/dist/components/resizableTray/index.jsx.map +1 -0
  139. package/dist/components/searchInput/index.jsx +20 -46
  140. package/dist/components/searchInput/index.jsx.map +1 -1
  141. package/dist/components/sidebar/collapsedSidebar.jsx +19 -47
  142. package/dist/components/sidebar/collapsedSidebar.jsx.map +1 -1
  143. package/dist/components/sidebar/expandedSidebar.jsx +19 -50
  144. package/dist/components/sidebar/expandedSidebar.jsx.map +1 -1
  145. package/dist/components/sidebar/index.js +3 -24
  146. package/dist/components/sidebar/index.js.map +1 -1
  147. package/dist/components/sidebar/sidebar.jsx +10 -15
  148. package/dist/components/sidebar/sidebar.jsx.map +1 -1
  149. package/dist/components/sidebar/sidebarChild.jsx +38 -53
  150. package/dist/components/sidebar/sidebarChild.jsx.map +1 -1
  151. package/dist/components/sidebar/useSidebar/constants.js +4 -5
  152. package/dist/components/sidebar/useSidebar/constants.js.map +1 -1
  153. package/dist/components/sidebar/useSidebar/context.js +9 -12
  154. package/dist/components/sidebar/useSidebar/context.js.map +1 -1
  155. package/dist/components/sidebar/useSidebar/index.js +3 -19
  156. package/dist/components/sidebar/useSidebar/index.js.map +1 -1
  157. package/dist/components/sidebar/useSidebar/provider.jsx +77 -100
  158. package/dist/components/sidebar/useSidebar/provider.jsx.map +1 -1
  159. package/dist/components/sidebar/useSidebar/types.js +1 -2
  160. package/dist/components/sidebar/useSidebar/types.js.map +1 -1
  161. package/dist/components/sidebar/useSidebar/useSidebar.jsx +4 -7
  162. package/dist/components/sidebar/useSidebar/useSidebar.jsx.map +1 -1
  163. package/dist/components/sidebar/useSidebar/utils/createKeyPath.js +3 -8
  164. package/dist/components/sidebar/useSidebar/utils/createKeyPath.js.map +1 -1
  165. package/dist/components/sidebar/useSidebar/utils/findItem.js +11 -9
  166. package/dist/components/sidebar/useSidebar/utils/findItem.js.map +1 -1
  167. package/dist/components/sidebar/useSidebar/utils/findKeyParent.js +1 -3
  168. package/dist/components/sidebar/useSidebar/utils/findKeyParent.js.map +1 -1
  169. package/dist/components/sidebar/useSidebar/utils/findNextItem.js +7 -12
  170. package/dist/components/sidebar/useSidebar/utils/findNextItem.js.map +1 -1
  171. package/dist/components/sidebar/useSidebar/utils/findPrevItem.js +6 -11
  172. package/dist/components/sidebar/useSidebar/utils/findPrevItem.js.map +1 -1
  173. package/dist/components/sidebar/useSidebar/utils/index.js +6 -18
  174. package/dist/components/sidebar/useSidebar/utils/index.js.map +1 -1
  175. package/dist/components/sidebar/useSidebar/utils/matchKey.js +1 -3
  176. package/dist/components/sidebar/useSidebar/utils/matchKey.js.map +1 -1
  177. package/dist/components/slider/index.jsx +29 -0
  178. package/dist/components/slider/index.jsx.map +1 -0
  179. package/dist/components/table/components/columnMenu/columnList.jsx +7 -35
  180. package/dist/components/table/components/columnMenu/columnList.jsx.map +1 -1
  181. package/dist/components/table/components/columnMenu/columnListItem.jsx +4 -9
  182. package/dist/components/table/components/columnMenu/columnListItem.jsx.map +1 -1
  183. package/dist/components/table/components/columnMenu/index.jsx +32 -46
  184. package/dist/components/table/components/columnMenu/index.jsx.map +1 -1
  185. package/dist/components/table/components/filtersSidebar/chips/index.jsx +4 -9
  186. package/dist/components/table/components/filtersSidebar/chips/index.jsx.map +1 -1
  187. package/dist/components/table/components/filtersSidebar/index.jsx +7 -35
  188. package/dist/components/table/components/filtersSidebar/index.jsx.map +1 -1
  189. package/dist/components/table/components/index.jsx +58 -71
  190. package/dist/components/table/components/index.jsx.map +1 -1
  191. package/dist/components/table/components/tableBody/bodyCell.jsx +22 -22
  192. package/dist/components/table/components/tableBody/bodyCell.jsx.map +1 -1
  193. package/dist/components/table/components/tableBody/bodyRow.jsx +33 -57
  194. package/dist/components/table/components/tableBody/bodyRow.jsx.map +1 -1
  195. package/dist/components/table/components/tableBody/index.jsx +39 -60
  196. package/dist/components/table/components/tableBody/index.jsx.map +1 -1
  197. package/dist/components/table/components/tableHeader/headerCell.jsx +25 -52
  198. package/dist/components/table/components/tableHeader/headerCell.jsx.map +1 -1
  199. package/dist/components/table/components/tableHeader/headerResizer.jsx +2 -7
  200. package/dist/components/table/components/tableHeader/headerResizer.jsx.map +1 -1
  201. package/dist/components/table/components/tableHeader/headerRow.jsx +8 -13
  202. package/dist/components/table/components/tableHeader/headerRow.jsx.map +1 -1
  203. package/dist/components/table/components/tableHeader/index.jsx +7 -35
  204. package/dist/components/table/components/tableHeader/index.jsx.map +1 -1
  205. package/dist/components/table/components/tableTopBar/index.jsx +10 -15
  206. package/dist/components/table/components/tableTopBar/index.jsx.map +1 -1
  207. package/dist/components/table/index.js +11 -38
  208. package/dist/components/table/index.js.map +1 -1
  209. package/dist/components/table/persistentSettingsStore/index.jsx +28 -69
  210. package/dist/components/table/persistentSettingsStore/index.jsx.map +1 -1
  211. package/dist/components/table/persistentSettingsStore/utils/extractStorage.js +8 -19
  212. package/dist/components/table/persistentSettingsStore/utils/extractStorage.js.map +1 -1
  213. package/dist/components/table/persistentSettingsStore/utils/index.js +2 -10
  214. package/dist/components/table/persistentSettingsStore/utils/index.js.map +1 -1
  215. package/dist/components/table/persistentSettingsStore/utils/updateStorage.js +24 -32
  216. package/dist/components/table/persistentSettingsStore/utils/updateStorage.js.map +1 -1
  217. package/dist/components/table/useTable/context.js +19 -18
  218. package/dist/components/table/useTable/context.js.map +1 -1
  219. package/dist/components/table/useTable/index.js +3 -19
  220. package/dist/components/table/useTable/index.js.map +1 -1
  221. package/dist/components/table/useTable/provider.jsx +78 -62
  222. package/dist/components/table/useTable/provider.jsx.map +1 -1
  223. package/dist/components/table/useTable/types.js +1 -2
  224. package/dist/components/table/useTable/useColumnResizing/index.jsx +237 -125
  225. package/dist/components/table/useTable/useColumnResizing/index.jsx.map +1 -1
  226. package/dist/components/table/useTable/useColumnSorting/index.jsx +16 -20
  227. package/dist/components/table/useTable/useColumnSorting/index.jsx.map +1 -1
  228. package/dist/components/table/useTable/useColumnVisibility/index.jsx +22 -24
  229. package/dist/components/table/useTable/useColumnVisibility/index.jsx.map +1 -1
  230. package/dist/components/table/useTable/useFiltering/hooks/index.js +3 -12
  231. package/dist/components/table/useTable/useFiltering/hooks/index.js.map +1 -1
  232. package/dist/components/table/useTable/useFiltering/hooks/useFiltersExtraction.jsx +44 -39
  233. package/dist/components/table/useTable/useFiltering/hooks/useFiltersExtraction.jsx.map +1 -1
  234. package/dist/components/table/useTable/useFiltering/hooks/useFiltersOptions.jsx +14 -16
  235. package/dist/components/table/useTable/useFiltering/hooks/useFiltersOptions.jsx.map +1 -1
  236. package/dist/components/table/useTable/useFiltering/hooks/useFiltersPersistence.jsx +39 -25
  237. package/dist/components/table/useTable/useFiltering/hooks/useFiltersPersistence.jsx.map +1 -1
  238. package/dist/components/table/useTable/useFiltering/index.jsx +58 -47
  239. package/dist/components/table/useTable/useFiltering/index.jsx.map +1 -1
  240. package/dist/components/table/useTable/useSearch/index.jsx +11 -13
  241. package/dist/components/table/useTable/useSearch/index.jsx.map +1 -1
  242. package/dist/components/table/useTable/useTable.jsx +4 -7
  243. package/dist/components/table/useTable/useTable.jsx.map +1 -1
  244. package/dist/components/table/utils/index.js +1 -17
  245. package/dist/components/table/utils/index.js.map +1 -1
  246. package/dist/components/table/utils/precalculatedFiltersUtils/calculateBlockedReasonsFilterValues.js +5 -7
  247. package/dist/components/table/utils/precalculatedFiltersUtils/calculateBlockedReasonsFilterValues.js.map +1 -1
  248. package/dist/components/table/utils/precalculatedFiltersUtils/calculateDynamicFilterValues.js +6 -8
  249. package/dist/components/table/utils/precalculatedFiltersUtils/calculateDynamicFilterValues.js.map +1 -1
  250. package/dist/components/table/utils/precalculatedFiltersUtils/calculateExemptionReasons.js +2 -4
  251. package/dist/components/table/utils/precalculatedFiltersUtils/calculateExemptionReasons.js.map +1 -1
  252. package/dist/components/table/utils/precalculatedFiltersUtils/evaluateSelectAllOption.js +5 -8
  253. package/dist/components/table/utils/precalculatedFiltersUtils/evaluateSelectAllOption.js.map +1 -1
  254. package/dist/components/table/utils/precalculatedFiltersUtils/evaluateStaticFilterValues.js +3 -6
  255. package/dist/components/table/utils/precalculatedFiltersUtils/evaluateStaticFilterValues.js.map +1 -1
  256. package/dist/components/table/utils/precalculatedFiltersUtils/index.js +5 -16
  257. package/dist/components/table/utils/precalculatedFiltersUtils/index.js.map +1 -1
  258. package/dist/components/tabs/index.jsx +132 -75
  259. package/dist/components/tabs/index.jsx.map +1 -1
  260. package/dist/components/tabs/useTabs/context.js +12 -9
  261. package/dist/components/tabs/useTabs/context.js.map +1 -1
  262. package/dist/components/tabs/useTabs/index.js +3 -19
  263. package/dist/components/tabs/useTabs/index.js.map +1 -1
  264. package/dist/components/tabs/useTabs/provider.jsx +144 -62
  265. package/dist/components/tabs/useTabs/provider.jsx.map +1 -1
  266. package/dist/components/tabs/useTabs/types.js +1 -2
  267. package/dist/components/tabs/useTabs/useTabs.jsx +4 -7
  268. package/dist/components/tabs/useTabs/useTabs.jsx.map +1 -1
  269. package/dist/components/timeline/bar.jsx +71 -0
  270. package/dist/components/timeline/bar.jsx.map +1 -0
  271. package/dist/components/timeline/constants.js +29 -0
  272. package/dist/components/timeline/constants.js.map +1 -0
  273. package/dist/components/timeline/index.jsx +195 -0
  274. package/dist/components/timeline/index.jsx.map +1 -0
  275. package/dist/components/toastMessage/index.jsx +2 -7
  276. package/dist/components/toastMessage/index.jsx.map +1 -1
  277. package/dist/components/toggleSwitch/index.jsx +2 -7
  278. package/dist/components/toggleSwitch/index.jsx.map +1 -1
  279. package/dist/components/topbar/index.jsx +13 -41
  280. package/dist/components/topbar/index.jsx.map +1 -1
  281. package/dist/constants.js +9 -12
  282. package/dist/constants.js.map +1 -1
  283. package/dist/icons/index.jsx +118 -225
  284. package/dist/icons/index.jsx.map +1 -1
  285. package/dist/icons/ps-icons/index.js +12 -30
  286. package/dist/icons/ps-icons/index.js.map +1 -1
  287. package/dist/index.js +5 -21
  288. package/dist/index.js.map +1 -1
  289. package/dist/test-data/cookieMockData.js +44 -22
  290. package/dist/test-data/cookieMockData.js.map +1 -1
  291. package/dist/test-data/cookieStats.js +1 -3
  292. package/dist/test-data/cookieStats.js.map +1 -1
  293. package/dist/test-data/cookieTableBody.js +9 -14
  294. package/dist/test-data/cookieTableBody.js.map +1 -1
  295. package/dist/test-data/cookieTableMockData.jsx +18 -24
  296. package/dist/test-data/cookieTableMockData.jsx.map +1 -1
  297. package/dist/test-data/cookiesStatsComponents.js +1 -3
  298. package/dist/test-data/cookiesStatsComponents.js.map +1 -1
  299. package/dist/theme/colors.js +1 -4
  300. package/dist/theme/colors.js.map +1 -1
  301. package/dist/utils/index.js +6 -18
  302. package/dist/utils/index.js.map +1 -1
  303. package/dist/utils/noop.js +1 -5
  304. package/dist/utils/noop.js.map +1 -1
  305. package/dist/utils/prepareCookieDataMapping.js +7 -10
  306. package/dist/utils/prepareCookieDataMapping.js.map +1 -1
  307. package/dist/utils/prepareCookieStatsComponents.js +29 -33
  308. package/dist/utils/prepareCookieStatsComponents.js.map +1 -1
  309. package/dist/utils/prepareCookiesCount.js +12 -25
  310. package/dist/utils/prepareCookiesCount.js.map +1 -1
  311. package/dist/utils/prepareFrameStatsComponent.js +19 -24
  312. package/dist/utils/prepareFrameStatsComponent.js.map +1 -1
  313. package/dist/utils/prepareFrameStatsComponentForExtensionDashboard.js +16 -21
  314. package/dist/utils/prepareFrameStatsComponentForExtensionDashboard.js.map +1 -1
  315. package/dist-types/components/button/index.d.ts +2 -1
  316. package/dist-types/components/chipsBar/index.d.ts +1 -1
  317. package/dist-types/components/circlePieChart/emptyCirclePieChart.d.ts +4 -1
  318. package/dist-types/components/circlePieChart/index.d.ts +3 -1
  319. package/dist-types/components/circlePieChart/tooltip.d.ts +8 -0
  320. package/dist-types/components/draggableTray/index.d.ts +4 -0
  321. package/dist-types/components/dropdown/index.d.ts +18 -0
  322. package/dist-types/components/dropdown/options.d.ts +20 -0
  323. package/dist-types/components/index.d.ts +7 -0
  324. package/dist-types/components/landingPage/LandingPage.d.ts +2 -5
  325. package/dist-types/components/landingPage/cardsPanel.d.ts +7 -8
  326. package/dist-types/components/landingPage/contentPanel.d.ts +1 -1
  327. package/dist-types/components/landingPage/infoCard/fetchPSInfo.d.ts +2 -0
  328. package/dist-types/components/landingPage/infoCard/index.d.ts +2 -1
  329. package/dist-types/components/link/index.d.ts +2 -1
  330. package/dist-types/components/messageBox/index.d.ts +5 -1
  331. package/dist-types/components/multiSelectDropDown/index.d.ts +14 -0
  332. package/dist-types/components/pillToggle/index.d.ts +8 -5
  333. package/dist-types/components/resizableTray/index.d.ts +15 -0
  334. package/dist-types/components/searchInput/index.d.ts +4 -1
  335. package/dist-types/components/sidebar/expandedSidebar.d.ts +2 -1
  336. package/dist-types/components/sidebar/sidebar.d.ts +2 -1
  337. package/dist-types/components/sidebar/sidebarChild.d.ts +2 -1
  338. package/dist-types/components/sidebar/useSidebar/constants.d.ts +3 -1
  339. package/dist-types/components/sidebar/useSidebar/context.d.ts +6 -2
  340. package/dist-types/components/sidebar/useSidebar/types.d.ts +2 -0
  341. package/dist-types/components/sidebar/useSidebar/utils/findItem.d.ts +2 -1
  342. package/dist-types/components/slider/index.d.ts +14 -0
  343. package/dist-types/components/table/components/index.d.ts +4 -2
  344. package/dist-types/components/table/components/tableBody/bodyCell.d.ts +5 -2
  345. package/dist-types/components/table/components/tableBody/bodyRow.d.ts +3 -2
  346. package/dist-types/components/table/components/tableBody/index.d.ts +3 -2
  347. package/dist-types/components/table/components/tableHeader/headerCell.d.ts +4 -2
  348. package/dist-types/components/table/components/tableTopBar/index.d.ts +2 -1
  349. package/dist-types/components/table/persistentSettingsStore/index.d.ts +1 -1
  350. package/dist-types/components/table/useTable/context.d.ts +13 -5
  351. package/dist-types/components/table/useTable/provider.d.ts +1 -1
  352. package/dist-types/components/table/useTable/types.d.ts +47 -4
  353. package/dist-types/components/table/useTable/useColumnResizing/index.d.ts +11 -9
  354. package/dist-types/components/table/useTable/useFiltering/index.d.ts +1 -1
  355. package/dist-types/components/tabs/index.d.ts +1 -1
  356. package/dist-types/components/tabs/useTabs/context.d.ts +11 -1
  357. package/dist-types/components/tabs/useTabs/provider.d.ts +2 -2
  358. package/dist-types/components/tabs/useTabs/types.d.ts +8 -3
  359. package/dist-types/components/timeline/bar.d.ts +16 -0
  360. package/dist-types/components/timeline/constants.d.ts +8 -0
  361. package/dist-types/components/timeline/index.d.ts +12 -0
  362. package/dist-types/icons/index.d.ts +117 -101
  363. package/dist-types/icons/ps-icons/index.d.ts +12 -12
  364. package/package.json +12 -7
  365. package/tsconfig.json +5 -3
  366. package/dist/components/button/stories/Button.stories.jsx +0 -23
  367. package/dist/components/button/stories/Button.stories.jsx.map +0 -1
  368. package/dist/components/circle/stories/circle.stories.jsx +0 -26
  369. package/dist/components/circle/stories/circle.stories.jsx.map +0 -1
  370. package/dist/components/circle/stories/circleEmpty.stories.jsx +0 -18
  371. package/dist/components/circle/stories/circleEmpty.stories.jsx.map +0 -1
  372. package/dist/components/circlePieChart/stories/circlePieChart.stories.jsx +0 -91
  373. package/dist/components/circlePieChart/stories/circlePieChart.stories.jsx.map +0 -1
  374. package/dist/components/circlePieChart/stories/emptyCirclePieChart.stories.jsx +0 -48
  375. package/dist/components/circlePieChart/stories/emptyCirclePieChart.stories.jsx.map +0 -1
  376. package/dist/components/cookieDetails/stories/cookieDetails.stories.js +0 -30
  377. package/dist/components/cookieDetails/stories/cookieDetails.stories.js.map +0 -1
  378. package/dist/components/cookieDetails/stories/details.stories.js +0 -30
  379. package/dist/components/cookieDetails/stories/details.stories.js.map +0 -1
  380. package/dist/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.jsx +0 -59
  381. package/dist/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.jsx.map +0 -1
  382. package/dist/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.jsx +0 -40
  383. package/dist/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.jsx.map +0 -1
  384. package/dist/components/cookiesLanding/stories/cookiesLanding.stories.jsx +0 -20
  385. package/dist/components/cookiesLanding/stories/cookiesLanding.stories.jsx.map +0 -1
  386. package/dist/components/errorFallback/stories/errorFallback.stories.jsx +0 -31
  387. package/dist/components/errorFallback/stories/errorFallback.stories.jsx.map +0 -1
  388. package/dist/components/errorFallback/stories/extensionReloadNotification.stories.jsx +0 -20
  389. package/dist/components/errorFallback/stories/extensionReloadNotification.stories.jsx.map +0 -1
  390. package/dist/components/matrix/matrixComponent/stories/MatrixComponent.stories.jsx +0 -27
  391. package/dist/components/matrix/matrixComponent/stories/MatrixComponent.stories.jsx.map +0 -1
  392. package/dist/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.jsx +0 -25
  393. package/dist/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.jsx.map +0 -1
  394. package/dist/components/matrix/stories/matrix.stories.jsx +0 -59
  395. package/dist/components/matrix/stories/matrix.stories.jsx.map +0 -1
  396. package/dist/components/messageBox/stories/messageBox.stories.jsx +0 -23
  397. package/dist/components/messageBox/stories/messageBox.stories.jsx.map +0 -1
  398. package/dist/components/progressBar/stories/progressBar.stories.jsx +0 -22
  399. package/dist/components/progressBar/stories/progressBar.stories.jsx.map +0 -1
  400. package/dist/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.js +0 -61
  401. package/dist/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.js.map +0 -1
  402. package/dist/components/table/useTable/useColumnResizing/resizeColumns.js +0 -54
  403. package/dist/components/table/useTable/useColumnResizing/resizeColumns.js.map +0 -1
  404. package/dist-types/components/button/stories/Button.stories.d.ts +0 -11
  405. package/dist-types/components/circle/stories/circle.stories.d.ts +0 -11
  406. package/dist-types/components/circle/stories/circleEmpty.stories.d.ts +0 -11
  407. package/dist-types/components/circlePieChart/stories/circlePieChart.stories.d.ts +0 -9
  408. package/dist-types/components/circlePieChart/stories/emptyCirclePieChart.stories.d.ts +0 -9
  409. package/dist-types/components/cookieDetails/stories/cookieDetails.stories.d.ts +0 -12
  410. package/dist-types/components/cookieDetails/stories/details.stories.d.ts +0 -12
  411. package/dist-types/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.d.ts +0 -11
  412. package/dist-types/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.d.ts +0 -11
  413. package/dist-types/components/cookiesLanding/stories/cookiesLanding.stories.d.ts +0 -11
  414. package/dist-types/components/errorFallback/stories/errorFallback.stories.d.ts +0 -12
  415. package/dist-types/components/errorFallback/stories/extensionReloadNotification.stories.d.ts +0 -11
  416. package/dist-types/components/matrix/matrixComponent/stories/MatrixComponent.stories.d.ts +0 -11
  417. package/dist-types/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.d.ts +0 -11
  418. package/dist-types/components/matrix/stories/matrix.stories.d.ts +0 -11
  419. package/dist-types/components/messageBox/stories/messageBox.stories.d.ts +0 -11
  420. package/dist-types/components/progressBar/stories/progressBar.stories.d.ts +0 -11
  421. package/dist-types/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.d.ts +0 -7
  422. package/dist-types/components/table/useTable/useColumnResizing/resizeColumns.d.ts +0 -5
@@ -1,29 +1,3 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.TabsProvider = void 0;
27
1
  /*
28
2
  * Copyright 2024 Google LLC
29
3
  *
@@ -42,27 +16,76 @@ exports.TabsProvider = void 0;
42
16
  /**
43
17
  * External dependencies.
44
18
  */
45
- const react_1 = __importStar(require("react"));
46
- const context_1 = require("./context");
47
- const TabsProvider = ({ children, items, }) => {
48
- const [tabItems, setTabItems] = (0, react_1.useState)(items);
49
- const [activeTab, setActiveTab] = (0, react_1.useState)(0);
50
- const activeTabRef = (0, react_1.useRef)(activeTab);
51
- const [storage, _setStorage] = (0, react_1.useState)(Array(items.length).fill(''));
52
- const [highlightedTabs, setHighlightedTabs] = (0, react_1.useState)({});
53
- (0, react_1.useEffect)(() => {
54
- activeTabRef.current = activeTab;
55
- }, [activeTab]);
56
- (0, react_1.useEffect)(() => {
57
- setTabItems(items);
58
- _setStorage(Array(items.length).fill(''));
59
- }, [items]);
60
- const titles = (0, react_1.useMemo)(() => tabItems.map((item) => item.title), [tabItems]);
61
- const panel = tabItems[activeTab].content;
62
- const setStorage = (0, react_1.useCallback)((data, index) => {
19
+ import React, { useCallback, useEffect, useMemo, useRef, useState, } from 'react';
20
+ import { getSessionStorage, updateSessionStorage } from '@google-psat/common';
21
+ import { TabsContext } from './context';
22
+ import ProgressBar from '../../progressBar';
23
+ export const TabsProvider = ({ children, items, isGroup = true, name, }) => {
24
+ const [groupedItems, setGroupedItems] = useState({});
25
+ useEffect(() => {
26
+ if (!isGroup && Array.isArray(items)) {
27
+ setGroupedItems(items.reduce((acc, item, index) => {
28
+ acc[`group-${index}`] = [item];
29
+ return acc;
30
+ }, {}));
31
+ }
32
+ else {
33
+ setGroupedItems(items);
34
+ }
35
+ }, [isGroup, items]);
36
+ const [activeGroup, _setActiveGroup] = useState(isGroup ? Object.keys(items)[0] ?? null : null);
37
+ const [activeTab, setActiveTab] = useState(0);
38
+ const groupItemsRef = useRef(groupedItems);
39
+ useEffect(() => {
40
+ groupItemsRef.current = groupedItems;
41
+ }, [groupedItems]);
42
+ useEffect(() => {
43
+ _setActiveGroup((prev) => prev === null ? Object.keys(groupItemsRef.current)[0] ?? null : prev);
44
+ }, []);
45
+ const setActiveGroup = useCallback((group) => {
46
+ _setActiveGroup(group);
47
+ const keys = Object.keys(groupItemsRef.current);
48
+ let index = 0;
49
+ let tabIndex = 0;
50
+ while (index < keys.length && keys[index] !== group) {
51
+ tabIndex += groupItemsRef.current[keys[index]]?.length || 0;
52
+ index++;
53
+ }
54
+ setActiveTab(tabIndex);
55
+ }, []);
56
+ const tabItems = useMemo(() => {
57
+ return Object.values(groupedItems).flat();
58
+ }, [groupedItems]);
59
+ const [storage, _setStorage] = useState(Array(tabItems.length).fill(''));
60
+ const [highlightedTabs, setHighlightedTabs] = useState({});
61
+ useEffect(() => {
62
+ _setStorage(Array(tabItems.length).fill(''));
63
+ }, [tabItems.length]);
64
+ const groupedTitles = useMemo(() => {
65
+ let trackedIndex = 0;
66
+ return Object.entries(groupedItems).reduce((acc, [group, _items]) => {
67
+ const groupTitles = _items.map((item) => {
68
+ return {
69
+ title: item.title,
70
+ index: trackedIndex++,
71
+ };
72
+ });
73
+ return { ...acc, [group]: groupTitles };
74
+ }, {});
75
+ }, [groupedItems]);
76
+ const [loading, setLoading] = useState(true);
77
+ const titles = useMemo(() => tabItems.map((item) => item.title), [tabItems]);
78
+ const panel = loading
79
+ ? {
80
+ Element: ProgressBar,
81
+ }
82
+ : tabItems?.[activeTab]?.content ?? {
83
+ Element: null,
84
+ };
85
+ const setStorage = useCallback((data, index) => {
63
86
  _setStorage((prev) => {
64
87
  const next = [...prev];
65
- const _index = index !== null && index !== void 0 ? index : activeTab;
88
+ const _index = index ?? activeTab;
66
89
  const currentData = next[_index].startsWith('{')
67
90
  ? JSON.parse(next[_index])
68
91
  : next[_index];
@@ -75,55 +98,114 @@ const TabsProvider = ({ children, items, }) => {
75
98
  : JSON.stringify(incomingData);
76
99
  }
77
100
  else {
78
- next[_index] = JSON.stringify(Object.assign(Object.assign({}, currentData), incomingData));
101
+ next[_index] = JSON.stringify({
102
+ ...currentData,
103
+ ...incomingData,
104
+ });
79
105
  }
80
106
  return next;
81
107
  });
82
108
  }, [activeTab]);
83
- const highlightTab = (0, react_1.useCallback)((tab, update = true, increment = false) => {
84
- if (tab === activeTabRef.current) {
109
+ const highlightTab = useCallback((tab, update = true, increment = false) => {
110
+ if (tab === activeTab) {
85
111
  return;
86
112
  }
87
113
  setHighlightedTabs((prev) => {
88
- const next = Object.assign({}, prev);
114
+ const next = { ...prev };
89
115
  const prevCount = typeof next[tab] === 'number' ? next[tab] : 0;
90
116
  next[tab] = increment ? prevCount + 1 : update;
91
117
  return next;
92
118
  });
93
- }, []);
94
- const isTabHighlighted = (0, react_1.useCallback)((tab) => {
95
- var _a;
96
- return (_a = highlightedTabs === null || highlightedTabs === void 0 ? void 0 : highlightedTabs[tab]) !== null && _a !== void 0 ? _a : false;
119
+ }, [activeTab]);
120
+ const isTabHighlighted = useCallback((tab) => {
121
+ return highlightedTabs?.[tab] ?? false;
97
122
  }, [highlightedTabs]);
98
- (0, react_1.useEffect)(() => {
99
- if (highlightedTabs[activeTabRef.current]) {
123
+ useEffect(() => {
124
+ if (highlightedTabs[activeTab]) {
100
125
  setHighlightedTabs((prev) => {
101
- const next = Object.assign({}, prev);
102
- next[activeTabRef.current] = false;
126
+ const next = { ...prev };
127
+ next[activeTab] = false;
103
128
  return next;
104
129
  });
105
130
  }
106
131
  }, [activeTab, highlightTab, highlightedTabs]);
107
- const shouldAddSpacer = (0, react_1.useCallback)((index) => {
108
- return Boolean(tabItems[index].addSpacer);
132
+ const shouldAddSpacer = useCallback((index) => {
133
+ return Boolean(tabItems[index]?.addSpacer);
109
134
  }, [tabItems]);
110
- return (<context_1.TabsContext.Provider value={{
135
+ const getTabGroup = useCallback((tab) => {
136
+ let group = '';
137
+ let tracker = 0;
138
+ Object.entries(groupedItems).forEach(([groupKey, data]) => {
139
+ if (group) {
140
+ return;
141
+ }
142
+ if (tracker + data.length < tab + 1) {
143
+ tracker += data.length;
144
+ }
145
+ else {
146
+ group = groupKey;
147
+ return;
148
+ }
149
+ });
150
+ return group;
151
+ }, [groupedItems]);
152
+ useEffect(() => {
153
+ if (!name) {
154
+ setActiveTab(0);
155
+ setLoading(false);
156
+ return;
157
+ }
158
+ (async () => {
159
+ const sessionStorage = (await getSessionStorage('tabs')) || {};
160
+ if (!sessionStorage[name]) {
161
+ sessionStorage[name] = {
162
+ activeTab: 0,
163
+ activeGroup: 0,
164
+ };
165
+ }
166
+ const _activeTab = sessionStorage[name].activeTab || 0;
167
+ const _activeGroup = sessionStorage[name].activeGroup ||
168
+ Object.keys(groupItemsRef.current)[0];
169
+ setActiveGroup(_activeGroup);
170
+ setActiveTab(_activeTab);
171
+ setLoading(false);
172
+ })();
173
+ }, [name, setActiveGroup]);
174
+ useEffect(() => {
175
+ if (!name) {
176
+ return;
177
+ }
178
+ (async () => {
179
+ await updateSessionStorage({
180
+ [name]: {
181
+ activeTab,
182
+ activeGroup,
183
+ },
184
+ }, 'tabs');
185
+ })();
186
+ }, [name, activeTab, activeGroup]);
187
+ return (<TabsContext.Provider value={{
111
188
  state: {
112
189
  activeTab,
190
+ activeGroup,
191
+ groupedTitles,
113
192
  titles,
114
193
  panel,
115
194
  storage,
195
+ isGroup,
196
+ loading,
116
197
  },
117
198
  actions: {
118
199
  setStorage,
119
200
  setActiveTab,
201
+ setActiveGroup,
120
202
  highlightTab,
121
203
  isTabHighlighted,
122
204
  shouldAddSpacer,
205
+ getTabGroup,
123
206
  },
124
207
  }}>
125
208
  {children}
126
- </context_1.TabsContext.Provider>);
209
+ </TabsContext.Provider>);
127
210
  };
128
- exports.TabsProvider = TabsProvider;
129
211
  //# sourceMappingURL=provider.jsx.map
@@ -1 +1 @@
1
- {"version":3,"file":"provider.jsx","sourceRoot":"","sources":["../../../../src/components/tabs/useTabs/provider.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"provider.jsx","sourceRoot":"","sources":["../../../../src/components/tabs/useTabs/provider.tsx"],"names":[],"mappings":"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"}
@@ -1,3 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
1
+ export {};
3
2
  //# sourceMappingURL=types.js.map
@@ -1,6 +1,3 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useTabs = useTabs;
4
1
  /*
5
2
  * Copyright 2023 Google LLC
6
3
  *
@@ -19,17 +16,17 @@ exports.useTabs = useTabs;
19
16
  /**
20
17
  * External dependencies.
21
18
  */
22
- const common_1 = require("@google-psat/common");
19
+ import { useContextSelector } from '@google-psat/common';
23
20
  /**
24
21
  * Internal dependencies.
25
22
  */
26
- const context_1 = require("./context");
23
+ import { TabsContext } from './context';
27
24
  /**
28
25
  * Tabs store hook.
29
26
  * @param selector Selector function to partially select state.
30
27
  * @returns selected part of the state
31
28
  */
32
- function useTabs(selector = (state) => state) {
33
- return (0, common_1.useContextSelector)(context_1.TabsContext, selector);
29
+ export function useTabs(selector = (state) => state) {
30
+ return useContextSelector(TabsContext, selector);
34
31
  }
35
32
  //# sourceMappingURL=useTabs.jsx.map
@@ -1 +1 @@
1
- {"version":3,"file":"useTabs.jsx","sourceRoot":"","sources":["../../../../src/components/tabs/useTabs/useTabs.tsx"],"names":[],"mappings":";;AAiCA,0BAIC;AArCD;;;;;;;;;;;;;;GAcG;AACH;;GAEG;AACH,gDAAyD;AAEzD;;GAEG;AACH,uCAA0D;AAK1D;;;;GAIG;AACH,SAAgB,OAAO,CACrB,WAA8D,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK;IAE9E,OAAO,IAAA,2BAAkB,EAAC,qBAAW,EAAE,QAAQ,CAAC,CAAC;AACnD,CAAC"}
1
+ {"version":3,"file":"useTabs.jsx","sourceRoot":"","sources":["../../../../src/components/tabs/useTabs/useTabs.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH;;GAEG;AACH,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAEzD;;GAEG;AACH,OAAO,EAAE,WAAW,EAAoB,MAAM,WAAW,CAAC;AAK1D;;;;GAIG;AACH,MAAM,UAAU,OAAO,CACrB,WAA8D,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK;IAE9E,OAAO,kBAAkB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;AACnD,CAAC"}
@@ -0,0 +1,71 @@
1
+ /*
2
+ * Copyright 2025 Google LLC
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * https://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ /**
17
+ * External dependencies
18
+ */
19
+ import React, { useCallback, useState } from 'react';
20
+ import { BidderType, formatDuration } from '@google-psat/common';
21
+ import classNames from 'classnames';
22
+ /**
23
+ * Internal dependencies
24
+ */
25
+ import { HammerIcon } from '../../icons';
26
+ import { BAR_COLORS } from './constants';
27
+ const Bar = ({ bidder, index, zoom, bidderType, fullWidth, animate, setSelectedRow, }) => {
28
+ const [isBarHovered, setIsBarHovered] = useState(false);
29
+ const handleBarHover = useCallback(() => {
30
+ setIsBarHovered(true);
31
+ }, []);
32
+ const handleBarLeave = useCallback(() => {
33
+ setIsBarHovered(false);
34
+ }, []);
35
+ return (<div key={index} className="relative group" onMouseEnter={handleBarHover} onMouseLeave={handleBarLeave}>
36
+ <div className="absolute h-[10px] transition-all duration-300 ease-out group-hover:scale-101 group-hover:border group-hover:border-grey transform origin-left cursor-pointer" role="button" onClick={() => setSelectedRow(bidder?.data)} style={{
37
+ width: animate ? `${fullWidth.toFixed(0)}px` : `0px`,
38
+ backgroundColor: BAR_COLORS[bidderType],
39
+ top: `${(index + 1) * 40}px`,
40
+ left: `${bidder.startTime ? (bidder.startTime * zoom).toFixed(0) : 0}px`,
41
+ }}>
42
+ {/*Metadata*/}
43
+ <div className={classNames('absolute left-0 bottom-[-20px] w-full flex justify-between px-1 min-w-[180px]', {
44
+ hidden: (zoom < 1 || Number(fullWidth.toFixed(0)) < 200) &&
45
+ !isBarHovered,
46
+ block: (zoom < 1 || Number(fullWidth.toFixed(0)) < 200) &&
47
+ isBarHovered,
48
+ })}>
49
+ <span className="pr-2 text-xs dark:text-bright-gray flex text-nowrap">
50
+ {String(bidder.name)}
51
+ <span className="text-granite-gray dark:text-bright-gray ml-1">
52
+ {bidder.type === BidderType.NO_BID && ' (no bid)'}
53
+ {bidder.type === BidderType.BID && ' (received bid)'}
54
+ {bidder.type === BidderType.TIMED_OUT && ' (timed out)'}
55
+ </span>
56
+ {bidder.type === BidderType.WON && (<span className="flex text-granite-gray dark:text-bright-gray ">
57
+ <span>(won)</span>
58
+ <span>
59
+ <HammerIcon height="18"/>
60
+ </span>
61
+ </span>)}
62
+ </span>
63
+ <span className="text-xs dark:text-bright-gray">
64
+ {formatDuration(bidder.duration)}ms
65
+ </span>
66
+ </div>
67
+ </div>
68
+ </div>);
69
+ };
70
+ export default Bar;
71
+ //# sourceMappingURL=bar.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bar.jsx","sourceRoot":"","sources":["../../../src/components/timeline/bar.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH;;GAEG;AACH,OAAO,KAAK,EAAE,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACrD,OAAO,EAAU,UAAU,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACzE,OAAO,UAAU,MAAM,YAAY,CAAC;AAEpC;;GAEG;AACH,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAYzC,MAAM,GAAG,GAAG,CAAC,EACX,MAAM,EACN,KAAK,EACL,IAAI,EACJ,UAAU,EACV,SAAS,EACT,OAAO,EACP,cAAc,GACL,EAAE,EAAE;IACb,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAExD,MAAM,cAAc,GAAG,WAAW,CAAC,GAAG,EAAE;QACtC,eAAe,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,cAAc,GAAG,WAAW,CAAC,GAAG,EAAE;QACtC,eAAe,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,CAAC,GAAG,CACF,GAAG,CAAC,CAAC,KAAK,CAAC,CACX,SAAS,CAAC,gBAAgB,CAC1B,YAAY,CAAC,CAAC,cAAc,CAAC,CAC7B,YAAY,CAAC,CAAC,cAAc,CAAC,CAE7B;MAAA,CAAC,GAAG,CACF,SAAS,CAAC,8JAA8J,CACxK,IAAI,CAAC,QAAQ,CACb,OAAO,CAAC,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAC5C,KAAK,CAAC,CAAC;YACL,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;YACpD,eAAe,EAAE,UAAU,CAAC,UAAU,CAAC;YACvC,GAAG,EAAE,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,EAAE,IAAI;YAC5B,IAAI,EAAE,GACJ,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAC5D,IAAI;SACL,CAAC,CAEF;QAAA,CAAC,YAAY,CACb;QAAA,CAAC,GAAG,CACF,SAAS,CAAC,CAAC,UAAU,CACnB,+EAA+E,EAC/E;YACE,MAAM,EACJ,CAAC,IAAI,GAAG,CAAC,IAAI,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;gBAChD,CAAC,YAAY;YACf,KAAK,EACH,CAAC,IAAI,GAAG,CAAC,IAAI,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;gBAChD,YAAY;SACf,CACF,CAAC,CAEF;UAAA,CAAC,IAAI,CAAC,SAAS,CAAC,qDAAqD,CACnE;YAAA,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CACpB;YAAA,CAAC,IAAI,CAAC,SAAS,CAAC,8CAA8C,CAC5D;cAAA,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,MAAM,IAAI,WAAW,CACjD;cAAA,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,GAAG,IAAI,iBAAiB,CACpD;cAAA,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,SAAS,IAAI,cAAc,CACzD;YAAA,EAAE,IAAI,CACN;YAAA,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,CAAC,GAAG,IAAI,CACjC,CAAC,IAAI,CAAC,SAAS,CAAC,+CAA+C,CAC7D;gBAAA,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CACjB;gBAAA,CAAC,IAAI,CACH;kBAAA,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,EACzB;gBAAA,EAAE,IAAI,CACR;cAAA,EAAE,IAAI,CAAC,CACR,CACH;UAAA,EAAE,IAAI,CACN;UAAA,CAAC,IAAI,CAAC,SAAS,CAAC,+BAA+B,CAC7C;YAAA,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;UACnC,EAAE,IAAI,CACR;QAAA,EAAE,GAAG,CACP;MAAA,EAAE,GAAG,CACP;IAAA,EAAE,GAAG,CAAC,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,GAAG,CAAC"}
@@ -0,0 +1,29 @@
1
+ /*
2
+ * Copyright 2025 Google LLC
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * https://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ /**
17
+ * External dependencies
18
+ */
19
+ import { BidderType } from '@google-psat/common';
20
+ export const INITIAL_TIME = 50;
21
+ export const TIME_DURATION = 50;
22
+ export const BAR_HEIGHT = 50;
23
+ export const BAR_COLORS = {
24
+ [BidderType.BID]: '#7CACF8',
25
+ [BidderType.NO_BID]: '#EC7159',
26
+ [BidderType.WON]: '#5CC971',
27
+ [BidderType.TIMED_OUT]: '#FC2D04',
28
+ };
29
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/components/timeline/constants.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH;;GAEG;AACH,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,MAAM,CAAC,MAAM,YAAY,GAAG,EAAE,CAAC;AAC/B,MAAM,CAAC,MAAM,aAAa,GAAG,EAAE,CAAC;AAChC,MAAM,CAAC,MAAM,UAAU,GAAG,EAAE,CAAC;AAE7B,MAAM,CAAC,MAAM,UAAU,GAA+B;IACpD,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,SAAS;IAC3B,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,SAAS;IAC9B,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,SAAS;IAC3B,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,SAAS;CAClC,CAAC"}
@@ -0,0 +1,195 @@
1
+ /*
2
+ * Copyright 2025 Google LLC
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * https://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ /**
17
+ * External dependencies.
18
+ */
19
+ import React, { useEffect, useRef, useState, useMemo } from 'react';
20
+ import { findMaximumBidderDuration, formatDuration, BidderType, } from '@google-psat/common';
21
+ import classNames from 'classnames';
22
+ /**
23
+ * Internal dependencies.
24
+ */
25
+ import { BAR_HEIGHT, INITIAL_TIME, TIME_DURATION } from './constants';
26
+ import Bar from './bar';
27
+ const Timeline = ({ auctionTimeout, auctionId, auctionStartTimeFormatted, auctionTime, auctionEndDuration, bidders, zoomLevel = 2, setSelectedRow, navigateToAuction, }) => {
28
+ const [animate, setAnimate] = useState(false);
29
+ const [scrollWidth, setScrollWidth] = useState(0);
30
+ const containerRef = useRef(null);
31
+ const [timeoutBlockWidth, setTimeoutBlockWidth] = useState(0);
32
+ const [auctionEndBlockWidth, setAuctionEndBlockWidth] = useState(0);
33
+ const [zoom, setZoom] = useState(2);
34
+ const lineCount = useMemo(() => {
35
+ const maxDuration = Math.max(findMaximumBidderDuration(bidders), auctionTimeout);
36
+ const extraLines = 4;
37
+ if (maxDuration === 0) {
38
+ return extraLines * 2; // If no bidders, just show the timeout line
39
+ }
40
+ return maxDuration / TIME_DURATION + extraLines;
41
+ }, [bidders, auctionTimeout]);
42
+ const lines = Array.from({ length: lineCount });
43
+ const [timeoutBlock, setTimeoutBlock] = useState(auctionTimeout * zoomLevel);
44
+ const [auctionEndBlock, setAuctionEndBlock] = useState(auctionEndDuration * zoomLevel);
45
+ useEffect(() => {
46
+ const _zoom = zoomLevel;
47
+ setZoom(_zoom);
48
+ let _timeoutBlockWidth = auctionTimeout * _zoom;
49
+ let _auctionEndBlockWidth = auctionEndDuration * _zoom;
50
+ for (let i = 0; i < lines.length; i++) {
51
+ const lineWidth = TIME_DURATION * _zoom * (i + 1);
52
+ if (Math.abs(lineWidth - _timeoutBlockWidth) < 10 * _zoom) {
53
+ _timeoutBlockWidth += Math.abs(lineWidth - _timeoutBlockWidth);
54
+ }
55
+ if (Math.abs(lineWidth - _auctionEndBlockWidth) < 10 * _zoom) {
56
+ _auctionEndBlockWidth += Math.abs(lineWidth - _auctionEndBlockWidth);
57
+ }
58
+ }
59
+ const isAuctionEndBlockOverlappingTimeout = Math.abs(_auctionEndBlockWidth - _timeoutBlockWidth) <= 20;
60
+ if (isAuctionEndBlockOverlappingTimeout) {
61
+ if (_auctionEndBlockWidth > _timeoutBlockWidth) {
62
+ _auctionEndBlockWidth +=
63
+ 20 - Math.abs(_auctionEndBlockWidth - _timeoutBlockWidth);
64
+ }
65
+ else {
66
+ _timeoutBlockWidth +=
67
+ 20 - Math.abs(_auctionEndBlockWidth - _timeoutBlockWidth);
68
+ }
69
+ }
70
+ setTimeoutBlockWidth(scrollWidth - _timeoutBlockWidth);
71
+ setTimeoutBlock(_timeoutBlockWidth);
72
+ setAuctionEndBlockWidth(scrollWidth - _auctionEndBlockWidth);
73
+ setAuctionEndBlock(_auctionEndBlockWidth);
74
+ }, [
75
+ scrollWidth,
76
+ zoomLevel,
77
+ lines.length,
78
+ auctionTimeout,
79
+ auctionEndDuration,
80
+ ]);
81
+ useEffect(() => {
82
+ const timeout = setTimeout(() => {
83
+ setAnimate(true);
84
+ }, 100);
85
+ return () => clearTimeout(timeout);
86
+ }, []);
87
+ useEffect(() => {
88
+ if (containerRef.current) {
89
+ setScrollWidth(containerRef.current.scrollWidth);
90
+ }
91
+ }, [containerRef, bidders, auctionTimeout]);
92
+ const childHeight = Math.max((bidders?.length ?? 0) * BAR_HEIGHT, 200) + (zoom <= 1 ? 32 : 0);
93
+ return (<div className="mb-4">
94
+ <header className="flex justify-between text-sm dark:text-bright-gray font-semibold">
95
+ <p>Auction Start: {auctionStartTimeFormatted}</p>
96
+ <p>Auction Time: {auctionTime}ms</p>
97
+ </header>
98
+ <div ref={containerRef} className="min-h-[200px] border-pale-cornflower-blue border-1 mt-2 relative overflow-auto" style={{ height: bidders ? bidders.length * BAR_HEIGHT : '200px' }}>
99
+ {/*Vertical Columns*/}
100
+ <div className="flex" style={{
101
+ height: childHeight,
102
+ }}>
103
+ {lines.map((_, index) => {
104
+ const spanClasses = classNames('absolute right-0 block text-xs dark:text-bright-gray mt-1', {
105
+ 'pr-2': zoom > 1,
106
+ 'rotate-180': zoom <= 1,
107
+ });
108
+ return (<div className="border-pale-cornflower-blue border-r-1 h-full shrink-[0] grow-[0] relative transition-all duration-300 ease-out" style={{ flexBasis: `${TIME_DURATION * zoom}px` }} key={index}>
109
+ {Array.from({ length: TIME_DURATION / 10 - 1 }).map((__, subIndex) => {
110
+ const lineClasses = classNames('absolute w-[1px] border-r border-dotted h-full transition-all duration-300 ease-out', 'border-sky-100 dark:border-gray-800');
111
+ return (<div key={subIndex} className={lineClasses} style={{
112
+ left: `${(subIndex + 1) * (zoom * 10)}px`,
113
+ top: '0',
114
+ }}></div>);
115
+ })}
116
+ <span className={spanClasses} style={{
117
+ writingMode: zoom <= 1 ? 'vertical-rl' : undefined,
118
+ }}>
119
+ {INITIAL_TIME + index * TIME_DURATION}ms
120
+ </span>
121
+ </div>);
122
+ })}
123
+ </div>
124
+
125
+ {/*Timeout block*/}
126
+ <div className="absolute flex top-0" style={{
127
+ height: childHeight,
128
+ width: lines.length * TIME_DURATION * zoom,
129
+ }}>
130
+ <div style={{
131
+ width: `${(auctionTimeout * zoom).toFixed(0)}px`,
132
+ }}></div>
133
+ <div className="h-full relative flex-1" style={{ width: `${timeoutBlockWidth}px` }}>
134
+ <div className="bg-[#E90303] opacity-[9%] w-full h-full"></div>
135
+ <span className="absolute top-1/2 -translate-y-1/2 rotate-180 text-xs text-[#828282] dark:text-gray h-full flex items-center justify-center" style={{
136
+ writingMode: 'vertical-rl',
137
+ left: `${Math.abs(timeoutBlock - auctionTimeout * zoom)}px`,
138
+ }}>
139
+ Timeout: {auctionTimeout}ms
140
+ </span>
141
+ </div>
142
+ </div>
143
+
144
+ {/*Auction-End block*/}
145
+ <div className="absolute flex top-0" style={{
146
+ height: childHeight,
147
+ width: lines.length * TIME_DURATION * zoom,
148
+ }}>
149
+ <div style={{ width: `${(auctionEndDuration * zoom).toFixed(0)}px` }} className="h-full"></div>
150
+ <div className="h-full relative flex-1" style={{ width: `${auctionEndBlockWidth}px` }}>
151
+ <div className="bg-[#E90303] opacity-[4%] w-full h-full"></div>
152
+ <span className="absolute top-1/2 -translate-y-1/2 rotate-180 text-xs text-[#828282] dark:text-gray h-full flex items-center justify-center" style={{
153
+ writingMode: 'vertical-rl',
154
+ left: `${Math.abs(auctionEndBlock - auctionEndDuration * zoom)}px`,
155
+ }}>
156
+ Auction End: {formatDuration(String(auctionEndDuration))}ms
157
+ </span>
158
+ </div>
159
+ </div>
160
+
161
+ {/*Bars Block*/}
162
+ <div className={classNames('absolute left-0 w-full h-full', {
163
+ 'top-8': zoom <= 1,
164
+ 'top-0': zoom > 1,
165
+ })}>
166
+ <div className="relative">
167
+ {bidders &&
168
+ bidders.map((bidder, index) => {
169
+ const fullWidth = parseFloat(bidder.duration) * zoom;
170
+ const bidderType = bidder.type === BidderType.NO_BID &&
171
+ Number(bidder.duration) > auctionTimeout
172
+ ? BidderType.TIMED_OUT
173
+ : bidder.type;
174
+ return (<React.Fragment key={index}>
175
+ <Bar bidder={bidder} index={index} zoom={zoom} bidderType={bidderType} fullWidth={fullWidth} animate={animate} setSelectedRow={setSelectedRow}/>
176
+ </React.Fragment>);
177
+ })}
178
+ </div>
179
+ </div>
180
+ </div>
181
+ <footer>
182
+ <p className="text-sm text-right my-1 dark:text-bright-gray">
183
+ Auction ID:{' '}
184
+ <a onClick={(event) => {
185
+ event.preventDefault();
186
+ navigateToAuction(auctionId);
187
+ }} className="underline" href="#">
188
+ {auctionId}
189
+ </a>
190
+ </p>
191
+ </footer>
192
+ </div>);
193
+ };
194
+ export default Timeline;
195
+ //# sourceMappingURL=index.jsx.map