@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.
- package/dist/components/breadcrumbs/index.jsx +10 -15
- package/dist/components/breadcrumbs/index.jsx.map +1 -1
- package/dist/components/bulletList/index.jsx +6 -14
- package/dist/components/bulletList/index.jsx.map +1 -1
- package/dist/components/bulletList/listRow.jsx +19 -40
- package/dist/components/bulletList/listRow.jsx.map +1 -1
- package/dist/components/button/index.jsx +17 -16
- package/dist/components/button/index.jsx.map +1 -1
- package/dist/components/chipsBar/chip.jsx +5 -10
- package/dist/components/chipsBar/chip.jsx.map +1 -1
- package/dist/components/chipsBar/chipsList.jsx +4 -9
- package/dist/components/chipsBar/chipsList.jsx.map +1 -1
- package/dist/components/chipsBar/index.jsx +12 -14
- package/dist/components/chipsBar/index.jsx.map +1 -1
- package/dist/components/circle/circleEmpty.jsx +4 -9
- package/dist/components/circle/circleEmpty.jsx.map +1 -1
- package/dist/components/circle/index.jsx +3 -8
- package/dist/components/circle/index.jsx.map +1 -1
- package/dist/components/circlePieChart/emptyCirclePieChart.jsx +9 -12
- package/dist/components/circlePieChart/emptyCirclePieChart.jsx.map +1 -1
- package/dist/components/circlePieChart/index.jsx +18 -21
- package/dist/components/circlePieChart/index.jsx.map +1 -1
- package/dist/components/circlePieChart/tooltip.jsx +26 -0
- package/dist/components/circlePieChart/tooltip.jsx.map +1 -0
- package/dist/components/cookieDetails/details.jsx +76 -105
- package/dist/components/cookieDetails/details.jsx.map +1 -1
- package/dist/components/cookieDetails/index.jsx +8 -13
- package/dist/components/cookieDetails/index.jsx.map +1 -1
- package/dist/components/cookieTable/index.jsx +32 -57
- package/dist/components/cookieTable/index.jsx.map +1 -1
- package/dist/components/cookieTable/utils/conditionalTableRowClassesHandler.js +14 -19
- package/dist/components/cookieTable/utils/conditionalTableRowClassesHandler.js.map +1 -1
- package/dist/components/cookieTable/utils/exportCookies.js +6 -8
- package/dist/components/cookieTable/utils/exportCookies.js.map +1 -1
- package/dist/components/cookieTable/utils/index.js +2 -10
- package/dist/components/cookieTable/utils/index.js.map +1 -1
- package/dist/components/cookiesLanding/cookiesLandingWrapper.jsx +6 -11
- package/dist/components/cookiesLanding/cookiesLandingWrapper.jsx.map +1 -1
- package/dist/components/cookiesLanding/cookiesMatrix/index.jsx +19 -20
- package/dist/components/cookiesLanding/cookiesMatrix/index.jsx.map +1 -1
- package/dist/components/cookiesLanding/index.jsx +2 -7
- package/dist/components/cookiesLanding/index.jsx.map +1 -1
- package/dist/components/cookiesLanding/landingHeader/index.jsx +11 -18
- package/dist/components/cookiesLanding/landingHeader/index.jsx.map +1 -1
- package/dist/components/cookiesLanding/useFiltersMapping.jsx +13 -11
- package/dist/components/cookiesLanding/useFiltersMapping.jsx.map +1 -1
- package/dist/components/cookiesLanding/useGlobalFiltering.jsx +77 -83
- package/dist/components/cookiesLanding/useGlobalFiltering.jsx.map +1 -1
- package/dist/components/draggableTray/index.jsx +36 -52
- package/dist/components/draggableTray/index.jsx.map +1 -1
- package/dist/components/dropdown/index.jsx +30 -0
- package/dist/components/dropdown/index.jsx.map +1 -0
- package/dist/components/dropdown/options.jsx +41 -0
- package/dist/components/dropdown/options.jsx.map +1 -0
- package/dist/components/errorFallback/extensionReloadNotification.jsx +5 -11
- package/dist/components/errorFallback/extensionReloadNotification.jsx.map +1 -1
- package/dist/components/errorFallback/index.jsx +6 -11
- package/dist/components/errorFallback/index.jsx.map +1 -1
- package/dist/components/exportButton/index.jsx +7 -12
- package/dist/components/exportButton/index.jsx.map +1 -1
- package/dist/components/filtersSidebar/index.jsx +14 -42
- package/dist/components/filtersSidebar/index.jsx.map +1 -1
- package/dist/components/filtersSidebar/listItem.jsx +20 -50
- package/dist/components/filtersSidebar/listItem.jsx.map +1 -1
- package/dist/components/filtersSidebar/option.jsx +6 -34
- package/dist/components/filtersSidebar/option.jsx.map +1 -1
- package/dist/components/filtersSidebar/subList.jsx +9 -37
- package/dist/components/filtersSidebar/subList.jsx.map +1 -1
- package/dist/components/frameContent/index.jsx +5 -10
- package/dist/components/frameContent/index.jsx.map +1 -1
- package/dist/components/index.js +60 -119
- package/dist/components/index.js.map +1 -1
- package/dist/components/inspectButton/index.jsx +7 -12
- package/dist/components/inspectButton/index.jsx.map +1 -1
- package/dist/components/jsonView/index.js +1 -8
- package/dist/components/jsonView/index.js.map +1 -1
- package/dist/components/jsonView/jsonTheme.js +1 -5
- package/dist/components/jsonView/jsonTheme.js.map +1 -1
- package/dist/components/jsonView/jsonView.jsx +11 -41
- package/dist/components/jsonView/jsonView.jsx.map +1 -1
- package/dist/components/landingPage/LandingPage.jsx +32 -64
- package/dist/components/landingPage/LandingPage.jsx.map +1 -1
- package/dist/components/landingPage/cardsPanel.jsx +33 -44
- package/dist/components/landingPage/cardsPanel.jsx.map +1 -1
- package/dist/components/landingPage/constants.js +1 -4
- package/dist/components/landingPage/constants.js.map +1 -1
- package/dist/components/landingPage/contentPanel.jsx +27 -28
- package/dist/components/landingPage/contentPanel.jsx.map +1 -1
- package/dist/components/landingPage/getStoryPlayerMarkup.js +3 -8
- package/dist/components/landingPage/getStoryPlayerMarkup.js.map +1 -1
- package/dist/components/landingPage/index.jsx +23 -47
- package/dist/components/landingPage/index.jsx.map +1 -1
- package/dist/components/landingPage/infoCard/fetchPSInfo.js +7 -21
- package/dist/components/landingPage/infoCard/fetchPSInfo.js.map +1 -1
- package/dist/components/landingPage/infoCard/index.jsx +28 -58
- package/dist/components/landingPage/infoCard/index.jsx.map +1 -1
- package/dist/components/landingPage/infoCard/learnMoreDropdown.jsx +13 -17
- package/dist/components/landingPage/infoCard/learnMoreDropdown.jsx.map +1 -1
- package/dist/components/landingPage/infoCard/renderLink.jsx +5 -10
- package/dist/components/landingPage/infoCard/renderLink.jsx.map +1 -1
- package/dist/components/landingPage/quickLinksList.jsx +29 -64
- package/dist/components/landingPage/quickLinksList.jsx.map +1 -1
- package/dist/components/landingPage/supportLink.jsx +8 -13
- package/dist/components/landingPage/supportLink.jsx.map +1 -1
- package/dist/components/link/index.jsx +7 -41
- package/dist/components/link/index.jsx.map +1 -1
- package/dist/components/linkProcessor/index.jsx +13 -41
- package/dist/components/linkProcessor/index.jsx.map +1 -1
- package/dist/components/matrix/index.jsx +10 -13
- package/dist/components/matrix/index.jsx.map +1 -1
- package/dist/components/matrix/matrixComponent/index.jsx +6 -11
- package/dist/components/matrix/matrixComponent/index.jsx.map +1 -1
- package/dist/components/matrix/matrixComponent/matrixComponentHorizontal.jsx +4 -9
- package/dist/components/matrix/matrixComponent/matrixComponentHorizontal.jsx.map +1 -1
- package/dist/components/matrixContainer/index.jsx +15 -43
- package/dist/components/matrixContainer/index.jsx.map +1 -1
- package/dist/components/menuBar/index.jsx +31 -69
- package/dist/components/menuBar/index.jsx.map +1 -1
- package/dist/components/menuBar/utils/index.js +1 -8
- package/dist/components/menuBar/utils/index.js.map +1 -1
- package/dist/components/menuBar/utils/isElementInView.js +1 -4
- package/dist/components/menuBar/utils/isElementInView.js.map +1 -1
- package/dist/components/messageBox/index.jsx +8 -11
- package/dist/components/messageBox/index.jsx.map +1 -1
- package/dist/components/multiSelectDropDown/index.jsx +143 -0
- package/dist/components/multiSelectDropDown/index.jsx.map +1 -0
- package/dist/components/pill/index.jsx +2 -7
- package/dist/components/pill/index.jsx.map +1 -1
- package/dist/components/pillToggle/index.jsx +60 -24
- package/dist/components/pillToggle/index.jsx.map +1 -1
- package/dist/components/progressBar/borderProgressbar.jsx +2 -7
- package/dist/components/progressBar/borderProgressbar.jsx.map +1 -1
- package/dist/components/progressBar/index.jsx +2 -7
- package/dist/components/progressBar/index.jsx.map +1 -1
- package/dist/components/refreshButton/index.jsx +5 -10
- package/dist/components/refreshButton/index.jsx.map +1 -1
- package/dist/components/resizableTray/index.jsx +74 -0
- package/dist/components/resizableTray/index.jsx.map +1 -0
- package/dist/components/searchInput/index.jsx +20 -46
- package/dist/components/searchInput/index.jsx.map +1 -1
- package/dist/components/sidebar/collapsedSidebar.jsx +19 -47
- package/dist/components/sidebar/collapsedSidebar.jsx.map +1 -1
- package/dist/components/sidebar/expandedSidebar.jsx +19 -50
- package/dist/components/sidebar/expandedSidebar.jsx.map +1 -1
- package/dist/components/sidebar/index.js +3 -24
- package/dist/components/sidebar/index.js.map +1 -1
- package/dist/components/sidebar/sidebar.jsx +10 -15
- package/dist/components/sidebar/sidebar.jsx.map +1 -1
- package/dist/components/sidebar/sidebarChild.jsx +38 -53
- package/dist/components/sidebar/sidebarChild.jsx.map +1 -1
- package/dist/components/sidebar/useSidebar/constants.js +4 -5
- package/dist/components/sidebar/useSidebar/constants.js.map +1 -1
- package/dist/components/sidebar/useSidebar/context.js +9 -12
- package/dist/components/sidebar/useSidebar/context.js.map +1 -1
- package/dist/components/sidebar/useSidebar/index.js +3 -19
- package/dist/components/sidebar/useSidebar/index.js.map +1 -1
- package/dist/components/sidebar/useSidebar/provider.jsx +77 -100
- package/dist/components/sidebar/useSidebar/provider.jsx.map +1 -1
- package/dist/components/sidebar/useSidebar/types.js +1 -2
- package/dist/components/sidebar/useSidebar/types.js.map +1 -1
- package/dist/components/sidebar/useSidebar/useSidebar.jsx +4 -7
- package/dist/components/sidebar/useSidebar/useSidebar.jsx.map +1 -1
- package/dist/components/sidebar/useSidebar/utils/createKeyPath.js +3 -8
- package/dist/components/sidebar/useSidebar/utils/createKeyPath.js.map +1 -1
- package/dist/components/sidebar/useSidebar/utils/findItem.js +11 -9
- package/dist/components/sidebar/useSidebar/utils/findItem.js.map +1 -1
- package/dist/components/sidebar/useSidebar/utils/findKeyParent.js +1 -3
- package/dist/components/sidebar/useSidebar/utils/findKeyParent.js.map +1 -1
- package/dist/components/sidebar/useSidebar/utils/findNextItem.js +7 -12
- package/dist/components/sidebar/useSidebar/utils/findNextItem.js.map +1 -1
- package/dist/components/sidebar/useSidebar/utils/findPrevItem.js +6 -11
- package/dist/components/sidebar/useSidebar/utils/findPrevItem.js.map +1 -1
- package/dist/components/sidebar/useSidebar/utils/index.js +6 -18
- package/dist/components/sidebar/useSidebar/utils/index.js.map +1 -1
- package/dist/components/sidebar/useSidebar/utils/matchKey.js +1 -3
- package/dist/components/sidebar/useSidebar/utils/matchKey.js.map +1 -1
- package/dist/components/slider/index.jsx +29 -0
- package/dist/components/slider/index.jsx.map +1 -0
- package/dist/components/table/components/columnMenu/columnList.jsx +7 -35
- package/dist/components/table/components/columnMenu/columnList.jsx.map +1 -1
- package/dist/components/table/components/columnMenu/columnListItem.jsx +4 -9
- package/dist/components/table/components/columnMenu/columnListItem.jsx.map +1 -1
- package/dist/components/table/components/columnMenu/index.jsx +32 -46
- package/dist/components/table/components/columnMenu/index.jsx.map +1 -1
- package/dist/components/table/components/filtersSidebar/chips/index.jsx +4 -9
- package/dist/components/table/components/filtersSidebar/chips/index.jsx.map +1 -1
- package/dist/components/table/components/filtersSidebar/index.jsx +7 -35
- package/dist/components/table/components/filtersSidebar/index.jsx.map +1 -1
- package/dist/components/table/components/index.jsx +58 -71
- package/dist/components/table/components/index.jsx.map +1 -1
- package/dist/components/table/components/tableBody/bodyCell.jsx +22 -22
- package/dist/components/table/components/tableBody/bodyCell.jsx.map +1 -1
- package/dist/components/table/components/tableBody/bodyRow.jsx +33 -57
- package/dist/components/table/components/tableBody/bodyRow.jsx.map +1 -1
- package/dist/components/table/components/tableBody/index.jsx +39 -60
- package/dist/components/table/components/tableBody/index.jsx.map +1 -1
- package/dist/components/table/components/tableHeader/headerCell.jsx +25 -52
- package/dist/components/table/components/tableHeader/headerCell.jsx.map +1 -1
- package/dist/components/table/components/tableHeader/headerResizer.jsx +2 -7
- package/dist/components/table/components/tableHeader/headerResizer.jsx.map +1 -1
- package/dist/components/table/components/tableHeader/headerRow.jsx +8 -13
- package/dist/components/table/components/tableHeader/headerRow.jsx.map +1 -1
- package/dist/components/table/components/tableHeader/index.jsx +7 -35
- package/dist/components/table/components/tableHeader/index.jsx.map +1 -1
- package/dist/components/table/components/tableTopBar/index.jsx +10 -15
- package/dist/components/table/components/tableTopBar/index.jsx.map +1 -1
- package/dist/components/table/index.js +11 -38
- package/dist/components/table/index.js.map +1 -1
- package/dist/components/table/persistentSettingsStore/index.jsx +28 -69
- package/dist/components/table/persistentSettingsStore/index.jsx.map +1 -1
- package/dist/components/table/persistentSettingsStore/utils/extractStorage.js +8 -19
- package/dist/components/table/persistentSettingsStore/utils/extractStorage.js.map +1 -1
- package/dist/components/table/persistentSettingsStore/utils/index.js +2 -10
- package/dist/components/table/persistentSettingsStore/utils/index.js.map +1 -1
- package/dist/components/table/persistentSettingsStore/utils/updateStorage.js +24 -32
- package/dist/components/table/persistentSettingsStore/utils/updateStorage.js.map +1 -1
- package/dist/components/table/useTable/context.js +19 -18
- package/dist/components/table/useTable/context.js.map +1 -1
- package/dist/components/table/useTable/index.js +3 -19
- package/dist/components/table/useTable/index.js.map +1 -1
- package/dist/components/table/useTable/provider.jsx +78 -62
- package/dist/components/table/useTable/provider.jsx.map +1 -1
- package/dist/components/table/useTable/types.js +1 -2
- package/dist/components/table/useTable/useColumnResizing/index.jsx +237 -125
- package/dist/components/table/useTable/useColumnResizing/index.jsx.map +1 -1
- package/dist/components/table/useTable/useColumnSorting/index.jsx +16 -20
- package/dist/components/table/useTable/useColumnSorting/index.jsx.map +1 -1
- package/dist/components/table/useTable/useColumnVisibility/index.jsx +22 -24
- package/dist/components/table/useTable/useColumnVisibility/index.jsx.map +1 -1
- package/dist/components/table/useTable/useFiltering/hooks/index.js +3 -12
- package/dist/components/table/useTable/useFiltering/hooks/index.js.map +1 -1
- package/dist/components/table/useTable/useFiltering/hooks/useFiltersExtraction.jsx +44 -39
- package/dist/components/table/useTable/useFiltering/hooks/useFiltersExtraction.jsx.map +1 -1
- package/dist/components/table/useTable/useFiltering/hooks/useFiltersOptions.jsx +14 -16
- package/dist/components/table/useTable/useFiltering/hooks/useFiltersOptions.jsx.map +1 -1
- package/dist/components/table/useTable/useFiltering/hooks/useFiltersPersistence.jsx +39 -25
- package/dist/components/table/useTable/useFiltering/hooks/useFiltersPersistence.jsx.map +1 -1
- package/dist/components/table/useTable/useFiltering/index.jsx +58 -47
- package/dist/components/table/useTable/useFiltering/index.jsx.map +1 -1
- package/dist/components/table/useTable/useSearch/index.jsx +11 -13
- package/dist/components/table/useTable/useSearch/index.jsx.map +1 -1
- package/dist/components/table/useTable/useTable.jsx +4 -7
- package/dist/components/table/useTable/useTable.jsx.map +1 -1
- package/dist/components/table/utils/index.js +1 -17
- package/dist/components/table/utils/index.js.map +1 -1
- package/dist/components/table/utils/precalculatedFiltersUtils/calculateBlockedReasonsFilterValues.js +5 -7
- package/dist/components/table/utils/precalculatedFiltersUtils/calculateBlockedReasonsFilterValues.js.map +1 -1
- package/dist/components/table/utils/precalculatedFiltersUtils/calculateDynamicFilterValues.js +6 -8
- package/dist/components/table/utils/precalculatedFiltersUtils/calculateDynamicFilterValues.js.map +1 -1
- package/dist/components/table/utils/precalculatedFiltersUtils/calculateExemptionReasons.js +2 -4
- package/dist/components/table/utils/precalculatedFiltersUtils/calculateExemptionReasons.js.map +1 -1
- package/dist/components/table/utils/precalculatedFiltersUtils/evaluateSelectAllOption.js +5 -8
- package/dist/components/table/utils/precalculatedFiltersUtils/evaluateSelectAllOption.js.map +1 -1
- package/dist/components/table/utils/precalculatedFiltersUtils/evaluateStaticFilterValues.js +3 -6
- package/dist/components/table/utils/precalculatedFiltersUtils/evaluateStaticFilterValues.js.map +1 -1
- package/dist/components/table/utils/precalculatedFiltersUtils/index.js +5 -16
- package/dist/components/table/utils/precalculatedFiltersUtils/index.js.map +1 -1
- package/dist/components/tabs/index.jsx +132 -75
- package/dist/components/tabs/index.jsx.map +1 -1
- package/dist/components/tabs/useTabs/context.js +12 -9
- package/dist/components/tabs/useTabs/context.js.map +1 -1
- package/dist/components/tabs/useTabs/index.js +3 -19
- package/dist/components/tabs/useTabs/index.js.map +1 -1
- package/dist/components/tabs/useTabs/provider.jsx +144 -62
- package/dist/components/tabs/useTabs/provider.jsx.map +1 -1
- package/dist/components/tabs/useTabs/types.js +1 -2
- package/dist/components/tabs/useTabs/useTabs.jsx +4 -7
- package/dist/components/tabs/useTabs/useTabs.jsx.map +1 -1
- package/dist/components/timeline/bar.jsx +71 -0
- package/dist/components/timeline/bar.jsx.map +1 -0
- package/dist/components/timeline/constants.js +29 -0
- package/dist/components/timeline/constants.js.map +1 -0
- package/dist/components/timeline/index.jsx +195 -0
- package/dist/components/timeline/index.jsx.map +1 -0
- package/dist/components/toastMessage/index.jsx +2 -7
- package/dist/components/toastMessage/index.jsx.map +1 -1
- package/dist/components/toggleSwitch/index.jsx +2 -7
- package/dist/components/toggleSwitch/index.jsx.map +1 -1
- package/dist/components/topbar/index.jsx +13 -41
- package/dist/components/topbar/index.jsx.map +1 -1
- package/dist/constants.js +9 -12
- package/dist/constants.js.map +1 -1
- package/dist/icons/index.jsx +118 -225
- package/dist/icons/index.jsx.map +1 -1
- package/dist/icons/ps-icons/index.js +12 -30
- package/dist/icons/ps-icons/index.js.map +1 -1
- package/dist/index.js +5 -21
- package/dist/index.js.map +1 -1
- package/dist/test-data/cookieMockData.js +44 -22
- package/dist/test-data/cookieMockData.js.map +1 -1
- package/dist/test-data/cookieStats.js +1 -3
- package/dist/test-data/cookieStats.js.map +1 -1
- package/dist/test-data/cookieTableBody.js +9 -14
- package/dist/test-data/cookieTableBody.js.map +1 -1
- package/dist/test-data/cookieTableMockData.jsx +18 -24
- package/dist/test-data/cookieTableMockData.jsx.map +1 -1
- package/dist/test-data/cookiesStatsComponents.js +1 -3
- package/dist/test-data/cookiesStatsComponents.js.map +1 -1
- package/dist/theme/colors.js +1 -4
- package/dist/theme/colors.js.map +1 -1
- package/dist/utils/index.js +6 -18
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/noop.js +1 -5
- package/dist/utils/noop.js.map +1 -1
- package/dist/utils/prepareCookieDataMapping.js +7 -10
- package/dist/utils/prepareCookieDataMapping.js.map +1 -1
- package/dist/utils/prepareCookieStatsComponents.js +29 -33
- package/dist/utils/prepareCookieStatsComponents.js.map +1 -1
- package/dist/utils/prepareCookiesCount.js +12 -25
- package/dist/utils/prepareCookiesCount.js.map +1 -1
- package/dist/utils/prepareFrameStatsComponent.js +19 -24
- package/dist/utils/prepareFrameStatsComponent.js.map +1 -1
- package/dist/utils/prepareFrameStatsComponentForExtensionDashboard.js +16 -21
- package/dist/utils/prepareFrameStatsComponentForExtensionDashboard.js.map +1 -1
- package/dist-types/components/button/index.d.ts +2 -1
- package/dist-types/components/chipsBar/index.d.ts +1 -1
- package/dist-types/components/circlePieChart/emptyCirclePieChart.d.ts +4 -1
- package/dist-types/components/circlePieChart/index.d.ts +3 -1
- package/dist-types/components/circlePieChart/tooltip.d.ts +8 -0
- package/dist-types/components/draggableTray/index.d.ts +4 -0
- package/dist-types/components/dropdown/index.d.ts +18 -0
- package/dist-types/components/dropdown/options.d.ts +20 -0
- package/dist-types/components/index.d.ts +7 -0
- package/dist-types/components/landingPage/LandingPage.d.ts +2 -5
- package/dist-types/components/landingPage/cardsPanel.d.ts +7 -8
- package/dist-types/components/landingPage/contentPanel.d.ts +1 -1
- package/dist-types/components/landingPage/infoCard/fetchPSInfo.d.ts +2 -0
- package/dist-types/components/landingPage/infoCard/index.d.ts +2 -1
- package/dist-types/components/link/index.d.ts +2 -1
- package/dist-types/components/messageBox/index.d.ts +5 -1
- package/dist-types/components/multiSelectDropDown/index.d.ts +14 -0
- package/dist-types/components/pillToggle/index.d.ts +8 -5
- package/dist-types/components/resizableTray/index.d.ts +15 -0
- package/dist-types/components/searchInput/index.d.ts +4 -1
- package/dist-types/components/sidebar/expandedSidebar.d.ts +2 -1
- package/dist-types/components/sidebar/sidebar.d.ts +2 -1
- package/dist-types/components/sidebar/sidebarChild.d.ts +2 -1
- package/dist-types/components/sidebar/useSidebar/constants.d.ts +3 -1
- package/dist-types/components/sidebar/useSidebar/context.d.ts +6 -2
- package/dist-types/components/sidebar/useSidebar/types.d.ts +2 -0
- package/dist-types/components/sidebar/useSidebar/utils/findItem.d.ts +2 -1
- package/dist-types/components/slider/index.d.ts +14 -0
- package/dist-types/components/table/components/index.d.ts +4 -2
- package/dist-types/components/table/components/tableBody/bodyCell.d.ts +5 -2
- package/dist-types/components/table/components/tableBody/bodyRow.d.ts +3 -2
- package/dist-types/components/table/components/tableBody/index.d.ts +3 -2
- package/dist-types/components/table/components/tableHeader/headerCell.d.ts +4 -2
- package/dist-types/components/table/components/tableTopBar/index.d.ts +2 -1
- package/dist-types/components/table/persistentSettingsStore/index.d.ts +1 -1
- package/dist-types/components/table/useTable/context.d.ts +13 -5
- package/dist-types/components/table/useTable/provider.d.ts +1 -1
- package/dist-types/components/table/useTable/types.d.ts +47 -4
- package/dist-types/components/table/useTable/useColumnResizing/index.d.ts +11 -9
- package/dist-types/components/table/useTable/useFiltering/index.d.ts +1 -1
- package/dist-types/components/tabs/index.d.ts +1 -1
- package/dist-types/components/tabs/useTabs/context.d.ts +11 -1
- package/dist-types/components/tabs/useTabs/provider.d.ts +2 -2
- package/dist-types/components/tabs/useTabs/types.d.ts +8 -3
- package/dist-types/components/timeline/bar.d.ts +16 -0
- package/dist-types/components/timeline/constants.d.ts +8 -0
- package/dist-types/components/timeline/index.d.ts +12 -0
- package/dist-types/icons/index.d.ts +117 -101
- package/dist-types/icons/ps-icons/index.d.ts +12 -12
- package/package.json +12 -7
- package/tsconfig.json +5 -3
- package/dist/components/button/stories/Button.stories.jsx +0 -23
- package/dist/components/button/stories/Button.stories.jsx.map +0 -1
- package/dist/components/circle/stories/circle.stories.jsx +0 -26
- package/dist/components/circle/stories/circle.stories.jsx.map +0 -1
- package/dist/components/circle/stories/circleEmpty.stories.jsx +0 -18
- package/dist/components/circle/stories/circleEmpty.stories.jsx.map +0 -1
- package/dist/components/circlePieChart/stories/circlePieChart.stories.jsx +0 -91
- package/dist/components/circlePieChart/stories/circlePieChart.stories.jsx.map +0 -1
- package/dist/components/circlePieChart/stories/emptyCirclePieChart.stories.jsx +0 -48
- package/dist/components/circlePieChart/stories/emptyCirclePieChart.stories.jsx.map +0 -1
- package/dist/components/cookieDetails/stories/cookieDetails.stories.js +0 -30
- package/dist/components/cookieDetails/stories/cookieDetails.stories.js.map +0 -1
- package/dist/components/cookieDetails/stories/details.stories.js +0 -30
- package/dist/components/cookieDetails/stories/details.stories.js.map +0 -1
- package/dist/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.jsx +0 -59
- package/dist/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.jsx.map +0 -1
- package/dist/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.jsx +0 -40
- package/dist/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.jsx.map +0 -1
- package/dist/components/cookiesLanding/stories/cookiesLanding.stories.jsx +0 -20
- package/dist/components/cookiesLanding/stories/cookiesLanding.stories.jsx.map +0 -1
- package/dist/components/errorFallback/stories/errorFallback.stories.jsx +0 -31
- package/dist/components/errorFallback/stories/errorFallback.stories.jsx.map +0 -1
- package/dist/components/errorFallback/stories/extensionReloadNotification.stories.jsx +0 -20
- package/dist/components/errorFallback/stories/extensionReloadNotification.stories.jsx.map +0 -1
- package/dist/components/matrix/matrixComponent/stories/MatrixComponent.stories.jsx +0 -27
- package/dist/components/matrix/matrixComponent/stories/MatrixComponent.stories.jsx.map +0 -1
- package/dist/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.jsx +0 -25
- package/dist/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.jsx.map +0 -1
- package/dist/components/matrix/stories/matrix.stories.jsx +0 -59
- package/dist/components/matrix/stories/matrix.stories.jsx.map +0 -1
- package/dist/components/messageBox/stories/messageBox.stories.jsx +0 -23
- package/dist/components/messageBox/stories/messageBox.stories.jsx.map +0 -1
- package/dist/components/progressBar/stories/progressBar.stories.jsx +0 -22
- package/dist/components/progressBar/stories/progressBar.stories.jsx.map +0 -1
- package/dist/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.js +0 -61
- package/dist/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.js.map +0 -1
- package/dist/components/table/useTable/useColumnResizing/resizeColumns.js +0 -54
- package/dist/components/table/useTable/useColumnResizing/resizeColumns.js.map +0 -1
- package/dist-types/components/button/stories/Button.stories.d.ts +0 -11
- package/dist-types/components/circle/stories/circle.stories.d.ts +0 -11
- package/dist-types/components/circle/stories/circleEmpty.stories.d.ts +0 -11
- package/dist-types/components/circlePieChart/stories/circlePieChart.stories.d.ts +0 -9
- package/dist-types/components/circlePieChart/stories/emptyCirclePieChart.stories.d.ts +0 -9
- package/dist-types/components/cookieDetails/stories/cookieDetails.stories.d.ts +0 -12
- package/dist-types/components/cookieDetails/stories/details.stories.d.ts +0 -12
- package/dist-types/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.d.ts +0 -11
- package/dist-types/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.d.ts +0 -11
- package/dist-types/components/cookiesLanding/stories/cookiesLanding.stories.d.ts +0 -11
- package/dist-types/components/errorFallback/stories/errorFallback.stories.d.ts +0 -12
- package/dist-types/components/errorFallback/stories/extensionReloadNotification.stories.d.ts +0 -11
- package/dist-types/components/matrix/matrixComponent/stories/MatrixComponent.stories.d.ts +0 -11
- package/dist-types/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.d.ts +0 -11
- package/dist-types/components/matrix/stories/matrix.stories.d.ts +0 -11
- package/dist-types/components/messageBox/stories/messageBox.stories.d.ts +0 -11
- package/dist-types/components/progressBar/stories/progressBar.stories.d.ts +0 -11
- package/dist-types/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.d.ts +0 -7
- 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
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
const
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
const
|
|
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
|
|
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(
|
|
101
|
+
next[_index] = JSON.stringify({
|
|
102
|
+
...currentData,
|
|
103
|
+
...incomingData,
|
|
104
|
+
});
|
|
79
105
|
}
|
|
80
106
|
return next;
|
|
81
107
|
});
|
|
82
108
|
}, [activeTab]);
|
|
83
|
-
const highlightTab =
|
|
84
|
-
if (tab ===
|
|
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 =
|
|
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 =
|
|
95
|
-
|
|
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
|
-
|
|
99
|
-
if (highlightedTabs[
|
|
123
|
+
useEffect(() => {
|
|
124
|
+
if (highlightedTabs[activeTab]) {
|
|
100
125
|
setHighlightedTabs((prev) => {
|
|
101
|
-
const next =
|
|
102
|
-
next[
|
|
126
|
+
const next = { ...prev };
|
|
127
|
+
next[activeTab] = false;
|
|
103
128
|
return next;
|
|
104
129
|
});
|
|
105
130
|
}
|
|
106
131
|
}, [activeTab, highlightTab, highlightedTabs]);
|
|
107
|
-
const shouldAddSpacer =
|
|
108
|
-
return Boolean(tabItems[index]
|
|
132
|
+
const shouldAddSpacer = useCallback((index) => {
|
|
133
|
+
return Boolean(tabItems[index]?.addSpacer);
|
|
109
134
|
}, [tabItems]);
|
|
110
|
-
|
|
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
|
-
</
|
|
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":"
|
|
1
|
+
{"version":3,"file":"provider.jsx","sourceRoot":"","sources":["../../../../src/components/tabs/useTabs/provider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -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
|
-
|
|
19
|
+
import { useContextSelector } from '@google-psat/common';
|
|
23
20
|
/**
|
|
24
21
|
* Internal dependencies.
|
|
25
22
|
*/
|
|
26
|
-
|
|
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
|
|
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":"
|
|
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":"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"}
|
|
@@ -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
|