FEATURE: Add the ability to go back and forth between PM and New Topic (#15173)

Before this, if you were composing a new topic and then switched the mode to "New Message", the dropdown would disappear.

So if you changed your mind, you'd have to copy the text you typed, cancel, click "New Topic" again, and then paste the text. (and if you already had a title entered too, things would be more complicated…)
This commit is contained in:
Jarek Radosz 2021-12-02 19:46:40 +01:00 committed by GitHub
parent bd10f113e9
commit 7456a59022
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 23 additions and 28 deletions

View File

@ -2,6 +2,7 @@ import {
acceptance, acceptance,
count, count,
exists, exists,
query,
queryAll, queryAll,
updateCurrentUser, updateCurrentUser,
} from "discourse/tests/helpers/qunit-helpers"; } from "discourse/tests/helpers/qunit-helpers";
@ -187,7 +188,7 @@ acceptance("Composer Actions", function (needs) {
assert.deepEqual(privateMessageUsers.header().value(), "foo,foo_group"); assert.deepEqual(privateMessageUsers.header().value(), "foo,foo_group");
}); });
test("hide component if no content", async function (assert) { test("allow switching back to New Topic", async function (assert) {
await visit("/"); await visit("/");
await click("button#create-topic"); await click("button#create-topic");
@ -195,12 +196,18 @@ acceptance("Composer Actions", function (needs) {
await composerActions.expand(); await composerActions.expand();
await composerActions.selectRowByValue("reply_as_private_message"); await composerActions.selectRowByValue("reply_as_private_message");
assert.ok(composerActions.el().hasClass("is-hidden")); assert.strictEqual(
assert.strictEqual(composerActions.el().children().length, 0); query(".action-title").innerText,
I18n.t("topic.private_message")
);
await click("button#create-topic");
await composerActions.expand(); await composerActions.expand();
assert.strictEqual(composerActions.rows().length, 2); await composerActions.selectRowByValue("create_topic");
assert.strictEqual(
query(".action-title").innerText,
I18n.t("topic.create_long")
);
}); });
test("interactions", async function (assert) { test("interactions", async function (assert) {

View File

@ -208,11 +208,6 @@ export default DropdownSelectBoxComponent.extend({
}); });
} }
let showCreateTopic = false;
if (this.action === CREATE_SHARED_DRAFT) {
showCreateTopic = true;
}
if (this.action === CREATE_TOPIC) { if (this.action === CREATE_TOPIC) {
if (this.site.shared_drafts_category_id) { if (this.site.shared_drafts_category_id) {
// Shared Drafts Choice // Shared Drafts Choice
@ -223,24 +218,6 @@ export default DropdownSelectBoxComponent.extend({
id: "shared_draft", id: "shared_draft",
}); });
} }
// Edge case: If personal messages are disabled, it is possible to have
// no items which still renders a button that pops up nothing. In this
// case, add an option for what you're currently doing.
if (items.length === 0) {
showCreateTopic = true;
}
}
if (showCreateTopic) {
items.push({
name: I18n.t("composer.composer_actions.create_topic.label"),
description: I18n.t(
"composer.composer_actions.reply_as_new_topic.desc"
),
icon: "share",
id: "create_topic",
});
} }
const showToggleTopicBump = const showToggleTopicBump =
@ -256,6 +233,17 @@ export default DropdownSelectBoxComponent.extend({
}); });
} }
if (items.length === 0) {
items.push({
name: I18n.t("composer.composer_actions.create_topic.label"),
description: I18n.t(
"composer.composer_actions.reply_as_new_topic.desc"
),
icon: "share",
id: "create_topic",
});
}
return items; return items;
}, },