import React, { useState, forwardRef, useImperativeHandle, useRef } from 'react'; import { View, Text } from 'react-native'; import { Col, Row, Grid } from 'react-native-easy-grid'; import _ from 'lodash'; import PropTypes from 'prop-types'; import * as Animatable from 'react-native-animatable'; import * as Haptics from 'expo-haptics'; import styles from './styles'; import Button from './Button'; import Dots from './Dots'; import { TYPE } from '../constants'; import { themes } from '../../../constants/colors'; import { PASSCODE_LENGTH } from '../../../constants/localAuthentication'; const Base = forwardRef(({ theme, type, onEndProcess, previousPasscode, title, subtitle, onError }, ref) => { const rootRef = useRef(); const dotsRef = useRef(); const [passcode, setPasscode] = useState(''); const wrongPasscode = () => { setPasscode(''); dotsRef?.current?.shake(500); Haptics.notificationAsync(Haptics.NotificationFeedbackType.Error); }; const animate = (animation, duration = 500) => { rootRef?.current?.[animation](duration); }; const onPressNumber = text => setPasscode((p) => { const currentPasscode = p + text; if (currentPasscode?.length === PASSCODE_LENGTH) { switch (type) { case TYPE.CHOOSE: onEndProcess(currentPasscode); break; case TYPE.CONFIRM: if (currentPasscode !== previousPasscode) { onError(); } else { onEndProcess(currentPasscode); } break; case TYPE.ENTER: onEndProcess(currentPasscode); break; default: break; } return ''; } return currentPasscode; }); const onPressDelete = () => setPasscode((p) => { if (p?.length > 0) { const newPasscode = p.slice(0, -1); return newPasscode; } return ''; }); useImperativeHandle(ref, () => ({ wrongPasscode, animate })); return ( {title} {subtitle ? {subtitle} : null} {_.range(1, 4).map(i => (