FIX: simplify review community section link (#21907)
Before, the review button was shown in `primary section` when there were items to review. Otherwise, it was hidden in `more section`. Because we are allowing admins to customize community section and reorder link, it makes sense to simplify that logic and review link should follow admin's decision.
This commit is contained in:
parent
ce2bd96590
commit
658b310305
|
@ -22,8 +22,6 @@ import {
|
||||||
} from "discourse/lib/sidebar/custom-community-section-links";
|
} from "discourse/lib/sidebar/custom-community-section-links";
|
||||||
import showModal from "discourse/lib/show-modal";
|
import showModal from "discourse/lib/show-modal";
|
||||||
|
|
||||||
const LINKS_IN_BOTH_SEGMENTS = ["/review"];
|
|
||||||
|
|
||||||
const SPECIAL_LINKS_MAP = {
|
const SPECIAL_LINKS_MAP = {
|
||||||
"/latest": EverythingSectionLink,
|
"/latest": EverythingSectionLink,
|
||||||
"/new": EverythingSectionLink,
|
"/new": EverythingSectionLink,
|
||||||
|
@ -66,10 +64,7 @@ export default class CommunitySection {
|
||||||
.map((link) => this.#initializeSectionLink(link, { inMoreDrawer: true }));
|
.map((link) => this.#initializeSectionLink(link, { inMoreDrawer: true }));
|
||||||
|
|
||||||
this.links = this.section.links.reduce((filtered, link) => {
|
this.links = this.section.links.reduce((filtered, link) => {
|
||||||
if (
|
if (link.segment === "primary") {
|
||||||
link.segment === "primary" ||
|
|
||||||
LINKS_IN_BOTH_SEGMENTS.includes(link.value)
|
|
||||||
) {
|
|
||||||
const generatedLink = this.#generateLink(link);
|
const generatedLink = this.#generateLink(link);
|
||||||
|
|
||||||
if (generatedLink) {
|
if (generatedLink) {
|
||||||
|
@ -82,10 +77,7 @@ export default class CommunitySection {
|
||||||
|
|
||||||
this.moreLinks = this.section.links
|
this.moreLinks = this.section.links
|
||||||
.reduce((filtered, link) => {
|
.reduce((filtered, link) => {
|
||||||
if (
|
if (link.segment === "secondary") {
|
||||||
link.segment === "secondary" ||
|
|
||||||
LINKS_IN_BOTH_SEGMENTS.includes(link.value)
|
|
||||||
) {
|
|
||||||
const generatedLink = this.#generateLink(link, true);
|
const generatedLink = this.#generateLink(link, true);
|
||||||
|
|
||||||
if (generatedLink) {
|
if (generatedLink) {
|
||||||
|
|
|
@ -1,43 +1,9 @@
|
||||||
import I18n from "I18n";
|
import I18n from "I18n";
|
||||||
|
|
||||||
import { tracked } from "@glimmer/tracking";
|
|
||||||
|
|
||||||
import { bind } from "discourse-common/utils/decorators";
|
|
||||||
import BaseSectionLink from "discourse/lib/sidebar/base-community-section-link";
|
import BaseSectionLink from "discourse/lib/sidebar/base-community-section-link";
|
||||||
|
|
||||||
export default class ReviewSectionLink extends BaseSectionLink {
|
export default class ReviewSectionLink extends BaseSectionLink {
|
||||||
@tracked canDisplay;
|
get shouldDisplay() {
|
||||||
|
return !!this.currentUser?.can_review;
|
||||||
constructor() {
|
|
||||||
super(...arguments);
|
|
||||||
|
|
||||||
this._refreshCanDisplay();
|
|
||||||
|
|
||||||
this.appEvents?.on(
|
|
||||||
"user-reviewable-count:changed",
|
|
||||||
this._refreshCanDisplay
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
teardown() {
|
|
||||||
this.appEvents?.off(
|
|
||||||
"user-reviewable-count:changed",
|
|
||||||
this._refreshCanDisplay
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@bind
|
|
||||||
_refreshCanDisplay() {
|
|
||||||
if (!this.currentUser?.can_review) {
|
|
||||||
this.canDisplay = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this.inMoreDrawer) {
|
|
||||||
this.canDisplay = this.currentUser.reviewable_count < 1;
|
|
||||||
} else {
|
|
||||||
this.canDisplay = this.currentUser.reviewable_count > 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
get name() {
|
get name() {
|
||||||
|
@ -59,10 +25,6 @@ export default class ReviewSectionLink extends BaseSectionLink {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
get shouldDisplay() {
|
|
||||||
return this.canDisplay;
|
|
||||||
}
|
|
||||||
|
|
||||||
get badgeText() {
|
get badgeText() {
|
||||||
// force a tracker for reviewable_count by using .get to ensure badgeText
|
// force a tracker for reviewable_count by using .get to ensure badgeText
|
||||||
// rerenders when reviewable_count changes
|
// rerenders when reviewable_count changes
|
||||||
|
|
|
@ -197,7 +197,9 @@ describe "Custom sidebar sections", type: :system, js: true do
|
||||||
sign_in admin
|
sign_in admin
|
||||||
visit("/latest")
|
visit("/latest")
|
||||||
|
|
||||||
expect(sidebar.primary_section_icons("community")).to eq(%w[layer-group user wrench ellipsis-v])
|
expect(sidebar.primary_section_icons("community")).to eq(
|
||||||
|
%w[layer-group user flag wrench ellipsis-v],
|
||||||
|
)
|
||||||
|
|
||||||
sidebar.edit_custom_section("Community")
|
sidebar.edit_custom_section("Community")
|
||||||
section_modal.fill_link("Everything", "/latest", "paper-plane")
|
section_modal.fill_link("Everything", "/latest", "paper-plane")
|
||||||
|
@ -207,10 +209,10 @@ describe "Custom sidebar sections", type: :system, js: true do
|
||||||
|
|
||||||
expect(sidebar).to have_section("Edited community section")
|
expect(sidebar).to have_section("Edited community section")
|
||||||
expect(sidebar.primary_section_links("edited-community-section")).to eq(
|
expect(sidebar.primary_section_links("edited-community-section")).to eq(
|
||||||
["My Posts", "Everything", "Admin", "More"],
|
["My Posts", "Everything", "Review", "Admin", "More"],
|
||||||
)
|
)
|
||||||
expect(sidebar.primary_section_icons("edited-community-section")).to eq(
|
expect(sidebar.primary_section_icons("edited-community-section")).to eq(
|
||||||
%w[user paper-plane wrench ellipsis-v],
|
%w[user paper-plane flag wrench ellipsis-v],
|
||||||
)
|
)
|
||||||
|
|
||||||
sidebar.edit_custom_section("Edited community section")
|
sidebar.edit_custom_section("Edited community section")
|
||||||
|
@ -218,9 +220,11 @@ describe "Custom sidebar sections", type: :system, js: true do
|
||||||
|
|
||||||
expect(sidebar).to have_section("Community")
|
expect(sidebar).to have_section("Community")
|
||||||
expect(sidebar.primary_section_links("community")).to eq(
|
expect(sidebar.primary_section_links("community")).to eq(
|
||||||
["Everything", "My Posts", "Admin", "More"],
|
["Everything", "My Posts", "Review", "Admin", "More"],
|
||||||
|
)
|
||||||
|
expect(sidebar.primary_section_icons("community")).to eq(
|
||||||
|
%w[layer-group user flag wrench ellipsis-v],
|
||||||
)
|
)
|
||||||
expect(sidebar.primary_section_icons("community")).to eq(%w[layer-group user wrench ellipsis-v])
|
|
||||||
end
|
end
|
||||||
|
|
||||||
it "shows anonymous public sections" do
|
it "shows anonymous public sections" do
|
||||||
|
|
Loading…
Reference in New Issue