Files
mattermost/web/react/components/tutorial/tutorial_intro_screens.jsx

205 lines
6.7 KiB
React
Raw Normal View History

// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved.
// See License.txt for license information.
import UserStore from '../../stores/user_store.jsx';
import ChannelStore from '../../stores/channel_store.jsx';
import TeamStore from '../../stores/team_store.jsx';
import PreferenceStore from '../../stores/preference_store.jsx';
import * as Utils from '../../utils/utils.jsx';
import * as AsyncClient from '../../utils/async_client.jsx';
import Constants from '../../utils/constants.jsx';
const Preferences = Constants.Preferences;
const NUM_SCREENS = 3;
export default class TutorialIntroScreens extends React.Component {
constructor(props) {
super(props);
this.handleNext = this.handleNext.bind(this);
this.createScreen = this.createScreen.bind(this);
this.createCircles = this.createCircles.bind(this);
2015-10-30 11:35:16 -04:00
this.state = {currentScreen: 0};
}
handleNext() {
2015-10-30 11:35:16 -04:00
if (this.state.currentScreen < 2) {
this.setState({currentScreen: this.state.currentScreen + 1});
return;
}
Utils.switchChannel(ChannelStore.getByName(Constants.DEFAULT_CHANNEL));
2015-10-30 11:35:16 -04:00
let preference = PreferenceStore.getPreference(Preferences.TUTORIAL_STEP, UserStore.getCurrentId(), {value: '0'});
const newValue = (parseInt(preference.value, 10) + 1).toString();
preference = PreferenceStore.setPreference(Preferences.TUTORIAL_STEP, UserStore.getCurrentId(), newValue);
AsyncClient.savePreferences([preference]);
}
2015-11-03 19:56:46 +05:00
componentDidMount() {
$('.tutorials__scroll').perfectScrollbar();
}
skipTutorial(e) {
e.preventDefault();
const preference = PreferenceStore.setPreference(Preferences.TUTORIAL_STEP, UserStore.getCurrentId(), '999');
AsyncClient.savePreferences([preference]);
}
createScreen() {
2015-10-30 11:35:16 -04:00
switch (this.state.currentScreen) {
case 0:
return this.createScreenOne();
case 1:
return this.createScreenTwo();
case 2:
return this.createScreenThree();
}
}
createScreenOne() {
const circles = this.createCircles();
return (
<div>
2015-11-02 11:40:53 +05:00
<h3>{'Welcome to:'}</h3>
<h1>{'Mattermost'}</h1>
2015-11-03 18:03:11 -08:00
<p>{'Your team communication all in one place, instantly searchable and available anywhere.'}</p>
2015-11-02 11:40:53 +05:00
<p>{'Keep your team connected to help them achieve what matters most.'}</p>
{circles}
</div>
);
}
createScreenTwo() {
const circles = this.createCircles();
return (
<div>
2015-11-02 11:40:53 +05:00
<h3>{'How Mattermost works:'}</h3>
<p>{'Communication happens in public discussion channels, private groups and direct messages.'}</p>
2015-11-03 08:42:04 -08:00
<p>{'Everything is archived and searchable from any web-enabled desktop, laptop or phone.'}</p>
{circles}
</div>
);
}
createScreenThree() {
const team = TeamStore.getCurrent();
let inviteModalLink;
if (team.type === Constants.INVITE_TEAM) {
inviteModalLink = (
<a
className='intro-links'
href='#'
data-toggle='modal'
data-target='#invite_member'
>
{'Invite teammates'}
</a>
);
} else {
inviteModalLink = (
<a
className='intro-links'
href='#'
data-toggle='modal'
data-target='#get_link'
data-title='Team Invite'
data-value={Utils.getWindowLocationOrigin() + '/signup_user_complete/?id=' + team.id}
>
{'Invite teammates'}
</a>
);
}
const circles = this.createCircles();
let supportInfo = null;
if (global.window.mm_config.SupportEmail) {
supportInfo = (
2015-11-02 11:40:53 +05:00
<p>
{'Need anything, just email us at '}
<a
href={'mailto:' + global.window.mm_config.SupportEmail}
2015-11-02 11:40:53 +05:00
target='_blank'
>
{global.window.mm_config.SupportEmail}
2015-11-02 11:40:53 +05:00
</a>
2015-11-02 11:13:21 -05:00
{'.'}
2015-11-02 11:40:53 +05:00
</p>
);
}
return (
<div>
<h3>{'Youre all set'}</h3>
<p>
{inviteModalLink}
{' when youre ready.'}
</p>
{supportInfo}
2015-11-03 08:42:04 -08:00
{'Click “Next” to enter Town Square. This is the first channel teammates see when they sign up. Use it for posting updates everyone needs to know.'}
{circles}
</div>
);
}
createCircles() {
const circles = [];
for (let i = 0; i < NUM_SCREENS; i++) {
let className = 'circle';
if (i === this.state.currentScreen) {
className += ' active';
}
circles.push(
<a
href='#'
key={'circle' + i}
className={className}
onClick={(e) => { //eslint-disable-line no-loop-func
e.preventDefault();
this.setState({currentScreen: i});
}}
/>
);
}
return (
<div className='tutorial__circles'>
{circles}
</div>
);
}
render() {
const height = Utils.windowHeight() - 100;
const screen = this.createScreen();
return (
<div
className='tutorials__scroll'
style={{height}}
>
2015-11-03 19:56:46 +05:00
<div className='tutorial-steps__container'>
<div className='tutorial__content'>
<div className='tutorial__steps'>
{screen}
<button
className='btn btn-primary'
tabIndex='1'
onClick={this.handleNext}
>
{'Next'}
</button>
<a
className='tutorial-skip'
href='#'
onClick={this.skipTutorial}
>
{'Skip tutorial'}
</a>
2015-11-03 19:56:46 +05:00
</div>
2015-11-02 11:40:53 +05:00
</div>
</div>
</div>
);
}
}