@23blocks/react 12.0.1 → 12.0.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.
- package/dist/index.esm.js +39 -38
- package/dist/src/lib/context.d.ts.map +1 -1
- package/dist/src/lib/hooks/use-mfa.d.ts +11 -11
- package/dist/src/lib/hooks/use-mfa.d.ts.map +1 -1
- package/dist/src/lib/hooks/use-oauth.d.ts +12 -10
- package/dist/src/lib/hooks/use-oauth.d.ts.map +1 -1
- package/dist/src/lib/simple-provider.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/index.esm.js
CHANGED
|
@@ -1508,26 +1508,26 @@ function useUniversityBlock() {
|
|
|
1508
1508
|
*
|
|
1509
1509
|
* @example
|
|
1510
1510
|
* ```tsx
|
|
1511
|
-
* function MfaSettings() {
|
|
1511
|
+
* function MfaSettings({ userUniqueId }: { userUniqueId: string }) {
|
|
1512
1512
|
* const { setup, enable, disable, getStatus, status, isLoading, error } = useMfa();
|
|
1513
1513
|
*
|
|
1514
1514
|
* useEffect(() => {
|
|
1515
|
-
* getStatus();
|
|
1516
|
-
* }, [getStatus]);
|
|
1515
|
+
* getStatus(userUniqueId);
|
|
1516
|
+
* }, [getStatus, userUniqueId]);
|
|
1517
1517
|
*
|
|
1518
1518
|
* const handleSetup = async () => {
|
|
1519
|
-
* const data = await setup();
|
|
1519
|
+
* const data = await setup(userUniqueId);
|
|
1520
1520
|
* // Show QR code from data.qrCodeUri
|
|
1521
1521
|
* };
|
|
1522
1522
|
*
|
|
1523
1523
|
* const handleEnable = async (code: string) => {
|
|
1524
|
-
* await enable({ totpCode: code });
|
|
1524
|
+
* await enable(userUniqueId, { totpCode: code });
|
|
1525
1525
|
* };
|
|
1526
1526
|
*
|
|
1527
1527
|
* return (
|
|
1528
1528
|
* <div>
|
|
1529
1529
|
* {status?.enabled ? (
|
|
1530
|
-
* <button onClick={() => disable({ password: 'xxx' })}>Disable MFA</button>
|
|
1530
|
+
* <button onClick={() => disable(userUniqueId, { password: 'xxx' })}>Disable MFA</button>
|
|
1531
1531
|
* ) : (
|
|
1532
1532
|
* <button onClick={handleSetup}>Setup MFA</button>
|
|
1533
1533
|
* )}
|
|
@@ -1541,11 +1541,11 @@ function useUniversityBlock() {
|
|
|
1541
1541
|
const [error, setError] = useState(null);
|
|
1542
1542
|
const [status, setStatus] = useState(null);
|
|
1543
1543
|
const [setupData, setSetupData] = useState(null);
|
|
1544
|
-
const setup = useCallback(async ()=>{
|
|
1544
|
+
const setup = useCallback(async (userUniqueId, regenerate)=>{
|
|
1545
1545
|
setIsLoading(true);
|
|
1546
1546
|
setError(null);
|
|
1547
1547
|
try {
|
|
1548
|
-
const result = await block.mfa.setup();
|
|
1548
|
+
const result = await block.mfa.setup(userUniqueId, regenerate);
|
|
1549
1549
|
setSetupData(result);
|
|
1550
1550
|
return result;
|
|
1551
1551
|
} catch (err) {
|
|
@@ -1558,14 +1558,14 @@ function useUniversityBlock() {
|
|
|
1558
1558
|
}, [
|
|
1559
1559
|
block.mfa
|
|
1560
1560
|
]);
|
|
1561
|
-
const enable = useCallback(async (request)=>{
|
|
1561
|
+
const enable = useCallback(async (userUniqueId, request)=>{
|
|
1562
1562
|
setIsLoading(true);
|
|
1563
1563
|
setError(null);
|
|
1564
1564
|
try {
|
|
1565
|
-
const result = await block.mfa.enable(request);
|
|
1565
|
+
const result = await block.mfa.enable(userUniqueId, request);
|
|
1566
1566
|
setSetupData(null);
|
|
1567
1567
|
// Refresh status after enabling
|
|
1568
|
-
const newStatus = await block.mfa.status();
|
|
1568
|
+
const newStatus = await block.mfa.status(userUniqueId);
|
|
1569
1569
|
setStatus(newStatus);
|
|
1570
1570
|
return result;
|
|
1571
1571
|
} catch (err) {
|
|
@@ -1578,13 +1578,13 @@ function useUniversityBlock() {
|
|
|
1578
1578
|
}, [
|
|
1579
1579
|
block.mfa
|
|
1580
1580
|
]);
|
|
1581
|
-
const disable = useCallback(async (request)=>{
|
|
1581
|
+
const disable = useCallback(async (userUniqueId, request)=>{
|
|
1582
1582
|
setIsLoading(true);
|
|
1583
1583
|
setError(null);
|
|
1584
1584
|
try {
|
|
1585
|
-
const result = await block.mfa.disable(request);
|
|
1585
|
+
const result = await block.mfa.disable(userUniqueId, request);
|
|
1586
1586
|
// Refresh status after disabling
|
|
1587
|
-
const newStatus = await block.mfa.status();
|
|
1587
|
+
const newStatus = await block.mfa.status(userUniqueId);
|
|
1588
1588
|
setStatus(newStatus);
|
|
1589
1589
|
return result;
|
|
1590
1590
|
} catch (err) {
|
|
@@ -1597,11 +1597,11 @@ function useUniversityBlock() {
|
|
|
1597
1597
|
}, [
|
|
1598
1598
|
block.mfa
|
|
1599
1599
|
]);
|
|
1600
|
-
const verify = useCallback(async (request)=>{
|
|
1600
|
+
const verify = useCallback(async (userUniqueId, request)=>{
|
|
1601
1601
|
setIsLoading(true);
|
|
1602
1602
|
setError(null);
|
|
1603
1603
|
try {
|
|
1604
|
-
return await block.mfa.verify(request);
|
|
1604
|
+
return await block.mfa.verify(userUniqueId, request);
|
|
1605
1605
|
} catch (err) {
|
|
1606
1606
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
1607
1607
|
setError(error);
|
|
@@ -1612,11 +1612,11 @@ function useUniversityBlock() {
|
|
|
1612
1612
|
}, [
|
|
1613
1613
|
block.mfa
|
|
1614
1614
|
]);
|
|
1615
|
-
const getStatus = useCallback(async ()=>{
|
|
1615
|
+
const getStatus = useCallback(async (userUniqueId)=>{
|
|
1616
1616
|
setIsLoading(true);
|
|
1617
1617
|
setError(null);
|
|
1618
1618
|
try {
|
|
1619
|
-
const result = await block.mfa.status();
|
|
1619
|
+
const result = await block.mfa.status(userUniqueId);
|
|
1620
1620
|
setStatus(result);
|
|
1621
1621
|
return result;
|
|
1622
1622
|
} catch (err) {
|
|
@@ -1655,11 +1655,11 @@ function useUniversityBlock() {
|
|
|
1655
1655
|
* @example
|
|
1656
1656
|
* ```tsx
|
|
1657
1657
|
* function SocialLogin() {
|
|
1658
|
-
* const {
|
|
1658
|
+
* const { googleLogin, facebookLogin, isLoading, error } = useOAuth();
|
|
1659
1659
|
*
|
|
1660
1660
|
* const handleGoogleLogin = async (googleToken: string) => {
|
|
1661
1661
|
* try {
|
|
1662
|
-
* const response = await
|
|
1662
|
+
* const response = await googleLogin({ token: googleToken });
|
|
1663
1663
|
* // User is now logged in
|
|
1664
1664
|
* } catch (err) {
|
|
1665
1665
|
* // Handle error
|
|
@@ -1680,11 +1680,11 @@ function useUniversityBlock() {
|
|
|
1680
1680
|
const [isLoading, setIsLoading] = useState(false);
|
|
1681
1681
|
const [error, setError] = useState(null);
|
|
1682
1682
|
const [tenantContext, setTenantContext] = useState(null);
|
|
1683
|
-
const
|
|
1683
|
+
const facebookLogin = useCallback(async (request)=>{
|
|
1684
1684
|
setIsLoading(true);
|
|
1685
1685
|
setError(null);
|
|
1686
1686
|
try {
|
|
1687
|
-
return await block.oauth.
|
|
1687
|
+
return await block.oauth.facebookLogin(request);
|
|
1688
1688
|
} catch (err) {
|
|
1689
1689
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
1690
1690
|
setError(error);
|
|
@@ -1695,11 +1695,11 @@ function useUniversityBlock() {
|
|
|
1695
1695
|
}, [
|
|
1696
1696
|
block.oauth
|
|
1697
1697
|
]);
|
|
1698
|
-
const
|
|
1698
|
+
const googleLogin = useCallback(async (request)=>{
|
|
1699
1699
|
setIsLoading(true);
|
|
1700
1700
|
setError(null);
|
|
1701
1701
|
try {
|
|
1702
|
-
return await block.oauth.
|
|
1702
|
+
return await block.oauth.googleLogin(request);
|
|
1703
1703
|
} catch (err) {
|
|
1704
1704
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
1705
1705
|
setError(error);
|
|
@@ -1710,11 +1710,11 @@ function useUniversityBlock() {
|
|
|
1710
1710
|
}, [
|
|
1711
1711
|
block.oauth
|
|
1712
1712
|
]);
|
|
1713
|
-
const
|
|
1713
|
+
const tenantLogin = useCallback(async (request)=>{
|
|
1714
1714
|
setIsLoading(true);
|
|
1715
1715
|
setError(null);
|
|
1716
1716
|
try {
|
|
1717
|
-
return await block.oauth.
|
|
1717
|
+
return await block.oauth.tenantLogin(request);
|
|
1718
1718
|
} catch (err) {
|
|
1719
1719
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
1720
1720
|
setError(error);
|
|
@@ -1787,12 +1787,13 @@ function useUniversityBlock() {
|
|
|
1787
1787
|
}, [
|
|
1788
1788
|
block.oauth
|
|
1789
1789
|
]);
|
|
1790
|
-
const revokeTenantContext = useCallback(async ()=>{
|
|
1790
|
+
const revokeTenantContext = useCallback(async (request)=>{
|
|
1791
1791
|
setIsLoading(true);
|
|
1792
1792
|
setError(null);
|
|
1793
1793
|
try {
|
|
1794
|
-
await block.oauth.revokeTenantContext();
|
|
1794
|
+
const result = await block.oauth.revokeTenantContext(request);
|
|
1795
1795
|
setTenantContext(null);
|
|
1796
|
+
return result;
|
|
1796
1797
|
} catch (err) {
|
|
1797
1798
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
1798
1799
|
setError(error);
|
|
@@ -1803,11 +1804,11 @@ function useUniversityBlock() {
|
|
|
1803
1804
|
}, [
|
|
1804
1805
|
block.oauth
|
|
1805
1806
|
]);
|
|
1806
|
-
const
|
|
1807
|
+
const getTenantContextAudit = useCallback(async ()=>{
|
|
1807
1808
|
setIsLoading(true);
|
|
1808
1809
|
setError(null);
|
|
1809
1810
|
try {
|
|
1810
|
-
return await block.oauth.
|
|
1811
|
+
return await block.oauth.getTenantContextAudit();
|
|
1811
1812
|
} catch (err) {
|
|
1812
1813
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
1813
1814
|
setError(error);
|
|
@@ -1825,15 +1826,15 @@ function useUniversityBlock() {
|
|
|
1825
1826
|
isLoading,
|
|
1826
1827
|
error,
|
|
1827
1828
|
tenantContext,
|
|
1828
|
-
|
|
1829
|
-
|
|
1830
|
-
|
|
1829
|
+
facebookLogin,
|
|
1830
|
+
googleLogin,
|
|
1831
|
+
tenantLogin,
|
|
1831
1832
|
introspectToken,
|
|
1832
1833
|
revokeToken,
|
|
1833
1834
|
revokeAllTokens,
|
|
1834
1835
|
createTenantContext,
|
|
1835
1836
|
revokeTenantContext,
|
|
1836
|
-
|
|
1837
|
+
getTenantContextAudit,
|
|
1837
1838
|
clearError
|
|
1838
1839
|
};
|
|
1839
1840
|
}
|
|
@@ -2343,8 +2344,8 @@ function useUniversityBlock() {
|
|
|
2343
2344
|
setError(null);
|
|
2344
2345
|
try {
|
|
2345
2346
|
const result = await block.favorites.list();
|
|
2346
|
-
setFavorites(result);
|
|
2347
|
-
return result;
|
|
2347
|
+
setFavorites(result.data);
|
|
2348
|
+
return result.data;
|
|
2348
2349
|
} catch (err) {
|
|
2349
2350
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
2350
2351
|
setError(error);
|
|
@@ -2460,7 +2461,7 @@ function useUniversityBlock() {
|
|
|
2460
2461
|
try {
|
|
2461
2462
|
const response = await block.series.list(params);
|
|
2462
2463
|
setSeries(response.data);
|
|
2463
|
-
setTotalRecords(response.meta.
|
|
2464
|
+
setTotalRecords(response.meta.totalCount);
|
|
2464
2465
|
return response;
|
|
2465
2466
|
} catch (err) {
|
|
2466
2467
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
@@ -2478,7 +2479,7 @@ function useUniversityBlock() {
|
|
|
2478
2479
|
try {
|
|
2479
2480
|
const response = await block.series.query(params);
|
|
2480
2481
|
setSeries(response.data);
|
|
2481
|
-
setTotalRecords(response.meta.
|
|
2482
|
+
setTotalRecords(response.meta.totalCount);
|
|
2482
2483
|
return response;
|
|
2483
2484
|
} catch (err) {
|
|
2484
2485
|
const error = err instanceof Error ? err : new Error(String(err));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../src/lib/context.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAsC,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAC3E,OAAO,KAAK,EAAE,SAAS,
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../src/lib/context.tsx"],"names":[],"mappings":"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"}
|
|
@@ -6,11 +6,11 @@ export interface UseMfaState {
|
|
|
6
6
|
setupData: MfaSetupResponseFull | null;
|
|
7
7
|
}
|
|
8
8
|
export interface UseMfaActions {
|
|
9
|
-
setup: () => Promise<MfaSetupResponseFull>;
|
|
10
|
-
enable: (request: MfaEnableRequest) => Promise<MfaOperationResponse>;
|
|
11
|
-
disable: (request: MfaDisableRequest) => Promise<MfaOperationResponse>;
|
|
12
|
-
verify: (request: MfaVerifyRequestFull) => Promise<MfaVerificationResponse>;
|
|
13
|
-
getStatus: () => Promise<MfaStatusResponse>;
|
|
9
|
+
setup: (userUniqueId: string, regenerate?: boolean) => Promise<MfaSetupResponseFull>;
|
|
10
|
+
enable: (userUniqueId: string, request: MfaEnableRequest) => Promise<MfaOperationResponse>;
|
|
11
|
+
disable: (userUniqueId: string, request: MfaDisableRequest) => Promise<MfaOperationResponse>;
|
|
12
|
+
verify: (userUniqueId: string, request: MfaVerifyRequestFull) => Promise<MfaVerificationResponse>;
|
|
13
|
+
getStatus: (userUniqueId: string) => Promise<MfaStatusResponse>;
|
|
14
14
|
clearError: () => void;
|
|
15
15
|
}
|
|
16
16
|
export type UseMfaReturn = UseMfaState & UseMfaActions;
|
|
@@ -19,26 +19,26 @@ export type UseMfaReturn = UseMfaState & UseMfaActions;
|
|
|
19
19
|
*
|
|
20
20
|
* @example
|
|
21
21
|
* ```tsx
|
|
22
|
-
* function MfaSettings() {
|
|
22
|
+
* function MfaSettings({ userUniqueId }: { userUniqueId: string }) {
|
|
23
23
|
* const { setup, enable, disable, getStatus, status, isLoading, error } = useMfa();
|
|
24
24
|
*
|
|
25
25
|
* useEffect(() => {
|
|
26
|
-
* getStatus();
|
|
27
|
-
* }, [getStatus]);
|
|
26
|
+
* getStatus(userUniqueId);
|
|
27
|
+
* }, [getStatus, userUniqueId]);
|
|
28
28
|
*
|
|
29
29
|
* const handleSetup = async () => {
|
|
30
|
-
* const data = await setup();
|
|
30
|
+
* const data = await setup(userUniqueId);
|
|
31
31
|
* // Show QR code from data.qrCodeUri
|
|
32
32
|
* };
|
|
33
33
|
*
|
|
34
34
|
* const handleEnable = async (code: string) => {
|
|
35
|
-
* await enable({ totpCode: code });
|
|
35
|
+
* await enable(userUniqueId, { totpCode: code });
|
|
36
36
|
* };
|
|
37
37
|
*
|
|
38
38
|
* return (
|
|
39
39
|
* <div>
|
|
40
40
|
* {status?.enabled ? (
|
|
41
|
-
* <button onClick={() => disable({ password: 'xxx' })}>Disable MFA</button>
|
|
41
|
+
* <button onClick={() => disable(userUniqueId, { password: 'xxx' })}>Disable MFA</button>
|
|
42
42
|
* ) : (
|
|
43
43
|
* <button onClick={handleSetup}>Setup MFA</button>
|
|
44
44
|
* )}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-mfa.d.ts","sourceRoot":"","sources":["../../../../src/lib/hooks/use-mfa.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,oBAAoB,EACpB,gBAAgB,EAChB,iBAAiB,EACjB,oBAAoB,EACpB,iBAAiB,EACjB,uBAAuB,EACvB,oBAAoB,EACrB,MAAM,gCAAgC,CAAC;AAOxC,MAAM,WAAW,WAAW;IAC1B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,MAAM,EAAE,iBAAiB,GAAG,IAAI,CAAC;IACjC,SAAS,EAAE,oBAAoB,GAAG,IAAI,CAAC;CACxC;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,OAAO,CAAC,oBAAoB,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"use-mfa.d.ts","sourceRoot":"","sources":["../../../../src/lib/hooks/use-mfa.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,oBAAoB,EACpB,gBAAgB,EAChB,iBAAiB,EACjB,oBAAoB,EACpB,iBAAiB,EACjB,uBAAuB,EACvB,oBAAoB,EACrB,MAAM,gCAAgC,CAAC;AAOxC,MAAM,WAAW,WAAW;IAC1B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,MAAM,EAAE,iBAAiB,GAAG,IAAI,CAAC;IACjC,SAAS,EAAE,oBAAoB,GAAG,IAAI,CAAC;CACxC;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,CAAC,YAAY,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,OAAO,KAAK,OAAO,CAAC,oBAAoB,CAAC,CAAC;IACrF,MAAM,EAAE,CAAC,YAAY,EAAE,MAAM,EAAE,OAAO,EAAE,gBAAgB,KAAK,OAAO,CAAC,oBAAoB,CAAC,CAAC;IAC3F,OAAO,EAAE,CAAC,YAAY,EAAE,MAAM,EAAE,OAAO,EAAE,iBAAiB,KAAK,OAAO,CAAC,oBAAoB,CAAC,CAAC;IAC7F,MAAM,EAAE,CAAC,YAAY,EAAE,MAAM,EAAE,OAAO,EAAE,oBAAoB,KAAK,OAAO,CAAC,uBAAuB,CAAC,CAAC;IAClG,SAAS,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,OAAO,CAAC,iBAAiB,CAAC,CAAC;IAChE,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB;AAED,MAAM,MAAM,YAAY,GAAG,WAAW,GAAG,aAAa,CAAC;AAMvD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AACH,wBAAgB,MAAM,IAAI,YAAY,CA2GrC"}
|
|
@@ -1,19 +1,21 @@
|
|
|
1
|
-
import type { SignInResponse, OAuthSocialLoginRequest, TenantLoginRequest, TokenIntrospectionResponse, TokenRevokeRequest, TokenRevokeAllRequest, TokenRevokeResponse, TenantContextCreateRequest, TenantContextResponse, TenantContextAuditEntry } from '@23blocks/block-authentication';
|
|
1
|
+
import type { SignInResponse, OAuthSocialLoginRequest, TenantLoginRequest, TokenIntrospectionResponse, TokenRevokeRequest, TokenRevokeAllRequest, TokenRevokeResponse, TenantContextCreateRequest, TenantContextRevokeRequest, TenantContextResponse, TenantContextAuditEntry } from '@23blocks/block-authentication';
|
|
2
2
|
export interface UseOAuthState {
|
|
3
3
|
isLoading: boolean;
|
|
4
4
|
error: Error | null;
|
|
5
5
|
tenantContext: TenantContextResponse | null;
|
|
6
6
|
}
|
|
7
7
|
export interface UseOAuthActions {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
introspectToken: (token
|
|
8
|
+
facebookLogin: (request: OAuthSocialLoginRequest) => Promise<SignInResponse>;
|
|
9
|
+
googleLogin: (request: OAuthSocialLoginRequest) => Promise<SignInResponse>;
|
|
10
|
+
tenantLogin: (request: TenantLoginRequest) => Promise<SignInResponse>;
|
|
11
|
+
introspectToken: (token?: string) => Promise<TokenIntrospectionResponse>;
|
|
12
12
|
revokeToken: (request: TokenRevokeRequest) => Promise<TokenRevokeResponse>;
|
|
13
|
-
revokeAllTokens: (request
|
|
13
|
+
revokeAllTokens: (request: TokenRevokeAllRequest) => Promise<TokenRevokeResponse>;
|
|
14
14
|
createTenantContext: (request: TenantContextCreateRequest) => Promise<TenantContextResponse>;
|
|
15
|
-
revokeTenantContext: () => Promise<
|
|
16
|
-
|
|
15
|
+
revokeTenantContext: (request: TenantContextRevokeRequest) => Promise<{
|
|
16
|
+
message: string;
|
|
17
|
+
}>;
|
|
18
|
+
getTenantContextAudit: () => Promise<TenantContextAuditEntry[]>;
|
|
17
19
|
clearError: () => void;
|
|
18
20
|
}
|
|
19
21
|
export type UseOAuthReturn = UseOAuthState & UseOAuthActions;
|
|
@@ -23,11 +25,11 @@ export type UseOAuthReturn = UseOAuthState & UseOAuthActions;
|
|
|
23
25
|
* @example
|
|
24
26
|
* ```tsx
|
|
25
27
|
* function SocialLogin() {
|
|
26
|
-
* const {
|
|
28
|
+
* const { googleLogin, facebookLogin, isLoading, error } = useOAuth();
|
|
27
29
|
*
|
|
28
30
|
* const handleGoogleLogin = async (googleToken: string) => {
|
|
29
31
|
* try {
|
|
30
|
-
* const response = await
|
|
32
|
+
* const response = await googleLogin({ token: googleToken });
|
|
31
33
|
* // User is now logged in
|
|
32
34
|
* } catch (err) {
|
|
33
35
|
* // Handle error
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-oauth.d.ts","sourceRoot":"","sources":["../../../../src/lib/hooks/use-oauth.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,cAAc,EACd,uBAAuB,EACvB,kBAAkB,EAClB,0BAA0B,EAC1B,kBAAkB,EAClB,qBAAqB,EACrB,mBAAmB,EACnB,0BAA0B,EAC1B,qBAAqB,EACrB,uBAAuB,EACxB,MAAM,gCAAgC,CAAC;AAOxC,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,aAAa,EAAE,qBAAqB,GAAG,IAAI,CAAC;CAC7C;AAED,MAAM,WAAW,eAAe;IAC9B,
|
|
1
|
+
{"version":3,"file":"use-oauth.d.ts","sourceRoot":"","sources":["../../../../src/lib/hooks/use-oauth.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,cAAc,EACd,uBAAuB,EACvB,kBAAkB,EAClB,0BAA0B,EAC1B,kBAAkB,EAClB,qBAAqB,EACrB,mBAAmB,EACnB,0BAA0B,EAC1B,0BAA0B,EAC1B,qBAAqB,EACrB,uBAAuB,EACxB,MAAM,gCAAgC,CAAC;AAOxC,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,aAAa,EAAE,qBAAqB,GAAG,IAAI,CAAC;CAC7C;AAED,MAAM,WAAW,eAAe;IAC9B,aAAa,EAAE,CAAC,OAAO,EAAE,uBAAuB,KAAK,OAAO,CAAC,cAAc,CAAC,CAAC;IAC7E,WAAW,EAAE,CAAC,OAAO,EAAE,uBAAuB,KAAK,OAAO,CAAC,cAAc,CAAC,CAAC;IAC3E,WAAW,EAAE,CAAC,OAAO,EAAE,kBAAkB,KAAK,OAAO,CAAC,cAAc,CAAC,CAAC;IACtE,eAAe,EAAE,CAAC,KAAK,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,0BAA0B,CAAC,CAAC;IACzE,WAAW,EAAE,CAAC,OAAO,EAAE,kBAAkB,KAAK,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAC3E,eAAe,EAAE,CAAC,OAAO,EAAE,qBAAqB,KAAK,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAClF,mBAAmB,EAAE,CAAC,OAAO,EAAE,0BAA0B,KAAK,OAAO,CAAC,qBAAqB,CAAC,CAAC;IAC7F,mBAAmB,EAAE,CAAC,OAAO,EAAE,0BAA0B,KAAK,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC3F,qBAAqB,EAAE,MAAM,OAAO,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAChE,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB;AAED,MAAM,MAAM,cAAc,GAAG,aAAa,GAAG,eAAe,CAAC;AAM7D;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,QAAQ,IAAI,cAAc,CA4JzC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"simple-provider.d.ts","sourceRoot":"","sources":["../../../src/lib/simple-provider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAgF,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"simple-provider.d.ts","sourceRoot":"","sources":["../../../src/lib/simple-provider.tsx"],"names":[],"mappings":"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"}
|