FIX: ensures edited message is correctly re-decorated (#20637)
This commit is contained in:
parent
60ce3d24fa
commit
ada89d6124
|
@ -632,7 +632,7 @@ export default class ChatLivePane extends Component {
|
||||||
handleRefreshMessage(data) {
|
handleRefreshMessage(data) {
|
||||||
const message = this.args.channel.findMessage(data.chat_message.id);
|
const message = this.args.channel.findMessage(data.chat_message.id);
|
||||||
if (message) {
|
if (message) {
|
||||||
message.version = message.version + 1;
|
message.incrementVersion();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -644,6 +644,7 @@ export default class ChatLivePane extends Component {
|
||||||
message.excerpt = data.chat_message.excerpt;
|
message.excerpt = data.chat_message.excerpt;
|
||||||
message.uploads = cloneJSON(data.chat_message.uploads || []);
|
message.uploads = cloneJSON(data.chat_message.uploads || []);
|
||||||
message.edited = true;
|
message.edited = true;
|
||||||
|
message.incrementVersion();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -123,6 +123,10 @@ export default class ChatMessage {
|
||||||
return this.channel?.messages?.objectAt?.(this.index + 1);
|
return this.channel?.messages?.objectAt?.(this.index + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
incrementVersion() {
|
||||||
|
this.version++;
|
||||||
|
}
|
||||||
|
|
||||||
react(emoji, action, actor, currentUserId) {
|
react(emoji, action, actor, currentUserId) {
|
||||||
const selfReaction = actor.id === currentUserId;
|
const selfReaction = actor.id === currentUserId;
|
||||||
const existingReaction = this.reactions.find(
|
const existingReaction = this.reactions.find(
|
||||||
|
|
|
@ -5,18 +5,21 @@ RSpec.describe "Edited message", type: :system, js: true do
|
||||||
let(:channel_page) { PageObjects::Pages::ChatChannel.new }
|
let(:channel_page) { PageObjects::Pages::ChatChannel.new }
|
||||||
|
|
||||||
fab!(:current_user) { Fabricate(:user) }
|
fab!(:current_user) { Fabricate(:user) }
|
||||||
fab!(:editing_user) { Fabricate(:user) }
|
|
||||||
fab!(:channel_1) { Fabricate(:category_channel) }
|
fab!(:channel_1) { Fabricate(:category_channel) }
|
||||||
fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1, user: editing_user) }
|
|
||||||
|
|
||||||
before do
|
before do
|
||||||
chat_system_bootstrap
|
chat_system_bootstrap
|
||||||
channel_1.add(current_user)
|
channel_1.add(current_user)
|
||||||
channel_1.add(editing_user)
|
|
||||||
sign_in(current_user)
|
sign_in(current_user)
|
||||||
end
|
end
|
||||||
|
|
||||||
context "when editing message" do
|
context "when editing message" do
|
||||||
|
context "with multiple users in the channel" do
|
||||||
|
fab!(:editing_user) { Fabricate(:user) }
|
||||||
|
fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1, user: editing_user) }
|
||||||
|
|
||||||
|
before { channel_1.add(editing_user) }
|
||||||
|
|
||||||
it "shows as edited for all users" do
|
it "shows as edited for all users" do
|
||||||
chat_page.visit_channel(channel_1)
|
chat_page.visit_channel(channel_1)
|
||||||
|
|
||||||
|
@ -30,4 +33,13 @@ RSpec.describe "Edited message", type: :system, js: true do
|
||||||
expect(page).to have_content(I18n.t("js.chat.edited"))
|
expect(page).to have_content(I18n.t("js.chat.edited"))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "runs decorators on the edited message" do
|
||||||
|
message_1 = Fabricate(:chat_message, chat_channel: channel_1, user: current_user)
|
||||||
|
chat_page.visit_channel(channel_1)
|
||||||
|
|
||||||
|
channel_page.edit_message(message_1, '[date=2025-03-10 timezone="Europe/Paris"]')
|
||||||
|
expect(page).to have_css(".cooked-date")
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue