@chem-po/firebase-native 0.0.16 → 0.0.18
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/README.md +215 -0
- package/lib/commonjs/adapter/auth.js +431 -0
- package/lib/commonjs/adapter/auth.js.map +1 -0
- package/lib/commonjs/adapter/db.js +103 -0
- package/lib/commonjs/adapter/db.js.map +1 -0
- package/lib/commonjs/adapter/index.js +16 -0
- package/lib/commonjs/adapter/index.js.map +1 -0
- package/lib/commonjs/adapter/storage.js +52 -0
- package/lib/commonjs/adapter/storage.js.map +1 -0
- package/lib/commonjs/auth/functions.js +11 -0
- package/lib/commonjs/auth/functions.js.map +1 -0
- package/lib/commonjs/auth/index.js +17 -0
- package/lib/commonjs/auth/index.js.map +1 -0
- package/lib/commonjs/components/AuthenticatorVerify.js +90 -0
- package/lib/commonjs/components/AuthenticatorVerify.js.map +1 -0
- package/lib/commonjs/components/FirebaseSignIn.js +196 -0
- package/lib/commonjs/components/FirebaseSignIn.js.map +1 -0
- package/lib/commonjs/components/PhoneVerify.js +123 -0
- package/lib/commonjs/components/PhoneVerify.js.map +1 -0
- package/lib/commonjs/components/TwoFactorAuthModal.js +118 -0
- package/lib/commonjs/components/TwoFactorAuthModal.js.map +1 -0
- package/lib/commonjs/components/index.js +28 -0
- package/lib/commonjs/components/index.js.map +1 -0
- package/lib/commonjs/contexts/FirebaseContext.js +48 -0
- package/lib/commonjs/contexts/FirebaseContext.js.map +1 -0
- package/lib/commonjs/contexts/index.js +17 -0
- package/lib/commonjs/contexts/index.js.map +1 -0
- package/lib/commonjs/db/index.js +17 -0
- package/lib/commonjs/db/index.js.map +1 -0
- package/lib/commonjs/db/utils.js +120 -0
- package/lib/commonjs/db/utils.js.map +1 -0
- package/lib/commonjs/hooks/backend.js +12 -0
- package/lib/commonjs/hooks/backend.js.map +1 -0
- package/lib/commonjs/hooks/index.js +17 -0
- package/lib/commonjs/hooks/index.js.map +1 -0
- package/lib/commonjs/hooks/useAuthenticatorVerify.js +52 -0
- package/lib/commonjs/hooks/useAuthenticatorVerify.js.map +1 -0
- package/lib/commonjs/hooks/usePhoneVerify.js +83 -0
- package/lib/commonjs/hooks/usePhoneVerify.js.map +1 -0
- package/lib/commonjs/icons/Google.js +29 -0
- package/lib/commonjs/icons/Google.js.map +1 -0
- package/lib/commonjs/index.js +105 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/commonjs/storage/index.js +17 -0
- package/lib/commonjs/storage/index.js.map +1 -0
- package/lib/commonjs/storage/utils.js +37 -0
- package/lib/commonjs/storage/utils.js.map +1 -0
- package/lib/commonjs/types/adapter.js +6 -0
- package/lib/commonjs/types/adapter.js.map +1 -0
- package/lib/commonjs/types/auth.js +6 -0
- package/lib/commonjs/types/auth.js.map +1 -0
- package/lib/commonjs/types/db.js +6 -0
- package/lib/commonjs/types/db.js.map +1 -0
- package/lib/commonjs/types/functions.js +6 -0
- package/lib/commonjs/types/functions.js.map +1 -0
- package/lib/commonjs/types/index.js +6 -0
- package/lib/commonjs/types/index.js.map +1 -0
- package/lib/commonjs/types/storage.js +6 -0
- package/lib/commonjs/types/storage.js.map +1 -0
- package/lib/commonjs/utils/validation.js +71 -0
- package/lib/commonjs/utils/validation.js.map +1 -0
- package/lib/module/adapter/auth.js +424 -0
- package/lib/module/adapter/auth.js.map +1 -0
- package/lib/module/adapter/db.js +96 -0
- package/lib/module/adapter/db.js.map +1 -0
- package/lib/module/adapter/index.js +9 -0
- package/lib/module/adapter/index.js.map +1 -0
- package/lib/module/adapter/storage.js +45 -0
- package/lib/module/adapter/storage.js.map +1 -0
- package/lib/module/auth/functions.js +3 -0
- package/lib/module/auth/functions.js.map +1 -0
- package/lib/module/auth/index.js +2 -0
- package/lib/module/auth/index.js.map +1 -0
- package/lib/module/components/AuthenticatorVerify.js +82 -0
- package/lib/module/components/AuthenticatorVerify.js.map +1 -0
- package/lib/module/components/FirebaseSignIn.js +187 -0
- package/lib/module/components/FirebaseSignIn.js.map +1 -0
- package/lib/module/components/PhoneVerify.js +116 -0
- package/lib/module/components/PhoneVerify.js.map +1 -0
- package/lib/module/components/TwoFactorAuthModal.js +110 -0
- package/lib/module/components/TwoFactorAuthModal.js.map +1 -0
- package/lib/module/components/index.js +3 -0
- package/lib/module/components/index.js.map +1 -0
- package/lib/module/contexts/FirebaseContext.js +39 -0
- package/lib/module/contexts/FirebaseContext.js.map +1 -0
- package/lib/module/contexts/index.js +2 -0
- package/lib/module/contexts/index.js.map +1 -0
- package/lib/module/db/index.js +2 -0
- package/lib/module/db/index.js.map +1 -0
- package/lib/module/db/utils.js +111 -0
- package/lib/module/db/utils.js.map +1 -0
- package/lib/module/hooks/backend.js +5 -0
- package/lib/module/hooks/backend.js.map +1 -0
- package/lib/module/hooks/index.js +2 -0
- package/lib/module/hooks/index.js.map +1 -0
- package/lib/module/hooks/useAuthenticatorVerify.js +45 -0
- package/lib/module/hooks/useAuthenticatorVerify.js.map +1 -0
- package/lib/module/hooks/usePhoneVerify.js +76 -0
- package/lib/module/hooks/usePhoneVerify.js.map +1 -0
- package/lib/module/icons/Google.js +22 -0
- package/lib/module/icons/Google.js.map +1 -0
- package/lib/module/index.js +10 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/storage/index.js +2 -0
- package/lib/module/storage/index.js.map +1 -0
- package/lib/module/storage/utils.js +30 -0
- package/lib/module/storage/utils.js.map +1 -0
- package/lib/module/types/adapter.js +2 -0
- package/lib/module/types/adapter.js.map +1 -0
- package/lib/module/types/auth.js +2 -0
- package/lib/module/types/auth.js.map +1 -0
- package/lib/module/types/db.js +2 -0
- package/lib/module/types/db.js.map +1 -0
- package/lib/module/types/functions.js +2 -0
- package/lib/module/types/functions.js.map +1 -0
- package/lib/module/types/index.js +2 -0
- package/lib/module/types/index.js.map +1 -0
- package/lib/module/types/storage.js +2 -0
- package/lib/module/types/storage.js.map +1 -0
- package/lib/module/utils/validation.js +62 -0
- package/lib/module/utils/validation.js.map +1 -0
- package/lib/typescript/adapter/auth.d.ts +7 -0
- package/lib/typescript/adapter/auth.d.ts.map +1 -0
- package/lib/typescript/adapter/db.d.ts +5 -0
- package/lib/typescript/adapter/db.d.ts.map +1 -0
- package/lib/typescript/adapter/index.d.ts +9 -0
- package/lib/typescript/adapter/index.d.ts.map +1 -0
- package/lib/typescript/adapter/storage.d.ts +4 -0
- package/lib/typescript/adapter/storage.d.ts.map +1 -0
- package/lib/typescript/auth/functions.d.ts +4 -0
- package/lib/typescript/auth/functions.d.ts.map +1 -0
- package/lib/typescript/auth/index.d.ts +2 -0
- package/lib/typescript/auth/index.d.ts.map +1 -0
- package/lib/typescript/components/AuthenticatorVerify.d.ts +3 -0
- package/lib/typescript/components/AuthenticatorVerify.d.ts.map +1 -0
- package/lib/typescript/components/FirebaseSignIn.d.ts +6 -0
- package/lib/typescript/components/FirebaseSignIn.d.ts.map +1 -0
- package/lib/typescript/components/PhoneVerify.d.ts +6 -0
- package/lib/typescript/components/PhoneVerify.d.ts.map +1 -0
- package/lib/typescript/components/TwoFactorAuthModal.d.ts +3 -0
- package/lib/typescript/components/TwoFactorAuthModal.d.ts.map +1 -0
- package/lib/typescript/components/index.d.ts +3 -0
- package/lib/typescript/components/index.d.ts.map +1 -0
- package/lib/typescript/contexts/FirebaseContext.d.ts +9 -0
- package/lib/typescript/contexts/FirebaseContext.d.ts.map +1 -0
- package/lib/typescript/contexts/index.d.ts +2 -0
- package/lib/typescript/contexts/index.d.ts.map +1 -0
- package/lib/typescript/db/index.d.ts +2 -0
- package/lib/typescript/db/index.d.ts.map +1 -0
- package/lib/typescript/db/utils.d.ts +6 -0
- package/lib/typescript/db/utils.d.ts.map +1 -0
- package/lib/typescript/hooks/backend.d.ts +2 -0
- package/lib/typescript/hooks/backend.d.ts.map +1 -0
- package/lib/typescript/hooks/index.d.ts +2 -0
- package/lib/typescript/hooks/index.d.ts.map +1 -0
- package/lib/typescript/hooks/useAuthenticatorVerify.d.ts +8 -0
- package/lib/typescript/hooks/useAuthenticatorVerify.d.ts.map +1 -0
- package/lib/typescript/hooks/usePhoneVerify.d.ts +9 -0
- package/lib/typescript/hooks/usePhoneVerify.d.ts.map +1 -0
- package/lib/typescript/icons/Google.d.ts +5 -0
- package/lib/typescript/icons/Google.d.ts.map +1 -0
- package/lib/typescript/index.d.ts +10 -0
- package/lib/typescript/index.d.ts.map +1 -0
- package/lib/typescript/storage/index.d.ts +2 -0
- package/lib/typescript/storage/index.d.ts.map +1 -0
- package/lib/typescript/storage/utils.d.ts +4 -0
- package/lib/typescript/storage/utils.d.ts.map +1 -0
- package/lib/typescript/types/adapter.d.ts +6 -0
- package/lib/typescript/types/adapter.d.ts.map +1 -0
- package/lib/typescript/types/auth.d.ts +12 -0
- package/lib/typescript/types/auth.d.ts.map +1 -0
- package/lib/typescript/types/db.d.ts +8 -0
- package/lib/typescript/types/db.d.ts.map +1 -0
- package/lib/typescript/types/functions.d.ts +3 -0
- package/lib/typescript/types/functions.d.ts.map +1 -0
- package/lib/typescript/types/index.d.ts +24 -0
- package/lib/typescript/types/index.d.ts.map +1 -0
- package/lib/typescript/types/storage.d.ts +3 -0
- package/lib/typescript/types/storage.d.ts.map +1 -0
- package/lib/typescript/utils/validation.d.ts +21 -0
- package/lib/typescript/utils/validation.d.ts.map +1 -0
- package/package.json +29 -12
- package/src/adapter/auth.ts +474 -0
- package/src/adapter/db.ts +146 -0
- package/src/adapter/index.ts +30 -0
- package/src/adapter/storage.ts +58 -0
- package/src/auth/functions.ts +7 -0
- package/src/auth/index.ts +1 -0
- package/src/components/AuthenticatorVerify.tsx +75 -0
- package/src/components/FirebaseSignIn.tsx +187 -0
- package/src/components/PhoneVerify.tsx +102 -0
- package/src/components/TwoFactorAuthModal.tsx +133 -0
- package/src/components/index.ts +2 -0
- package/src/contexts/FirebaseContext.tsx +54 -0
- package/src/contexts/index.ts +1 -0
- package/src/db/index.ts +1 -0
- package/src/db/utils.ts +142 -0
- package/src/hooks/backend.ts +4 -0
- package/src/hooks/index.ts +1 -0
- package/src/hooks/useAuthenticatorVerify.ts +45 -0
- package/src/hooks/usePhoneVerify.ts +76 -0
- package/src/icons/Google.tsx +24 -0
- package/src/index.ts +9 -0
- package/src/storage/index.ts +1 -0
- package/src/storage/utils.ts +29 -0
- package/src/types/adapter.ts +13 -0
- package/src/types/auth.ts +13 -0
- package/src/types/db.ts +10 -0
- package/src/types/functions.ts +3 -0
- package/src/types/index.ts +26 -0
- package/src/types/storage.ts +3 -0
- package/src/utils/validation.ts +85 -0
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { LoadingButton, Txt } from '@chem-po/react-native';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { StyleSheet, TextInput, View } from 'react-native';
|
|
4
|
+
import { useAuthenticatorVerify } from '../hooks/useAuthenticatorVerify';
|
|
5
|
+
export const AuthenticatorVerify = () => {
|
|
6
|
+
const {
|
|
7
|
+
code,
|
|
8
|
+
setCode,
|
|
9
|
+
verifying,
|
|
10
|
+
error,
|
|
11
|
+
handleVerify
|
|
12
|
+
} = useAuthenticatorVerify();
|
|
13
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
14
|
+
style: styles.wrapper
|
|
15
|
+
}, /*#__PURE__*/React.createElement(View, {
|
|
16
|
+
style: styles.container
|
|
17
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
18
|
+
style: styles.text
|
|
19
|
+
}, "Enter the code on your authenticator app:"), /*#__PURE__*/React.createElement(TextInput, {
|
|
20
|
+
style: styles.input,
|
|
21
|
+
value: code,
|
|
22
|
+
onChangeText: setCode,
|
|
23
|
+
placeholder: "Verification Code",
|
|
24
|
+
keyboardType: "number-pad",
|
|
25
|
+
maxLength: 6,
|
|
26
|
+
autoFocus: true
|
|
27
|
+
}), error ? /*#__PURE__*/React.createElement(Txt, {
|
|
28
|
+
style: styles.errorText
|
|
29
|
+
}, error) : null, /*#__PURE__*/React.createElement(LoadingButton, {
|
|
30
|
+
style: styles.button,
|
|
31
|
+
onPress: handleVerify,
|
|
32
|
+
disabled: verifying
|
|
33
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
34
|
+
style: styles.buttonText
|
|
35
|
+
}, verifying ? 'Verifying...' : 'Verify'))));
|
|
36
|
+
};
|
|
37
|
+
const styles = StyleSheet.create({
|
|
38
|
+
wrapper: {
|
|
39
|
+
flex: 1,
|
|
40
|
+
padding: 16
|
|
41
|
+
},
|
|
42
|
+
container: {
|
|
43
|
+
flex: 1,
|
|
44
|
+
alignItems: 'center',
|
|
45
|
+
justifyContent: 'center',
|
|
46
|
+
gap: 16
|
|
47
|
+
},
|
|
48
|
+
text: {
|
|
49
|
+
fontSize: 16,
|
|
50
|
+
textAlign: 'center',
|
|
51
|
+
marginBottom: 8
|
|
52
|
+
},
|
|
53
|
+
input: {
|
|
54
|
+
width: '100%',
|
|
55
|
+
height: 48,
|
|
56
|
+
borderWidth: 1,
|
|
57
|
+
borderColor: '#ccc',
|
|
58
|
+
borderRadius: 8,
|
|
59
|
+
paddingHorizontal: 16,
|
|
60
|
+
fontSize: 16,
|
|
61
|
+
marginBottom: 8
|
|
62
|
+
},
|
|
63
|
+
button: {
|
|
64
|
+
backgroundColor: '#007AFF',
|
|
65
|
+
paddingHorizontal: 24,
|
|
66
|
+
paddingVertical: 12,
|
|
67
|
+
borderRadius: 8,
|
|
68
|
+
minWidth: 200,
|
|
69
|
+
alignItems: 'center'
|
|
70
|
+
},
|
|
71
|
+
buttonText: {
|
|
72
|
+
color: 'white',
|
|
73
|
+
fontSize: 16,
|
|
74
|
+
fontWeight: '600'
|
|
75
|
+
},
|
|
76
|
+
errorText: {
|
|
77
|
+
color: 'red',
|
|
78
|
+
fontSize: 14,
|
|
79
|
+
marginBottom: 8
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
//# sourceMappingURL=AuthenticatorVerify.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["LoadingButton","Txt","React","StyleSheet","TextInput","View","useAuthenticatorVerify","AuthenticatorVerify","code","setCode","verifying","error","handleVerify","createElement","style","styles","wrapper","container","text","input","value","onChangeText","placeholder","keyboardType","maxLength","autoFocus","errorText","button","onPress","disabled","buttonText","create","flex","padding","alignItems","justifyContent","gap","fontSize","textAlign","marginBottom","width","height","borderWidth","borderColor","borderRadius","paddingHorizontal","backgroundColor","paddingVertical","minWidth","color","fontWeight"],"sourceRoot":"..\\..\\..\\src","sources":["components/AuthenticatorVerify.tsx"],"mappings":"AAAA,SAASA,aAAa,EAAEC,GAAG,QAAQ,uBAAuB;AAC1D,OAAOC,KAAK,MAAM,OAAO;AACzB,SAASC,UAAU,EAAEC,SAAS,EAAEC,IAAI,QAAQ,cAAc;AAC1D,SAASC,sBAAsB,QAAQ,iCAAiC;AAExE,OAAO,MAAMC,mBAAmB,GAAGA,CAAA,KAAM;EACvC,MAAM;IAAEC,IAAI;IAAEC,OAAO;IAAEC,SAAS;IAAEC,KAAK;IAAEC;EAAa,CAAC,GAAGN,sBAAsB,CAAC,CAAC;EAElF,oBACEJ,KAAA,CAAAW,aAAA,CAACR,IAAI;IAACS,KAAK,EAAEC,MAAM,CAACC;EAAQ,gBAC1Bd,KAAA,CAAAW,aAAA,CAACR,IAAI;IAACS,KAAK,EAAEC,MAAM,CAACE;EAAU,gBAC5Bf,KAAA,CAAAW,aAAA,CAACZ,GAAG;IAACa,KAAK,EAAEC,MAAM,CAACG;EAAK,GAAC,2CAA8C,CAAC,eACxEhB,KAAA,CAAAW,aAAA,CAACT,SAAS;IACRU,KAAK,EAAEC,MAAM,CAACI,KAAM;IACpBC,KAAK,EAAEZ,IAAK;IACZa,YAAY,EAAEZ,OAAQ;IACtBa,WAAW,EAAC,mBAAmB;IAC/BC,YAAY,EAAC,YAAY;IACzBC,SAAS,EAAE,CAAE;IACbC,SAAS;EAAA,CACV,CAAC,EACDd,KAAK,gBAAGT,KAAA,CAAAW,aAAA,CAACZ,GAAG;IAACa,KAAK,EAAEC,MAAM,CAACW;EAAU,GAAEf,KAAW,CAAC,GAAG,IAAI,eAC3DT,KAAA,CAAAW,aAAA,CAACb,aAAa;IAACc,KAAK,EAAEC,MAAM,CAACY,MAAO;IAACC,OAAO,EAAEhB,YAAa;IAACiB,QAAQ,EAAEnB;EAAU,gBAC9ER,KAAA,CAAAW,aAAA,CAACZ,GAAG;IAACa,KAAK,EAAEC,MAAM,CAACe;EAAW,GAAEpB,SAAS,GAAG,cAAc,GAAG,QAAc,CAC9D,CACX,CACF,CAAC;AAEX,CAAC;AAED,MAAMK,MAAM,GAAGZ,UAAU,CAAC4B,MAAM,CAAC;EAC/Bf,OAAO,EAAE;IACPgB,IAAI,EAAE,CAAC;IACPC,OAAO,EAAE;EACX,CAAC;EACDhB,SAAS,EAAE;IACTe,IAAI,EAAE,CAAC;IACPE,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE,QAAQ;IACxBC,GAAG,EAAE;EACP,CAAC;EACDlB,IAAI,EAAE;IACJmB,QAAQ,EAAE,EAAE;IACZC,SAAS,EAAE,QAAQ;IACnBC,YAAY,EAAE;EAChB,CAAC;EACDpB,KAAK,EAAE;IACLqB,KAAK,EAAE,MAAM;IACbC,MAAM,EAAE,EAAE;IACVC,WAAW,EAAE,CAAC;IACdC,WAAW,EAAE,MAAM;IACnBC,YAAY,EAAE,CAAC;IACfC,iBAAiB,EAAE,EAAE;IACrBR,QAAQ,EAAE,EAAE;IACZE,YAAY,EAAE;EAChB,CAAC;EACDZ,MAAM,EAAE;IACNmB,eAAe,EAAE,SAAS;IAC1BD,iBAAiB,EAAE,EAAE;IACrBE,eAAe,EAAE,EAAE;IACnBH,YAAY,EAAE,CAAC;IACfI,QAAQ,EAAE,GAAG;IACbd,UAAU,EAAE;EACd,CAAC;EACDJ,UAAU,EAAE;IACVmB,KAAK,EAAE,OAAO;IACdZ,QAAQ,EAAE,EAAE;IACZa,UAAU,EAAE;EACd,CAAC;EACDxB,SAAS,EAAE;IACTuB,KAAK,EAAE,KAAK;IACZZ,QAAQ,EAAE,EAAE;IACZE,YAAY,EAAE;EAChB;AACF,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
import { useBackend } from '../hooks';
|
|
2
|
+
import { useBorderColor, useToast } from '@chem-po/react';
|
|
3
|
+
import { LoadingButton, StandaloneInput, Txt } from '@chem-po/react-native';
|
|
4
|
+
import React, { useCallback, useState } from 'react';
|
|
5
|
+
import { StyleSheet, View } from 'react-native';
|
|
6
|
+
import { Divider } from 'react-native-paper';
|
|
7
|
+
import SvgGoogle from '../icons/Google';
|
|
8
|
+
const emailField = {
|
|
9
|
+
_type: 'text',
|
|
10
|
+
type: 'email',
|
|
11
|
+
placeholder: 'Email'
|
|
12
|
+
};
|
|
13
|
+
const passwordField = {
|
|
14
|
+
_type: 'text',
|
|
15
|
+
type: 'password',
|
|
16
|
+
placeholder: 'Password'
|
|
17
|
+
};
|
|
18
|
+
const GoogleLogin = ({
|
|
19
|
+
provider
|
|
20
|
+
}) => {
|
|
21
|
+
const {
|
|
22
|
+
auth
|
|
23
|
+
} = useBackend();
|
|
24
|
+
const {
|
|
25
|
+
showError
|
|
26
|
+
} = useToast();
|
|
27
|
+
const handleSignIn = useCallback(() => {
|
|
28
|
+
return auth.loginWithPopup(provider).catch(error => {
|
|
29
|
+
showError(error instanceof Error ? error.message : 'An unknown error occurred');
|
|
30
|
+
});
|
|
31
|
+
}, [auth, provider, showError]);
|
|
32
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
33
|
+
style: styles.row
|
|
34
|
+
}, /*#__PURE__*/React.createElement(LoadingButton, {
|
|
35
|
+
style: styles.googleLoginButton,
|
|
36
|
+
onPress: handleSignIn
|
|
37
|
+
}, /*#__PURE__*/React.createElement(View, {
|
|
38
|
+
style: styles.googleLogin
|
|
39
|
+
}, /*#__PURE__*/React.createElement(SvgGoogle, {
|
|
40
|
+
width: 24
|
|
41
|
+
}), /*#__PURE__*/React.createElement(Txt, null, "Log In with Google"))));
|
|
42
|
+
};
|
|
43
|
+
const EmailPasswordLogin = () => {
|
|
44
|
+
const [email, setEmail] = useState('');
|
|
45
|
+
const [password, setPassword] = useState('');
|
|
46
|
+
const [isLoading, setIsLoading] = useState(false);
|
|
47
|
+
const [error, setError] = useState(null);
|
|
48
|
+
const {
|
|
49
|
+
auth
|
|
50
|
+
} = useBackend();
|
|
51
|
+
const handleLogin = async () => {
|
|
52
|
+
setIsLoading(true);
|
|
53
|
+
try {
|
|
54
|
+
await auth.loginWithPassword({
|
|
55
|
+
name: 'email'
|
|
56
|
+
}, {
|
|
57
|
+
email,
|
|
58
|
+
password
|
|
59
|
+
});
|
|
60
|
+
} catch (error) {
|
|
61
|
+
setError(error instanceof Error ? error.message : 'An unknown error occurred');
|
|
62
|
+
}
|
|
63
|
+
setIsLoading(false);
|
|
64
|
+
};
|
|
65
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
66
|
+
style: styles.column
|
|
67
|
+
}, /*#__PURE__*/React.createElement(StandaloneInput, {
|
|
68
|
+
field: emailField,
|
|
69
|
+
onChange: setEmail,
|
|
70
|
+
value: email
|
|
71
|
+
}), /*#__PURE__*/React.createElement(StandaloneInput, {
|
|
72
|
+
field: passwordField,
|
|
73
|
+
onChange: setPassword,
|
|
74
|
+
value: password
|
|
75
|
+
}), error && /*#__PURE__*/React.createElement(View, {
|
|
76
|
+
style: styles.error
|
|
77
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
78
|
+
style: styles.errorText
|
|
79
|
+
}, error)), /*#__PURE__*/React.createElement(View, {
|
|
80
|
+
style: styles.row
|
|
81
|
+
}, /*#__PURE__*/React.createElement(View, {
|
|
82
|
+
style: styles.forgotPassword
|
|
83
|
+
}, /*#__PURE__*/React.createElement(LoadingButton, {
|
|
84
|
+
textStyle: styles.forgotPasswordButtonText,
|
|
85
|
+
contentStyle: styles.forgotPasswordButton,
|
|
86
|
+
onPress: () => {
|
|
87
|
+
console.log('press');
|
|
88
|
+
}
|
|
89
|
+
}, "Forgot Password?")), /*#__PURE__*/React.createElement(LoadingButton, {
|
|
90
|
+
onPress: () => handleLogin(),
|
|
91
|
+
disabled: isLoading
|
|
92
|
+
}, "Sign In")));
|
|
93
|
+
};
|
|
94
|
+
export const FirebaseSignIn = ({
|
|
95
|
+
googleProvider
|
|
96
|
+
}) => {
|
|
97
|
+
const borderColor = useBorderColor();
|
|
98
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
99
|
+
style: styles.signInContent
|
|
100
|
+
}, /*#__PURE__*/React.createElement(EmailPasswordLogin, null), googleProvider ? /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Divider, {
|
|
101
|
+
style: {
|
|
102
|
+
backgroundColor: borderColor,
|
|
103
|
+
width: '100%'
|
|
104
|
+
}
|
|
105
|
+
}), /*#__PURE__*/React.createElement(GoogleLogin, {
|
|
106
|
+
provider: googleProvider
|
|
107
|
+
})) : null);
|
|
108
|
+
};
|
|
109
|
+
const styles = StyleSheet.create({
|
|
110
|
+
container: {
|
|
111
|
+
flex: 1,
|
|
112
|
+
width: '100%',
|
|
113
|
+
justifyContent: 'center',
|
|
114
|
+
alignItems: 'center'
|
|
115
|
+
},
|
|
116
|
+
column: {
|
|
117
|
+
flexDirection: 'column',
|
|
118
|
+
gap: 20,
|
|
119
|
+
flex: 1,
|
|
120
|
+
width: '100%',
|
|
121
|
+
alignItems: 'center',
|
|
122
|
+
justifyContent: 'center'
|
|
123
|
+
},
|
|
124
|
+
colorModeToggle: {
|
|
125
|
+
paddingVertical: 20
|
|
126
|
+
},
|
|
127
|
+
signInContent: {
|
|
128
|
+
paddingVertical: 20,
|
|
129
|
+
paddingHorizontal: 20,
|
|
130
|
+
height: 300,
|
|
131
|
+
gap: 12,
|
|
132
|
+
justifyContent: 'center',
|
|
133
|
+
alignItems: 'center',
|
|
134
|
+
width: '100%'
|
|
135
|
+
},
|
|
136
|
+
forgotPasswordButton: {
|
|
137
|
+
borderWidth: 0
|
|
138
|
+
},
|
|
139
|
+
forgotPasswordButtonText: {
|
|
140
|
+
fontSize: 14
|
|
141
|
+
},
|
|
142
|
+
row: {
|
|
143
|
+
flexDirection: 'row',
|
|
144
|
+
justifyContent: 'space-between',
|
|
145
|
+
width: '100%'
|
|
146
|
+
},
|
|
147
|
+
forgotPassword: {
|
|
148
|
+
// flex: 1,
|
|
149
|
+
},
|
|
150
|
+
header: {
|
|
151
|
+
fontSize: 16,
|
|
152
|
+
opacity: 0.7,
|
|
153
|
+
fontWeight: 'bold'
|
|
154
|
+
},
|
|
155
|
+
infoText: {
|
|
156
|
+
fontSize: 16,
|
|
157
|
+
textAlign: 'center',
|
|
158
|
+
// fontFamily: fontFamilies.body.regular,
|
|
159
|
+
paddingBottom: 20
|
|
160
|
+
},
|
|
161
|
+
logo: {
|
|
162
|
+
height: 50,
|
|
163
|
+
resizeMode: 'contain'
|
|
164
|
+
},
|
|
165
|
+
link: {
|
|
166
|
+
fontSize: 14,
|
|
167
|
+
// fontFamily: fontFamilies.body.regular,
|
|
168
|
+
textDecorationLine: 'underline',
|
|
169
|
+
fontWeight: 'semibold'
|
|
170
|
+
},
|
|
171
|
+
googleLogin: {
|
|
172
|
+
flexDirection: 'row',
|
|
173
|
+
alignItems: 'center',
|
|
174
|
+
justifyContent: 'center',
|
|
175
|
+
gap: 10,
|
|
176
|
+
width: '100%'
|
|
177
|
+
},
|
|
178
|
+
googleLoginButton: {
|
|
179
|
+
width: '100%'
|
|
180
|
+
},
|
|
181
|
+
error: {},
|
|
182
|
+
errorText: {
|
|
183
|
+
fontSize: 12,
|
|
184
|
+
color: 'red'
|
|
185
|
+
}
|
|
186
|
+
});
|
|
187
|
+
//# sourceMappingURL=FirebaseSignIn.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["useBackend","useBorderColor","useToast","LoadingButton","StandaloneInput","Txt","React","useCallback","useState","StyleSheet","View","Divider","SvgGoogle","emailField","_type","type","placeholder","passwordField","GoogleLogin","provider","auth","showError","handleSignIn","loginWithPopup","catch","error","Error","message","createElement","style","styles","row","googleLoginButton","onPress","googleLogin","width","EmailPasswordLogin","email","setEmail","password","setPassword","isLoading","setIsLoading","setError","handleLogin","loginWithPassword","name","column","field","onChange","value","errorText","forgotPassword","textStyle","forgotPasswordButtonText","contentStyle","forgotPasswordButton","console","log","disabled","FirebaseSignIn","googleProvider","borderColor","signInContent","Fragment","backgroundColor","create","container","flex","justifyContent","alignItems","flexDirection","gap","colorModeToggle","paddingVertical","paddingHorizontal","height","borderWidth","fontSize","header","opacity","fontWeight","infoText","textAlign","paddingBottom","logo","resizeMode","link","textDecorationLine","color"],"sourceRoot":"..\\..\\..\\src","sources":["components/FirebaseSignIn.tsx"],"mappings":"AAAA,SAASA,UAAU,QAAQ,UAAU;AAGrC,SAAoBC,cAAc,EAAEC,QAAQ,QAAQ,gBAAgB;AACpE,SAASC,aAAa,EAAEC,eAAe,EAAEC,GAAG,QAAQ,uBAAuB;AAC3E,OAAOC,KAAK,IAAIC,WAAW,EAAEC,QAAQ,QAAQ,OAAO;AACpD,SAASC,UAAU,EAAEC,IAAI,QAAQ,cAAc;AAC/C,SAASC,OAAO,QAAQ,oBAAoB;AAC5C,OAAOC,SAAS,MAAM,iBAAiB;AAEvC,MAAMC,UAAqB,GAAG;EAC5BC,KAAK,EAAE,MAAM;EACbC,IAAI,EAAE,OAAO;EACbC,WAAW,EAAE;AACf,CAAC;AAED,MAAMC,aAAwB,GAAG;EAC/BH,KAAK,EAAE,MAAM;EACbC,IAAI,EAAE,UAAU;EAChBC,WAAW,EAAE;AACf,CAAC;AAED,MAAME,WAAW,GAAGA,CAAC;EAAEC;AAA2C,CAAC,KAAK;EACtE,MAAM;IAAEC;EAAK,CAAC,GAAGpB,UAAU,CAAC,CAAC;EAC7B,MAAM;IAAEqB;EAAU,CAAC,GAAGnB,QAAQ,CAAC,CAAC;EAEhC,MAAMoB,YAAY,GAAGf,WAAW,CAAC,MAAM;IACrC,OAAOa,IAAI,CAACG,cAAc,CAACJ,QAAQ,CAAC,CAACK,KAAK,CAACC,KAAK,IAAI;MAClDJ,SAAS,CAACI,KAAK,YAAYC,KAAK,GAAGD,KAAK,CAACE,OAAO,GAAG,2BAA2B,CAAC;IACjF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACP,IAAI,EAAED,QAAQ,EAAEE,SAAS,CAAC,CAAC;EAE/B,oBACEf,KAAA,CAAAsB,aAAA,CAAClB,IAAI;IAACmB,KAAK,EAAEC,MAAM,CAACC;EAAI,gBACtBzB,KAAA,CAAAsB,aAAA,CAACzB,aAAa;IAAC0B,KAAK,EAAEC,MAAM,CAACE,iBAAkB;IAACC,OAAO,EAAEX;EAAa,gBACpEhB,KAAA,CAAAsB,aAAA,CAAClB,IAAI;IAACmB,KAAK,EAAEC,MAAM,CAACI;EAAY,gBAC9B5B,KAAA,CAAAsB,aAAA,CAAChB,SAAS;IAACuB,KAAK,EAAE;EAAG,CAAE,CAAC,eACxB7B,KAAA,CAAAsB,aAAA,CAACvB,GAAG,QAAC,oBAAuB,CACxB,CACO,CACX,CAAC;AAEX,CAAC;AAED,MAAM+B,kBAAkB,GAAGA,CAAA,KAAM;EAC/B,MAAM,CAACC,KAAK,EAAEC,QAAQ,CAAC,GAAG9B,QAAQ,CAAC,EAAE,CAAC;EACtC,MAAM,CAAC+B,QAAQ,EAAEC,WAAW,CAAC,GAAGhC,QAAQ,CAAC,EAAE,CAAC;EAC5C,MAAM,CAACiC,SAAS,EAAEC,YAAY,CAAC,GAAGlC,QAAQ,CAAC,KAAK,CAAC;EACjD,MAAM,CAACiB,KAAK,EAAEkB,QAAQ,CAAC,GAAGnC,QAAQ,CAAgB,IAAI,CAAC;EAEvD,MAAM;IAAEY;EAAK,CAAC,GAAGpB,UAAU,CAAC,CAAC;EAE7B,MAAM4C,WAAW,GAAG,MAAAA,CAAA,KAAY;IAC9BF,YAAY,CAAC,IAAI,CAAC;IAClB,IAAI;MACF,MAAMtB,IAAI,CAACyB,iBAAiB,CAAC;QAAEC,IAAI,EAAE;MAAQ,CAAC,EAAE;QAAET,KAAK;QAAEE;MAAS,CAAC,CAAC;IACtE,CAAC,CAAC,OAAOd,KAAK,EAAE;MACdkB,QAAQ,CAAClB,KAAK,YAAYC,KAAK,GAAGD,KAAK,CAACE,OAAO,GAAG,2BAA2B,CAAC;IAChF;IACAe,YAAY,CAAC,KAAK,CAAC;EACrB,CAAC;EAED,oBACEpC,KAAA,CAAAsB,aAAA,CAAClB,IAAI;IAACmB,KAAK,EAAEC,MAAM,CAACiB;EAAO,gBACzBzC,KAAA,CAAAsB,aAAA,CAACxB,eAAe;IAAC4C,KAAK,EAAEnC,UAAW;IAACoC,QAAQ,EAAEX,QAAS;IAACY,KAAK,EAAEb;EAAM,CAAE,CAAC,eACxE/B,KAAA,CAAAsB,aAAA,CAACxB,eAAe;IAAC4C,KAAK,EAAE/B,aAAc;IAACgC,QAAQ,EAAET,WAAY;IAACU,KAAK,EAAEX;EAAS,CAAE,CAAC,EAChFd,KAAK,iBACJnB,KAAA,CAAAsB,aAAA,CAAClB,IAAI;IAACmB,KAAK,EAAEC,MAAM,CAACL;EAAM,gBACxBnB,KAAA,CAAAsB,aAAA,CAACvB,GAAG;IAACwB,KAAK,EAAEC,MAAM,CAACqB;EAAU,GAAE1B,KAAW,CACtC,CACP,eACDnB,KAAA,CAAAsB,aAAA,CAAClB,IAAI;IAACmB,KAAK,EAAEC,MAAM,CAACC;EAAI,gBACtBzB,KAAA,CAAAsB,aAAA,CAAClB,IAAI;IAACmB,KAAK,EAAEC,MAAM,CAACsB;EAAe,gBACjC9C,KAAA,CAAAsB,aAAA,CAACzB,aAAa;IACZkD,SAAS,EAAEvB,MAAM,CAACwB,wBAAyB;IAC3CC,YAAY,EAAEzB,MAAM,CAAC0B,oBAAqB;IAC1CvB,OAAO,EAAEA,CAAA,KAAM;MACbwB,OAAO,CAACC,GAAG,CAAC,OAAO,CAAC;IACtB;EAAE,GAAC,kBAEU,CACX,CAAC,eACPpD,KAAA,CAAAsB,aAAA,CAACzB,aAAa;IAAC8B,OAAO,EAAEA,CAAA,KAAMW,WAAW,CAAC,CAAE;IAACe,QAAQ,EAAElB;EAAU,GAAC,SAEnD,CACX,CACF,CAAC;AAEX,CAAC;AAED,OAAO,MAAMmB,cAAc,GAAGA,CAAC;EAC7BC;AAGF,CAAC,KAAK;EACJ,MAAMC,WAAW,GAAG7D,cAAc,CAAC,CAAC;EACpC,oBACEK,KAAA,CAAAsB,aAAA,CAAClB,IAAI;IAACmB,KAAK,EAAEC,MAAM,CAACiC;EAAc,gBAChCzD,KAAA,CAAAsB,aAAA,CAACQ,kBAAkB,MAAE,CAAC,EACrByB,cAAc,gBACbvD,KAAA,CAAAsB,aAAA,CAAAtB,KAAA,CAAA0D,QAAA,qBACE1D,KAAA,CAAAsB,aAAA,CAACjB,OAAO;IAACkB,KAAK,EAAE;MAAEoC,eAAe,EAAEH,WAAW;MAAE3B,KAAK,EAAE;IAAO;EAAE,CAAE,CAAC,eACnE7B,KAAA,CAAAsB,aAAA,CAACV,WAAW;IAACC,QAAQ,EAAE0C;EAAe,CAAE,CACxC,CAAC,GACD,IACA,CAAC;AAEX,CAAC;AAED,MAAM/B,MAAM,GAAGrB,UAAU,CAACyD,MAAM,CAAC;EAC/BC,SAAS,EAAE;IACTC,IAAI,EAAE,CAAC;IACPjC,KAAK,EAAE,MAAM;IACbkC,cAAc,EAAE,QAAQ;IACxBC,UAAU,EAAE;EACd,CAAC;EACDvB,MAAM,EAAE;IACNwB,aAAa,EAAE,QAAQ;IACvBC,GAAG,EAAE,EAAE;IACPJ,IAAI,EAAE,CAAC;IACPjC,KAAK,EAAE,MAAM;IACbmC,UAAU,EAAE,QAAQ;IACpBD,cAAc,EAAE;EAClB,CAAC;EACDI,eAAe,EAAE;IACfC,eAAe,EAAE;EACnB,CAAC;EACDX,aAAa,EAAE;IACbW,eAAe,EAAE,EAAE;IACnBC,iBAAiB,EAAE,EAAE;IACrBC,MAAM,EAAE,GAAG;IACXJ,GAAG,EAAE,EAAE;IACPH,cAAc,EAAE,QAAQ;IACxBC,UAAU,EAAE,QAAQ;IACpBnC,KAAK,EAAE;EACT,CAAC;EACDqB,oBAAoB,EAAE;IACpBqB,WAAW,EAAE;EACf,CAAC;EACDvB,wBAAwB,EAAE;IACxBwB,QAAQ,EAAE;EACZ,CAAC;EACD/C,GAAG,EAAE;IACHwC,aAAa,EAAE,KAAK;IACpBF,cAAc,EAAE,eAAe;IAC/BlC,KAAK,EAAE;EACT,CAAC;EACDiB,cAAc,EAAE;IACd;EAAA,CACD;EACD2B,MAAM,EAAE;IACND,QAAQ,EAAE,EAAE;IACZE,OAAO,EAAE,GAAG;IACZC,UAAU,EAAE;EACd,CAAC;EACDC,QAAQ,EAAE;IACRJ,QAAQ,EAAE,EAAE;IACZK,SAAS,EAAE,QAAQ;IACnB;IACAC,aAAa,EAAE;EACjB,CAAC;EACDC,IAAI,EAAE;IACJT,MAAM,EAAE,EAAE;IACVU,UAAU,EAAE;EACd,CAAC;EACDC,IAAI,EAAE;IACJT,QAAQ,EAAE,EAAE;IACZ;IACAU,kBAAkB,EAAE,WAAW;IAC/BP,UAAU,EAAE;EACd,CAAC;EACD/C,WAAW,EAAE;IACXqC,aAAa,EAAE,KAAK;IACpBD,UAAU,EAAE,QAAQ;IACpBD,cAAc,EAAE,QAAQ;IACxBG,GAAG,EAAE,EAAE;IACPrC,KAAK,EAAE;EACT,CAAC;EACDH,iBAAiB,EAAE;IACjBG,KAAK,EAAE;EACT,CAAC;EACDV,KAAK,EAAE,CAAC,CAAC;EACT0B,SAAS,EAAE;IACT2B,QAAQ,EAAE,EAAE;IACZW,KAAK,EAAE;EACT;AACF,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { useAuth } from '@chem-po/react';
|
|
2
|
+
import { Txt } from '@chem-po/react-native';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { ActivityIndicator, StyleSheet, TextInput, TouchableOpacity, View } from 'react-native';
|
|
5
|
+
import { usePhoneVerify } from '../hooks/usePhoneVerify';
|
|
6
|
+
|
|
7
|
+
// UI to send code and verify code
|
|
8
|
+
export const PhoneVerify = ({
|
|
9
|
+
factor
|
|
10
|
+
}) => {
|
|
11
|
+
const {
|
|
12
|
+
handleVerify,
|
|
13
|
+
verifying,
|
|
14
|
+
error,
|
|
15
|
+
code,
|
|
16
|
+
setCode
|
|
17
|
+
} = usePhoneVerify(factor, true);
|
|
18
|
+
const {
|
|
19
|
+
multiFactorVerification: twoFactorVerification,
|
|
20
|
+
multiFactorLoading: loading
|
|
21
|
+
} = useAuth();
|
|
22
|
+
const verificationId = twoFactorVerification === null || twoFactorVerification === void 0 ? void 0 : twoFactorVerification.verificationId;
|
|
23
|
+
let body = null;
|
|
24
|
+
if (loading) {
|
|
25
|
+
body = /*#__PURE__*/React.createElement(View, {
|
|
26
|
+
style: styles.container
|
|
27
|
+
}, /*#__PURE__*/React.createElement(ActivityIndicator, {
|
|
28
|
+
size: "large",
|
|
29
|
+
color: "#0000ff"
|
|
30
|
+
}), /*#__PURE__*/React.createElement(Txt, {
|
|
31
|
+
style: styles.text
|
|
32
|
+
}, "Sending verification code..."));
|
|
33
|
+
} else if (verificationId) {
|
|
34
|
+
body = /*#__PURE__*/React.createElement(View, {
|
|
35
|
+
style: styles.container
|
|
36
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
37
|
+
style: styles.text
|
|
38
|
+
}, "Enter the code sent to your phone:"), /*#__PURE__*/React.createElement(TextInput, {
|
|
39
|
+
style: styles.input,
|
|
40
|
+
value: code,
|
|
41
|
+
onChangeText: setCode,
|
|
42
|
+
placeholder: "Verification Code",
|
|
43
|
+
keyboardType: "number-pad",
|
|
44
|
+
maxLength: 6
|
|
45
|
+
}), error ? /*#__PURE__*/React.createElement(Txt, {
|
|
46
|
+
style: styles.errorText
|
|
47
|
+
}, error) : null, /*#__PURE__*/React.createElement(TouchableOpacity, {
|
|
48
|
+
style: styles.button,
|
|
49
|
+
onPress: handleVerify,
|
|
50
|
+
disabled: verifying
|
|
51
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
52
|
+
style: styles.buttonText
|
|
53
|
+
}, verifying ? 'Verifying...' : 'Verify')));
|
|
54
|
+
} else {
|
|
55
|
+
body = /*#__PURE__*/React.createElement(View, {
|
|
56
|
+
style: styles.container
|
|
57
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
58
|
+
style: styles.text
|
|
59
|
+
}, "We'll send a verification code to ", factor.phoneNumber), /*#__PURE__*/React.createElement(TouchableOpacity, {
|
|
60
|
+
style: styles.button,
|
|
61
|
+
onPress: () => {},
|
|
62
|
+
disabled: loading
|
|
63
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
64
|
+
style: styles.buttonText
|
|
65
|
+
}, "Send Verification Code")));
|
|
66
|
+
}
|
|
67
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
68
|
+
style: styles.wrapper
|
|
69
|
+
}, body);
|
|
70
|
+
};
|
|
71
|
+
const styles = StyleSheet.create({
|
|
72
|
+
wrapper: {
|
|
73
|
+
flex: 1,
|
|
74
|
+
padding: 16
|
|
75
|
+
},
|
|
76
|
+
container: {
|
|
77
|
+
flex: 1,
|
|
78
|
+
alignItems: 'center',
|
|
79
|
+
justifyContent: 'center',
|
|
80
|
+
gap: 16
|
|
81
|
+
},
|
|
82
|
+
text: {
|
|
83
|
+
fontSize: 16,
|
|
84
|
+
textAlign: 'center',
|
|
85
|
+
marginBottom: 8
|
|
86
|
+
},
|
|
87
|
+
input: {
|
|
88
|
+
width: '100%',
|
|
89
|
+
height: 48,
|
|
90
|
+
borderWidth: 1,
|
|
91
|
+
borderColor: '#ccc',
|
|
92
|
+
borderRadius: 8,
|
|
93
|
+
paddingHorizontal: 16,
|
|
94
|
+
fontSize: 16,
|
|
95
|
+
marginBottom: 8
|
|
96
|
+
},
|
|
97
|
+
button: {
|
|
98
|
+
backgroundColor: '#007AFF',
|
|
99
|
+
paddingHorizontal: 24,
|
|
100
|
+
paddingVertical: 12,
|
|
101
|
+
borderRadius: 8,
|
|
102
|
+
minWidth: 200,
|
|
103
|
+
alignItems: 'center'
|
|
104
|
+
},
|
|
105
|
+
buttonText: {
|
|
106
|
+
color: 'white',
|
|
107
|
+
fontSize: 16,
|
|
108
|
+
fontWeight: '600'
|
|
109
|
+
},
|
|
110
|
+
errorText: {
|
|
111
|
+
color: 'red',
|
|
112
|
+
fontSize: 14,
|
|
113
|
+
marginBottom: 8
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
//# sourceMappingURL=PhoneVerify.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["useAuth","Txt","React","ActivityIndicator","StyleSheet","TextInput","TouchableOpacity","View","usePhoneVerify","PhoneVerify","factor","handleVerify","verifying","error","code","setCode","multiFactorVerification","twoFactorVerification","multiFactorLoading","loading","verificationId","body","createElement","style","styles","container","size","color","text","input","value","onChangeText","placeholder","keyboardType","maxLength","errorText","button","onPress","disabled","buttonText","phoneNumber","wrapper","create","flex","padding","alignItems","justifyContent","gap","fontSize","textAlign","marginBottom","width","height","borderWidth","borderColor","borderRadius","paddingHorizontal","backgroundColor","paddingVertical","minWidth","fontWeight"],"sourceRoot":"..\\..\\..\\src","sources":["components/PhoneVerify.tsx"],"mappings":"AACA,SAASA,OAAO,QAAQ,gBAAgB;AACxC,SAASC,GAAG,QAAQ,uBAAuB;AAC3C,OAAOC,KAAK,MAAM,OAAO;AACzB,SAASC,iBAAiB,EAAEC,UAAU,EAAEC,SAAS,EAAEC,gBAAgB,EAAEC,IAAI,QAAQ,cAAc;AAC/F,SAASC,cAAc,QAAQ,yBAAyB;;AAExD;AACA,OAAO,MAAMC,WAAW,GAAGA,CAAC;EAAEC;AAA0C,CAAC,KAAK;EAC5E,MAAM;IAAEC,YAAY;IAAEC,SAAS;IAAEC,KAAK;IAAEC,IAAI;IAAEC;EAAQ,CAAC,GACrDP,cAAc,CAACE,MAAM,EAAE,IAAI,CAAC;EAE9B,MAAM;IAACM,uBAAuB,EAAEC,qBAAqB;IAAEC,kBAAkB,EAAEC;EAAO,CAAC,GAAGnB,OAAO,CAAC,CAAC;EAE/F,MAAMoB,cAAc,GAAGH,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAEG,cAAc;EAE5D,IAAIC,IAAqB,GAAG,IAAI;EAEhC,IAAIF,OAAO,EAAE;IACXE,IAAI,gBACFnB,KAAA,CAAAoB,aAAA,CAACf,IAAI;MAACgB,KAAK,EAAEC,MAAM,CAACC;IAAU,gBAC5BvB,KAAA,CAAAoB,aAAA,CAACnB,iBAAiB;MAACuB,IAAI,EAAC,OAAO;MAACC,KAAK,EAAC;IAAS,CAAE,CAAC,eAClDzB,KAAA,CAAAoB,aAAA,CAACrB,GAAG;MAACsB,KAAK,EAAEC,MAAM,CAACI;IAAK,GAAC,8BAAiC,CACtD,CACP;EACH,CAAC,MAAM,IAAIR,cAAc,EAAE;IACzBC,IAAI,gBACFnB,KAAA,CAAAoB,aAAA,CAACf,IAAI;MAACgB,KAAK,EAAEC,MAAM,CAACC;IAAU,gBAC5BvB,KAAA,CAAAoB,aAAA,CAACrB,GAAG;MAACsB,KAAK,EAAEC,MAAM,CAACI;IAAK,GAAC,oCAAuC,CAAC,eACjE1B,KAAA,CAAAoB,aAAA,CAACjB,SAAS;MACRkB,KAAK,EAAEC,MAAM,CAACK,KAAM;MACpBC,KAAK,EAAEhB,IAAK;MACZiB,YAAY,EAAEhB,OAAQ;MACtBiB,WAAW,EAAC,mBAAmB;MAC/BC,YAAY,EAAC,YAAY;MACzBC,SAAS,EAAE;IAAE,CACd,CAAC,EACDrB,KAAK,gBAAGX,KAAA,CAAAoB,aAAA,CAACrB,GAAG;MAACsB,KAAK,EAAEC,MAAM,CAACW;IAAU,GAAEtB,KAAW,CAAC,GAAG,IAAI,eAC3DX,KAAA,CAAAoB,aAAA,CAAChB,gBAAgB;MAACiB,KAAK,EAAEC,MAAM,CAACY,MAAO;MAACC,OAAO,EAAE1B,YAAa;MAAC2B,QAAQ,EAAE1B;IAAU,gBACjFV,KAAA,CAAAoB,aAAA,CAACrB,GAAG;MAACsB,KAAK,EAAEC,MAAM,CAACe;IAAW,GAAE3B,SAAS,GAAG,cAAc,GAAG,QAAc,CAC3D,CACd,CACP;EACH,CAAC,MAAM;IACLS,IAAI,gBACFnB,KAAA,CAAAoB,aAAA,CAACf,IAAI;MAACgB,KAAK,EAAEC,MAAM,CAACC;IAAU,gBAC5BvB,KAAA,CAAAoB,aAAA,CAACrB,GAAG;MAACsB,KAAK,EAAEC,MAAM,CAACI;IAAK,GAAC,oCAAkC,EAAClB,MAAM,CAAC8B,WAAiB,CAAC,eACrFtC,KAAA,CAAAoB,aAAA,CAAChB,gBAAgB;MAACiB,KAAK,EAAEC,MAAM,CAACY,MAAO;MAACC,OAAO,EAAEA,CAAA,KAAM,CAAC,CAAE;MAACC,QAAQ,EAAEnB;IAAQ,gBAC3EjB,KAAA,CAAAoB,aAAA,CAACrB,GAAG;MAACsB,KAAK,EAAEC,MAAM,CAACe;IAAW,GAAC,wBAA2B,CAC1C,CACd,CACP;EACH;EAEA,oBAAOrC,KAAA,CAAAoB,aAAA,CAACf,IAAI;IAACgB,KAAK,EAAEC,MAAM,CAACiB;EAAQ,GAAEpB,IAAW,CAAC;AACnD,CAAC;AAED,MAAMG,MAAM,GAAGpB,UAAU,CAACsC,MAAM,CAAC;EAC/BD,OAAO,EAAE;IACPE,IAAI,EAAE,CAAC;IACPC,OAAO,EAAE;EACX,CAAC;EACDnB,SAAS,EAAE;IACTkB,IAAI,EAAE,CAAC;IACPE,UAAU,EAAE,QAAQ;IACpBC,cAAc,EAAE,QAAQ;IACxBC,GAAG,EAAE;EACP,CAAC;EACDnB,IAAI,EAAE;IACJoB,QAAQ,EAAE,EAAE;IACZC,SAAS,EAAE,QAAQ;IACnBC,YAAY,EAAE;EAChB,CAAC;EACDrB,KAAK,EAAE;IACLsB,KAAK,EAAE,MAAM;IACbC,MAAM,EAAE,EAAE;IACVC,WAAW,EAAE,CAAC;IACdC,WAAW,EAAE,MAAM;IACnBC,YAAY,EAAE,CAAC;IACfC,iBAAiB,EAAE,EAAE;IACrBR,QAAQ,EAAE,EAAE;IACZE,YAAY,EAAE;EAChB,CAAC;EACDd,MAAM,EAAE;IACNqB,eAAe,EAAE,SAAS;IAC1BD,iBAAiB,EAAE,EAAE;IACrBE,eAAe,EAAE,EAAE;IACnBH,YAAY,EAAE,CAAC;IACfI,QAAQ,EAAE,GAAG;IACbd,UAAU,EAAE;EACd,CAAC;EACDN,UAAU,EAAE;IACVZ,KAAK,EAAE,OAAO;IACdqB,QAAQ,EAAE,EAAE;IACZY,UAAU,EAAE;EACd,CAAC;EACDzB,SAAS,EAAE;IACTR,KAAK,EAAE,KAAK;IACZqB,QAAQ,EAAE,EAAE;IACZE,YAAY,EAAE;EAChB;AACF,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { useAuth, useBackgroundColor } from '@chem-po/react';
|
|
2
|
+
import { Txt } from '@chem-po/react-native';
|
|
3
|
+
import React, { useState } from 'react';
|
|
4
|
+
import { ScrollView, StyleSheet, TouchableOpacity, View } from 'react-native';
|
|
5
|
+
import { Modal, Portal } from 'react-native-paper';
|
|
6
|
+
import { useBackend } from '../hooks/backend';
|
|
7
|
+
import { AuthenticatorVerify } from './AuthenticatorVerify';
|
|
8
|
+
import { PhoneVerify } from './PhoneVerify';
|
|
9
|
+
const TwoFactorSelect = ({
|
|
10
|
+
factors,
|
|
11
|
+
onSelect
|
|
12
|
+
}) => {
|
|
13
|
+
const buttonBackgroundColor = useBackgroundColor(100);
|
|
14
|
+
return /*#__PURE__*/React.createElement(View, {
|
|
15
|
+
style: styles.selectContainer
|
|
16
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
17
|
+
style: styles.selectTitle
|
|
18
|
+
}, "Select an option to verify with:"), /*#__PURE__*/React.createElement(View, {
|
|
19
|
+
style: styles.factorsList
|
|
20
|
+
}, factors.map(factor => /*#__PURE__*/React.createElement(TouchableOpacity, {
|
|
21
|
+
key: factor.uid,
|
|
22
|
+
style: [styles.factorButton, {
|
|
23
|
+
backgroundColor: buttonBackgroundColor
|
|
24
|
+
}],
|
|
25
|
+
onPress: () => onSelect(factor)
|
|
26
|
+
}, /*#__PURE__*/React.createElement(Txt, {
|
|
27
|
+
style: styles.factorHeaderText
|
|
28
|
+
}, factor.type === 'phone' ? `Phone: ${factor.phoneNumber}` : 'Authenticator App'), factor.displayName ? /*#__PURE__*/React.createElement(Txt, {
|
|
29
|
+
style: styles.factorDetailsText
|
|
30
|
+
}, factor.displayName) : null))));
|
|
31
|
+
};
|
|
32
|
+
const TwoFactorVerify = ({
|
|
33
|
+
factorInfo
|
|
34
|
+
}) => factorInfo.type === 'phone' ? /*#__PURE__*/React.createElement(PhoneVerify, {
|
|
35
|
+
factor: factorInfo
|
|
36
|
+
}) : /*#__PURE__*/React.createElement(AuthenticatorVerify, null);
|
|
37
|
+
const TwoFactorContent = () => {
|
|
38
|
+
const [selectedEnrollmentFactor, setSelectedEnrollmentFactor] = useState(null);
|
|
39
|
+
const enrolledFactors = useAuth(s => s.enrollmentFactors);
|
|
40
|
+
if (selectedEnrollmentFactor) return /*#__PURE__*/React.createElement(TwoFactorVerify, {
|
|
41
|
+
factorInfo: selectedEnrollmentFactor
|
|
42
|
+
});
|
|
43
|
+
if (!enrolledFactors) return null;
|
|
44
|
+
if (enrolledFactors.enrollmentFactors.length === 0) return null;
|
|
45
|
+
// if (enrolledFactors.enrollmentFactors.length === 1) return <TwoFactorVerify factorInfo={enrolledFactors.enrollmentFactors[0]} />
|
|
46
|
+
return /*#__PURE__*/React.createElement(TwoFactorSelect, {
|
|
47
|
+
factors: enrolledFactors.enrollmentFactors,
|
|
48
|
+
onSelect: setSelectedEnrollmentFactor
|
|
49
|
+
});
|
|
50
|
+
};
|
|
51
|
+
export const TwoFactorAuthModal = () => {
|
|
52
|
+
const {
|
|
53
|
+
multiFactorVerification: twoFactorVerification,
|
|
54
|
+
enrollmentFactors
|
|
55
|
+
} = useAuth();
|
|
56
|
+
const {
|
|
57
|
+
auth
|
|
58
|
+
} = useBackend();
|
|
59
|
+
const backgroundColor = useBackgroundColor(150);
|
|
60
|
+
if (!twoFactorVerification && !enrollmentFactors) return null;
|
|
61
|
+
return /*#__PURE__*/React.createElement(Portal, null, /*#__PURE__*/React.createElement(Modal, {
|
|
62
|
+
visible: true,
|
|
63
|
+
onDismiss: () => {
|
|
64
|
+
auth.logout();
|
|
65
|
+
},
|
|
66
|
+
contentContainerStyle: [styles.modalContent, {
|
|
67
|
+
backgroundColor
|
|
68
|
+
}],
|
|
69
|
+
style: styles.modal
|
|
70
|
+
}, /*#__PURE__*/React.createElement(ScrollView, {
|
|
71
|
+
contentContainerStyle: styles.scrollContent
|
|
72
|
+
}, /*#__PURE__*/React.createElement(TwoFactorContent, null))));
|
|
73
|
+
};
|
|
74
|
+
const styles = StyleSheet.create({
|
|
75
|
+
modal: {
|
|
76
|
+
margin: 0
|
|
77
|
+
},
|
|
78
|
+
modalContent: {
|
|
79
|
+
margin: 20,
|
|
80
|
+
borderRadius: 12,
|
|
81
|
+
maxHeight: '80%'
|
|
82
|
+
},
|
|
83
|
+
scrollContent: {
|
|
84
|
+
padding: 16
|
|
85
|
+
},
|
|
86
|
+
selectContainer: {
|
|
87
|
+
width: '100%'
|
|
88
|
+
},
|
|
89
|
+
selectTitle: {
|
|
90
|
+
fontSize: 16,
|
|
91
|
+
marginBottom: 16
|
|
92
|
+
},
|
|
93
|
+
factorsList: {
|
|
94
|
+
gap: 8
|
|
95
|
+
},
|
|
96
|
+
factorButton: {
|
|
97
|
+
padding: 16,
|
|
98
|
+
borderRadius: 8,
|
|
99
|
+
borderWidth: 1
|
|
100
|
+
},
|
|
101
|
+
factorHeaderText: {
|
|
102
|
+
fontSize: 14,
|
|
103
|
+
fontWeight: 'bold',
|
|
104
|
+
opacity: 0.8
|
|
105
|
+
},
|
|
106
|
+
factorDetailsText: {
|
|
107
|
+
fontSize: 16
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
//# sourceMappingURL=TwoFactorAuthModal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["useAuth","useBackgroundColor","Txt","React","useState","ScrollView","StyleSheet","TouchableOpacity","View","Modal","Portal","useBackend","AuthenticatorVerify","PhoneVerify","TwoFactorSelect","factors","onSelect","buttonBackgroundColor","createElement","style","styles","selectContainer","selectTitle","factorsList","map","factor","key","uid","factorButton","backgroundColor","onPress","factorHeaderText","type","phoneNumber","displayName","factorDetailsText","TwoFactorVerify","factorInfo","TwoFactorContent","selectedEnrollmentFactor","setSelectedEnrollmentFactor","enrolledFactors","s","enrollmentFactors","length","TwoFactorAuthModal","multiFactorVerification","twoFactorVerification","auth","visible","onDismiss","logout","contentContainerStyle","modalContent","modal","scrollContent","create","margin","borderRadius","maxHeight","padding","width","fontSize","marginBottom","gap","borderWidth","fontWeight","opacity"],"sourceRoot":"..\\..\\..\\src","sources":["components/TwoFactorAuthModal.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"..\\..\\..\\src","sources":["components/index.ts"],"mappings":"AAAA,cAAc,kBAAkB;AAChC,cAAc,sBAAsB","ignoreList":[]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import firebase from '@react-native-firebase/app';
|
|
2
|
+
import React, { createContext, useContext, useEffect, useMemo, useState } from 'react';
|
|
3
|
+
const FirebaseContext = /*#__PURE__*/createContext(null);
|
|
4
|
+
export function FirebaseProvider({
|
|
5
|
+
config,
|
|
6
|
+
children
|
|
7
|
+
}) {
|
|
8
|
+
const [loading, setLoading] = useState(true);
|
|
9
|
+
const [app, setApp] = useState(null);
|
|
10
|
+
const [auth] = useState(firebase.auth());
|
|
11
|
+
const [firestore] = useState(firebase.firestore());
|
|
12
|
+
const [storage] = useState(firebase.storage());
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
const initializeApp = async () => {
|
|
15
|
+
const firebaseApp = await firebase.initializeApp(config);
|
|
16
|
+
setApp(firebaseApp);
|
|
17
|
+
setLoading(false);
|
|
18
|
+
};
|
|
19
|
+
initializeApp();
|
|
20
|
+
}, [config]);
|
|
21
|
+
const value = useMemo(() => ({
|
|
22
|
+
loading,
|
|
23
|
+
app,
|
|
24
|
+
auth,
|
|
25
|
+
firestore,
|
|
26
|
+
storage
|
|
27
|
+
}), [app, auth, firestore, storage, loading]);
|
|
28
|
+
return /*#__PURE__*/React.createElement(FirebaseContext.Provider, {
|
|
29
|
+
value: value
|
|
30
|
+
}, children);
|
|
31
|
+
}
|
|
32
|
+
export function useFirebase() {
|
|
33
|
+
const context = useContext(FirebaseContext);
|
|
34
|
+
if (!context) {
|
|
35
|
+
throw new Error('useFirebase must be used within a FirebaseProvider');
|
|
36
|
+
}
|
|
37
|
+
return context;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=FirebaseContext.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["firebase","React","createContext","useContext","useEffect","useMemo","useState","FirebaseContext","FirebaseProvider","config","children","loading","setLoading","app","setApp","auth","firestore","storage","initializeApp","firebaseApp","value","createElement","Provider","useFirebase","context","Error"],"sourceRoot":"..\\..\\..\\src","sources":["contexts/FirebaseContext.tsx"],"mappings":"AAAA,OAAOA,QAAQ,MAAM,4BAA4B;AACjD,OAAOC,KAAK,IAAIC,aAAa,EAAEC,UAAU,EAAEC,SAAS,EAAEC,OAAO,EAAEC,QAAQ,QAAQ,OAAO;AAStF,MAAMC,eAAe,gBAAGL,aAAa,CAA8B,IAAI,CAAC;AAOxE,OAAO,SAASM,gBAAgBA,CAAC;EAAEC,MAAM;EAAEC;AAAgC,CAAC,EAAE;EAC5E,MAAM,CAACC,OAAO,EAAEC,UAAU,CAAC,GAAGN,QAAQ,CAAC,IAAI,CAAC;EAC5C,MAAM,CAACO,GAAG,EAAEC,MAAM,CAAC,GAAGR,QAAQ,CAAqC,IAAI,CAAC;EACxE,MAAM,CAACS,IAAI,CAAC,GAAGT,QAAQ,CAAeN,QAAQ,CAACe,IAAI,CAAC,CAAC,CAAC;EACtD,MAAM,CAACC,SAAS,CAAC,GAAGV,QAAQ,CAAoBN,QAAQ,CAACgB,SAAS,CAAC,CAAC,CAAC;EACrE,MAAM,CAACC,OAAO,CAAC,GAAGX,QAAQ,CAAkBN,QAAQ,CAACiB,OAAO,CAAC,CAAC,CAAC;EAE/Db,SAAS,CAAC,MAAM;IACd,MAAMc,aAAa,GAAG,MAAAA,CAAA,KAAY;MAChC,MAAMC,WAAW,GAAG,MAAMnB,QAAQ,CAACkB,aAAa,CAACT,MAAM,CAAC;MACxDK,MAAM,CAACK,WAAW,CAAC;MACnBP,UAAU,CAAC,KAAK,CAAC;IACnB,CAAC;IACDM,aAAa,CAAC,CAAC;EACjB,CAAC,EAAE,CAACT,MAAM,CAAC,CAAC;EAEZ,MAAMW,KAA2B,GAAGf,OAAO,CACzC,OAAO;IACLM,OAAO;IACPE,GAAG;IACHE,IAAI;IACJC,SAAS;IACTC;EACF,CAAC,CAAC,EACF,CAACJ,GAAG,EAAEE,IAAI,EAAEC,SAAS,EAAEC,OAAO,EAAEN,OAAO,CACzC,CAAC;EAED,oBAAOV,KAAA,CAAAoB,aAAA,CAACd,eAAe,CAACe,QAAQ;IAACF,KAAK,EAAEA;EAAM,GAAEV,QAAmC,CAAC;AACtF;AAEA,OAAO,SAASa,WAAWA,CAAA,EAAG;EAC5B,MAAMC,OAAO,GAAGrB,UAAU,CAACI,eAAe,CAAC;EAC3C,IAAI,CAACiB,OAAO,EAAE;IACZ,MAAM,IAAIC,KAAK,CAAC,oDAAoD,CAAC;EACvE;EACA,OAAOD,OAAO;AAChB","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"..\\..\\..\\src","sources":["contexts/index.ts"],"mappings":"AAAA,cAAc,mBAAmB","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sourceRoot":"..\\..\\..\\src","sources":["db/index.ts"],"mappings":"AAAA,cAAc,SAAS","ignoreList":[]}
|