summaryrefslogtreecommitdiffstats
path: root/web/react/components/user_settings/user_settings_general.jsx
diff options
context:
space:
mode:
authorFlorian Orben <florian.orben@gmail.com>2015-10-26 22:05:26 +0100
committerFlorian Orben <florian.orben@gmail.com>2015-10-28 01:26:10 +0100
commit0e5612a7db9f4205485b0c4bfcd8d2ab35727d01 (patch)
tree3133ca6e277170accf23ca6963e861ba91a0a3f8 /web/react/components/user_settings/user_settings_general.jsx
parentede80afe4cce19b4c561f028220ccc21f2581605 (diff)
downloadchat-0e5612a7db9f4205485b0c4bfcd8d2ab35727d01.tar.gz
chat-0e5612a7db9f4205485b0c4bfcd8d2ab35727d01.tar.bz2
chat-0e5612a7db9f4205485b0c4bfcd8d2ab35727d01.zip
allow messages to be send on ctrl+enter
Diffstat (limited to 'web/react/components/user_settings/user_settings_general.jsx')
-rw-r--r--web/react/components/user_settings/user_settings_general.jsx89
1 files changed, 88 insertions, 1 deletions
diff --git a/web/react/components/user_settings/user_settings_general.jsx b/web/react/components/user_settings/user_settings_general.jsx
index 1c8ce3c79..6b7f1ad51 100644
--- a/web/react/components/user_settings/user_settings_general.jsx
+++ b/web/react/components/user_settings/user_settings_general.jsx
@@ -22,6 +22,7 @@ export default class UserSettingsGeneralTab extends React.Component {
this.submitEmail = this.submitEmail.bind(this);
this.submitUser = this.submitUser.bind(this);
this.submitPicture = this.submitPicture.bind(this);
+ this.submitCtrlSend = this.submitCtrlSend.bind(this);
this.updateUsername = this.updateUsername.bind(this);
this.updateFirstName = this.updateFirstName.bind(this);
@@ -30,6 +31,7 @@ export default class UserSettingsGeneralTab extends React.Component {
this.updateEmail = this.updateEmail.bind(this);
this.updateConfirmEmail = this.updateConfirmEmail.bind(this);
this.updatePicture = this.updatePicture.bind(this);
+ this.updateCtrlSend = this.updateCtrlSend.bind(this);
this.updateSection = this.updateSection.bind(this);
this.handleClose = this.handleClose.bind(this);
@@ -176,6 +178,13 @@ export default class UserSettingsGeneralTab extends React.Component {
}.bind(this)
);
}
+ submitCtrlSend(e) {
+ e.preventDefault();
+
+ var user = UserStore.getCurrentUser();
+ user.props = this.state.props;
+ this.submitUser(user, true);
+ }
updateUsername(e) {
this.setState({username: e.target.value});
}
@@ -194,6 +203,11 @@ export default class UserSettingsGeneralTab extends React.Component {
updateConfirmEmail(e) {
this.setState({confirmEmail: e.target.value});
}
+ updateCtrlSend(value) {
+ let props = this.state.props;
+ props.ctrlSend = value;
+ this.setState({props});
+ }
updatePicture(e) {
if (e.target.files && e.target.files[0]) {
this.setState({picture: e.target.files[0]});
@@ -228,7 +242,8 @@ export default class UserSettingsGeneralTab extends React.Component {
var user = props.user;
return {username: user.username, firstName: user.first_name, lastName: user.last_name, nickname: user.nickname,
- email: user.email, confirmEmail: '', picture: null, loadingPicture: false, emailChangeInProgress: false};
+ email: user.email, confirmEmail: '', picture: null, loadingPicture: false, emailChangeInProgress: false,
+ props: user.props};
}
render() {
var user = this.props.user;
@@ -570,6 +585,76 @@ export default class UserSettingsGeneralTab extends React.Component {
/>
);
}
+
+ var miscellaneousSection;
+ var describeCtrlSend = this.state.props.ctrlSend === 'true' ? 'On' : 'Off';
+ if (this.props.activeSection === 'ctrlSend') {
+ var ctrlSendActive = [false, false];
+ if (this.state.props.ctrlSend === 'true') {
+ ctrlSendActive[0] = true;
+ } else {
+ ctrlSendActive[1] = true;
+ }
+
+ let ctrlSendInputs = [];
+ ctrlSendInputs.push(
+ <div
+ key='ctrlSendSetting'
+ className='form-group'
+ >
+ <div className=''>
+ <div className='radio'>
+ <label>
+ <input
+ type='radio'
+ onChange={() => this.updateCtrlSend('true')}
+ checked={ctrlSendActive[0]}
+ />
+ {'On'}
+ </label>
+ <br/>
+ </div>
+ <div className='radio'>
+ <label>
+ <input
+ type='radio'
+ onChange={() => this.updateCtrlSend('false')}
+ checked={ctrlSendActive[1]}
+ />
+ {'Off'}
+ </label>
+ <br/>
+ </div>
+ <div><br/>{'If enabled \'Enter\' inserts a new line and ctrl + enter submits the message.'}</div>
+ </div>
+ </div>
+ );
+
+ miscellaneousSection = (
+ <SettingItemMax
+ title='Send messages on Ctrl + Enter'
+ inputs={ctrlSendInputs}
+ submit={this.submitCtrlSend}
+ server_error={serverError}
+ client_error={emailError}
+ updateSection={function clearCtrlSend(e) {
+ this.updateSection('ctrlSend');
+ e.preventDefault();
+ }.bind(this)}
+ />
+ );
+ } else {
+ miscellaneousSection = (
+ <SettingItemMin
+ title='Send messages on Ctrl + Enter'
+ describe={describeCtrlSend}
+ updateSection={function updateCtrlSend() {
+ this.updateSection('ctrlSend');
+ }.bind(this)}
+ />
+ );
+ }
+
return (
<div>
<div className='modal-header'>
@@ -601,6 +686,8 @@ export default class UserSettingsGeneralTab extends React.Component {
{emailSection}
<div className='divider-light'/>
{pictureSection}
+ <div className='divider-light'/>
+ {miscellaneousSection}
<div className='divider-dark'/>
</div>
</div>