@civic/auth 0.3.1-beta.1 → 0.3.2-beta.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 (228) hide show
  1. package/CHANGELOG.md +5 -0
  2. package/dist/cjs/constants.d.ts +2 -1
  3. package/dist/cjs/constants.d.ts.map +1 -1
  4. package/dist/cjs/constants.js +9 -1
  5. package/dist/cjs/constants.js.map +1 -1
  6. package/dist/cjs/nextjs/index.d.ts +2 -2
  7. package/dist/cjs/nextjs/index.d.ts.map +1 -1
  8. package/dist/cjs/nextjs/index.js.map +1 -1
  9. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts +1 -5
  10. package/dist/cjs/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  11. package/dist/cjs/nextjs/providers/NextAuthProvider.js +5 -45
  12. package/dist/cjs/nextjs/providers/NextAuthProvider.js.map +1 -1
  13. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts +1 -1
  14. package/dist/cjs/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -1
  15. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js +16 -23
  16. package/dist/cjs/reactjs/components/ButtonContentOrLoader.js.map +1 -1
  17. package/dist/cjs/reactjs/components/SignInButton.d.ts +4 -3
  18. package/dist/cjs/reactjs/components/SignInButton.d.ts.map +1 -1
  19. package/dist/cjs/reactjs/components/SignInButton.js +5 -9
  20. package/dist/cjs/reactjs/components/SignInButton.js.map +1 -1
  21. package/dist/cjs/reactjs/components/SignOutButton.d.ts +4 -3
  22. package/dist/cjs/reactjs/components/SignOutButton.d.ts.map +1 -1
  23. package/dist/cjs/reactjs/components/SignOutButton.js +4 -8
  24. package/dist/cjs/reactjs/components/SignOutButton.js.map +1 -1
  25. package/dist/cjs/reactjs/components/UserButton.d.ts +6 -3
  26. package/dist/cjs/reactjs/components/UserButton.d.ts.map +1 -1
  27. package/dist/cjs/reactjs/components/UserButton.js +69 -109
  28. package/dist/cjs/reactjs/components/UserButton.js.map +1 -1
  29. package/dist/cjs/reactjs/providers/AuthProvider.d.ts +1 -2
  30. package/dist/cjs/reactjs/providers/AuthProvider.d.ts.map +1 -1
  31. package/dist/cjs/reactjs/providers/AuthProvider.js +3 -37
  32. package/dist/cjs/reactjs/providers/AuthProvider.js.map +1 -1
  33. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts +1 -2
  34. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts.map +1 -1
  35. package/dist/cjs/reactjs/providers/CivicAuthProvider.js +4 -13
  36. package/dist/cjs/reactjs/providers/CivicAuthProvider.js.map +1 -1
  37. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +1 -1
  38. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -1
  39. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js +3 -35
  40. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -1
  41. package/dist/cjs/services/UserinfoService.d.ts +5 -0
  42. package/dist/cjs/services/UserinfoService.d.ts.map +1 -0
  43. package/dist/cjs/services/UserinfoService.js +15 -0
  44. package/dist/cjs/services/UserinfoService.js.map +1 -0
  45. package/dist/cjs/shared/components/BlockDisplay.d.ts +1 -2
  46. package/dist/cjs/shared/components/BlockDisplay.d.ts.map +1 -1
  47. package/dist/cjs/shared/components/BlockDisplay.js +4 -8
  48. package/dist/cjs/shared/components/BlockDisplay.js.map +1 -1
  49. package/dist/cjs/shared/components/CivicAuthIframe.js +16 -17
  50. package/dist/cjs/shared/components/CivicAuthIframe.js.map +1 -1
  51. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts +2 -2
  52. package/dist/cjs/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  53. package/dist/cjs/shared/components/CivicAuthIframeContainer.js +29 -68
  54. package/dist/cjs/shared/components/CivicAuthIframeContainer.js.map +1 -1
  55. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts +1 -2
  56. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -1
  57. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js +9 -15
  58. package/dist/cjs/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -1
  59. package/dist/cjs/shared/components/CloseIcon.d.ts +1 -2
  60. package/dist/cjs/shared/components/CloseIcon.d.ts.map +1 -1
  61. package/dist/cjs/shared/components/CloseIcon.js +2 -7
  62. package/dist/cjs/shared/components/CloseIcon.js.map +1 -1
  63. package/dist/cjs/shared/components/IFrameAndLoading.d.ts +1 -2
  64. package/dist/cjs/shared/components/IFrameAndLoading.d.ts.map +1 -1
  65. package/dist/cjs/shared/components/IFrameAndLoading.js +5 -47
  66. package/dist/cjs/shared/components/IFrameAndLoading.js.map +1 -1
  67. package/dist/cjs/shared/components/LoadingIcon.d.ts +1 -2
  68. package/dist/cjs/shared/components/LoadingIcon.d.ts.map +1 -1
  69. package/dist/cjs/shared/components/LoadingIcon.js +19 -27
  70. package/dist/cjs/shared/components/LoadingIcon.js.map +1 -1
  71. package/dist/cjs/shared/components/SVGLoading.js +11 -24
  72. package/dist/cjs/shared/components/SVGLoading.js.map +1 -1
  73. package/dist/cjs/shared/lib/UserSession.d.ts +4 -2
  74. package/dist/cjs/shared/lib/UserSession.d.ts.map +1 -1
  75. package/dist/cjs/shared/lib/UserSession.js.map +1 -1
  76. package/dist/cjs/shared/lib/session.d.ts +2 -2
  77. package/dist/cjs/shared/lib/session.d.ts.map +1 -1
  78. package/dist/cjs/shared/lib/session.js +11 -6
  79. package/dist/cjs/shared/lib/session.js.map +1 -1
  80. package/dist/cjs/shared/lib/types.d.ts +1 -0
  81. package/dist/cjs/shared/lib/types.d.ts.map +1 -1
  82. package/dist/cjs/shared/lib/types.js +2 -1
  83. package/dist/cjs/shared/lib/types.js.map +1 -1
  84. package/dist/cjs/shared/lib/util.d.ts.map +1 -1
  85. package/dist/cjs/shared/lib/util.js +6 -5
  86. package/dist/cjs/shared/lib/util.js.map +1 -1
  87. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts +1 -1
  88. package/dist/cjs/shared/providers/CivicAuthConfigContext.d.ts.map +1 -1
  89. package/dist/cjs/shared/providers/CivicAuthConfigContext.js +3 -35
  90. package/dist/cjs/shared/providers/CivicAuthConfigContext.js.map +1 -1
  91. package/dist/cjs/shared/providers/IframeProvider.d.ts +1 -1
  92. package/dist/cjs/shared/providers/IframeProvider.d.ts.map +1 -1
  93. package/dist/cjs/shared/providers/IframeProvider.js +4 -36
  94. package/dist/cjs/shared/providers/IframeProvider.js.map +1 -1
  95. package/dist/cjs/shared/providers/SessionProvider.d.ts +1 -1
  96. package/dist/cjs/shared/providers/SessionProvider.d.ts.map +1 -1
  97. package/dist/cjs/shared/providers/SessionProvider.js +4 -36
  98. package/dist/cjs/shared/providers/SessionProvider.js.map +1 -1
  99. package/dist/cjs/shared/providers/TokenProvider.d.ts +1 -1
  100. package/dist/cjs/shared/providers/TokenProvider.d.ts.map +1 -1
  101. package/dist/cjs/shared/providers/TokenProvider.js +5 -40
  102. package/dist/cjs/shared/providers/TokenProvider.js.map +1 -1
  103. package/dist/cjs/shared/providers/UserProvider.d.ts +3 -3
  104. package/dist/cjs/shared/providers/UserProvider.d.ts.map +1 -1
  105. package/dist/cjs/shared/providers/UserProvider.js +4 -36
  106. package/dist/cjs/shared/providers/UserProvider.js.map +1 -1
  107. package/dist/cjs/shared/version.d.ts +1 -1
  108. package/dist/cjs/shared/version.js +1 -1
  109. package/dist/cjs/shared/version.js.map +1 -1
  110. package/dist/cjs/types.d.ts +4 -14
  111. package/dist/cjs/types.d.ts.map +1 -1
  112. package/dist/cjs/types.js +0 -1
  113. package/dist/cjs/types.js.map +1 -1
  114. package/dist/esm/constants.d.ts +2 -1
  115. package/dist/esm/constants.d.ts.map +1 -1
  116. package/dist/esm/constants.js +8 -1
  117. package/dist/esm/constants.js.map +1 -1
  118. package/dist/esm/nextjs/index.d.ts +2 -2
  119. package/dist/esm/nextjs/index.d.ts.map +1 -1
  120. package/dist/esm/nextjs/index.js.map +1 -1
  121. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts +1 -5
  122. package/dist/esm/nextjs/providers/NextAuthProvider.d.ts.map +1 -1
  123. package/dist/esm/nextjs/providers/NextAuthProvider.js +4 -11
  124. package/dist/esm/nextjs/providers/NextAuthProvider.js.map +1 -1
  125. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts +1 -1
  126. package/dist/esm/reactjs/components/ButtonContentOrLoader.d.ts.map +1 -1
  127. package/dist/esm/reactjs/components/ButtonContentOrLoader.js +16 -19
  128. package/dist/esm/reactjs/components/ButtonContentOrLoader.js.map +1 -1
  129. package/dist/esm/reactjs/components/SignInButton.d.ts +4 -3
  130. package/dist/esm/reactjs/components/SignInButton.d.ts.map +1 -1
  131. package/dist/esm/reactjs/components/SignInButton.js +5 -6
  132. package/dist/esm/reactjs/components/SignInButton.js.map +1 -1
  133. package/dist/esm/reactjs/components/SignOutButton.d.ts +4 -3
  134. package/dist/esm/reactjs/components/SignOutButton.d.ts.map +1 -1
  135. package/dist/esm/reactjs/components/SignOutButton.js +5 -5
  136. package/dist/esm/reactjs/components/SignOutButton.js.map +1 -1
  137. package/dist/esm/reactjs/components/UserButton.d.ts +6 -3
  138. package/dist/esm/reactjs/components/UserButton.d.ts.map +1 -1
  139. package/dist/esm/reactjs/components/UserButton.js +69 -76
  140. package/dist/esm/reactjs/components/UserButton.js.map +1 -1
  141. package/dist/esm/reactjs/providers/AuthProvider.d.ts +1 -2
  142. package/dist/esm/reactjs/providers/AuthProvider.d.ts.map +1 -1
  143. package/dist/esm/reactjs/providers/AuthProvider.js +2 -3
  144. package/dist/esm/reactjs/providers/AuthProvider.js.map +1 -1
  145. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts +1 -2
  146. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts.map +1 -1
  147. package/dist/esm/reactjs/providers/CivicAuthProvider.js +4 -9
  148. package/dist/esm/reactjs/providers/CivicAuthProvider.js.map +1 -1
  149. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +1 -1
  150. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -1
  151. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js +2 -1
  152. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -1
  153. package/dist/esm/shared/components/BlockDisplay.d.ts +1 -2
  154. package/dist/esm/shared/components/BlockDisplay.d.ts.map +1 -1
  155. package/dist/esm/shared/components/BlockDisplay.js +4 -4
  156. package/dist/esm/shared/components/BlockDisplay.js.map +1 -1
  157. package/dist/esm/shared/components/CivicAuthIframe.js +16 -17
  158. package/dist/esm/shared/components/CivicAuthIframe.js.map +1 -1
  159. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts +2 -2
  160. package/dist/esm/shared/components/CivicAuthIframeContainer.d.ts.map +1 -1
  161. package/dist/esm/shared/components/CivicAuthIframeContainer.js +28 -34
  162. package/dist/esm/shared/components/CivicAuthIframeContainer.js.map +1 -1
  163. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts +1 -2
  164. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.d.ts.map +1 -1
  165. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js +9 -11
  166. package/dist/esm/shared/components/CivicAuthLogoutIframeContainer.js.map +1 -1
  167. package/dist/esm/shared/components/CloseIcon.d.ts +1 -2
  168. package/dist/esm/shared/components/CloseIcon.d.ts.map +1 -1
  169. package/dist/esm/shared/components/CloseIcon.js +2 -3
  170. package/dist/esm/shared/components/CloseIcon.js.map +1 -1
  171. package/dist/esm/shared/components/IFrameAndLoading.d.ts +1 -2
  172. package/dist/esm/shared/components/IFrameAndLoading.d.ts.map +1 -1
  173. package/dist/esm/shared/components/IFrameAndLoading.js +4 -13
  174. package/dist/esm/shared/components/IFrameAndLoading.js.map +1 -1
  175. package/dist/esm/shared/components/LoadingIcon.d.ts +1 -2
  176. package/dist/esm/shared/components/LoadingIcon.d.ts.map +1 -1
  177. package/dist/esm/shared/components/LoadingIcon.js +19 -23
  178. package/dist/esm/shared/components/LoadingIcon.js.map +1 -1
  179. package/dist/esm/shared/components/SVGLoading.js +11 -20
  180. package/dist/esm/shared/components/SVGLoading.js.map +1 -1
  181. package/dist/esm/shared/lib/UserSession.d.ts +4 -2
  182. package/dist/esm/shared/lib/UserSession.d.ts.map +1 -1
  183. package/dist/esm/shared/lib/UserSession.js.map +1 -1
  184. package/dist/esm/shared/lib/session.d.ts +2 -2
  185. package/dist/esm/shared/lib/session.d.ts.map +1 -1
  186. package/dist/esm/shared/lib/session.js +11 -6
  187. package/dist/esm/shared/lib/session.js.map +1 -1
  188. package/dist/esm/shared/lib/types.d.ts +1 -0
  189. package/dist/esm/shared/lib/types.d.ts.map +1 -1
  190. package/dist/esm/shared/lib/types.js +1 -0
  191. package/dist/esm/shared/lib/types.js.map +1 -1
  192. package/dist/esm/shared/lib/util.d.ts.map +1 -1
  193. package/dist/esm/shared/lib/util.js +7 -6
  194. package/dist/esm/shared/lib/util.js.map +1 -1
  195. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts +1 -1
  196. package/dist/esm/shared/providers/CivicAuthConfigContext.d.ts.map +1 -1
  197. package/dist/esm/shared/providers/CivicAuthConfigContext.js +2 -1
  198. package/dist/esm/shared/providers/CivicAuthConfigContext.js.map +1 -1
  199. package/dist/esm/shared/providers/IframeProvider.d.ts +1 -1
  200. package/dist/esm/shared/providers/IframeProvider.d.ts.map +1 -1
  201. package/dist/esm/shared/providers/IframeProvider.js +3 -2
  202. package/dist/esm/shared/providers/IframeProvider.js.map +1 -1
  203. package/dist/esm/shared/providers/SessionProvider.d.ts +1 -1
  204. package/dist/esm/shared/providers/SessionProvider.d.ts.map +1 -1
  205. package/dist/esm/shared/providers/SessionProvider.js +3 -2
  206. package/dist/esm/shared/providers/SessionProvider.js.map +1 -1
  207. package/dist/esm/shared/providers/TokenProvider.d.ts +1 -1
  208. package/dist/esm/shared/providers/TokenProvider.d.ts.map +1 -1
  209. package/dist/esm/shared/providers/TokenProvider.js +4 -6
  210. package/dist/esm/shared/providers/TokenProvider.js.map +1 -1
  211. package/dist/esm/shared/providers/UserProvider.d.ts +3 -3
  212. package/dist/esm/shared/providers/UserProvider.d.ts.map +1 -1
  213. package/dist/esm/shared/providers/UserProvider.js +3 -2
  214. package/dist/esm/shared/providers/UserProvider.js.map +1 -1
  215. package/dist/esm/shared/version.d.ts +1 -1
  216. package/dist/esm/shared/version.js +1 -1
  217. package/dist/esm/shared/version.js.map +1 -1
  218. package/dist/esm/types.d.ts +4 -14
  219. package/dist/esm/types.d.ts.map +1 -1
  220. package/dist/esm/types.js +0 -1
  221. package/dist/esm/types.js.map +1 -1
  222. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  223. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  224. package/package.json +2 -1
  225. package/dist/cjs/reactjs/components/LoadingSpinner.d.ts +0 -7
  226. package/dist/cjs/reactjs/components/LoadingSpinner.d.ts.map +0 -1
  227. package/dist/cjs/reactjs/components/LoadingSpinner.js +0 -33
  228. package/dist/cjs/reactjs/components/LoadingSpinner.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/nextjs/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,YAAY,EAAE,CAAC;AACf,OAAO,EACL,SAAS,IAAI,gBAAgB,EAC7B,OAAO,IAAI,cAAc,GAC1B,MAAM,yBAAyB,CAAC;AAGjC,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAE9E,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,IAA0B,EAAE;IACtD,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,cAAc,CAAC,aAAa,CAAC,CAAC;AACvC,CAAC,CAAC;AACF,MAAM,CAAC,MAAM,SAAS,GAAG,KAAK,IAAiC,EAAE;IAC/D,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,gBAAgB,CAAC,aAAa,CAAC,CAAC;AACzC,CAAC,CAAC;AACF,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAM1D,OAAO,EACL,qBAAqB,IAAI,iBAAiB,GAE3C,MAAM,wCAAwC,CAAC","sourcesContent":["import { NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nimport { printVersion } from \"@/shared/index.js\";\nprintVersion();\nimport {\n getTokens as getSessionTokens,\n getUser as getSessionUser,\n} from \"@/shared/lib/session.js\";\nimport type { OAuthTokens, User } from \"@/types.js\";\n\nexport { createCivicAuthPlugin, defaultAuthConfig } from \"@/nextjs/config.js\";\n\nexport const getUser = async (): Promise<User | null> => {\n const clientStorage = new NextjsCookieStorage();\n return getSessionUser(clientStorage);\n};\nexport const getTokens = async (): Promise<OAuthTokens | null> => {\n const clientStorage = new NextjsCookieStorage();\n return getSessionTokens(clientStorage);\n};\nexport { handler } from \"@/nextjs/routeHandler.js\";\nexport { NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nexport type {\n AuthConfig,\n CookiesConfigObject,\n AuthConfigWithDefaults,\n} from \"@/nextjs/config.js\";\nexport {\n CivicNextAuthProvider as CivicAuthProvider,\n type NextCivicAuthProviderProps as AuthProviderProps,\n} from \"@/nextjs/providers/NextAuthProvider.js\";\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/nextjs/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,YAAY,EAAE,CAAC;AACf,OAAO,EACL,SAAS,IAAI,gBAAgB,EAC7B,OAAO,IAAI,cAAc,GAC1B,MAAM,yBAAyB,CAAC;AAGjC,OAAO,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAE9E,MAAM,CAAC,MAAM,OAAO,GAAG,KAAK,IAEC,EAAE;IAC7B,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,cAAc,CAAI,aAAa,CAAC,CAAC;AAC1C,CAAC,CAAC;AACF,MAAM,CAAC,MAAM,SAAS,GAAG,KAAK,IAAiC,EAAE;IAC/D,MAAM,aAAa,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAChD,OAAO,gBAAgB,CAAC,aAAa,CAAC,CAAC;AACzC,CAAC,CAAC;AACF,OAAO,EAAE,OAAO,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAM1D,OAAO,EACL,qBAAqB,IAAI,iBAAiB,GAE3C,MAAM,wCAAwC,CAAC","sourcesContent":["import { NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nimport { printVersion } from \"@/shared/index.js\";\nprintVersion();\nimport {\n getTokens as getSessionTokens,\n getUser as getSessionUser,\n} from \"@/shared/lib/session.js\";\nimport type { EmptyObject, OAuthTokens, UnknownObject, User } from \"@/types.js\";\n\nexport { createCivicAuthPlugin, defaultAuthConfig } from \"@/nextjs/config.js\";\n\nexport const getUser = async <\n T extends UnknownObject = EmptyObject,\n>(): Promise<User<T> | null> => {\n const clientStorage = new NextjsCookieStorage();\n return getSessionUser<T>(clientStorage);\n};\nexport const getTokens = async (): Promise<OAuthTokens | null> => {\n const clientStorage = new NextjsCookieStorage();\n return getSessionTokens(clientStorage);\n};\nexport { handler } from \"@/nextjs/routeHandler.js\";\nexport { NextjsCookieStorage } from \"@/nextjs/cookies.js\";\nexport type {\n AuthConfig,\n CookiesConfigObject,\n AuthConfigWithDefaults,\n} from \"@/nextjs/config.js\";\nexport {\n CivicNextAuthProvider as CivicAuthProvider,\n type NextCivicAuthProviderProps as AuthProviderProps,\n} from \"@/nextjs/providers/NextAuthProvider.js\";\n"]}
@@ -1,13 +1,9 @@
1
- /**
2
- * A very small context provider for the user object - it takes the user object from the cookie and provides it to the app.
3
- */
4
- import React from "react";
5
1
  import { type AuthConfigWithDefaults } from "../../nextjs/config.js";
6
2
  import type { AuthProviderProps } from "../../shared/providers/types.js";
7
3
  type NextCivicAuthProviderInternalProps = Omit<AuthProviderProps, "clientId"> & {
8
4
  resolvedConfig: AuthConfigWithDefaults;
9
5
  };
10
6
  type NextCivicAuthProviderProps = Omit<NextCivicAuthProviderInternalProps, "clientId" | "resolvedConfig" | "redirectUrl">;
11
- declare const CivicNextAuthProvider: ({ children, ...props }: NextCivicAuthProviderProps) => React.JSX.Element;
7
+ declare const CivicNextAuthProvider: ({ children, ...props }: NextCivicAuthProviderProps) => import("@emotion/react/jsx-runtime").JSX.Element;
12
8
  export { CivicNextAuthProvider, type NextCivicAuthProviderProps };
13
9
  //# sourceMappingURL=NextAuthProvider.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"NextAuthProvider.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"AACA;;GAEG;AACH,OAAO,KAA2C,MAAM,OAAO,CAAC;AAChE,OAAO,EAEL,KAAK,sBAAsB,EAC5B,MAAM,oBAAoB,CAAC;AAe5B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAcrE,KAAK,kCAAkC,GAAG,IAAI,CAC5C,iBAAiB,EACjB,UAAU,CACX,GAAG;IACF,cAAc,EAAE,sBAAsB,CAAC;CACxC,CAAC;AACF,KAAK,0BAA0B,GAAG,IAAI,CACpC,kCAAkC,EAClC,UAAU,GAAG,gBAAgB,GAAG,aAAa,CAC9C,CAAC;AAoHF,QAAA,MAAM,qBAAqB,2BAGxB,0BAA0B,sBA0C5B,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,KAAK,0BAA0B,EAAE,CAAC"}
1
+ {"version":3,"file":"NextAuthProvider.d.ts","sourceRoot":"","sources":["../../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"AAKA,OAAO,EAEL,KAAK,sBAAsB,EAC5B,MAAM,oBAAoB,CAAC;AAe5B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAcrE,KAAK,kCAAkC,GAAG,IAAI,CAC5C,iBAAiB,EACjB,UAAU,CACX,GAAG;IACF,cAAc,EAAE,sBAAsB,CAAC;CACxC,CAAC;AACF,KAAK,0BAA0B,GAAG,IAAI,CACpC,kCAAkC,EAClC,UAAU,GAAG,gBAAgB,GAAG,aAAa,CAC9C,CAAC;AAoHF,QAAA,MAAM,qBAAqB,2BAGxB,0BAA0B,qDA0C5B,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,KAAK,0BAA0B,EAAE,CAAC"}
@@ -1,4 +1,5 @@
1
1
  "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
2
3
  /**
3
4
  * A very small context provider for the user object - it takes the user object from the cookie and provides it to the app.
4
5
  */
@@ -68,12 +69,7 @@ const CivicNextAuthTokenProviderInternal = ({ children, isLoading, displayMode =
68
69
  startSignIn,
69
70
  displayMode,
70
71
  ]);
71
- return (React.createElement(TokenProvider, null,
72
- React.createElement(UserProvider, { storage: new BrowserCookieStorage(), user: user, signOut: signOut, signIn: signIn, displayMode: displayMode, authStatus: authStatus },
73
- React.createElement(IFrameAndLoading, { error: null, isLoading: isLoading }),
74
- isLoading && (React.createElement(BlockDisplay, null,
75
- React.createElement(LoadingIcon, null))),
76
- children)));
72
+ return (_jsx(TokenProvider, { children: _jsxs(UserProvider, { storage: new BrowserCookieStorage(), user: user, signOut: signOut, signIn: signIn, displayMode: displayMode, authStatus: authStatus, children: [_jsx(IFrameAndLoading, { error: null, isLoading: isLoading }), isLoading && (_jsx(BlockDisplay, { children: _jsx(LoadingIcon, {}) })), children] }) }));
77
73
  };
78
74
  const CivicNextAuthProviderInternal = ({ children, ...props }) => {
79
75
  // if the SDK loads in an iframe, we show the loading spinner as the iframe
@@ -85,8 +81,7 @@ const CivicNextAuthProviderInternal = ({ children, ...props }) => {
85
81
  idToken,
86
82
  };
87
83
  useRefresh(session);
88
- return (React.createElement(SessionProvider, { data: session, isLoading: isLoading },
89
- React.createElement(CivicNextAuthTokenProviderInternal, { ...props, user: user, idToken: idToken, fetchUser: fetchUser, isLoading: isLoading }, children)));
84
+ return (_jsx(SessionProvider, { data: session, isLoading: isLoading, children: _jsx(CivicNextAuthTokenProviderInternal, { ...props, user: user, idToken: idToken, fetchUser: fetchUser, isLoading: isLoading, children: children }) }));
90
85
  };
91
86
  const CivicNextAuthProvider = ({ children, ...props }) => {
92
87
  const resolvedConfig = resolveAuthConfig();
@@ -98,9 +93,7 @@ const CivicNextAuthProvider = ({ children, ...props }) => {
98
93
  setRedirectUrl(resolveCallbackUrl(resolvedConfig, appUrl));
99
94
  }
100
95
  }, [callbackUrl, resolvedConfig]);
101
- return (React.createElement(CivicAuthConfigProvider, { oauthServer: oauthServer, clientId: clientId, redirectUrl: redirectUrl, logoutRedirectUrl: logoutCallbackUrl, nonce: props?.nonce, challengeUrl: challengeUrl, refreshUrl: refreshUrl, logoutUrl: logoutUrl, logoutCallbackUrl: logoutCallbackUrl },
102
- React.createElement(IframeProvider, { iframeMode: props.iframeMode },
103
- React.createElement(CivicNextAuthProviderInternal, { ...props, resolvedConfig: resolvedConfig }, children))));
96
+ return (_jsx(CivicAuthConfigProvider, { oauthServer: oauthServer, clientId: clientId, redirectUrl: redirectUrl, logoutRedirectUrl: logoutCallbackUrl, nonce: props?.nonce, challengeUrl: challengeUrl, refreshUrl: refreshUrl, logoutUrl: logoutUrl, logoutCallbackUrl: logoutCallbackUrl, children: _jsx(IframeProvider, { iframeMode: props.iframeMode, children: _jsx(CivicNextAuthProviderInternal, { ...props, resolvedConfig: resolvedConfig, children: children }) }) }));
104
97
  };
105
98
  export { CivicNextAuthProvider };
106
99
  //# sourceMappingURL=NextAuthProvider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"NextAuthProvider.js","sourceRoot":"","sources":["../../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\n/**\n * A very small context provider for the user object - it takes the user object from the cookie and provides it to the app.\n */\nimport React, { useCallback, useEffect, useState } from \"react\";\nimport {\n resolveAuthConfig,\n type AuthConfigWithDefaults,\n} from \"@/nextjs/config.js\";\nimport { resolveCallbackUrl } from \"@/nextjs/utils.js\";\nimport { ConfidentialClientPKCEConsumer } from \"@/services/PKCE.js\";\nimport { UserProvider } from \"@/shared/providers/UserProvider.js\";\nimport { useUserCookie } from \"@/nextjs/hooks/useUserCookie.js\";\nimport { CivicAuthConfigProvider } from \"@/shared/providers/CivicAuthConfigContext.js\";\nimport { SessionProvider } from \"@/shared/providers/SessionProvider.js\";\nimport { IframeProvider } from \"@/shared/providers/IframeProvider.js\";\nimport { TokenProvider } from \"@/shared/providers/TokenProvider.js\";\nimport { useSignIn } from \"@/shared/hooks/useSignIn.js\";\nimport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nimport { IFrameAndLoading } from \"@/shared/components/IFrameAndLoading.js\";\nimport { BlockDisplay } from \"@/shared/components/BlockDisplay.js\";\nimport { LoadingIcon } from \"@/shared/components/LoadingIcon.js\";\nimport { useIframe } from \"@/shared/hooks/useIframe.js\";\nimport type { AuthProviderProps } from \"@/shared/providers/types.js\";\nimport { useIsInIframe } from \"@/shared/hooks/useIsInIframe.js\";\nimport { AuthStatus, type UnknownObject, type User } from \"@/types.js\";\nimport { useRefresh } from \"@/nextjs/hooks/useRefresh.js\";\nimport { useCurrentUrl, useSession } from \"@/shared/hooks/index.js\";\nimport { BrowserCookieStorage } from \"@/shared/index.js\";\n\ntype CivicNextAuthTokenProviderInternalProps<TUser extends UnknownObject> =\n NextCivicAuthProviderInternalProps & {\n isLoading: boolean;\n idToken?: string;\n user: User<TUser> | null;\n fetchUser: () => Promise<void>;\n };\ntype NextCivicAuthProviderInternalProps = Omit<\n AuthProviderProps,\n \"clientId\"\n> & {\n resolvedConfig: AuthConfigWithDefaults;\n};\ntype NextCivicAuthProviderProps = Omit<\n NextCivicAuthProviderInternalProps,\n \"clientId\" | \"resolvedConfig\" | \"redirectUrl\"\n>;\n\nconst CivicNextAuthTokenProviderInternal = <\n TUser extends UnknownObject = UnknownObject,\n>({\n children,\n isLoading,\n displayMode = \"iframe\",\n user,\n fetchUser,\n ...props\n}: CivicNextAuthTokenProviderInternalProps<TUser>) => {\n const { iframeMode, resolvedConfig } = props;\n const { iframeRef, setIframeIsVisible } = useIframe();\n const civicAuthConfig = useCivicAuthConfig();\n const { challengeUrl } = resolvedConfig;\n const pkceConsumer = new ConfidentialClientPKCEConsumer(challengeUrl);\n const { data: session } = useSession();\n const currentUrl = useCurrentUrl();\n\n useEffect(() => {\n if (session?.authenticated) {\n // the session is authenticated, so don't show the login iframe\n setIframeIsVisible(false);\n return;\n }\n }, [session?.authenticated, setIframeIsVisible]);\n\n const postSignOut = useCallback(async () => {\n // user is signed out, manually update the user from cookies to not wait for polling\n await fetchUser();\n await props?.onSignOut?.();\n }, [fetchUser, props]);\n\n const { signIn, startSignIn, signOut, authStatus } = useSignIn({\n postSignOut,\n pkceConsumer,\n displayMode,\n });\n\n useEffect(() => {\n if (\n civicAuthConfig &&\n !session?.authenticated &&\n iframeRef?.current &&\n authStatus === AuthStatus.UNAUTHENTICATED &&\n displayMode === \"iframe\" &&\n !currentUrl?.includes(\"code=\")\n ) {\n startSignIn();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n currentUrl,\n iframeMode,\n iframeRef,\n civicAuthConfig,\n session?.authenticated,\n authStatus,\n startSignIn,\n displayMode,\n ]);\n\n return (\n <TokenProvider>\n <UserProvider\n storage={new BrowserCookieStorage()}\n user={user}\n signOut={signOut}\n signIn={signIn}\n displayMode={displayMode}\n authStatus={authStatus}\n >\n <IFrameAndLoading error={null} isLoading={isLoading} />\n {isLoading && (\n <BlockDisplay>\n <LoadingIcon />\n </BlockDisplay>\n )}\n {children}\n </UserProvider>\n </TokenProvider>\n );\n};\n\nconst CivicNextAuthProviderInternal = ({\n children,\n ...props\n}: NextCivicAuthProviderInternalProps) => {\n // if the SDK loads in an iframe, we show the loading spinner as the iframe\n // will be waiting to be minimized\n const isLoading = useIsInIframe();\n const { user, idToken, fetchUser } = useUserCookie();\n\n const session = {\n authenticated: !!user,\n idToken,\n };\n\n useRefresh(session);\n\n return (\n <SessionProvider data={session} isLoading={isLoading}>\n <CivicNextAuthTokenProviderInternal\n {...props}\n user={user}\n idToken={idToken}\n fetchUser={fetchUser}\n isLoading={isLoading}\n >\n {children}\n </CivicNextAuthTokenProviderInternal>\n </SessionProvider>\n );\n};\n\nconst CivicNextAuthProvider = ({\n children,\n ...props\n}: NextCivicAuthProviderProps) => {\n const resolvedConfig = resolveAuthConfig();\n const {\n clientId,\n oauthServer,\n callbackUrl,\n challengeUrl,\n logoutUrl,\n refreshUrl,\n logoutCallbackUrl,\n } = resolvedConfig;\n const [redirectUrl, setRedirectUrl] = useState<string>(\"\");\n\n useEffect(() => {\n if (typeof globalThis.window !== \"undefined\") {\n const appUrl = globalThis.window.location.origin;\n setRedirectUrl(resolveCallbackUrl(resolvedConfig, appUrl));\n }\n }, [callbackUrl, resolvedConfig]);\n\n return (\n <CivicAuthConfigProvider\n oauthServer={oauthServer}\n clientId={clientId}\n redirectUrl={redirectUrl}\n logoutRedirectUrl={logoutCallbackUrl}\n nonce={props?.nonce}\n challengeUrl={challengeUrl}\n refreshUrl={refreshUrl}\n logoutUrl={logoutUrl}\n logoutCallbackUrl={logoutCallbackUrl}\n >\n <IframeProvider iframeMode={props.iframeMode}>\n <CivicNextAuthProviderInternal\n {...props}\n resolvedConfig={resolvedConfig}\n >\n {children}\n </CivicNextAuthProviderInternal>\n </IframeProvider>\n </CivicAuthConfigProvider>\n );\n};\n\nexport { CivicNextAuthProvider, type NextCivicAuthProviderProps };\n"]}
1
+ {"version":3,"file":"NextAuthProvider.js","sourceRoot":"","sources":["../../../../src/nextjs/providers/NextAuthProvider.tsx"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\n/**\n * A very small context provider for the user object - it takes the user object from the cookie and provides it to the app.\n */\nimport React, { useCallback, useEffect, useState } from \"react\";\nimport {\n resolveAuthConfig,\n type AuthConfigWithDefaults,\n} from \"@/nextjs/config.js\";\nimport { resolveCallbackUrl } from \"@/nextjs/utils.js\";\nimport { ConfidentialClientPKCEConsumer } from \"@/services/PKCE.js\";\nimport { UserProvider } from \"@/shared/providers/UserProvider.js\";\nimport { useUserCookie } from \"@/nextjs/hooks/useUserCookie.js\";\nimport { CivicAuthConfigProvider } from \"@/shared/providers/CivicAuthConfigContext.js\";\nimport { SessionProvider } from \"@/shared/providers/SessionProvider.js\";\nimport { IframeProvider } from \"@/shared/providers/IframeProvider.js\";\nimport { TokenProvider } from \"@/shared/providers/TokenProvider.js\";\nimport { useSignIn } from \"@/shared/hooks/useSignIn.js\";\nimport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nimport { IFrameAndLoading } from \"@/shared/components/IFrameAndLoading.js\";\nimport { BlockDisplay } from \"@/shared/components/BlockDisplay.js\";\nimport { LoadingIcon } from \"@/shared/components/LoadingIcon.js\";\nimport { useIframe } from \"@/shared/hooks/useIframe.js\";\nimport type { AuthProviderProps } from \"@/shared/providers/types.js\";\nimport { useIsInIframe } from \"@/shared/hooks/useIsInIframe.js\";\nimport { AuthStatus, type UnknownObject, type User } from \"@/types.js\";\nimport { useRefresh } from \"@/nextjs/hooks/useRefresh.js\";\nimport { useCurrentUrl, useSession } from \"@/shared/hooks/index.js\";\nimport { BrowserCookieStorage } from \"@/shared/index.js\";\n\ntype CivicNextAuthTokenProviderInternalProps<TUser extends UnknownObject> =\n NextCivicAuthProviderInternalProps & {\n isLoading: boolean;\n idToken?: string;\n user: User<TUser> | null;\n fetchUser: () => Promise<void>;\n };\ntype NextCivicAuthProviderInternalProps = Omit<\n AuthProviderProps,\n \"clientId\"\n> & {\n resolvedConfig: AuthConfigWithDefaults;\n};\ntype NextCivicAuthProviderProps = Omit<\n NextCivicAuthProviderInternalProps,\n \"clientId\" | \"resolvedConfig\" | \"redirectUrl\"\n>;\n\nconst CivicNextAuthTokenProviderInternal = <\n TUser extends UnknownObject = UnknownObject,\n>({\n children,\n isLoading,\n displayMode = \"iframe\",\n user,\n fetchUser,\n ...props\n}: CivicNextAuthTokenProviderInternalProps<TUser>) => {\n const { iframeMode, resolvedConfig } = props;\n const { iframeRef, setIframeIsVisible } = useIframe();\n const civicAuthConfig = useCivicAuthConfig();\n const { challengeUrl } = resolvedConfig;\n const pkceConsumer = new ConfidentialClientPKCEConsumer(challengeUrl);\n const { data: session } = useSession();\n const currentUrl = useCurrentUrl();\n\n useEffect(() => {\n if (session?.authenticated) {\n // the session is authenticated, so don't show the login iframe\n setIframeIsVisible(false);\n return;\n }\n }, [session?.authenticated, setIframeIsVisible]);\n\n const postSignOut = useCallback(async () => {\n // user is signed out, manually update the user from cookies to not wait for polling\n await fetchUser();\n await props?.onSignOut?.();\n }, [fetchUser, props]);\n\n const { signIn, startSignIn, signOut, authStatus } = useSignIn({\n postSignOut,\n pkceConsumer,\n displayMode,\n });\n\n useEffect(() => {\n if (\n civicAuthConfig &&\n !session?.authenticated &&\n iframeRef?.current &&\n authStatus === AuthStatus.UNAUTHENTICATED &&\n displayMode === \"iframe\" &&\n !currentUrl?.includes(\"code=\")\n ) {\n startSignIn();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [\n currentUrl,\n iframeMode,\n iframeRef,\n civicAuthConfig,\n session?.authenticated,\n authStatus,\n startSignIn,\n displayMode,\n ]);\n\n return (\n <TokenProvider>\n <UserProvider\n storage={new BrowserCookieStorage()}\n user={user}\n signOut={signOut}\n signIn={signIn}\n displayMode={displayMode}\n authStatus={authStatus}\n >\n <IFrameAndLoading error={null} isLoading={isLoading} />\n {isLoading && (\n <BlockDisplay>\n <LoadingIcon />\n </BlockDisplay>\n )}\n {children}\n </UserProvider>\n </TokenProvider>\n );\n};\n\nconst CivicNextAuthProviderInternal = ({\n children,\n ...props\n}: NextCivicAuthProviderInternalProps) => {\n // if the SDK loads in an iframe, we show the loading spinner as the iframe\n // will be waiting to be minimized\n const isLoading = useIsInIframe();\n const { user, idToken, fetchUser } = useUserCookie();\n\n const session = {\n authenticated: !!user,\n idToken,\n };\n\n useRefresh(session);\n\n return (\n <SessionProvider data={session} isLoading={isLoading}>\n <CivicNextAuthTokenProviderInternal\n {...props}\n user={user}\n idToken={idToken}\n fetchUser={fetchUser}\n isLoading={isLoading}\n >\n {children}\n </CivicNextAuthTokenProviderInternal>\n </SessionProvider>\n );\n};\n\nconst CivicNextAuthProvider = ({\n children,\n ...props\n}: NextCivicAuthProviderProps) => {\n const resolvedConfig = resolveAuthConfig();\n const {\n clientId,\n oauthServer,\n callbackUrl,\n challengeUrl,\n logoutUrl,\n refreshUrl,\n logoutCallbackUrl,\n } = resolvedConfig;\n const [redirectUrl, setRedirectUrl] = useState<string>(\"\");\n\n useEffect(() => {\n if (typeof globalThis.window !== \"undefined\") {\n const appUrl = globalThis.window.location.origin;\n setRedirectUrl(resolveCallbackUrl(resolvedConfig, appUrl));\n }\n }, [callbackUrl, resolvedConfig]);\n\n return (\n <CivicAuthConfigProvider\n oauthServer={oauthServer}\n clientId={clientId}\n redirectUrl={redirectUrl}\n logoutRedirectUrl={logoutCallbackUrl}\n nonce={props?.nonce}\n challengeUrl={challengeUrl}\n refreshUrl={refreshUrl}\n logoutUrl={logoutUrl}\n logoutCallbackUrl={logoutCallbackUrl}\n >\n <IframeProvider iframeMode={props.iframeMode}>\n <CivicNextAuthProviderInternal\n {...props}\n resolvedConfig={resolvedConfig}\n >\n {children}\n </CivicNextAuthProviderInternal>\n </IframeProvider>\n </CivicAuthConfigProvider>\n );\n};\n\nexport { CivicNextAuthProvider, type NextCivicAuthProviderProps };\n"]}
@@ -5,5 +5,5 @@ export declare const ButtonContentOrLoader: ({ authStatus, displayMode, iframeIs
5
5
  displayMode: DisplayMode;
6
6
  iframeIsVisible?: boolean;
7
7
  children: React.ReactNode;
8
- }) => React.JSX.Element;
8
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
9
9
  //# sourceMappingURL=ButtonContentOrLoader.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ButtonContentOrLoader.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/ButtonContentOrLoader.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAG1D,eAAO,MAAM,qBAAqB,4DAK/B;IACD,UAAU,EAAE,UAAU,CAAC;IACvB,WAAW,EAAE,WAAW,CAAC;IACzB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,sBAsCA,CAAC"}
1
+ {"version":3,"file":"ButtonContentOrLoader.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/ButtonContentOrLoader.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAG1D,eAAO,MAAM,qBAAqB,4DAK/B;IACD,UAAU,EAAE,UAAU,CAAC;IACvB,WAAW,EAAE,WAAW,CAAC;IACzB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,qDAsCA,CAAC"}
@@ -1,30 +1,27 @@
1
1
  "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
2
3
  import React from "react";
3
4
  import { LoadingIcon } from "../../shared/components/LoadingIcon.js";
4
5
  import { shouldShowLoader } from "./utils.js";
5
6
  export const ButtonContentOrLoader = ({ authStatus, displayMode, iframeIsVisible, children, }) => {
6
- return (React.createElement("div", { style: {
7
+ const showLoader = shouldShowLoader(authStatus, displayMode, iframeIsVisible);
8
+ return (_jsxs("div", { css: {
7
9
  position: "relative",
8
10
  display: "flex",
9
11
  alignItems: "center",
10
12
  justifyContent: "center",
11
- } },
12
- React.createElement("span", { style: {
13
- visibility: shouldShowLoader(authStatus, displayMode, iframeIsVisible)
14
- ? "hidden"
15
- : "visible",
16
- whiteSpace: "nowrap",
17
- } }, children),
18
- shouldShowLoader(authStatus, displayMode, iframeIsVisible) && (React.createElement("span", { style: {
19
- position: "absolute",
20
- display: "flex",
21
- justifyContent: "center",
22
- alignItems: "center",
23
- top: 0,
24
- left: 0,
25
- right: 0,
26
- bottom: 0,
27
- } },
28
- React.createElement(LoadingIcon, { width: "1.5em", height: "1.5em" })))));
13
+ }, children: [_jsx("span", { css: {
14
+ visibility: showLoader ? "hidden" : "visible",
15
+ whiteSpace: "nowrap",
16
+ }, children: children }), showLoader ? (_jsx("span", { css: {
17
+ position: "absolute",
18
+ display: "flex",
19
+ justifyContent: "center",
20
+ alignItems: "center",
21
+ top: 0,
22
+ left: 0,
23
+ right: 0,
24
+ bottom: 0,
25
+ }, children: _jsx(LoadingIcon, { width: "1.5em", height: "1.5em" }) })) : null] }));
29
26
  };
30
27
  //# sourceMappingURL=ButtonContentOrLoader.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ButtonContentOrLoader.js","sourceRoot":"","sources":["../../../../src/reactjs/components/ButtonContentOrLoader.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAC;AAEjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE9C,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,EACpC,UAAU,EACV,WAAW,EACX,eAAe,EACf,QAAQ,GAMT,EAAE,EAAE;IACH,OAAO,CACL,6BACE,KAAK,EAAE;YACL,QAAQ,EAAE,UAAU;YACpB,OAAO,EAAE,MAAM;YACf,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;SACzB;QAED,8BACE,KAAK,EAAE;gBACL,UAAU,EAAE,gBAAgB,CAAC,UAAU,EAAE,WAAW,EAAE,eAAe,CAAC;oBACpE,CAAC,CAAC,QAAQ;oBACV,CAAC,CAAC,SAAS;gBACb,UAAU,EAAE,QAAQ;aACrB,IAEA,QAAQ,CACJ;QACN,gBAAgB,CAAC,UAAU,EAAE,WAAW,EAAE,eAAe,CAAC,IAAI,CAC7D,8BACE,KAAK,EAAE;gBACL,QAAQ,EAAE,UAAU;gBACpB,OAAO,EAAE,MAAM;gBACf,cAAc,EAAE,QAAQ;gBACxB,UAAU,EAAE,QAAQ;gBACpB,GAAG,EAAE,CAAC;gBACN,IAAI,EAAE,CAAC;gBACP,KAAK,EAAE,CAAC;gBACR,MAAM,EAAE,CAAC;aACV;YAED,oBAAC,WAAW,IAAC,KAAK,EAAC,OAAO,EAAC,MAAM,EAAC,OAAO,GAAG,CACvC,CACR,CACG,CACP,CAAC;AACJ,CAAC,CAAC","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport { LoadingIcon } from \"@/shared/components/LoadingIcon.js\";\nimport type { AuthStatus, DisplayMode } from \"@/types.js\";\nimport { shouldShowLoader } from \"./utils.js\";\n\nexport const ButtonContentOrLoader = ({\n authStatus,\n displayMode,\n iframeIsVisible,\n children,\n}: {\n authStatus: AuthStatus;\n displayMode: DisplayMode;\n iframeIsVisible?: boolean;\n children: React.ReactNode;\n}) => {\n return (\n <div\n style={{\n position: \"relative\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n }}\n >\n <span\n style={{\n visibility: shouldShowLoader(authStatus, displayMode, iframeIsVisible)\n ? \"hidden\"\n : \"visible\",\n whiteSpace: \"nowrap\",\n }}\n >\n {children}\n </span>\n {shouldShowLoader(authStatus, displayMode, iframeIsVisible) && (\n <span\n style={{\n position: \"absolute\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n }}\n >\n <LoadingIcon width=\"1.5em\" height=\"1.5em\" />\n </span>\n )}\n </div>\n );\n};\n"]}
1
+ {"version":3,"file":"ButtonContentOrLoader.js","sourceRoot":"","sources":["../../../../src/reactjs/components/ButtonContentOrLoader.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AACb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAC;AAEjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE9C,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,EACpC,UAAU,EACV,WAAW,EACX,eAAe,EACf,QAAQ,GAMT,EAAE,EAAE;IACH,MAAM,UAAU,GAAG,gBAAgB,CAAC,UAAU,EAAE,WAAW,EAAE,eAAe,CAAC,CAAC;IAE9E,OAAO,CACL,eACE,GAAG,EAAE;YACH,QAAQ,EAAE,UAAU;YACpB,OAAO,EAAE,MAAM;YACf,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;SACzB,aAED,eACE,GAAG,EAAE;oBACH,UAAU,EAAE,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS;oBAC7C,UAAU,EAAE,QAAQ;iBACrB,YAEA,QAAQ,GACJ,EACN,UAAU,CAAC,CAAC,CAAC,CACZ,eACE,GAAG,EAAE;oBACH,QAAQ,EAAE,UAAU;oBACpB,OAAO,EAAE,MAAM;oBACf,cAAc,EAAE,QAAQ;oBACxB,UAAU,EAAE,QAAQ;oBACpB,GAAG,EAAE,CAAC;oBACN,IAAI,EAAE,CAAC;oBACP,KAAK,EAAE,CAAC;oBACR,MAAM,EAAE,CAAC;iBACV,YAED,KAAC,WAAW,IAAC,KAAK,EAAC,OAAO,EAAC,MAAM,EAAC,OAAO,GAAG,GACvC,CACR,CAAC,CAAC,CAAC,IAAI,IACJ,CACP,CAAC;AACJ,CAAC,CAAC","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport { LoadingIcon } from \"@/shared/components/LoadingIcon.js\";\nimport type { AuthStatus, DisplayMode } from \"@/types.js\";\nimport { shouldShowLoader } from \"./utils.js\";\n\nexport const ButtonContentOrLoader = ({\n authStatus,\n displayMode,\n iframeIsVisible,\n children,\n}: {\n authStatus: AuthStatus;\n displayMode: DisplayMode;\n iframeIsVisible?: boolean;\n children: React.ReactNode;\n}) => {\n const showLoader = shouldShowLoader(authStatus, displayMode, iframeIsVisible);\n\n return (\n <div\n css={{\n position: \"relative\",\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"center\",\n }}\n >\n <span\n css={{\n visibility: showLoader ? \"hidden\" : \"visible\",\n whiteSpace: \"nowrap\",\n }}\n >\n {children}\n </span>\n {showLoader ? (\n <span\n css={{\n position: \"absolute\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n }}\n >\n <LoadingIcon width=\"1.5em\" height=\"1.5em\" />\n </span>\n ) : null}\n </div>\n );\n};\n"]}
@@ -1,8 +1,9 @@
1
- import React from "react";
1
+ import type { CSSProperties } from "react";
2
2
  import type { DisplayMode } from "../../types.js";
3
- declare const SignInButton: ({ displayMode, className, }: {
3
+ declare const SignInButton: ({ displayMode, className, style, }: {
4
4
  displayMode?: DisplayMode;
5
5
  className?: string;
6
- }) => React.JSX.Element;
6
+ style?: CSSProperties;
7
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
7
8
  export { SignInButton };
8
9
  //# sourceMappingURL=SignInButton.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"SignInButton.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/SignInButton.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAK9C,QAAA,MAAM,YAAY,gCAGf;IACD,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,sBA0BA,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
1
+ {"version":3,"file":"SignInButton.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/SignInButton.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAC3C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAK9C,QAAA,MAAM,YAAY,uCAIf;IACD,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB,qDA2BA,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -1,19 +1,18 @@
1
1
  "use client";
2
- import React from "react";
2
+ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
3
3
  import { useUser } from "../../reactjs/hooks/useUser.js";
4
- import { ButtonContentOrLoader } from "./ButtonContentOrLoader.js";
5
4
  import { useIframe } from "../../shared/hooks/useIframe.js";
6
- const SignInButton = ({ displayMode, className, }) => {
5
+ import { ButtonContentOrLoader } from "./ButtonContentOrLoader.js";
6
+ const SignInButton = ({ displayMode, className, style, }) => {
7
7
  const { iframeIsVisible } = useIframe();
8
8
  const { signIn, authStatus, displayMode: userDisplayMode } = useUser();
9
- return (React.createElement("button", { "data-testid": "sign-in-button", style: {
9
+ return (_jsx("button", { "data-testid": "sign-in-button", css: {
10
10
  borderRadius: "9999px",
11
11
  border: "1px solid #6b7280",
12
12
  padding: "0.75rem 1rem",
13
13
  transition: "background-color 0.2s",
14
14
  minWidth: "9em", // this stops the button from going too small when in loading mode
15
- }, className: className, onClick: () => signIn(displayMode) },
16
- React.createElement(ButtonContentOrLoader, { authStatus: authStatus, displayMode: displayMode || userDisplayMode, iframeIsVisible: iframeIsVisible }, "Sign In")));
15
+ }, className: className, style: style, onClick: () => signIn(displayMode), children: _jsx(ButtonContentOrLoader, { authStatus: authStatus, displayMode: displayMode || userDisplayMode, iframeIsVisible: iframeIsVisible, children: "Sign In" }) }));
17
16
  };
18
17
  export { SignInButton };
19
18
  //# sourceMappingURL=SignInButton.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SignInButton.js","sourceRoot":"","sources":["../../../../src/reactjs/components/SignInButton.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAExD,MAAM,YAAY,GAAG,CAAC,EACpB,WAAW,EACX,SAAS,GAIV,EAAE,EAAE;IACH,MAAM,EAAE,eAAe,EAAE,GAAG,SAAS,EAAE,CAAC;IACxC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,OAAO,EAAE,CAAC;IAEvE,OAAO,CACL,+CACc,gBAAgB,EAC5B,KAAK,EAAE;YACL,YAAY,EAAE,QAAQ;YACtB,MAAM,EAAE,mBAAmB;YAC3B,OAAO,EAAE,cAAc;YACvB,UAAU,EAAE,uBAAuB;YACnC,QAAQ,EAAE,KAAK,EAAE,kEAAkE;SACpF,EACD,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC;QAElC,oBAAC,qBAAqB,IACpB,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,IAAI,eAAe,EAC3C,eAAe,EAAE,eAAe,cAGV,CACjB,CACV,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport type { DisplayMode } from \"@/types.js\";\nimport { useUser } from \"@/reactjs/hooks/useUser.js\";\nimport { ButtonContentOrLoader } from \"./ButtonContentOrLoader.js\";\nimport { useIframe } from \"@/shared/hooks/useIframe.js\";\n\nconst SignInButton = ({\n displayMode,\n className,\n}: {\n displayMode?: DisplayMode;\n className?: string;\n}) => {\n const { iframeIsVisible } = useIframe();\n const { signIn, authStatus, displayMode: userDisplayMode } = useUser();\n\n return (\n <button\n data-testid=\"sign-in-button\"\n style={{\n borderRadius: \"9999px\",\n border: \"1px solid #6b7280\",\n padding: \"0.75rem 1rem\",\n transition: \"background-color 0.2s\",\n minWidth: \"9em\", // this stops the button from going too small when in loading mode\n }}\n className={className}\n onClick={() => signIn(displayMode)}\n >\n <ButtonContentOrLoader\n authStatus={authStatus}\n displayMode={displayMode || userDisplayMode}\n iframeIsVisible={iframeIsVisible}\n >\n Sign In\n </ButtonContentOrLoader>\n </button>\n );\n};\n\nexport { SignInButton };\n"]}
1
+ {"version":3,"file":"SignInButton.js","sourceRoot":"","sources":["../../../../src/reactjs/components/SignInButton.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAIb,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,MAAM,YAAY,GAAG,CAAC,EACpB,WAAW,EACX,SAAS,EACT,KAAK,GAKN,EAAE,EAAE;IACH,MAAM,EAAE,eAAe,EAAE,GAAG,SAAS,EAAE,CAAC;IACxC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,OAAO,EAAE,CAAC;IAEvE,OAAO,CACL,gCACc,gBAAgB,EAC5B,GAAG,EAAE;YACH,YAAY,EAAE,QAAQ;YACtB,MAAM,EAAE,mBAAmB;YAC3B,OAAO,EAAE,cAAc;YACvB,UAAU,EAAE,uBAAuB;YACnC,QAAQ,EAAE,KAAK,EAAE,kEAAkE;SACpF,EACD,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,WAAW,CAAC,YAElC,KAAC,qBAAqB,IACpB,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,IAAI,eAAe,EAC3C,eAAe,EAAE,eAAe,wBAGV,GACjB,CACV,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC","sourcesContent":["\"use client\";\n\nimport type { CSSProperties } from \"react\";\nimport type { DisplayMode } from \"@/types.js\";\nimport { useUser } from \"@/reactjs/hooks/useUser.js\";\nimport { useIframe } from \"@/shared/hooks/useIframe.js\";\nimport { ButtonContentOrLoader } from \"./ButtonContentOrLoader.js\";\n\nconst SignInButton = ({\n displayMode,\n className,\n style,\n}: {\n displayMode?: DisplayMode;\n className?: string;\n style?: CSSProperties;\n}) => {\n const { iframeIsVisible } = useIframe();\n const { signIn, authStatus, displayMode: userDisplayMode } = useUser();\n\n return (\n <button\n data-testid=\"sign-in-button\"\n css={{\n borderRadius: \"9999px\",\n border: \"1px solid #6b7280\",\n padding: \"0.75rem 1rem\",\n transition: \"background-color 0.2s\",\n minWidth: \"9em\", // this stops the button from going too small when in loading mode\n }}\n className={className}\n style={style}\n onClick={() => signIn(displayMode)}\n >\n <ButtonContentOrLoader\n authStatus={authStatus}\n displayMode={displayMode || userDisplayMode}\n iframeIsVisible={iframeIsVisible}\n >\n Sign In\n </ButtonContentOrLoader>\n </button>\n );\n};\n\nexport { SignInButton };\n"]}
@@ -1,6 +1,7 @@
1
- import React from "react";
2
- declare const SignOutButton: ({ className }: {
1
+ import { type CSSProperties } from "react";
2
+ declare const SignOutButton: ({ className, style, }: {
3
3
  className?: string;
4
- }) => React.JSX.Element;
4
+ style?: CSSProperties;
5
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
5
6
  export { SignOutButton };
6
7
  //# sourceMappingURL=SignOutButton.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"SignOutButton.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/SignOutButton.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,QAAA,MAAM,aAAa,kBAAmB;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,sBAmB3D,CAAC;AAEF,OAAO,EAAE,aAAa,EAAE,CAAC"}
1
+ {"version":3,"file":"SignOutButton.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/SignOutButton.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,OAAO,CAAC;AAI3C,QAAA,MAAM,aAAa,0BAGhB;IACD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,aAAa,CAAC;CACvB,qDAoBA,CAAC;AAEF,OAAO,EAAE,aAAa,EAAE,CAAC"}
@@ -1,16 +1,16 @@
1
1
  "use client";
2
- import React from "react";
2
+ import { jsx as _jsx } from "@emotion/react/jsx-runtime";
3
+ import {} from "react";
3
4
  import { useUser } from "../../reactjs/hooks/useUser.js";
4
5
  import { ButtonContentOrLoader } from "./ButtonContentOrLoader.js";
5
- const SignOutButton = ({ className }) => {
6
+ const SignOutButton = ({ className, style, }) => {
6
7
  const { signOut, authStatus, displayMode } = useUser();
7
- return (React.createElement("button", { style: {
8
+ return (_jsx("button", { css: {
8
9
  borderRadius: "9999px",
9
10
  border: "1px solid #6b7280",
10
11
  padding: "0.75rem 1rem",
11
12
  transition: "background-color 0.2s",
12
- }, className: className, onClick: () => signOut() },
13
- React.createElement(ButtonContentOrLoader, { authStatus: authStatus, displayMode: displayMode }, "Sign Out")));
13
+ }, className: className, style: style, onClick: () => signOut(), children: _jsx(ButtonContentOrLoader, { authStatus: authStatus, displayMode: displayMode, children: "Sign Out" }) }));
14
14
  };
15
15
  export { SignOutButton };
16
16
  //# sourceMappingURL=SignOutButton.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SignOutButton.js","sourceRoot":"","sources":["../../../../src/reactjs/components/SignOutButton.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,MAAM,aAAa,GAAG,CAAC,EAAE,SAAS,EAA0B,EAAE,EAAE;IAC9D,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,GAAG,OAAO,EAAE,CAAC;IAEvD,OAAO,CACL,gCACE,KAAK,EAAE;YACL,YAAY,EAAE,QAAQ;YACtB,MAAM,EAAE,mBAAmB;YAC3B,OAAO,EAAE,cAAc;YACvB,UAAU,EAAE,uBAAuB;SACpC,EACD,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE;QAExB,oBAAC,qBAAqB,IAAC,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,WAAW,eAE/C,CACjB,CACV,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,aAAa,EAAE,CAAC","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport { useUser } from \"@/reactjs/hooks/useUser.js\";\nimport { ButtonContentOrLoader } from \"./ButtonContentOrLoader.js\";\n\nconst SignOutButton = ({ className }: { className?: string }) => {\n const { signOut, authStatus, displayMode } = useUser();\n\n return (\n <button\n style={{\n borderRadius: \"9999px\",\n border: \"1px solid #6b7280\",\n padding: \"0.75rem 1rem\",\n transition: \"background-color 0.2s\",\n }}\n className={className}\n onClick={() => signOut()}\n >\n <ButtonContentOrLoader authStatus={authStatus} displayMode={displayMode}>\n Sign Out\n </ButtonContentOrLoader>\n </button>\n );\n};\n\nexport { SignOutButton };\n"]}
1
+ {"version":3,"file":"SignOutButton.js","sourceRoot":"","sources":["../../../../src/reactjs/components/SignOutButton.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AACb,OAAO,EAAsB,MAAM,OAAO,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,MAAM,aAAa,GAAG,CAAC,EACrB,SAAS,EACT,KAAK,GAIN,EAAE,EAAE;IACH,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,GAAG,OAAO,EAAE,CAAC;IAEvD,OAAO,CACL,iBACE,GAAG,EAAE;YACH,YAAY,EAAE,QAAQ;YACtB,MAAM,EAAE,mBAAmB;YAC3B,OAAO,EAAE,cAAc;YACvB,UAAU,EAAE,uBAAuB;SACpC,EACD,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,YAExB,KAAC,qBAAqB,IAAC,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,WAAW,yBAE/C,GACjB,CACV,CAAC;AACJ,CAAC,CAAC;AAEF,OAAO,EAAE,aAAa,EAAE,CAAC","sourcesContent":["\"use client\";\nimport { type CSSProperties } from \"react\";\nimport { useUser } from \"@/reactjs/hooks/useUser.js\";\nimport { ButtonContentOrLoader } from \"./ButtonContentOrLoader.js\";\n\nconst SignOutButton = ({\n className,\n style,\n}: {\n className?: string;\n style?: CSSProperties;\n}) => {\n const { signOut, authStatus, displayMode } = useUser();\n\n return (\n <button\n css={{\n borderRadius: \"9999px\",\n border: \"1px solid #6b7280\",\n padding: \"0.75rem 1rem\",\n transition: \"background-color 0.2s\",\n }}\n className={className}\n style={style}\n onClick={() => signOut()}\n >\n <ButtonContentOrLoader authStatus={authStatus} displayMode={displayMode}>\n Sign Out\n </ButtonContentOrLoader>\n </button>\n );\n};\n\nexport { SignOutButton };\n"]}
@@ -1,6 +1,9 @@
1
- import React from "react";
2
- declare const UserButton: ({ className }: {
1
+ import { type CSSProperties } from "react";
2
+ declare const UserButton: ({ className, wrapperClassName, style, wrapperStyle, }: {
3
3
  className?: string;
4
- }) => React.JSX.Element;
4
+ wrapperClassName?: string;
5
+ style?: CSSProperties;
6
+ wrapperStyle?: CSSProperties;
7
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
5
8
  export { UserButton };
6
9
  //# sourceMappingURL=UserButton.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"UserButton.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/UserButton.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAmD,MAAM,OAAO,CAAC;AAwCxE,QAAA,MAAM,UAAU,kBAAmB;IAAE,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,sBAyNxD,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
1
+ {"version":3,"file":"UserButton.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/components/UserButton.tsx"],"names":[],"mappings":"AAEA,OAAc,EAKZ,KAAK,aAAa,EACnB,MAAM,OAAO,CAAC;AAwCf,QAAA,MAAM,UAAU,0DAKb;IACD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,YAAY,CAAC,EAAE,aAAa,CAAC;CAC9B,qDAwNA,CAAC;AAEF,OAAO,EAAE,UAAU,EAAE,CAAC"}
@@ -1,15 +1,14 @@
1
1
  "use client";
2
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
2
3
  import { useUser } from "../../reactjs/hooks/index.js";
3
- import React, { useCallback, useEffect, useRef, useState } from "react";
4
+ import React, { useCallback, useEffect, useRef, useState, } from "react";
4
5
  import { ButtonContentOrLoader } from "./ButtonContentOrLoader.js";
5
6
  import { AuthStatus } from "../../types.js";
6
7
  import { shouldShowLoader } from "./utils.js";
7
8
  import { useIframe } from "../../shared/hooks/useIframe.js";
8
- const ChevronDown = () => (React.createElement("svg", { xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", className: "lucide lucide-chevron-down" },
9
- React.createElement("path", { d: "m6 9 6 6 6-6" })));
10
- const ChevronUp = () => (React.createElement("svg", { xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", className: "lucide lucide-chevron-up" },
11
- React.createElement("path", { d: "m18 15-6-6-6 6" })));
12
- const UserButton = ({ className }) => {
9
+ const ChevronDown = () => (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", className: "lucide lucide-chevron-down", children: _jsx("path", { d: "m6 9 6 6 6-6" }) }));
10
+ const ChevronUp = () => (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", className: "lucide lucide-chevron-up", children: _jsx("path", { d: "m18 15-6-6-6 6" }) }));
11
+ const UserButton = ({ className, wrapperClassName, style, wrapperStyle, }) => {
13
12
  const [isOpen, setIsOpen] = useState(false);
14
13
  const [buttonWidth, setButtonWidth] = useState(null);
15
14
  const { user, signIn, signOut, authStatus, displayMode } = useUser();
@@ -54,76 +53,68 @@ const UserButton = ({ className }) => {
54
53
  };
55
54
  }, [handleClickOutside, handleEscape, isOpen]);
56
55
  if (user) {
57
- return (React.createElement("div", { style: { position: "relative", width: "auto" }, id: "civic-dropdown-container" },
58
- React.createElement("button", { ref: buttonRef, style: {
59
- cursor: "pointer",
60
- display: "flex",
61
- minWidth: "10rem",
62
- alignItems: "center",
63
- justifyContent: "space-between",
64
- gap: "0.5rem",
65
- borderRadius: "9999px",
66
- border: "1px solid #6b7280",
67
- padding: "0.75rem 1rem",
68
- color: "#6b7280",
69
- background: "none",
70
- transition: "background-color 0.2s",
71
- }, className: className, onMouseEnter: (e) => (e.currentTarget.style.backgroundColor = "#f3f4f6"), onMouseLeave: (e) => (e.currentTarget.style.backgroundColor = "transparent"), onClick: () => {
72
- authStatus !== AuthStatus.SIGNING_OUT &&
73
- setIsOpen((isOpen) => !isOpen);
74
- } },
75
- React.createElement(React.Fragment, null,
76
- user?.picture ? (React.createElement("span", { style: {
77
- position: "relative",
78
- display: "flex",
79
- height: "1.5rem",
80
- width: "1.5rem",
81
- flexShrink: 0,
82
- gap: "0.5rem",
83
- overflow: "hidden",
84
- borderRadius: "9999px",
85
- } },
86
- React.createElement("img", { style: {
87
- height: "100%",
88
- width: "100%",
89
- objectFit: "cover",
90
- }, src: user.picture, alt: user?.name || user?.email }))) : (React.createElement("span", { style: { display: "block" } })),
91
- React.createElement(ButtonContentOrLoader, { authStatus: authStatus, displayMode: displayMode, iframeIsVisible: iframeIsVisible }, user?.name || user?.email),
92
- React.createElement("span", { style: {
93
- display: "block",
94
- pointerEvents: "none",
95
- visibility: shouldShowLoader(authStatus, displayMode)
96
- ? "hidden"
97
- : "visible",
98
- } }, isOpen ? React.createElement(ChevronUp, null) : React.createElement(ChevronDown, null)))),
99
- React.createElement("div", { ref: dropdownRef, style: isOpen
100
- ? {
101
- position: "absolute",
102
- left: 0,
103
- width: buttonWidth || "auto",
104
- marginTop: "0.5rem",
105
- borderRadius: "0.5rem",
106
- backgroundColor: "white",
107
- padding: "0.5rem 0",
56
+ return (_jsxs("div", { css: { position: "relative", width: "auto" }, className: wrapperClassName, style: wrapperStyle, id: "civic-dropdown-container", children: [_jsx("button", { ref: buttonRef, css: {
57
+ cursor: "pointer",
58
+ display: "flex",
59
+ minWidth: "10rem",
60
+ alignItems: "center",
61
+ justifyContent: "space-between",
62
+ gap: "0.5rem",
63
+ borderRadius: "9999px",
64
+ border: "1px solid #6b7280",
65
+ padding: "0.75rem 1rem",
108
66
  color: "#6b7280",
109
- boxShadow: "0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)",
110
- zIndex: 1000,
111
- }
112
- : { display: "none" } },
113
- React.createElement("ul", { style: { listStyleType: "none", margin: 0, padding: 0 } },
114
- React.createElement("li", null,
115
- React.createElement("button", { style: {
116
- display: "block",
117
- width: "100%",
118
- padding: "0.5rem 1rem",
119
- transition: "background-color 0.2s",
120
- background: "none",
121
- border: "none",
122
- textAlign: "center",
123
- cursor: "pointer",
124
- }, onClick: () => !shouldShowLoader(authStatus, displayMode) && handleSignOut(), onMouseEnter: (e) => (e.currentTarget.style.backgroundColor = "#f3f4f6"), onMouseLeave: (e) => (e.currentTarget.style.backgroundColor = "transparent") }, "Logout"))))));
67
+ transition: "background-color 0.2s",
68
+ "&:hover": {
69
+ backgroundColor: "#f3f4f6",
70
+ },
71
+ }, className: className, style: style, onClick: () => {
72
+ authStatus !== AuthStatus.SIGNING_OUT &&
73
+ setIsOpen((isOpen) => !isOpen);
74
+ }, children: _jsxs(_Fragment, { children: [user?.picture ? (_jsx("span", { css: {
75
+ position: "relative",
76
+ display: "flex",
77
+ height: "1.5rem",
78
+ width: "1.5rem",
79
+ flexShrink: 0,
80
+ gap: "0.5rem",
81
+ overflow: "hidden",
82
+ borderRadius: "9999px",
83
+ }, children: _jsx("img", { css: {
84
+ height: "100%",
85
+ width: "100%",
86
+ objectFit: "cover",
87
+ }, src: user.picture, alt: user?.name || user?.email }) })) : (_jsx("span", { css: { display: "block" } })), _jsx(ButtonContentOrLoader, { authStatus: authStatus, displayMode: displayMode, iframeIsVisible: iframeIsVisible, children: user?.name || user?.email }), _jsx("span", { css: {
88
+ display: "block",
89
+ pointerEvents: "none",
90
+ visibility: shouldShowLoader(authStatus, displayMode)
91
+ ? "hidden"
92
+ : "visible",
93
+ }, children: isOpen ? _jsx(ChevronUp, {}) : _jsx(ChevronDown, {}) })] }) }), _jsx("div", { ref: dropdownRef, css: isOpen
94
+ ? {
95
+ position: "absolute",
96
+ left: 0,
97
+ width: buttonWidth || "auto",
98
+ marginTop: "0.5rem",
99
+ borderRadius: "0.5rem",
100
+ backgroundColor: "white",
101
+ padding: "0.5rem 0",
102
+ color: "#6b7280",
103
+ boxShadow: "0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)",
104
+ zIndex: 1000,
105
+ }
106
+ : { display: "none" }, children: _jsx("ul", { css: { listStyleType: "none", margin: 0, padding: 0 }, children: _jsx("li", { children: _jsx("button", { css: {
107
+ display: "block",
108
+ width: "100%",
109
+ padding: "0.5rem 1rem",
110
+ transition: "background-color 0.2s",
111
+ background: "none",
112
+ border: "none",
113
+ textAlign: "center",
114
+ cursor: "pointer",
115
+ }, onClick: () => !shouldShowLoader(authStatus, displayMode) && handleSignOut(), onMouseEnter: (e) => (e.currentTarget.style.backgroundColor = "#f3f4f6"), onMouseLeave: (e) => (e.currentTarget.style.backgroundColor = "transparent"), children: "Logout" }) }) }) })] }));
125
116
  }
126
- return (React.createElement("button", { ref: buttonRef, "data-testid": "sign-in-button", style: {
117
+ return (_jsx("button", { ref: buttonRef, "data-testid": "sign-in-button", css: {
127
118
  cursor: "pointer",
128
119
  borderRadius: "9999px",
129
120
  border: "1px solid #6b7280",
@@ -131,8 +122,10 @@ const UserButton = ({ className }) => {
131
122
  background: "none",
132
123
  transition: "background-color 0.2s",
133
124
  minWidth: "9em", // this stops the button from going too small when in loading mode
134
- }, className: className, onMouseEnter: (e) => (e.currentTarget.style.backgroundColor = "#f3f4f6"), onMouseLeave: (e) => (e.currentTarget.style.backgroundColor = "transparent"), onClick: () => !shouldShowLoader(authStatus, displayMode) && handleSignIn() },
135
- React.createElement(ButtonContentOrLoader, { authStatus: authStatus, displayMode: displayMode }, "Sign in")));
125
+ "&:hover": {
126
+ backgroundColor: "#f3f4f6",
127
+ },
128
+ }, className: className, style: style, onClick: () => !shouldShowLoader(authStatus, displayMode) && handleSignIn(), children: _jsx(ButtonContentOrLoader, { authStatus: authStatus, displayMode: displayMode, children: "Sign in" }) }));
136
129
  };
137
130
  export { UserButton };
138
131
  //# sourceMappingURL=UserButton.js.map