Files
mattermost/web/react/components/user_settings.jsx

1172 lines
44 KiB
JavaScript

// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved.
// See License.txt for license information.
var UserStore = require('../stores/user_store.jsx');
var SettingItemMin = require('./setting_item_min.jsx');
var SettingItemMax = require('./setting_item_max.jsx');
var SettingPicture = require('./setting_picture.jsx');
var AccessHistoryModal = require('./access_history_modal.jsx');
var ActivityLogModal = require('./activity_log_modal.jsx');
var client = require('../utils/client.jsx');
var AsyncClient = require('../utils/async_client.jsx');
var utils = require('../utils/utils.jsx');
var Constants = require('../utils/constants.jsx');
var assign = require('object-assign');
function getNotificationsStateFromStores() {
var user = UserStore.getCurrentUser();
var sound = (!user.notify_props || user.notify_props.desktop_sound == undefined) ? "true" : user.notify_props.desktop_sound;
var desktop = (!user.notify_props || user.notify_props.desktop == undefined) ? "all" : user.notify_props.desktop;
var email = (!user.notify_props || user.notify_props.email == undefined) ? "true" : user.notify_props.email;
var username_key = false;
var mention_key = false;
var custom_keys = "";
var first_name_key = false;
var all_key = false;
var channel_key = false;
if (user.notify_props) {
if (user.notify_props.mention_keys !== undefined) {
var keys = user.notify_props.mention_keys.split(',');
if (keys.indexOf(user.username) !== -1) {
username_key = true;
keys.splice(keys.indexOf(user.username), 1);
} else {
username_key = false;
}
if (keys.indexOf('@'+user.username) !== -1) {
mention_key = true;
keys.splice(keys.indexOf('@'+user.username), 1);
} else {
mention_key = false;
}
custom_keys = keys.join(',');
}
if (user.notify_props.first_name !== undefined) {
first_name_key = user.notify_props.first_name === "true";
}
if (user.notify_props.all !== undefined) {
all_key = user.notify_props.all === "true";
}
if (user.notify_props.channel !== undefined) {
channel_key = user.notify_props.channel === "true";
}
}
return { notify_level: desktop, enable_email: email, enable_sound: sound, username_key: username_key, mention_key: mention_key, custom_keys: custom_keys, custom_keys_checked: custom_keys.length > 0, first_name_key: first_name_key, all_key: all_key, channel_key: channel_key };
}
var NotificationsTab = React.createClass({
handleSubmit: function() {
data = {}
data["user_id"] = this.props.user.id;
data["email"] = this.state.enable_email;
data["desktop_sound"] = this.state.enable_sound;
data["desktop"] = this.state.notify_level;
var mention_keys = [];
if (this.state.username_key) mention_keys.push(this.props.user.username);
if (this.state.mention_key) mention_keys.push('@'+this.props.user.username);
var string_keys = mention_keys.join(',');
if (this.state.custom_keys.length > 0 && this.state.custom_keys_checked) {
string_keys += ',' + this.state.custom_keys;
}
data["mention_keys"] = string_keys;
data["first_name"] = this.state.first_name_key ? "true" : "false";
data["all"] = this.state.all_key ? "true" : "false";
data["channel"] = this.state.channel_key ? "true" : "false";
client.updateUserNotifyProps(data,
function(data) {
this.props.updateSection("");
AsyncClient.getMe();
}.bind(this),
function(err) {
this.setState({ server_error: err.message });
}.bind(this)
);
},
handleClose: function() {
$(this.getDOMNode()).find(".form-control").each(function() {
this.value = "";
});
this.setState(assign({},getNotificationsStateFromStores(),{server_error: null}));
},
componentDidMount: function() {
UserStore.addChangeListener(this._onChange);
$('#user_settings1').on('hidden.bs.modal', this.handleClose);
},
componentWillUnmount: function() {
UserStore.removeChangeListener(this._onChange);
$('#user_settings1').off('hidden.bs.modal', this.handleClose);
},
_onChange: function() {
var newState = getNotificationsStateFromStores();
if (!utils.areStatesEqual(newState, this.state)) {
this.setState(newState);
}
},
getInitialState: function() {
return getNotificationsStateFromStores();
},
handleNotifyRadio: function(notifyLevel) {
this.setState({ notify_level: notifyLevel });
this.refs.wrapper.getDOMNode().focus();
},
handleEmailRadio: function(enableEmail) {
this.setState({ enable_email: enableEmail });
this.refs.wrapper.getDOMNode().focus();
},
handleSoundRadio: function(enableSound) {
this.setState({ enable_sound: enableSound });
this.refs.wrapper.getDOMNode().focus();
},
updateUsernameKey: function(val) {
this.setState({ username_key: val });
},
updateMentionKey: function(val) {
this.setState({ mention_key: val });
},
updateFirstNameKey: function(val) {
this.setState({ first_name_key: val });
},
updateAllKey: function(val) {
this.setState({ all_key: val });
},
updateChannelKey: function(val) {
this.setState({ channel_key: val });
},
updateCustomMentionKeys: function() {
var checked = this.refs.customcheck.getDOMNode().checked;
if (checked) {
var text = this.refs.custommentions.getDOMNode().value;
// remove all spaces and split string into individual keys
this.setState({ custom_keys: text.replace(/ /g, ''), custom_keys_checked: true });
} else {
this.setState({ custom_keys: "", custom_keys_checked: false });
}
},
onCustomChange: function() {
this.refs.customcheck.getDOMNode().checked = true;
this.updateCustomMentionKeys();
},
render: function() {
var server_error = this.state.server_error ? this.state.server_error : null;
var self = this;
var user = this.props.user;
var desktopSection;
if (this.props.activeSection === 'desktop') {
var notifyActive = [false, false, false];
if (this.state.notify_level === "mention") {
notifyActive[1] = true;
} else if (this.state.notify_level === "none") {
notifyActive[2] = true;
} else {
notifyActive[0] = true;
}
var inputs = [];
inputs.push(
<div>
<div className="radio">
<label>
<input type="radio" checked={notifyActive[0]} onClick={function(){self.handleNotifyRadio("all")}}>For all activity</input>
</label>
<br/>
</div>
<div className="radio">
<label>
<input type="radio" checked={notifyActive[1]} onClick={function(){self.handleNotifyRadio("mention")}}>Only for mentions and private messages</input>
</label>
<br/>
</div>
<div className="radio">
<label>
<input type="radio" checked={notifyActive[2]} onClick={function(){self.handleNotifyRadio("none")}}>Never</input>
</label>
</div>
</div>
);
desktopSection = (
<SettingItemMax
title="Send desktop notifications"
inputs={inputs}
submit={this.handleSubmit}
server_error={server_error}
updateSection={function(e){self.props.updateSection("");e.preventDefault();}}
/>
);
} else {
var describe = "";
if (this.state.notify_level === "mention") {
describe = "Only for mentions and private messages";
} else if (this.state.notify_level === "none") {
describe = "Never";
} else {
describe = "For all activity";
}
desktopSection = (
<SettingItemMin
title="Send desktop notifications"
describe={describe}
updateSection={function(){self.props.updateSection("desktop");}}
/>
);
}
var soundSection;
if (this.props.activeSection === 'sound') {
var soundActive = ["",""];
if (this.state.enable_sound === "false") {
soundActive[1] = "active";
} else {
soundActive[0] = "active";
}
var inputs = [];
inputs.push(
<div>
<div className="btn-group" data-toggle="buttons-radio">
<button className={"btn btn-default "+soundActive[0]} onClick={function(){self.handleSoundRadio("true")}}>On</button>
<button className={"btn btn-default "+soundActive[1]} onClick={function(){self.handleSoundRadio("false")}}>Off</button>
</div>
</div>
);
soundSection = (
<SettingItemMax
title="Desktop notification sounds"
inputs={inputs}
submit={this.handleSubmit}
server_error={server_error}
updateSection={function(e){self.props.updateSection("");e.preventDefault();}}
/>
);
} else {
var describe = "";
if (this.state.enable_sound === "false") {
describe = "Off";
} else {
describe = "On";
}
soundSection = (
<SettingItemMin
title="Desktop notification sounds"
describe={describe}
updateSection={function(){self.props.updateSection("sound");}}
/>
);
}
var emailSection;
if (this.props.activeSection === 'email') {
var emailActive = ["",""];
if (this.state.enable_email === "false") {
emailActive[1] = "active";
} else {
emailActive[0] = "active";
}
var inputs = [];
inputs.push(
<div>
<div className="btn-group" data-toggle="buttons-radio">
<button className={"btn btn-default "+emailActive[0]} onClick={function(){self.handleEmailRadio("true")}}>On</button>
<button className={"btn btn-default "+emailActive[1]} onClick={function(){self.handleEmailRadio("false")}}>Off</button>
</div>
<div><br/>{"Email notifications are sent for mentions and private messages after you have been away from " + config.SiteName + " for 5 minutes."}</div>
</div>
);
emailSection = (
<SettingItemMax
title="Email notifications"
inputs={inputs}
submit={this.handleSubmit}
server_error={server_error}
updateSection={function(e){self.props.updateSection("");e.preventDefault();}}
/>
);
} else {
var describe = "";
if (this.state.enable_email === "false") {
describe = "Off";
} else {
describe = "On";
}
emailSection = (
<SettingItemMin
title="Email notifications"
describe={describe}
updateSection={function(){self.props.updateSection("email");}}
/>
);
}
var keysSection;
if (this.props.activeSection === 'keys') {
var inputs = [];
if (user.first_name) {
inputs.push(
<div>
<div className="checkbox">
<label>
<input type="checkbox" checked={this.state.first_name_key} onChange={function(e){self.updateFirstNameKey(e.target.checked);}}>{'Your case sensitive first name "' + user.first_name + '"'}</input>
</label>
</div>
</div>
);
}
inputs.push(
<div>
<div className="checkbox">
<label>
<input type="checkbox" checked={this.state.username_key} onChange={function(e){self.updateUsernameKey(e.target.checked);}}>{'Your non-case sensitive username "' + user.username + '"'}</input>
</label>
</div>
</div>
);
inputs.push(
<div>
<div className="checkbox">
<label>
<input type="checkbox" checked={this.state.mention_key} onChange={function(e){self.updateMentionKey(e.target.checked);}}>{'Your username mentioned "@' + user.username + '"'}</input>
</label>
</div>
</div>
);
inputs.push(
<div>
<div className="checkbox">
<label>
<input type="checkbox" checked={this.state.all_key} onChange={function(e){self.updateAllKey(e.target.checked);}}>{'Team-wide mentions "@all"'}</input>
</label>
</div>
</div>
);
inputs.push(
<div>
<div className="checkbox">
<label>
<input type="checkbox" checked={this.state.channel_key} onChange={function(e){self.updateChannelKey(e.target.checked);}}>{'Channel-wide mentions "@channel"'}</input>
</label>
</div>
</div>
);
inputs.push(
<div>
<div className="checkbox">
<label>
<input ref="customcheck" type="checkbox" checked={this.state.custom_keys_checked} onChange={this.updateCustomMentionKeys}>{'Other non-case sensitive words, separated by commas:'}</input>
</label>
</div>
<input ref="custommentions" className="form-control mentions-input" type="text" defaultValue={this.state.custom_keys} onChange={this.onCustomChange} />
</div>
);
keysSection = (
<SettingItemMax
title="Words that trigger mentions"
inputs={inputs}
submit={this.handleSubmit}
server_error={server_error}
updateSection={function(e){self.props.updateSection("");e.preventDefault();}}
/>
);
} else {
var keys = [];
if (this.state.first_name_key) keys.push(user.first_name);
if (this.state.username_key) keys.push(user.username);
if (this.state.mention_key) keys.push('@'+user.username);
if (this.state.all_key) keys.push('@all');
if (this.state.channel_key) keys.push('@channel');
if (this.state.custom_keys.length > 0) keys = keys.concat(this.state.custom_keys.split(','));
var describe = "";
for (var i = 0; i < keys.length; i++) {
describe += '"' + keys[i] + '", ';
}
if (describe.length > 0) {
describe = describe.substring(0, describe.length - 2);
} else {
describe = "No words configured";
}
keysSection = (
<SettingItemMin
title="Words that trigger mentions"
describe={describe}
updateSection={function(){self.props.updateSection("keys");}}
/>
);
}
return (
<div>
<div className="modal-header">
<button type="button" className="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 className="modal-title" ref="title"><i className="modal-back"></i>Notifications</h4>
</div>
<div ref="wrapper" className="user-settings">
<h3 className="tab-header">Notifications</h3>
<div className="divider-dark first"/>
{desktopSection}
<div className="divider-light"/>
{soundSection}
<div className="divider-light"/>
{emailSection}
<div className="divider-light"/>
{keysSection}
<div className="divider-dark"/>
</div>
</div>
);
}
});
var SecurityTab = React.createClass({
submitPassword: function(e) {
e.preventDefault();
var user = this.props.user;
var currentPassword = this.state.current_password;
var newPassword = this.state.new_password;
var confirmPassword = this.state.confirm_password;
if (currentPassword === '') {
this.setState({ password_error: "Please enter your current password" });
return;
}
if (newPassword.length < 5) {
this.setState({ password_error: "New passwords must be at least 5 characters" });
return;
}
if (newPassword != confirmPassword) {
this.setState({ password_error: "The new passwords you entered do not match" });
return;
}
var data = {};
data.user_id = user.id;
data.current_password = currentPassword;
data.new_password = newPassword;
client.updatePassword(data,
function(data) {
this.props.updateSection("");
AsyncClient.getMe();
this.setState({ current_password: '', new_password: '', confirm_password: '' });
}.bind(this),
function(err) {
state = this.getInitialState();
state.server_error = err;
this.setState(state);
}.bind(this)
);
},
updateCurrentPassword: function(e) {
this.setState({ current_password: e.target.value });
},
updateNewPassword: function(e) {
this.setState({ new_password: e.target.value });
},
updateConfirmPassword: function(e) {
this.setState({ confirm_password: e.target.value });
},
handleHistoryOpen: function() {
$("#user_settings1").modal('hide');
},
handleDevicesOpen: function() {
$("#user_settings1").modal('hide');
},
handleClose: function() {
$(this.getDOMNode()).find(".form-control").each(function() {
this.value = "";
});
this.setState({current_password: '', new_password: '', confirm_password: '', server_error: null, password_error: null});
},
componentDidMount: function() {
$('#user_settings1').on('hidden.bs.modal', this.handleClose);
},
componentWillUnmount: function() {
$('#user_settings1').off('hidden.bs.modal', this.handleClose);
},
getInitialState: function() {
return { current_password: '', new_password: '', confirm_password: '' };
},
render: function() {
var server_error = this.state.server_error ? this.state.server_error : null;
var password_error = this.state.password_error ? this.state.password_error : null;
var passwordSection;
var self = this;
if (this.props.activeSection === 'password') {
var inputs = [];
var submit = null;
if (this.props.user.auth_service === "") {
inputs.push(
<div className="form-group">
<label className="col-sm-5 control-label">Current Password</label>
<div className="col-sm-7">
<input className="form-control" type="password" onChange={this.updateCurrentPassword} value={this.state.current_password}/>
</div>
</div>
);
inputs.push(
<div className="form-group">
<label className="col-sm-5 control-label">New Password</label>
<div className="col-sm-7">
<input className="form-control" type="password" onChange={this.updateNewPassword} value={this.state.new_password}/>
</div>
</div>
);
inputs.push(
<div className="form-group">
<label className="col-sm-5 control-label">Retype New Password</label>
<div className="col-sm-7">
<input className="form-control" type="password" onChange={this.updateConfirmPassword} value={this.state.confirm_password}/>
</div>
</div>
);
submit = this.submitPassword;
} else {
inputs.push(
<div className="form-group">
<label className="col-sm-12">Log in occurs through GitLab. Please see your GitLab account settings page to update your password.</label>
</div>
);
}
passwordSection = (
<SettingItemMax
title="Password"
inputs={inputs}
submit={submit}
server_error={server_error}
client_error={password_error}
updateSection={function(e){self.props.updateSection("");e.preventDefault();}}
/>
);
} else {
var describe;
if (this.props.user.auth_service === "") {
var d = new Date(this.props.user.last_password_update);
var hour = d.getHours() % 12 ? String(d.getHours() % 12) : "12";
var min = d.getMinutes() < 10 ? "0" + d.getMinutes() : String(d.getMinutes());
var timeOfDay = d.getHours() >= 12 ? " pm" : " am";
describe = "Last updated " + Constants.MONTHS[d.getMonth()] + " " + d.getDate() + ", " + d.getFullYear() + " at " + hour + ":" + min + timeOfDay;
} else {
describe = "Log in done through GitLab"
}
passwordSection = (
<SettingItemMin
title="Password"
describe={describe}
updateSection={function(){self.props.updateSection("password");}}
/>
);
}
return (
<div>
<div className="modal-header">
<button type="button" className="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 className="modal-title" ref="title"><i className="modal-back"></i>Security Settings</h4>
</div>
<div className="user-settings">
<h3 className="tab-header">Security Settings</h3>
<div className="divider-dark first"/>
{ passwordSection }
<div className="divider-dark"/>
<br></br>
<a data-toggle="modal" className="security-links theme" data-target="#access-history" href="#" onClick={this.handleHistoryOpen}><i className="fa fa-clock-o"></i>View Access History</a>
<b> </b>
<a data-toggle="modal" className="security-links theme" data-target="#activity-log" href="#" onClick={this.handleDevicesOpen}><i className="fa fa-globe"></i>View and Logout of Active Sessions</a>
</div>
</div>
);
}
});
var GeneralTab = React.createClass({
submitActive: false,
submitUsername: function(e) {
e.preventDefault();
var user = this.props.user;
var username = this.state.username.trim();
var username_error = utils.isValidUsername(username);
if (username_error === "Cannot use a reserved word as a username.") {
this.setState({client_error: "This username is reserved, please choose a new one." });
return;
} else if (username_error) {
this.setState({client_error: "Username must begin with a letter, and contain between 3 to 15 lowercase characters made up of numbers, letters, and the symbols '.', '-' and '_'." });
return;
}
if (user.username === username) {
this.setState({client_error: "You must submit a new username"});
return;
}
user.username = username;
this.submitUser(user);
},
submitNickname: function(e) {
e.preventDefault();
var user = UserStore.getCurrentUser();
var nickname = this.state.nickname.trim();
if (user.nickname === nickname) {
this.setState({client_error: "You must submit a new nickname"})
return;
}
user.nickname = nickname;
this.submitUser(user);
},
submitName: function(e) {
e.preventDefault();
var user = UserStore.getCurrentUser();
var firstName = this.state.first_name.trim();
var lastName = this.state.last_name.trim();
if (user.first_name === firstName && user.last_name === lastName) {
this.setState({client_error: "You must submit a new first or last name"})
return;
}
user.first_name = firstName;
user.last_name = lastName;
this.submitUser(user);
},
submitEmail: function(e) {
e.preventDefault();
var user = UserStore.getCurrentUser();
var email = this.state.email.trim().toLowerCase();
if (user.email === email) {
return;
}
if (email === '' || !utils.isEmail(email)) {
this.setState({ email_error: "Please enter a valid email address" });
return;
}
user.email = email;
this.submitUser(user);
},
submitUser: function(user) {
client.updateUser(user,
function(data) {
this.updateSection("");
AsyncClient.getMe();
}.bind(this),
function(err) {
state = this.getInitialState();
if(err.message) {
state.server_error = err.message;
} else {
state.server_error = err
}
this.setState(state);
}.bind(this)
);
},
submitPicture: function(e) {
e.preventDefault();
if (!this.state.picture) return;
if(!this.submitActive) return;
var picture = this.state.picture;
if(picture.type !== "image/jpeg" && picture.type !== "image/png") {
this.setState({client_error: "Only JPG or PNG images may be used for profile pictures"});
return;
}
formData = new FormData();
formData.append('image', picture, picture.name);
client.uploadProfileImage(formData,
function(data) {
this.submitActive = false;
AsyncClient.getMe();
window.location.reload();
}.bind(this),
function(err) {
state = this.getInitialState();
state.server_error = err;
this.setState(state);
}.bind(this)
);
},
updateUsername: function(e) {
this.setState({ username: e.target.value });
},
updateFirstName: function(e) {
this.setState({ first_name: e.target.value });
},
updateLastName: function(e) {
this.setState({ last_name: e.target.value});
},
updateNickname: function(e) {
this.setState({nickname: e.target.value});
},
updateEmail: function(e) {
this.setState({ email: e.target.value});
},
updatePicture: function(e) {
if (e.target.files && e.target.files[0]) {
this.setState({ picture: e.target.files[0] });
this.submitActive = true;
this.setState({client_error:null})
} else {
this.setState({ picture: null });
}
},
updateSection: function(section) {
this.setState({client_error:""})
this.submitActive = false
this.props.updateSection(section);
},
handleClose: function() {
$(this.getDOMNode()).find(".form-control").each(function() {
this.value = "";
});
this.setState(assign({}, this.getInitialState(), {client_error: null, server_error: null, email_error: null}));
},
componentDidMount: function() {
$('#user_settings1').on('hidden.bs.modal', this.handleClose);
},
componentWillUnmount: function() {
$('#user_settings1').off('hidden.bs.modal', this.handleClose);
},
getInitialState: function() {
var user = this.props.user;
return { username: user.username, first_name: user.first_name, last_name: user.last_name, nickname: user.nickname,
email: user.email, picture: null };
},
render: function() {
var user = this.props.user;
var client_error = this.state.client_error ? this.state.client_error : null;
var server_error = this.state.server_error ? this.state.server_error : null;
var email_error = this.state.email_error ? this.state.email_error : null;
var nameSection;
var self = this;
if (this.props.activeSection === 'name') {
var inputs = [];
inputs.push(
<div className="form-group">
<label className="col-sm-5 control-label">First Name</label>
<div className="col-sm-7">
<input className="form-control" type="text" onChange={this.updateFirstName} value={this.state.first_name}/>
</div>
</div>
);
inputs.push(
<div className="form-group">
<label className="col-sm-5 control-label">Last Name</label>
<div className="col-sm-7">
<input className="form-control" type="text" onChange={this.updateLastName} value={this.state.last_name}/>
</div>
</div>
);
nameSection = (
<SettingItemMax
title="Full Name"
inputs={inputs}
submit={this.submitName}
server_error={server_error}
client_error={client_error}
updateSection={function(e){self.updateSection("");e.preventDefault();}}
/>
);
} else {
var full_name = "";
if (user.first_name && user.last_name) {
full_name = user.first_name + " " + user.last_name;
} else if (user.first_name) {
full_name = user.first_name;
} else if (user.last_name) {
full_name = user.last_name;
}
nameSection = (
<SettingItemMin
title="Full Name"
describe={full_name}
updateSection={function(){self.updateSection("name");}}
/>
);
}
var nicknameSection;
if (this.props.activeSection === 'nickname') {
var inputs = [];
inputs.push(
<div className="form-group">
<label className="col-sm-5 control-label">{utils.isMobile() ? "": "Nickname"}</label>
<div className="col-sm-7">
<input className="form-control" type="text" onChange={this.updateNickname} value={this.state.nickname}/>
</div>
</div>
);
nicknameSection = (
<SettingItemMax
title="Nickname"
inputs={inputs}
submit={this.submitNickname}
server_error={server_error}
client_error={client_error}
updateSection={function(e){self.updateSection("");e.preventDefault();}}
/>
);
} else {
nicknameSection = (
<SettingItemMin
title="Nickname"
describe={UserStore.getCurrentUser().nickname}
updateSection={function(){self.updateSection("nickname");}}
/>
);
}
var usernameSection;
if (this.props.activeSection === 'username') {
var inputs = [];
inputs.push(
<div className="form-group">
<label className="col-sm-5 control-label">{utils.isMobile() ? "": "Username"}</label>
<div className="col-sm-7">
<input className="form-control" type="text" onChange={this.updateUsername} value={this.state.username}/>
</div>
</div>
);
usernameSection = (
<SettingItemMax
title="Username"
inputs={inputs}
submit={this.submitUsername}
server_error={server_error}
client_error={client_error}
updateSection={function(e){self.updateSection("");e.preventDefault();}}
/>
);
} else {
usernameSection = (
<SettingItemMin
title="Username"
describe={UserStore.getCurrentUser().username}
updateSection={function(){self.updateSection("username");}}
/>
);
}
var emailSection;
if (this.props.activeSection === 'email') {
var inputs = [];
inputs.push(
<div className="form-group">
<label className="col-sm-5 control-label">Primary Email</label>
<div className="col-sm-7">
<input className="form-control" type="text" onChange={this.updateEmail} value={this.state.email}/>
</div>
</div>
);
emailSection = (
<SettingItemMax
title="Email"
inputs={inputs}
submit={this.submitEmail}
server_error={server_error}
client_error={email_error}
updateSection={function(e){self.updateSection("");e.preventDefault();}}
/>
);
} else {
emailSection = (
<SettingItemMin
title="Email"
describe={UserStore.getCurrentUser().email}
updateSection={function(){self.updateSection("email");}}
/>
);
}
var pictureSection;
if (this.props.activeSection === 'picture') {
pictureSection = (
<SettingPicture
title="Profile Picture"
submit={this.submitPicture}
src={"/api/v1/users/" + user.id + "/image?time=" + user.last_picture_update}
server_error={server_error}
client_error={client_error}
updateSection={function(e){self.updateSection("");e.preventDefault();}}
picture={this.state.picture}
pictureChange={this.updatePicture}
submitActive={this.submitActive}
/>
);
} else {
var minMessage = "Click Edit to upload an image.";
if (user.last_picture_update) {
minMessage = "Image last updated " + utils.displayDate(user.last_picture_update)
}
pictureSection = (
<SettingItemMin
title="Profile Picture"
describe={minMessage}
updateSection={function(){self.updateSection("picture");}}
/>
);
}
return (
<div>
<div className="modal-header">
<button type="button" className="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 className="modal-title" ref="title"><i className="modal-back"></i>General Settings</h4>
</div>
<div className="user-settings">
<h3 className="tab-header">General Settings</h3>
<div className="divider-dark first"/>
{nameSection}
<div className="divider-light"/>
{usernameSection}
<div className="divider-light"/>
{nicknameSection}
<div className="divider-light"/>
{emailSection}
<div className="divider-light"/>
{pictureSection}
<div className="divider-dark"/>
</div>
</div>
);
}
});
var AppearanceTab = React.createClass({
submitTheme: function(e) {
e.preventDefault();
var user = UserStore.getCurrentUser();
if (!user.props) user.props = {};
user.props.theme = this.state.theme;
client.updateUser(user,
function(data) {
this.props.updateSection("");
window.location.reload();
}.bind(this),
function(err) {
state = this.getInitialState();
state.server_error = err;
this.setState(state);
}.bind(this)
);
},
updateTheme: function(e) {
var hex = utils.rgb2hex(e.target.style.backgroundColor);
this.setState({ theme: hex.toLowerCase() });
},
handleClose: function() {
this.setState({server_error: null});
},
componentDidMount: function() {
if (this.props.activeSection === "theme") {
$(this.refs[this.state.theme].getDOMNode()).addClass('active-border');
}
$('#user_settings1').on('hidden.bs.modal', this.handleClose);
},
componentDidUpdate: function() {
if (this.props.activeSection === "theme") {
$('.color-btn').removeClass('active-border');
$(this.refs[this.state.theme].getDOMNode()).addClass('active-border');
}
},
componentWillUnmount: function() {
$('#user_settings1').off('hidden.bs.modal', this.handleClose);
},
getInitialState: function() {
var user = UserStore.getCurrentUser();
var theme = config.ThemeColors != null ? config.ThemeColors[0] : "#2389d7";
if (user.props && user.props.theme) {
theme = user.props.theme;
}
return { theme: theme.toLowerCase() };
},
render: function() {
var server_error = this.state.server_error ? this.state.server_error : null;
var themeSection;
var self = this;
if (config.ThemeColors != null) {
if (this.props.activeSection === 'theme') {
var theme_buttons = [];
for (var i = 0; i < config.ThemeColors.length; i++) {
theme_buttons.push(<button ref={config.ThemeColors[i]} type="button" className="btn btn-lg color-btn" style={{backgroundColor: config.ThemeColors[i]}} onClick={this.updateTheme} />);
}
var inputs = [];
inputs.push(
<li className="setting-list-item">
<div className="btn-group" data-toggle="buttons-radio">
{ theme_buttons }
</div>
</li>
);
themeSection = (
<SettingItemMax
title="Theme Color"
inputs={inputs}
submit={this.submitTheme}
server_error={server_error}
updateSection={function(e){self.props.updateSection("");e.preventDefault;}}
/>
);
} else {
themeSection = (
<SettingItemMin
title="Theme Color"
describe={this.state.theme}
updateSection={function(){self.props.updateSection("theme");}}
/>
);
}
}
return (
<div>
<div className="modal-header">
<button type="button" className="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 className="modal-title" ref="title"><i className="modal-back"></i>Appearance Settings</h4>
</div>
<div className="user-settings">
<h3 className="tab-header">Appearance Settings</h3>
<div className="divider-dark first"/>
{themeSection}
<div className="divider-dark"/>
</div>
</div>
);
}
});
module.exports = React.createClass({
componentDidMount: function() {
UserStore.addChangeListener(this._onChange);
},
componentWillUnmount: function() {
UserStore.removeChangeListener(this._onChange);
},
_onChange: function () {
var user = UserStore.getCurrentUser();
if (!utils.areStatesEqual(this.state.user, user)) {
this.setState({ user: user });
}
},
getInitialState: function() {
return { user: UserStore.getCurrentUser() };
},
render: function() {
if (this.props.activeTab === 'general') {
return (
<div>
<GeneralTab user={this.state.user} activeSection={this.props.activeSection} updateSection={this.props.updateSection} />
</div>
);
} else if (this.props.activeTab === 'security') {
return (
<div>
<SecurityTab user={this.state.user} activeSection={this.props.activeSection} updateSection={this.props.updateSection} />
</div>
);
} else if (this.props.activeTab === 'notifications') {
return (
<div>
<NotificationsTab user={this.state.user} activeSection={this.props.activeSection} updateSection={this.props.updateSection} />
</div>
);
} else if (this.props.activeTab === 'appearance') {
return (
<div>
<AppearanceTab activeSection={this.props.activeSection} updateSection={this.props.updateSection} />
</div>
);
} else {
return <div/>;
}
}
});