mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
94 lines
2.8 KiB
JavaScript
94 lines
2.8 KiB
JavaScript
// Copyright (c) 2016 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: React.PropTypes.string.isRequired,
|
|
label: React.PropTypes.node.isRequired,
|
|
placeholder: React.PropTypes.string,
|
|
value: React.PropTypes.string.isRequired,
|
|
onChange: React.PropTypes.func.isRequired,
|
|
disabled: React.PropTypes.bool.isRequired,
|
|
disabledText: React.PropTypes.node,
|
|
helpText: React.PropTypes.node.isRequired,
|
|
regenerateText: React.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>
|
|
);
|
|
}
|
|
}
|