mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
* Updating client dependancies. Switching to using yarn. * Updating React * Moving pure components to using function syntax (performance gains with newer react version) * Updating client dependancies. * Ignore .yarninstall * Enabling pre-lockfile because it's the entire point of using yarn. * Removing old webpack config * Moving to new prop-types * Fixing ESLint Errors * Updating jest snapshots. * Cleaning up package.json
96 lines
2.8 KiB
JavaScript
96 lines
2.8 KiB
JavaScript
import PropTypes from 'prop-types';
|
|
|
|
// Copyright (c) 2016-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
import React from 'react';
|
|
|
|
import crypto from 'crypto';
|
|
|
|
import {FormattedMessage} from 'react-intl';
|
|
|
|
export default class GeneratedSetting extends React.Component {
|
|
static get propTypes() {
|
|
return {
|
|
id: PropTypes.string.isRequired,
|
|
label: PropTypes.node.isRequired,
|
|
placeholder: PropTypes.string,
|
|
value: PropTypes.string.isRequired,
|
|
onChange: PropTypes.func.isRequired,
|
|
disabled: PropTypes.bool.isRequired,
|
|
disabledText: PropTypes.node,
|
|
helpText: PropTypes.node.isRequired,
|
|
regenerateText: PropTypes.node
|
|
};
|
|
}
|
|
|
|
static get defaultProps() {
|
|
return {
|
|
disabled: false,
|
|
regenerateText: (
|
|
<FormattedMessage
|
|
id='admin.regenerate'
|
|
defaultMessage='Regenerate'
|
|
/>
|
|
)
|
|
};
|
|
}
|
|
|
|
constructor(props) {
|
|
super(props);
|
|
|
|
this.regenerate = this.regenerate.bind(this);
|
|
}
|
|
|
|
regenerate(e) {
|
|
e.preventDefault();
|
|
|
|
this.props.onChange(this.props.id, crypto.randomBytes(256).toString('base64').substring(0, 32));
|
|
}
|
|
|
|
render() {
|
|
let disabledText = null;
|
|
if (this.props.disabled && this.props.disabledText) {
|
|
disabledText = (
|
|
<div className='admin-console__disabled-text'>
|
|
{this.props.disabledText}
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div className='form-group'>
|
|
<label
|
|
className='control-label col-sm-4'
|
|
htmlFor={this.props.id}
|
|
>
|
|
{this.props.label}
|
|
</label>
|
|
<div className='col-sm-8'>
|
|
<input
|
|
type='text'
|
|
className='form-control'
|
|
id={this.props.id}
|
|
placeholder={this.props.placeholder}
|
|
value={this.props.value}
|
|
disabled={true}
|
|
/>
|
|
{disabledText}
|
|
<div className='help-text'>
|
|
{this.props.helpText}
|
|
</div>
|
|
<div className='help-text'>
|
|
<button
|
|
className='btn btn-default'
|
|
onClick={this.regenerate}
|
|
disabled={this.props.disabled}
|
|
>
|
|
{this.props.regenerateText}
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
}
|