diff options
author | Harrison Healey <harrisonmhealey@gmail.com> | 2016-08-03 00:01:33 -0400 |
---|---|---|
committer | Corey Hulen <corey@hulen.com> | 2016-08-02 20:01:33 -0800 |
commit | 1de3bd3b4340cb51b2699a14a92d653db988a988 (patch) | |
tree | 604703f9acf4ea3b71f30bdfa532020e9fb233be /webapp/routes | |
parent | 790dd91e7d93b5debaf86915c34f8a73a3ff95bd (diff) | |
download | chat-1de3bd3b4340cb51b2699a14a92d653db988a988.tar.gz chat-1de3bd3b4340cb51b2699a14a92d653db988a988.tar.bz2 chat-1de3bd3b4340cb51b2699a14a92d653db988a988.zip |
PLT-3640 Add mobile landing pages (#3674)
* PLT-3640 Moved all clientside user agent snooping into a single file
* PLT-3640 Added mobile landing pages on login to iOS and Android web apps
* PLT-3640 Moved landing page to appear before first login
* PLT-3640 Fixed detection of Chrome on Android
* PLT-3640 Disabled mobile landing pages when their respective URLs are set to blank
Diffstat (limited to 'webapp/routes')
-rw-r--r-- | webapp/routes/route_root.jsx | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/webapp/routes/route_root.jsx b/webapp/routes/route_root.jsx index 6593e2bd8..88c94b54b 100644 --- a/webapp/routes/route_root.jsx +++ b/webapp/routes/route_root.jsx @@ -9,7 +9,23 @@ import claimAccountRoute from 'routes/route_claim.jsx'; import createTeamRoute from 'routes/route_create_team.jsx'; import teamRoute from 'routes/route_team.jsx'; +import BrowserStore from 'stores/browser_store.jsx'; import ErrorStore from 'stores/error_store.jsx'; +import * as UserAgent from 'utils/user_agent.jsx'; + +function preLogin(nextState, replace, callback) { + // redirect to the mobile landing page if the user hasn't seen it before + if (window.mm_config.IosAppDownloadLink && UserAgent.isIosWeb() && !BrowserStore.hasSeenLandingPage()) { + replace('/get_ios_app'); + BrowserStore.setLandingPageSeen(true); + } else if (window.mm_config.AndroidAppDownloadLink && UserAgent.isAndroidWeb() && !BrowserStore.hasSeenLandingPage()) { + replace('/get_android_app'); + BrowserStore.setLandingPageSeen(true); + } + + callback(); +} + function preLoggedIn(nextState, replace, callback) { ErrorStore.clearLastError(); callback(); @@ -28,6 +44,7 @@ export default { [ { path: 'login', + onEnter: preLogin, getComponents: (location, callback) => { System.import('components/login/login_controller.jsx').then(RouteUtils.importComponentSuccess(callback)); } @@ -67,6 +84,18 @@ export default { ) }, { + path: 'get_ios_app', + getComponents: (location, callback) => { + System.import('components/get_ios_app/get_ios_app.jsx').then(RouteUtils.importComponentSuccess(callback)); + } + }, + { + path: 'get_android_app', + getComponents: (location, callback) => { + System.import('components/get_android_app/get_android_app.jsx').then(RouteUtils.importComponentSuccess(callback)); + } + }, + { path: 'error', getComponents: (location, callback) => { System.import('components/error_page.jsx').then(RouteUtils.importComponentSuccess(callback)); |