From 2d311ff1866977d77d6b0018dbc2a7a2ee511040 Mon Sep 17 00:00:00 2001 From: Laurin Quast Date: Mon, 24 Sep 2018 15:48:16 +0200 Subject: [PATCH] fix(rn-camera): use `componentDidMount` instead of `componentWillMount`. closes #1809 closes #1760 --- src/RNCamera.js | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/RNCamera.js b/src/RNCamera.js index 9d6bc4b0e..c3fba0f22 100644 --- a/src/RNCamera.js +++ b/src/RNCamera.js @@ -251,6 +251,7 @@ export default class Camera extends React.Component { super(props); this._lastEvents = {}; this._lastEventsTimes = {}; + this._isMounted = true; this.state = { isAuthorized: false, isAuthorizationChecked: false, @@ -288,7 +289,7 @@ export default class Camera extends React.Component { } else if (typeof options.quality === 'string') { options.quality = Camera.Constants.VideoQuality[options.quality]; } - if (typeof options.orientation=== 'string') { + if (typeof options.orientation === 'string') { options.orientation = CameraManager.Orientation[options.orientation]; } return await CameraManager.record(options, this._cameraHandle); @@ -353,8 +354,11 @@ export default class Camera extends React.Component { } }; - // eslint-disable-next-line - async componentWillMount() { + componentWillUnmount() { + this._isMounted = false; + } + + async componentDidMount() { const hasVideoAndAudio = this.props.captureAudio; const isAuthorized = await requestPermissions( hasVideoAndAudio, @@ -362,6 +366,9 @@ export default class Camera extends React.Component { this.props.permissionDialogTitle, this.props.permissionDialogMessage, ); + if (this._isMounted === false) { + return; + } this.setState({ isAuthorized, isAuthorizationChecked: true }); }