import { createRef, useState } from 'react'; import { View } from 'react-native'; import { WebView } from 'react-native-webview'; import ErrorOnParams from '../ErrorOnParams'; import Loading from '../Loading'; import { IMPConst } from '../../constants'; import { IMPData, Validation } from '../../utils/Validation'; import viewStyles from '../../styles'; import IamportUrl from '../../utils/IamportUrl'; type Props = { userCode: string; tierCode?: string; data: IMPData.CertificationData; loading?: any; callback: (response: any) => any; }; function Certification({ userCode, tierCode, data, loading, callback }: Props) { const [isWebViewLoaded, setIsWebViewLoaded] = useState(false); const webview = createRef(); const validation = new Validation(userCode, loading, callback, data); let redirectUrl = IMPConst.M_REDIRECT_URL; if (data.m_redirect_url !== undefined && data.m_redirect_url.trim() !== '') { redirectUrl = data.m_redirect_url; } else { data.m_redirect_url = redirectUrl; } if (validation.getIsValid()) { const { loadingContainer, webViewContainer } = viewStyles; return ( <> { if (!isWebViewLoaded) { // html이 load되고 최초 한번만 inject javascript if (tierCode) { webview.current?.injectJavaScript(` setTimeout(function() { IMP.agency("${userCode}", "${tierCode}"); }); `); } else { webview.current?.injectJavaScript(` setTimeout(function() { IMP.init("${userCode}"); }); `); } webview.current?.injectJavaScript(` setTimeout(function() { IMP.certification(${JSON.stringify(data)}, function(response) { window.ReactNativeWebView.postMessage(JSON.stringify(response)); }); }); `); setIsWebViewLoaded(true); } }} onMessage={(e) => { let messageData = e.nativeEvent.data; if (decodeURIComponent(messageData) !== messageData) { messageData = decodeURIComponent(messageData); } let response = JSON.parse(messageData); if (typeof callback === 'function') { callback(response); } }} startInLoadingState renderLoading={() => ( {loading || } )} originWhitelist={['*']} // https://github.com/facebook/react-native/issues/19986 onShouldStartLoadWithRequest={(request) => { const { url } = request; // console.log('url: ' + url); const iamportUrl = new IamportUrl(url); if (iamportUrl.isAppUrl()) { /* 3rd-party 앱 오픈 */ iamportUrl.launchApp().catch((e) => { const { code, message } = e; callback({ imp_success: false, error_code: code, error_msg: message, }); }); return false; } if (iamportUrl.isPaymentOver(redirectUrl)) { callback(iamportUrl.getQuery()); return false; } return true; }} /> ); } return ; } export default Certification;