Skip to content

Commit

Permalink
Merge pull request Expensify#26064 from software-mansion-labs/maciejd…
Browse files Browse the repository at this point in the history
…obosz/exp-171-250-migrate-indexjs-to-function-component

Rewrite WalletStatementModal to functional component
  • Loading branch information
srikarparsi authored Sep 1, 2023
2 parents 567c8c6 + 3a76d56 commit 9b48540
Showing 1 changed file with 32 additions and 40 deletions.
72 changes: 32 additions & 40 deletions src/components/WalletStatementModal/index.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React from 'react';
import React, {useState} from 'react';
import {withOnyx} from 'react-native-onyx';
import lodashGet from 'lodash/get';
import {View} from 'react-native';
Expand All @@ -13,63 +13,55 @@ import ROUTES from '../../ROUTES';
import Navigation from '../../libs/Navigation/Navigation';
import * as Report from '../../libs/actions/Report';

class WalletStatementModal extends React.Component {
constructor(props) {
super(props);

this.state = {
isLoading: true,
};
}
function WalletStatementModal({statementPageURL, session}) {
const [isLoading, setIsLoading] = useState(true);
const authToken = lodashGet(session, 'authToken', null);

/**
* Handles in-app navigation for iframe links
*
* @param {MessageEvent} e
* @param {MessageEvent} event
*/
navigate(e) {
if (!e.data || !e.data.type || (e.data.type !== 'STATEMENT_NAVIGATE' && e.data.type !== 'CONCIERGE_NAVIGATE')) {
const navigate = (event) => {
if (!event.data || !event.data.type || (event.data.type !== 'STATEMENT_NAVIGATE' && event.data.type !== 'CONCIERGE_NAVIGATE')) {
return;
}

if (e.data.type === 'CONCIERGE_NAVIGATE') {
if (event.data.type === 'CONCIERGE_NAVIGATE') {
Report.navigateToConciergeChat();
}

if (e.data.type === 'STATEMENT_NAVIGATE' && e.data.url) {
if (event.data.type === 'STATEMENT_NAVIGATE' && event.data.url) {
const iouRoutes = [ROUTES.IOU_REQUEST, ROUTES.IOU_SEND, ROUTES.IOU_BILL];
const navigateToIOURoute = _.find(iouRoutes, (iouRoute) => e.data.url.includes(iouRoute));
const navigateToIOURoute = _.find(iouRoutes, (iouRoute) => event.data.url.includes(iouRoute));
if (navigateToIOURoute) {
Navigation.navigate(navigateToIOURoute);
}
}
}
};

render() {
const authToken = lodashGet(this.props, 'session.authToken', null);
return (
<>
{this.state.isLoading && <FullScreenLoadingIndicator />}
<View style={[styles.flex1]}>
<iframe
src={`${this.props.statementPageURL}&authToken=${authToken}`}
title="Statements"
height="100%"
width="100%"
seamless="seamless"
frameBorder="0"
onLoad={() => {
this.setState({isLoading: false});
return (
<>
{isLoading && <FullScreenLoadingIndicator />}
<View style={[styles.flex1]}>
<iframe
src={`${statementPageURL}&authToken=${authToken}`}
title="Statements"
height="100%"
width="100%"
seamless="seamless"
frameBorder="0"
onLoad={() => {
setIsLoading(false);

// We listen to a message sent from the iframe to the parent component when a link is clicked.
// This lets us handle navigation in the app, outside of the iframe.
window.onmessage = (e) => this.navigate(e);
}}
/>
</View>
</>
);
}
// We listen to a message sent from the iframe to the parent component when a link is clicked.
// This lets us handle navigation in the app, outside of the iframe.
window.onmessage = navigate;
}}
/>
</View>
</>
);
}

WalletStatementModal.propTypes = walletStatementPropTypes;
Expand Down

0 comments on commit 9b48540

Please sign in to comment.