@databiosphere/findable-ui 19.0.0 → 20.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 (363) hide show
  1. package/.release-please-manifest.json +1 -1
  2. package/CHANGELOG.md +11 -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/common/Banner/components/SessionTimeout/sessionTimeout.js +1 -1
  42. package/lib/components/common/CustomIcon/common/entities.d.ts +1 -4
  43. package/lib/components/common/CustomIcon/components/GoogleIcon/googleIcon.d.ts +2 -2
  44. package/lib/components/common/CustomIcon/components/GoogleIcon/googleIcon.js +1 -1
  45. package/lib/config/entities.d.ts +22 -23
  46. package/lib/hooks/authentication/auth/useAuthReducer.d.ts +2 -0
  47. package/lib/hooks/authentication/auth/useAuthReducer.js +8 -0
  48. package/lib/hooks/authentication/authentication/useAuthenticationReducer.d.ts +2 -0
  49. package/lib/hooks/authentication/authentication/useAuthenticationReducer.js +8 -0
  50. package/lib/hooks/authentication/config/useAuthenticationConfig.d.ts +6 -0
  51. package/lib/hooks/authentication/config/useAuthenticationConfig.js +9 -0
  52. package/lib/hooks/authentication/credentials/useCredentialsReducer.d.ts +2 -0
  53. package/lib/hooks/authentication/credentials/useCredentialsReducer.js +7 -0
  54. package/lib/hooks/authentication/profile/types.d.ts +5 -0
  55. package/lib/hooks/authentication/profile/types.js +1 -0
  56. package/lib/hooks/authentication/profile/useProfile.d.ts +6 -0
  57. package/lib/hooks/authentication/profile/useProfile.js +15 -0
  58. package/lib/hooks/authentication/providers/types.d.ts +6 -0
  59. package/lib/hooks/authentication/providers/types.js +1 -0
  60. package/lib/hooks/authentication/providers/useProviders.d.ts +6 -0
  61. package/lib/hooks/authentication/providers/useProviders.js +14 -0
  62. package/lib/hooks/authentication/session/useSessionActive.d.ts +12 -0
  63. package/lib/hooks/authentication/session/useSessionActive.js +36 -0
  64. package/lib/hooks/authentication/session/useSessionCallbackUrl.d.ts +4 -0
  65. package/lib/hooks/authentication/session/useSessionCallbackUrl.js +20 -0
  66. package/lib/hooks/authentication/session/useSessionIdleTimer.d.ts +6 -0
  67. package/lib/hooks/authentication/session/useSessionIdleTimer.js +8 -0
  68. package/lib/hooks/{useSessionTimeout.js → authentication/session/useSessionTimeout.js} +2 -2
  69. package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.d.ts +0 -1
  70. package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.js +6 -9
  71. package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.js +3 -4
  72. package/lib/hooks/authentication/token/types.d.ts +4 -0
  73. package/lib/hooks/authentication/token/types.js +1 -0
  74. package/lib/hooks/authentication/token/useToken.d.ts +2 -0
  75. package/lib/hooks/authentication/token/useToken.js +5 -0
  76. package/lib/hooks/authentication/token/useTokenReducer.d.ts +7 -0
  77. package/lib/hooks/authentication/token/useTokenReducer.js +12 -0
  78. package/lib/hooks/useEntityList.js +2 -2
  79. package/lib/hooks/useFetchEntity.js +4 -3
  80. package/lib/hooks/useFileManifest/useFetchFilesFacets.js +2 -3
  81. package/lib/hooks/useFileManifest/useFetchSummary.js +2 -3
  82. package/lib/hooks/useRequestFileLocation.js +2 -3
  83. package/lib/hooks/useRouteHistory.d.ts +14 -0
  84. package/lib/hooks/useRouteHistory.js +40 -0
  85. package/lib/hooks/useRouteRoot.d.ts +1 -0
  86. package/lib/hooks/useRouteRoot.js +8 -0
  87. package/lib/hooks/useSummary.js +3 -3
  88. package/lib/providers/authentication/auth/actions.d.ts +8 -0
  89. package/lib/providers/authentication/auth/actions.js +12 -0
  90. package/lib/providers/authentication/auth/constants.d.ts +2 -0
  91. package/lib/providers/authentication/auth/constants.js +5 -0
  92. package/lib/providers/authentication/auth/context.d.ts +2 -0
  93. package/lib/providers/authentication/auth/context.js +7 -0
  94. package/lib/providers/authentication/auth/dispatch.d.ts +23 -0
  95. package/lib/providers/authentication/auth/dispatch.js +43 -0
  96. package/lib/providers/authentication/auth/hook.d.ts +6 -0
  97. package/lib/providers/authentication/auth/hook.js +9 -0
  98. package/lib/providers/authentication/auth/reducer.d.ts +8 -0
  99. package/lib/providers/authentication/auth/reducer.js +24 -0
  100. package/lib/providers/authentication/auth/types.d.ts +48 -0
  101. package/lib/providers/authentication/auth/types.js +11 -0
  102. package/lib/providers/authentication/authentication/actions.d.ts +8 -0
  103. package/lib/providers/authentication/authentication/actions.js +12 -0
  104. package/lib/providers/authentication/authentication/constants.d.ts +2 -0
  105. package/lib/providers/authentication/authentication/constants.js +5 -0
  106. package/lib/providers/authentication/authentication/context.d.ts +2 -0
  107. package/lib/providers/authentication/authentication/context.js +6 -0
  108. package/lib/providers/authentication/authentication/dispatch.d.ts +22 -0
  109. package/lib/providers/authentication/authentication/dispatch.js +42 -0
  110. package/lib/providers/authentication/authentication/hook.d.ts +6 -0
  111. package/lib/providers/authentication/authentication/hook.js +9 -0
  112. package/lib/providers/authentication/authentication/reducer.d.ts +9 -0
  113. package/lib/providers/authentication/authentication/reducer.js +25 -0
  114. package/lib/providers/authentication/authentication/types.d.ts +47 -0
  115. package/lib/providers/authentication/authentication/types.js +11 -0
  116. package/lib/providers/authentication/authentication/utils.d.ts +12 -0
  117. package/lib/providers/authentication/authentication/utils.js +18 -0
  118. package/lib/providers/authentication/common/types.d.ts +1 -0
  119. package/lib/providers/authentication/common/types.js +1 -0
  120. package/lib/providers/authentication/common/utils.d.ts +6 -0
  121. package/lib/providers/authentication/common/utils.js +11 -0
  122. package/lib/providers/authentication/credentials/actions.d.ts +8 -0
  123. package/lib/providers/authentication/credentials/actions.js +12 -0
  124. package/lib/providers/authentication/credentials/constants.d.ts +2 -0
  125. package/lib/providers/authentication/credentials/constants.js +3 -0
  126. package/lib/providers/authentication/credentials/context.d.ts +2 -0
  127. package/lib/providers/authentication/credentials/context.js +6 -0
  128. package/lib/providers/authentication/credentials/dispatch.d.ts +12 -0
  129. package/lib/providers/authentication/credentials/dispatch.js +22 -0
  130. package/lib/providers/authentication/credentials/hook.d.ts +6 -0
  131. package/lib/providers/authentication/credentials/hook.js +9 -0
  132. package/lib/providers/authentication/credentials/reducer.d.ts +8 -0
  133. package/lib/providers/authentication/credentials/reducer.js +22 -0
  134. package/lib/providers/authentication/credentials/types.d.ts +24 -0
  135. package/lib/providers/authentication/credentials/types.js +5 -0
  136. package/lib/providers/authentication/terra/context.d.ts +2 -0
  137. package/lib/providers/authentication/terra/context.js +7 -0
  138. package/lib/providers/authentication/terra/hook.d.ts +6 -0
  139. package/lib/providers/authentication/terra/hook.js +9 -0
  140. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.d.ts +2 -0
  141. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.js +7 -0
  142. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.d.ts +3 -7
  143. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.js +1 -5
  144. package/lib/providers/authentication/terra/hooks/useFetchProfiles.d.ts +13 -0
  145. package/lib/providers/authentication/terra/hooks/useFetchProfiles.js +31 -0
  146. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.js +11 -6
  147. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.js +11 -6
  148. package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.js +11 -6
  149. package/lib/providers/authentication/terra/hooks/utils.d.ts +16 -0
  150. package/lib/providers/authentication/terra/hooks/utils.js +19 -0
  151. package/lib/providers/authentication/terra/provider.d.ts +2 -0
  152. package/lib/providers/authentication/terra/provider.js +42 -0
  153. package/lib/providers/authentication/terra/types.d.ts +20 -0
  154. package/lib/providers/authentication/terra/types.js +6 -0
  155. package/lib/providers/authentication/terra/utils.d.ts +19 -0
  156. package/lib/providers/authentication/terra/utils.js +36 -0
  157. package/lib/providers/authentication/token/constants.d.ts +2 -0
  158. package/lib/providers/authentication/token/constants.js +4 -0
  159. package/lib/providers/authentication/token/dispatch.d.ts +12 -0
  160. package/lib/providers/authentication/token/dispatch.js +22 -0
  161. package/lib/providers/authentication/token/reducer.d.ts +8 -0
  162. package/lib/providers/authentication/token/reducer.js +22 -0
  163. package/lib/providers/authentication/token/types.d.ts +28 -0
  164. package/lib/providers/authentication/token/types.js +5 -0
  165. package/lib/providers/exploreState.js +3 -5
  166. package/lib/providers/googleSignInAuthentication/common/types.d.ts +17 -0
  167. package/lib/providers/googleSignInAuthentication/common/types.js +1 -0
  168. package/lib/providers/googleSignInAuthentication/constants.d.ts +4 -0
  169. package/lib/providers/googleSignInAuthentication/constants.js +12 -0
  170. package/lib/providers/googleSignInAuthentication/hooks/useGoogleSignInService.d.ts +3 -0
  171. package/lib/providers/googleSignInAuthentication/hooks/useGoogleSignInService.js +36 -0
  172. package/lib/providers/googleSignInAuthentication/profile/types.d.ts +14 -0
  173. package/lib/providers/googleSignInAuthentication/profile/types.js +1 -0
  174. package/lib/providers/googleSignInAuthentication/profile/utils.d.ts +8 -0
  175. package/lib/providers/googleSignInAuthentication/profile/utils.js +25 -0
  176. package/lib/providers/googleSignInAuthentication/provider.d.ts +2 -0
  177. package/lib/providers/googleSignInAuthentication/provider.js +40 -0
  178. package/lib/providers/googleSignInAuthentication/service/constants.d.ts +4 -0
  179. package/lib/providers/googleSignInAuthentication/service/constants.js +9 -0
  180. package/lib/providers/googleSignInAuthentication/service/service.d.ts +6 -0
  181. package/lib/providers/googleSignInAuthentication/service/service.js +43 -0
  182. package/lib/providers/googleSignInAuthentication/types.d.ts +6 -0
  183. package/lib/providers/googleSignInAuthentication/types.js +1 -0
  184. package/lib/providers/nextAuthAuthentication/hooks/useNextAuthService.d.ts +2 -0
  185. package/lib/providers/nextAuthAuthentication/hooks/useNextAuthService.js +14 -0
  186. package/lib/providers/nextAuthAuthentication/provider.d.ts +2 -0
  187. package/lib/providers/nextAuthAuthentication/provider.js +30 -0
  188. package/lib/providers/nextAuthAuthentication/service/service.d.ts +6 -0
  189. package/lib/providers/nextAuthAuthentication/service/service.js +12 -0
  190. package/lib/providers/nextAuthAuthentication/types.d.ts +8 -0
  191. package/lib/providers/nextAuthAuthentication/types.js +1 -0
  192. package/lib/routes/constants.d.ts +3 -0
  193. package/lib/routes/constants.js +3 -0
  194. package/lib/styles/common/mui/button.d.ts +3 -0
  195. package/lib/styles/common/mui/button.js +17 -0
  196. package/lib/styles/common/mui/paper.d.ts +2 -0
  197. package/lib/styles/common/mui/paper.js +9 -0
  198. package/lib/styles/common/mui/popover.d.ts +3 -0
  199. package/lib/styles/common/mui/popover.js +10 -0
  200. package/lib/theme/common/entities.d.ts +6 -0
  201. package/lib/theme/common/entities.js +1 -0
  202. package/lib/views/LoginView/loginView.d.ts +5 -1
  203. package/lib/views/LoginView/loginView.js +6 -4
  204. package/package.json +3 -2
  205. package/src/components/Authentication/components/SessionController/components/GoogleSessionController/SessionController.tsx +38 -0
  206. package/src/components/Authentication/components/SessionController/components/GoogleSessionController/types.ts +7 -0
  207. package/src/components/Authentication/components/SessionController/components/NextSessionController/SessionController.tsx +23 -0
  208. package/src/components/Authentication/components/SessionController/components/NextSessionController/constants.ts +21 -0
  209. package/src/components/Authentication/components/SessionController/components/NextSessionController/types.ts +5 -0
  210. package/src/components/Authentication/components/SessionController/components/NextSessionController/utils.ts +74 -0
  211. package/src/components/ComponentCreator/ComponentCreator.tsx +4 -3
  212. package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/FormStep/components/AcceptTerraTOS/acceptTerraTOS.tsx +4 -4
  213. package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/NIHAccountExpiryWarning/nihAccountExpiryWarning.tsx +1 -1
  214. package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/terraSetUpForm.tsx +9 -6
  215. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.tsx +27 -25
  216. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.ts +2 -2
  217. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.tsx +18 -42
  218. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/constants.ts +19 -0
  219. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/Button/button.styles.ts +3 -2
  220. package/src/components/Layout/components/Header/header.tsx +1 -1
  221. package/src/components/Login/components/Button/button.styles.ts +12 -0
  222. package/src/components/Login/components/Button/button.tsx +8 -0
  223. package/src/components/Login/components/Button/constants.ts +8 -0
  224. package/src/components/Login/components/Button/types.ts +4 -0
  225. package/src/components/Login/login.tsx +28 -28
  226. package/src/components/Login/types.ts +11 -0
  227. package/src/components/common/Banner/components/SessionTimeout/sessionTimeout.tsx +1 -1
  228. package/src/components/common/CustomIcon/common/entities.ts +1 -4
  229. package/src/components/common/CustomIcon/components/GoogleIcon/googleIcon.tsx +3 -4
  230. package/src/config/entities.ts +20 -25
  231. package/src/hooks/authentication/auth/useAuthReducer.ts +16 -0
  232. package/src/hooks/authentication/authentication/useAuthenticationReducer.ts +16 -0
  233. package/src/hooks/authentication/config/useAuthenticationConfig.ts +13 -0
  234. package/src/hooks/authentication/credentials/useCredentialsReducer.ts +13 -0
  235. package/src/hooks/authentication/profile/types.ts +9 -0
  236. package/src/hooks/authentication/profile/useProfile.ts +21 -0
  237. package/src/hooks/authentication/providers/types.ts +7 -0
  238. package/src/hooks/authentication/providers/useProviders.ts +23 -0
  239. package/src/hooks/authentication/session/useSessionActive.ts +51 -0
  240. package/src/hooks/authentication/session/useSessionCallbackUrl.ts +25 -0
  241. package/src/hooks/authentication/session/useSessionIdleTimer.ts +10 -0
  242. package/src/hooks/{useSessionTimeout.ts → authentication/session/useSessionTimeout.ts} +2 -2
  243. package/src/hooks/{useAuthentication → authentication/terra}/useAuthenticationForm.ts +8 -13
  244. package/src/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.ts +3 -4
  245. package/src/hooks/authentication/token/types.ts +5 -0
  246. package/src/hooks/authentication/token/useToken.ts +9 -0
  247. package/src/hooks/authentication/token/useTokenReducer.ts +19 -0
  248. package/src/hooks/useEntityList.ts +2 -2
  249. package/src/hooks/useFetchEntity.tsx +3 -3
  250. package/src/hooks/useFileManifest/useFetchFilesFacets.ts +2 -3
  251. package/src/hooks/useFileManifest/useFetchSummary.ts +2 -3
  252. package/src/hooks/useRequestFileLocation.ts +2 -3
  253. package/src/hooks/useRouteHistory.ts +65 -0
  254. package/src/hooks/useRouteRoot.ts +11 -0
  255. package/src/hooks/useSummary.ts +3 -3
  256. package/src/providers/authentication/auth/actions.ts +17 -0
  257. package/src/providers/authentication/auth/constants.ts +6 -0
  258. package/src/providers/authentication/auth/context.ts +9 -0
  259. package/src/providers/authentication/auth/dispatch.ts +58 -0
  260. package/src/providers/authentication/auth/hook.ts +11 -0
  261. package/src/providers/authentication/auth/reducer.ts +25 -0
  262. package/src/providers/authentication/auth/types.ts +63 -0
  263. package/src/providers/authentication/authentication/actions.ts +17 -0
  264. package/src/providers/authentication/authentication/constants.ts +6 -0
  265. package/src/providers/authentication/authentication/context.ts +8 -0
  266. package/src/providers/authentication/authentication/dispatch.ts +55 -0
  267. package/src/providers/authentication/authentication/hook.ts +11 -0
  268. package/src/providers/authentication/authentication/reducer.ts +34 -0
  269. package/src/providers/authentication/authentication/types.ts +64 -0
  270. package/src/providers/authentication/authentication/utils.ts +25 -0
  271. package/src/providers/authentication/common/types.ts +1 -0
  272. package/src/providers/authentication/common/utils.ts +11 -0
  273. package/src/providers/authentication/credentials/actions.ts +17 -0
  274. package/src/providers/authentication/credentials/constants.ts +5 -0
  275. package/src/providers/authentication/credentials/context.ts +8 -0
  276. package/src/providers/authentication/credentials/dispatch.ts +31 -0
  277. package/src/providers/authentication/credentials/hook.ts +11 -0
  278. package/src/providers/authentication/credentials/reducer.ts +30 -0
  279. package/src/providers/authentication/credentials/types.ts +33 -0
  280. package/src/providers/authentication/terra/context.ts +16 -0
  281. package/src/providers/authentication/terra/hook.ts +11 -0
  282. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/constants.ts +9 -0
  283. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/entities.ts +1 -7
  284. package/src/providers/authentication/terra/hooks/useFetchProfiles.ts +61 -0
  285. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.ts +18 -7
  286. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.ts +18 -7
  287. package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.ts +18 -7
  288. package/src/providers/authentication/terra/hooks/utils.ts +29 -0
  289. package/src/providers/authentication/terra/provider.tsx +60 -0
  290. package/src/providers/authentication/terra/types.ts +23 -0
  291. package/src/providers/authentication/terra/utils.ts +49 -0
  292. package/src/providers/authentication/token/constants.ts +6 -0
  293. package/src/providers/authentication/token/dispatch.ts +29 -0
  294. package/src/providers/authentication/token/reducer.ts +26 -0
  295. package/src/providers/authentication/token/types.ts +36 -0
  296. package/src/providers/exploreState.tsx +3 -4
  297. package/src/providers/googleSignInAuthentication/common/types.ts +28 -0
  298. package/src/providers/googleSignInAuthentication/constants.ts +17 -0
  299. package/src/providers/googleSignInAuthentication/hooks/useGoogleSignInService.ts +53 -0
  300. package/src/providers/googleSignInAuthentication/profile/types.ts +15 -0
  301. package/src/providers/googleSignInAuthentication/profile/utils.ts +29 -0
  302. package/src/providers/googleSignInAuthentication/provider.tsx +53 -0
  303. package/src/providers/googleSignInAuthentication/service/constants.ts +16 -0
  304. package/src/providers/googleSignInAuthentication/service/service.ts +68 -0
  305. package/src/providers/googleSignInAuthentication/types.ts +7 -0
  306. package/src/providers/nextAuthAuthentication/hooks/useNextAuthService.ts +26 -0
  307. package/src/providers/nextAuthAuthentication/provider.tsx +42 -0
  308. package/src/providers/nextAuthAuthentication/service/service.ts +14 -0
  309. package/src/providers/nextAuthAuthentication/types.ts +9 -0
  310. package/src/routes/constants.ts +3 -0
  311. package/src/styles/common/mui/button.ts +20 -0
  312. package/src/styles/common/mui/paper.ts +11 -0
  313. package/src/styles/common/mui/popover.ts +19 -0
  314. package/src/theme/common/entities.ts +7 -0
  315. package/src/views/LoginView/loginView.tsx +15 -9
  316. package/tests/getProfileStatus.test.ts +290 -0
  317. package/tests/terraProfileProvider.test.tsx +121 -0
  318. package/tests/transformRoute.test.ts +21 -0
  319. package/tests/useRouteHistory.test.ts +97 -0
  320. package/tests/useSessionActive.test.ts +107 -0
  321. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.d.ts +0 -5
  322. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.js +0 -29
  323. package/lib/components/Login/login.stories.d.ts +0 -6
  324. package/lib/components/Login/login.stories.js +0 -31
  325. package/lib/components/common/Button/components/LoginButton/loginButton.d.ts +0 -3
  326. package/lib/components/common/Button/components/LoginButton/loginButton.js +0 -6
  327. package/lib/components/common/Button/components/LoginButton/loginButton.styles.d.ts +0 -7
  328. package/lib/components/common/Button/components/LoginButton/loginButton.styles.js +0 -11
  329. package/lib/hooks/useAuthentication/useAuthentication.d.ts +0 -6
  330. package/lib/hooks/useAuthentication/useAuthentication.js +0 -9
  331. package/lib/hooks/useAuthentication/useAuthenticationComplete.d.ts +0 -6
  332. package/lib/hooks/useAuthentication/useAuthenticationComplete.js +0 -55
  333. package/lib/hooks/useAuthentication/useAuthenticationStatus.d.ts +0 -20
  334. package/lib/hooks/useAuthentication/useAuthenticationStatus.js +0 -32
  335. package/lib/hooks/useAuthentication/useFetchGoogleProfile.d.ts +0 -21
  336. package/lib/hooks/useAuthentication/useFetchGoogleProfile.js +0 -41
  337. package/lib/hooks/useAuthentication/useTokenClient.d.ts +0 -11
  338. package/lib/hooks/useAuthentication/useTokenClient.js +0 -29
  339. package/lib/hooks/useAuthenticationConfig.d.ts +0 -6
  340. package/lib/hooks/useAuthenticationConfig.js +0 -14
  341. package/lib/providers/authentication.d.ts +0 -51
  342. package/lib/providers/authentication.js +0 -110
  343. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.tsx +0 -35
  344. package/src/components/Login/login.stories.tsx +0 -43
  345. package/src/components/common/Button/components/LoginButton/loginButton.styles.ts +0 -13
  346. package/src/components/common/Button/components/LoginButton/loginButton.tsx +0 -16
  347. package/src/hooks/useAuthentication/useAuthentication.tsx +0 -10
  348. package/src/hooks/useAuthentication/useAuthenticationComplete.ts +0 -66
  349. package/src/hooks/useAuthentication/useAuthenticationStatus.ts +0 -49
  350. package/src/hooks/useAuthentication/useFetchGoogleProfile.ts +0 -68
  351. package/src/hooks/useAuthentication/useTokenClient.ts +0 -54
  352. package/src/hooks/useAuthenticationConfig.ts +0 -18
  353. package/src/providers/authentication.tsx +0 -181
  354. package/tests/authentication.test.ts +0 -142
  355. package/tests/useAuthenticationStatus.test.ts +0 -155
  356. /package/lib/hooks/{useSessionTimeout.d.ts → authentication/session/useSessionTimeout.d.ts} +0 -0
  357. /package/lib/hooks/{useAuthentication → authentication/terra}/useAuthenticationNIHExpiry.d.ts +0 -0
  358. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.d.ts +0 -0
  359. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.js +0 -0
  360. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraNIHProfile.d.ts +0 -0
  361. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraProfile.d.ts +0 -0
  362. /package/lib/{hooks/useAuthentication → providers/authentication/terra/hooks}/useFetchTerraTermsOfService.d.ts +0 -0
  363. /package/src/{hooks/useAuthentication → providers/authentication/terra/hooks}/common/utils.ts +0 -0
@@ -0,0 +1,21 @@
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
+
5
+ export const AUTH_STATUS_MAP: Record<
6
+ SessionContextValue["status"],
7
+ AUTH_STATUS
8
+ > = {
9
+ authenticated: AUTH_STATUS.SETTLED,
10
+ loading: AUTH_STATUS.PENDING,
11
+ unauthenticated: AUTH_STATUS.SETTLED,
12
+ };
13
+
14
+ export const AUTHENTICATION_STATUS_MAP: Record<
15
+ SessionContextValue["status"],
16
+ AUTHENTICATION_STATUS
17
+ > = {
18
+ authenticated: AUTHENTICATION_STATUS.SETTLED,
19
+ loading: AUTHENTICATION_STATUS.PENDING,
20
+ unauthenticated: AUTHENTICATION_STATUS.SETTLED,
21
+ };
@@ -0,0 +1,5 @@
1
+ import { ReactNode } from "react";
2
+
3
+ export interface SessionControllerProps {
4
+ children: ReactNode | ReactNode[];
5
+ }
@@ -0,0 +1,74 @@
1
+ import { Session } from "next-auth";
2
+ import { SessionContextValue } from "next-auth/react";
3
+ import {
4
+ AUTH_STATUS,
5
+ UpdateAuthStatePayload,
6
+ } from "../../../../../../providers/authentication/auth/types";
7
+ import {
8
+ AUTHENTICATION_STATUS,
9
+ UpdateAuthenticationPayload,
10
+ UserProfile,
11
+ } from "../../../../../../providers/authentication/authentication/types";
12
+ import { AUTH_STATUS_MAP, AUTHENTICATION_STATUS_MAP } from "./constants";
13
+
14
+ /**
15
+ * Returns the auth state from the session context.
16
+ * @param session - Session context value.
17
+ * @returns auth state.
18
+ */
19
+ export function mapAuth(session: SessionContextValue): UpdateAuthStatePayload {
20
+ return {
21
+ isAuthenticated: session.status === "authenticated",
22
+ status: mapStatus(session.status, AUTH_STATUS_MAP, AUTH_STATUS.SETTLED),
23
+ };
24
+ }
25
+
26
+ /**
27
+ * Returns the authentication profile and status from the session context.
28
+ * @param session - Session context value.
29
+ * @returns authentication profile and status.
30
+ */
31
+ export function mapAuthentication(
32
+ session: SessionContextValue
33
+ ): UpdateAuthenticationPayload {
34
+ return {
35
+ profile: mapProfile(session.data),
36
+ status: mapStatus(
37
+ session.status,
38
+ AUTHENTICATION_STATUS_MAP,
39
+ AUTHENTICATION_STATUS.SETTLED
40
+ ),
41
+ };
42
+ }
43
+
44
+ /**
45
+ * Maps the session data to a user profile.
46
+ * @param sessionData - Session data.
47
+ * @returns user profile.
48
+ */
49
+ function mapProfile(sessionData: Session | null): UserProfile | undefined {
50
+ if (!sessionData) return;
51
+ const { user } = sessionData;
52
+ if (!user) return;
53
+ const { email, image, name } = user;
54
+ return {
55
+ email: email || "",
56
+ image: image || "",
57
+ name: name || "",
58
+ };
59
+ }
60
+
61
+ /**
62
+ * Returns the auth or authentication status <S> based on the session status.
63
+ * @param status - Session status.
64
+ * @param statusBySessionStatus - Map of session status to auth or authentication status.
65
+ * @param defaultStatus - Default auth or authentication status.
66
+ * @returns auth or authentication status.
67
+ */
68
+ function mapStatus<S>(
69
+ status: SessionContextValue["status"],
70
+ statusBySessionStatus: Record<SessionContextValue["status"], S>,
71
+ defaultStatus: S
72
+ ): S {
73
+ return statusBySessionStatus[status] || defaultStatus;
74
+ }
@@ -1,10 +1,10 @@
1
1
  import React from "react";
2
2
  import { ComponentsConfig, ViewContext } from "../../config/entities";
3
- import { useAuthentication } from "../../hooks/useAuthentication/useAuthentication";
4
3
  import { useConfig } from "../../hooks/useConfig";
5
4
  import { useExploreState } from "../../hooks/useExploreState";
6
5
  import { useFileManifestState } from "../../hooks/useFileManifestState";
7
6
  import { useSystemStatus } from "../../hooks/useSystemStatus";
7
+ import { useAuth } from "../../providers/authentication/auth/hook";
8
8
 
9
9
  export interface ComponentCreatorProps<T> {
10
10
  components: ComponentsConfig;
@@ -27,7 +27,9 @@ export const ComponentCreator = <T,>({
27
27
  response,
28
28
  viewContext,
29
29
  }: ComponentCreatorProps<T>): JSX.Element => {
30
- const { authenticationStatus, isAuthenticated } = useAuthentication();
30
+ const {
31
+ authState: { isAuthenticated },
32
+ } = useAuth();
31
33
  const { config, entityConfig } = useConfig();
32
34
  const { exploreState } = useExploreState();
33
35
  const { fileManifestState } = useFileManifestState();
@@ -53,7 +55,6 @@ export const ComponentCreator = <T,>({
53
55
  ? c.viewBuilder(response, {
54
56
  ...viewContext,
55
57
  authState: {
56
- authenticationStatus,
57
58
  isAuthenticated,
58
59
  },
59
60
  entityConfig,
@@ -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,6 +1,6 @@
1
1
  import { AlertProps, Fade } from "@mui/material";
2
2
  import React from "react";
3
- import { useSessionTimeout } from "../../../../../hooks/useSessionTimeout";
3
+ import { useSessionTimeout } from "../../../../../hooks/authentication/session/useSessionTimeout";
4
4
  import { BaseComponentProps, ContentProps } from "../../../../types";
5
5
  import { Banner } from "../../banner";
6
6
 
@@ -1,6 +1,3 @@
1
1
  import { SvgIconProps } from "@mui/material";
2
2
 
3
- export interface CustomSVGIconProps extends SvgIconProps {
4
- fontSize?: SvgIconProps["fontSize"];
5
- viewBox?: string;
6
- }
3
+ export type CustomSVGIconProps = SvgIconProps;
@@ -1,6 +1,5 @@
1
- import { SvgIcon } from "@mui/material";
1
+ import { SvgIcon, SvgIconProps } from "@mui/material";
2
2
  import React from "react";
3
- import { CustomSVGIconProps } from "../../common/entities";
4
3
 
5
4
  /**
6
5
  * Custom Google logo icon.
@@ -9,8 +8,8 @@ import { CustomSVGIconProps } from "../../common/entities";
9
8
  export const GoogleIcon = ({
10
9
  fontSize = "xsmall",
11
10
  viewBox = "0 0 20 20",
12
- ...props /* Spread props to allow for Mui SvgIconProps specific prop overrides e.g. "htmlColor". */
13
- }: CustomSVGIconProps): JSX.Element => {
11
+ ...props
12
+ }: SvgIconProps): JSX.Element => {
14
13
  return (
15
14
  <SvgIcon fontSize={fontSize} viewBox={viewBox} {...props}>
16
15
  <path