@civic/auth 0.1.4-beta.7 → 0.1.4

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 (103) hide show
  1. package/README.md +11 -8
  2. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  3. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  4. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js +16 -0
  5. package/dist/cjs/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  6. package/dist/cjs/reactjs/providers/AuthProvider.d.ts +11 -0
  7. package/dist/cjs/reactjs/providers/AuthProvider.d.ts.map +1 -0
  8. package/dist/cjs/reactjs/providers/AuthProvider.js +99 -0
  9. package/dist/cjs/reactjs/providers/AuthProvider.js.map +1 -0
  10. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts +6 -0
  11. package/dist/cjs/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  12. package/dist/cjs/reactjs/providers/CivicAuthProvider.js +38 -0
  13. package/dist/cjs/reactjs/providers/CivicAuthProvider.js.map +1 -0
  14. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  15. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  16. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js +183 -0
  17. package/dist/cjs/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  18. package/dist/cjs/reactjs/providers/index.d.ts +2 -2
  19. package/dist/cjs/reactjs/providers/index.d.ts.map +1 -1
  20. package/dist/cjs/reactjs/providers/index.js +2 -2
  21. package/dist/cjs/reactjs/providers/index.js.map +1 -1
  22. package/dist/cjs/shared/hooks/index.d.ts +3 -1
  23. package/dist/cjs/shared/hooks/index.d.ts.map +1 -1
  24. package/dist/cjs/shared/hooks/index.js +6 -2
  25. package/dist/cjs/shared/hooks/index.js.map +1 -1
  26. package/dist/cjs/shared/hooks/useWindowFocused.d.ts +5 -0
  27. package/dist/cjs/shared/hooks/useWindowFocused.d.ts.map +1 -0
  28. package/dist/cjs/shared/hooks/useWindowFocused.js +24 -0
  29. package/dist/cjs/shared/hooks/useWindowFocused.js.map +1 -0
  30. package/dist/cjs/shared/index.d.ts +1 -0
  31. package/dist/cjs/shared/index.d.ts.map +1 -1
  32. package/dist/cjs/shared/index.js +5 -3
  33. package/dist/cjs/shared/index.js.map +1 -1
  34. package/dist/cjs/shared/providers/AuthProvider.d.ts +13 -3
  35. package/dist/cjs/shared/providers/AuthProvider.d.ts.map +1 -1
  36. package/dist/cjs/shared/providers/AuthProvider.js.map +1 -1
  37. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts +1 -1
  38. package/dist/cjs/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  39. package/dist/cjs/shared/providers/CivicAuthProvider.js.map +1 -1
  40. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -1
  41. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js +7 -24
  42. package/dist/cjs/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -1
  43. package/dist/cjs/shared/version.d.ts +1 -1
  44. package/dist/cjs/shared/version.d.ts.map +1 -1
  45. package/dist/cjs/shared/version.js +1 -1
  46. package/dist/cjs/shared/version.js.map +1 -1
  47. package/dist/cjs/version.d.ts +2 -0
  48. package/dist/cjs/version.d.ts.map +1 -0
  49. package/dist/cjs/version.js +6 -0
  50. package/dist/cjs/version.js.map +1 -0
  51. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts +3 -0
  52. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.d.ts.map +1 -0
  53. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js +13 -0
  54. package/dist/esm/reactjs/hooks/useClientTokenExchangeSession.js.map +1 -0
  55. package/dist/esm/reactjs/providers/AuthProvider.d.ts +11 -0
  56. package/dist/esm/reactjs/providers/AuthProvider.d.ts.map +1 -0
  57. package/dist/esm/reactjs/providers/AuthProvider.js +63 -0
  58. package/dist/esm/reactjs/providers/AuthProvider.js.map +1 -0
  59. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts +6 -0
  60. package/dist/esm/reactjs/providers/CivicAuthProvider.d.ts.map +1 -0
  61. package/dist/esm/reactjs/providers/CivicAuthProvider.js +32 -0
  62. package/dist/esm/reactjs/providers/CivicAuthProvider.js.map +1 -0
  63. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts +17 -0
  64. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -0
  65. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js +146 -0
  66. package/dist/esm/reactjs/providers/ClientTokenExchangeSessionProvider.js.map +1 -0
  67. package/dist/esm/reactjs/providers/index.d.ts +2 -2
  68. package/dist/esm/reactjs/providers/index.d.ts.map +1 -1
  69. package/dist/esm/reactjs/providers/index.js +2 -2
  70. package/dist/esm/reactjs/providers/index.js.map +1 -1
  71. package/dist/esm/shared/hooks/index.d.ts +3 -1
  72. package/dist/esm/shared/hooks/index.d.ts.map +1 -1
  73. package/dist/esm/shared/hooks/index.js +3 -1
  74. package/dist/esm/shared/hooks/index.js.map +1 -1
  75. package/dist/esm/shared/hooks/useWindowFocused.d.ts +5 -0
  76. package/dist/esm/shared/hooks/useWindowFocused.d.ts.map +1 -0
  77. package/dist/esm/shared/hooks/useWindowFocused.js +21 -0
  78. package/dist/esm/shared/hooks/useWindowFocused.js.map +1 -0
  79. package/dist/esm/shared/index.d.ts +1 -0
  80. package/dist/esm/shared/index.d.ts.map +1 -1
  81. package/dist/esm/shared/index.js +3 -2
  82. package/dist/esm/shared/index.js.map +1 -1
  83. package/dist/esm/shared/providers/AuthProvider.d.ts +13 -3
  84. package/dist/esm/shared/providers/AuthProvider.d.ts.map +1 -1
  85. package/dist/esm/shared/providers/AuthProvider.js.map +1 -1
  86. package/dist/esm/shared/providers/CivicAuthProvider.d.ts +1 -1
  87. package/dist/esm/shared/providers/CivicAuthProvider.d.ts.map +1 -1
  88. package/dist/esm/shared/providers/CivicAuthProvider.js +1 -1
  89. package/dist/esm/shared/providers/CivicAuthProvider.js.map +1 -1
  90. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.d.ts.map +1 -1
  91. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js +5 -22
  92. package/dist/esm/shared/providers/ClientTokenExchangeSessionProvider.js.map +1 -1
  93. package/dist/esm/shared/version.d.ts +1 -1
  94. package/dist/esm/shared/version.d.ts.map +1 -1
  95. package/dist/esm/shared/version.js +1 -1
  96. package/dist/esm/shared/version.js.map +1 -1
  97. package/dist/esm/version.d.ts +2 -0
  98. package/dist/esm/version.d.ts.map +1 -0
  99. package/dist/esm/version.js +3 -0
  100. package/dist/esm/version.js.map +1 -0
  101. package/dist/tsconfig.cjs.tsbuildinfo +1 -1
  102. package/dist/tsconfig.esm.tsbuildinfo +1 -1
  103. package/package.json +6 -6
package/README.md CHANGED
@@ -176,6 +176,12 @@ The full user context object (provided by `useUser`) looks like this:
176
176
  ```typescript
177
177
  {
178
178
  user: User | null;
179
+ // these are the OAuth tokens created during authentication
180
+ idToken?: string;
181
+ accessToken?: string;
182
+ refreshToken?: string;
183
+ forwardedTokens?: ForwardedTokens;
184
+ // functions and flags for UI and signIn/signOut
179
185
  isLoading: boolean;
180
186
  error: Error | null;
181
187
  signIn: (displayMode?: DisplayMode) => Promise<void>;
@@ -197,14 +203,11 @@ type BaseUser = {
197
203
  updated_at?: Date;
198
204
  };
199
205
 
200
- type Tokens = {
201
- idToken: string;
202
- accessToken: string;
203
- refreshToken: string;
204
- forwardedTokens: ForwardedTokens;
205
- };
206
-
207
- type User = BaseUser & Tokens
206
+ type User<T extends UnknownObject = EmptyObject> = BaseUser & T;
207
+ ```
208
+ Where you can pass extra user attributes to the object that you know will be present in user claims, e.g.
209
+ ```typescript
210
+ const UserWithNickName = User<{ nickname: string }>;
208
211
  ```
209
212
 
210
213
  Field descriptions:
@@ -0,0 +1,3 @@
1
+ declare const useClientTokenExchangeSession: () => import("../../reactjs/providers/ClientTokenExchangeSessionProvider.js").ClientTokenExchangeSessionProviderOutput;
2
+ export { useClientTokenExchangeSession };
3
+ //# sourceMappingURL=useClientTokenExchangeSession.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useClientTokenExchangeSession.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/hooks/useClientTokenExchangeSession.ts"],"names":[],"mappings":"AAKA,QAAA,MAAM,6BAA6B,oHAMlC,CAAC;AAEF,OAAO,EAAE,6BAA6B,EAAE,CAAC"}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ "use client";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.useClientTokenExchangeSession = void 0;
5
+ const react_1 = require("react");
6
+ const ClientTokenExchangeSessionProvider_js_1 = require("../../reactjs/providers/ClientTokenExchangeSessionProvider.js");
7
+ // TokenProvider will use this internal context to access session
8
+ const useClientTokenExchangeSession = () => {
9
+ const context = (0, react_1.useContext)(ClientTokenExchangeSessionProvider_js_1.ClientTokenExchangeSessionContext);
10
+ if (!context) {
11
+ throw new Error("useSession must be used within an SessionProvider");
12
+ }
13
+ return context;
14
+ };
15
+ exports.useClientTokenExchangeSession = useClientTokenExchangeSession;
16
+ //# sourceMappingURL=useClientTokenExchangeSession.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useClientTokenExchangeSession.js","sourceRoot":"","sources":["../../../../src/reactjs/hooks/useClientTokenExchangeSession.ts"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;AACb,iCAAmC;AACnC,qHAA8G;AAE9G,iEAAiE;AACjE,MAAM,6BAA6B,GAAG,GAAG,EAAE;IACzC,MAAM,OAAO,GAAG,IAAA,kBAAU,EAAC,yEAAiC,CAAC,CAAC;IAC9D,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,mDAAmD,CAAC,CAAC;IACvE,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEO,sEAA6B","sourcesContent":["\"use client\";\nimport { useContext } from \"react\";\nimport { ClientTokenExchangeSessionContext } from \"@/reactjs/providers/ClientTokenExchangeSessionProvider.js\";\n\n// TokenProvider will use this internal context to access session\nconst useClientTokenExchangeSession = () => {\n const context = useContext(ClientTokenExchangeSessionContext);\n if (!context) {\n throw new Error(\"useSession must be used within an SessionProvider\");\n }\n return context;\n};\n\nexport { useClientTokenExchangeSession };\n"]}
@@ -0,0 +1,11 @@
1
+ import React from "react";
2
+ import type { SessionData } from "../../types.js";
3
+ import type { PKCEConsumer } from "../../services/types.js";
4
+ import type { AuthProviderProps } from "../../shared/providers/types.js";
5
+ export type InternalAuthProviderProps = AuthProviderProps & {
6
+ sessionData?: SessionData;
7
+ pkceConsumer?: PKCEConsumer;
8
+ };
9
+ declare const AuthProvider: ({ children, onSignIn, onSignOut, pkceConsumer, iframeMode, }: InternalAuthProviderProps) => React.JSX.Element;
10
+ export { AuthProvider };
11
+ //# sourceMappingURL=AuthProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AuthProvider.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/providers/AuthProvider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAuC,MAAM,OAAO,CAAC;AAC5D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAMxD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAarE,MAAM,MAAM,yBAAyB,GAAG,iBAAiB,GAAG;IAC1D,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,YAAY,CAAC,EAAE,YAAY,CAAC;CAC7B,CAAC;AAEF,QAAA,MAAM,YAAY,iEAMf,yBAAyB,sBA6D3B,CAAC;AAEF,OAAO,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,99 @@
1
+ "use strict";
2
+ "use client";
3
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
+ if (k2 === undefined) k2 = k;
5
+ var desc = Object.getOwnPropertyDescriptor(m, k);
6
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
+ desc = { enumerable: true, get: function() { return m[k]; } };
8
+ }
9
+ Object.defineProperty(o, k2, desc);
10
+ }) : (function(o, m, k, k2) {
11
+ if (k2 === undefined) k2 = k;
12
+ o[k2] = m[k];
13
+ }));
14
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
15
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
16
+ }) : function(o, v) {
17
+ o["default"] = v;
18
+ });
19
+ var __importStar = (this && this.__importStar) || (function () {
20
+ var ownKeys = function(o) {
21
+ ownKeys = Object.getOwnPropertyNames || function (o) {
22
+ var ar = [];
23
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
24
+ return ar;
25
+ };
26
+ return ownKeys(o);
27
+ };
28
+ return function (mod) {
29
+ if (mod && mod.__esModule) return mod;
30
+ var result = {};
31
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
32
+ __setModuleDefault(result, mod);
33
+ return result;
34
+ };
35
+ })();
36
+ Object.defineProperty(exports, "__esModule", { value: true });
37
+ exports.AuthProvider = void 0;
38
+ const react_1 = __importStar(require("react"));
39
+ const AuthContext_js_1 = require("../../shared/providers/AuthContext.js");
40
+ const useSignIn_js_1 = require("../../shared/hooks/useSignIn.js");
41
+ const useIframe_js_1 = require("../../shared/hooks/useIframe.js");
42
+ const useCivicAuthConfig_js_1 = require("../../shared/hooks/useCivicAuthConfig.js");
43
+ const useSession_js_1 = require("../../shared/hooks/useSession.js");
44
+ const IFrameAndLoading_js_1 = require("../../shared/components/IFrameAndLoading.js");
45
+ // Global this object setup
46
+ let globalThisObject;
47
+ if (typeof window !== "undefined") {
48
+ globalThisObject = window;
49
+ }
50
+ else if (typeof global !== "undefined") {
51
+ globalThisObject = global;
52
+ }
53
+ else {
54
+ globalThisObject = Function("return this")();
55
+ }
56
+ globalThisObject.globalThis = globalThisObject;
57
+ const AuthProvider = ({ children, onSignIn, onSignOut, pkceConsumer, iframeMode = "modal", }) => {
58
+ const authConfig = (0, useCivicAuthConfig_js_1.useCivicAuthConfig)();
59
+ const { redirectUrl } = authConfig || {};
60
+ const { iframeRef } = (0, useIframe_js_1.useIframe)();
61
+ const { signIn, signOut } = (0, useSignIn_js_1.useSignIn)({
62
+ preSignOut: onSignOut,
63
+ pkceConsumer,
64
+ });
65
+ const [localSessionData, setLocalSessionData] = (0, react_1.useState)();
66
+ const { data: session, error: tokenExchangeError, isLoading: tokenExchangeInProgress, } = (0, useSession_js_1.useSession)();
67
+ (0, react_1.useEffect)(() => {
68
+ if (session) {
69
+ setLocalSessionData(session);
70
+ if (session.authenticated) {
71
+ onSignIn?.();
72
+ }
73
+ }
74
+ }, [onSignIn, session]);
75
+ const isAuthenticated = (0, react_1.useMemo)(() => {
76
+ return !!localSessionData?.idToken;
77
+ }, [localSessionData]);
78
+ (0, react_1.useEffect)(() => {
79
+ if (iframeMode === "embedded" &&
80
+ redirectUrl &&
81
+ !isAuthenticated &&
82
+ iframeRef?.current) {
83
+ signIn("iframe");
84
+ }
85
+ }, [iframeMode, redirectUrl, isAuthenticated, iframeRef, signIn]);
86
+ const isLoading = tokenExchangeInProgress || !authConfig;
87
+ const value = (0, react_1.useMemo)(() => ({
88
+ isLoading,
89
+ error: tokenExchangeError,
90
+ signOut,
91
+ isAuthenticated,
92
+ signIn,
93
+ }), [isLoading, tokenExchangeError, isAuthenticated, signIn, signOut]);
94
+ return (react_1.default.createElement(AuthContext_js_1.AuthContext.Provider, { value: value },
95
+ react_1.default.createElement(IFrameAndLoading_js_1.IFrameAndLoading, { error: tokenExchangeError, isLoading: isLoading }),
96
+ children));
97
+ };
98
+ exports.AuthProvider = AuthProvider;
99
+ //# sourceMappingURL=AuthProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AuthProvider.js","sourceRoot":"","sources":["../../../../src/reactjs/providers/AuthProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEb,+CAA4D;AAE5D,sEAAgE;AAEhE,8DAAwD;AACxD,8DAAwD;AACxD,gFAA0E;AAC1E,gEAA0D;AAC1D,iFAA2E;AAG3E,2BAA2B;AAC3B,IAAI,gBAAgB,CAAC;AACrB,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;IAClC,gBAAgB,GAAG,MAAM,CAAC;AAC5B,CAAC;KAAM,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;IACzC,gBAAgB,GAAG,MAAM,CAAC;AAC5B,CAAC;KAAM,CAAC;IACN,gBAAgB,GAAG,QAAQ,CAAC,aAAa,CAAC,EAAE,CAAC;AAC/C,CAAC;AACD,gBAAgB,CAAC,UAAU,GAAG,gBAAgB,CAAC;AAO/C,MAAM,YAAY,GAAG,CAAC,EACpB,QAAQ,EACR,QAAQ,EACR,SAAS,EACT,YAAY,EACZ,UAAU,GAAG,OAAO,GACM,EAAE,EAAE;IAC9B,MAAM,UAAU,GAAG,IAAA,0CAAkB,GAAE,CAAC;IACxC,MAAM,EAAE,WAAW,EAAE,GAAG,UAAU,IAAI,EAAE,CAAC;IACzC,MAAM,EAAE,SAAS,EAAE,GAAG,IAAA,wBAAS,GAAE,CAAC;IAElC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,IAAA,wBAAS,EAAC;QACpC,UAAU,EAAE,SAAS;QACrB,YAAY;KACb,CAAC,CAAC;IAEH,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAC3C,IAAA,gBAAQ,GAAsB,CAAC;IAEjC,MAAM,EACJ,IAAI,EAAE,OAAO,EACb,KAAK,EAAE,kBAAkB,EACzB,SAAS,EAAE,uBAAuB,GACnC,GAAG,IAAA,0BAAU,GAAE,CAAC;IAEjB,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,OAAO,EAAE,CAAC;YACZ,mBAAmB,CAAC,OAAO,CAAC,CAAC;YAC7B,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;gBAC1B,QAAQ,EAAE,EAAE,CAAC;YACf,CAAC;QACH,CAAC;IACH,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;IAExB,MAAM,eAAe,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE;QACnC,OAAO,CAAC,CAAC,gBAAgB,EAAE,OAAO,CAAC;IACrC,CAAC,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAEvB,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IACE,UAAU,KAAK,UAAU;YACzB,WAAW;YACX,CAAC,eAAe;YAChB,SAAS,EAAE,OAAO,EAClB,CAAC;YACD,MAAM,CAAC,QAAQ,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC;IAElE,MAAM,SAAS,GAAG,uBAAuB,IAAI,CAAC,UAAU,CAAC;IACzD,MAAM,KAAK,GAAG,IAAA,eAAO,EACnB,GAAG,EAAE,CAAC,CAAC;QACL,SAAS;QACT,KAAK,EAAE,kBAAkC;QACzC,OAAO;QACP,eAAe;QACf,MAAM;KACP,CAAC,EACF,CAAC,SAAS,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,EAAE,OAAO,CAAC,CAClE,CAAC;IAEF,OAAO,CACL,8BAAC,4BAAW,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK;QAChC,8BAAC,sCAAgB,IAAC,KAAK,EAAE,kBAAkB,EAAE,SAAS,EAAE,SAAS,GAAI;QACpE,QAAQ,CACY,CACxB,CAAC;AACJ,CAAC,CAAC;AAEO,oCAAY","sourcesContent":["\"use client\";\n\nimport React, { useEffect, useMemo, useState } from \"react\";\nimport type { SessionData } from \"@/types.js\";\nimport { AuthContext } from \"@/shared/providers/AuthContext.js\";\nimport type { PKCEConsumer } from \"@/services/types.js\";\nimport { useSignIn } from \"@/shared/hooks/useSignIn.js\";\nimport { useIframe } from \"@/shared/hooks/useIframe.js\";\nimport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nimport { useSession } from \"@/shared/hooks/useSession.js\";\nimport { IFrameAndLoading } from \"@/shared/components/IFrameAndLoading.js\";\nimport type { AuthProviderProps } from \"@/shared/providers/types.js\";\n\n// Global this object setup\nlet globalThisObject;\nif (typeof window !== \"undefined\") {\n globalThisObject = window;\n} else if (typeof global !== \"undefined\") {\n globalThisObject = global;\n} else {\n globalThisObject = Function(\"return this\")();\n}\nglobalThisObject.globalThis = globalThisObject;\n\nexport type InternalAuthProviderProps = AuthProviderProps & {\n sessionData?: SessionData;\n pkceConsumer?: PKCEConsumer;\n};\n\nconst AuthProvider = ({\n children,\n onSignIn,\n onSignOut,\n pkceConsumer,\n iframeMode = \"modal\",\n}: InternalAuthProviderProps) => {\n const authConfig = useCivicAuthConfig();\n const { redirectUrl } = authConfig || {};\n const { iframeRef } = useIframe();\n\n const { signIn, signOut } = useSignIn({\n preSignOut: onSignOut,\n pkceConsumer,\n });\n\n const [localSessionData, setLocalSessionData] =\n useState<SessionData | null>();\n\n const {\n data: session,\n error: tokenExchangeError,\n isLoading: tokenExchangeInProgress,\n } = useSession();\n\n useEffect(() => {\n if (session) {\n setLocalSessionData(session);\n if (session.authenticated) {\n onSignIn?.();\n }\n }\n }, [onSignIn, session]);\n\n const isAuthenticated = useMemo(() => {\n return !!localSessionData?.idToken;\n }, [localSessionData]);\n\n useEffect(() => {\n if (\n iframeMode === \"embedded\" &&\n redirectUrl &&\n !isAuthenticated &&\n iframeRef?.current\n ) {\n signIn(\"iframe\");\n }\n }, [iframeMode, redirectUrl, isAuthenticated, iframeRef, signIn]);\n\n const isLoading = tokenExchangeInProgress || !authConfig;\n const value = useMemo(\n () => ({\n isLoading,\n error: tokenExchangeError as Error | null,\n signOut,\n isAuthenticated,\n signIn,\n }),\n [isLoading, tokenExchangeError, isAuthenticated, signIn, signOut],\n );\n\n return (\n <AuthContext.Provider value={value}>\n <IFrameAndLoading error={tokenExchangeError} isLoading={isLoading} />\n {children}\n </AuthContext.Provider>\n );\n};\n\nexport { AuthProvider };\n"]}
@@ -0,0 +1,6 @@
1
+ import React from "react";
2
+ import type { AuthProviderProps } from "../../shared/providers/types.js";
3
+ type CivicAuthProviderProps = Omit<AuthProviderProps, "pkceConsumer">;
4
+ declare const CivicAuthProvider: ({ children, ...props }: CivicAuthProviderProps) => React.JSX.Element;
5
+ export { CivicAuthProvider, type CivicAuthProviderProps };
6
+ //# sourceMappingURL=CivicAuthProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CivicAuthProvider.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/providers/CivicAuthProvider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAY1B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAErE,KAAK,sBAAsB,GAAG,IAAI,CAAC,iBAAiB,EAAE,cAAc,CAAC,CAAC;AAkCtE,QAAA,MAAM,iBAAiB,2BAA4B,sBAAsB,sBAexE,CAAC;AAEF,OAAO,EAAE,iBAAiB,EAAE,KAAK,sBAAsB,EAAE,CAAC"}
@@ -0,0 +1,38 @@
1
+ "use strict";
2
+ "use client";
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.CivicAuthProvider = void 0;
8
+ const react_1 = __importDefault(require("react"));
9
+ const AuthProvider_js_1 = require("../../reactjs/providers/AuthProvider.js");
10
+ const PKCE_js_1 = require("../../services/PKCE.js");
11
+ const UserProvider_js_1 = require("../../shared/providers/UserProvider.js");
12
+ const storage_js_1 = require("../../browser/storage.js");
13
+ const CivicAuthConfigContext_js_1 = require("../../shared/providers/CivicAuthConfigContext.js");
14
+ const IframeProvider_js_1 = require("../../shared/providers/IframeProvider.js");
15
+ const ClientTokenExchangeSessionProvider_js_1 = require("../../reactjs/providers/ClientTokenExchangeSessionProvider.js");
16
+ const SessionProvider_js_1 = require("../../shared/providers/SessionProvider.js");
17
+ const useClientTokenExchangeSession_js_1 = require("../../reactjs/hooks/useClientTokenExchangeSession.js");
18
+ const TokenProvider_js_1 = require("../../shared/providers/TokenProvider.js");
19
+ const useAuth_js_1 = require("../../shared/hooks/useAuth.js");
20
+ const WrapperUserProvider = ({ children }) => {
21
+ const { signIn, signOut } = (0, useAuth_js_1.useAuth)();
22
+ return (react_1.default.createElement(UserProvider_js_1.UserProvider, { storage: new storage_js_1.LocalStorageAdapter(), signIn: signIn, signOut: signOut }, children));
23
+ };
24
+ const WrapperSessionAuthProvider = ({ children, ...props }) => {
25
+ const sessionData = (0, useClientTokenExchangeSession_js_1.useClientTokenExchangeSession)();
26
+ return (react_1.default.createElement(SessionProvider_js_1.SessionProvider, { ...sessionData },
27
+ react_1.default.createElement(IframeProvider_js_1.IframeProvider, { iframeMode: props.iframeMode },
28
+ react_1.default.createElement(AuthProvider_js_1.AuthProvider, { ...props, pkceConsumer: new PKCE_js_1.BrowserPublicClientPKCEProducer() },
29
+ react_1.default.createElement(TokenProvider_js_1.TokenProvider, null,
30
+ react_1.default.createElement(WrapperUserProvider, null, children))))));
31
+ };
32
+ const CivicAuthProvider = ({ children, ...props }) => {
33
+ return (react_1.default.createElement(CivicAuthConfigContext_js_1.CivicAuthConfigProvider, { oauthServer: props?.config?.oauthServer, clientId: props?.clientId, redirectUrl: props?.redirectUrl, nonce: props?.nonce },
34
+ react_1.default.createElement(ClientTokenExchangeSessionProvider_js_1.ClientTokenExchangeSessionProvider, null,
35
+ react_1.default.createElement(WrapperSessionAuthProvider, { ...props }, children))));
36
+ };
37
+ exports.CivicAuthProvider = CivicAuthProvider;
38
+ //# sourceMappingURL=CivicAuthProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CivicAuthProvider.js","sourceRoot":"","sources":["../../../../src/reactjs/providers/CivicAuthProvider.tsx"],"names":[],"mappings":";AAAA,YAAY,CAAC;;;;;;AACb,kDAA0B;AAC1B,yEAAmE;AACnE,gDAAqE;AACrE,wEAAkE;AAClE,qDAA2D;AAC3D,4FAAuF;AACvF,4EAAsE;AACtE,qHAA+G;AAC/G,8EAAwE;AACxE,uGAAiG;AACjG,0EAAoE;AACpE,0DAAoD;AAKpD,MAAM,mBAAmB,GAAG,CAAC,EAAE,QAAQ,EAAiC,EAAE,EAAE;IAC1E,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,IAAA,oBAAO,GAAE,CAAC;IACtC,OAAO,CACL,8BAAC,8BAAY,IACX,OAAO,EAAE,IAAI,gCAAmB,EAAE,EAClC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,OAAO,IAEf,QAAQ,CACI,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,MAAM,0BAA0B,GAAG,CAAC,EAClC,QAAQ,EACR,GAAG,KAAK,EACe,EAAE,EAAE;IAC3B,MAAM,WAAW,GAAG,IAAA,gEAA6B,GAAE,CAAC;IACpD,OAAO,CACL,8BAAC,oCAAe,OAAK,WAAW;QAC9B,8BAAC,kCAAc,IAAC,UAAU,EAAE,KAAK,CAAC,UAAU;YAC1C,8BAAC,8BAAY,OACP,KAAK,EACT,YAAY,EAAE,IAAI,yCAA+B,EAAE;gBAEnD,8BAAC,gCAAa;oBACZ,8BAAC,mBAAmB,QAAE,QAAQ,CAAuB,CACvC,CACH,CACA,CACD,CACnB,CAAC;AACJ,CAAC,CAAC;AACF,MAAM,iBAAiB,GAAG,CAAC,EAAE,QAAQ,EAAE,GAAG,KAAK,EAA0B,EAAE,EAAE;IAC3E,OAAO,CACL,8BAAC,mDAAuB,IACtB,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,WAAW,EACvC,QAAQ,EAAE,KAAK,EAAE,QAAQ,EACzB,WAAW,EAAE,KAAK,EAAE,WAAW,EAC/B,KAAK,EAAE,KAAK,EAAE,KAAK;QAEnB,8BAAC,0EAAkC;YACjC,8BAAC,0BAA0B,OAAK,KAAK,IAClC,QAAQ,CACkB,CACM,CACb,CAC3B,CAAC;AACJ,CAAC,CAAC;AAEO,8CAAiB","sourcesContent":["\"use client\";\nimport React from \"react\";\nimport { AuthProvider } from \"@/reactjs/providers/AuthProvider.js\";\nimport { BrowserPublicClientPKCEProducer } from \"@/services/PKCE.js\";\nimport { UserProvider } from \"@/shared/providers/UserProvider.js\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport { CivicAuthConfigProvider } from \"@/shared/providers/CivicAuthConfigContext.js\";\nimport { IframeProvider } from \"@/shared/providers/IframeProvider.js\";\nimport { ClientTokenExchangeSessionProvider } from \"@/reactjs/providers/ClientTokenExchangeSessionProvider.js\";\nimport { SessionProvider } from \"@/shared/providers/SessionProvider.js\";\nimport { useClientTokenExchangeSession } from \"@/reactjs/hooks/useClientTokenExchangeSession.js\";\nimport { TokenProvider } from \"@/shared/providers/TokenProvider.js\";\nimport { useAuth } from \"@/shared/hooks/useAuth.js\";\nimport type { AuthProviderProps } from \"@/shared/providers/types.js\";\n\ntype CivicAuthProviderProps = Omit<AuthProviderProps, \"pkceConsumer\">;\n\nconst WrapperUserProvider = ({ children }: { children: React.ReactNode }) => {\n const { signIn, signOut } = useAuth();\n return (\n <UserProvider\n storage={new LocalStorageAdapter()}\n signIn={signIn}\n signOut={signOut}\n >\n {children}\n </UserProvider>\n );\n};\nconst WrapperSessionAuthProvider = ({\n children,\n ...props\n}: CivicAuthProviderProps) => {\n const sessionData = useClientTokenExchangeSession();\n return (\n <SessionProvider {...sessionData}>\n <IframeProvider iframeMode={props.iframeMode}>\n <AuthProvider\n {...props}\n pkceConsumer={new BrowserPublicClientPKCEProducer()}\n >\n <TokenProvider>\n <WrapperUserProvider>{children}</WrapperUserProvider>\n </TokenProvider>\n </AuthProvider>\n </IframeProvider>\n </SessionProvider>\n );\n};\nconst CivicAuthProvider = ({ children, ...props }: CivicAuthProviderProps) => {\n return (\n <CivicAuthConfigProvider\n oauthServer={props?.config?.oauthServer}\n clientId={props?.clientId}\n redirectUrl={props?.redirectUrl}\n nonce={props?.nonce}\n >\n <ClientTokenExchangeSessionProvider>\n <WrapperSessionAuthProvider {...props}>\n {children}\n </WrapperSessionAuthProvider>\n </ClientTokenExchangeSessionProvider>\n </CivicAuthConfigProvider>\n );\n};\n\nexport { CivicAuthProvider, type CivicAuthProviderProps };\n"]}
@@ -0,0 +1,17 @@
1
+ import type { ReactNode } from "react";
2
+ import React from "react";
3
+ import type { SessionData } from "../../types.js";
4
+ export type ClientTokenExchangeSessionProviderOutput = {
5
+ data: SessionData | null;
6
+ error: Error | null;
7
+ isLoading: boolean;
8
+ doTokenExchange: null | ((url: string) => Promise<void>);
9
+ };
10
+ declare const ClientTokenExchangeSessionContext: React.Context<ClientTokenExchangeSessionProviderOutput>;
11
+ type ClientTokenExchangeSessionContextType = {
12
+ children: ReactNode;
13
+ };
14
+ declare const ClientTokenExchangeSessionProvider: ({ children, }: ClientTokenExchangeSessionContextType) => React.JSX.Element;
15
+ export type { ClientTokenExchangeSessionContextType as SessionContextType };
16
+ export { ClientTokenExchangeSessionProvider, ClientTokenExchangeSessionContext, };
17
+ //# sourceMappingURL=ClientTokenExchangeSessionProvider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ClientTokenExchangeSessionProvider.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/providers/ClientTokenExchangeSessionProvider.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAMN,MAAM,OAAO,CAAC;AAIf,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAM9C,MAAM,MAAM,wCAAwC,GAAG;IACrD,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC;IACzB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,SAAS,EAAE,OAAO,CAAC;IACnB,eAAe,EAAE,IAAI,GAAG,CAAC,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;CAC1D,CAAC;AAcF,QAAA,MAAM,iCAAiC,yDACkC,CAAC;AAE1E,KAAK,qCAAqC,GAAG;IAC3C,QAAQ,EAAE,SAAS,CAAC;CACrB,CAAC;AAEF,QAAA,MAAM,kCAAkC,kBAErC,qCAAqC,sBA+IvC,CAAC;AAEF,YAAY,EAAE,qCAAqC,IAAI,kBAAkB,EAAE,CAAC;AAC5E,OAAO,EACL,kCAAkC,EAClC,iCAAiC,GAClC,CAAC"}
@@ -0,0 +1,183 @@
1
+ "use strict";
2
+ "use client";
3
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
4
+ if (k2 === undefined) k2 = k;
5
+ var desc = Object.getOwnPropertyDescriptor(m, k);
6
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
7
+ desc = { enumerable: true, get: function() { return m[k]; } };
8
+ }
9
+ Object.defineProperty(o, k2, desc);
10
+ }) : (function(o, m, k, k2) {
11
+ if (k2 === undefined) k2 = k;
12
+ o[k2] = m[k];
13
+ }));
14
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
15
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
16
+ }) : function(o, v) {
17
+ o["default"] = v;
18
+ });
19
+ var __importStar = (this && this.__importStar) || (function () {
20
+ var ownKeys = function(o) {
21
+ ownKeys = Object.getOwnPropertyNames || function (o) {
22
+ var ar = [];
23
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
24
+ return ar;
25
+ };
26
+ return ownKeys(o);
27
+ };
28
+ return function (mod) {
29
+ if (mod && mod.__esModule) return mod;
30
+ var result = {};
31
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
32
+ __setModuleDefault(result, mod);
33
+ return result;
34
+ };
35
+ })();
36
+ Object.defineProperty(exports, "__esModule", { value: true });
37
+ exports.ClientTokenExchangeSessionContext = exports.ClientTokenExchangeSessionProvider = void 0;
38
+ const react_1 = __importStar(require("react"));
39
+ const AuthenticationService_js_1 = require("../../services/AuthenticationService.js");
40
+ const windowUtil_js_1 = require("../../lib/windowUtil.js");
41
+ const useCurrentUrl_js_1 = require("../../shared/hooks/useCurrentUrl.js");
42
+ const useCivicAuthConfig_js_1 = require("../../shared/hooks/useCivicAuthConfig.js");
43
+ const storage_js_1 = require("../../browser/storage.js");
44
+ const useRefresh_js_1 = require("../../shared/hooks/useRefresh.js");
45
+ const defaultSession = {
46
+ data: {
47
+ authenticated: false,
48
+ idToken: undefined,
49
+ accessToken: undefined,
50
+ displayMode: "iframe",
51
+ },
52
+ error: null,
53
+ isLoading: false,
54
+ doTokenExchange: null,
55
+ };
56
+ // Context for exposing session specifically to the TokenProvider
57
+ const ClientTokenExchangeSessionContext = (0, react_1.createContext)(defaultSession);
58
+ exports.ClientTokenExchangeSessionContext = ClientTokenExchangeSessionContext;
59
+ const ClientTokenExchangeSessionProvider = ({ children, }) => {
60
+ const authConfig = (0, useCivicAuthConfig_js_1.useCivicAuthConfig)();
61
+ const [authService, setAuthService] = (0, react_1.useState)();
62
+ const [error, setError] = (0, react_1.useState)(null);
63
+ const [isLoading, setIsLoading] = (0, react_1.useState)(false);
64
+ const [session, setSession] = (0, react_1.useState)(null);
65
+ const [isWindowFocused, setIsWindowFocused] = (0, react_1.useState)(true);
66
+ (0, useRefresh_js_1.useRefresh)(session);
67
+ // handle the window refocusing after redirect
68
+ (0, react_1.useEffect)(() => {
69
+ const handleFocus = () => {
70
+ setIsWindowFocused(true);
71
+ };
72
+ const handleBlur = () => {
73
+ setIsWindowFocused(false);
74
+ };
75
+ window.addEventListener("focus", handleFocus);
76
+ window.addEventListener("blur", handleBlur);
77
+ return () => {
78
+ window.removeEventListener("focus", handleFocus);
79
+ window.removeEventListener("blur", handleBlur);
80
+ };
81
+ }, []);
82
+ const currentUrl = (0, useCurrentUrl_js_1.useCurrentUrl)();
83
+ (0, react_1.useEffect)(() => {
84
+ if (!currentUrl || !authConfig)
85
+ return;
86
+ const { redirectUrl, clientId, oauthServer, scopes } = authConfig;
87
+ AuthenticationService_js_1.BrowserAuthenticationService.build({
88
+ clientId,
89
+ redirectUrl,
90
+ oauthServer,
91
+ scopes,
92
+ displayMode: "iframe",
93
+ }).then(setAuthService);
94
+ }, [currentUrl, authConfig]);
95
+ const isInIframe = (0, windowUtil_js_1.isWindowInIframe)(globalThis.window);
96
+ const doTokenExchange = (0, react_1.useCallback)(async (inUrl) => {
97
+ if (!authService)
98
+ return;
99
+ const url = new URL(inUrl);
100
+ const code = url.searchParams.get("code");
101
+ const state = url.searchParams.get("state");
102
+ if (code && state) {
103
+ try {
104
+ setIsLoading(true);
105
+ await authService.tokenExchange(code, state);
106
+ }
107
+ catch (error) {
108
+ setError(error);
109
+ setSession({ authenticated: false });
110
+ }
111
+ setIsLoading(false);
112
+ }
113
+ }, [authService]);
114
+ const onSignIn = (0, react_1.useCallback)(async () => {
115
+ if (!authService)
116
+ return;
117
+ const session = await authService.getSessionData();
118
+ setSession(session);
119
+ }, [authService]);
120
+ const onSignOut = (0, react_1.useCallback)(() => {
121
+ setSession({ authenticated: false });
122
+ }, []);
123
+ (0, react_1.useEffect)(() => {
124
+ storage_js_1.LocalStorageAdapter.emitter.on("signIn", onSignIn);
125
+ storage_js_1.LocalStorageAdapter.emitter.on("signOut", onSignOut);
126
+ return () => {
127
+ storage_js_1.LocalStorageAdapter.emitter.off("signIn", onSignIn);
128
+ storage_js_1.LocalStorageAdapter.emitter.off("signOut", onSignOut);
129
+ };
130
+ }, [onSignIn, onSignOut]);
131
+ (0, react_1.useEffect)(() => {
132
+ if (!authConfig) {
133
+ setIsLoading(true);
134
+ }
135
+ else {
136
+ setIsLoading(false);
137
+ }
138
+ }, [authConfig]);
139
+ // Handle page load or refocus
140
+ (0, react_1.useEffect)(() => {
141
+ if (!authConfig || !authService || !currentUrl || isInIframe || isLoading) {
142
+ return;
143
+ }
144
+ const abortController = new AbortController();
145
+ const onPageLoad = async () => {
146
+ // if we have existing tokens, then validate them and return the session data
147
+ // otherwise check if we have a code in the url and exchange it for tokens
148
+ // if we have neither, return undefined
149
+ const existingSessionData = await authService.validateExistingSession();
150
+ if (existingSessionData.authenticated) {
151
+ setSession(existingSessionData);
152
+ return;
153
+ }
154
+ if (abortController.signal.aborted ||
155
+ !new URL(currentUrl).searchParams.get("code")) {
156
+ return;
157
+ }
158
+ await doTokenExchange(currentUrl);
159
+ };
160
+ onPageLoad();
161
+ return () => {
162
+ abortController.abort();
163
+ };
164
+ }, [
165
+ authConfig,
166
+ authService,
167
+ currentUrl,
168
+ doTokenExchange,
169
+ isInIframe,
170
+ isLoading,
171
+ isWindowFocused,
172
+ session?.authenticated,
173
+ ]);
174
+ const value = (0, react_1.useMemo)(() => ({
175
+ data: session,
176
+ error,
177
+ isLoading,
178
+ doTokenExchange,
179
+ }), [session, error, isLoading, doTokenExchange]);
180
+ return (react_1.default.createElement(ClientTokenExchangeSessionContext.Provider, { value: value }, children));
181
+ };
182
+ exports.ClientTokenExchangeSessionProvider = ClientTokenExchangeSessionProvider;
183
+ //# sourceMappingURL=ClientTokenExchangeSessionProvider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ClientTokenExchangeSessionProvider.js","sourceRoot":"","sources":["../../../../src/reactjs/providers/ClientTokenExchangeSessionProvider.tsx"],"names":[],"mappings":"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","sourcesContent":["\"use client\";\nimport type { ReactNode } from \"react\";\nimport React, {\n createContext,\n useCallback,\n useEffect,\n useMemo,\n useState,\n} from \"react\";\nimport { BrowserAuthenticationService } from \"@/services/AuthenticationService.js\";\nimport type { AuthenticationResolver } from \"@/services/types.js\";\nimport { isWindowInIframe } from \"@/lib/windowUtil.js\";\nimport type { SessionData } from \"@/types.js\";\nimport { useCurrentUrl } from \"@/shared/hooks/useCurrentUrl.js\";\nimport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nimport { LocalStorageAdapter } from \"@/browser/storage.js\";\nimport { useRefresh } from \"../../shared/hooks/useRefresh.js\";\n\nexport type ClientTokenExchangeSessionProviderOutput = {\n data: SessionData | null;\n error: Error | null;\n isLoading: boolean;\n doTokenExchange: null | ((url: string) => Promise<void>);\n};\nconst defaultSession: ClientTokenExchangeSessionProviderOutput = {\n data: {\n authenticated: false,\n idToken: undefined,\n accessToken: undefined,\n displayMode: \"iframe\",\n },\n error: null,\n isLoading: false,\n doTokenExchange: null,\n};\n\n// Context for exposing session specifically to the TokenProvider\nconst ClientTokenExchangeSessionContext =\n createContext<ClientTokenExchangeSessionProviderOutput>(defaultSession);\n\ntype ClientTokenExchangeSessionContextType = {\n children: ReactNode;\n};\n\nconst ClientTokenExchangeSessionProvider = ({\n children,\n}: ClientTokenExchangeSessionContextType) => {\n const authConfig = useCivicAuthConfig();\n const [authService, setAuthService] = useState<AuthenticationResolver>();\n const [error, setError] = useState<Error | null>(null);\n const [isLoading, setIsLoading] = useState(false);\n const [session, setSession] = useState<SessionData | null>(null);\n const [isWindowFocused, setIsWindowFocused] = useState(true);\n\n useRefresh(session);\n // handle the window refocusing after redirect\n useEffect(() => {\n const handleFocus = () => {\n setIsWindowFocused(true);\n };\n\n const handleBlur = () => {\n setIsWindowFocused(false);\n };\n window.addEventListener(\"focus\", handleFocus);\n window.addEventListener(\"blur\", handleBlur);\n\n return () => {\n window.removeEventListener(\"focus\", handleFocus);\n window.removeEventListener(\"blur\", handleBlur);\n };\n }, []);\n\n const currentUrl = useCurrentUrl();\n\n useEffect(() => {\n if (!currentUrl || !authConfig) return;\n\n const { redirectUrl, clientId, oauthServer, scopes } = authConfig;\n BrowserAuthenticationService.build({\n clientId,\n redirectUrl,\n oauthServer,\n scopes,\n displayMode: \"iframe\",\n }).then(setAuthService);\n }, [currentUrl, authConfig]);\n\n const isInIframe = isWindowInIframe(globalThis.window);\n\n const doTokenExchange = useCallback(\n async (inUrl: string) => {\n if (!authService) return;\n const url = new URL(inUrl);\n const code = url.searchParams.get(\"code\");\n const state = url.searchParams.get(\"state\");\n if (code && state) {\n try {\n setIsLoading(true);\n await authService.tokenExchange(code, state);\n } catch (error) {\n setError(error as Error);\n setSession({ authenticated: false });\n }\n setIsLoading(false);\n }\n },\n [authService],\n );\n\n const onSignIn = useCallback(async () => {\n if (!authService) return;\n const session = await authService.getSessionData();\n setSession(session);\n }, [authService]);\n\n const onSignOut = useCallback(() => {\n setSession({ authenticated: false });\n }, []);\n\n useEffect(() => {\n LocalStorageAdapter.emitter.on(\"signIn\", onSignIn);\n LocalStorageAdapter.emitter.on(\"signOut\", onSignOut);\n return () => {\n LocalStorageAdapter.emitter.off(\"signIn\", onSignIn);\n LocalStorageAdapter.emitter.off(\"signOut\", onSignOut);\n };\n }, [onSignIn, onSignOut]);\n\n useEffect(() => {\n if (!authConfig) {\n setIsLoading(true);\n } else {\n setIsLoading(false);\n }\n }, [authConfig]);\n // Handle page load or refocus\n useEffect(() => {\n if (!authConfig || !authService || !currentUrl || isInIframe || isLoading) {\n return;\n }\n const abortController = new AbortController();\n const onPageLoad = async () => {\n // if we have existing tokens, then validate them and return the session data\n // otherwise check if we have a code in the url and exchange it for tokens\n // if we have neither, return undefined\n const existingSessionData = await authService.validateExistingSession();\n if (existingSessionData.authenticated) {\n setSession(existingSessionData);\n return;\n }\n if (\n abortController.signal.aborted ||\n !new URL(currentUrl).searchParams.get(\"code\")\n ) {\n return;\n }\n await doTokenExchange(currentUrl);\n };\n onPageLoad();\n return () => {\n abortController.abort();\n };\n }, [\n authConfig,\n authService,\n currentUrl,\n doTokenExchange,\n isInIframe,\n isLoading,\n isWindowFocused,\n session?.authenticated,\n ]);\n\n const value = useMemo(\n () => ({\n data: session,\n error,\n isLoading,\n doTokenExchange,\n }),\n [session, error, isLoading, doTokenExchange],\n );\n\n return (\n <ClientTokenExchangeSessionContext.Provider value={value}>\n {children}\n </ClientTokenExchangeSessionContext.Provider>\n );\n};\n\nexport type { ClientTokenExchangeSessionContextType as SessionContextType };\nexport {\n ClientTokenExchangeSessionProvider,\n ClientTokenExchangeSessionContext,\n};\n"]}
@@ -1,8 +1,8 @@
1
1
  export { UserProvider, UserContext, type UserContextType, } from "../../shared/providers/UserProvider.js";
2
2
  export { TokenProvider, TokenContext, type TokenContextType, } from "../../shared/providers/TokenProvider.js";
3
- export { AuthProvider } from "../../shared/providers/AuthProvider.js";
3
+ export { AuthProvider } from "../../reactjs/providers/AuthProvider.js";
4
4
  export { SessionProvider, SessionContext, type SessionContextType, } from "../../shared/providers/SessionProvider.js";
5
- export { CivicAuthProvider, type CivicAuthProviderProps, } from "../../shared/providers/CivicAuthProvider.js";
5
+ export { CivicAuthProvider, type CivicAuthProviderProps, } from "../../reactjs/providers/CivicAuthProvider.js";
6
6
  export { AuthContext } from "../../shared/providers/AuthContext.js";
7
7
  export type { AuthContextType } from "../../shared/providers/AuthContext.js";
8
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/providers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,WAAW,EACX,KAAK,eAAe,GACrB,MAAM,oCAAoC,CAAC;AAE5C,OAAO,EACL,aAAa,EACb,YAAY,EACZ,KAAK,gBAAgB,GACtB,MAAM,qCAAqC,CAAC;AAE7C,OAAO,EAAE,YAAY,EAAE,MAAM,oCAAoC,CAAC;AAElE,OAAO,EACL,eAAe,EACf,cAAc,EACd,KAAK,kBAAkB,GACxB,MAAM,uCAAuC,CAAC;AAE/C,OAAO,EACL,iBAAiB,EACjB,KAAK,sBAAsB,GAC5B,MAAM,yCAAyC,CAAC;AAEjD,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAChE,YAAY,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/reactjs/providers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,WAAW,EACX,KAAK,eAAe,GACrB,MAAM,oCAAoC,CAAC;AAE5C,OAAO,EACL,aAAa,EACb,YAAY,EACZ,KAAK,gBAAgB,GACtB,MAAM,qCAAqC,CAAC;AAE7C,OAAO,EAAE,YAAY,EAAE,MAAM,qCAAqC,CAAC;AAEnE,OAAO,EACL,eAAe,EACf,cAAc,EACd,KAAK,kBAAkB,GACxB,MAAM,uCAAuC,CAAC;AAE/C,OAAO,EACL,iBAAiB,EACjB,KAAK,sBAAsB,GAC5B,MAAM,0CAA0C,CAAC;AAElD,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAChE,YAAY,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC"}
@@ -7,12 +7,12 @@ Object.defineProperty(exports, "UserContext", { enumerable: true, get: function
7
7
  var TokenProvider_js_1 = require("../../shared/providers/TokenProvider.js");
8
8
  Object.defineProperty(exports, "TokenProvider", { enumerable: true, get: function () { return TokenProvider_js_1.TokenProvider; } });
9
9
  Object.defineProperty(exports, "TokenContext", { enumerable: true, get: function () { return TokenProvider_js_1.TokenContext; } });
10
- var AuthProvider_js_1 = require("../../shared/providers/AuthProvider.js");
10
+ var AuthProvider_js_1 = require("../../reactjs/providers/AuthProvider.js");
11
11
  Object.defineProperty(exports, "AuthProvider", { enumerable: true, get: function () { return AuthProvider_js_1.AuthProvider; } });
12
12
  var SessionProvider_js_1 = require("../../shared/providers/SessionProvider.js");
13
13
  Object.defineProperty(exports, "SessionProvider", { enumerable: true, get: function () { return SessionProvider_js_1.SessionProvider; } });
14
14
  Object.defineProperty(exports, "SessionContext", { enumerable: true, get: function () { return SessionProvider_js_1.SessionContext; } });
15
- var CivicAuthProvider_js_1 = require("../../shared/providers/CivicAuthProvider.js");
15
+ var CivicAuthProvider_js_1 = require("../../reactjs/providers/CivicAuthProvider.js");
16
16
  Object.defineProperty(exports, "CivicAuthProvider", { enumerable: true, get: function () { return CivicAuthProvider_js_1.CivicAuthProvider; } });
17
17
  var AuthContext_js_1 = require("../../shared/providers/AuthContext.js");
18
18
  Object.defineProperty(exports, "AuthContext", { enumerable: true, get: function () { return AuthContext_js_1.AuthContext; } });
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/reactjs/providers/index.ts"],"names":[],"mappings":";;;AAAA,sEAI4C;AAH1C,+GAAA,YAAY,OAAA;AACZ,8GAAA,WAAW,OAAA;AAIb,wEAI6C;AAH3C,iHAAA,aAAa,OAAA;AACb,gHAAA,YAAY,OAAA;AAId,sEAAkE;AAAzD,+GAAA,YAAY,OAAA;AAErB,4EAI+C;AAH7C,qHAAA,eAAe,OAAA;AACf,oHAAA,cAAc,OAAA;AAIhB,gFAGiD;AAF/C,yHAAA,iBAAiB,OAAA;AAInB,oEAAgE;AAAvD,6GAAA,WAAW,OAAA","sourcesContent":["export {\n UserProvider,\n UserContext,\n type UserContextType,\n} from \"@/shared/providers/UserProvider.js\";\n\nexport {\n TokenProvider,\n TokenContext,\n type TokenContextType,\n} from \"@/shared/providers/TokenProvider.js\";\n\nexport { AuthProvider } from \"@/shared/providers/AuthProvider.js\";\n\nexport {\n SessionProvider,\n SessionContext,\n type SessionContextType,\n} from \"@/shared/providers/SessionProvider.js\";\n\nexport {\n CivicAuthProvider,\n type CivicAuthProviderProps,\n} from \"@/shared/providers/CivicAuthProvider.js\";\n\nexport { AuthContext } from \"@/shared/providers/AuthContext.js\";\nexport type { AuthContextType } from \"@/shared/providers/AuthContext.js\";\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/reactjs/providers/index.ts"],"names":[],"mappings":";;;AAAA,sEAI4C;AAH1C,+GAAA,YAAY,OAAA;AACZ,8GAAA,WAAW,OAAA;AAIb,wEAI6C;AAH3C,iHAAA,aAAa,OAAA;AACb,gHAAA,YAAY,OAAA;AAId,uEAAmE;AAA1D,+GAAA,YAAY,OAAA;AAErB,4EAI+C;AAH7C,qHAAA,eAAe,OAAA;AACf,oHAAA,cAAc,OAAA;AAIhB,iFAGkD;AAFhD,yHAAA,iBAAiB,OAAA;AAInB,oEAAgE;AAAvD,6GAAA,WAAW,OAAA","sourcesContent":["export {\n UserProvider,\n UserContext,\n type UserContextType,\n} from \"@/shared/providers/UserProvider.js\";\n\nexport {\n TokenProvider,\n TokenContext,\n type TokenContextType,\n} from \"@/shared/providers/TokenProvider.js\";\n\nexport { AuthProvider } from \"@/reactjs/providers/AuthProvider.js\";\n\nexport {\n SessionProvider,\n SessionContext,\n type SessionContextType,\n} from \"@/shared/providers/SessionProvider.js\";\n\nexport {\n CivicAuthProvider,\n type CivicAuthProviderProps,\n} from \"@/reactjs/providers/CivicAuthProvider.js\";\n\nexport { AuthContext } from \"@/shared/providers/AuthContext.js\";\nexport type { AuthContextType } from \"@/shared/providers/AuthContext.js\";\n"]}
@@ -5,5 +5,7 @@ export { useSession } from "../../shared/hooks/useSession.js";
5
5
  export { useCivicAuthConfig } from "../../shared/hooks/useCivicAuthConfig.js";
6
6
  export { useOAuthEndpoints } from "../../shared/hooks/useOAuthEndpoints.js";
7
7
  export { useCurrentUrl } from "../../shared/hooks/useCurrentUrl.js";
8
- export { useClientTokenExchangeSession } from "../../shared/hooks/useClientTokenExchangeSession.js";
8
+ export { useClientTokenExchangeSession } from "../../reactjs/hooks/useClientTokenExchangeSession.js";
9
+ export { useWindowFocused } from "../../shared/hooks/useWindowFocused.js";
10
+ export { useRefresh } from "../../shared/hooks/useRefresh.js";
9
11
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,6BAA6B,EAAE,MAAM,iDAAiD,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AACxD,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,EAAE,6BAA6B,EAAE,MAAM,kDAAkD,CAAC;AACjG,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useClientTokenExchangeSession = exports.useCurrentUrl = exports.useOAuthEndpoints = exports.useCivicAuthConfig = exports.useSession = exports.useIframe = exports.useAuth = exports.useToken = void 0;
3
+ exports.useRefresh = exports.useWindowFocused = exports.useClientTokenExchangeSession = exports.useCurrentUrl = exports.useOAuthEndpoints = exports.useCivicAuthConfig = exports.useSession = exports.useIframe = exports.useAuth = exports.useToken = void 0;
4
4
  var useToken_js_1 = require("../../shared/hooks/useToken.js");
5
5
  Object.defineProperty(exports, "useToken", { enumerable: true, get: function () { return useToken_js_1.useToken; } });
6
6
  var useAuth_js_1 = require("../../shared/hooks/useAuth.js");
@@ -15,6 +15,10 @@ var useOAuthEndpoints_js_1 = require("../../shared/hooks/useOAuthEndpoints.js");
15
15
  Object.defineProperty(exports, "useOAuthEndpoints", { enumerable: true, get: function () { return useOAuthEndpoints_js_1.useOAuthEndpoints; } });
16
16
  var useCurrentUrl_js_1 = require("../../shared/hooks/useCurrentUrl.js");
17
17
  Object.defineProperty(exports, "useCurrentUrl", { enumerable: true, get: function () { return useCurrentUrl_js_1.useCurrentUrl; } });
18
- var useClientTokenExchangeSession_js_1 = require("../../shared/hooks/useClientTokenExchangeSession.js");
18
+ var useClientTokenExchangeSession_js_1 = require("../../reactjs/hooks/useClientTokenExchangeSession.js");
19
19
  Object.defineProperty(exports, "useClientTokenExchangeSession", { enumerable: true, get: function () { return useClientTokenExchangeSession_js_1.useClientTokenExchangeSession; } });
20
+ var useWindowFocused_js_1 = require("../../shared/hooks/useWindowFocused.js");
21
+ Object.defineProperty(exports, "useWindowFocused", { enumerable: true, get: function () { return useWindowFocused_js_1.useWindowFocused; } });
22
+ var useRefresh_js_1 = require("../../shared/hooks/useRefresh.js");
23
+ Object.defineProperty(exports, "useRefresh", { enumerable: true, get: function () { return useRefresh_js_1.useRefresh; } });
20
24
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/shared/hooks/index.ts"],"names":[],"mappings":";;;AAAA,0DAAsD;AAA7C,uGAAA,QAAQ,OAAA;AACjB,wDAAoD;AAA3C,qGAAA,OAAO,OAAA;AAChB,4DAAwD;AAA/C,yGAAA,SAAS,OAAA;AAClB,8DAA0D;AAAjD,2GAAA,UAAU,OAAA;AACnB,8EAA0E;AAAjE,2HAAA,kBAAkB,OAAA;AAC3B,4EAAwE;AAA/D,yHAAA,iBAAiB,OAAA;AAC1B,oEAAgE;AAAvD,iHAAA,aAAa,OAAA;AACtB,oGAAgG;AAAvF,iJAAA,6BAA6B,OAAA","sourcesContent":["export { useToken } from \"@/shared/hooks/useToken.js\";\nexport { useAuth } from \"@/shared/hooks/useAuth.js\";\nexport { useIframe } from \"@/shared/hooks/useIframe.js\";\nexport { useSession } from \"@/shared/hooks/useSession.js\";\nexport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nexport { useOAuthEndpoints } from \"@/shared/hooks/useOAuthEndpoints.js\";\nexport { useCurrentUrl } from \"@/shared/hooks/useCurrentUrl.js\";\nexport { useClientTokenExchangeSession } from \"@/shared/hooks/useClientTokenExchangeSession.js\";\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/shared/hooks/index.ts"],"names":[],"mappings":";;;AAAA,0DAAsD;AAA7C,uGAAA,QAAQ,OAAA;AACjB,wDAAoD;AAA3C,qGAAA,OAAO,OAAA;AAChB,4DAAwD;AAA/C,yGAAA,SAAS,OAAA;AAClB,8DAA0D;AAAjD,2GAAA,UAAU,OAAA;AACnB,8EAA0E;AAAjE,2HAAA,kBAAkB,OAAA;AAC3B,4EAAwE;AAA/D,yHAAA,iBAAiB,OAAA;AAC1B,oEAAgE;AAAvD,iHAAA,aAAa,OAAA;AACtB,qGAAiG;AAAxF,iJAAA,6BAA6B,OAAA;AACtC,0EAAsE;AAA7D,uHAAA,gBAAgB,OAAA;AACzB,8DAA0D;AAAjD,2GAAA,UAAU,OAAA","sourcesContent":["export { useToken } from \"@/shared/hooks/useToken.js\";\nexport { useAuth } from \"@/shared/hooks/useAuth.js\";\nexport { useIframe } from \"@/shared/hooks/useIframe.js\";\nexport { useSession } from \"@/shared/hooks/useSession.js\";\nexport { useCivicAuthConfig } from \"@/shared/hooks/useCivicAuthConfig.js\";\nexport { useOAuthEndpoints } from \"@/shared/hooks/useOAuthEndpoints.js\";\nexport { useCurrentUrl } from \"@/shared/hooks/useCurrentUrl.js\";\nexport { useClientTokenExchangeSession } from \"@/reactjs/hooks/useClientTokenExchangeSession.js\";\nexport { useWindowFocused } from \"@/shared/hooks/useWindowFocused.js\";\nexport { useRefresh } from \"@/shared/hooks/useRefresh.js\";\n"]}
@@ -0,0 +1,5 @@
1
+ declare const useWindowFocused: () => {
2
+ isWindowFocused: boolean;
3
+ };
4
+ export { useWindowFocused };
5
+ //# sourceMappingURL=useWindowFocused.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useWindowFocused.d.ts","sourceRoot":"","sources":["../../../../src/shared/hooks/useWindowFocused.ts"],"names":[],"mappings":"AAEA,QAAA,MAAM,gBAAgB;;CAmBrB,CAAC;AACF,OAAO,EAAE,gBAAgB,EAAE,CAAC"}
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useWindowFocused = void 0;
4
+ const react_1 = require("react");
5
+ const useWindowFocused = () => {
6
+ const [isWindowFocused, setIsWindowFocused] = (0, react_1.useState)(true);
7
+ (0, react_1.useEffect)(() => {
8
+ const handleFocus = () => {
9
+ setIsWindowFocused(true);
10
+ };
11
+ const handleBlur = () => {
12
+ setIsWindowFocused(false);
13
+ };
14
+ window.addEventListener("focus", handleFocus);
15
+ window.addEventListener("blur", handleBlur);
16
+ return () => {
17
+ window.removeEventListener("focus", handleFocus);
18
+ window.removeEventListener("blur", handleBlur);
19
+ };
20
+ }, []);
21
+ return { isWindowFocused };
22
+ };
23
+ exports.useWindowFocused = useWindowFocused;
24
+ //# sourceMappingURL=useWindowFocused.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useWindowFocused.js","sourceRoot":"","sources":["../../../../src/shared/hooks/useWindowFocused.ts"],"names":[],"mappings":";;;AAAA,iCAA4C;AAE5C,MAAM,gBAAgB,GAAG,GAAG,EAAE;IAC5B,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,IAAA,gBAAQ,EAAC,IAAI,CAAC,CAAC;IAC7D,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,MAAM,WAAW,GAAG,GAAG,EAAE;YACvB,kBAAkB,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC,CAAC;QAEF,MAAM,UAAU,GAAG,GAAG,EAAE;YACtB,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC,CAAC;QACF,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;QAC9C,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAE5C,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;YACjD,MAAM,CAAC,mBAAmB,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QACjD,CAAC,CAAC;IACJ,CAAC,EAAE,EAAE,CAAC,CAAC;IACP,OAAO,EAAE,eAAe,EAAE,CAAC;AAC7B,CAAC,CAAC;AACO,4CAAgB","sourcesContent":["import { useEffect, useState } from \"react\";\n\nconst useWindowFocused = () => {\n const [isWindowFocused, setIsWindowFocused] = useState(true);\n useEffect(() => {\n const handleFocus = () => {\n setIsWindowFocused(true);\n };\n\n const handleBlur = () => {\n setIsWindowFocused(false);\n };\n window.addEventListener(\"focus\", handleFocus);\n window.addEventListener(\"blur\", handleBlur);\n\n return () => {\n window.removeEventListener(\"focus\", handleFocus);\n window.removeEventListener(\"blur\", handleBlur);\n };\n }, []);\n return { isWindowFocused };\n};\nexport { useWindowFocused };\n"]}