Show topic count, based on the defaultCategoryLinkRenderer (#7)

This commit is contained in:
Renato Atilio 2020-09-16 09:48:02 -03:00 committed by GitHub
parent 38781436cb
commit 0d5750f791
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 18 additions and 1 deletions

View File

@ -6,6 +6,7 @@ import { isRTL } from "discourse/lib/text-direction";
import { h } from "virtual-dom"; import { h } from "virtual-dom";
import getURL from "discourse-common/lib/get-url"; import getURL from "discourse-common/lib/get-url";
import categoryTitleLink from "discourse/components/category-title-link"; import categoryTitleLink from "discourse/components/category-title-link";
import I18n from "I18n";
export default { export default {
name: "category-icons", name: "category-icons",
@ -46,6 +47,13 @@ export default {
} }
} }
function buildTopicCount(count) {
return `<span class="topic-count" aria-label="${I18n.t(
"category_row.topic_count",
{ count }
)}">&times; ${count}</span>`;
}
function categoryIconsRenderer(category, opts) { function categoryIconsRenderer(category, opts) {
let siteSettings = helperContext().siteSettings; let siteSettings = helperContext().siteSettings;
let description = get(category, "description_text"); let description = get(category, "description_text");
@ -117,6 +125,10 @@ export default {
} }
html += `<span class="category-name" ${categoryDir}>${categoryName}</span></span>`; html += `<span class="category-name" ${categoryDir}>${categoryName}</span></span>`;
if (opts.topicCount && categoryStyle !== "box") {
html += buildTopicCount(opts.topicCount);
}
if (href) { if (href) {
href = ` href="${href}" `; href = ` href="${href}" `;
} }
@ -124,7 +136,12 @@ export default {
extraClasses = categoryStyle extraClasses = categoryStyle
? categoryStyle + extraClasses ? categoryStyle + extraClasses
: extraClasses; : extraClasses;
return `<${tagName} class="badge-wrapper ${extraClasses}" ${href}>${html}</${tagName}>`;
let afterBadgeWrapper = "";
if (opts.topicCount && categoryStyle === "box") {
afterBadgeWrapper += buildTopicCount(opts.topicCount);
}
return `<${tagName} class="badge-wrapper ${extraClasses}" ${href}>${html}</${tagName}>${afterBadgeWrapper}`;
} }
api.replaceCategoryLinkRenderer(categoryIconsRenderer); api.replaceCategoryLinkRenderer(categoryIconsRenderer);