FIX: generates markdown from pasting link (#21241)
After removing `TextareaTextManipulation` from `ChatComposer` and using `TextareaInteractor` as a proxy, one function has been forgotten: `paste(event)` which is not available in glimmer components anymore, and even less avaiable now that the mixin is not tied to a component anymore but a real DOM node. As a solution we now add a manual paste event listener which will call `paste(event)`.
This commit is contained in:
parent
1e08afa8d4
commit
427fa36edd
|
@ -402,10 +402,12 @@ export default Mixin.create({
|
||||||
plainText = plainText.replace(/\r/g, "");
|
plainText = plainText.replace(/\r/g, "");
|
||||||
const table = this.extractTable(plainText);
|
const table = this.extractTable(plainText);
|
||||||
if (table) {
|
if (table) {
|
||||||
this.appEvents.trigger(
|
this.composerEventPrefix
|
||||||
|
? this.appEvents.trigger(
|
||||||
`${this.composerEventPrefix}:insert-text`,
|
`${this.composerEventPrefix}:insert-text`,
|
||||||
table
|
table
|
||||||
);
|
)
|
||||||
|
: this.insertText(table);
|
||||||
handled = true;
|
handled = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -457,10 +459,12 @@ export default Mixin.create({
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isComposer) {
|
if (isComposer) {
|
||||||
this.appEvents.trigger(
|
this.composerEventPrefix
|
||||||
|
? this.appEvents.trigger(
|
||||||
`${this.composerEventPrefix}:insert-text`,
|
`${this.composerEventPrefix}:insert-text`,
|
||||||
markdown
|
markdown
|
||||||
);
|
)
|
||||||
|
: this.insertText(markdown);
|
||||||
handled = true;
|
handled = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,7 @@ import TextareaTextManipulation from "discourse/mixins/textarea-text-manipulatio
|
||||||
import { next, schedule } from "@ember/runloop";
|
import { next, schedule } from "@ember/runloop";
|
||||||
import { setOwner } from "@ember/application";
|
import { setOwner } from "@ember/application";
|
||||||
import { inject as service } from "@ember/service";
|
import { inject as service } from "@ember/service";
|
||||||
|
import { registerDestructor } from "@ember/destroyable";
|
||||||
|
|
||||||
// This class sole purpose is to provide a way to interact with the textarea
|
// This class sole purpose is to provide a way to interact with the textarea
|
||||||
// using the existing TextareaTextManipulation mixin without using it directly
|
// using the existing TextareaTextManipulation mixin without using it directly
|
||||||
|
@ -12,6 +13,7 @@ export default class TextareaInteractor extends EmberObject.extend(
|
||||||
) {
|
) {
|
||||||
@service capabilities;
|
@service capabilities;
|
||||||
@service site;
|
@service site;
|
||||||
|
@service siteSettings;
|
||||||
|
|
||||||
constructor(owner, textarea) {
|
constructor(owner, textarea) {
|
||||||
super(...arguments);
|
super(...arguments);
|
||||||
|
@ -20,6 +22,18 @@ export default class TextareaInteractor extends EmberObject.extend(
|
||||||
this._textarea = textarea;
|
this._textarea = textarea;
|
||||||
this.element = this._textarea;
|
this.element = this._textarea;
|
||||||
this.ready = true;
|
this.ready = true;
|
||||||
|
this.composerFocusSelector = ".chat-composer__input";
|
||||||
|
|
||||||
|
this.init(); // mixin init wouldn't be called otherwise
|
||||||
|
this.composerEventPrefix = null; // we don't need app events
|
||||||
|
|
||||||
|
// paste is using old native ember events defined on composer
|
||||||
|
this.textarea.addEventListener("paste", this.paste);
|
||||||
|
registerDestructor(this, (instance) => instance.teardown());
|
||||||
|
}
|
||||||
|
|
||||||
|
teardown() {
|
||||||
|
this.textarea.removeEventListener("paste", this.paste);
|
||||||
}
|
}
|
||||||
|
|
||||||
set value(value) {
|
set value(value) {
|
||||||
|
|
|
@ -262,4 +262,35 @@ RSpec.describe "Chat composer", type: :system, js: true do
|
||||||
expect(find(".chat-composer__input").value).to eq("bb")
|
expect(find(".chat-composer__input").value).to eq("bb")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "when pasting link over selected text" do
|
||||||
|
before do
|
||||||
|
channel_1.add(current_user)
|
||||||
|
sign_in(current_user)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "outputs a markdown link" do
|
||||||
|
modifier = /darwin/i =~ RbConfig::CONFIG["host_os"] ? :command : :control
|
||||||
|
select_text = <<-JS
|
||||||
|
const element = document.querySelector(arguments[0]);
|
||||||
|
element.focus();
|
||||||
|
element.setSelectionRange(0, element.value.length)
|
||||||
|
JS
|
||||||
|
|
||||||
|
chat.visit_channel(channel_1)
|
||||||
|
|
||||||
|
find("body").send_keys("https://www.discourse.org")
|
||||||
|
page.execute_script(select_text, ".chat-composer__input")
|
||||||
|
|
||||||
|
page.send_keys [modifier, "c"]
|
||||||
|
page.send_keys [:backspace]
|
||||||
|
|
||||||
|
find("body").send_keys("discourse")
|
||||||
|
page.execute_script(select_text, ".chat-composer__input")
|
||||||
|
|
||||||
|
page.send_keys [modifier, "v"]
|
||||||
|
|
||||||
|
expect(find(".chat-composer__input").value).to eq("[discourse](https://www.discourse.org)")
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue