@bmc-soft/keycloak-auth 2.0.1 → 2.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/README.md +8 -1
- package/dist/_lib/index.d.ts +1 -0
- package/dist/_lib/index.d.ts.map +1 -1
- package/dist/_lib/types/authStage.d.ts +1 -0
- package/dist/_lib/types/authStage.d.ts.map +1 -1
- package/dist/_lib/types/authStage.js +1 -0
- package/dist/_lib/types/authStage.js.map +1 -1
- package/dist/_lib/types/confirmAuthPhase.d.ts +1 -0
- package/dist/_lib/types/confirmAuthPhase.d.ts.map +1 -1
- package/dist/_lib/types/confirmAuthPhase.js +1 -0
- package/dist/_lib/types/confirmAuthPhase.js.map +1 -1
- package/dist/_lib/types/index.d.ts +1 -0
- package/dist/_lib/types/index.d.ts.map +1 -1
- package/dist/_lib/types/successFeedback.d.ts +6 -0
- package/dist/_lib/types/successFeedback.d.ts.map +1 -0
- package/dist/_lib/types/successFeedback.js +2 -0
- package/dist/_lib/types/successFeedback.js.map +1 -0
- package/dist/axios/adapters/KeycloakTokenProvider.js +1 -1
- package/dist/axios/adapters/KeycloakTokenProvider.js.map +1 -1
- package/dist/context/KeycloakConfigContext.d.ts +4 -1
- package/dist/context/KeycloakConfigContext.d.ts.map +1 -1
- package/dist/context/KeycloakConfigContext.js +24 -6
- package/dist/context/KeycloakConfigContext.js.map +1 -1
- package/dist/context/KeycloakInstanceContext.d.ts.map +1 -1
- package/dist/context/KeycloakInstanceContext.js +65 -9
- package/dist/context/KeycloakInstanceContext.js.map +1 -1
- package/dist/context/KeycloakProvider.d.ts +1 -0
- package/dist/context/KeycloakProvider.d.ts.map +1 -1
- package/dist/context/KeycloakProvider.js +2 -2
- package/dist/context/KeycloakProvider.js.map +1 -1
- package/dist/context/TokenContext.d.ts.map +1 -1
- package/dist/context/TokenContext.js +33 -15
- package/dist/context/TokenContext.js.map +1 -1
- package/dist/core/adapter.d.ts.map +1 -1
- package/dist/core/adapter.js +25 -9
- package/dist/core/adapter.js.map +1 -1
- package/dist/core/index.d.ts +1 -1
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/sessionTermination.d.ts +2 -0
- package/dist/core/sessionTermination.d.ts.map +1 -0
- package/dist/core/sessionTermination.js +38 -0
- package/dist/core/sessionTermination.js.map +1 -0
- package/dist/core/types.d.ts +3 -0
- package/dist/core/types.d.ts.map +1 -1
- package/dist/hooks/useKeycloakAuthScreen.d.ts +1 -1
- package/dist/hooks/useKeycloakAuthScreen.d.ts.map +1 -1
- package/dist/hooks/useKeycloakAuthScreen.js +5 -3
- package/dist/hooks/useKeycloakAuthScreen.js.map +1 -1
- package/dist/index.d.ts +3 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/screens/AuthPage/AuthPage.d.ts +2 -1
- package/dist/screens/AuthPage/AuthPage.d.ts.map +1 -1
- package/dist/screens/AuthPage/AuthPage.js +29 -9
- package/dist/screens/AuthPage/AuthPage.js.map +1 -1
- package/dist/screens/ConfirmAuthPage/ConfirmAuthPage.d.ts +4 -0
- package/dist/screens/ConfirmAuthPage/ConfirmAuthPage.d.ts.map +1 -1
- package/dist/screens/ConfirmAuthPage/ConfirmAuthPage.js +119 -19
- package/dist/screens/ConfirmAuthPage/ConfirmAuthPage.js.map +1 -1
- package/dist/storage/credentialStorage.d.ts +2 -0
- package/dist/storage/credentialStorage.d.ts.map +1 -1
- package/dist/storage/credentialStorage.js +55 -0
- package/dist/storage/credentialStorage.js.map +1 -1
- package/dist/storage/index.d.ts +1 -0
- package/dist/storage/index.d.ts.map +1 -1
- package/dist/storage/index.js +1 -0
- package/dist/storage/index.js.map +1 -1
- package/dist/storage/installStorage.d.ts +3 -0
- package/dist/storage/installStorage.d.ts.map +1 -0
- package/dist/storage/installStorage.js +91 -0
- package/dist/storage/installStorage.js.map +1 -0
- package/dist/storage/tokenStorage.d.ts.map +1 -1
- package/dist/storage/tokenStorage.js.map +1 -1
- package/dist/ui/LogoutConfirmSheet/LogoutConfirmSheet.d.ts.map +1 -1
- package/dist/ui/LogoutConfirmSheet/LogoutConfirmSheet.js +6 -5
- package/dist/ui/LogoutConfirmSheet/LogoutConfirmSheet.js.map +1 -1
- package/dist/ui/NumberPad/NumberPad.d.ts +1 -0
- package/dist/ui/NumberPad/NumberPad.d.ts.map +1 -1
- package/dist/ui/NumberPad/NumberPad.js +12 -6
- package/dist/ui/NumberPad/NumberPad.js.map +1 -1
- package/dist/ui/PINConfirm/PINConfirm.d.ts +2 -1
- package/dist/ui/PINConfirm/PINConfirm.d.ts.map +1 -1
- package/dist/ui/PINConfirm/PINConfirm.js +85 -23
- package/dist/ui/PINConfirm/PINConfirm.js.map +1 -1
- package/dist/ui/PINIndicator/PINIndicator.d.ts +1 -0
- package/dist/ui/PINIndicator/PINIndicator.d.ts.map +1 -1
- package/dist/ui/PINIndicator/PINIndicator.js +52 -13
- package/dist/ui/PINIndicator/PINIndicator.js.map +1 -1
- package/dist/ui/PINSetup/PINSetup.d.ts.map +1 -1
- package/dist/ui/PINSetup/PINSetup.js +4 -2
- package/dist/ui/PINSetup/PINSetup.js.map +1 -1
- package/dist/ui/PINSetup/stages/BiometryStage.d.ts.map +1 -1
- package/dist/ui/PINSetup/stages/BiometryStage.js +1 -1
- package/dist/ui/PINSetup/stages/BiometryStage.js.map +1 -1
- package/dist/ui/SuccessAuthAnimation/SuccessAuthAnimation.d.ts +11 -0
- package/dist/ui/SuccessAuthAnimation/SuccessAuthAnimation.d.ts.map +1 -0
- package/dist/ui/SuccessAuthAnimation/SuccessAuthAnimation.js +86 -0
- package/dist/ui/SuccessAuthAnimation/SuccessAuthAnimation.js.map +1 -0
- package/dist/ui/SuccessAuthAnimation/index.d.ts +2 -0
- package/dist/ui/SuccessAuthAnimation/index.d.ts.map +1 -0
- package/dist/ui/SuccessAuthAnimation/index.js +2 -0
- package/dist/ui/SuccessAuthAnimation/index.js.map +1 -0
- package/dist/ui/WebViewLogin/WebViewLogin.d.ts.map +1 -1
- package/dist/ui/WebViewLogin/WebViewLogin.js +117 -10
- package/dist/ui/WebViewLogin/WebViewLogin.js.map +1 -1
- package/dist/ui/WebViewLogout/WebViewLogout.js +4 -4
- package/dist/ui/WebViewLogout/WebViewLogout.js.map +1 -1
- package/dist/ui/index.d.ts +1 -0
- package/dist/ui/index.d.ts.map +1 -1
- package/dist/ui/index.js +1 -0
- package/dist/ui/index.js.map +1 -1
- package/dist/widgets/ReauthBottomSheet/ReauthBottomSheet.d.ts +4 -0
- package/dist/widgets/ReauthBottomSheet/ReauthBottomSheet.d.ts.map +1 -1
- package/dist/widgets/ReauthBottomSheet/ReauthBottomSheet.js +39 -7
- package/dist/widgets/ReauthBottomSheet/ReauthBottomSheet.js.map +1 -1
- package/package.json +7 -3
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import BottomSheet, { BottomSheetBackdrop, BottomSheetView } from '@gorhom/bottom-sheet';
|
|
2
2
|
import React, { forwardRef, useCallback, useImperativeHandle, useRef } from 'react';
|
|
3
3
|
import { StyleSheet, Text, View } from 'react-native';
|
|
4
|
-
import { useSafeAreaInsets } from 'react-native-safe-area-context';
|
|
5
4
|
import { useKeycloakTheme } from '../../context';
|
|
6
5
|
const DEFAULT_TITLE = 'Выйти из аккаунта';
|
|
7
6
|
const DEFAULT_MESSAGE = 'Вы уверены что хотите выйти?';
|
|
@@ -9,7 +8,6 @@ const DEFAULT_CANCEL_TEXT = 'Отмена';
|
|
|
9
8
|
const DEFAULT_CONFIRM_TEXT = 'Выход';
|
|
10
9
|
export const LogoutConfirmSheet = forwardRef(({ title = DEFAULT_TITLE, message = DEFAULT_MESSAGE, cancelText = DEFAULT_CANCEL_TEXT, confirmText = DEFAULT_CONFIRM_TEXT, onCancel, onConfirm, }, ref) => {
|
|
11
10
|
const { ContainedButtonComponent, OutlinedButtonComponent } = useKeycloakTheme();
|
|
12
|
-
const { bottom } = useSafeAreaInsets();
|
|
13
11
|
const bottomSheetRef = useRef(null);
|
|
14
12
|
const open = useCallback(() => {
|
|
15
13
|
bottomSheetRef.current?.snapToIndex(0);
|
|
@@ -26,7 +24,7 @@ export const LogoutConfirmSheet = forwardRef(({ title = DEFAULT_TITLE, message =
|
|
|
26
24
|
const handleConfirm = useCallback(() => {
|
|
27
25
|
onConfirm?.();
|
|
28
26
|
}, [onConfirm]);
|
|
29
|
-
return (<BottomSheet ref={bottomSheetRef} index={-1} enableDynamicSizing bottomInset={
|
|
27
|
+
return (<BottomSheet ref={bottomSheetRef} index={-1} snapPoints={['23%']} enableDynamicSizing={false} bottomInset={0} handleComponent={null} enablePanDownToClose enableOverDrag={false} backdropComponent={renderBackdrop}>
|
|
30
28
|
<BottomSheetView style={styles.content}>
|
|
31
29
|
<Text style={styles.title}>{title}</Text>
|
|
32
30
|
<Text style={styles.message}>{message}</Text>
|
|
@@ -44,8 +42,11 @@ export const LogoutConfirmSheet = forwardRef(({ title = DEFAULT_TITLE, message =
|
|
|
44
42
|
LogoutConfirmSheet.displayName = 'LogoutConfirmSheet';
|
|
45
43
|
const styles = StyleSheet.create({
|
|
46
44
|
content: {
|
|
47
|
-
|
|
48
|
-
|
|
45
|
+
flex: 1,
|
|
46
|
+
justifyContent: 'flex-start',
|
|
47
|
+
paddingHorizontal: 16,
|
|
48
|
+
paddingTop: 18,
|
|
49
|
+
paddingBottom: 16,
|
|
49
50
|
},
|
|
50
51
|
title: {
|
|
51
52
|
fontSize: 18,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LogoutConfirmSheet.js","sourceRoot":"","sources":["../../../src/ui/LogoutConfirmSheet/LogoutConfirmSheet.tsx"],"names":[],"mappings":"AAAA,OAAO,WAAW,EAAE,EAAC,mBAAmB,EAAE,eAAe,EAAC,MAAM,sBAAsB,CAAC;AACvF,OAAO,KAAK,EAAE,EAAC,UAAU,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,EAAC,MAAM,OAAO,CAAC;AAClF,OAAO,EAAC,UAAU,EAAE,IAAI,EAAE,IAAI,EAAC,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"LogoutConfirmSheet.js","sourceRoot":"","sources":["../../../src/ui/LogoutConfirmSheet/LogoutConfirmSheet.tsx"],"names":[],"mappings":"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"}
|
|
@@ -8,6 +8,7 @@ interface NumberPadProps {
|
|
|
8
8
|
biometryType?: 'FaceID' | 'TouchID' | 'Fingerprint' | null;
|
|
9
9
|
BiometryIcon?: React.ReactNode;
|
|
10
10
|
BackspaceIcon?: React.ReactNode;
|
|
11
|
+
disabled?: boolean;
|
|
11
12
|
style?: ViewStyle;
|
|
12
13
|
}
|
|
13
14
|
export declare const NumberPad: React.FC<NumberPadProps>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumberPad.d.ts","sourceRoot":"","sources":["../../../src/ui/NumberPad/NumberPad.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAgB,MAAM,OAAO,CAAC;AACrC,OAAO,EAAuD,SAAS,EAAC,MAAM,cAAc,CAAC;AAsB7F,UAAU,cAAc;IAItB,KAAK,EAAE,MAAM,EAAE,CAAC;IAKhB,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;IAMzC,UAAU,CAAC,EAAE,MAAM,CAAC;IAKpB,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;IAKxB,YAAY,CAAC,EAAE,QAAQ,GAAG,SAAS,GAAG,aAAa,GAAG,IAAI,CAAC;IAK3D,YAAY,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAK/B,aAAa,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"NumberPad.d.ts","sourceRoot":"","sources":["../../../src/ui/NumberPad/NumberPad.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAgB,MAAM,OAAO,CAAC;AACrC,OAAO,EAAuD,SAAS,EAAC,MAAM,cAAc,CAAC;AAsB7F,UAAU,cAAc;IAItB,KAAK,EAAE,MAAM,EAAE,CAAC;IAKhB,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;IAMzC,UAAU,CAAC,EAAE,MAAM,CAAC;IAKpB,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;IAKxB,YAAY,CAAC,EAAE,QAAQ,GAAG,SAAS,GAAG,aAAa,GAAG,IAAI,CAAC;IAK3D,YAAY,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAK/B,aAAa,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAMhC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAKnB,KAAK,CAAC,EAAE,SAAS,CAAC;CACnB;AA2BD,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAoI9C,CAAC"}
|
|
@@ -19,18 +19,24 @@ const NUMBER_OF_COLUMNS = 3;
|
|
|
19
19
|
const { width: SCREEN_WIDTH } = Dimensions.get('window');
|
|
20
20
|
const BUTTON_SIZE = (SCREEN_WIDTH - 20 - HORIZONTAL_PADDING * 2 - BUTTON_GAP * NUMBER_OF_COLUMNS * 2) /
|
|
21
21
|
NUMBER_OF_COLUMNS;
|
|
22
|
-
export const NumberPad = ({ value, onChangeValue, codeLength = 4, onBiometry, biometryType, BiometryIcon, BackspaceIcon, style, }) => {
|
|
22
|
+
export const NumberPad = ({ value, onChangeValue, codeLength = 4, onBiometry, biometryType, BiometryIcon, BackspaceIcon, disabled = false, style, }) => {
|
|
23
23
|
const { colors: { numberPadButtonBackground: buttonBackgroundColor, numberPadText: textColor, numberPadDisabled: disabledColor, }, } = useKeycloakTheme();
|
|
24
24
|
const onNumberBackspace = () => {
|
|
25
|
+
if (disabled) {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
25
28
|
onChangeValue(value.slice(0, -1));
|
|
26
29
|
};
|
|
27
30
|
const onNumberPress = (number) => {
|
|
28
|
-
if (value.length === codeLength) {
|
|
31
|
+
if (disabled || value.length === codeLength) {
|
|
29
32
|
return;
|
|
30
33
|
}
|
|
31
34
|
onChangeValue([...value, number]);
|
|
32
35
|
};
|
|
33
36
|
const onBiometryPress = () => {
|
|
37
|
+
if (disabled) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
34
40
|
onBiometry?.();
|
|
35
41
|
};
|
|
36
42
|
const BIOMETRY_ICON_SIZE = 32;
|
|
@@ -47,7 +53,7 @@ export const NumberPad = ({ value, onChangeValue, codeLength = 4, onBiometry, bi
|
|
|
47
53
|
}
|
|
48
54
|
return <Text style={[styles.icon, { color: !value.length ? disabledColor : textColor }]}>⌫</Text>;
|
|
49
55
|
}, [BackspaceIcon, value.length, textColor, disabledColor]);
|
|
50
|
-
const renderKey = ({ number, letters }, index = 0) => (<TouchableOpacity key={number} activeOpacity={0.7} onPress={() => onNumberPress(number)} style={[
|
|
56
|
+
const renderKey = ({ number, letters }, index = 0) => (<TouchableOpacity key={number} activeOpacity={0.7} disabled={disabled} onPress={() => onNumberPress(number)} style={[
|
|
51
57
|
styles.numberButton,
|
|
52
58
|
{
|
|
53
59
|
width: BUTTON_SIZE,
|
|
@@ -68,11 +74,11 @@ export const NumberPad = ({ value, onChangeValue, codeLength = 4, onBiometry, bi
|
|
|
68
74
|
{[numberKeys.slice(0, 3), numberKeys.slice(3, 6), numberKeys.slice(6, 9)].map(renderNumberRow)}
|
|
69
75
|
<View style={[styles.numberRow, styles.rowSpacing]}>
|
|
70
76
|
<View style={styles.sideButtonContainer}>
|
|
71
|
-
{onBiometry ? (<TouchableOpacity style={[styles.sideButton, { width: BUTTON_SIZE }]} onPress={onBiometryPress}>
|
|
77
|
+
{onBiometry ? (<TouchableOpacity style={[styles.sideButton, { width: BUTTON_SIZE }]} disabled={disabled} onPress={onBiometryPress}>
|
|
72
78
|
{defaultBiometryIcon}
|
|
73
79
|
</TouchableOpacity>) : (<View style={[styles.emptyButton, { width: BUTTON_SIZE }]}/>)}
|
|
74
80
|
</View>
|
|
75
|
-
<TouchableOpacity key={0} onPress={() => onNumberPress(0)} style={[
|
|
81
|
+
<TouchableOpacity key={0} disabled={disabled} onPress={() => onNumberPress(0)} style={[
|
|
76
82
|
styles.numberButton,
|
|
77
83
|
styles.keySpacing,
|
|
78
84
|
{
|
|
@@ -86,7 +92,7 @@ export const NumberPad = ({ value, onChangeValue, codeLength = 4, onBiometry, bi
|
|
|
86
92
|
</View>
|
|
87
93
|
</TouchableOpacity>
|
|
88
94
|
<View style={[styles.sideButtonContainer, styles.keySpacing]}>
|
|
89
|
-
<TouchableOpacity style={[styles.sideButton, { width: BUTTON_SIZE }]} disabled={!value.length} key="backspace" onPress={onNumberBackspace}>
|
|
95
|
+
<TouchableOpacity style={[styles.sideButton, { width: BUTTON_SIZE }]} disabled={disabled || !value.length} key="backspace" onPress={onNumberBackspace}>
|
|
90
96
|
{defaultBackspaceIcon}
|
|
91
97
|
</TouchableOpacity>
|
|
92
98
|
</View>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NumberPad.js","sourceRoot":"","sources":["../../../src/ui/NumberPad/NumberPad.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAC,OAAO,EAAC,MAAM,OAAO,CAAC;AACrC,OAAO,EAAC,UAAU,EAAE,UAAU,EAAE,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAY,MAAM,cAAc,CAAC;AAE7F,OAAO,EAAC,gBAAgB,EAAC,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAC,UAAU,EAAE,eAAe,EAAC,MAAM,UAAU,CAAC;AAOrD,MAAM,UAAU,GAAgB;IAC9B,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAC;IACxB,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAC;IAC3B,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAC;IAC3B,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAC;IAC3B,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAC;IAC3B,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAC;IAC3B,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAC;IAC5B,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAC;IAC3B,EAAC,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAC;CAC7B,CAAC;
|
|
1
|
+
{"version":3,"file":"NumberPad.js","sourceRoot":"","sources":["../../../src/ui/NumberPad/NumberPad.tsx"],"names":[],"mappings":"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"}
|
|
@@ -5,12 +5,13 @@ interface PINConfirmProps {
|
|
|
5
5
|
onSuccess?: (credentials?: {
|
|
6
6
|
username: string;
|
|
7
7
|
password: string;
|
|
8
|
-
}) => void
|
|
8
|
+
}) => void | Promise<void>;
|
|
9
9
|
onError?: (error: Error) => void;
|
|
10
10
|
allowBiometry?: boolean;
|
|
11
11
|
autoShowBiometry?: boolean;
|
|
12
12
|
title?: string;
|
|
13
13
|
description?: string;
|
|
14
|
+
compact?: boolean;
|
|
14
15
|
style?: ViewStyle;
|
|
15
16
|
}
|
|
16
17
|
export declare const PINConfirm: React.FC<PINConfirmProps>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PINConfirm.d.ts","sourceRoot":"","sources":["../../../src/ui/PINConfirm/PINConfirm.tsx"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"PINConfirm.d.ts","sourceRoot":"","sources":["../../../src/ui/PINConfirm/PINConfirm.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAiD,MAAM,OAAO,CAAC;AACtE,OAAO,EAAuD,SAAS,EAAC,MAAM,cAAc,CAAC;AAY7F,UAAU,eAAe;IAKvB,SAAS,CAAC,EAAE,MAAM,CAAC;IAMnB,SAAS,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAC,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAKzF,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IAMjC,aAAa,CAAC,EAAE,OAAO,CAAC;IAMxB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAK3B,KAAK,CAAC,EAAE,MAAM,CAAC;IAKf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAKlB,KAAK,CAAC,EAAE,SAAS,CAAC;CACnB;AAoBD,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAyLhD,CAAC"}
|
|
@@ -1,57 +1,90 @@
|
|
|
1
|
-
import React, { useCallback, useEffect, useState } from 'react';
|
|
2
|
-
import { StyleSheet, Text, View } from 'react-native';
|
|
1
|
+
import React, { useCallback, useEffect, useRef, useState } from 'react';
|
|
2
|
+
import { InteractionManager, Platform, StyleSheet, Text, View } from 'react-native';
|
|
3
3
|
import { useKeycloakTheme } from '../../context/KeycloakThemeContext';
|
|
4
4
|
import { getBiometryEnabled, getSupportedBiometryType, verifyBiometry, verifyPIN, } from '../../storage';
|
|
5
5
|
import { NumberPad } from '../NumberPad';
|
|
6
6
|
import { PINIndicator } from '../PINIndicator';
|
|
7
|
-
export const PINConfirm = ({ pinLength = 4, onSuccess, onError, allowBiometry = true, autoShowBiometry = true, title = 'Введите PIN', style, }) => {
|
|
7
|
+
export const PINConfirm = ({ pinLength = 4, onSuccess, onError, allowBiometry = true, autoShowBiometry = true, title = 'Введите PIN', description, compact = false, style, }) => {
|
|
8
8
|
const { colors } = useKeycloakTheme();
|
|
9
9
|
const [pin, setPin] = useState([]);
|
|
10
10
|
const [error, setError] = useState(null);
|
|
11
11
|
const [biometryType, setBiometryType] = useState(null);
|
|
12
|
-
const [
|
|
12
|
+
const [biometryEnabledValue, setBiometryEnabledValue] = useState(false);
|
|
13
13
|
const [isVerifying, setIsVerifying] = useState(false);
|
|
14
|
+
const [isProcessingSuccess, setIsProcessingSuccess] = useState(false);
|
|
15
|
+
const autoBiometryTimerRef = useRef(null);
|
|
16
|
+
const biometrySuccessRef = useRef(false);
|
|
17
|
+
const mountedRef = useRef(true);
|
|
14
18
|
const { background, text } = colors;
|
|
19
|
+
useEffect(() => () => {
|
|
20
|
+
mountedRef.current = false;
|
|
21
|
+
}, []);
|
|
15
22
|
useEffect(() => {
|
|
16
23
|
const checkBiometry = async () => {
|
|
17
24
|
try {
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
25
|
+
const enabled = await getBiometryEnabled();
|
|
26
|
+
const type = enabled ? await getSupportedBiometryType() : null;
|
|
27
|
+
if (!mountedRef.current)
|
|
28
|
+
return;
|
|
22
29
|
setBiometryType(type);
|
|
23
|
-
|
|
30
|
+
setBiometryEnabledValue(enabled && !!type);
|
|
24
31
|
}
|
|
25
32
|
catch (err) {
|
|
26
33
|
console.error('[PINConfirm] Ошибка проверки биометрии:', err);
|
|
34
|
+
if (!mountedRef.current)
|
|
35
|
+
return;
|
|
27
36
|
setBiometryType(null);
|
|
28
|
-
|
|
37
|
+
setBiometryEnabledValue(false);
|
|
29
38
|
}
|
|
30
39
|
};
|
|
31
40
|
checkBiometry();
|
|
32
41
|
}, []);
|
|
33
42
|
useEffect(() => {
|
|
34
|
-
if (autoShowBiometry && allowBiometry &&
|
|
43
|
+
if (autoShowBiometry && allowBiometry && biometryEnabledValue && biometryType) {
|
|
44
|
+
if (Platform.OS === 'android') {
|
|
45
|
+
let cancelled = false;
|
|
46
|
+
const interactionHandle = InteractionManager.runAfterInteractions(() => {
|
|
47
|
+
autoBiometryTimerRef.current = setTimeout(() => {
|
|
48
|
+
autoBiometryTimerRef.current = null;
|
|
49
|
+
if (!cancelled && mountedRef.current) {
|
|
50
|
+
handleBiometry();
|
|
51
|
+
}
|
|
52
|
+
}, 350);
|
|
53
|
+
});
|
|
54
|
+
return () => {
|
|
55
|
+
cancelled = true;
|
|
56
|
+
interactionHandle?.cancel?.();
|
|
57
|
+
if (autoBiometryTimerRef.current) {
|
|
58
|
+
clearTimeout(autoBiometryTimerRef.current);
|
|
59
|
+
autoBiometryTimerRef.current = null;
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
}
|
|
35
63
|
handleBiometry();
|
|
36
64
|
}
|
|
37
|
-
|
|
65
|
+
return undefined;
|
|
66
|
+
}, [autoShowBiometry, allowBiometry, biometryEnabledValue, biometryType]);
|
|
38
67
|
useEffect(() => {
|
|
39
68
|
if (pin.length > 0 && error) {
|
|
40
69
|
setError(null);
|
|
41
70
|
}
|
|
42
71
|
}, [pin.length, error]);
|
|
43
72
|
useEffect(() => {
|
|
44
|
-
if (pin.length === pinLength && !isVerifying) {
|
|
73
|
+
if (pin.length === pinLength && !isVerifying && !isProcessingSuccess) {
|
|
45
74
|
handleVerifyPIN();
|
|
46
75
|
}
|
|
47
|
-
}, [pin, pinLength, isVerifying]);
|
|
76
|
+
}, [pin, pinLength, isVerifying, isProcessingSuccess]);
|
|
48
77
|
const handleVerifyPIN = async () => {
|
|
49
78
|
setIsVerifying(true);
|
|
50
79
|
try {
|
|
51
80
|
const pinStr = pin.join('');
|
|
52
81
|
const isPINValid = await verifyPIN(pinStr);
|
|
82
|
+
if (!mountedRef.current)
|
|
83
|
+
return;
|
|
53
84
|
if (isPINValid) {
|
|
54
|
-
|
|
85
|
+
biometrySuccessRef.current = false;
|
|
86
|
+
setIsProcessingSuccess(true);
|
|
87
|
+
await onSuccess?.();
|
|
55
88
|
}
|
|
56
89
|
else {
|
|
57
90
|
const errorMsg = 'Неверный PIN';
|
|
@@ -61,41 +94,61 @@ export const PINConfirm = ({ pinLength = 4, onSuccess, onError, allowBiometry =
|
|
|
61
94
|
}
|
|
62
95
|
}
|
|
63
96
|
catch (err) {
|
|
97
|
+
if (!mountedRef.current)
|
|
98
|
+
return;
|
|
64
99
|
const pinError = err instanceof Error ? err : new Error('Ошибка проверки PIN');
|
|
65
100
|
setError(pinError.message);
|
|
66
101
|
setPin([]);
|
|
67
102
|
onError?.(pinError);
|
|
68
103
|
}
|
|
69
104
|
finally {
|
|
70
|
-
|
|
105
|
+
if (mountedRef.current) {
|
|
106
|
+
setIsVerifying(false);
|
|
107
|
+
setIsProcessingSuccess(false);
|
|
108
|
+
}
|
|
71
109
|
}
|
|
72
110
|
};
|
|
73
111
|
const handleBiometry = useCallback(async () => {
|
|
74
|
-
if (!
|
|
112
|
+
if (!biometryEnabledValue || !biometryType) {
|
|
75
113
|
return;
|
|
76
114
|
}
|
|
77
115
|
try {
|
|
78
116
|
const isBiometryValid = await verifyBiometry();
|
|
117
|
+
if (!mountedRef.current)
|
|
118
|
+
return;
|
|
79
119
|
if (isBiometryValid) {
|
|
80
|
-
|
|
120
|
+
biometrySuccessRef.current = true;
|
|
121
|
+
setIsProcessingSuccess(true);
|
|
122
|
+
await onSuccess?.();
|
|
81
123
|
}
|
|
82
124
|
}
|
|
83
125
|
catch (err) {
|
|
84
126
|
console.error('[PINConfirm] Биометрия не удалась:', err);
|
|
127
|
+
if (!mountedRef.current)
|
|
128
|
+
return;
|
|
85
129
|
setError('Ошибка биометрической аутентификации');
|
|
86
130
|
}
|
|
87
|
-
|
|
131
|
+
finally {
|
|
132
|
+
if (mountedRef.current) {
|
|
133
|
+
setIsProcessingSuccess(false);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}, [biometryEnabledValue, biometryType, onSuccess]);
|
|
137
|
+
const displayedPin = isProcessingSuccess && biometrySuccessRef.current
|
|
138
|
+
? Array.from({ length: pinLength }, () => 0)
|
|
139
|
+
: pin;
|
|
88
140
|
return (<View style={[styles.container, { backgroundColor: background }, style]}>
|
|
89
|
-
<View style={styles.content}>
|
|
141
|
+
<View style={[styles.content, compact && styles.compactContent]}>
|
|
90
142
|
<View style={styles.header}>
|
|
91
143
|
<Text style={[styles.title, { color: text }]}>{title}</Text>
|
|
144
|
+
{description ? (<Text style={[styles.description, { color: text }]}>{description}</Text>) : null}
|
|
92
145
|
</View>
|
|
93
146
|
|
|
94
|
-
<View style={styles.indicatorContainer}>
|
|
95
|
-
<PINIndicator value={
|
|
147
|
+
<View style={[styles.indicatorContainer, compact && styles.compactIndicatorContainer]}>
|
|
148
|
+
<PINIndicator value={displayedPin} codeLength={pinLength} error={error} loading={isProcessingSuccess}/>
|
|
96
149
|
</View>
|
|
97
150
|
|
|
98
|
-
<NumberPad value={pin} onChangeValue={setPin} codeLength={pinLength} onBiometry={allowBiometry &&
|
|
151
|
+
<NumberPad value={pin} onChangeValue={setPin} codeLength={pinLength} onBiometry={allowBiometry && biometryEnabledValue ? handleBiometry : undefined} biometryType={biometryType} disabled={isProcessingSuccess}/>
|
|
99
152
|
</View>
|
|
100
153
|
</View>);
|
|
101
154
|
};
|
|
@@ -109,6 +162,11 @@ const styles = StyleSheet.create({
|
|
|
109
162
|
justifyContent: 'space-between',
|
|
110
163
|
paddingTop: 24,
|
|
111
164
|
},
|
|
165
|
+
compactContent: {
|
|
166
|
+
flex: 1,
|
|
167
|
+
justifyContent: 'space-between',
|
|
168
|
+
paddingTop: 0,
|
|
169
|
+
},
|
|
112
170
|
header: {
|
|
113
171
|
alignItems: 'center',
|
|
114
172
|
},
|
|
@@ -127,6 +185,10 @@ const styles = StyleSheet.create({
|
|
|
127
185
|
alignItems: 'center',
|
|
128
186
|
marginVertical: 40,
|
|
129
187
|
},
|
|
188
|
+
compactIndicatorContainer: {
|
|
189
|
+
marginTop: 24,
|
|
190
|
+
marginBottom: 28,
|
|
191
|
+
},
|
|
130
192
|
errorContainer: {
|
|
131
193
|
alignItems: 'center',
|
|
132
194
|
marginTop: -20,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PINConfirm.js","sourceRoot":"","sources":["../../../src/ui/PINConfirm/PINConfirm.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAC,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAC,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"PINConfirm.js","sourceRoot":"","sources":["../../../src/ui/PINConfirm/PINConfirm.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PINIndicator.d.ts","sourceRoot":"","sources":["../../../src/ui/PINIndicator/PINIndicator.tsx"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"PINIndicator.d.ts","sourceRoot":"","sources":["../../../src/ui/PINIndicator/PINIndicator.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmC,MAAM,OAAO,CAAC;AACxD,OAAO,EAAmC,SAAS,EAAC,MAAM,cAAc,CAAC;AAIzE,UAAU,iBAAiB;IAIzB,KAAK,EAAE,MAAM,EAAE,CAAC;IAKhB,UAAU,EAAE,MAAM,CAAC;IAKnB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAKtB,OAAO,CAAC,EAAE,MAAM,CAAC;IAKjB,UAAU,CAAC,EAAE,MAAM,CAAC;IAKpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAKlB,KAAK,CAAC,EAAE,SAAS,CAAC;CACnB;AAaD,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAsFpD,CAAC"}
|
|
@@ -1,24 +1,63 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { StyleSheet, Text, View } from 'react-native';
|
|
1
|
+
import React, { useEffect, useMemo, useRef } from 'react';
|
|
2
|
+
import { Animated, StyleSheet, Text, View } from 'react-native';
|
|
3
3
|
import { useKeycloakTheme } from '../../context';
|
|
4
4
|
const ERROR_PLACEHOLDER_MIN_HEIGHT = 22;
|
|
5
|
-
export const PINIndicator = ({ value, codeLength, error = null, dotSize = 28, dotSpacing = 8, style, }) => {
|
|
5
|
+
export const PINIndicator = ({ value, codeLength, error = null, dotSize = 28, dotSpacing = 8, loading = false, style, }) => {
|
|
6
6
|
const { colors: { primary: filledColor, pinIndicatorEmpty: emptyColor, error: errorColor }, } = useKeycloakTheme();
|
|
7
7
|
const hasError = Boolean(error);
|
|
8
8
|
const dotFilledColor = hasError ? errorColor : filledColor;
|
|
9
9
|
const dotEmptyColor = hasError ? `${errorColor}30` : emptyColor;
|
|
10
|
+
const pulse = useRef(new Animated.Value(0)).current;
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (!loading || hasError) {
|
|
13
|
+
pulse.stopAnimation();
|
|
14
|
+
pulse.setValue(0);
|
|
15
|
+
return undefined;
|
|
16
|
+
}
|
|
17
|
+
const animation = Animated.loop(Animated.sequence([
|
|
18
|
+
Animated.timing(pulse, {
|
|
19
|
+
toValue: 1,
|
|
20
|
+
duration: 420,
|
|
21
|
+
useNativeDriver: true,
|
|
22
|
+
}),
|
|
23
|
+
Animated.timing(pulse, {
|
|
24
|
+
toValue: 0,
|
|
25
|
+
duration: 420,
|
|
26
|
+
useNativeDriver: true,
|
|
27
|
+
}),
|
|
28
|
+
]));
|
|
29
|
+
animation.start();
|
|
30
|
+
return () => animation.stop();
|
|
31
|
+
}, [hasError, loading, pulse]);
|
|
32
|
+
const loadingDotStyle = useMemo(() => ({
|
|
33
|
+
opacity: pulse.interpolate({
|
|
34
|
+
inputRange: [0, 1],
|
|
35
|
+
outputRange: [1, 0.55],
|
|
36
|
+
}),
|
|
37
|
+
transform: [
|
|
38
|
+
{
|
|
39
|
+
scale: pulse.interpolate({
|
|
40
|
+
inputRange: [0, 1],
|
|
41
|
+
outputRange: [1, 0.82],
|
|
42
|
+
}),
|
|
43
|
+
},
|
|
44
|
+
],
|
|
45
|
+
}), [pulse]);
|
|
10
46
|
const dots = Array.from({ length: codeLength }, (_, index) => {
|
|
11
47
|
const isFilled = index < value.length;
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
48
|
+
const dotStyle = [
|
|
49
|
+
styles.dot,
|
|
50
|
+
{
|
|
51
|
+
width: dotSize,
|
|
52
|
+
height: dotSize,
|
|
53
|
+
borderRadius: dotSize / 2,
|
|
54
|
+
backgroundColor: isFilled ? dotFilledColor : dotEmptyColor,
|
|
55
|
+
marginHorizontal: dotSpacing / 2,
|
|
56
|
+
},
|
|
57
|
+
loading && isFilled && !hasError ? loadingDotStyle : null,
|
|
58
|
+
];
|
|
59
|
+
const DotComponent = loading && isFilled && !hasError ? Animated.View : View;
|
|
60
|
+
return <DotComponent key={index} style={dotStyle}/>;
|
|
22
61
|
});
|
|
23
62
|
return (<View style={[styles.container, style]}>
|
|
24
63
|
<View style={styles.dotsRow}>{dots}</View>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PINIndicator.js","sourceRoot":"","sources":["../../../src/ui/PINIndicator/PINIndicator.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"PINIndicator.js","sourceRoot":"","sources":["../../../src/ui/PINIndicator/PINIndicator.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PINSetup.d.ts","sourceRoot":"","sources":["../../../src/ui/PINSetup/PINSetup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAuD,MAAM,OAAO,CAAC;AAC5E,OAAO,EAAO,SAAS,EAAC,MAAM,cAAc,CAAC;AAQ7C,UAAU,aAAa;IAKrB,SAAS,CAAC,EAAE,MAAM,CAAC;IAMnB,SAAS,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC;IAKlC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IAMjC,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAK7B,UAAU,CAAC,EAAE,MAAM,CAAC;IAKpB,YAAY,CAAC,EAAE,MAAM,CAAC;IAKtB,aAAa,CAAC,EAAE,MAAM,CAAC;IAKvB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAK1B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAK5B,KAAK,CAAC,EAAE,SAAS,CAAC;CACnB;AAmBD,eAAO,MAAM,QAAQ,2KAYhB,aAAa,
|
|
1
|
+
{"version":3,"file":"PINSetup.d.ts","sourceRoot":"","sources":["../../../src/ui/PINSetup/PINSetup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAuD,MAAM,OAAO,CAAC;AAC5E,OAAO,EAAO,SAAS,EAAC,MAAM,cAAc,CAAC;AAQ7C,UAAU,aAAa;IAKrB,SAAS,CAAC,EAAE,MAAM,CAAC;IAMnB,SAAS,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC;IAKlC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IAMjC,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAK7B,UAAU,CAAC,EAAE,MAAM,CAAC;IAKpB,YAAY,CAAC,EAAE,MAAM,CAAC;IAKtB,aAAa,CAAC,EAAE,MAAM,CAAC;IAKvB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAK1B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAK5B,KAAK,CAAC,EAAE,SAAS,CAAC;CACnB;AAmBD,eAAO,MAAM,QAAQ,2KAYhB,aAAa,uBAwJjB,CAAC"}
|
|
@@ -2,7 +2,7 @@ import React, { memo, useCallback, useEffect, useRef, useState } from 'react';
|
|
|
2
2
|
import { View } from 'react-native';
|
|
3
3
|
import { SETUP_STAGE } from '../../_lib';
|
|
4
4
|
import { useKeycloakTheme } from '../../context/KeycloakThemeContext';
|
|
5
|
-
import { getSupportedBiometryType, saveBiometryEnabled } from '../../storage';
|
|
5
|
+
import { getSupportedBiometryType, requestBiometryPermission, saveBiometryEnabled } from '../../storage';
|
|
6
6
|
import { BiometryStage, ConfirmStage, EnterStage } from './stages';
|
|
7
7
|
import { pinSetupStyles } from './styles';
|
|
8
8
|
export const PINSetup = memo(({ pinLength = 4, onSuccess, onError, showBiometryPrompt = true, enterTitle = 'Придумайте PIN-код', confirmTitle = 'Подтвердите PIN-код', biometryTitle = 'Использовать биометрию?', enterDescription = 'Этот код будет использоваться для входа в приложение', confirmDescription = 'Введите PIN-код еще раз', style, }) => {
|
|
@@ -50,11 +50,13 @@ export const PINSetup = memo(({ pinLength = 4, onSuccess, onError, showBiometryP
|
|
|
50
50
|
const handleBiometryAccept = useCallback(async () => {
|
|
51
51
|
try {
|
|
52
52
|
setIsLoading(true);
|
|
53
|
-
await
|
|
53
|
+
const biometryGranted = await requestBiometryPermission();
|
|
54
|
+
await saveBiometryEnabled(biometryGranted);
|
|
54
55
|
onSuccess?.(pin.join(''));
|
|
55
56
|
}
|
|
56
57
|
catch (err) {
|
|
57
58
|
const biometryError = err instanceof Error ? err : new Error('Ошибка настройки биометрии');
|
|
59
|
+
await saveBiometryEnabled(false);
|
|
58
60
|
onError?.(biometryError);
|
|
59
61
|
onSuccess?.(pin.join(''));
|
|
60
62
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PINSetup.js","sourceRoot":"","sources":["../../../src/ui/PINSetup/PINSetup.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAC,IAAI,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAC,MAAM,OAAO,CAAC;AAC5E,OAAO,EAAC,IAAI,EAAY,MAAM,cAAc,CAAC;AAE7C,OAAO,EAAC,WAAW,EAAkB,MAAM,YAAY,CAAC;AACxD,OAAO,EAAC,gBAAgB,EAAC,MAAM,oCAAoC,CAAC;AACpE,OAAO,EAAC,wBAAwB,EAAE,mBAAmB,EAAC,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"PINSetup.js","sourceRoot":"","sources":["../../../src/ui/PINSetup/PINSetup.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BiometryStage.d.ts","sourceRoot":"","sources":["../../../../src/ui/PINSetup/stages/BiometryStage.tsx"],"names":[],"mappings":"AACA,OAAO,KAAsB,MAAM,OAAO,CAAC;AAS3C,UAAU,kBAAkB;IAC1B,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,QAAQ,EAAE,MAAM,IAAI,CAAC;IAC9B,QAAQ,CAAC,MAAM,EAAE,MAAM,IAAI,CAAC;CAC7B;AAwDD,eAAO,MAAM,aAAa,
|
|
1
|
+
{"version":3,"file":"BiometryStage.d.ts","sourceRoot":"","sources":["../../../../src/ui/PINSetup/stages/BiometryStage.tsx"],"names":[],"mappings":"AACA,OAAO,KAAsB,MAAM,OAAO,CAAC;AAS3C,UAAU,kBAAkB;IAC1B,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,QAAQ,EAAE,MAAM,IAAI,CAAC;IAC9B,QAAQ,CAAC,MAAM,EAAE,MAAM,IAAI,CAAC;CAC7B;AAwDD,eAAO,MAAM,aAAa,gDAwCxB,CAAC"}
|
|
@@ -66,7 +66,7 @@ export const BiometryStage = memo(function BiometryStage({ title, biometryType,
|
|
|
66
66
|
</Text>
|
|
67
67
|
|
|
68
68
|
<View style={styles.animationContainer}>
|
|
69
|
-
<LottieView source={animationSource} style={styles.animation} speed={animationSpeed} autoPlay loop/>
|
|
69
|
+
<LottieView source={animationSource} style={styles.animation} speed={animationSpeed} colorFilters={[{ keypath: '**', color: textColor }]} autoPlay loop/>
|
|
70
70
|
</View>
|
|
71
71
|
|
|
72
72
|
<View style={styles.buttonsBlock}>
|