You've already forked mattermost-webapp
mirror of
https://github.com/zerotier/mattermost-webapp.git
synced 2026-05-22 16:23:25 -07:00
6c53eb7f5c
* Added additional message for empty BackstageList when filtering * Make search term 'bold' in list filter feedback * replace html with markdown. added testing for bot accounts. * test fix * moved matchesFilter to an exported function refactored render methods to use shallow for testing * reverted bot's accessToken fix corrected e2e spec
185 lines
5.8 KiB
React
185 lines
5.8 KiB
React
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import PropTypes from 'prop-types';
|
|
import React from 'react';
|
|
import {FormattedMessage} from 'react-intl';
|
|
import {Link} from 'react-router-dom';
|
|
|
|
import {t} from 'utils/i18n';
|
|
import CopyText from '../copy_text.jsx';
|
|
|
|
import DeleteIntegration from './delete_integration.jsx';
|
|
|
|
export function matchesFilter(command, filter) {
|
|
if (!filter) {
|
|
return true;
|
|
}
|
|
|
|
return command.display_name.toLowerCase().indexOf(filter) !== -1 ||
|
|
command.description.toLowerCase().indexOf(filter) !== -1 ||
|
|
command.trigger.toLowerCase().indexOf(filter) !== -1;
|
|
}
|
|
|
|
export default class InstalledCommand extends React.PureComponent {
|
|
static propTypes = {
|
|
|
|
/**
|
|
* The team data
|
|
*/
|
|
team: PropTypes.object.isRequired,
|
|
|
|
/**
|
|
* Installed slash command to display
|
|
*/
|
|
command: PropTypes.object.isRequired,
|
|
|
|
/**
|
|
* The function to call when Regenerate Token link is clicked
|
|
*/
|
|
onRegenToken: PropTypes.func.isRequired,
|
|
|
|
/**
|
|
* The function to call when Delete link is clicked
|
|
*/
|
|
onDelete: PropTypes.func.isRequired,
|
|
|
|
/**
|
|
* Set to filter command, comes from BackstageList
|
|
*/
|
|
filter: PropTypes.string,
|
|
|
|
/**
|
|
* The creator user data
|
|
*/
|
|
creator: PropTypes.object.isRequired,
|
|
|
|
/**
|
|
* Set to show edit link
|
|
*/
|
|
canChange: PropTypes.bool.isRequired,
|
|
}
|
|
|
|
handleRegenToken = (e) => {
|
|
e.preventDefault();
|
|
|
|
this.props.onRegenToken(this.props.command);
|
|
}
|
|
|
|
handleDelete = () => {
|
|
this.props.onDelete(this.props.command);
|
|
}
|
|
|
|
render() {
|
|
const command = this.props.command;
|
|
const filter = this.props.filter ? this.props.filter.toLowerCase() : '';
|
|
|
|
if (!matchesFilter(command, filter)) {
|
|
return null;
|
|
}
|
|
|
|
let name;
|
|
|
|
if (command.display_name) {
|
|
name = command.display_name;
|
|
} else {
|
|
name = (
|
|
<FormattedMessage
|
|
id='installed_commands.unnamed_command'
|
|
defaultMessage='Unnamed Slash Command'
|
|
/>
|
|
);
|
|
}
|
|
|
|
let description = null;
|
|
if (command.description) {
|
|
description = (
|
|
<div className='item-details__row'>
|
|
<span className='item-details__description'>
|
|
{command.description}
|
|
</span>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
let trigger = '- /' + command.trigger;
|
|
if (command.auto_complete && command.auto_complete_hint) {
|
|
trigger += ' ' + command.auto_complete_hint;
|
|
}
|
|
|
|
let actions = null;
|
|
if (this.props.canChange) {
|
|
actions = (
|
|
<div className='item-actions'>
|
|
<button
|
|
className='style--none color--link'
|
|
onClick={this.handleRegenToken}
|
|
>
|
|
<FormattedMessage
|
|
id='installed_integrations.regenToken'
|
|
defaultMessage='Regenerate Token'
|
|
/>
|
|
</button>
|
|
{' - '}
|
|
<Link to={`/${this.props.team.name}/integrations/commands/edit?id=${command.id}`}>
|
|
<FormattedMessage
|
|
id='installed_integrations.edit'
|
|
defaultMessage='Edit'
|
|
/>
|
|
</Link>
|
|
{' - '}
|
|
<DeleteIntegration
|
|
messageId={t('installed_commands.delete.confirm')}
|
|
onDelete={this.handleDelete}
|
|
/>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
const commandToken = command.token;
|
|
|
|
return (
|
|
<div className='backstage-list__item'>
|
|
<div className='item-details'>
|
|
<div className='item-details__row'>
|
|
<span className='item-details__name'>
|
|
{name}
|
|
</span>
|
|
<span className='item-details__trigger'>
|
|
{trigger}
|
|
</span>
|
|
</div>
|
|
{description}
|
|
<div className='item-details__row'>
|
|
<span className='item-details__token'>
|
|
<FormattedMessage
|
|
id='installed_integrations.token'
|
|
defaultMessage='Token: {token}'
|
|
values={{
|
|
token: commandToken,
|
|
}}
|
|
/>
|
|
<CopyText
|
|
value={commandToken}
|
|
/>
|
|
</span>
|
|
</div>
|
|
<div className='item-details__row'>
|
|
<span className='item-details__creation'>
|
|
<FormattedMessage
|
|
id='installed_integrations.creation'
|
|
defaultMessage='Created by {creator} on {createAt, date, full}'
|
|
values={{
|
|
creator: this.props.creator.username,
|
|
createAt: command.create_at,
|
|
}}
|
|
/>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
{actions}
|
|
</div>
|
|
);
|
|
}
|
|
}
|