// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved. // See License.txt for license information. import $ from 'jquery'; require('perfect-scrollbar/jquery')($); import 'bootstrap-colorpicker/dist/css/bootstrap-colorpicker.css'; import 'google-fonts/google-fonts.css'; import 'sass/styles.scss'; import React from 'react'; import ReactDOM from 'react-dom'; import {Router, Route, IndexRoute, IndexRedirect, Redirect, browserHistory} from 'react-router'; import Root from 'components/root.jsx'; import LoggedIn from 'components/logged_in.jsx'; import NotLoggedIn from 'components/not_logged_in.jsx'; import NeedsTeam from 'components/needs_team.jsx'; import PasswordResetSendLink from 'components/password_reset_send_link.jsx'; import PasswordResetForm from 'components/password_reset_form.jsx'; import ChannelView from 'components/channel_view.jsx'; import PermalinkView from 'components/permalink_view.jsx'; import Sidebar from 'components/sidebar.jsx'; import * as AsyncClient from 'utils/async_client.jsx'; import PreferenceStore from 'stores/preference_store.jsx'; import ChannelStore from 'stores/channel_store.jsx'; import ErrorStore from 'stores/error_store.jsx'; import BrowserStore from 'stores/browser_store.jsx'; import SignupTeam from 'components/signup_team.jsx'; import * as Client from 'utils/client.jsx'; import * as Websockets from 'action_creators/websocket_actions.jsx'; import * as Utils from 'utils/utils.jsx'; import * as GlobalActions from 'action_creators/global_actions.jsx'; import SignupTeamConfirm from 'components/signup_team_confirm.jsx'; import SignupUserComplete from 'components/signup_user_complete.jsx'; import ShouldVerifyEmail from 'components/should_verify_email.jsx'; import DoVerifyEmail from 'components/do_verify_email.jsx'; import AdminConsole from 'components/admin_console/admin_controller.jsx'; import TutorialView from 'components/tutorial/tutorial_view.jsx'; import BackstageNavbar from 'components/backstage/backstage_navbar.jsx'; import BackstageSidebar from 'components/backstage/backstage_sidebar.jsx'; import InstalledIntegrations from 'components/backstage/installed_integrations.jsx'; import AddIntegration from 'components/backstage/add_integration.jsx'; import AddIncomingWebhook from 'components/backstage/add_incoming_webhook.jsx'; import AddOutgoingWebhook from 'components/backstage/add_outgoing_webhook.jsx'; import ErrorPage from 'components/error_page.jsx'; import SignupTeamComplete from 'components/signup_team_complete/components/signup_team_complete.jsx'; import WelcomePage from 'components/signup_team_complete/components/team_signup_welcome_page.jsx'; import TeamDisplayNamePage from 'components/signup_team_complete/components/team_signup_display_name_page.jsx'; import TeamURLPage from 'components/signup_team_complete/components/team_signup_url_page.jsx'; import SendInivtesPage from 'components/signup_team_complete/components/team_signup_send_invites_page.jsx'; import UsernamePage from 'components/signup_team_complete/components/team_signup_username_page.jsx'; import PasswordPage from 'components/signup_team_complete/components/team_signup_password_page.jsx'; import FinishedPage from 'components/signup_team_complete/components/team_signup_finished.jsx'; import Claim from 'components/claim/claim.jsx'; import EmailToOAuth from 'components/claim/components/email_to_oauth.jsx'; import OAuthToEmail from 'components/claim/components/oauth_to_email.jsx'; import LDAPToEmail from 'components/claim/components/ldap_to_email.jsx'; import EmailToLDAP from 'components/claim/components/email_to_ldap.jsx'; import Login from 'components/login/login.jsx'; import * as I18n from 'i18n/i18n.jsx'; const notFoundParams = { title: Utils.localizeMessage('error.not_found.title', 'Page not found'), message: Utils.localizeMessage('error.not_found.message', 'The page you where trying to reach does not exist'), link: '/', linkmessage: Utils.localizeMessage('error.not_found.link_message', 'Back to Mattermost') }; // This is for anything that needs to be done for ALL react components. // This runs before we start to render anything. function preRenderSetup(callwhendone) { const d1 = Client.getClientConfig( (data, textStatus, xhr) => { if (!data) { return; } global.window.mm_config = data; var serverVersion = xhr.getResponseHeader('X-Version-ID'); if (serverVersion !== BrowserStore.getLastServerVersion()) { if (!BrowserStore.getLastServerVersion() || BrowserStore.getLastServerVersion() === '') { BrowserStore.setLastServerVersion(serverVersion); } else { BrowserStore.setLastServerVersion(serverVersion); window.location.reload(true); console.log('Detected version update refreshing the page'); //eslint-disable-line no-console } } }, (err) => { AsyncClient.dispatchError(err, 'getClientConfig'); } ); const d2 = Client.getClientLicenceConfig( (data) => { if (!data) { return; } global.window.mm_license = data; }, (err) => { AsyncClient.dispatchError(err, 'getClientLicenceConfig'); } ); // Set these here so they don't fail in client.jsx track global.window.analytics = []; global.window.analytics.page = () => { // Do Nothing }; global.window.analytics.track = () => { // Do Nothing }; // Make sure the websockets close $(window).on('beforeunload', () => { Websockets.close(); } ); function afterIntl() { I18n.doAddLocaleData(); $.when(d1, d2).done(callwhendone); } if (global.Intl) { afterIntl(); } else { I18n.safariFix(afterIntl); } } function preLoggedIn(nextState, replace, callback) { const d1 = Client.getAllPreferences( (data) => { PreferenceStore.setPreferencesFromServer(data); }, (err) => { AsyncClient.dispatchError(err, 'getAllPreferences'); } ); const d2 = AsyncClient.getChannels(); ErrorStore.clearLastError(); $.when(d1, d2).done(() => { callback(); }); } function onRootEnter(nextState, replace, callback) { if (nextState.location.pathname === '/') { Client.getMeLoggedIn((data) => { if (!data || data.logged_in === 'false') { replace({pathname: '/signup_team'}); callback(); } else { replace({pathname: '/' + data.team_name + '/channels/town-square'}); callback(); } }); return; } callback(); } function onPermalinkEnter(nextState) { const postId = nextState.params.postid; GlobalActions.emitPostFocusEvent(postId); } function onChannelEnter(nextState) { doChannelChange(nextState); } function onChannelChange(prevState, nextState) { if (prevState.params.channel !== nextState.params.channel) { doChannelChange(nextState); } } function doChannelChange(state) { let channel; if (state.location.query.fakechannel) { channel = JSON.parse(state.location.query.fakechannel); } else { channel = ChannelStore.getByName(state.params.channel); } GlobalActions.emitChannelClickEvent(channel); } function onLoggedOut(nextState) { const teamName = nextState.params.team; Client.logout( () => { browserHistory.push('/' + teamName + '/login'); BrowserStore.signalLogout(); BrowserStore.clear(); ErrorStore.clearLastError(); PreferenceStore.clear(); }, () => { browserHistory.push('/' + teamName + '/login'); } ); } function renderRootComponent() { ReactDOM.render(( ), document.getElementById('root')); } global.window.setup_root = () => { // Do the pre-render setup and call renderRootComponent when done preRenderSetup(renderRootComponent); };