@tern-secure/nextjs 1.9.2 → 1.9.3

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.
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
- import { AuthState } from '../../../types/ternsecure';
3
- export declare const useTernSecure: () => AuthState;
2
+ import { TernSecureState } from '../../../types/ternsecure';
3
+ export declare const useTernSecure: () => TernSecureState;
4
4
  interface TernSecureClientProps {
5
5
  children: React.ReactNode;
6
6
  }
@@ -3,14 +3,19 @@ import React, { createContext, useContext, useEffect, useState } from 'react';
3
3
  import { getTernSecureAuth } from '../client-init';
4
4
  // Move context creation inside the client component
5
5
  const createTernSecureContext = () => {
6
- const initialAuthState = {
7
- user: null,
8
- loading: true,
9
- error: null,
10
- initialized: false,
11
- isSignedIn: false
6
+ const initialState = {
7
+ firebase: {
8
+ initialized: false,
9
+ error: null
10
+ },
11
+ auth: {
12
+ user: null,
13
+ loading: true,
14
+ error: null,
15
+ isSignedIn: false
16
+ }
12
17
  };
13
- return createContext(initialAuthState);
18
+ return createContext(initialState);
14
19
  };
15
20
  // Create context lazily only on client side
16
21
  const TernSecureContext = createTernSecureContext();
@@ -25,45 +30,67 @@ export const useTernSecure = () => {
25
30
  return context;
26
31
  };
27
32
  export function TernSecureClientProvider({ children }) {
28
- const [authState, setAuthState] = useState({
29
- user: null,
30
- loading: true,
31
- error: null,
32
- initialized: false,
33
- isSignedIn: false
33
+ const [state, setState] = useState({
34
+ firebase: {
35
+ initialized: false,
36
+ error: null
37
+ },
38
+ auth: {
39
+ user: null,
40
+ loading: true,
41
+ error: null,
42
+ isSignedIn: false
43
+ }
34
44
  });
35
45
  useEffect(() => {
36
46
  try {
37
47
  const auth = getTernSecureAuth();
38
- const unsubscribe = auth.onAuthStateChanged((user) => {
39
- setAuthState({
40
- user,
41
- loading: false,
42
- error: null,
48
+ setState(prev => ({
49
+ ...prev,
50
+ firebase: {
43
51
  initialized: true,
44
- isSignedIn: !!user
45
- });
52
+ error: null
53
+ }
54
+ }));
55
+ const unsubscribe = auth.onAuthStateChanged((user) => {
56
+ setState(prev => ({
57
+ ...prev,
58
+ auth: {
59
+ user,
60
+ loading: false,
61
+ error: null,
62
+ isSignedIn: !!user
63
+ }
64
+ }));
46
65
  }, (error) => {
47
- setAuthState({
48
- user: null,
49
- loading: false,
50
- error,
51
- initialized: true,
52
- isSignedIn: false
53
- });
66
+ setState(prev => ({
67
+ ...prev,
68
+ auth: {
69
+ user: null,
70
+ loading: false,
71
+ error,
72
+ isSignedIn: false
73
+ }
74
+ }));
54
75
  });
55
76
  return () => unsubscribe();
56
77
  }
57
78
  catch (error) {
58
- setAuthState({
59
- user: null,
60
- loading: false,
61
- error: error,
62
- initialized: true,
63
- isSignedIn: false
64
- });
79
+ setState(prev => ({
80
+ ...prev,
81
+ firebase: {
82
+ initialized: false,
83
+ error: error
84
+ },
85
+ auth: {
86
+ user: null,
87
+ loading: false,
88
+ error: error,
89
+ isSignedIn: false
90
+ }
91
+ }));
65
92
  }
66
93
  }, []);
67
- return (React.createElement(TernSecureContext.Provider, { value: authState }, children));
94
+ return (React.createElement(TernSecureContext.Provider, { value: state }, children));
68
95
  }
69
96
  //# sourceMappingURL=ternSecureClientProvider.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ternSecureClientProvider.js","sourceRoot":"","sources":["../../../../src/app-router/client/providers/ternSecureClientProvider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AAGlD,oDAAoD;AACpD,MAAM,uBAAuB,GAAG,GAAG,EAAE;IACnC,MAAM,gBAAgB,GAAc;QAClC,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,KAAK;QAClB,UAAU,EAAE,KAAK;KAClB,CAAA;IAED,OAAO,aAAa,CAAY,gBAAgB,CAAC,CAAA;AACnD,CAAC,CAAA;AAED,4CAA4C;AAC5C,MAAM,iBAAiB,GAAG,uBAAuB,EAAE,CAAA;AAEnD,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,EAAE;IAChC,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAA;IACxE,CAAC;IAED,MAAM,OAAO,GAAG,UAAU,CAAC,iBAAiB,CAAC,CAAA;IAC7C,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAA;IAC/E,CAAC;IACD,OAAO,OAAO,CAAA;AAChB,CAAC,CAAA;AAMD,MAAM,UAAU,wBAAwB,CAAC,EAAE,QAAQ,EAAyB;IAC1E,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAY;QACpD,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,KAAK;QAClB,UAAU,EAAE,KAAK;KAClB,CAAC,CAAA;IAEF,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,iBAAiB,EAAE,CAAA;YAChC,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CACzC,CAAC,IAAI,EAAE,EAAE;gBACP,YAAY,CAAC;oBACX,IAAI;oBACJ,OAAO,EAAE,KAAK;oBACd,KAAK,EAAE,IAAI;oBACX,WAAW,EAAE,IAAI;oBACjB,UAAU,EAAE,CAAC,CAAC,IAAI;iBACnB,CAAC,CAAA;YACJ,CAAC,EACD,CAAC,KAAK,EAAE,EAAE;gBACR,YAAY,CAAC;oBACX,IAAI,EAAE,IAAI;oBACV,OAAO,EAAE,KAAK;oBACd,KAAK;oBACL,WAAW,EAAE,IAAI;oBACjB,UAAU,EAAE,KAAK;iBAClB,CAAC,CAAA;YACJ,CAAC,CACF,CAAA;YAED,OAAO,GAAG,EAAE,CAAC,WAAW,EAAE,CAAA;QAC5B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,YAAY,CAAC;gBACX,IAAI,EAAE,IAAI;gBACV,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,KAAc;gBACrB,WAAW,EAAE,IAAI;gBACjB,UAAU,EAAE,KAAK;aAClB,CAAC,CAAA;QACJ,CAAC;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,CACL,oBAAC,iBAAiB,CAAC,QAAQ,IAAC,KAAK,EAAE,SAAS,IACzC,QAAQ,CACkB,CAC9B,CAAA;AACH,CAAC"}
1
+ {"version":3,"file":"ternSecureClientProvider.js","sourceRoot":"","sources":["../../../../src/app-router/client/providers/ternSecureClientProvider.tsx"],"names":[],"mappings":"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"}
@@ -2,6 +2,5 @@ export declare function useAuth(): {
2
2
  user: import("@firebase/auth").User | null;
3
3
  loading: boolean;
4
4
  error: Error | null;
5
- initialized: boolean;
6
5
  isSignedIn: boolean;
7
6
  };
@@ -5,14 +5,12 @@ export function useAuth() {
5
5
  user: null,
6
6
  loading: true,
7
7
  error: null,
8
- initialized: false,
9
8
  isSignedIn: false,
10
9
  });
11
10
  return {
12
11
  user: authState.user,
13
12
  loading: authState.loading,
14
13
  error: authState.error,
15
- initialized: authState.initialized,
16
14
  isSignedIn: authState.isSignedIn,
17
15
  };
18
16
  }
@@ -1 +1 @@
1
- {"version":3,"file":"useAuth.js","sourceRoot":"","sources":["../../src/hooks/useAuth.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAIjC,MAAM,UAAU,OAAO;IACrB,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAY;QACpD,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,KAAK;QAClB,UAAU,EAAE,KAAK;KAClB,CAAC,CAAC;IAGH,OAAO;QACL,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,OAAO,EAAE,SAAS,CAAC,OAAO;QAC1B,KAAK,EAAE,SAAS,CAAC,KAAK;QACtB,WAAW,EAAE,SAAS,CAAC,WAAW;QAClC,UAAU,EAAE,SAAS,CAAC,UAAU;KACjC,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"useAuth.js","sourceRoot":"","sources":["../../src/hooks/useAuth.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAIjC,MAAM,UAAU,OAAO;IACrB,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAY;QACpD,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,UAAU,EAAE,KAAK;KAClB,CAAC,CAAC;IAGH,OAAO;QACL,IAAI,EAAE,SAAS,CAAC,IAAI;QACpB,OAAO,EAAE,SAAS,CAAC,OAAO;QAC1B,KAAK,EAAE,SAAS,CAAC,KAAK;QACtB,UAAU,EAAE,SAAS,CAAC,UAAU;KACjC,CAAC;AACJ,CAAC"}
@@ -13,11 +13,18 @@ export interface TernSecureOptions {
13
13
  environment?: 'development' | 'production';
14
14
  region?: string;
15
15
  }
16
+ export interface FirebaseState {
17
+ initialized: boolean;
18
+ error: Error | null;
19
+ }
20
+ export interface TernSecureState {
21
+ firebase: FirebaseState;
22
+ auth: AuthState;
23
+ }
16
24
  export interface AuthState {
17
25
  user: User | null;
18
26
  loading: boolean;
19
27
  error: Error | null;
20
- initialized: boolean;
21
28
  isSignedIn: boolean;
22
29
  }
23
30
  export interface TernSecureContextValue {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tern-secure/nextjs",
3
- "version": "1.9.2",
3
+ "version": "1.9.3",
4
4
  "publishConfig": {
5
5
  "access": "public",
6
6
  "registry": "https://registry.npmjs.org/"