mirror of
https://github.com/discourse/discourse.git
synced 2024-12-02 15:43:43 +08:00
10e1831139
This PR is introducing glimmer usage in the chat-live-pane, for components but also for models. RestModel usage has been dropped in favor of native classes. Other changes/additions in this PR: - sticky dates, scrolling will now keep the date separator of the current section at the top of the screen - better unread management, marking a channel as unread will correctly mark the correct message and not mark the whole channel as read. Tracking state will also now correctly return unread count and unread mentions. - adds an animation on bottom arrow - better scrolling behavior, we should now always correctly keep the scroll position while loading more - reactions are now more reactive, and will update their tooltip without needed to close/reopen it - skeleton has been improved with placeholder images and reactions - when making a reaction on the desktop message actions, the menu won't move anymore - simplify logic and stop maintaining a list of unloaded messages
49 lines
1.7 KiB
JavaScript
49 lines
1.7 KiB
JavaScript
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
|
|
import { exists } from "discourse/tests/helpers/qunit-helpers";
|
|
import hbs from "htmlbars-inline-precompile";
|
|
import fabricators from "../helpers/fabricators";
|
|
import { module, test } from "qunit";
|
|
import { render } from "@ember/test-helpers";
|
|
|
|
module("Discourse Chat | Component | chat-channel-metadata", function (hooks) {
|
|
setupRenderingTest(hooks);
|
|
|
|
test("displays last message sent at", async function (assert) {
|
|
let lastMessageSentAt = moment().subtract(1, "day").format();
|
|
this.channel = fabricators.directMessageChatChannel({
|
|
last_message_sent_at: lastMessageSentAt,
|
|
});
|
|
|
|
await render(hbs`<ChatChannelMetadata @channel={{this.channel}} />`);
|
|
|
|
assert.dom(".chat-channel-metadata__date").hasText("Yesterday");
|
|
|
|
lastMessageSentAt = moment();
|
|
this.channel.lastMessageSentAt = lastMessageSentAt;
|
|
await render(hbs`<ChatChannelMetadata @channel={{this.channel}} />`);
|
|
|
|
assert
|
|
.dom(".chat-channel-metadata__date")
|
|
.hasText(lastMessageSentAt.format("LT"));
|
|
});
|
|
|
|
test("unreadIndicator", async function (assert) {
|
|
this.channel = fabricators.directMessageChatChannel();
|
|
this.channel.currentUserMembership.unread_count = 1;
|
|
|
|
this.unreadIndicator = true;
|
|
await render(
|
|
hbs`<ChatChannelMetadata @channel={{this.channel}} @unreadIndicator={{this.unreadIndicator}}/>`
|
|
);
|
|
|
|
assert.true(exists(".chat-channel-unread-indicator"));
|
|
|
|
this.unreadIndicator = false;
|
|
await render(
|
|
hbs`<ChatChannelMetadata @channel={{this.channel}} @unreadIndicator={{this.unreadIndicator}}/>`
|
|
);
|
|
|
|
assert.false(exists(".chat-channel-unread-indicator"));
|
|
});
|
|
});
|