2022-11-02 21:41:30 +08:00
|
|
|
|
import {
|
|
|
|
|
acceptance,
|
|
|
|
|
loggedInUser,
|
|
|
|
|
} from "discourse/tests/helpers/qunit-helpers";
|
|
|
|
|
import { click, triggerEvent, visit } from "@ember/test-helpers";
|
|
|
|
|
import { test } from "qunit";
|
|
|
|
|
import {
|
|
|
|
|
chatChannels,
|
|
|
|
|
generateChatView,
|
|
|
|
|
} from "discourse/plugins/chat/chat-fixtures";
|
|
|
|
|
|
|
|
|
|
function setupPretenders(server, helper) {
|
|
|
|
|
server.get("/chat/chat_channels.json", () => helper.response(chatChannels));
|
|
|
|
|
server.get("/chat/:chat_channel_id/messages.json", () =>
|
|
|
|
|
helper.response(generateChatView(loggedInUser()))
|
|
|
|
|
);
|
|
|
|
|
server.get("/chat/emojis.json", () =>
|
|
|
|
|
helper.response({ favorites: [{ name: "grinning" }] })
|
|
|
|
|
);
|
|
|
|
|
server.put("/chat/:id/react/:message_id.json", helper.response);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
acceptance("Discourse Chat - Chat Message", function (needs) {
|
|
|
|
|
needs.user({ has_chat_enabled: true });
|
|
|
|
|
needs.settings({ chat_enabled: true });
|
|
|
|
|
needs.pretender((server, helper) => setupPretenders(server, helper));
|
|
|
|
|
|
|
|
|
|
test("when reacting to a message using inline reaction", async function (assert) {
|
|
|
|
|
const emojiReactionStore = this.container.lookup(
|
|
|
|
|
"service:chat-emoji-reaction-store"
|
|
|
|
|
);
|
|
|
|
|
|
2022-11-08 07:17:43 +08:00
|
|
|
|
assert.deepEqual(
|
|
|
|
|
emojiReactionStore.favorites,
|
|
|
|
|
this.siteSettings.default_emoji_reactions.split("|")
|
|
|
|
|
);
|
2022-11-02 21:41:30 +08:00
|
|
|
|
|
|
|
|
|
await visit("/chat/channel/4/public-category");
|
|
|
|
|
await click(
|
|
|
|
|
`.chat-message-container[data-id="176"] .chat-message-reaction[data-emoji-name="heart"]`
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
assert.deepEqual(
|
|
|
|
|
emojiReactionStore.favorites,
|
2022-11-08 07:17:43 +08:00
|
|
|
|
["heart"].concat(
|
|
|
|
|
this.siteSettings.default_emoji_reactions
|
|
|
|
|
.split("|")
|
|
|
|
|
.filter((r) => r !== "heart")
|
|
|
|
|
),
|
2022-11-02 21:41:30 +08:00
|
|
|
|
"it tracks the emoji"
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
await click(
|
|
|
|
|
`.chat-message-container[data-id="176"] .chat-message-reaction[data-emoji-name="heart"]`
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
assert.deepEqual(
|
|
|
|
|
emojiReactionStore.favorites,
|
2022-11-08 07:17:43 +08:00
|
|
|
|
["heart"].concat(
|
|
|
|
|
this.siteSettings.default_emoji_reactions
|
|
|
|
|
.split("|")
|
|
|
|
|
.filter((r) => r !== "heart")
|
|
|
|
|
),
|
2022-11-02 21:41:30 +08:00
|
|
|
|
"it doesn’t untrack when removing the reaction"
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
test("when reacting to a message using emoji picker reaction", async function (assert) {
|
|
|
|
|
const emojiReactionStore = this.container.lookup(
|
|
|
|
|
"service:chat-emoji-reaction-store"
|
|
|
|
|
);
|
|
|
|
|
|
2022-11-08 07:17:43 +08:00
|
|
|
|
assert.deepEqual(
|
|
|
|
|
emojiReactionStore.favorites,
|
|
|
|
|
this.siteSettings.default_emoji_reactions.split("|")
|
|
|
|
|
);
|
2022-11-02 21:41:30 +08:00
|
|
|
|
|
|
|
|
|
await visit("/chat/channel/4/public-category");
|
|
|
|
|
await triggerEvent(".chat-message-container[data-id='176']", "mouseenter");
|
2022-11-10 22:08:14 +08:00
|
|
|
|
await click(".chat-message-actions-container .react-btn");
|
2022-11-02 21:41:30 +08:00
|
|
|
|
await click(`[data-emoji="grinning"]`);
|
|
|
|
|
|
|
|
|
|
assert.deepEqual(
|
|
|
|
|
emojiReactionStore.favorites,
|
2022-11-08 07:17:43 +08:00
|
|
|
|
["grinning"].concat(this.siteSettings.default_emoji_reactions.split("|")),
|
2022-11-02 21:41:30 +08:00
|
|
|
|
"it tracks the emoji"
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
await click(
|
|
|
|
|
`.chat-message-container[data-id="176"] .chat-message-reaction[data-emoji-name="grinning"]`
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
assert.deepEqual(
|
|
|
|
|
emojiReactionStore.favorites,
|
2022-11-08 07:17:43 +08:00
|
|
|
|
["grinning"].concat(this.siteSettings.default_emoji_reactions.split("|")),
|
2022-11-02 21:41:30 +08:00
|
|
|
|
"it doesn’t untrack when removing the reaction"
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
});
|