@databiosphere/findable-ui 19.0.0 → 21.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (510) hide show
  1. package/.release-please-manifest.json +1 -1
  2. package/CHANGELOG.md +22 -0
  3. package/lib/components/Authentication/components/SessionController/components/GoogleSessionController/SessionController.d.ts +2 -0
  4. package/lib/components/Authentication/components/SessionController/components/GoogleSessionController/SessionController.js +29 -0
  5. package/lib/components/Authentication/components/SessionController/components/GoogleSessionController/types.d.ts +6 -0
  6. package/lib/components/Authentication/components/SessionController/components/GoogleSessionController/types.js +1 -0
  7. package/lib/components/Authentication/components/SessionController/components/NextSessionController/SessionController.d.ts +2 -0
  8. package/lib/components/Authentication/components/SessionController/components/NextSessionController/SessionController.js +17 -0
  9. package/lib/components/Authentication/components/SessionController/components/NextSessionController/constants.d.ts +5 -0
  10. package/lib/components/Authentication/components/SessionController/components/NextSessionController/constants.js +12 -0
  11. package/lib/components/Authentication/components/SessionController/components/NextSessionController/types.d.ts +4 -0
  12. package/lib/components/Authentication/components/SessionController/components/NextSessionController/types.js +1 -0
  13. package/lib/components/Authentication/components/SessionController/components/NextSessionController/utils.d.ts +15 -0
  14. package/lib/components/Authentication/components/SessionController/components/NextSessionController/utils.js +53 -0
  15. package/lib/components/ComponentCreator/ComponentCreator.js +2 -3
  16. package/lib/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/FormStep/components/AcceptTerraTOS/acceptTerraTOS.js +2 -2
  17. package/lib/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/NIHAccountExpiryWarning/nihAccountExpiryWarning.js +1 -1
  18. package/lib/components/Export/components/ExportToTerra/components/TerraSetUpForm/terraSetUpForm.js +8 -3
  19. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.d.ts +2 -1
  20. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.js +17 -14
  21. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.d.ts +3 -4
  22. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.js +15 -24
  23. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.d.ts +1 -1
  24. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.js +2 -2
  25. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/constants.d.ts +2 -0
  26. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/constants.js +14 -0
  27. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/Button/button.styles.js +3 -2
  28. package/lib/components/Layout/components/Header/header.js +1 -1
  29. package/lib/components/Login/components/Button/button.d.ts +2 -0
  30. package/lib/components/Login/components/Button/button.js +6 -0
  31. package/lib/components/Login/components/Button/button.styles.d.ts +5 -0
  32. package/lib/components/Login/components/Button/button.styles.js +11 -0
  33. package/lib/components/Login/components/Button/constants.d.ts +2 -0
  34. package/lib/components/Login/components/Button/constants.js +6 -0
  35. package/lib/components/Login/components/Button/types.d.ts +3 -0
  36. package/lib/components/Login/components/Button/types.js +1 -0
  37. package/lib/components/Login/login.d.ts +2 -9
  38. package/lib/components/Login/login.js +9 -10
  39. package/lib/components/Login/types.d.ts +10 -0
  40. package/lib/components/Login/types.js +1 -0
  41. package/lib/components/Table/common/columnDef.js +18 -2
  42. package/lib/components/Table/common/columnIdentifier.d.ts +4 -0
  43. package/lib/components/Table/common/columnIdentifier.js +4 -0
  44. package/lib/components/Table/common/typeGuards.d.ts +11 -0
  45. package/lib/components/Table/common/typeGuards.js +8 -0
  46. package/lib/components/Table/common/utils.d.ts +1 -28
  47. package/lib/components/Table/common/utils.js +5 -88
  48. package/lib/components/Table/components/TableCell/common/utils.js +3 -3
  49. package/lib/components/Table/components/TableCell/components/RowSelectionCell/rowSelectionCell.d.ts +2 -5
  50. package/lib/components/Table/components/TableFeatures/ColumnVisibility/utils.d.ts +7 -18
  51. package/lib/components/Table/components/TableFeatures/ColumnVisibility/utils.js +20 -31
  52. package/lib/components/Table/components/TableHead/components/HeadSelectionCell/headSelectionCell.d.ts +2 -5
  53. package/lib/components/Table/components/TableHead/components/HeadSelectionCell/headSelectionCell.js +2 -2
  54. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/columnGrouping.js +5 -17
  55. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/constants.d.ts +3 -0
  56. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/constants.js +10 -0
  57. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/menuItems.d.ts +1 -1
  58. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/menuItems.js +22 -10
  59. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/types.d.ts +1 -2
  60. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/utils.d.ts +27 -0
  61. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/utils.js +45 -0
  62. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/constants.d.ts +1 -3
  63. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/constants.js +0 -10
  64. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/utils.d.ts +3 -13
  65. package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/utils.js +22 -27
  66. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/columnVisibility.d.ts +3 -0
  67. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/columnVisibility.js +13 -0
  68. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/columnVisibility.styles.d.ts +3 -0
  69. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/columnVisibility.styles.js +11 -0
  70. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/constants.d.ts +2 -0
  71. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/constants.js +7 -0
  72. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/menuItems.d.ts +3 -0
  73. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/menuItems.js +22 -0
  74. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/menuItems.styles.d.ts +2 -0
  75. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/menuItems.styles.js +16 -0
  76. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/types.d.ts +4 -0
  77. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/types.js +1 -0
  78. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/utils.d.ts +26 -0
  79. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/utils.js +32 -0
  80. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/constants.d.ts +2 -0
  81. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/constants.js +3 -0
  82. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/types.d.ts +4 -0
  83. package/lib/components/Table/components/TableToolbar/components/ColumnVisibility/types.js +1 -0
  84. package/lib/components/Table/components/TableToolbar/tableToolbar.js +5 -12
  85. package/lib/components/Table/features/RowPosition/constants.js +5 -3
  86. package/lib/components/Table/features/RowPosition/types.d.ts +3 -0
  87. package/lib/components/Table/features/RowPosition/utils.d.ts +1 -7
  88. package/lib/components/Table/features/RowPosition/utils.js +0 -20
  89. package/lib/components/Table/features/RowPreview/constants.js +1 -1
  90. package/lib/components/Table/features/entities.d.ts +2 -2
  91. package/lib/components/Table/table.d.ts +2 -4
  92. package/lib/components/Table/table.js +9 -31
  93. package/lib/components/TableCreator/common/utils.js +1 -4
  94. package/lib/components/TableCreator/options/columnTrackSizing/typeGuards.d.ts +7 -0
  95. package/lib/components/TableCreator/options/columnTrackSizing/typeGuards.js +8 -0
  96. package/lib/components/TableCreator/options/columnTrackSizing/utils.d.ts +30 -0
  97. package/lib/components/TableCreator/options/columnTrackSizing/utils.js +83 -0
  98. package/lib/components/TableCreator/options/hook.js +8 -7
  99. package/lib/components/TableCreator/options/initialState/columnVisibility.d.ts +7 -0
  100. package/lib/components/TableCreator/options/initialState/columnVisibility.js +16 -0
  101. package/lib/components/TableCreator/options/initialState/hook.d.ts +2 -0
  102. package/lib/components/TableCreator/options/initialState/hook.js +10 -0
  103. package/lib/components/TableCreator/options/visibility/constants.d.ts +2 -0
  104. package/lib/components/TableCreator/options/visibility/constants.js +3 -0
  105. package/lib/components/TableCreator/options/visibility/hook.d.ts +2 -0
  106. package/lib/components/TableCreator/options/visibility/hook.js +11 -0
  107. package/lib/components/TableCreator/tableCreator.js +4 -18
  108. package/lib/components/common/Banner/components/SessionTimeout/sessionTimeout.js +1 -1
  109. package/lib/components/common/CustomIcon/common/entities.d.ts +1 -4
  110. package/lib/components/common/CustomIcon/components/GoogleIcon/googleIcon.d.ts +2 -2
  111. package/lib/components/common/CustomIcon/components/GoogleIcon/googleIcon.js +1 -1
  112. package/lib/config/entities.d.ts +22 -27
  113. package/lib/hooks/authentication/auth/useAuthReducer.d.ts +2 -0
  114. package/lib/hooks/authentication/auth/useAuthReducer.js +8 -0
  115. package/lib/hooks/authentication/authentication/useAuthenticationReducer.d.ts +2 -0
  116. package/lib/hooks/authentication/authentication/useAuthenticationReducer.js +8 -0
  117. package/lib/hooks/authentication/config/useAuthenticationConfig.d.ts +6 -0
  118. package/lib/hooks/authentication/config/useAuthenticationConfig.js +9 -0
  119. package/lib/hooks/authentication/credentials/useCredentialsReducer.d.ts +2 -0
  120. package/lib/hooks/authentication/credentials/useCredentialsReducer.js +7 -0
  121. package/lib/hooks/authentication/profile/types.d.ts +5 -0
  122. package/lib/hooks/authentication/profile/types.js +1 -0
  123. package/lib/hooks/authentication/profile/useProfile.d.ts +6 -0
  124. package/lib/hooks/authentication/profile/useProfile.js +15 -0
  125. package/lib/hooks/authentication/providers/types.d.ts +6 -0
  126. package/lib/hooks/authentication/providers/types.js +1 -0
  127. package/lib/hooks/authentication/providers/useProviders.d.ts +6 -0
  128. package/lib/hooks/authentication/providers/useProviders.js +14 -0
  129. package/lib/hooks/authentication/session/useSessionActive.d.ts +12 -0
  130. package/lib/hooks/authentication/session/useSessionActive.js +36 -0
  131. package/lib/hooks/authentication/session/useSessionCallbackUrl.d.ts +4 -0
  132. package/lib/hooks/authentication/session/useSessionCallbackUrl.js +20 -0
  133. package/lib/hooks/authentication/session/useSessionIdleTimer.d.ts +6 -0
  134. package/lib/hooks/authentication/session/useSessionIdleTimer.js +8 -0
  135. package/lib/hooks/{useSessionTimeout.js → authentication/session/useSessionTimeout.js} +2 -2
  136. package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.d.ts +0 -1
  137. package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.js +6 -9
  138. package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.js +3 -4
  139. package/lib/hooks/authentication/token/types.d.ts +4 -0
  140. package/lib/hooks/authentication/token/types.js +1 -0
  141. package/lib/hooks/authentication/token/useToken.d.ts +2 -0
  142. package/lib/hooks/authentication/token/useToken.js +5 -0
  143. package/lib/hooks/authentication/token/useTokenReducer.d.ts +7 -0
  144. package/lib/hooks/authentication/token/useTokenReducer.js +12 -0
  145. package/lib/hooks/useEntityList.js +2 -2
  146. package/lib/hooks/useFetchEntity.js +4 -3
  147. package/lib/hooks/useFileManifest/useFetchFilesFacets.js +2 -3
  148. package/lib/hooks/useFileManifest/useFetchSummary.js +2 -3
  149. package/lib/hooks/useRequestFileLocation.js +2 -3
  150. package/lib/hooks/useRouteHistory.d.ts +14 -0
  151. package/lib/hooks/useRouteHistory.js +40 -0
  152. package/lib/hooks/useRouteRoot.d.ts +1 -0
  153. package/lib/hooks/useRouteRoot.js +8 -0
  154. package/lib/hooks/useSummary.js +3 -3
  155. package/lib/providers/authentication/auth/actions.d.ts +8 -0
  156. package/lib/providers/authentication/auth/actions.js +12 -0
  157. package/lib/providers/authentication/auth/constants.d.ts +2 -0
  158. package/lib/providers/authentication/auth/constants.js +5 -0
  159. package/lib/providers/authentication/auth/context.d.ts +2 -0
  160. package/lib/providers/authentication/auth/context.js +7 -0
  161. package/lib/providers/authentication/auth/dispatch.d.ts +23 -0
  162. package/lib/providers/authentication/auth/dispatch.js +43 -0
  163. package/lib/providers/authentication/auth/hook.d.ts +6 -0
  164. package/lib/providers/authentication/auth/hook.js +9 -0
  165. package/lib/providers/authentication/auth/reducer.d.ts +8 -0
  166. package/lib/providers/authentication/auth/reducer.js +24 -0
  167. package/lib/providers/authentication/auth/types.d.ts +48 -0
  168. package/lib/providers/authentication/auth/types.js +11 -0
  169. package/lib/providers/authentication/authentication/actions.d.ts +8 -0
  170. package/lib/providers/authentication/authentication/actions.js +12 -0
  171. package/lib/providers/authentication/authentication/constants.d.ts +2 -0
  172. package/lib/providers/authentication/authentication/constants.js +5 -0
  173. package/lib/providers/authentication/authentication/context.d.ts +2 -0
  174. package/lib/providers/authentication/authentication/context.js +6 -0
  175. package/lib/providers/authentication/authentication/dispatch.d.ts +22 -0
  176. package/lib/providers/authentication/authentication/dispatch.js +42 -0
  177. package/lib/providers/authentication/authentication/hook.d.ts +6 -0
  178. package/lib/providers/authentication/authentication/hook.js +9 -0
  179. package/lib/providers/authentication/authentication/reducer.d.ts +9 -0
  180. package/lib/providers/authentication/authentication/reducer.js +25 -0
  181. package/lib/providers/authentication/authentication/types.d.ts +47 -0
  182. package/lib/providers/authentication/authentication/types.js +11 -0
  183. package/lib/providers/authentication/authentication/utils.d.ts +12 -0
  184. package/lib/providers/authentication/authentication/utils.js +18 -0
  185. package/lib/providers/authentication/common/types.d.ts +1 -0
  186. package/lib/providers/authentication/common/types.js +1 -0
  187. package/lib/providers/authentication/common/utils.d.ts +6 -0
  188. package/lib/providers/authentication/common/utils.js +11 -0
  189. package/lib/providers/authentication/credentials/actions.d.ts +8 -0
  190. package/lib/providers/authentication/credentials/actions.js +12 -0
  191. package/lib/providers/authentication/credentials/constants.d.ts +2 -0
  192. package/lib/providers/authentication/credentials/constants.js +3 -0
  193. package/lib/providers/authentication/credentials/context.d.ts +2 -0
  194. package/lib/providers/authentication/credentials/context.js +6 -0
  195. package/lib/providers/authentication/credentials/dispatch.d.ts +12 -0
  196. package/lib/providers/authentication/credentials/dispatch.js +22 -0
  197. package/lib/providers/authentication/credentials/hook.d.ts +6 -0
  198. package/lib/providers/authentication/credentials/hook.js +9 -0
  199. package/lib/providers/authentication/credentials/reducer.d.ts +8 -0
  200. package/lib/providers/authentication/credentials/reducer.js +22 -0
  201. package/lib/providers/authentication/credentials/types.d.ts +24 -0
  202. package/lib/providers/authentication/credentials/types.js +5 -0
  203. package/lib/providers/authentication/terra/context.d.ts +2 -0
  204. package/lib/providers/authentication/terra/context.js +7 -0
  205. package/lib/providers/authentication/terra/hook.d.ts +6 -0
  206. package/lib/providers/authentication/terra/hook.js +9 -0
  207. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.d.ts +2 -0
  208. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.js +7 -0
  209. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.d.ts +3 -7
  210. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.js +1 -5
  211. package/lib/providers/authentication/terra/hooks/useFetchProfiles.d.ts +13 -0
  212. package/lib/providers/authentication/terra/hooks/useFetchProfiles.js +31 -0
  213. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.js +11 -6
  214. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.js +11 -6
  215. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.js +11 -6
  216. package/lib/providers/authentication/terra/hooks/utils.d.ts +16 -0
  217. package/lib/providers/authentication/terra/hooks/utils.js +19 -0
  218. package/lib/providers/authentication/terra/provider.d.ts +2 -0
  219. package/lib/providers/authentication/terra/provider.js +42 -0
  220. package/lib/providers/authentication/terra/types.d.ts +20 -0
  221. package/lib/providers/authentication/terra/types.js +6 -0
  222. package/lib/providers/authentication/terra/utils.d.ts +19 -0
  223. package/lib/providers/authentication/terra/utils.js +36 -0
  224. package/lib/providers/authentication/token/constants.d.ts +2 -0
  225. package/lib/providers/authentication/token/constants.js +4 -0
  226. package/lib/providers/authentication/token/dispatch.d.ts +12 -0
  227. package/lib/providers/authentication/token/dispatch.js +22 -0
  228. package/lib/providers/authentication/token/reducer.d.ts +8 -0
  229. package/lib/providers/authentication/token/reducer.js +22 -0
  230. package/lib/providers/authentication/token/types.d.ts +28 -0
  231. package/lib/providers/authentication/token/types.js +5 -0
  232. package/lib/providers/exploreState/actions/updateVisibility/action.d.ts +10 -0
  233. package/lib/providers/exploreState/actions/updateVisibility/action.js +16 -0
  234. package/lib/providers/exploreState/actions/updateVisibility/dispatch.d.ts +7 -0
  235. package/lib/providers/exploreState/actions/updateVisibility/dispatch.js +12 -0
  236. package/lib/providers/exploreState/actions/updateVisibility/types.d.ts +9 -0
  237. package/lib/providers/exploreState/actions/updateVisibility/types.js +1 -0
  238. package/lib/providers/exploreState/actions/updateVisibility/utils.d.ts +10 -0
  239. package/lib/providers/exploreState/actions/updateVisibility/utils.js +21 -0
  240. package/lib/providers/exploreState/entities.d.ts +1 -1
  241. package/lib/providers/exploreState/initializer/utils.js +5 -13
  242. package/lib/providers/exploreState/payloads/entities.d.ts +1 -5
  243. package/lib/providers/exploreState/utils.d.ts +1 -1
  244. package/lib/providers/exploreState/utils.js +5 -5
  245. package/lib/providers/exploreState.d.ts +2 -8
  246. package/lib/providers/exploreState.js +5 -10
  247. package/lib/providers/googleSignInAuthentication/common/types.d.ts +17 -0
  248. package/lib/providers/googleSignInAuthentication/common/types.js +1 -0
  249. package/lib/providers/googleSignInAuthentication/constants.d.ts +4 -0
  250. package/lib/providers/googleSignInAuthentication/constants.js +12 -0
  251. package/lib/providers/googleSignInAuthentication/hooks/useGoogleSignInService.d.ts +3 -0
  252. package/lib/providers/googleSignInAuthentication/hooks/useGoogleSignInService.js +36 -0
  253. package/lib/providers/googleSignInAuthentication/profile/types.d.ts +14 -0
  254. package/lib/providers/googleSignInAuthentication/profile/types.js +1 -0
  255. package/lib/providers/googleSignInAuthentication/profile/utils.d.ts +8 -0
  256. package/lib/providers/googleSignInAuthentication/profile/utils.js +25 -0
  257. package/lib/providers/googleSignInAuthentication/provider.d.ts +2 -0
  258. package/lib/providers/googleSignInAuthentication/provider.js +40 -0
  259. package/lib/providers/googleSignInAuthentication/service/constants.d.ts +4 -0
  260. package/lib/providers/googleSignInAuthentication/service/constants.js +9 -0
  261. package/lib/providers/googleSignInAuthentication/service/service.d.ts +6 -0
  262. package/lib/providers/googleSignInAuthentication/service/service.js +43 -0
  263. package/lib/providers/googleSignInAuthentication/types.d.ts +6 -0
  264. package/lib/providers/googleSignInAuthentication/types.js +1 -0
  265. package/lib/providers/nextAuthAuthentication/hooks/useNextAuthService.d.ts +2 -0
  266. package/lib/providers/nextAuthAuthentication/hooks/useNextAuthService.js +14 -0
  267. package/lib/providers/nextAuthAuthentication/provider.d.ts +2 -0
  268. package/lib/providers/nextAuthAuthentication/provider.js +30 -0
  269. package/lib/providers/nextAuthAuthentication/service/service.d.ts +6 -0
  270. package/lib/providers/nextAuthAuthentication/service/service.js +12 -0
  271. package/lib/providers/nextAuthAuthentication/types.d.ts +8 -0
  272. package/lib/providers/nextAuthAuthentication/types.js +1 -0
  273. package/lib/routes/constants.d.ts +3 -0
  274. package/lib/routes/constants.js +3 -0
  275. package/lib/styles/common/mui/button.d.ts +3 -0
  276. package/lib/styles/common/mui/button.js +17 -0
  277. package/lib/styles/common/mui/paper.d.ts +2 -0
  278. package/lib/styles/common/mui/paper.js +9 -0
  279. package/lib/styles/common/mui/popover.d.ts +3 -0
  280. package/lib/styles/common/mui/popover.js +10 -0
  281. package/lib/theme/common/entities.d.ts +6 -0
  282. package/lib/theme/common/entities.js +1 -0
  283. package/lib/views/LoginView/loginView.d.ts +5 -1
  284. package/lib/views/LoginView/loginView.js +6 -4
  285. package/package.json +3 -2
  286. package/src/components/Authentication/components/SessionController/components/GoogleSessionController/SessionController.tsx +38 -0
  287. package/src/components/Authentication/components/SessionController/components/GoogleSessionController/types.ts +7 -0
  288. package/src/components/Authentication/components/SessionController/components/NextSessionController/SessionController.tsx +23 -0
  289. package/src/components/Authentication/components/SessionController/components/NextSessionController/constants.ts +21 -0
  290. package/src/components/Authentication/components/SessionController/components/NextSessionController/types.ts +5 -0
  291. package/src/components/Authentication/components/SessionController/components/NextSessionController/utils.ts +74 -0
  292. package/src/components/ComponentCreator/ComponentCreator.tsx +4 -3
  293. package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/FormStep/components/AcceptTerraTOS/acceptTerraTOS.tsx +4 -4
  294. package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/NIHAccountExpiryWarning/nihAccountExpiryWarning.tsx +1 -1
  295. package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/terraSetUpForm.tsx +9 -6
  296. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.tsx +27 -25
  297. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.ts +2 -2
  298. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.tsx +18 -42
  299. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/constants.ts +19 -0
  300. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/Button/button.styles.ts +3 -2
  301. package/src/components/Layout/components/Header/header.tsx +1 -1
  302. package/src/components/Login/components/Button/button.styles.ts +12 -0
  303. package/src/components/Login/components/Button/button.tsx +8 -0
  304. package/src/components/Login/components/Button/constants.ts +8 -0
  305. package/src/components/Login/components/Button/types.ts +4 -0
  306. package/src/components/Login/login.tsx +28 -28
  307. package/src/components/Login/types.ts +11 -0
  308. package/src/components/Table/common/columnDef.ts +18 -2
  309. package/src/components/Table/common/columnIdentifier.ts +4 -0
  310. package/src/components/Table/common/typeGuards.ts +12 -0
  311. package/src/components/Table/common/utils.ts +5 -115
  312. package/src/components/Table/components/TableCell/common/utils.ts +3 -3
  313. package/src/components/Table/components/TableCell/components/RowSelectionCell/rowSelectionCell.tsx +3 -7
  314. package/src/components/Table/components/TableFeatures/ColumnVisibility/utils.ts +25 -44
  315. package/src/components/Table/components/TableHead/components/HeadSelectionCell/headSelectionCell.tsx +5 -9
  316. package/src/components/Table/components/TableToolbar/components/ColumnGrouping/columnGrouping.tsx +4 -22
  317. package/src/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/constants.ts +13 -0
  318. package/src/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/menuItems.tsx +47 -20
  319. package/src/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/types.ts +1 -2
  320. package/src/components/Table/components/TableToolbar/components/ColumnGrouping/components/MenuItems/utils.ts +58 -0
  321. package/src/components/Table/components/TableToolbar/components/ColumnGrouping/constants.ts +1 -13
  322. package/src/components/Table/components/TableToolbar/components/ColumnGrouping/utils.ts +26 -33
  323. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/columnVisibility.styles.ts +12 -0
  324. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/columnVisibility.tsx +28 -0
  325. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/constants.ts +9 -0
  326. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/menuItems.styles.ts +17 -0
  327. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/menuItems.tsx +53 -0
  328. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/types.ts +5 -0
  329. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/components/MenuItems/utils.ts +44 -0
  330. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/constants.ts +5 -0
  331. package/src/components/Table/components/TableToolbar/components/ColumnVisibility/types.ts +5 -0
  332. package/src/components/Table/components/TableToolbar/tableToolbar.tsx +5 -19
  333. package/src/components/Table/features/RowPosition/constants.ts +8 -5
  334. package/src/components/Table/features/RowPosition/types.ts +4 -0
  335. package/src/components/Table/features/RowPosition/utils.ts +1 -30
  336. package/src/components/Table/features/RowPreview/constants.ts +1 -1
  337. package/src/components/Table/features/entities.ts +2 -2
  338. package/src/components/Table/table.tsx +8 -46
  339. package/src/components/TableCreator/common/utils.ts +0 -4
  340. package/src/components/TableCreator/options/columnTrackSizing/typeGuards.ts +12 -0
  341. package/src/components/TableCreator/options/columnTrackSizing/utils.ts +99 -0
  342. package/src/components/TableCreator/options/hook.ts +8 -11
  343. package/src/components/TableCreator/options/initialState/columnVisibility.ts +22 -0
  344. package/src/components/TableCreator/options/initialState/hook.ts +24 -0
  345. package/src/components/TableCreator/options/visibility/constants.ts +5 -0
  346. package/src/components/TableCreator/options/visibility/hook.ts +22 -0
  347. package/src/components/TableCreator/tableCreator.tsx +3 -27
  348. package/src/components/common/Banner/components/SessionTimeout/sessionTimeout.tsx +1 -1
  349. package/src/components/common/CustomIcon/common/entities.ts +1 -4
  350. package/src/components/common/CustomIcon/components/GoogleIcon/googleIcon.tsx +3 -4
  351. package/src/config/entities.ts +22 -29
  352. package/src/hooks/authentication/auth/useAuthReducer.ts +16 -0
  353. package/src/hooks/authentication/authentication/useAuthenticationReducer.ts +16 -0
  354. package/src/hooks/authentication/config/useAuthenticationConfig.ts +13 -0
  355. package/src/hooks/authentication/credentials/useCredentialsReducer.ts +13 -0
  356. package/src/hooks/authentication/profile/types.ts +9 -0
  357. package/src/hooks/authentication/profile/useProfile.ts +21 -0
  358. package/src/hooks/authentication/providers/types.ts +7 -0
  359. package/src/hooks/authentication/providers/useProviders.ts +23 -0
  360. package/src/hooks/authentication/session/useSessionActive.ts +51 -0
  361. package/src/hooks/authentication/session/useSessionCallbackUrl.ts +25 -0
  362. package/src/hooks/authentication/session/useSessionIdleTimer.ts +10 -0
  363. package/src/hooks/{useSessionTimeout.ts → authentication/session/useSessionTimeout.ts} +2 -2
  364. package/src/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.ts +8 -13
  365. package/src/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.ts +3 -4
  366. package/src/hooks/authentication/token/types.ts +5 -0
  367. package/src/hooks/authentication/token/useToken.ts +9 -0
  368. package/src/hooks/authentication/token/useTokenReducer.ts +19 -0
  369. package/src/hooks/useEntityList.ts +2 -2
  370. package/src/hooks/useFetchEntity.tsx +3 -3
  371. package/src/hooks/useFileManifest/useFetchFilesFacets.ts +2 -3
  372. package/src/hooks/useFileManifest/useFetchSummary.ts +2 -3
  373. package/src/hooks/useRequestFileLocation.ts +2 -3
  374. package/src/hooks/useRouteHistory.ts +65 -0
  375. package/src/hooks/useRouteRoot.ts +11 -0
  376. package/src/hooks/useSummary.ts +3 -3
  377. package/src/providers/authentication/auth/actions.ts +17 -0
  378. package/src/providers/authentication/auth/constants.ts +6 -0
  379. package/src/providers/authentication/auth/context.ts +9 -0
  380. package/src/providers/authentication/auth/dispatch.ts +58 -0
  381. package/src/providers/authentication/auth/hook.ts +11 -0
  382. package/src/providers/authentication/auth/reducer.ts +25 -0
  383. package/src/providers/authentication/auth/types.ts +63 -0
  384. package/src/providers/authentication/authentication/actions.ts +17 -0
  385. package/src/providers/authentication/authentication/constants.ts +6 -0
  386. package/src/providers/authentication/authentication/context.ts +8 -0
  387. package/src/providers/authentication/authentication/dispatch.ts +55 -0
  388. package/src/providers/authentication/authentication/hook.ts +11 -0
  389. package/src/providers/authentication/authentication/reducer.ts +34 -0
  390. package/src/providers/authentication/authentication/types.ts +64 -0
  391. package/src/providers/authentication/authentication/utils.ts +25 -0
  392. package/src/providers/authentication/common/types.ts +1 -0
  393. package/src/providers/authentication/common/utils.ts +11 -0
  394. package/src/providers/authentication/credentials/actions.ts +17 -0
  395. package/src/providers/authentication/credentials/constants.ts +5 -0
  396. package/src/providers/authentication/credentials/context.ts +8 -0
  397. package/src/providers/authentication/credentials/dispatch.ts +31 -0
  398. package/src/providers/authentication/credentials/hook.ts +11 -0
  399. package/src/providers/authentication/credentials/reducer.ts +30 -0
  400. package/src/providers/authentication/credentials/types.ts +33 -0
  401. package/src/providers/authentication/terra/context.ts +16 -0
  402. package/src/providers/authentication/terra/hook.ts +11 -0
  403. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.ts +9 -0
  404. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.ts +1 -7
  405. package/src/providers/authentication/terra/hooks/useFetchProfiles.ts +61 -0
  406. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.ts +18 -7
  407. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.ts +18 -7
  408. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.ts +18 -7
  409. package/src/providers/authentication/terra/hooks/utils.ts +29 -0
  410. package/src/providers/authentication/terra/provider.tsx +60 -0
  411. package/src/providers/authentication/terra/types.ts +23 -0
  412. package/src/providers/authentication/terra/utils.ts +49 -0
  413. package/src/providers/authentication/token/constants.ts +6 -0
  414. package/src/providers/authentication/token/dispatch.ts +29 -0
  415. package/src/providers/authentication/token/reducer.ts +26 -0
  416. package/src/providers/authentication/token/types.ts +36 -0
  417. package/src/providers/exploreState/actions/updateVisibility/action.ts +29 -0
  418. package/src/providers/exploreState/actions/updateVisibility/dispatch.ts +19 -0
  419. package/src/providers/exploreState/actions/updateVisibility/types.ts +11 -0
  420. package/src/providers/exploreState/actions/updateVisibility/utils.ts +28 -0
  421. package/src/providers/exploreState/entities.ts +1 -1
  422. package/src/providers/exploreState/initializer/utils.ts +5 -21
  423. package/src/providers/exploreState/payloads/entities.ts +0 -6
  424. package/src/providers/exploreState/utils.ts +5 -5
  425. package/src/providers/exploreState.tsx +6 -22
  426. package/src/providers/googleSignInAuthentication/common/types.ts +28 -0
  427. package/src/providers/googleSignInAuthentication/constants.ts +17 -0
  428. package/src/providers/googleSignInAuthentication/hooks/useGoogleSignInService.ts +53 -0
  429. package/src/providers/googleSignInAuthentication/profile/types.ts +15 -0
  430. package/src/providers/googleSignInAuthentication/profile/utils.ts +29 -0
  431. package/src/providers/googleSignInAuthentication/provider.tsx +53 -0
  432. package/src/providers/googleSignInAuthentication/service/constants.ts +16 -0
  433. package/src/providers/googleSignInAuthentication/service/service.ts +68 -0
  434. package/src/providers/googleSignInAuthentication/types.ts +7 -0
  435. package/src/providers/nextAuthAuthentication/hooks/useNextAuthService.ts +26 -0
  436. package/src/providers/nextAuthAuthentication/provider.tsx +42 -0
  437. package/src/providers/nextAuthAuthentication/service/service.ts +14 -0
  438. package/src/providers/nextAuthAuthentication/types.ts +9 -0
  439. package/src/routes/constants.ts +3 -0
  440. package/src/styles/common/mui/button.ts +20 -0
  441. package/src/styles/common/mui/paper.ts +11 -0
  442. package/src/styles/common/mui/popover.ts +19 -0
  443. package/src/theme/common/entities.ts +7 -0
  444. package/src/views/LoginView/loginView.tsx +15 -9
  445. package/tests/getProfileStatus.test.ts +290 -0
  446. package/tests/terraProfileProvider.test.tsx +121 -0
  447. package/tests/transformRoute.test.ts +21 -0
  448. package/tests/useRouteHistory.test.ts +97 -0
  449. package/tests/useSessionActive.test.ts +107 -0
  450. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.d.ts +0 -5
  451. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.js +0 -29
  452. package/lib/components/Login/login.stories.d.ts +0 -6
  453. package/lib/components/Login/login.stories.js +0 -31
  454. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.d.ts +0 -16
  455. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.js +0 -28
  456. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.stories.d.ts +0 -5
  457. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.stories.js +0 -46
  458. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.styles.d.ts +0 -3
  459. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.styles.js +0 -21
  460. package/lib/components/Table/features/constants.d.ts +0 -6
  461. package/lib/components/Table/features/constants.js +0 -8
  462. package/lib/components/TableCreator/common/constants.d.ts +0 -7
  463. package/lib/components/TableCreator/common/constants.js +0 -21
  464. package/lib/components/common/Button/components/LoginButton/loginButton.d.ts +0 -3
  465. package/lib/components/common/Button/components/LoginButton/loginButton.js +0 -6
  466. package/lib/components/common/Button/components/LoginButton/loginButton.styles.d.ts +0 -7
  467. package/lib/components/common/Button/components/LoginButton/loginButton.styles.js +0 -11
  468. package/lib/hooks/useAuthentication/useAuthentication.d.ts +0 -6
  469. package/lib/hooks/useAuthentication/useAuthentication.js +0 -9
  470. package/lib/hooks/useAuthentication/useAuthenticationComplete.d.ts +0 -6
  471. package/lib/hooks/useAuthentication/useAuthenticationComplete.js +0 -55
  472. package/lib/hooks/useAuthentication/useAuthenticationStatus.d.ts +0 -20
  473. package/lib/hooks/useAuthentication/useAuthenticationStatus.js +0 -32
  474. package/lib/hooks/useAuthentication/useFetchGoogleProfile.d.ts +0 -21
  475. package/lib/hooks/useAuthentication/useFetchGoogleProfile.js +0 -41
  476. package/lib/hooks/useAuthentication/useTokenClient.d.ts +0 -11
  477. package/lib/hooks/useAuthentication/useTokenClient.js +0 -29
  478. package/lib/hooks/useAuthenticationConfig.d.ts +0 -6
  479. package/lib/hooks/useAuthenticationConfig.js +0 -14
  480. package/lib/providers/authentication.d.ts +0 -51
  481. package/lib/providers/authentication.js +0 -110
  482. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.tsx +0 -35
  483. package/src/components/Login/login.stories.tsx +0 -43
  484. package/src/components/Table/components/CheckboxMenu/checkboxMenu.stories.tsx +0 -54
  485. package/src/components/Table/components/CheckboxMenu/checkboxMenu.styles.ts +0 -22
  486. package/src/components/Table/components/CheckboxMenu/checkboxMenu.tsx +0 -87
  487. package/src/components/Table/features/constants.ts +0 -10
  488. package/src/components/TableCreator/common/constants.ts +0 -25
  489. package/src/components/common/Button/components/LoginButton/loginButton.styles.ts +0 -13
  490. package/src/components/common/Button/components/LoginButton/loginButton.tsx +0 -16
  491. package/src/hooks/useAuthentication/useAuthentication.tsx +0 -10
  492. package/src/hooks/useAuthentication/useAuthenticationComplete.ts +0 -66
  493. package/src/hooks/useAuthentication/useAuthenticationStatus.ts +0 -49
  494. package/src/hooks/useAuthentication/useFetchGoogleProfile.ts +0 -68
  495. package/src/hooks/useAuthentication/useTokenClient.ts +0 -54
  496. package/src/hooks/useAuthenticationConfig.ts +0 -18
  497. package/src/providers/authentication.tsx +0 -181
  498. package/tests/authentication.test.ts +0 -142
  499. package/tests/useAuthenticationStatus.test.ts +0 -155
  500. /package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/{columnGrouping.styles.d.ts → components/MenuItems/menuItems.styles.d.ts} +0 -0
  501. /package/lib/components/Table/components/TableToolbar/components/ColumnGrouping/{columnGrouping.styles.js → components/MenuItems/menuItems.styles.js} +0 -0
  502. /package/lib/hooks/{useSessionTimeout.d.ts → authentication/session/useSessionTimeout.d.ts} +0 -0
  503. /package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.d.ts +0 -0
  504. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.d.ts +0 -0
  505. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.js +0 -0
  506. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.d.ts +0 -0
  507. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.d.ts +0 -0
  508. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.d.ts +0 -0
  509. /package/src/components/Table/components/TableToolbar/components/ColumnGrouping/{columnGrouping.styles.ts → components/MenuItems/menuItems.styles.ts} +0 -0
  510. /package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.ts +0 -0
@@ -1,8 +1,8 @@
1
1
  import React, { ReactNode } from "react";
2
- import { LoginStatus } from "../../../../../../../../../../hooks/useAuthentication/common/entities";
3
- import { useAuthentication } from "../../../../../../../../../../hooks/useAuthentication/useAuthentication";
4
- import { TerraResponse } from "../../../../../../../../../../hooks/useAuthentication/useFetchTerraProfile";
5
2
  import { useConfig } from "../../../../../../../../../../hooks/useConfig";
3
+ import { useTerraProfile } from "../../../../../../../../../../providers/authentication/terra/hook";
4
+ import { LoginStatus } from "../../../../../../../../../../providers/authentication/terra/hooks/common/entities";
5
+ import { TerraResponse } from "../../../../../../../../../../providers/authentication/terra/hooks/useFetchTerraProfile";
6
6
  import { ButtonPrimary } from "../../../../../../../../../common/Button/components/ButtonPrimary/buttonPrimary";
7
7
  import {
8
8
  ANCHOR_TARGET,
@@ -23,7 +23,7 @@ export const AcceptTerraTOS = ({
23
23
  }: AcceptTerraTOSProps): JSX.Element | null => {
24
24
  const { config } = useConfig();
25
25
  const { exportToTerraUrl } = config;
26
- const { terraProfileLoginStatus } = useAuthentication();
26
+ const { terraProfileLoginStatus } = useTerraProfile();
27
27
  const isTOSAccepted = isTermsOfServiceAccepted(terraProfileLoginStatus);
28
28
 
29
29
  const onOpenTerra = (): void => {
@@ -2,7 +2,7 @@ import React from "react";
2
2
  import {
3
3
  expireTimeInSeconds,
4
4
  useAuthenticationNIHExpiry,
5
- } from "../../../../../../../../hooks/useAuthentication/useAuthenticationNIHExpiry";
5
+ } from "../../../../../../../../hooks/authentication/terra/useAuthenticationNIHExpiry";
6
6
  import { Alert } from "../../../../../../../common/Alert/alert";
7
7
  import { ALERT_PROPS } from "../../../../../../../common/Alert/constants";
8
8
  import { FluidPaper } from "../../../../../../../common/Paper/paper.styles";
@@ -4,7 +4,9 @@ import {
4
4
  ONBOARDING_STEP,
5
5
  OnboardingStatus,
6
6
  useAuthenticationForm,
7
- } from "../../../../../../hooks/useAuthentication/useAuthenticationForm";
7
+ } from "../../../../../../hooks/authentication/terra/useAuthenticationForm";
8
+ import { useAuth } from "../../../../../../providers/authentication/auth/hook";
9
+ import { AUTH_STATUS } from "../../../../../../providers/authentication/auth/types";
8
10
  import { TEXT_BODY_400_2_LINES } from "../../../../../../theme/common/typography";
9
11
  import {
10
12
  FluidPaper,
@@ -17,11 +19,12 @@ import { CreateTerraAccount } from "./components/FormStep/components/CreateTerra
17
19
  import { Section, SectionContent } from "./terraSetUpForm.styles";
18
20
 
19
21
  export const TerraSetUpForm = (): JSX.Element | null => {
20
- const { isComplete, isReady, onboardingStatusByStep } =
21
- useAuthenticationForm();
22
-
23
- if (!isReady) return null;
24
-
22
+ const {
23
+ authState: { isAuthenticated, status },
24
+ } = useAuth();
25
+ const { isComplete, onboardingStatusByStep } = useAuthenticationForm();
26
+ if (!isAuthenticated) return null;
27
+ if (status === AUTH_STATUS.PENDING) return null;
25
28
  return isComplete ? null : (
26
29
  <FluidPaper>
27
30
  <GridPaper>
@@ -3,10 +3,13 @@ import {
3
3
  ButtonProps as MButtonProps,
4
4
  IconButton as MIconButton,
5
5
  IconButtonProps as MIconButtonProps,
6
+ Skeleton,
6
7
  } from "@mui/material";
7
- import { useRouter } from "next/router";
8
- import React, { ElementType, useCallback } from "react";
9
- import { useAuthentication } from "../../../../../../../../../../hooks/useAuthentication/useAuthentication";
8
+ import Router from "next/router";
9
+ import React, { ElementType } from "react";
10
+ import { useProfile } from "../../../../../../../../../../hooks/authentication/profile/useProfile";
11
+ import { ROUTE } from "../../../../../../../../../../routes/constants";
12
+ import { isNavigationLinkSelected } from "../../../Navigation/common/utils";
10
13
  import { AuthenticationMenu } from "./components/AuthenticationMenu/authenticationMenu";
11
14
  import { StyledButton } from "./components/Button/button.styles";
12
15
 
@@ -21,39 +24,38 @@ export const Authentication = ({
21
24
  Button,
22
25
  closeMenu,
23
26
  }: AuthenticationProps): JSX.Element | null => {
24
- const { isAuthenticated, requestAuthentication, userProfile } =
25
- useAuthentication();
26
- const router = useRouter();
27
- const onLogout = useCallback((): void => {
28
- location.href = router.basePath;
29
- }, [router]);
30
-
27
+ const { isLoading, profile } = useProfile();
31
28
  if (!authenticationEnabled) return null;
32
-
29
+ if (isLoading) return <Skeleton height={32} variant="circular" width={32} />;
30
+ if (profile) return <AuthenticationMenu profile={profile} />;
33
31
  return (
34
- <>
35
- {isAuthenticated && userProfile ? (
36
- <AuthenticationMenu onLogout={onLogout} userProfile={userProfile} />
37
- ) : (
38
- <Button
39
- onClick={(): void => {
40
- requestAuthentication();
41
- closeMenu();
42
- }}
43
- />
44
- )}
45
- </>
32
+ <Button
33
+ onClick={async (): Promise<void> => {
34
+ await Router.push(ROUTE.LOGIN);
35
+ closeMenu();
36
+ }}
37
+ />
46
38
  );
47
39
  };
48
40
 
49
41
  /**
50
42
  * Renders authentication button.
51
43
  * @param props - Button props.
44
+ * @param pathname - Pathname.
52
45
  * @returns button.
53
46
  */
54
- export function renderButton(props: MButtonProps): JSX.Element {
47
+ export function renderButton(
48
+ props: MButtonProps,
49
+ pathname: string
50
+ ): JSX.Element {
55
51
  return (
56
- <StyledButton startIcon={<LoginRoundedIcon />} variant="nav" {...props}>
52
+ <StyledButton
53
+ startIcon={<LoginRoundedIcon />}
54
+ variant={
55
+ isNavigationLinkSelected(pathname, [ROUTE.LOGIN]) ? "activeNav" : "nav"
56
+ }
57
+ {...props}
58
+ >
57
59
  Sign in
58
60
  </StyledButton>
59
61
  );
@@ -1,6 +1,6 @@
1
1
  import styled from "@emotion/styled";
2
2
  import {
3
- Avatar as MAvatar,
3
+ Avatar,
4
4
  IconButton as MIconButton,
5
5
  Menu as MMenu,
6
6
  MenuItem,
@@ -33,7 +33,7 @@ export const UserNames = styled(Typography)`
33
33
  max-width: 200px;
34
34
  `;
35
35
 
36
- export const Avatar = styled(MAvatar)`
36
+ export const StyledAvatar = styled(Avatar)`
37
37
  height: 32px;
38
38
  width: 32px;
39
39
  `;
@@ -1,69 +1,45 @@
1
1
  import { MenuItem } from "@mui/material";
2
- import React, { MouseEvent, useState } from "react";
3
- import { UserProfile } from "../../../../../../../../../../../../hooks/useAuthentication/useFetchGoogleProfile";
2
+ import React, { Fragment } from "react";
3
+ import { useAuth } from "../../../../../../../../../../../../providers/authentication/auth/hook";
4
+ import { UserProfile } from "../../../../../../../../../../../../providers/authentication/authentication/types";
5
+ import { useMenu } from "../../../../../../../../../../../common/Menu/hooks/useMenu";
4
6
  import {
5
- Avatar,
6
7
  AuthenticationMenu as Menu,
8
+ StyledAvatar,
7
9
  UserIcon,
8
10
  UserNames,
9
11
  UserSummary,
10
12
  } from "./authenticationMenu.styles";
13
+ import { MENU_PROPS } from "./constants";
11
14
 
12
15
  export interface AuthenticationMenuProps {
13
- onLogout: () => void;
14
- userProfile: UserProfile;
16
+ profile: UserProfile;
15
17
  }
16
18
 
17
19
  export const AuthenticationMenu = ({
18
- onLogout,
19
- userProfile,
20
+ profile,
20
21
  }: AuthenticationMenuProps): JSX.Element => {
21
- const [anchorEl, setAnchorEl] = useState<null | HTMLButtonElement>(null);
22
- const open = Boolean(anchorEl);
23
-
24
- const onOpenMenu = (event: MouseEvent<HTMLButtonElement>): void => {
25
- setAnchorEl(event.currentTarget);
26
- };
27
-
28
- const onCloseMenu = (): void => {
29
- setAnchorEl(null);
30
- };
31
-
22
+ const { service: { requestLogout } = {} } = useAuth();
23
+ const { anchorEl, onClose, onOpen, open } = useMenu<HTMLElement>();
32
24
  return (
33
- <>
34
- <UserIcon onClick={onOpenMenu}>
35
- <Avatar
36
- alt={`${userProfile.given_name} ${userProfile.family_name}`}
37
- src={userProfile.picture}
38
- />
25
+ <Fragment>
26
+ <UserIcon onClick={onOpen}>
27
+ <StyledAvatar alt={profile.name} src={profile.image} />
39
28
  </UserIcon>
40
- <Menu
41
- anchorEl={anchorEl}
42
- anchorOrigin={{ horizontal: "right", vertical: "bottom" }}
43
- autoFocus={false}
44
- onClose={onCloseMenu}
45
- open={open}
46
- slotProps={{ paper: { variant: "menu" } }}
47
- transformOrigin={{
48
- horizontal: "right",
49
- vertical: "top",
50
- }}
51
- >
29
+ <Menu {...MENU_PROPS} anchorEl={anchorEl} onClose={onClose} open={open}>
52
30
  <UserSummary>
53
31
  You are signed in as:
54
- <UserNames noWrap>
55
- {userProfile.given_name} {userProfile.family_name}
56
- </UserNames>
32
+ <UserNames noWrap>{profile.name}</UserNames>
57
33
  </UserSummary>
58
34
  <MenuItem
59
35
  onClick={(): void => {
60
- onCloseMenu();
61
- onLogout();
36
+ requestLogout?.();
37
+ onClose();
62
38
  }}
63
39
  >
64
40
  Logout
65
41
  </MenuItem>
66
42
  </Menu>
67
- </>
43
+ </Fragment>
68
44
  );
69
45
  };
@@ -0,0 +1,19 @@
1
+ import { MenuProps } from "@mui/material";
2
+ import { VARIANT } from "../../../../../../../../../../../../styles/common/mui/paper";
3
+ import {
4
+ POPOVER_ORIGIN_HORIZONTAL,
5
+ POPOVER_ORIGIN_VERTICAL,
6
+ } from "../../../../../../../../../../../../styles/common/mui/popover";
7
+
8
+ export const MENU_PROPS: Partial<MenuProps> = {
9
+ anchorOrigin: {
10
+ horizontal: POPOVER_ORIGIN_HORIZONTAL.RIGHT,
11
+ vertical: POPOVER_ORIGIN_VERTICAL.BOTTOM,
12
+ },
13
+ autoFocus: false,
14
+ slotProps: { paper: { variant: VARIANT.MENU } },
15
+ transformOrigin: {
16
+ horizontal: POPOVER_ORIGIN_HORIZONTAL.RIGHT,
17
+ vertical: POPOVER_ORIGIN_VERTICAL.TOP,
18
+ },
19
+ };
@@ -1,7 +1,8 @@
1
1
  import styled from "@emotion/styled";
2
- import { Button as MButton } from "@mui/material";
2
+ import { Button } from "@mui/material";
3
3
 
4
- export const StyledButton = styled(MButton)`
4
+ export const StyledButton = styled(Button)`
5
+ &.MuiButton-activeNav,
5
6
  &.MuiButton-nav {
6
7
  padding: 6px 12px;
7
8
  }
@@ -129,7 +129,7 @@ export const Header = ({ ...headerProps }: HeaderProps): JSX.Element => {
129
129
  Button={({ ...props }): JSX.Element =>
130
130
  isIn.isMenuIn
131
131
  ? renderAuthenticationIconButton(props)
132
- : renderAuthenticationButton(props)
132
+ : renderAuthenticationButton(props, pathname)
133
133
  }
134
134
  authenticationEnabled={authenticationEnabled}
135
135
  closeMenu={onClose}
@@ -0,0 +1,12 @@
1
+ import styled from "@emotion/styled";
2
+ import { Button } from "@mui/material";
3
+
4
+ export const StyledButton = styled(Button)`
5
+ &.MuiButton-root {
6
+ justify-content: space-between;
7
+
8
+ .MuiButton-endIcon {
9
+ margin: -6px;
10
+ }
11
+ }
12
+ `;
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import { StyledButton } from "./button.styles";
3
+ import { BUTTON_PROPS } from "./constants";
4
+ import { Props } from "./types";
5
+
6
+ export const Button = ({ className, ...props }: Props): JSX.Element => {
7
+ return <StyledButton className={className} {...BUTTON_PROPS} {...props} />;
8
+ };
@@ -0,0 +1,8 @@
1
+ import { ButtonProps } from "@mui/material";
2
+ import { COLOR, VARIANT } from "../../../../styles/common/mui/button";
3
+
4
+ export const BUTTON_PROPS: Partial<ButtonProps> = {
5
+ color: COLOR.SECONDARY,
6
+ fullWidth: true,
7
+ variant: VARIANT.CONTAINED,
8
+ };
@@ -0,0 +1,4 @@
1
+ import { ButtonProps } from "@mui/material/Button/Button";
2
+ import { BaseComponentProps } from "../../../../theme/common/entities";
3
+
4
+ export type Props = BaseComponentProps & ButtonProps;
@@ -1,13 +1,13 @@
1
1
  import { Checkbox, Typography } from "@mui/material";
2
- import React, { ChangeEvent, ReactNode, useState } from "react";
3
- import { useAuthentication } from "../../hooks/useAuthentication/useAuthentication";
4
- import { LoginButton } from "../common/Button/components/LoginButton/loginButton";
2
+ import React, { ChangeEvent, useCallback, useState } from "react";
3
+ import { useAuth } from "../../providers/authentication/auth/hook";
4
+ import { ProviderId } from "../../providers/authentication/common/types";
5
5
  import { CheckedIcon } from "../common/CustomIcon/components/CheckedIcon/checkedIcon";
6
- import { GoogleIcon } from "../common/CustomIcon/components/GoogleIcon/googleIcon";
7
6
  import { UncheckedErrorIcon } from "../common/CustomIcon/components/UncheckedErrorIcon/uncheckedErrorIcon";
8
7
  import { UncheckedIcon } from "../common/CustomIcon/components/UncheckedIcon/uncheckedIcon";
9
8
  import { RoundedPaper } from "../common/Paper/paper.styles";
10
9
  import { SectionContent } from "../common/Section/section.styles";
10
+ import { Button } from "./components/Button/button";
11
11
  import {
12
12
  LoginAgreement,
13
13
  LoginSection,
@@ -17,35 +17,31 @@ import {
17
17
  LoginWrapper,
18
18
  TermsOfService,
19
19
  } from "./login.styles";
20
+ import { Props } from "./types";
20
21
 
21
- export interface LoginProps {
22
- isGoogle?: boolean;
23
- termsOfService?: ReactNode;
24
- text?: ReactNode;
25
- title: string;
26
- warning?: ReactNode;
27
- }
28
-
29
- export const Login = ({
30
- isGoogle = false,
22
+ export const Login = <P,>({
23
+ providers = [],
31
24
  termsOfService,
32
25
  text,
33
26
  title,
34
27
  warning,
35
- }: LoginProps): JSX.Element => {
36
- const { authenticateUser } = useAuthentication();
28
+ }: Props<P>): JSX.Element => {
29
+ const { service: { requestLogin } = {} } = useAuth();
37
30
  const [isError, setIsError] = useState<boolean>(false);
38
31
  const [isInAgreement, setIsInAgreement] = useState<boolean>(!termsOfService);
39
32
 
40
33
  // Authenticates the user, if the user has agreed to the terms of service.
41
34
  // If the terms of service are not accepted, set the terms of service error state to true.
42
- const onAuthenticateUser = (): void => {
43
- if (!isInAgreement) {
44
- setIsError(true);
45
- return;
46
- }
47
- authenticateUser();
48
- };
35
+ const onLogin = useCallback(
36
+ (providerId: ProviderId): void => {
37
+ if (!isInAgreement) {
38
+ setIsError(true);
39
+ return;
40
+ }
41
+ requestLogin?.(providerId);
42
+ },
43
+ [isInAgreement, requestLogin]
44
+ );
49
45
 
50
46
  // Callback fired when the checkbox value is changed.
51
47
  // Clears the terms of service error state and sets state isInAgreement with checkbox selected value.
@@ -75,11 +71,15 @@ export const Login = ({
75
71
  <TermsOfService>{termsOfService}</TermsOfService>
76
72
  </LoginAgreement>
77
73
  )}
78
- {isGoogle && (
79
- <LoginButton EndIcon={GoogleIcon} onClick={onAuthenticateUser}>
80
- Google
81
- </LoginButton>
82
- )}
74
+ {providers?.map((provider) => (
75
+ <Button
76
+ key={provider.id}
77
+ endIcon={"icon" in provider && provider.icon}
78
+ onClick={() => onLogin(provider.id)}
79
+ >
80
+ {provider.name}
81
+ </Button>
82
+ ))}
83
83
  </LoginSectionActions>
84
84
  </LoginSection>
85
85
  </RoundedPaper>
@@ -0,0 +1,11 @@
1
+ import { ClientSafeProvider } from "next-auth/react";
2
+ import { ReactNode } from "react";
3
+ import { OAuthProvider } from "../../config/entities";
4
+
5
+ export interface Props<P> {
6
+ providers?: ClientSafeProvider[] | OAuthProvider<P>[];
7
+ termsOfService?: ReactNode;
8
+ text?: ReactNode;
9
+ title: string;
10
+ warning?: ReactNode;
11
+ }
@@ -1,7 +1,9 @@
1
1
  import { ColumnDef, RowData } from "@tanstack/react-table";
2
2
  import { TABLE_CELL_PROPS } from "../../../styles/common/mui/tableCell";
3
- import { ACCESSOR_KEYS } from "../../TableCreator/common/constants";
4
3
  import { RowPositionCell } from "../components/TableCell/components/RowPositionCell/rowPositionCell";
4
+ import { RowSelectionCell } from "../components/TableCell/components/RowSelectionCell/rowSelectionCell";
5
+ import { HeadSelectionCell } from "../components/TableHead/components/HeadSelectionCell/headSelectionCell";
6
+ import { COLUMN_IDENTIFIER } from "./columnIdentifier";
5
7
 
6
8
  export const COLUMN_DEF: Record<string, ColumnDef<RowData>> = {
7
9
  ROW_POSITION: {
@@ -10,9 +12,23 @@ export const COLUMN_DEF: Record<string, ColumnDef<RowData>> = {
10
12
  enableHiding: false,
11
13
  enableSorting: false,
12
14
  header: "",
13
- id: ACCESSOR_KEYS.ROW_POSITION,
15
+ id: COLUMN_IDENTIFIER.ROW_POSITION,
14
16
  meta: {
15
17
  align: TABLE_CELL_PROPS.ALIGN.RIGHT,
18
+ columnPinned: false,
19
+ header: "",
20
+ width: "max-content",
21
+ },
22
+ },
23
+ ROW_SELECTION: {
24
+ cell: RowSelectionCell,
25
+ enableGrouping: false,
26
+ enableHiding: false,
27
+ enableSorting: false,
28
+ header: HeadSelectionCell,
29
+ id: COLUMN_IDENTIFIER.ROW_SELECTION,
30
+ meta: {
31
+ columnPinned: false,
16
32
  header: "",
17
33
  width: "max-content",
18
34
  },
@@ -0,0 +1,4 @@
1
+ export const COLUMN_IDENTIFIER = {
2
+ ROW_POSITION: "rowPosition",
3
+ ROW_SELECTION: "rowSelection",
4
+ };
@@ -0,0 +1,12 @@
1
+ import { Column, RowData } from "@tanstack/react-table";
2
+
3
+ /**
4
+ * Type guard to check if a column's header is a string.
5
+ * @param column - Column.
6
+ * @returns true if the column has a string header.
7
+ */
8
+ export function isStringHeaderColumn<T extends RowData>(
9
+ column: Column<T>
10
+ ): column is Column<T> & { columnDef: { header: string } } {
11
+ return typeof column.columnDef.header === "string";
12
+ }