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:
parent
b39c30045b
commit
fd1220af69
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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!(
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue