FIX: Ensure emoji is inserted in the correct location (#17107)
In the specific case where you start typing an emoji, then open the full emoji picker, the chosen emoji would be inserted in the wrong place. This was an unintentional side effect of the changes in 75d9c16156
This commit updates the `emojiSelected` logic to avoid mutating the 'selected' object, and also adds a test for this specific behaviour.
This commit is contained in:
parent
c39cebc161
commit
a4fc88ce68
|
@ -570,14 +570,12 @@ export default Mixin.create({
|
||||||
this.addText(selected, `:${code}:`);
|
this.addText(selected, `:${code}:`);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
let numOfRemovedChars = selected.pre.length - captures[1].length;
|
let numOfRemovedChars = captures[1].length;
|
||||||
selected.pre = selected.pre.slice(
|
this._insertAt(
|
||||||
0,
|
selected.start - numOfRemovedChars,
|
||||||
selected.pre.length - captures[1].length
|
selected.end,
|
||||||
|
`${code}:`
|
||||||
);
|
);
|
||||||
selected.start -= numOfRemovedChars;
|
|
||||||
selected.end -= numOfRemovedChars;
|
|
||||||
this.addText(selected, `${code}:`);
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -19,6 +19,7 @@ import formatTextWithSelection from "discourse/tests/helpers/d-editor-helper";
|
||||||
import hbs from "htmlbars-inline-precompile";
|
import hbs from "htmlbars-inline-precompile";
|
||||||
import { next } from "@ember/runloop";
|
import { next } from "@ember/runloop";
|
||||||
import { withPluginApi } from "discourse/lib/plugin-api";
|
import { withPluginApi } from "discourse/lib/plugin-api";
|
||||||
|
import { isLegacyEmber } from "discourse-common/config/environment";
|
||||||
|
|
||||||
discourseModule("Integration | Component | d-editor", function (hooks) {
|
discourseModule("Integration | Component | d-editor", function (hooks) {
|
||||||
setupRenderingTest(hooks);
|
setupRenderingTest(hooks);
|
||||||
|
@ -727,7 +728,27 @@ third line`
|
||||||
await click(
|
await click(
|
||||||
'.emoji-picker .section[data-section="smileys_&_emotion"] img.emoji[title="grinning"]'
|
'.emoji-picker .section[data-section="smileys_&_emotion"] img.emoji[title="grinning"]'
|
||||||
);
|
);
|
||||||
assert.strictEqual(this.value, "hello world. :grinning:");
|
assert.strictEqual(
|
||||||
|
this.value,
|
||||||
|
"hello world. :grinning:",
|
||||||
|
"it works when there is no partial emoji"
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!isLegacyEmber()) {
|
||||||
|
await click("textarea.d-editor-input");
|
||||||
|
await fillIn(".d-editor-input", "starting to type an emoji like :gri");
|
||||||
|
jumpEnd(query("textarea.d-editor-input"));
|
||||||
|
await click("button.emoji");
|
||||||
|
|
||||||
|
await click(
|
||||||
|
'.emoji-picker .section[data-section="smileys_&_emotion"] img.emoji[title="grinning"]'
|
||||||
|
);
|
||||||
|
assert.strictEqual(
|
||||||
|
this.value,
|
||||||
|
"starting to type an emoji like :grinning:",
|
||||||
|
"it works when there is a partial emoji"
|
||||||
|
);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue