import React, { FC, useCallback, useEffect, useRef, useState } from 'react'; import { AppState, AppStateStatus, NativeSyntheticEvent, Platform, requireNativeComponent, ViewStyle, } from 'react-native'; type LabelDirection = 'right' | 'bottom'; type Charset = 'SJIS'; const AndroidQRCodeScannerView = requireNativeComponent<{ style?: ViewStyle; onQRCodeRead: (event: NativeSyntheticEvent) => void; onQRCodeTouch: (event: NativeSyntheticEvent) => void; colorMap?: { [pattern: string]: string }; colorMapForAlreadyRead?: { [pattern: string]: string }; labelMap?: { [pattern: string]: string }; labeledOnlyPatternMatched: boolean; labelColor?: string; labelColorMap?: { [pattern: string]: string }; labelDirection: LabelDirection; alpha?: number; labelAlpha?: number; labelFontSize?: number; // ポイント数 charset?: Charset; }>('QRCodeScannerView'); const IOSQRCodeScannerView = requireNativeComponent<{ style?: ViewStyle; onQRCodeRead: (event: NativeSyntheticEvent) => void; onQRCodeTouch: (event: NativeSyntheticEvent) => void; colorMap?: { [pattern: string]: string }; colorMapForAlreadyRead?: { [pattern: string]: string }; labelMap?: { [pattern: string]: string }; overlayAlpha?: number; labelAlpha?: number; labelFontSize?: number; labeledOnlyPatternMatched: boolean; labelColor?: string; labelColorMap?: { [pattern: string]: string }; labelDirection: LabelDirection; charset?: Charset; // IOSはアプリがバックグラウンドからフォアグアウンドになった時にカメラが止まる // このreloadKeyを変化させるとカメラが再起動する。 // Androidにはこの仕組みは必要ない。 reloadKey: number; }>('LXQRCodeScannerView'); type MultipleQRCodeScannerViewProps = { style?: ViewStyle; onQRCodeRead?: (code: string) => void; onQRCodeTouch?: (code: string) => void; colorMap?: { [pattern: string]: string }; colorMapForAlreadyRead?: { [pattern: string]: string }; labelMap?: { [pattern: string]: string }; labeledOnlyPatternMatched?: boolean; labelColor?: string; labelColorMap?: { [pattern: string]: string }; labelDirection?: LabelDirection; labelFontSize?: number; alpha?: number; labelAlpha?: number; charset?: Charset; }; /** * @param props * @constructor */ const MultipleQRCodeScannerView: FC = ( props ) => { const appState = useRef(AppState.currentState); const [reloadKey, setReloadKey] = useState(0); const _handleAppStateChange = useCallback( (nextAppState: AppStateStatus) => { if ( appState.current.match(/inactive|background/) && nextAppState === 'active' ) { setReloadKey(reloadKey + 1); console.log('App has come to the foreground!'); } appState.current = nextAppState; console.log('AppState', appState.current); }, [reloadKey] ); useEffect(() => { const subscription = AppState.addEventListener( 'change', _handleAppStateChange ); return () => { subscription.remove(); }; }, [_handleAppStateChange]); const onQRCodeRead = useCallback( (event) => { if (!props.onQRCodeRead) { return; } props.onQRCodeRead(event.nativeEvent.code); }, [props] ); const onQRCodeTouch = useCallback( (event) => { if (!props.onQRCodeTouch) { return; } props.onQRCodeTouch(event.nativeEvent.code); }, [props] ); const labeledOnlyPatternMatched = props.labeledOnlyPatternMatched !== undefined ? props.labeledOnlyPatternMatched : true; if (Platform.OS === 'ios') { return ( ); } return ( ); }; export default MultipleQRCodeScannerView;