You've already forked matrix-react-sdk
mirror of
https://github.com/matrix-org/matrix-react-sdk.git
synced 2025-11-07 10:46:24 +03:00
Merge pull request #3530 from matrix-org/bwindels/watchemoticonsetting
Fix: watch emoticon autoreplace setting
This commit is contained in:
@@ -90,6 +90,7 @@ export default class BasicMessageEditor extends React.Component {
|
|||||||
this._modifiedFlag = false;
|
this._modifiedFlag = false;
|
||||||
this._isIMEComposing = false;
|
this._isIMEComposing = false;
|
||||||
this._hasTextSelected = false;
|
this._hasTextSelected = false;
|
||||||
|
this._emoticonSettingHandle = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
_replaceEmoticon = (caretPosition, inputType, diff) => {
|
_replaceEmoticon = (caretPosition, inputType, diff) => {
|
||||||
@@ -437,18 +438,25 @@ export default class BasicMessageEditor extends React.Component {
|
|||||||
this.setState({completionIndex});
|
this.setState({completionIndex});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_configureEmoticonAutoReplace() {
|
||||||
|
const shouldReplace = SettingsStore.getValue('MessageComposerInput.autoReplaceEmoji');
|
||||||
|
this.props.model.setTransformCallback(shouldReplace ? this._replaceEmoticon : null);
|
||||||
|
}
|
||||||
|
|
||||||
componentWillUnmount() {
|
componentWillUnmount() {
|
||||||
this._editorRef.removeEventListener("input", this._onInput, true);
|
this._editorRef.removeEventListener("input", this._onInput, true);
|
||||||
this._editorRef.removeEventListener("compositionstart", this._onCompositionStart, true);
|
this._editorRef.removeEventListener("compositionstart", this._onCompositionStart, true);
|
||||||
this._editorRef.removeEventListener("compositionend", this._onCompositionEnd, true);
|
this._editorRef.removeEventListener("compositionend", this._onCompositionEnd, true);
|
||||||
|
SettingsStore.unwatchSetting(this._emoticonSettingHandle);
|
||||||
}
|
}
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
const model = this.props.model;
|
const model = this.props.model;
|
||||||
model.setUpdateCallback(this._updateEditorState);
|
model.setUpdateCallback(this._updateEditorState);
|
||||||
if (SettingsStore.getValue('MessageComposerInput.autoReplaceEmoji')) {
|
this._emoticonSettingHandle = SettingsStore.watchSetting('MessageComposerInput.autoReplaceEmoji', null, () => {
|
||||||
model.setTransformCallback(this._replaceEmoticon);
|
this._configureEmoticonAutoReplace();
|
||||||
}
|
});
|
||||||
|
this._configureEmoticonAutoReplace();
|
||||||
const partCreator = model.partCreator;
|
const partCreator = model.partCreator;
|
||||||
// TODO: does this allow us to get rid of EditorStateTransfer?
|
// TODO: does this allow us to get rid of EditorStateTransfer?
|
||||||
// not really, but we could not serialize the parts, and just change the autoCompleter
|
// not really, but we could not serialize the parts, and just change the autoCompleter
|
||||||
|
|||||||
Reference in New Issue
Block a user