UX: display correct replies count in embedded comments view. (#14175)

Previosuly, the reply count included the "small_action" posts too. It also caused the broken embed HTML issue.
This commit is contained in:
Vinoth Kannan 2021-08-30 10:37:53 +05:30 committed by GitHub
parent 55b22af3b6
commit 465774cf2c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 19 additions and 11 deletions

View File

@ -96,17 +96,13 @@ class EmbedController < ApplicationController
exclude_first: true, exclude_first: true,
exclude_deleted_users: true, exclude_deleted_users: true,
exclude_hidden: true) exclude_hidden: true)
raise Discourse::NotFound if @topic_view.blank?
@second_post_url = "#{@topic_view.topic.url}/2" if @topic_view
@posts_left = 0 @posts_left = 0
if @topic_view && @topic_view.posts.size == SiteSetting.embed_post_limit @second_post_url = "#{@topic_view.topic.url}/2"
@posts_left = @topic_view.topic.posts_count - SiteSetting.embed_post_limit - 1 @reply_count = @topic_view.filtered_posts.count - 1
end
if @topic_view
@reply_count = @topic_view.topic.posts_count - 1
@reply_count = 0 if @reply_count < 0 @reply_count = 0 if @reply_count < 0
end @posts_left = @reply_count - SiteSetting.embed_post_limit if @reply_count > SiteSetting.embed_post_limit
elsif embed_url.present? elsif embed_url.present?
Jobs.enqueue(:retrieve_topic, Jobs.enqueue(:retrieve_topic,
user_id: current_user.try(:id), user_id: current_user.try(:id),

View File

@ -1,7 +1,7 @@
<header class='discourse' data-embed-state='loaded'> <header class='discourse' data-embed-state='loaded'>
<% if @topic_view.topic.posts_count < 2 %> <% if @reply_count < 1 %>
<%= link_to(I18n.t('embed.start_discussion'), @topic_view.topic.url, class: 'button', target: '_blank') %> <%= link_to(I18n.t('embed.start_discussion'), @topic_view.topic.url, class: 'button', target: '_blank') %>
<% elsif @topic_view.topic.posts_count > 10 %> <% elsif @reply_count >= 10 %>
<%= link_to(I18n.t('embed.continue'), @second_post_url, class: 'button', target: '_blank') %> <%= link_to(I18n.t('embed.continue'), @second_post_url, class: 'button', target: '_blank') %>
<% end %> <% end %>
<span class='replies'><%= I18n.t('embed.replies', count: @reply_count) %></span> <span class='replies'><%= I18n.t('embed.replies', count: @reply_count) %></span>

View File

@ -166,3 +166,7 @@ end
Fabricator(:whisper, from: :post) do Fabricator(:whisper, from: :post) do
post_type Post.types[:whisper] post_type Post.types[:whisper]
end end
Fabricator(:small_action, from: :post) do
post_type Post.types[:small_action]
end

View File

@ -229,6 +229,14 @@ describe EmbedController do
expect(response.body).to match(I18n.t('embed.continue')) expect(response.body).to match(I18n.t('embed.continue'))
expect(response.body).to match(post.cooked) expect(response.body).to match(post.cooked)
expect(response.body).to match("<span class='replies'>1 reply</span>")
small_action = Fabricate(:small_action, topic: topic_embed.topic)
get '/embed/comments', params: { embed_url: embed_url }, headers: headers
expect(response.body).not_to match("post-#{small_action.id}")
expect(response.body).to match("<span class='replies'>1 reply</span>")
end end
it "provides the topic retriever with the discourse username when provided" do it "provides the topic retriever with the discourse username when provided" do