summaryrefslogtreecommitdiffstats
path: root/webapp
diff options
context:
space:
mode:
authorHarrison Healey <harrisonmhealey@gmail.com>2016-07-15 12:26:32 -0400
committerHarrison Healey <harrisonmhealey@gmail.com>2016-07-15 12:26:32 -0400
commitf7b3731b2b2767b0784e1f2e0ce723cae917c47a (patch)
treefd00d8da4bcbd671a9b1324dd500d133daf06e19 /webapp
parent942ae4c5278e0a3064ef08937063ec66a6a8e990 (diff)
parentab52700aaa76a5623de23cd0156f5dbd9a24e264 (diff)
downloadchat-f7b3731b2b2767b0784e1f2e0ce723cae917c47a.tar.gz
chat-f7b3731b2b2767b0784e1f2e0ce723cae917c47a.tar.bz2
chat-f7b3731b2b2767b0784e1f2e0ce723cae917c47a.zip
Merge branch 'release-3.2' into 'master'
Diffstat (limited to 'webapp')
-rw-r--r--webapp/components/admin_console/file_upload_setting.jsx6
-rw-r--r--webapp/components/admin_console/remove_file_setting.jsx13
-rw-r--r--webapp/components/admin_console/saml_settings.jsx10
-rw-r--r--webapp/components/post_view/post_view_controller.jsx4
-rw-r--r--webapp/stores/emoji_store.jsx12
5 files changed, 26 insertions, 19 deletions
diff --git a/webapp/components/admin_console/file_upload_setting.jsx b/webapp/components/admin_console/file_upload_setting.jsx
index e7cb387ee..a7df16c0a 100644
--- a/webapp/components/admin_console/file_upload_setting.jsx
+++ b/webapp/components/admin_console/file_upload_setting.jsx
@@ -18,7 +18,8 @@ export default class FileUploadSetting extends Setting {
uploadingText: React.PropTypes.node,
onSubmit: React.PropTypes.func.isRequired,
disabled: React.PropTypes.bool,
- fileType: React.PropTypes.string.isRequired
+ fileType: React.PropTypes.string.isRequired,
+ error: React.PropTypes.string
};
}
@@ -29,7 +30,8 @@ export default class FileUploadSetting extends Setting {
this.handleSubmit = this.handleSubmit.bind(this);
this.state = {
- fileName: null
+ fileName: null,
+ serverError: props.error
};
}
diff --git a/webapp/components/admin_console/remove_file_setting.jsx b/webapp/components/admin_console/remove_file_setting.jsx
index 5a76faae2..9a6266a62 100644
--- a/webapp/components/admin_console/remove_file_setting.jsx
+++ b/webapp/components/admin_console/remove_file_setting.jsx
@@ -23,28 +23,18 @@ export default class RemoveFileSetting extends Setting {
constructor(props) {
super(props);
this.handleRemove = this.handleRemove.bind(this);
-
- this.state = {
- serverError: null
- };
}
handleRemove(e) {
e.preventDefault();
$(this.refs.remove_button).button('loading');
- this.props.onSubmit(this.props.id, (error) => {
+ this.props.onSubmit(this.props.id, () => {
$(this.refs.remove_button).button('reset');
- this.setState({serverError: error});
});
}
render() {
- let serverError;
- if (this.state.serverError) {
- serverError = <div className='form-group has-error'><label className='control-label'>{this.state.serverError}</label></div>;
- }
-
return (
<Setting
label={this.props.label}
@@ -64,7 +54,6 @@ export default class RemoveFileSetting extends Setting {
>
{this.props.removeButtonText}
</button>
- {serverError}
</div>
</Setting>
);
diff --git a/webapp/components/admin_console/saml_settings.jsx b/webapp/components/admin_console/saml_settings.jsx
index 611c37192..5fba78b75 100644
--- a/webapp/components/admin_console/saml_settings.jsx
+++ b/webapp/components/admin_console/saml_settings.jsx
@@ -76,7 +76,7 @@ export default class SamlSettings extends AdminSettings {
() => {
const fileName = file.name;
this.handleChange(id, fileName);
- this.setState({[id]: fileName});
+ this.setState({[id]: fileName, [`${id}Error`]: null});
if (callback && typeof callback === 'function') {
callback();
}
@@ -94,12 +94,13 @@ export default class SamlSettings extends AdminSettings {
this.state[id],
() => {
this.handleChange(id, '');
- this.setState({[id]: null});
+ this.setState({[id]: null, [`${id}Error`]: null});
},
(error) => {
if (callback && typeof callback === 'function') {
- callback(error.message);
+ callback();
}
+ this.setState({[id]: null, [`${id}Error`]: error.message});
}
);
}
@@ -168,6 +169,7 @@ export default class SamlSettings extends AdminSettings {
disabled={!this.state.enable}
fileType='.crt,.cer'
onSubmit={this.uploadCertificate}
+ error={this.state.idpCertificateFileError}
/>
);
}
@@ -215,6 +217,7 @@ export default class SamlSettings extends AdminSettings {
disabled={!this.state.enable || !this.state.encrypt}
fileType='.key'
onSubmit={this.uploadCertificate}
+ error={this.state.privateKeyFileError}
/>
);
}
@@ -262,6 +265,7 @@ export default class SamlSettings extends AdminSettings {
disabled={!this.state.enable || !this.state.encrypt}
fileType='.crt,.cer'
onSubmit={this.uploadCertificate}
+ error={this.state.publicCertificateFileError}
/>
);
}
diff --git a/webapp/components/post_view/post_view_controller.jsx b/webapp/components/post_view/post_view_controller.jsx
index 3aba569fe..a7583fa38 100644
--- a/webapp/components/post_view/post_view_controller.jsx
+++ b/webapp/components/post_view/post_view_controller.jsx
@@ -260,6 +260,10 @@ export default class PostViewController extends React.Component {
return true;
}
+ if (nextState.emojis !== this.state.emojis) {
+ return true;
+ }
+
return false;
}
diff --git a/webapp/stores/emoji_store.jsx b/webapp/stores/emoji_store.jsx
index 5e1d81dd3..e369885b4 100644
--- a/webapp/stores/emoji_store.jsx
+++ b/webapp/stores/emoji_store.jsx
@@ -54,12 +54,13 @@ class EmojiStore extends EventEmitter {
this.addCustomEmoji(emoji);
}
- // add custom emojis to the map first so that they can't override system ones
- this.emojis = new Map([...this.customEmojis, ...this.systemEmojis]);
+ this.updateEmojiMap();
}
addCustomEmoji(emoji) {
this.customEmojis.set(emoji.name, emoji);
+
+ // this doesn't update this.emojis, but it's only called by setCustomEmojis which does that afterwards
}
removeCustomEmoji(id) {
@@ -69,6 +70,13 @@ class EmojiStore extends EventEmitter {
break;
}
}
+
+ this.updateEmojiMap();
+ }
+
+ updateEmojiMap() {
+ // add custom emojis to the map first so that they can't override system ones
+ this.emojis = new Map([...this.customEmojis, ...this.systemEmojis]);
}
getSystemEmojis() {