@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,3 +1,3 @@
1
1
  {
2
- ".": "19.0.0"
2
+ ".": "21.0.0"
3
3
  }
package/CHANGELOG.md CHANGED
@@ -1,5 +1,27 @@
1
1
  # Changelog
2
2
 
3
+ ## [21.0.0](https://github.com/DataBiosphere/findable-ui/compare/v20.0.0...v21.0.0) (2025-01-06)
4
+
5
+
6
+ ### ⚠ BREAKING CHANGES
7
+
8
+ * update column visibility to use only tanstack api ([#307](https://github.com/DataBiosphere/findable-ui/issues/307)) (#308)
9
+
10
+ ### Features
11
+
12
+ * update column visibility to use only tanstack api ([#307](https://github.com/DataBiosphere/findable-ui/issues/307)) ([#308](https://github.com/DataBiosphere/findable-ui/issues/308)) ([4baf212](https://github.com/DataBiosphere/findable-ui/commit/4baf212bf564d539b757dd82144511fc97ca7717))
13
+
14
+ ## [20.0.0](https://github.com/DataBiosphere/findable-ui/compare/v19.0.0...v20.0.0) (2025-01-06)
15
+
16
+
17
+ ### ⚠ BREAKING CHANGES
18
+
19
+ * remove terra functionality from authprovider into its own provider ([#178](https://github.com/DataBiosphere/findable-ui/issues/178)) (#240)
20
+
21
+ ### Features
22
+
23
+ * remove terra functionality from authprovider into its own provider ([#178](https://github.com/DataBiosphere/findable-ui/issues/178)) ([#240](https://github.com/DataBiosphere/findable-ui/issues/240)) ([18b0ea8](https://github.com/DataBiosphere/findable-ui/commit/18b0ea875b0096a76e968f8578769f62fbab8804))
24
+
3
25
  ## [19.0.0](https://github.com/DataBiosphere/findable-ui/compare/v18.0.0...v19.0.0) (2025-01-03)
4
26
 
5
27
 
@@ -0,0 +1,2 @@
1
+ import { SessionControllerProps } from "./types";
2
+ export declare function SessionController({ children, token, }: SessionControllerProps): JSX.Element;
@@ -0,0 +1,29 @@
1
+ import React, { Fragment, useEffect } from "react";
2
+ import { authComplete } from "../../../../../../providers/authentication/auth/dispatch";
3
+ import { useAuth } from "../../../../../../providers/authentication/auth/hook";
4
+ import { authenticationComplete } from "../../../../../../providers/authentication/authentication/dispatch";
5
+ import { useAuthentication } from "../../../../../../providers/authentication/authentication/hook";
6
+ import { updateCredentials } from "../../../../../../providers/authentication/credentials/dispatch";
7
+ import { useCredentials } from "../../../../../../providers/authentication/credentials/hook";
8
+ export function SessionController({ children, token, }) {
9
+ const { authDispatch } = useAuth();
10
+ const { authenticationDispatch, authenticationState: { profile }, } = useAuthentication();
11
+ const { credentialsDispatch } = useCredentials();
12
+ useEffect(() => {
13
+ // Dispatch only when profile is available:
14
+ // - Login errors are managed by the login service.
15
+ // - Logout operations handle resetting credentials, authentication and auth state.
16
+ if (!profile)
17
+ return;
18
+ credentialsDispatch?.(updateCredentials(token)); // Release credentials.
19
+ authenticationDispatch?.(authenticationComplete()); // Authentication `status` is "SETTLED".
20
+ authDispatch?.(authComplete({ isAuthenticated: true })); // Auth `status` is "SETTLED", and `isAuthenticated` is "true".
21
+ }, [
22
+ authDispatch,
23
+ authenticationDispatch,
24
+ credentialsDispatch,
25
+ profile,
26
+ token,
27
+ ]);
28
+ return React.createElement(Fragment, null, children);
29
+ }
@@ -0,0 +1,6 @@
1
+ import { ReactNode } from "react";
2
+ import { TokenState } from "../../../../../../providers/authentication/token/types";
3
+ export interface SessionControllerProps {
4
+ children: ReactNode | ReactNode[];
5
+ token: TokenState["token"];
6
+ }
@@ -0,0 +1,2 @@
1
+ import { SessionControllerProps } from "./types";
2
+ export declare function SessionController({ children, }: SessionControllerProps): JSX.Element;
@@ -0,0 +1,17 @@
1
+ import { useSession } from "next-auth/react";
2
+ import React, { Fragment, useEffect } from "react";
3
+ import { updateAuthState } from "../../../../../../providers/authentication/auth/dispatch";
4
+ import { useAuth } from "../../../../../../providers/authentication/auth/hook";
5
+ import { updateAuthentication } from "../../../../../../providers/authentication/authentication/dispatch";
6
+ import { useAuthentication } from "../../../../../../providers/authentication/authentication/hook";
7
+ import { mapAuth, mapAuthentication } from "./utils";
8
+ export function SessionController({ children, }) {
9
+ const { authDispatch } = useAuth();
10
+ const { authenticationDispatch } = useAuthentication();
11
+ const session = useSession();
12
+ useEffect(() => {
13
+ authDispatch?.(updateAuthState(mapAuth(session)));
14
+ authenticationDispatch?.(updateAuthentication(mapAuthentication(session)));
15
+ }, [authDispatch, authenticationDispatch, session]);
16
+ return React.createElement(Fragment, null, children);
17
+ }
@@ -0,0 +1,5 @@
1
+ import { SessionContextValue } from "next-auth/react";
2
+ import { AUTH_STATUS } from "../../../../../../providers/authentication/auth/types";
3
+ import { AUTHENTICATION_STATUS } from "../../../../../../providers/authentication/authentication/types";
4
+ export declare const AUTH_STATUS_MAP: Record<SessionContextValue["status"], AUTH_STATUS>;
5
+ export declare const AUTHENTICATION_STATUS_MAP: Record<SessionContextValue["status"], AUTHENTICATION_STATUS>;
@@ -0,0 +1,12 @@
1
+ import { AUTH_STATUS } from "../../../../../../providers/authentication/auth/types";
2
+ import { AUTHENTICATION_STATUS } from "../../../../../../providers/authentication/authentication/types";
3
+ export const AUTH_STATUS_MAP = {
4
+ authenticated: AUTH_STATUS.SETTLED,
5
+ loading: AUTH_STATUS.PENDING,
6
+ unauthenticated: AUTH_STATUS.SETTLED,
7
+ };
8
+ export const AUTHENTICATION_STATUS_MAP = {
9
+ authenticated: AUTHENTICATION_STATUS.SETTLED,
10
+ loading: AUTHENTICATION_STATUS.PENDING,
11
+ unauthenticated: AUTHENTICATION_STATUS.SETTLED,
12
+ };
@@ -0,0 +1,4 @@
1
+ import { ReactNode } from "react";
2
+ export interface SessionControllerProps {
3
+ children: ReactNode | ReactNode[];
4
+ }
@@ -0,0 +1,15 @@
1
+ import { SessionContextValue } from "next-auth/react";
2
+ import { UpdateAuthStatePayload } from "../../../../../../providers/authentication/auth/types";
3
+ import { UpdateAuthenticationPayload } from "../../../../../../providers/authentication/authentication/types";
4
+ /**
5
+ * Returns the auth state from the session context.
6
+ * @param session - Session context value.
7
+ * @returns auth state.
8
+ */
9
+ export declare function mapAuth(session: SessionContextValue): UpdateAuthStatePayload;
10
+ /**
11
+ * Returns the authentication profile and status from the session context.
12
+ * @param session - Session context value.
13
+ * @returns authentication profile and status.
14
+ */
15
+ export declare function mapAuthentication(session: SessionContextValue): UpdateAuthenticationPayload;
@@ -0,0 +1,53 @@
1
+ import { AUTH_STATUS, } from "../../../../../../providers/authentication/auth/types";
2
+ import { AUTHENTICATION_STATUS, } from "../../../../../../providers/authentication/authentication/types";
3
+ import { AUTH_STATUS_MAP, AUTHENTICATION_STATUS_MAP } from "./constants";
4
+ /**
5
+ * Returns the auth state from the session context.
6
+ * @param session - Session context value.
7
+ * @returns auth state.
8
+ */
9
+ export function mapAuth(session) {
10
+ return {
11
+ isAuthenticated: session.status === "authenticated",
12
+ status: mapStatus(session.status, AUTH_STATUS_MAP, AUTH_STATUS.SETTLED),
13
+ };
14
+ }
15
+ /**
16
+ * Returns the authentication profile and status from the session context.
17
+ * @param session - Session context value.
18
+ * @returns authentication profile and status.
19
+ */
20
+ export function mapAuthentication(session) {
21
+ return {
22
+ profile: mapProfile(session.data),
23
+ status: mapStatus(session.status, AUTHENTICATION_STATUS_MAP, AUTHENTICATION_STATUS.SETTLED),
24
+ };
25
+ }
26
+ /**
27
+ * Maps the session data to a user profile.
28
+ * @param sessionData - Session data.
29
+ * @returns user profile.
30
+ */
31
+ function mapProfile(sessionData) {
32
+ if (!sessionData)
33
+ return;
34
+ const { user } = sessionData;
35
+ if (!user)
36
+ return;
37
+ const { email, image, name } = user;
38
+ return {
39
+ email: email || "",
40
+ image: image || "",
41
+ name: name || "",
42
+ };
43
+ }
44
+ /**
45
+ * Returns the auth or authentication status <S> based on the session status.
46
+ * @param status - Session status.
47
+ * @param statusBySessionStatus - Map of session status to auth or authentication status.
48
+ * @param defaultStatus - Default auth or authentication status.
49
+ * @returns auth or authentication status.
50
+ */
51
+ function mapStatus(status, statusBySessionStatus, defaultStatus) {
52
+ return statusBySessionStatus[status] || defaultStatus;
53
+ }
@@ -1,9 +1,9 @@
1
1
  import React from "react";
2
- import { useAuthentication } from "../../hooks/useAuthentication/useAuthentication";
3
2
  import { useConfig } from "../../hooks/useConfig";
4
3
  import { useExploreState } from "../../hooks/useExploreState";
5
4
  import { useFileManifestState } from "../../hooks/useFileManifestState";
6
5
  import { useSystemStatus } from "../../hooks/useSystemStatus";
6
+ import { useAuth } from "../../providers/authentication/auth/hook";
7
7
  /**
8
8
  * ComponentCreator uses React API to create components based on the component configs, instead of using JSX.
9
9
  * That way we can continue to create UI components without having to worry about if they should be able to transform model data into props.
@@ -15,7 +15,7 @@ import { useSystemStatus } from "../../hooks/useSystemStatus";
15
15
  * @returns A set of React components.
16
16
  */
17
17
  export const ComponentCreator = ({ components, response, viewContext, }) => {
18
- const { authenticationStatus, isAuthenticated } = useAuthentication();
18
+ const { authState: { isAuthenticated }, } = useAuth();
19
19
  const { config, entityConfig } = useConfig();
20
20
  const { exploreState } = useExploreState();
21
21
  const { fileManifestState } = useFileManifestState();
@@ -30,7 +30,6 @@ export const ComponentCreator = ({ components, response, viewContext, }) => {
30
30
  ? c.viewBuilder(response, {
31
31
  ...viewContext,
32
32
  authState: {
33
- authenticationStatus,
34
33
  isAuthenticated,
35
34
  },
36
35
  entityConfig,
@@ -1,13 +1,13 @@
1
1
  import React from "react";
2
- import { useAuthentication } from "../../../../../../../../../../hooks/useAuthentication/useAuthentication";
3
2
  import { useConfig } from "../../../../../../../../../../hooks/useConfig";
3
+ import { useTerraProfile } from "../../../../../../../../../../providers/authentication/terra/hook";
4
4
  import { ButtonPrimary } from "../../../../../../../../../common/Button/components/ButtonPrimary/buttonPrimary";
5
5
  import { ANCHOR_TARGET, REL_ATTRIBUTE, } from "../../../../../../../../../Links/common/entities";
6
6
  import { FormStep } from "../../formStep";
7
7
  export const AcceptTerraTOS = ({ active, completed, step, }) => {
8
8
  const { config } = useConfig();
9
9
  const { exportToTerraUrl } = config;
10
- const { terraProfileLoginStatus } = useAuthentication();
10
+ const { terraProfileLoginStatus } = useTerraProfile();
11
11
  const isTOSAccepted = isTermsOfServiceAccepted(terraProfileLoginStatus);
12
12
  const onOpenTerra = () => {
13
13
  if (exportToTerraUrl) {
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- import { expireTimeInSeconds, useAuthenticationNIHExpiry, } from "../../../../../../../../hooks/useAuthentication/useAuthenticationNIHExpiry";
2
+ import { expireTimeInSeconds, useAuthenticationNIHExpiry, } from "../../../../../../../../hooks/authentication/terra/useAuthenticationNIHExpiry";
3
3
  import { Alert } from "../../../../../../../common/Alert/alert";
4
4
  import { ALERT_PROPS } from "../../../../../../../common/Alert/constants";
5
5
  import { FluidPaper } from "../../../../../../../common/Paper/paper.styles";
@@ -1,6 +1,8 @@
1
1
  import { Typography } from "@mui/material";
2
2
  import React from "react";
3
- import { ONBOARDING_STEP, useAuthenticationForm, } from "../../../../../../hooks/useAuthentication/useAuthenticationForm";
3
+ import { ONBOARDING_STEP, useAuthenticationForm, } from "../../../../../../hooks/authentication/terra/useAuthenticationForm";
4
+ import { useAuth } from "../../../../../../providers/authentication/auth/hook";
5
+ import { AUTH_STATUS } from "../../../../../../providers/authentication/auth/types";
4
6
  import { TEXT_BODY_400_2_LINES } from "../../../../../../theme/common/typography";
5
7
  import { FluidPaper, GridPaper, } from "../../../../../common/Paper/paper.styles";
6
8
  import { SectionTitle } from "../../../../../common/Section/components/SectionTitle/sectionTitle";
@@ -9,8 +11,11 @@ import { ConnectTerraToNIHAccount } from "./components/FormStep/components/Conne
9
11
  import { CreateTerraAccount } from "./components/FormStep/components/CreateTerraAccount/createTerraAccount";
10
12
  import { Section, SectionContent } from "./terraSetUpForm.styles";
11
13
  export const TerraSetUpForm = () => {
12
- const { isComplete, isReady, onboardingStatusByStep } = useAuthenticationForm();
13
- if (!isReady)
14
+ const { authState: { isAuthenticated, status }, } = useAuth();
15
+ const { isComplete, onboardingStatusByStep } = useAuthenticationForm();
16
+ if (!isAuthenticated)
17
+ return null;
18
+ if (status === AUTH_STATUS.PENDING)
14
19
  return null;
15
20
  return isComplete ? null : (React.createElement(FluidPaper, null,
16
21
  React.createElement(GridPaper, null,
@@ -9,9 +9,10 @@ export declare const Authentication: ({ authenticationEnabled, Button, closeMenu
9
9
  /**
10
10
  * Renders authentication button.
11
11
  * @param props - Button props.
12
+ * @param pathname - Pathname.
12
13
  * @returns button.
13
14
  */
14
- export declare function renderButton(props: MButtonProps): JSX.Element;
15
+ export declare function renderButton(props: MButtonProps, pathname: string): JSX.Element;
15
16
  /**
16
17
  * Renders authentication icon button.
17
18
  * @param props - Button props.
@@ -1,30 +1,33 @@
1
1
  import LoginRoundedIcon from "@mui/icons-material/LoginRounded";
2
- import { IconButton as MIconButton, } from "@mui/material";
3
- import { useRouter } from "next/router";
4
- import React, { useCallback } from "react";
5
- import { useAuthentication } from "../../../../../../../../../../hooks/useAuthentication/useAuthentication";
2
+ import { IconButton as MIconButton, Skeleton, } from "@mui/material";
3
+ import Router from "next/router";
4
+ import React from "react";
5
+ import { useProfile } from "../../../../../../../../../../hooks/authentication/profile/useProfile";
6
+ import { ROUTE } from "../../../../../../../../../../routes/constants";
7
+ import { isNavigationLinkSelected } from "../../../Navigation/common/utils";
6
8
  import { AuthenticationMenu } from "./components/AuthenticationMenu/authenticationMenu";
7
9
  import { StyledButton } from "./components/Button/button.styles";
8
10
  export const Authentication = ({ authenticationEnabled, Button, closeMenu, }) => {
9
- const { isAuthenticated, requestAuthentication, userProfile } = useAuthentication();
10
- const router = useRouter();
11
- const onLogout = useCallback(() => {
12
- location.href = router.basePath;
13
- }, [router]);
11
+ const { isLoading, profile } = useProfile();
14
12
  if (!authenticationEnabled)
15
13
  return null;
16
- return (React.createElement(React.Fragment, null, isAuthenticated && userProfile ? (React.createElement(AuthenticationMenu, { onLogout: onLogout, userProfile: userProfile })) : (React.createElement(Button, { onClick: () => {
17
- requestAuthentication();
14
+ if (isLoading)
15
+ return React.createElement(Skeleton, { height: 32, variant: "circular", width: 32 });
16
+ if (profile)
17
+ return React.createElement(AuthenticationMenu, { profile: profile });
18
+ return (React.createElement(Button, { onClick: async () => {
19
+ await Router.push(ROUTE.LOGIN);
18
20
  closeMenu();
19
- } }))));
21
+ } }));
20
22
  };
21
23
  /**
22
24
  * Renders authentication button.
23
25
  * @param props - Button props.
26
+ * @param pathname - Pathname.
24
27
  * @returns button.
25
28
  */
26
- export function renderButton(props) {
27
- return (React.createElement(StyledButton, { startIcon: React.createElement(LoginRoundedIcon, null), variant: "nav", ...props }, "Sign in"));
29
+ export function renderButton(props, pathname) {
30
+ return (React.createElement(StyledButton, { startIcon: React.createElement(LoginRoundedIcon, null), variant: isNavigationLinkSelected(pathname, [ROUTE.LOGIN]) ? "activeNav" : "nav", ...props }, "Sign in"));
28
31
  }
29
32
  /**
30
33
  * Renders authentication icon button.
@@ -1,6 +1,5 @@
1
- import { UserProfile } from "../../../../../../../../../../../../hooks/useAuthentication/useFetchGoogleProfile";
1
+ import { UserProfile } from "../../../../../../../../../../../../providers/authentication/authentication/types";
2
2
  export interface AuthenticationMenuProps {
3
- onLogout: () => void;
4
- userProfile: UserProfile;
3
+ profile: UserProfile;
5
4
  }
6
- export declare const AuthenticationMenu: ({ onLogout, userProfile, }: AuthenticationMenuProps) => JSX.Element;
5
+ export declare const AuthenticationMenu: ({ profile, }: AuthenticationMenuProps) => JSX.Element;
@@ -1,30 +1,21 @@
1
1
  import { MenuItem } from "@mui/material";
2
- import React, { useState } from "react";
3
- import { Avatar, AuthenticationMenu as Menu, UserIcon, UserNames, UserSummary, } from "./authenticationMenu.styles";
4
- export const AuthenticationMenu = ({ onLogout, userProfile, }) => {
5
- const [anchorEl, setAnchorEl] = useState(null);
6
- const open = Boolean(anchorEl);
7
- const onOpenMenu = (event) => {
8
- setAnchorEl(event.currentTarget);
9
- };
10
- const onCloseMenu = () => {
11
- setAnchorEl(null);
12
- };
13
- return (React.createElement(React.Fragment, null,
14
- React.createElement(UserIcon, { onClick: onOpenMenu },
15
- React.createElement(Avatar, { alt: `${userProfile.given_name} ${userProfile.family_name}`, src: userProfile.picture })),
16
- React.createElement(Menu, { anchorEl: anchorEl, anchorOrigin: { horizontal: "right", vertical: "bottom" }, autoFocus: false, onClose: onCloseMenu, open: open, slotProps: { paper: { variant: "menu" } }, transformOrigin: {
17
- horizontal: "right",
18
- vertical: "top",
19
- } },
2
+ import React, { Fragment } from "react";
3
+ import { useAuth } from "../../../../../../../../../../../../providers/authentication/auth/hook";
4
+ import { useMenu } from "../../../../../../../../../../../common/Menu/hooks/useMenu";
5
+ import { AuthenticationMenu as Menu, StyledAvatar, UserIcon, UserNames, UserSummary, } from "./authenticationMenu.styles";
6
+ import { MENU_PROPS } from "./constants";
7
+ export const AuthenticationMenu = ({ profile, }) => {
8
+ const { service: { requestLogout } = {} } = useAuth();
9
+ const { anchorEl, onClose, onOpen, open } = useMenu();
10
+ return (React.createElement(Fragment, null,
11
+ React.createElement(UserIcon, { onClick: onOpen },
12
+ React.createElement(StyledAvatar, { alt: profile.name, src: profile.image })),
13
+ React.createElement(Menu, { ...MENU_PROPS, anchorEl: anchorEl, onClose: onClose, open: open },
20
14
  React.createElement(UserSummary, null,
21
15
  "You are signed in as:",
22
- React.createElement(UserNames, { noWrap: true },
23
- userProfile.given_name,
24
- " ",
25
- userProfile.family_name)),
16
+ React.createElement(UserNames, { noWrap: true }, profile.name)),
26
17
  React.createElement(MenuItem, { onClick: () => {
27
- onCloseMenu();
28
- onLogout();
18
+ requestLogout?.();
19
+ onClose();
29
20
  } }, "Logout"))));
30
21
  };
@@ -16,7 +16,7 @@ export declare const UserNames: import("@emotion/styled").StyledComponent<import
16
16
  }, "fontSize" | "fontWeight" | "lineHeight" | "letterSpacing" | "textTransform" | "p" | "style" | "className" | "classes" | "color" | "children" | "border" | "borderTop" | "borderRight" | "borderBottom" | "borderLeft" | "borderColor" | "borderRadius" | "display" | "displayPrint" | "overflow" | "textOverflow" | "visibility" | "whiteSpace" | "flexBasis" | "flexDirection" | "flexWrap" | "justifyContent" | "alignItems" | "alignContent" | "order" | "flex" | "flexGrow" | "flexShrink" | "alignSelf" | "justifyItems" | "justifySelf" | "gap" | "columnGap" | "rowGap" | "gridColumn" | "gridRow" | "gridAutoFlow" | "gridAutoColumns" | "gridAutoRows" | "gridTemplateColumns" | "gridTemplateRows" | "gridTemplateAreas" | "gridArea" | "bgcolor" | "zIndex" | "position" | "top" | "right" | "bottom" | "left" | "boxShadow" | "width" | "maxWidth" | "minWidth" | "height" | "maxHeight" | "minHeight" | "boxSizing" | "m" | "mt" | "mr" | "mb" | "ml" | "mx" | "my" | "pt" | "pr" | "pb" | "pl" | "px" | "py" | "margin" | "marginTop" | "marginRight" | "marginBottom" | "marginLeft" | "marginX" | "marginY" | "marginInline" | "marginInlineStart" | "marginInlineEnd" | "marginBlock" | "marginBlockStart" | "marginBlockEnd" | "padding" | "paddingTop" | "paddingRight" | "paddingBottom" | "paddingLeft" | "paddingX" | "paddingY" | "paddingInline" | "paddingInlineStart" | "paddingInlineEnd" | "paddingBlock" | "paddingBlockStart" | "paddingBlockEnd" | "typography" | "fontFamily" | "fontStyle" | "textAlign" | "align" | "gutterBottom" | "noWrap" | "paragraph" | "sx" | "variant" | "variantMapping"> & {
17
17
  theme?: import("@emotion/react").Theme;
18
18
  }, {}, {}>;
19
- export declare const Avatar: import("@emotion/styled").StyledComponent<import("@mui/material").AvatarOwnProps & import("@mui/material").AvatarSlotsAndSlotProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
19
+ export declare const StyledAvatar: import("@emotion/styled").StyledComponent<import("@mui/material").AvatarOwnProps & import("@mui/material").AvatarSlotsAndSlotProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
20
20
  ref?: ((instance: HTMLDivElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLDivElement> | null | undefined;
21
21
  }, "style" | "className" | "classes" | "children" | "sx" | "variant" | "alt" | "src" | "sizes" | "srcSet" | "slotProps" | "slots" | "imgProps"> & {
22
22
  theme?: import("@emotion/react").Theme;
@@ -1,5 +1,5 @@
1
1
  import styled from "@emotion/styled";
2
- import { Avatar as MAvatar, IconButton as MIconButton, Menu as MMenu, MenuItem, Typography, } from "@mui/material";
2
+ import { Avatar, IconButton as MIconButton, Menu as MMenu, MenuItem, Typography, } from "@mui/material";
3
3
  export const AuthenticationMenu = styled(MMenu) `
4
4
  margin: 4px 0;
5
5
  `;
@@ -22,7 +22,7 @@ export const UserNames = styled(Typography) `
22
22
  font-weight: 500;
23
23
  max-width: 200px;
24
24
  `;
25
- export const Avatar = styled(MAvatar) `
25
+ export const StyledAvatar = styled(Avatar) `
26
26
  height: 32px;
27
27
  width: 32px;
28
28
  `;
@@ -0,0 +1,2 @@
1
+ import { MenuProps } from "@mui/material";
2
+ export declare const MENU_PROPS: Partial<MenuProps>;
@@ -0,0 +1,14 @@
1
+ import { VARIANT } from "../../../../../../../../../../../../styles/common/mui/paper";
2
+ import { POPOVER_ORIGIN_HORIZONTAL, POPOVER_ORIGIN_VERTICAL, } from "../../../../../../../../../../../../styles/common/mui/popover";
3
+ export const MENU_PROPS = {
4
+ anchorOrigin: {
5
+ horizontal: POPOVER_ORIGIN_HORIZONTAL.RIGHT,
6
+ vertical: POPOVER_ORIGIN_VERTICAL.BOTTOM,
7
+ },
8
+ autoFocus: false,
9
+ slotProps: { paper: { variant: VARIANT.MENU } },
10
+ transformOrigin: {
11
+ horizontal: POPOVER_ORIGIN_HORIZONTAL.RIGHT,
12
+ vertical: POPOVER_ORIGIN_VERTICAL.TOP,
13
+ },
14
+ };
@@ -1,6 +1,7 @@
1
1
  import styled from "@emotion/styled";
2
- import { Button as MButton } from "@mui/material";
3
- export const StyledButton = styled(MButton) `
2
+ import { Button } from "@mui/material";
3
+ export const StyledButton = styled(Button) `
4
+ &.MuiButton-activeNav,
4
5
  &.MuiButton-nav {
5
6
  padding: 6px 12px;
6
7
  }
@@ -49,7 +49,7 @@ export const Header = ({ ...headerProps }) => {
49
49
  : renderSearchButton(props), closeMenu: onClose, searchEnabled: searchEnabled, searchURL: searchURL }),
50
50
  React.createElement(Authentication, { Button: ({ ...props }) => isIn.isMenuIn
51
51
  ? renderAuthenticationIconButton(props)
52
- : renderAuthenticationButton(props), authenticationEnabled: authenticationEnabled, closeMenu: onClose }),
52
+ : renderAuthenticationButton(props, pathname), authenticationEnabled: authenticationEnabled, closeMenu: onClose }),
53
53
  actions,
54
54
  React.createElement(Menu, { ...navigationProps, closeMenu: onClose, isMenuIn: isIn.isMenuIn, open: open, openMenu: onOpen }))))))));
55
55
  };
@@ -0,0 +1,2 @@
1
+ import { Props } from "./types";
2
+ export declare const Button: ({ className, ...props }: Props) => JSX.Element;
@@ -0,0 +1,6 @@
1
+ import React from "react";
2
+ import { StyledButton } from "./button.styles";
3
+ import { BUTTON_PROPS } from "./constants";
4
+ export const Button = ({ className, ...props }) => {
5
+ return React.createElement(StyledButton, { className: className, ...BUTTON_PROPS, ...props });
6
+ };
@@ -0,0 +1,5 @@
1
+ export declare const StyledButton: import("@emotion/styled").StyledComponent<import("@mui/material").ButtonOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
2
+ ref?: ((instance: HTMLButtonElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement> | null | undefined;
3
+ }, "style" | "className" | "classes" | "tabIndex" | "color" | "children" | "sx" | "variant" | "disabled" | "href" | "action" | "size" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "fullWidth" | "disableElevation" | "disableFocusRipple" | "endIcon" | "startIcon"> & {
4
+ theme?: import("@emotion/react").Theme;
5
+ }, {}, {}>;
@@ -0,0 +1,11 @@
1
+ import styled from "@emotion/styled";
2
+ import { Button } from "@mui/material";
3
+ export const StyledButton = styled(Button) `
4
+ &.MuiButton-root {
5
+ justify-content: space-between;
6
+
7
+ .MuiButton-endIcon {
8
+ margin: -6px;
9
+ }
10
+ }
11
+ `;
@@ -0,0 +1,2 @@
1
+ import { ButtonProps } from "@mui/material";
2
+ export declare const BUTTON_PROPS: Partial<ButtonProps>;
@@ -0,0 +1,6 @@
1
+ import { COLOR, VARIANT } from "../../../../styles/common/mui/button";
2
+ export const BUTTON_PROPS = {
3
+ color: COLOR.SECONDARY,
4
+ fullWidth: true,
5
+ variant: VARIANT.CONTAINED,
6
+ };
@@ -0,0 +1,3 @@
1
+ import { ButtonProps } from "@mui/material/Button/Button";
2
+ import { BaseComponentProps } from "../../../../theme/common/entities";
3
+ export type Props = BaseComponentProps & ButtonProps;
@@ -0,0 +1 @@
1
+ export {};
@@ -1,9 +1,2 @@
1
- import { ReactNode } from "react";
2
- export interface LoginProps {
3
- isGoogle?: boolean;
4
- termsOfService?: ReactNode;
5
- text?: ReactNode;
6
- title: string;
7
- warning?: ReactNode;
8
- }
9
- export declare const Login: ({ isGoogle, termsOfService, text, title, warning, }: LoginProps) => JSX.Element;
1
+ import { Props } from "./types";
2
+ export declare const Login: <P>({ providers, termsOfService, text, title, warning, }: Props<P>) => JSX.Element;
@@ -1,27 +1,26 @@
1
1
  import { Checkbox, Typography } from "@mui/material";
2
- import React, { useState } from "react";
3
- import { useAuthentication } from "../../hooks/useAuthentication/useAuthentication";
4
- import { LoginButton } from "../common/Button/components/LoginButton/loginButton";
2
+ import React, { useCallback, useState } from "react";
3
+ import { useAuth } from "../../providers/authentication/auth/hook";
5
4
  import { CheckedIcon } from "../common/CustomIcon/components/CheckedIcon/checkedIcon";
6
- import { GoogleIcon } from "../common/CustomIcon/components/GoogleIcon/googleIcon";
7
5
  import { UncheckedErrorIcon } from "../common/CustomIcon/components/UncheckedErrorIcon/uncheckedErrorIcon";
8
6
  import { UncheckedIcon } from "../common/CustomIcon/components/UncheckedIcon/uncheckedIcon";
9
7
  import { RoundedPaper } from "../common/Paper/paper.styles";
10
8
  import { SectionContent } from "../common/Section/section.styles";
9
+ import { Button } from "./components/Button/button";
11
10
  import { LoginAgreement, LoginSection, LoginSectionActions, LoginText, LoginWarning, LoginWrapper, TermsOfService, } from "./login.styles";
12
- export const Login = ({ isGoogle = false, termsOfService, text, title, warning, }) => {
13
- const { authenticateUser } = useAuthentication();
11
+ export const Login = ({ providers = [], termsOfService, text, title, warning, }) => {
12
+ const { service: { requestLogin } = {} } = useAuth();
14
13
  const [isError, setIsError] = useState(false);
15
14
  const [isInAgreement, setIsInAgreement] = useState(!termsOfService);
16
15
  // Authenticates the user, if the user has agreed to the terms of service.
17
16
  // If the terms of service are not accepted, set the terms of service error state to true.
18
- const onAuthenticateUser = () => {
17
+ const onLogin = useCallback((providerId) => {
19
18
  if (!isInAgreement) {
20
19
  setIsError(true);
21
20
  return;
22
21
  }
23
- authenticateUser();
24
- };
22
+ requestLogin?.(providerId);
23
+ }, [isInAgreement, requestLogin]);
25
24
  // Callback fired when the checkbox value is changed.
26
25
  // Clears the terms of service error state and sets state isInAgreement with checkbox selected value.
27
26
  const handleChange = (changeEvent) => {
@@ -38,6 +37,6 @@ export const Login = ({ isGoogle = false, termsOfService, text, title, warning,
38
37
  termsOfService && (React.createElement(LoginAgreement, null,
39
38
  React.createElement(Checkbox, { checkedIcon: React.createElement(CheckedIcon, null), icon: isError ? React.createElement(UncheckedErrorIcon, null) : React.createElement(UncheckedIcon, null), onChange: handleChange }),
40
39
  React.createElement(TermsOfService, null, termsOfService))),
41
- isGoogle && (React.createElement(LoginButton, { EndIcon: GoogleIcon, onClick: onAuthenticateUser }, "Google"))))),
40
+ providers?.map((provider) => (React.createElement(Button, { key: provider.id, endIcon: "icon" in provider && provider.icon, onClick: () => onLogin(provider.id) }, provider.name)))))),
42
41
  warning && React.createElement(LoginWarning, null, warning)));
43
42
  };
@@ -0,0 +1,10 @@
1
+ import { ClientSafeProvider } from "next-auth/react";
2
+ import { ReactNode } from "react";
3
+ import { OAuthProvider } from "../../config/entities";
4
+ export interface Props<P> {
5
+ providers?: ClientSafeProvider[] | OAuthProvider<P>[];
6
+ termsOfService?: ReactNode;
7
+ text?: ReactNode;
8
+ title: string;
9
+ warning?: ReactNode;
10
+ }
@@ -0,0 +1 @@
1
+ export {};