2024-04-08 15:00:09 -04:00
|
|
|
import { getOwner } from "@ember/application";
|
2023-10-10 14:38:59 -04:00
|
|
|
import { click, render } from "@ember/test-helpers";
|
2023-07-06 09:26:25 -04:00
|
|
|
import hbs from "htmlbars-inline-precompile";
|
|
|
|
import { module, test } from "qunit";
|
2023-10-10 14:38:59 -04:00
|
|
|
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
|
|
|
|
import pretender from "discourse/tests/helpers/create-pretender";
|
|
|
|
import { query, queryAll } from "discourse/tests/helpers/qunit-helpers";
|
2023-10-18 06:07:09 -04:00
|
|
|
import I18n from "discourse-i18n";
|
2024-04-08 15:00:09 -04:00
|
|
|
import ChatFabricators from "discourse/plugins/chat/discourse/lib/fabricators";
|
2023-07-06 09:26:25 -04:00
|
|
|
|
|
|
|
module("Discourse Chat | Component | chat-notice", function (hooks) {
|
|
|
|
setupRenderingTest(hooks);
|
|
|
|
|
|
|
|
test("displays all notices for a channel", async function (assert) {
|
2024-04-08 15:00:09 -04:00
|
|
|
this.channel = new ChatFabricators(getOwner(this)).channel();
|
2023-11-25 12:10:10 -05:00
|
|
|
this.manager = this.container.lookup(
|
|
|
|
"service:chat-channel-notices-manager"
|
|
|
|
);
|
2023-07-06 09:26:25 -04:00
|
|
|
this.manager.handleNotice({
|
|
|
|
channel_id: this.channel.id,
|
|
|
|
text_content: "hello",
|
|
|
|
});
|
|
|
|
this.manager.handleNotice({
|
|
|
|
channel_id: this.channel.id,
|
|
|
|
text_content: "goodbye",
|
|
|
|
});
|
|
|
|
this.manager.handleNotice({
|
|
|
|
channel_id: this.channel.id + 1,
|
|
|
|
text_content: "N/A",
|
|
|
|
});
|
|
|
|
|
|
|
|
await render(hbs`<ChatNotices @channel={{this.channel}} />`);
|
|
|
|
|
|
|
|
const notices = queryAll(".chat-notices .chat-notices__notice");
|
|
|
|
|
|
|
|
assert.strictEqual(notices.length, 2, "Two notices are rendered");
|
|
|
|
|
|
|
|
assert.true(notices[0].innerText.includes("hello"));
|
|
|
|
assert.true(notices[1].innerText.includes("goodbye"));
|
|
|
|
});
|
|
|
|
|
|
|
|
test("Notices can be cleared", async function (assert) {
|
2024-04-08 15:00:09 -04:00
|
|
|
this.channel = new ChatFabricators(getOwner(this)).channel();
|
2023-11-25 12:10:10 -05:00
|
|
|
this.manager = this.container.lookup(
|
|
|
|
"service:chat-channel-notices-manager"
|
|
|
|
);
|
2023-07-06 09:26:25 -04:00
|
|
|
this.manager.handleNotice({
|
|
|
|
channel_id: this.channel.id,
|
|
|
|
text_content: "hello",
|
|
|
|
});
|
|
|
|
|
|
|
|
await render(hbs`<ChatNotices @channel={{this.channel}} />`);
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
queryAll(".chat-notices .chat-notices__notice").length,
|
|
|
|
1,
|
|
|
|
"Notice is present"
|
|
|
|
);
|
|
|
|
|
|
|
|
await click(query(".chat-notices__notice__clear"), "Clear the notice");
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
queryAll(".chat-notices .chat-notices__notice").length,
|
|
|
|
0,
|
|
|
|
"Notice was cleared"
|
|
|
|
);
|
|
|
|
});
|
2023-09-01 10:07:23 -04:00
|
|
|
test("MentionWithoutMembership notice renders", async function (assert) {
|
2024-04-08 15:00:09 -04:00
|
|
|
this.channel = new ChatFabricators(getOwner(this)).channel();
|
2023-11-25 12:10:10 -05:00
|
|
|
this.manager = this.container.lookup(
|
|
|
|
"service:chat-channel-notices-manager"
|
|
|
|
);
|
2023-09-01 10:07:23 -04:00
|
|
|
const text = "Joffrey can't chat, hermano";
|
|
|
|
this.manager.handleNotice({
|
|
|
|
channel_id: this.channel.id,
|
|
|
|
notice_type: "mention_without_membership",
|
|
|
|
data: { user_ids: [1], message_id: 1, text },
|
|
|
|
});
|
|
|
|
|
|
|
|
await render(hbs`<ChatNotices @channel={{this.channel}} />`);
|
|
|
|
|
|
|
|
assert.strictEqual(
|
|
|
|
queryAll(
|
|
|
|
".chat-notices .chat-notices__notice .mention-without-membership-notice"
|
|
|
|
).length,
|
|
|
|
1,
|
|
|
|
"Notice is present"
|
|
|
|
);
|
|
|
|
|
|
|
|
assert.dom(".mention-without-membership-notice__body__text").hasText(text);
|
|
|
|
assert
|
|
|
|
.dom(".mention-without-membership-notice__body__link")
|
|
|
|
.hasText(I18n.t("chat.mention_warning.invite"));
|
|
|
|
|
2023-10-24 12:51:33 -04:00
|
|
|
pretender.post(`/chat/api/channels/${this.channel.id}/invites`, () => {
|
2023-09-01 10:07:23 -04:00
|
|
|
return [200, { "Content-Type": "application/json" }, {}];
|
|
|
|
});
|
|
|
|
|
|
|
|
await click(
|
|
|
|
query(".mention-without-membership-notice__body__link"),
|
|
|
|
"Invites the user"
|
|
|
|
);
|
|
|
|
|
|
|
|
// I would love to test that the invitation sent text is present here but
|
|
|
|
// dismiss is called right away instead of waiting 3 seconds.. Not much we can
|
|
|
|
// do about this - at least we are testing that nothing broke all the way through
|
|
|
|
// clearing the notice
|
|
|
|
assert.strictEqual(
|
|
|
|
queryAll(
|
|
|
|
".chat-notices .chat-notices__notice .mention-without-membership-notice"
|
|
|
|
).length,
|
|
|
|
0,
|
|
|
|
"Notice has been cleared"
|
|
|
|
);
|
|
|
|
});
|
2023-07-06 09:26:25 -04:00
|
|
|
});
|