FIX: chat bookmarks in drawer mode (#29757)

When using chat in drawer mode, after you've clicked on a chat bookmark in the user menu, clicking any other chat bookmark would "do nothing".

In 8b18fd1556 we added an optimization to prevent the same route from being reloaded, but it ended up breaking the bookmarks.

This commit reverts the changed made the above commit and adds a system specs that ensure we can click two chat bookmarks in the user menu when using chat in drawer mode.

Internal ref - t/134362
This commit is contained in:
Régis Hanol 2024-11-14 17:20:11 +01:00 committed by GitHub
parent b39c30045b
commit fd1220af69
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 48 additions and 4 deletions

View File

@ -34,11 +34,8 @@ export default class ChatRoute extends DiscourseRoute {
) { ) {
transition.abort(); transition.abort();
if (this.chatDrawerRouter.currentRouteName === transition.targetName) {
return;
}
let url = transition.intent.url; let url = transition.intent.url;
if (transition.targetName.startsWith("chat.channel")) { if (transition.targetName.startsWith("chat.channel")) {
url ??= this.router.urlFor( url ??= this.router.urlFor(
transition.targetName, transition.targetName,
@ -49,6 +46,7 @@ export default class ChatRoute extends DiscourseRoute {
} }
this.appEvents.trigger("chat:open-url", url); this.appEvents.trigger("chat:open-url", url);
return; return;
} }

View File

@ -7,6 +7,7 @@ RSpec.describe "Bookmark message", type: :system do
let(:channel_page) { PageObjects::Pages::ChatChannel.new } let(:channel_page) { PageObjects::Pages::ChatChannel.new }
let(:thread_page) { PageObjects::Pages::ChatThread.new } let(:thread_page) { PageObjects::Pages::ChatThread.new }
let(:bookmark_modal) { PageObjects::Modals::Bookmark.new } let(:bookmark_modal) { PageObjects::Modals::Bookmark.new }
let(:user_menu) { PageObjects::Components::UserMenu.new }
fab!(:category_channel_1) { Fabricate(:category_channel) } fab!(:category_channel_1) { Fabricate(:category_channel) }
fab!(:message_1) { Fabricate(:chat_message, chat_channel: category_channel_1) } fab!(:message_1) { Fabricate(:chat_message, chat_channel: category_channel_1) }
@ -48,6 +49,36 @@ RSpec.describe "Bookmark message", type: :system do
expect(thread_page).to have_bookmarked_message(first_message) expect(thread_page).to have_bookmarked_message(first_message)
end end
context "in drawer mode" do
fab!(:category_channel_2) { Fabricate(:category_channel) }
fab!(:message_2) { Fabricate(:chat_message, chat_channel: category_channel_2) }
fab!(:bookmark_1) { Bookmark.create!(bookmarkable: message_1, user: current_user) }
fab!(:bookmark_2) { Bookmark.create!(bookmarkable: message_2, user: current_user) }
before do
chat_page.prefers_drawer
category_channel_2.add(current_user)
end
it "supports visiting multiple chat bookmarks from the user menu" do
visit("/")
user_menu.open
user_menu.click_bookmarks_tab
expect(user_menu).to have_bookmark_count_of(2)
user_menu.click_bookmark(bookmark_1)
expect(channel_page).to have_bookmarked_message(message_1)
user_menu.click_bookmark(bookmark_2)
expect(channel_page).to have_bookmarked_message(message_2)
end
end
context "when the user has a bookmark auto_delete_preference" do context "when the user has a bookmark auto_delete_preference" do
before do before do
current_user.user_option.update!( current_user.user_option.update!(

View File

@ -15,6 +15,12 @@ module PageObjects
self self
end end
def click_bookmarks_tab
click_link("user-menu-button-bookmarks")
has_css?("#quick-access-bookmarks")
self
end
def click_profile_tab def click_profile_tab
click_link("user-menu-button-profile") click_link("user-menu-button-profile")
has_css?("#quick-access-profile") has_css?("#quick-access-profile")
@ -27,6 +33,11 @@ module PageObjects
self self
end end
def click_bookmark(bookmark)
find("#quick-access-bookmarks .bookmark a[href='#{bookmark.bookmarkable.url}']").click
self
end
def sign_out def sign_out
open open
click_profile_tab click_profile_tab
@ -47,6 +58,10 @@ module PageObjects
def has_notification_count_of?(count) def has_notification_count_of?(count)
page.has_css?(".user-menu li.notification", count: count) page.has_css?(".user-menu li.notification", count: count)
end end
def has_bookmark_count_of?(count)
page.has_css?(".user-menu #quick-access-bookmarks li.bookmark", count: count)
end
end end
end end
end end