@google-psat/design-system 0.9.0-1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (430) hide show
  1. package/.eslintrc.json +6 -0
  2. package/README.md +4 -0
  3. package/dist/components/bulletList/index.jsx +51 -0
  4. package/dist/components/bulletList/index.jsx.map +1 -0
  5. package/dist/components/bulletList/listRow.jsx +41 -0
  6. package/dist/components/bulletList/listRow.jsx.map +1 -0
  7. package/dist/components/button/index.jsx +44 -0
  8. package/dist/components/button/index.jsx.map +1 -0
  9. package/dist/components/button/stories/Button.stories.jsx +23 -0
  10. package/dist/components/button/stories/Button.stories.jsx.map +1 -0
  11. package/dist/components/circle/circleEmpty.jsx +31 -0
  12. package/dist/components/circle/circleEmpty.jsx.map +1 -0
  13. package/dist/components/circle/index.jsx +27 -0
  14. package/dist/components/circle/index.jsx.map +1 -0
  15. package/dist/components/circle/stories/circle.stories.jsx +26 -0
  16. package/dist/components/circle/stories/circle.stories.jsx.map +1 -0
  17. package/dist/components/circle/stories/circleEmpty.stories.jsx +18 -0
  18. package/dist/components/circle/stories/circleEmpty.stories.jsx.map +1 -0
  19. package/dist/components/circlePieChart/emptyCirclePieChart.jsx +39 -0
  20. package/dist/components/circlePieChart/emptyCirclePieChart.jsx.map +1 -0
  21. package/dist/components/circlePieChart/index.jsx +52 -0
  22. package/dist/components/circlePieChart/index.jsx.map +1 -0
  23. package/dist/components/circlePieChart/stories/circlePieChart.stories.jsx +91 -0
  24. package/dist/components/circlePieChart/stories/circlePieChart.stories.jsx.map +1 -0
  25. package/dist/components/circlePieChart/stories/emptyCirclePieChart.stories.jsx +48 -0
  26. package/dist/components/circlePieChart/stories/emptyCirclePieChart.stories.jsx.map +1 -0
  27. package/dist/components/cookieDetails/details.jsx +272 -0
  28. package/dist/components/cookieDetails/details.jsx.map +1 -0
  29. package/dist/components/cookieDetails/index.jsx +41 -0
  30. package/dist/components/cookieDetails/index.jsx.map +1 -0
  31. package/dist/components/cookieDetails/stories/cookieDetails.stories.js +30 -0
  32. package/dist/components/cookieDetails/stories/cookieDetails.stories.js.map +1 -0
  33. package/dist/components/cookieDetails/stories/details.stories.js +30 -0
  34. package/dist/components/cookieDetails/stories/details.stories.js.map +1 -0
  35. package/dist/components/cookieTable/index.jsx +117 -0
  36. package/dist/components/cookieTable/index.jsx.map +1 -0
  37. package/dist/components/cookieTable/utils/conditionalTableRowClassesHandler.js +53 -0
  38. package/dist/components/cookieTable/utils/conditionalTableRowClassesHandler.js.map +1 -0
  39. package/dist/components/cookieTable/utils/exportCookies.js +32 -0
  40. package/dist/components/cookieTable/utils/exportCookies.js.map +1 -0
  41. package/dist/components/cookieTable/utils/index.js +26 -0
  42. package/dist/components/cookieTable/utils/index.js.map +1 -0
  43. package/dist/components/cookiesLanding/cookiesLandingWrapper.jsx +56 -0
  44. package/dist/components/cookiesLanding/cookiesLandingWrapper.jsx.map +1 -0
  45. package/dist/components/cookiesLanding/cookiesMatrix/index.jsx +60 -0
  46. package/dist/components/cookiesLanding/cookiesMatrix/index.jsx.map +1 -0
  47. package/dist/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.jsx +59 -0
  48. package/dist/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.jsx.map +1 -0
  49. package/dist/components/cookiesLanding/index.jsx +31 -0
  50. package/dist/components/cookiesLanding/index.jsx.map +1 -0
  51. package/dist/components/cookiesLanding/landingHeader/index.jsx +54 -0
  52. package/dist/components/cookiesLanding/landingHeader/index.jsx.map +1 -0
  53. package/dist/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.jsx +40 -0
  54. package/dist/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.jsx.map +1 -0
  55. package/dist/components/cookiesLanding/stories/cookiesLanding.stories.jsx +20 -0
  56. package/dist/components/cookiesLanding/stories/cookiesLanding.stories.jsx.map +1 -0
  57. package/dist/components/cookiesLanding/useFiltersMapping.jsx +55 -0
  58. package/dist/components/cookiesLanding/useFiltersMapping.jsx.map +1 -0
  59. package/dist/components/errorFallback/extensionReloadNotification.jsx +50 -0
  60. package/dist/components/errorFallback/extensionReloadNotification.jsx.map +1 -0
  61. package/dist/components/errorFallback/index.jsx +37 -0
  62. package/dist/components/errorFallback/index.jsx.map +1 -0
  63. package/dist/components/errorFallback/stories/errorFallback.stories.jsx +31 -0
  64. package/dist/components/errorFallback/stories/errorFallback.stories.jsx.map +1 -0
  65. package/dist/components/errorFallback/stories/extensionReloadNotification.stories.jsx +20 -0
  66. package/dist/components/errorFallback/stories/extensionReloadNotification.stories.jsx.map +1 -0
  67. package/dist/components/exportButton/index.jsx +40 -0
  68. package/dist/components/exportButton/index.jsx.map +1 -0
  69. package/dist/components/index.js +97 -0
  70. package/dist/components/index.js.map +1 -0
  71. package/dist/components/inspectButton/index.jsx +39 -0
  72. package/dist/components/inspectButton/index.jsx.map +1 -0
  73. package/dist/components/landingPage/constants.js +45 -0
  74. package/dist/components/landingPage/constants.js.map +1 -0
  75. package/dist/components/landingPage/contentPanel.jsx +51 -0
  76. package/dist/components/landingPage/contentPanel.jsx.map +1 -0
  77. package/dist/components/landingPage/index.jsx +90 -0
  78. package/dist/components/landingPage/index.jsx.map +1 -0
  79. package/dist/components/landingPage/infoCard/fetchPSInfo.js +54 -0
  80. package/dist/components/landingPage/infoCard/fetchPSInfo.js.map +1 -0
  81. package/dist/components/landingPage/infoCard/index.jsx +87 -0
  82. package/dist/components/landingPage/infoCard/index.jsx.map +1 -0
  83. package/dist/components/landingPage/infoCard/learnMoreDropdown.jsx +91 -0
  84. package/dist/components/landingPage/infoCard/learnMoreDropdown.jsx.map +1 -0
  85. package/dist/components/landingPage/infoCard/renderLink.jsx +40 -0
  86. package/dist/components/landingPage/infoCard/renderLink.jsx.map +1 -0
  87. package/dist/components/landingPage/quickLinksList.jsx +117 -0
  88. package/dist/components/landingPage/quickLinksList.jsx.map +1 -0
  89. package/dist/components/matrix/index.jsx +55 -0
  90. package/dist/components/matrix/index.jsx.map +1 -0
  91. package/dist/components/matrix/matrixComponent/index.jsx +47 -0
  92. package/dist/components/matrix/matrixComponent/index.jsx.map +1 -0
  93. package/dist/components/matrix/matrixComponent/matrixComponentHorizontal.jsx +55 -0
  94. package/dist/components/matrix/matrixComponent/matrixComponentHorizontal.jsx.map +1 -0
  95. package/dist/components/matrix/matrixComponent/stories/MatrixComponent.stories.jsx +27 -0
  96. package/dist/components/matrix/matrixComponent/stories/MatrixComponent.stories.jsx.map +1 -0
  97. package/dist/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.jsx +25 -0
  98. package/dist/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.jsx.map +1 -0
  99. package/dist/components/matrix/stories/matrix.stories.jsx +59 -0
  100. package/dist/components/matrix/stories/matrix.stories.jsx.map +1 -0
  101. package/dist/components/matrixContainer/index.jsx +91 -0
  102. package/dist/components/matrixContainer/index.jsx.map +1 -0
  103. package/dist/components/menuBar/index.jsx +141 -0
  104. package/dist/components/menuBar/index.jsx.map +1 -0
  105. package/dist/components/menuBar/utils/index.js +24 -0
  106. package/dist/components/menuBar/utils/index.js.map +1 -0
  107. package/dist/components/menuBar/utils/isElementInView.js +39 -0
  108. package/dist/components/menuBar/utils/isElementInView.js.map +1 -0
  109. package/dist/components/messageBox/index.jsx +34 -0
  110. package/dist/components/messageBox/index.jsx.map +1 -0
  111. package/dist/components/messageBox/stories/messageBox.stories.jsx +23 -0
  112. package/dist/components/messageBox/stories/messageBox.stories.jsx.map +1 -0
  113. package/dist/components/progressBar/borderProgressbar.jsx +33 -0
  114. package/dist/components/progressBar/borderProgressbar.jsx.map +1 -0
  115. package/dist/components/progressBar/index.jsx +33 -0
  116. package/dist/components/progressBar/index.jsx.map +1 -0
  117. package/dist/components/progressBar/stories/progressBar.stories.jsx +22 -0
  118. package/dist/components/progressBar/stories/progressBar.stories.jsx.map +1 -0
  119. package/dist/components/refreshButton/index.jsx +32 -0
  120. package/dist/components/refreshButton/index.jsx.map +1 -0
  121. package/dist/components/searchInput/index.jsx +86 -0
  122. package/dist/components/searchInput/index.jsx.map +1 -0
  123. package/dist/components/sidebar/index.js +40 -0
  124. package/dist/components/sidebar/index.js.map +1 -0
  125. package/dist/components/sidebar/sidebar.jsx +82 -0
  126. package/dist/components/sidebar/sidebar.jsx.map +1 -0
  127. package/dist/components/sidebar/sidebarChild.jsx +141 -0
  128. package/dist/components/sidebar/sidebarChild.jsx.map +1 -0
  129. package/dist/components/sidebar/useSidebar/constants.js +38 -0
  130. package/dist/components/sidebar/useSidebar/constants.js.map +1 -0
  131. package/dist/components/sidebar/useSidebar/context.js +48 -0
  132. package/dist/components/sidebar/useSidebar/context.js.map +1 -0
  133. package/dist/components/sidebar/useSidebar/index.js +35 -0
  134. package/dist/components/sidebar/useSidebar/index.js.map +1 -0
  135. package/dist/components/sidebar/useSidebar/provider.jsx +243 -0
  136. package/dist/components/sidebar/useSidebar/provider.jsx.map +1 -0
  137. package/dist/components/sidebar/useSidebar/types.js +18 -0
  138. package/dist/components/sidebar/useSidebar/types.js.map +1 -0
  139. package/dist/components/sidebar/useSidebar/useSidebar.jsx +30 -0
  140. package/dist/components/sidebar/useSidebar/useSidebar.jsx.map +1 -0
  141. package/dist/components/sidebar/useSidebar/utils/createKeyPath.js +54 -0
  142. package/dist/components/sidebar/useSidebar/utils/createKeyPath.js.map +1 -0
  143. package/dist/components/sidebar/useSidebar/utils/findItem.js +54 -0
  144. package/dist/components/sidebar/useSidebar/utils/findItem.js.map +1 -0
  145. package/dist/components/sidebar/useSidebar/utils/findKeyParent.js +32 -0
  146. package/dist/components/sidebar/useSidebar/utils/findKeyParent.js.map +1 -0
  147. package/dist/components/sidebar/useSidebar/utils/findNextItem.js +66 -0
  148. package/dist/components/sidebar/useSidebar/utils/findNextItem.js.map +1 -0
  149. package/dist/components/sidebar/useSidebar/utils/findPrevItem.js +59 -0
  150. package/dist/components/sidebar/useSidebar/utils/findPrevItem.js.map +1 -0
  151. package/dist/components/sidebar/useSidebar/utils/index.js +34 -0
  152. package/dist/components/sidebar/useSidebar/utils/index.js.map +1 -0
  153. package/dist/components/sidebar/useSidebar/utils/matchKey.js +30 -0
  154. package/dist/components/sidebar/useSidebar/utils/matchKey.js.map +1 -0
  155. package/dist/components/table/components/columnMenu/columnList.jsx +71 -0
  156. package/dist/components/table/components/columnMenu/columnList.jsx.map +1 -0
  157. package/dist/components/table/components/columnMenu/columnListItem.jsx +40 -0
  158. package/dist/components/table/components/columnMenu/columnListItem.jsx.map +1 -0
  159. package/dist/components/table/components/columnMenu/index.jsx +110 -0
  160. package/dist/components/table/components/columnMenu/index.jsx.map +1 -0
  161. package/dist/components/table/components/filtersSidebar/chips/chip.jsx +40 -0
  162. package/dist/components/table/components/filtersSidebar/chips/chip.jsx.map +1 -0
  163. package/dist/components/table/components/filtersSidebar/chips/chipList.jsx +44 -0
  164. package/dist/components/table/components/filtersSidebar/chips/chipList.jsx.map +1 -0
  165. package/dist/components/table/components/filtersSidebar/chips/index.jsx +53 -0
  166. package/dist/components/table/components/filtersSidebar/chips/index.jsx.map +1 -0
  167. package/dist/components/table/components/filtersSidebar/index.jsx +107 -0
  168. package/dist/components/table/components/filtersSidebar/index.jsx.map +1 -0
  169. package/dist/components/table/components/filtersSidebar/listItem.jsx +110 -0
  170. package/dist/components/table/components/filtersSidebar/listItem.jsx.map +1 -0
  171. package/dist/components/table/components/filtersSidebar/option.jsx +65 -0
  172. package/dist/components/table/components/filtersSidebar/option.jsx.map +1 -0
  173. package/dist/components/table/components/filtersSidebar/subList.jsx +74 -0
  174. package/dist/components/table/components/filtersSidebar/subList.jsx.map +1 -0
  175. package/dist/components/table/components/index.jsx +118 -0
  176. package/dist/components/table/components/index.jsx.map +1 -0
  177. package/dist/components/table/components/tableBody/bodyCell.jsx +54 -0
  178. package/dist/components/table/components/tableBody/bodyCell.jsx.map +1 -0
  179. package/dist/components/table/components/tableBody/bodyRow.jsx +64 -0
  180. package/dist/components/table/components/tableBody/bodyRow.jsx.map +1 -0
  181. package/dist/components/table/components/tableBody/index.jsx +148 -0
  182. package/dist/components/table/components/tableBody/index.jsx.map +1 -0
  183. package/dist/components/table/components/tableHeader/headerCell.jsx +83 -0
  184. package/dist/components/table/components/tableHeader/headerCell.jsx.map +1 -0
  185. package/dist/components/table/components/tableHeader/headerResizer.jsx +31 -0
  186. package/dist/components/table/components/tableHeader/headerResizer.jsx.map +1 -0
  187. package/dist/components/table/components/tableHeader/headerRow.jsx +39 -0
  188. package/dist/components/table/components/tableHeader/headerRow.jsx.map +1 -0
  189. package/dist/components/table/components/tableHeader/index.jsx +63 -0
  190. package/dist/components/table/components/tableHeader/index.jsx.map +1 -0
  191. package/dist/components/table/components/tableTopBar/index.jsx +92 -0
  192. package/dist/components/table/components/tableTopBar/index.jsx.map +1 -0
  193. package/dist/components/table/index.js +41 -0
  194. package/dist/components/table/index.js.map +1 -0
  195. package/dist/components/table/persistentSettingsStore/index.jsx +114 -0
  196. package/dist/components/table/persistentSettingsStore/index.jsx.map +1 -0
  197. package/dist/components/table/persistentSettingsStore/utils/extractStorage.js +50 -0
  198. package/dist/components/table/persistentSettingsStore/utils/extractStorage.js.map +1 -0
  199. package/dist/components/table/persistentSettingsStore/utils/index.js +26 -0
  200. package/dist/components/table/persistentSettingsStore/utils/index.js.map +1 -0
  201. package/dist/components/table/persistentSettingsStore/utils/updateStorage.js +87 -0
  202. package/dist/components/table/persistentSettingsStore/utils/updateStorage.js.map +1 -0
  203. package/dist/components/table/useTable/context.js +57 -0
  204. package/dist/components/table/useTable/context.js.map +1 -0
  205. package/dist/components/table/useTable/index.js +35 -0
  206. package/dist/components/table/useTable/index.js.map +1 -0
  207. package/dist/components/table/useTable/provider.jsx +138 -0
  208. package/dist/components/table/useTable/provider.jsx.map +1 -0
  209. package/dist/components/table/useTable/types.js +3 -0
  210. package/dist/components/table/useTable/types.js.map +1 -0
  211. package/dist/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.js +61 -0
  212. package/dist/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.js.map +1 -0
  213. package/dist/components/table/useTable/useColumnResizing/index.jsx +161 -0
  214. package/dist/components/table/useTable/useColumnResizing/index.jsx.map +1 -0
  215. package/dist/components/table/useTable/useColumnResizing/resizeColumns.js +54 -0
  216. package/dist/components/table/useTable/useColumnResizing/resizeColumns.js.map +1 -0
  217. package/dist/components/table/useTable/useColumnSorting/index.jsx +90 -0
  218. package/dist/components/table/useTable/useColumnSorting/index.jsx.map +1 -0
  219. package/dist/components/table/useTable/useColumnVisibility/index.jsx +127 -0
  220. package/dist/components/table/useTable/useColumnVisibility/index.jsx.map +1 -0
  221. package/dist/components/table/useTable/useFiltering/hooks/index.js +28 -0
  222. package/dist/components/table/useTable/useFiltering/hooks/index.js.map +1 -0
  223. package/dist/components/table/useTable/useFiltering/hooks/useFiltersExtraction.jsx +159 -0
  224. package/dist/components/table/useTable/useFiltering/hooks/useFiltersExtraction.jsx.map +1 -0
  225. package/dist/components/table/useTable/useFiltering/hooks/useFiltersOptions.jsx +65 -0
  226. package/dist/components/table/useTable/useFiltering/hooks/useFiltersOptions.jsx.map +1 -0
  227. package/dist/components/table/useTable/useFiltering/hooks/useFiltersPersistence.jsx +121 -0
  228. package/dist/components/table/useTable/useFiltering/hooks/useFiltersPersistence.jsx.map +1 -0
  229. package/dist/components/table/useTable/useFiltering/index.jsx +189 -0
  230. package/dist/components/table/useTable/useFiltering/index.jsx.map +1 -0
  231. package/dist/components/table/useTable/useSearch/index.jsx +73 -0
  232. package/dist/components/table/useTable/useSearch/index.jsx.map +1 -0
  233. package/dist/components/table/useTable/useTable.jsx +36 -0
  234. package/dist/components/table/useTable/useTable.jsx.map +1 -0
  235. package/dist/components/table/utils/generatExtensionCookietableCSV.js +88 -0
  236. package/dist/components/table/utils/generatExtensionCookietableCSV.js.map +1 -0
  237. package/dist/components/table/utils/generateCLICookieTableCSV.js +76 -0
  238. package/dist/components/table/utils/generateCLICookieTableCSV.js.map +1 -0
  239. package/dist/components/table/utils/index.js +41 -0
  240. package/dist/components/table/utils/index.js.map +1 -0
  241. package/dist/components/table/utils/precalculatedFiltersUtils/calculateBlockedReasonsFilterValues.js +57 -0
  242. package/dist/components/table/utils/precalculatedFiltersUtils/calculateBlockedReasonsFilterValues.js.map +1 -0
  243. package/dist/components/table/utils/precalculatedFiltersUtils/calculateDynamicFilterValues.js +58 -0
  244. package/dist/components/table/utils/precalculatedFiltersUtils/calculateDynamicFilterValues.js.map +1 -0
  245. package/dist/components/table/utils/precalculatedFiltersUtils/calculateExemptionReasons.js +37 -0
  246. package/dist/components/table/utils/precalculatedFiltersUtils/calculateExemptionReasons.js.map +1 -0
  247. package/dist/components/table/utils/precalculatedFiltersUtils/evaluateSelectAllOption.js +39 -0
  248. package/dist/components/table/utils/precalculatedFiltersUtils/evaluateSelectAllOption.js.map +1 -0
  249. package/dist/components/table/utils/precalculatedFiltersUtils/evaluateStaticFilterValues.js +48 -0
  250. package/dist/components/table/utils/precalculatedFiltersUtils/evaluateStaticFilterValues.js.map +1 -0
  251. package/dist/components/table/utils/precalculatedFiltersUtils/index.js +32 -0
  252. package/dist/components/table/utils/precalculatedFiltersUtils/index.js.map +1 -0
  253. package/dist/components/toastMessage/index.jsx +39 -0
  254. package/dist/components/toastMessage/index.jsx.map +1 -0
  255. package/dist/components/toggleSwitch/index.jsx +41 -0
  256. package/dist/components/toggleSwitch/index.jsx.map +1 -0
  257. package/dist/constants.js +143 -0
  258. package/dist/constants.js.map +1 -0
  259. package/dist/icons/index.jsx +143 -0
  260. package/dist/icons/index.jsx.map +1 -0
  261. package/dist/index.js +37 -0
  262. package/dist/index.js.map +1 -0
  263. package/dist/test-data/cookieMockData.js +117 -0
  264. package/dist/test-data/cookieMockData.js.map +1 -0
  265. package/dist/test-data/cookieStats.js +38 -0
  266. package/dist/test-data/cookieStats.js.map +1 -0
  267. package/dist/test-data/cookieTableBody.js +43 -0
  268. package/dist/test-data/cookieTableBody.js.map +1 -0
  269. package/dist/test-data/cookieTableMockData.jsx +268 -0
  270. package/dist/test-data/cookieTableMockData.jsx.map +1 -0
  271. package/dist/test-data/cookiesStatsComponents.js +96 -0
  272. package/dist/test-data/cookiesStatsComponents.js.map +1 -0
  273. package/dist/theme/colors.js +213 -0
  274. package/dist/theme/colors.js.map +1 -0
  275. package/dist/utils/index.js +32 -0
  276. package/dist/utils/index.js.map +1 -0
  277. package/dist/utils/noop.js +22 -0
  278. package/dist/utils/noop.js.map +1 -0
  279. package/dist/utils/prepareCookieDataMapping.js +34 -0
  280. package/dist/utils/prepareCookieDataMapping.js.map +1 -0
  281. package/dist/utils/prepareCookieStatsComponents.js +127 -0
  282. package/dist/utils/prepareCookieStatsComponents.js.map +1 -0
  283. package/dist/utils/prepareCookiesCount.js +110 -0
  284. package/dist/utils/prepareCookiesCount.js.map +1 -0
  285. package/dist/utils/prepareFrameStatsComponent.js +125 -0
  286. package/dist/utils/prepareFrameStatsComponent.js.map +1 -0
  287. package/dist-types/components/bulletList/index.d.ts +10 -0
  288. package/dist-types/components/bulletList/listRow.d.ts +9 -0
  289. package/dist-types/components/button/index.d.ts +14 -0
  290. package/dist-types/components/button/stories/Button.stories.d.ts +11 -0
  291. package/dist-types/components/circle/circleEmpty.d.ts +9 -0
  292. package/dist-types/components/circle/index.d.ts +9 -0
  293. package/dist-types/components/circle/stories/circle.stories.d.ts +11 -0
  294. package/dist-types/components/circle/stories/circleEmpty.stories.d.ts +11 -0
  295. package/dist-types/components/circlePieChart/emptyCirclePieChart.d.ts +6 -0
  296. package/dist-types/components/circlePieChart/index.d.ts +19 -0
  297. package/dist-types/components/circlePieChart/stories/circlePieChart.stories.d.ts +9 -0
  298. package/dist-types/components/circlePieChart/stories/emptyCirclePieChart.stories.d.ts +9 -0
  299. package/dist-types/components/cookieDetails/details.d.ts +11 -0
  300. package/dist-types/components/cookieDetails/index.d.ts +13 -0
  301. package/dist-types/components/cookieDetails/stories/cookieDetails.stories.d.ts +8 -0
  302. package/dist-types/components/cookieDetails/stories/details.stories.d.ts +8 -0
  303. package/dist-types/components/cookieTable/index.d.ts +34 -0
  304. package/dist-types/components/cookieTable/utils/conditionalTableRowClassesHandler.d.ts +3 -0
  305. package/dist-types/components/cookieTable/utils/exportCookies.d.ts +6 -0
  306. package/dist-types/components/cookieTable/utils/index.d.ts +2 -0
  307. package/dist-types/components/cookiesLanding/cookiesLandingWrapper.d.ts +15 -0
  308. package/dist-types/components/cookiesLanding/cookiesMatrix/index.d.ts +24 -0
  309. package/dist-types/components/cookiesLanding/cookiesMatrix/stories/cookiesMatrix.stories.d.ts +11 -0
  310. package/dist-types/components/cookiesLanding/index.d.ts +17 -0
  311. package/dist-types/components/cookiesLanding/landingHeader/index.d.ts +10 -0
  312. package/dist-types/components/cookiesLanding/landingHeader/stories/LandingHeader.stories.d.ts +11 -0
  313. package/dist-types/components/cookiesLanding/stories/cookiesLanding.stories.d.ts +11 -0
  314. package/dist-types/components/cookiesLanding/useFiltersMapping.d.ts +12 -0
  315. package/dist-types/components/errorFallback/extensionReloadNotification.d.ts +13 -0
  316. package/dist-types/components/errorFallback/index.d.ts +9 -0
  317. package/dist-types/components/errorFallback/stories/errorFallback.stories.d.ts +12 -0
  318. package/dist-types/components/errorFallback/stories/extensionReloadNotification.stories.d.ts +11 -0
  319. package/dist-types/components/exportButton/index.d.ts +11 -0
  320. package/dist-types/components/index.d.ts +34 -0
  321. package/dist-types/components/inspectButton/index.d.ts +11 -0
  322. package/dist-types/components/landingPage/constants.d.ts +4 -0
  323. package/dist-types/components/landingPage/contentPanel.d.ts +16 -0
  324. package/dist-types/components/landingPage/index.d.ts +16 -0
  325. package/dist-types/components/landingPage/infoCard/fetchPSInfo.d.ts +26 -0
  326. package/dist-types/components/landingPage/infoCard/index.d.ts +11 -0
  327. package/dist-types/components/landingPage/infoCard/learnMoreDropdown.d.ts +14 -0
  328. package/dist-types/components/landingPage/infoCard/renderLink.d.ts +11 -0
  329. package/dist-types/components/landingPage/quickLinksList.d.ts +6 -0
  330. package/dist-types/components/matrix/index.d.ts +14 -0
  331. package/dist-types/components/matrix/matrixComponent/index.d.ts +16 -0
  332. package/dist-types/components/matrix/matrixComponent/matrixComponentHorizontal.d.ts +13 -0
  333. package/dist-types/components/matrix/matrixComponent/stories/MatrixComponent.stories.d.ts +11 -0
  334. package/dist-types/components/matrix/matrixComponent/stories/matrixComponentHorizontal.stories.d.ts +11 -0
  335. package/dist-types/components/matrix/stories/matrix.stories.d.ts +11 -0
  336. package/dist-types/components/matrixContainer/index.d.ts +20 -0
  337. package/dist-types/components/menuBar/index.d.ts +17 -0
  338. package/dist-types/components/menuBar/utils/index.d.ts +1 -0
  339. package/dist-types/components/menuBar/utils/isElementInView.d.ts +6 -0
  340. package/dist-types/components/messageBox/index.d.ts +10 -0
  341. package/dist-types/components/messageBox/stories/messageBox.stories.d.ts +11 -0
  342. package/dist-types/components/progressBar/borderProgressbar.d.ts +9 -0
  343. package/dist-types/components/progressBar/index.d.ts +9 -0
  344. package/dist-types/components/progressBar/stories/progressBar.stories.d.ts +11 -0
  345. package/dist-types/components/refreshButton/index.d.ts +10 -0
  346. package/dist-types/components/searchInput/index.d.ts +11 -0
  347. package/dist-types/components/sidebar/index.d.ts +3 -0
  348. package/dist-types/components/sidebar/sidebar.d.ts +9 -0
  349. package/dist-types/components/sidebar/sidebarChild.d.ts +15 -0
  350. package/dist-types/components/sidebar/useSidebar/constants.d.ts +18 -0
  351. package/dist-types/components/sidebar/useSidebar/context.d.ts +28 -0
  352. package/dist-types/components/sidebar/useSidebar/index.d.ts +3 -0
  353. package/dist-types/components/sidebar/useSidebar/provider.d.ts +6 -0
  354. package/dist-types/components/sidebar/useSidebar/types.d.ts +24 -0
  355. package/dist-types/components/sidebar/useSidebar/useSidebar.d.ts +3 -0
  356. package/dist-types/components/sidebar/useSidebar/utils/createKeyPath.d.ts +13 -0
  357. package/dist-types/components/sidebar/useSidebar/utils/findItem.d.ts +14 -0
  358. package/dist-types/components/sidebar/useSidebar/utils/findKeyParent.d.ts +8 -0
  359. package/dist-types/components/sidebar/useSidebar/utils/findNextItem.d.ts +17 -0
  360. package/dist-types/components/sidebar/useSidebar/utils/findPrevItem.d.ts +16 -0
  361. package/dist-types/components/sidebar/useSidebar/utils/index.d.ts +6 -0
  362. package/dist-types/components/sidebar/useSidebar/utils/matchKey.d.ts +8 -0
  363. package/dist-types/components/table/components/columnMenu/columnList.d.ts +10 -0
  364. package/dist-types/components/table/components/columnMenu/columnListItem.d.ts +16 -0
  365. package/dist-types/components/table/components/columnMenu/index.d.ts +14 -0
  366. package/dist-types/components/table/components/filtersSidebar/chips/chip.d.ts +11 -0
  367. package/dist-types/components/table/components/filtersSidebar/chips/chipList.d.ts +6 -0
  368. package/dist-types/components/table/components/filtersSidebar/chips/index.d.ts +6 -0
  369. package/dist-types/components/table/components/filtersSidebar/index.d.ts +6 -0
  370. package/dist-types/components/table/components/filtersSidebar/listItem.d.ts +14 -0
  371. package/dist-types/components/table/components/filtersSidebar/option.d.ts +13 -0
  372. package/dist-types/components/table/components/filtersSidebar/subList.d.ts +18 -0
  373. package/dist-types/components/table/components/index.d.ts +12 -0
  374. package/dist-types/components/table/components/tableBody/bodyCell.d.ts +23 -0
  375. package/dist-types/components/table/components/tableBody/bodyRow.d.ts +20 -0
  376. package/dist-types/components/table/components/tableBody/index.d.ts +11 -0
  377. package/dist-types/components/table/components/tableHeader/headerCell.d.ts +12 -0
  378. package/dist-types/components/table/components/tableHeader/headerResizer.d.ts +9 -0
  379. package/dist-types/components/table/components/tableHeader/headerRow.d.ts +9 -0
  380. package/dist-types/components/table/components/tableHeader/index.d.ts +14 -0
  381. package/dist-types/components/table/components/tableTopBar/index.d.ts +13 -0
  382. package/dist-types/components/table/index.d.ts +4 -0
  383. package/dist-types/components/table/persistentSettingsStore/index.d.ts +22 -0
  384. package/dist-types/components/table/persistentSettingsStore/utils/extractStorage.d.ts +6 -0
  385. package/dist-types/components/table/persistentSettingsStore/utils/index.d.ts +2 -0
  386. package/dist-types/components/table/persistentSettingsStore/utils/updateStorage.d.ts +8 -0
  387. package/dist-types/components/table/useTable/context.d.ts +46 -0
  388. package/dist-types/components/table/useTable/index.d.ts +3 -0
  389. package/dist-types/components/table/useTable/provider.d.ts +6 -0
  390. package/dist-types/components/table/useTable/types.d.ts +77 -0
  391. package/dist-types/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.d.ts +7 -0
  392. package/dist-types/components/table/useTable/useColumnResizing/index.d.ts +13 -0
  393. package/dist-types/components/table/useTable/useColumnResizing/resizeColumns.d.ts +5 -0
  394. package/dist-types/components/table/useTable/useColumnSorting/index.d.ts +17 -0
  395. package/dist-types/components/table/useTable/useColumnVisibility/index.d.ts +14 -0
  396. package/dist-types/components/table/useTable/useFiltering/hooks/index.d.ts +3 -0
  397. package/dist-types/components/table/useTable/useFiltering/hooks/useFiltersExtraction.d.ts +14 -0
  398. package/dist-types/components/table/useTable/useFiltering/hooks/useFiltersOptions.d.ts +10 -0
  399. package/dist-types/components/table/useTable/useFiltering/hooks/useFiltersPersistence.d.ts +7 -0
  400. package/dist-types/components/table/useTable/useFiltering/index.d.ts +16 -0
  401. package/dist-types/components/table/useTable/useSearch/index.d.ts +16 -0
  402. package/dist-types/components/table/useTable/useTable.d.ts +6 -0
  403. package/dist-types/components/table/utils/generatExtensionCookietableCSV.d.ts +6 -0
  404. package/dist-types/components/table/utils/generateCLICookieTableCSV.d.ts +6 -0
  405. package/dist-types/components/table/utils/index.d.ts +3 -0
  406. package/dist-types/components/table/utils/precalculatedFiltersUtils/calculateBlockedReasonsFilterValues.d.ts +19 -0
  407. package/dist-types/components/table/utils/precalculatedFiltersUtils/calculateDynamicFilterValues.d.ts +20 -0
  408. package/dist-types/components/table/utils/precalculatedFiltersUtils/calculateExemptionReasons.d.ts +15 -0
  409. package/dist-types/components/table/utils/precalculatedFiltersUtils/evaluateSelectAllOption.d.ts +9 -0
  410. package/dist-types/components/table/utils/precalculatedFiltersUtils/evaluateStaticFilterValues.d.ts +16 -0
  411. package/dist-types/components/table/utils/precalculatedFiltersUtils/index.d.ts +5 -0
  412. package/dist-types/components/toastMessage/index.d.ts +14 -0
  413. package/dist-types/components/toggleSwitch/index.d.ts +12 -0
  414. package/dist-types/constants.d.ts +20 -0
  415. package/dist-types/icons/index.d.ts +60 -0
  416. package/dist-types/index.d.ts +5 -0
  417. package/dist-types/test-data/cookieMockData.d.ts +28 -0
  418. package/dist-types/test-data/cookieStats.d.ts +21 -0
  419. package/dist-types/test-data/cookieTableBody.d.ts +88 -0
  420. package/dist-types/test-data/cookieTableMockData.d.ts +209 -0
  421. package/dist-types/test-data/cookiesStatsComponents.d.ts +27 -0
  422. package/dist-types/theme/colors.d.ts +6 -0
  423. package/dist-types/utils/index.d.ts +5 -0
  424. package/dist-types/utils/noop.d.ts +1 -0
  425. package/dist-types/utils/prepareCookieDataMapping.d.ts +12 -0
  426. package/dist-types/utils/prepareCookieStatsComponents.d.ts +6 -0
  427. package/dist-types/utils/prepareCookiesCount.d.ts +13 -0
  428. package/dist-types/utils/prepareFrameStatsComponent.d.ts +27 -0
  429. package/package.json +46 -0
  430. package/tsconfig.json +28 -0
@@ -0,0 +1,138 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright 2023 Google LLC
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * https://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ */
17
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
18
+ if (k2 === undefined) k2 = k;
19
+ var desc = Object.getOwnPropertyDescriptor(m, k);
20
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
21
+ desc = { enumerable: true, get: function() { return m[k]; } };
22
+ }
23
+ Object.defineProperty(o, k2, desc);
24
+ }) : (function(o, m, k, k2) {
25
+ if (k2 === undefined) k2 = k;
26
+ o[k2] = m[k];
27
+ }));
28
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
29
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
30
+ }) : function(o, v) {
31
+ o["default"] = v;
32
+ });
33
+ var __importStar = (this && this.__importStar) || function (mod) {
34
+ if (mod && mod.__esModule) return mod;
35
+ var result = {};
36
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
37
+ __setModuleDefault(result, mod);
38
+ return result;
39
+ };
40
+ var __importDefault = (this && this.__importDefault) || function (mod) {
41
+ return (mod && mod.__esModule) ? mod : { "default": mod };
42
+ };
43
+ Object.defineProperty(exports, "__esModule", { value: true });
44
+ exports.TableProvider = void 0;
45
+ /**
46
+ * External dependencies.
47
+ */
48
+ const react_1 = __importStar(require("react"));
49
+ const common_1 = require("@google-psat/common");
50
+ /**
51
+ * Internal dependencies.
52
+ */
53
+ const useColumnSorting_1 = __importDefault(require("./useColumnSorting"));
54
+ const useColumnVisibility_1 = __importDefault(require("./useColumnVisibility"));
55
+ const useColumnResizing_1 = __importDefault(require("./useColumnResizing"));
56
+ const useFiltering_1 = __importDefault(require("./useFiltering"));
57
+ const useSearch_1 = __importDefault(require("./useSearch"));
58
+ const context_1 = require("./context");
59
+ const TableProvider = ({ data, tableColumns, tableFilterData, tableSearchKeys, tablePersistentSettingsKey, onRowClick, onRowContextMenu, getRowObjectKey, conditionalTableRowClassesHandler, exportTableData, hasVerticalBar, isRowSelected, children, }) => {
60
+ const commonKey = (0, react_1.useMemo)(() => {
61
+ if (!tablePersistentSettingsKey) {
62
+ return undefined;
63
+ }
64
+ const keys = tablePersistentSettingsKey.split('#');
65
+ return keys[0];
66
+ }, [tablePersistentSettingsKey]);
67
+ const { visibleColumns, hideColumn, toggleVisibility, areAllColumnsVisible, showColumn, isColumnHidden, } = (0, useColumnVisibility_1.default)(tableColumns, commonKey);
68
+ const allTableColumnsKeys = (0, react_1.useMemo)(() => {
69
+ return tableColumns.map(({ accessorKey }) => accessorKey);
70
+ }, [tableColumns]);
71
+ const { columns, tableContainerRef, onMouseDown, isResizing } = (0, useColumnResizing_1.default)(visibleColumns, allTableColumnsKeys, commonKey);
72
+ const { sortedData, sortKey, sortOrder, setSortKey, setSortOrder } = (0, useColumnSorting_1.default)(data, commonKey);
73
+ const { filters, selectedFilters, filteredData, isFiltering, toggleFilterSelection, toggleSelectAllFilter, resetFilters, isSelectAllFilterSelected, } = (0, useFiltering_1.default)(sortedData, tableFilterData, tablePersistentSettingsKey, commonKey);
74
+ const { searchValue, setSearchValue, searchFilteredData } = (0, useSearch_1.default)(filteredData, tableSearchKeys, commonKey);
75
+ const [rows, setRows] = (0, react_1.useState)([]);
76
+ (0, react_1.useEffect)(() => {
77
+ const newRows = searchFilteredData.map((_data) => {
78
+ const row = {
79
+ originalData: _data,
80
+ };
81
+ columns.forEach((column) => {
82
+ const value = (0, common_1.getValueByKey)(column.accessorKey, _data);
83
+ row[column.accessorKey] = {
84
+ value: () => column.cell(value, _data),
85
+ };
86
+ });
87
+ return row;
88
+ });
89
+ setRows(newRows);
90
+ }, [searchFilteredData, columns]);
91
+ const hideableColumns = (0, react_1.useMemo)(() => tableColumns.filter((column) => column.enableHiding !== false), [tableColumns]);
92
+ (0, react_1.useEffect)(() => {
93
+ const filteredRows = rows.filter((row) => { var _a; return (_a = isRowSelected === null || isRowSelected === void 0 ? void 0 : isRowSelected(row.originalData)) !== null && _a !== void 0 ? _a : true; });
94
+ if (filteredRows.length === 0) {
95
+ onRowClick(null);
96
+ }
97
+ }, [isRowSelected, onRowClick, rows]);
98
+ return (<context_1.TableContext.Provider value={{
99
+ state: {
100
+ columns,
101
+ hideableColumns,
102
+ rows,
103
+ sortKey,
104
+ sortOrder,
105
+ areAllColumnsVisible,
106
+ tableContainerRef,
107
+ isResizing,
108
+ filters,
109
+ selectedFilters,
110
+ isFiltering,
111
+ searchValue,
112
+ },
113
+ actions: {
114
+ setSortKey,
115
+ setSortOrder,
116
+ hideColumn,
117
+ toggleVisibility,
118
+ showColumn,
119
+ isColumnHidden,
120
+ onMouseDown,
121
+ toggleFilterSelection,
122
+ toggleSelectAllFilter,
123
+ resetFilters,
124
+ isSelectAllFilterSelected,
125
+ setSearchValue,
126
+ onRowClick,
127
+ onRowContextMenu,
128
+ getRowObjectKey,
129
+ conditionalTableRowClassesHandler,
130
+ exportTableData,
131
+ hasVerticalBar,
132
+ },
133
+ }}>
134
+ {children}
135
+ </context_1.TableContext.Provider>);
136
+ };
137
+ exports.TableProvider = TableProvider;
138
+ //# sourceMappingURL=provider.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider.jsx","sourceRoot":"","sources":["../../../../src/components/table/useTable/provider.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/components/table/useTable/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright 2023 Google LLC
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * https://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ */
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.handleResizeOnColumnsVisibilityChange = void 0;
19
+ const resizeColumns_1 = require("./resizeColumns");
20
+ const getInitialColumnSize = (widthWeightagePercentage, tableWidth, columnsCount) => {
21
+ if (widthWeightagePercentage) {
22
+ return (widthWeightagePercentage / 100) * tableWidth;
23
+ }
24
+ return tableWidth / columnsCount;
25
+ };
26
+ const handleResizeOnColumnsVisibilityChange = (prevColumnsState, newTableColumnsToRender, columnsSizing, tableWidth, isToggleAll) => {
27
+ // new columns are added and it's not the first render
28
+ if (prevColumnsState.length < newTableColumnsToRender.length &&
29
+ prevColumnsState.length) {
30
+ const incomingColumnsWidth = newTableColumnsToRender
31
+ .filter((column) => !prevColumnsState.find((prevColumn) => prevColumn.accessorKey === column.accessorKey))
32
+ .reduce((acc, column) => {
33
+ if (!columnsSizing[column.accessorKey]) {
34
+ const percentage = isToggleAll
35
+ ? column.widthWeightagePercentage || 0
36
+ : 0;
37
+ columnsSizing[column.accessorKey] = getInitialColumnSize(percentage, tableWidth, newTableColumnsToRender.length);
38
+ }
39
+ acc += columnsSizing[column.accessorKey];
40
+ return acc;
41
+ }, 0);
42
+ const resizedPrev = (0, resizeColumns_1.resizeColumns)(prevColumnsState, tableWidth - incomingColumnsWidth);
43
+ resizedPrev.forEach((column) => {
44
+ columnsSizing[column.accessorKey] = column.width || 0;
45
+ });
46
+ }
47
+ const newColumns = newTableColumnsToRender.map((column) => {
48
+ if (!columnsSizing[column.accessorKey]) {
49
+ columnsSizing[column.accessorKey] = getInitialColumnSize(column.widthWeightagePercentage || 0, tableWidth, newTableColumnsToRender.length);
50
+ }
51
+ return Object.assign(Object.assign({}, column), { width: columnsSizing === null || columnsSizing === void 0 ? void 0 : columnsSizing[column.accessorKey] });
52
+ });
53
+ // columns are removed or it's the first render
54
+ if (prevColumnsState.length > newTableColumnsToRender.length ||
55
+ !prevColumnsState.length) {
56
+ return (0, resizeColumns_1.resizeColumns)(newColumns, tableWidth);
57
+ }
58
+ return newColumns;
59
+ };
60
+ exports.handleResizeOnColumnsVisibilityChange = handleResizeOnColumnsVisibilityChange;
61
+ //# sourceMappingURL=handleResizeOnColumnsVisibilityChange.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handleResizeOnColumnsVisibilityChange.js","sourceRoot":"","sources":["../../../../../src/components/table/useTable/useColumnResizing/handleResizeOnColumnsVisibilityChange.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;GAcG;;;AAMH,mDAAgD;AAEhD,MAAM,oBAAoB,GAAG,CAC3B,wBAAgC,EAChC,UAAkB,EAClB,YAAoB,EACpB,EAAE;IACF,IAAI,wBAAwB,EAAE,CAAC;QAC7B,OAAO,CAAC,wBAAwB,GAAG,GAAG,CAAC,GAAG,UAAU,CAAC;IACvD,CAAC;IAED,OAAO,UAAU,GAAG,YAAY,CAAC;AACnC,CAAC,CAAC;AAEK,MAAM,qCAAqC,GAAG,CACnD,gBAA+B,EAC/B,uBAAsC,EACtC,aAAwC,EACxC,UAAkB,EAClB,WAAoB,EACpB,EAAE;IACF,sDAAsD;IACtD,IACE,gBAAgB,CAAC,MAAM,GAAG,uBAAuB,CAAC,MAAM;QACxD,gBAAgB,CAAC,MAAM,EACvB,CAAC;QACD,MAAM,oBAAoB,GAAG,uBAAuB;aACjD,MAAM,CACL,CAAC,MAAM,EAAE,EAAE,CACT,CAAC,gBAAgB,CAAC,IAAI,CACpB,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,WAAW,KAAK,MAAM,CAAC,WAAW,CAC9D,CACJ;aACA,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;gBACvC,MAAM,UAAU,GAAG,WAAW;oBAC5B,CAAC,CAAC,MAAM,CAAC,wBAAwB,IAAI,CAAC;oBACtC,CAAC,CAAC,CAAC,CAAC;gBACN,aAAa,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,oBAAoB,CACtD,UAAU,EACV,UAAU,EACV,uBAAuB,CAAC,MAAM,CAC/B,CAAC;YACJ,CAAC;YAED,GAAG,IAAI,aAAa,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;YAEzC,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,CAAC,CAAC,CAAC;QAER,MAAM,WAAW,GAAG,IAAA,6BAAa,EAC/B,gBAAgB,EAChB,UAAU,GAAG,oBAAoB,CAClC,CAAC;QAEF,WAAW,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YAC7B,aAAa,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,MAAM,CAAC,KAAK,IAAI,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,UAAU,GAAG,uBAAuB,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;QACxD,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;YACvC,aAAa,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,oBAAoB,CACtD,MAAM,CAAC,wBAAwB,IAAI,CAAC,EACpC,UAAU,EACV,uBAAuB,CAAC,MAAM,CAC/B,CAAC;QACJ,CAAC;QAED,uCACK,MAAM,KACT,KAAK,EAAE,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAG,MAAM,CAAC,WAAW,CAAC,IAC1C;IACJ,CAAC,CAAC,CAAC;IAEH,+CAA+C;IAC/C,IACE,gBAAgB,CAAC,MAAM,GAAG,uBAAuB,CAAC,MAAM;QACxD,CAAC,gBAAgB,CAAC,MAAM,EACxB,CAAC;QACD,OAAO,IAAA,6BAAa,EAAC,UAAU,EAAE,UAAU,CAAC,CAAC;IAC/C,CAAC;IAED,OAAO,UAAU,CAAC;AACpB,CAAC,CAAC;AAtEW,QAAA,qCAAqC,yCAsEhD"}
@@ -0,0 +1,161 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright 2023 Google LLC
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * https://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ */
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ /**
19
+ * External dependencies.
20
+ */
21
+ const react_1 = require("react");
22
+ const persistentSettingsStore_1 = require("../../persistentSettingsStore");
23
+ const resizeColumns_1 = require("./resizeColumns");
24
+ const handleResizeOnColumnsVisibilityChange_1 = require("./handleResizeOnColumnsVisibilityChange");
25
+ const useColumnResizing = (tableColumns, allTableColumnsKeys, tablePersistentSettingsKey) => {
26
+ const tableContainerRef = (0, react_1.useRef)(null);
27
+ const [columns, setColumns] = (0, react_1.useState)(tableColumns);
28
+ const [isResizing, setIsResizing] = (0, react_1.useState)(false);
29
+ const columnsSizingRef = (0, react_1.useRef)({});
30
+ (0, react_1.useEffect)(() => {
31
+ if (tableColumns.length === 1) {
32
+ columnsSizingRef.current = {};
33
+ columnsSizingRef.current[tableColumns[0].accessorKey] =
34
+ tableColumns[0].width || 0;
35
+ }
36
+ }, [tableColumns]);
37
+ (0, react_1.useEffect)(() => {
38
+ setColumns((prev) => {
39
+ var _a;
40
+ return (0, handleResizeOnColumnsVisibilityChange_1.handleResizeOnColumnsVisibilityChange)(prev, tableColumns, columnsSizingRef.current, ((_a = tableContainerRef.current) === null || _a === void 0 ? void 0 : _a.scrollWidth) || 0, allTableColumnsKeys.length === tableColumns.length);
41
+ });
42
+ }, [allTableColumnsKeys.length, tableColumns]);
43
+ const setColumnsCallback = (0, react_1.useCallback)((columnsSizing) => {
44
+ setColumns((prevColumns) => {
45
+ var _a;
46
+ const tableWidth = ((_a = tableContainerRef.current) === null || _a === void 0 ? void 0 : _a.scrollWidth) || 0;
47
+ const newColumns = prevColumns.map((column) => (Object.assign(Object.assign({}, column), { width: (columnsSizing === null || columnsSizing === void 0 ? void 0 : columnsSizing[column.accessorKey]) || column.width || 0 })));
48
+ return (0, resizeColumns_1.resizeColumns)(newColumns, tableWidth);
49
+ });
50
+ }, []);
51
+ (0, react_1.useEffect)(() => {
52
+ const _setColumnsCallback = () => setColumnsCallback();
53
+ globalThis === null || globalThis === void 0 ? void 0 : globalThis.addEventListener('resize', _setColumnsCallback);
54
+ return () => {
55
+ globalThis === null || globalThis === void 0 ? void 0 : globalThis.removeEventListener('resize', _setColumnsCallback);
56
+ };
57
+ }, [setColumnsCallback]);
58
+ const onMouseDown = (0, react_1.useCallback)((selectedColumnRef, index) => {
59
+ var _a, _b;
60
+ const onMove = (clientXPos) => {
61
+ setColumns((prev) => {
62
+ var _a;
63
+ setIsResizing(true);
64
+ const startOffset = ((_a = selectedColumnRef.current) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect().left) || 0;
65
+ const selectedColumn = index;
66
+ const column1 = prev[selectedColumn], column2 = prev[selectedColumn + 1];
67
+ if (selectedColumn + 1 === prev.length) {
68
+ return prev;
69
+ }
70
+ const column1Width = column1.width || 0, column2Width = column2.width || 0;
71
+ const widthChange = clientXPos - (startOffset + column1Width);
72
+ let newColumn1Width = 40, newColumn2Width = 40;
73
+ if (widthChange > 0) {
74
+ newColumn2Width = Math.max(40, column2Width - widthChange);
75
+ newColumn1Width =
76
+ newColumn2Width === 40
77
+ ? column1Width + column2Width - 40
78
+ : column1Width + widthChange;
79
+ }
80
+ else {
81
+ newColumn1Width = Math.max(40, column1Width + widthChange);
82
+ newColumn2Width =
83
+ newColumn1Width === 40
84
+ ? column1Width + column2Width - 40
85
+ : column2Width - widthChange;
86
+ }
87
+ const newColumns = [...prev];
88
+ newColumns[selectedColumn] = Object.assign(Object.assign({}, column1), { width: newColumn1Width });
89
+ newColumns[selectedColumn + 1] = Object.assign(Object.assign({}, column2), { width: newColumn2Width });
90
+ return newColumns;
91
+ });
92
+ };
93
+ const mouseEvents = {
94
+ moveHandler: (e) => onMove(e.clientX),
95
+ upHandler: () => {
96
+ var _a, _b;
97
+ setTimeout(() => setIsResizing(false), 100);
98
+ (_a = globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) === null || _a === void 0 ? void 0 : _a.removeEventListener('mousemove', mouseEvents.moveHandler);
99
+ (_b = globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) === null || _b === void 0 ? void 0 : _b.removeEventListener('mouseup', mouseEvents.upHandler);
100
+ },
101
+ };
102
+ (_a = globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) === null || _a === void 0 ? void 0 : _a.addEventListener('mousemove', mouseEvents.moveHandler);
103
+ (_b = globalThis === null || globalThis === void 0 ? void 0 : globalThis.document) === null || _b === void 0 ? void 0 : _b.addEventListener('mouseup', mouseEvents.upHandler);
104
+ }, []);
105
+ (0, react_1.useEffect)(() => {
106
+ const resizer = new ResizeObserver(() => {
107
+ setColumnsCallback();
108
+ });
109
+ if (tableContainerRef.current) {
110
+ resizer.observe(tableContainerRef.current);
111
+ }
112
+ return () => resizer.disconnect();
113
+ }, [setColumnsCallback]);
114
+ const { getPreferences, setPreferences } = (0, persistentSettingsStore_1.useTablePersistentSettingsStore)(({ actions }) => ({
115
+ getPreferences: actions.getPreferences,
116
+ setPreferences: actions.setPreferences,
117
+ }));
118
+ (0, react_1.useEffect)(() => {
119
+ if (tablePersistentSettingsKey) {
120
+ const data = getPreferences(tablePersistentSettingsKey, 'columnsSizing');
121
+ if (data) {
122
+ columnsSizingRef.current =
123
+ data || {};
124
+ setColumnsCallback(data || {});
125
+ }
126
+ }
127
+ return () => {
128
+ setColumns([]);
129
+ };
130
+ }, [getPreferences, setColumnsCallback, tablePersistentSettingsKey]);
131
+ (0, react_1.useEffect)(() => {
132
+ const _columns = columns.reduce((acc, { accessorKey, width }) => {
133
+ acc[accessorKey] = width || 0;
134
+ return acc;
135
+ }, {});
136
+ const _columnsSizing = (allTableColumnsKeys || []).reduce((acc, accessorKey) => {
137
+ acc[accessorKey] =
138
+ _columns[accessorKey] || columnsSizingRef.current[accessorKey] || 0;
139
+ return acc;
140
+ }, {});
141
+ columnsSizingRef.current = Object.assign(Object.assign({}, columnsSizingRef.current), _columnsSizing);
142
+ if (tablePersistentSettingsKey) {
143
+ setPreferences({
144
+ columnsSizing: _columnsSizing,
145
+ }, tablePersistentSettingsKey);
146
+ }
147
+ }, [
148
+ allTableColumnsKeys,
149
+ columns,
150
+ setPreferences,
151
+ tablePersistentSettingsKey,
152
+ ]);
153
+ return {
154
+ columns,
155
+ tableContainerRef,
156
+ onMouseDown,
157
+ isResizing,
158
+ };
159
+ };
160
+ exports.default = useColumnResizing;
161
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../src/components/table/useTable/useColumnResizing/index.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright 2023 Google LLC
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * https://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ */
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.resizeColumns = void 0;
19
+ const resizeColumns = (columnsToResize, tableWidth) => {
20
+ const totalWidth = columnsToResize.reduce((acc, column) => acc + (column.width || 0), 0);
21
+ const diff = tableWidth - totalWidth;
22
+ // If the table is wider than the columns, we need to add the difference to the columns
23
+ if (diff > 0) {
24
+ const perColumnDiff = diff / columnsToResize.length;
25
+ columnsToResize.forEach((column) => {
26
+ if (!column.width) {
27
+ column.width = 0;
28
+ }
29
+ column.width += perColumnDiff;
30
+ });
31
+ }
32
+ // If the table is narrower than the columns, we need to remove the difference from the columns
33
+ else if (diff < 0) {
34
+ const sortedColumns = [...columnsToResize].sort(({ width: width1 }, { width: width2 }) => (width2 || 0) - (width1 || 0));
35
+ let columnsWithLowWidth = 0;
36
+ sortedColumns.forEach((column) => {
37
+ if (!column.width) {
38
+ column.width = 40;
39
+ }
40
+ const perColumnDiffPercentage = (column.width / totalWidth) * 100;
41
+ const diffCanApply = (perColumnDiffPercentage / 100) * (-diff + columnsWithLowWidth * 40);
42
+ if (column.width - diffCanApply >= 40) {
43
+ column.width -= diffCanApply;
44
+ }
45
+ else {
46
+ columnsWithLowWidth++;
47
+ column.width = 40;
48
+ }
49
+ });
50
+ }
51
+ return columnsToResize;
52
+ };
53
+ exports.resizeColumns = resizeColumns;
54
+ //# sourceMappingURL=resizeColumns.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resizeColumns.js","sourceRoot":"","sources":["../../../../../src/components/table/useTable/useColumnResizing/resizeColumns.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;GAcG;;;AAOI,MAAM,aAAa,GAAG,CAC3B,eAA8B,EAC9B,UAAkB,EAClB,EAAE;IACF,MAAM,UAAU,GAAG,eAAe,CAAC,MAAM,CACvC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,CAAC,EAC1C,CAAC,CACF,CAAC;IAEF,MAAM,IAAI,GAAG,UAAU,GAAG,UAAU,CAAC;IAErC,uFAAuF;IACvF,IAAI,IAAI,GAAG,CAAC,EAAE,CAAC;QACb,MAAM,aAAa,GAAG,IAAI,GAAG,eAAe,CAAC,MAAM,CAAC;QACpD,eAAe,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YACjC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;gBAClB,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;YACnB,CAAC;YAED,MAAM,CAAC,KAAK,IAAI,aAAa,CAAC;QAChC,CAAC,CAAC,CAAC;IACL,CAAC;IACD,+FAA+F;SAC1F,IAAI,IAAI,GAAG,CAAC,EAAE,CAAC;QAClB,MAAM,aAAa,GAAG,CAAC,GAAG,eAAe,CAAC,CAAC,IAAI,CAC7C,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,CAAC,CACxE,CAAC;QAEF,IAAI,mBAAmB,GAAG,CAAC,CAAC;QAE5B,aAAa,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YAC/B,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;gBAClB,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;YACpB,CAAC;YAED,MAAM,uBAAuB,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,UAAU,CAAC,GAAG,GAAG,CAAC;YAClE,MAAM,YAAY,GAChB,CAAC,uBAAuB,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,GAAG,mBAAmB,GAAG,EAAE,CAAC,CAAC;YAEvE,IAAI,MAAM,CAAC,KAAK,GAAG,YAAY,IAAI,EAAE,EAAE,CAAC;gBACtC,MAAM,CAAC,KAAK,IAAI,YAAY,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,mBAAmB,EAAE,CAAC;gBACtB,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;YACpB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,eAAe,CAAC;AACzB,CAAC,CAAC;AAjDW,QAAA,aAAa,iBAiDxB"}
@@ -0,0 +1,90 @@
1
+ "use strict";
2
+ /*
3
+ * Copyright 2023 Google LLC
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ * you may not use this file except in compliance with the License.
7
+ * You may obtain a copy of the License at
8
+ *
9
+ * https://www.apache.org/licenses/LICENSE-2.0
10
+ *
11
+ * Unless required by applicable law or agreed to in writing, software
12
+ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ * See the License for the specific language governing permissions and
15
+ * limitations under the License.
16
+ */
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ /**
19
+ * External dependencies.
20
+ */
21
+ const react_1 = require("react");
22
+ const common_1 = require("@google-psat/common");
23
+ const persistentSettingsStore_1 = require("../../persistentSettingsStore");
24
+ const useColumnSorting = (data, tablePersistentSettingsKey) => {
25
+ const [sortKey, _setSortKey] = (0, react_1.useState)('');
26
+ const [ascending, setAscending] = (0, react_1.useState)(true);
27
+ const [isDataLoading, setIsDataLoading] = (0, react_1.useState)(true);
28
+ const setSortOrder = (0, react_1.useCallback)((sortOrder) => {
29
+ setAscending(sortOrder === 'asc');
30
+ }, []);
31
+ const setSortKey = (0, react_1.useCallback)((newSortKey) => {
32
+ if (newSortKey === sortKey) {
33
+ setAscending(!ascending);
34
+ }
35
+ else {
36
+ _setSortKey(newSortKey);
37
+ setAscending(true);
38
+ }
39
+ }, [ascending, sortKey]);
40
+ const sortedData = (0, react_1.useMemo)(() => {
41
+ if (isDataLoading) {
42
+ return [];
43
+ }
44
+ const _sortedData = [...data].sort((a, b) => {
45
+ const candidateA = (0, common_1.getValueByKey)(sortKey, a);
46
+ const candidateB = (0, common_1.getValueByKey)(sortKey, b);
47
+ return ((candidateA === candidateB ? 0 : candidateA > candidateB ? 1 : -1) *
48
+ (ascending ? 1 : -1));
49
+ });
50
+ return _sortedData;
51
+ }, [ascending, data, isDataLoading, sortKey]);
52
+ const { getPreferences, setPreferences } = (0, persistentSettingsStore_1.useTablePersistentSettingsStore)(({ actions }) => ({
53
+ getPreferences: actions.getPreferences,
54
+ setPreferences: actions.setPreferences,
55
+ }));
56
+ (0, react_1.useEffect)(() => {
57
+ if (tablePersistentSettingsKey) {
58
+ const sortByData = getPreferences(tablePersistentSettingsKey, 'sortBy');
59
+ const sortOrderData = getPreferences(tablePersistentSettingsKey, 'sortOrder');
60
+ if (sortByData) {
61
+ _setSortKey(sortByData);
62
+ }
63
+ if (sortOrderData) {
64
+ setAscending(sortOrderData === 'asc');
65
+ }
66
+ }
67
+ setIsDataLoading(false);
68
+ return () => {
69
+ _setSortKey('');
70
+ setAscending(true);
71
+ };
72
+ }, [getPreferences, tablePersistentSettingsKey]);
73
+ (0, react_1.useEffect)(() => {
74
+ if (tablePersistentSettingsKey && sortKey) {
75
+ setPreferences({
76
+ sortBy: sortKey,
77
+ sortOrder: ascending ? 'asc' : 'desc',
78
+ }, tablePersistentSettingsKey);
79
+ }
80
+ }, [sortKey, ascending, tablePersistentSettingsKey, setPreferences]);
81
+ return {
82
+ sortedData,
83
+ setSortKey,
84
+ setSortOrder,
85
+ sortKey,
86
+ sortOrder: ascending ? 'asc' : 'desc',
87
+ };
88
+ };
89
+ exports.default = useColumnSorting;
90
+ //# sourceMappingURL=index.jsx.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../src/components/table/useTable/useColumnSorting/index.tsx"],"names":[],"mappings":"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"}