mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
215 lines
7.6 KiB
JavaScript
215 lines
7.6 KiB
JavaScript
|
|
// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
const Utils = require('./utils.jsx');
|
|
const InviteMemberModal = require('../components/invite_member_modal.jsx');
|
|
const UserProfile = require('../components/user_profile.jsx');
|
|
const ChannelStore = require('../stores/channel_store.jsx');
|
|
const Constants = require('../utils/constants.jsx');
|
|
const TeamStore = require('../stores/team_store.jsx');
|
|
|
|
export function createChannelIntroMessage(channel, showInviteModal) {
|
|
if (channel.type === 'D') {
|
|
return createDMIntroMessage(channel);
|
|
} else if (ChannelStore.isDefault(channel)) {
|
|
return createDefaultIntroMessage(channel);
|
|
} else if (channel.name === Constants.OFFTOPIC_CHANNEL) {
|
|
return createOffTopicIntroMessage(channel, showInviteModal);
|
|
} else if (channel.type === 'O' || channel.type === 'P') {
|
|
return createStandardIntroMessage(channel, showInviteModal);
|
|
}
|
|
}
|
|
|
|
export function createDMIntroMessage(channel) {
|
|
var teammate = Utils.getDirectTeammate(channel.id);
|
|
|
|
if (teammate) {
|
|
var teammateName = teammate.username;
|
|
if (teammate.nickname.length > 0) {
|
|
teammateName = teammate.nickname;
|
|
}
|
|
|
|
return (
|
|
<div className='channel-intro'>
|
|
<div className='post-profile-img__container channel-intro-img'>
|
|
<img
|
|
className='post-profile-img'
|
|
src={'/api/v1/users/' + teammate.id + '/image?time=' + teammate.update_at + '&' + Utils.getSessionIndex()}
|
|
height='50'
|
|
width='50'
|
|
/>
|
|
</div>
|
|
<div className='channel-intro-profile'>
|
|
<strong>
|
|
<UserProfile userId={teammate.id} />
|
|
</strong>
|
|
</div>
|
|
<p className='channel-intro-text'>
|
|
{'This is the start of your direct message history with ' + teammateName + '.'}<br/>
|
|
{'Direct messages and files shared here are not shown to people outside this area.'}
|
|
</p>
|
|
<a
|
|
className='intro-links'
|
|
href='#'
|
|
data-toggle='modal'
|
|
data-target='#edit_channel'
|
|
data-header={channel.header}
|
|
data-title={channel.display_name}
|
|
data-channelid={channel.id}
|
|
>
|
|
<i className='fa fa-pencil'></i>{'Set a header'}
|
|
</a>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div className='channel-intro'>
|
|
<p className='channel-intro-text'>{'This is the start of your direct message history with this teammate. Direct messages and files shared here are not shown to people outside this area.'}</p>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export function createOffTopicIntroMessage(channel, showInviteModal) {
|
|
return (
|
|
<div className='channel-intro'>
|
|
<h4 className='channel-intro__title'>{'Beginning of ' + channel.display_name}</h4>
|
|
<p className='channel-intro__content'>
|
|
{'This is the start of ' + channel.display_name + ', a channel for non-work-related conversations.'}
|
|
<br/>
|
|
</p>
|
|
<a
|
|
className='intro-links'
|
|
href='#'
|
|
data-toggle='modal'
|
|
data-target='#edit_channel'
|
|
data-header={channel.header}
|
|
data-title={channel.display_name}
|
|
data-channelid={channel.id}
|
|
>
|
|
<i className='fa fa-pencil'></i>{'Set a header'}
|
|
</a>
|
|
<a
|
|
href='#'
|
|
onClick={showInviteModal}
|
|
>
|
|
<i className='fa fa-user-plus'></i>{'Invite others to this channel'}
|
|
</a>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export function createDefaultIntroMessage(channel) {
|
|
const team = TeamStore.getCurrent();
|
|
let inviteModalLink;
|
|
if (team.type === Constants.INVITE_TEAM) {
|
|
inviteModalLink = (
|
|
<a
|
|
className='intro-links'
|
|
href='#'
|
|
onClick={InviteMemberModal.show}
|
|
>
|
|
<i className='fa fa-user-plus'></i>{'Invite others to this team'}
|
|
</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}
|
|
>
|
|
<i className='fa fa-user-plus'></i>{'Invite others to this team'}
|
|
</a>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div className='channel-intro'>
|
|
<h4 className='channel-intro__title'>{'Beginning of ' + channel.display_name}</h4>
|
|
<p className='channel-intro__content'>
|
|
<strong>{'Welcome to ' + channel.display_name + '!'}</strong>
|
|
<br/><br/>
|
|
{'This is the first channel teammates see when they sign up - use it for posting updates everyone needs to know.'}
|
|
</p>
|
|
{inviteModalLink}
|
|
<a
|
|
className='intro-links'
|
|
href='#'
|
|
data-toggle='modal'
|
|
data-target='#edit_channel'
|
|
data-header={channel.header}
|
|
data-title={channel.display_name}
|
|
data-channelid={channel.id}
|
|
>
|
|
<i className='fa fa-pencil'></i>{'Set a header'}
|
|
</a>
|
|
<br/>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export function createStandardIntroMessage(channel, showInviteModal) {
|
|
var uiName = channel.display_name;
|
|
var creatorName = '';
|
|
|
|
var uiType;
|
|
var memberMessage;
|
|
if (channel.type === 'P') {
|
|
uiType = 'private group';
|
|
memberMessage = ' Only invited members can see this private group.';
|
|
} else {
|
|
uiType = 'channel';
|
|
memberMessage = ' Any member can join and read this channel.';
|
|
}
|
|
|
|
var createMessage;
|
|
if (creatorName === '') {
|
|
createMessage = 'This is the start of the ' + uiName + ' ' + uiType + ', created on ' + Utils.displayDate(channel.create_at) + '.';
|
|
} else {
|
|
createMessage = (
|
|
<span>
|
|
{'This is the start of the '}
|
|
<strong>{uiName}</strong>
|
|
{' '}
|
|
{uiType}{', created by '}
|
|
<strong>{creatorName}</strong>
|
|
{' on '}
|
|
<strong>{Utils.displayDate(channel.create_at)}</strong>
|
|
</span>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div className='channel-intro'>
|
|
<h4 className='channel-intro__title'>{'Beginning of ' + uiName}</h4>
|
|
<p className='channel-intro__content'>
|
|
{createMessage}
|
|
{memberMessage}
|
|
<br/>
|
|
</p>
|
|
<a
|
|
className='intro-links'
|
|
href='#'
|
|
data-toggle='modal'
|
|
data-target='#edit_channel'
|
|
data-header={channel.header}
|
|
data-title={channel.display_name}
|
|
data-channelid={channel.id}
|
|
>
|
|
<i className='fa fa-pencil'></i>{'Set a header'}
|
|
</a>
|
|
<a
|
|
href='#'
|
|
onClick={showInviteModal}
|
|
>
|
|
<i className='fa fa-user-plus'></i>{'Invite others to this ' + uiType}
|
|
</a>
|
|
</div>
|
|
);
|
|
}
|