From ec553b0c3d36d23c08085b4a3f47c70013d0a8e2 Mon Sep 17 00:00:00 2001 From: Evan Morikawa Date: Fri, 29 Jan 2016 17:11:54 -0800 Subject: [PATCH] fix(pref): check for mounting on async launch service --- .../lib/tabs/workspace-section.cjsx | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/internal_packages/preferences/lib/tabs/workspace-section.cjsx b/internal_packages/preferences/lib/tabs/workspace-section.cjsx index 9504cb8bc..76d512df7 100644 --- a/internal_packages/preferences/lib/tabs/workspace-section.cjsx +++ b/internal_packages/preferences/lib/tabs/workspace-section.cjsx @@ -9,7 +9,13 @@ class DefaultMailClientItem extends React.Component @_services = new LaunchServices() if @_services.available() @_services.isRegisteredForURLScheme 'mailto', (registered) => - @setState(defaultClient: registered) + @setState(defaultClient: registered) if @_mounted + + componentDidMount: -> + @_mounted = true + + componentWillUnmount: -> + @_mounted = false render: => return false unless process.platform is 'darwin' @@ -36,11 +42,15 @@ class LaunchSystemStartItem extends React.Component @_service = new SystemStartService() componentDidMount: -> + @_mounted = true @_service.checkAvailability().then (available) => - @setState {available} - return if not available + @setState {available} if @_mounted + return if not available or not @_mounted @_service.doesLaunchOnSystemStart().then (launchOnStart) => - @setState({launchOnStart}) + @setState({launchOnStart}) if @_mounted + + componentWillUnmount: -> + @_mounted = false render: => return false if not @state.available