[RN] Fix passing url prop to Root and App components

React (pun intended) to prop changes, that is, load the new specified URL.

In addition, fix a hidden bug in loading the initial URL from the linking
module: we prefer a prop to the URL the app was launched with, in case somehow
both are specified. We (the Jitsi Meet app) are not going to run into this
corner case, but let's be defensive just in case.
This commit is contained in:
Saúl Ibarra Corretgé 2017-07-06 10:01:35 +02:00 committed by Lyubo Marinov
parent 35fddfa8f4
commit cc9249ba1a
2 changed files with 30 additions and 10 deletions

View File

@ -137,6 +137,11 @@ export class AbstractApp extends Component {
store: this._maybeCreateStore(nextProps) store: this._maybeCreateStore(nextProps)
}); });
} }
// Deal with URL changes
if (typeof nextProps.url !== 'undefined') {
this._openURL(nextProps.url || this._getDefaultURL());
}
} }
/** /**

View File

@ -56,18 +56,33 @@ class Root extends Component {
url: this.props.url url: this.props.url
}; };
// Handle the URL, if any, with which the app was launched. // Handle the URL the application was launched with, but props have
Linking.getInitialURL() // precedence.
.then(url => this.setState({ url })) if (typeof this.props.url === 'undefined') {
.catch(err => { Linking.getInitialURL()
console.error('Failed to get initial URL', err); .then(url => {
this.setState({ url });
})
.catch(err => {
console.error('Failed to get initial URL', err);
// XXX Start with an empty URL if getting the initial URL fails; // Start with an empty URL if getting the initial URL fails
// otherwise, nothing will be rendered. // otherwise, nothing will be rendered.
if (this.state.url !== null) {
this.setState({ url: null }); this.setState({ url: null });
} });
}); }
}
/**
* Implements React's {@link Component#componentWillReceiveProps()}.
*
* New props can be set from the native side by setting the appProperties
* property (on iOS) or calling setAppProperties (on Android).
*
* @inheritdoc
*/
componentWillReceiveProps(nextProps) {
this.setState({ url: nextProps.url || null });
} }
/** /**