2024-04-08 15:00:09 -04:00
|
|
|
import { getOwner } from "@ember/application";
|
2023-08-31 08:46:37 -04:00
|
|
|
import { render } from "@ember/test-helpers";
|
2023-10-10 14:38:59 -04:00
|
|
|
import hbs from "htmlbars-inline-precompile";
|
2023-08-31 08:46:37 -04:00
|
|
|
import { module, test } from "qunit";
|
2024-04-08 15:00:09 -04:00
|
|
|
import CoreFabricators from "discourse/lib/fabricators";
|
2023-10-10 14:38:59 -04:00
|
|
|
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
|
2024-04-08 15:00:09 -04:00
|
|
|
import ChatFabricators from "discourse/plugins/chat/discourse/lib/fabricators";
|
2023-08-31 08:46:37 -04:00
|
|
|
|
|
|
|
module(
|
2023-10-09 15:12:50 -04:00
|
|
|
"Discourse Chat | Component | <ChatThreadParticipants />",
|
2023-08-31 08:46:37 -04:00
|
|
|
function (hooks) {
|
|
|
|
setupRenderingTest(hooks);
|
|
|
|
|
|
|
|
test("no participants", async function (assert) {
|
2024-04-08 15:00:09 -04:00
|
|
|
this.thread = new ChatFabricators(getOwner(this)).thread();
|
2023-10-09 15:12:50 -04:00
|
|
|
await render(hbs`<ChatThreadParticipants @thread={{this.thread}} />`);
|
2023-08-31 08:46:37 -04:00
|
|
|
|
|
|
|
assert.dom(".chat-thread-participants").doesNotExist();
|
|
|
|
});
|
|
|
|
|
2023-10-09 15:12:50 -04:00
|
|
|
test("@includeOriginalMessageUser=true", async function (assert) {
|
2024-04-08 15:00:09 -04:00
|
|
|
const originalMessageUser = new CoreFabricators(getOwner(this)).user({
|
|
|
|
username: "bob",
|
|
|
|
});
|
|
|
|
this.thread = new ChatFabricators(getOwner(this)).thread({
|
|
|
|
original_message: new ChatFabricators(getOwner(this)).message({
|
|
|
|
user: originalMessageUser,
|
|
|
|
}),
|
|
|
|
preview: new ChatFabricators(getOwner(this)).threadPreview({
|
2023-08-31 08:46:37 -04:00
|
|
|
channel: this.channel,
|
|
|
|
participant_users: [
|
2023-11-20 10:49:49 -05:00
|
|
|
originalMessageUser,
|
2024-04-08 15:00:09 -04:00
|
|
|
new CoreFabricators(getOwner(this)).user({ username: "alice" }),
|
2023-08-31 08:46:37 -04:00
|
|
|
],
|
|
|
|
}),
|
|
|
|
});
|
|
|
|
|
2023-10-09 15:12:50 -04:00
|
|
|
await render(hbs`<ChatThreadParticipants @thread={{this.thread}} />`);
|
2023-08-31 08:46:37 -04:00
|
|
|
|
2023-10-09 15:12:50 -04:00
|
|
|
assert.dom(".chat-user-avatar[data-username]").exists({ count: 2 });
|
2023-08-31 08:46:37 -04:00
|
|
|
});
|
|
|
|
|
2023-10-09 15:12:50 -04:00
|
|
|
test("@includeOriginalMessageUser=false", async function (assert) {
|
2024-04-08 15:00:09 -04:00
|
|
|
const originalMessageUser = new CoreFabricators(getOwner(this)).user({
|
|
|
|
username: "bob",
|
|
|
|
});
|
|
|
|
this.thread = new ChatFabricators(getOwner(this)).thread({
|
|
|
|
original_message: new ChatFabricators(getOwner(this)).message({
|
|
|
|
user: originalMessageUser,
|
|
|
|
}),
|
|
|
|
preview: new ChatFabricators(getOwner(this)).threadPreview({
|
2023-08-31 08:46:37 -04:00
|
|
|
channel: this.channel,
|
|
|
|
participant_users: [
|
2023-11-20 10:49:49 -05:00
|
|
|
originalMessageUser,
|
2024-04-08 15:00:09 -04:00
|
|
|
new CoreFabricators(getOwner(this)).user({ username: "alice" }),
|
2023-08-31 08:46:37 -04:00
|
|
|
],
|
|
|
|
}),
|
|
|
|
});
|
|
|
|
|
|
|
|
await render(
|
2023-10-09 15:12:50 -04:00
|
|
|
hbs`<ChatThreadParticipants @thread={{this.thread}} @includeOriginalMessageUser={{false}} />`
|
2023-08-31 08:46:37 -04:00
|
|
|
);
|
|
|
|
|
2023-10-09 15:12:50 -04:00
|
|
|
assert.dom('.chat-user-avatar[data-username="bob"]').doesNotExist();
|
|
|
|
assert.dom('.chat-user-avatar[data-username="alice"]').exists();
|
2023-08-31 08:46:37 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
);
|