FEATURE: add new setting to select view for category page on mobile (#30519)

This commit is contained in:
Arpit Jalan 2025-01-06 09:25:25 +05:30 committed by GitHub
parent 02bebb7e91
commit d400fe6623
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 71 additions and 10 deletions

View File

@ -13,11 +13,6 @@ import PluginOutlet from "discourse/components/plugin-outlet";
import SubcategoriesWithFeaturedTopics from "discourse/components/subcategories-with-featured-topics"; import SubcategoriesWithFeaturedTopics from "discourse/components/subcategories-with-featured-topics";
import { MAX_UNOPTIMIZED_CATEGORIES } from "discourse/lib/constants"; import { MAX_UNOPTIMIZED_CATEGORIES } from "discourse/lib/constants";
const mobileCompatibleViews = [
"categories_with_featured_topics",
"subcategories_with_featured_topics",
];
const subcategoryComponents = { const subcategoryComponents = {
boxes_with_featured_topics: CategoriesBoxesWithTopics, boxes_with_featured_topics: CategoriesBoxesWithTopics,
boxes: CategoriesBoxes, boxes: CategoriesBoxes,
@ -57,8 +52,8 @@ export default class CategoriesDisplay extends Component {
get style() { get style() {
let style = this.siteSettings.desktop_category_page_style; let style = this.siteSettings.desktop_category_page_style;
if (this.site.mobileView && !mobileCompatibleViews.includes(style)) { if (this.site.mobileView) {
style = mobileCompatibleViews[0]; style = this.siteSettings.mobile_category_page_style;
} }
if (this.site.categories.length > MAX_UNOPTIMIZED_CATEGORIES) { if (this.site.categories.length > MAX_UNOPTIMIZED_CATEGORIES) {
style = "categories_only"; style = "categories_only";

View File

@ -107,7 +107,7 @@ acceptance(
function (needs) { function (needs) {
needs.mobileView(); needs.mobileView();
needs.settings({ needs.settings({
desktop_category_page_style: "subcategories_with_featured_topics", mobile_category_page_style: "subcategories_with_featured_topics",
}); });
test("basic functionality", async function (assert) { test("basic functionality", async function (assert) {
@ -127,6 +127,30 @@ acceptance(
} }
); );
acceptance(
"Categories - 'categories_boxes_with_topics' (mobile)",
function (needs) {
needs.mobileView();
needs.settings({
mobile_category_page_style: "categories_boxes_with_topics",
});
test("basic functionality", async function (assert) {
await visit("/categories");
assert
.dom(
"div.category-box-inner .category-box-heading a.parent-box-link[href='/c/dev/7']"
)
.exists("shows boxes for top-level category");
assert
.dom(
"div.category-box-inner .featured-topics li[data-topic-id='11994']"
)
.exists("shows featured topics in boxes");
});
}
);
acceptance("Categories - preloadStore handling", function () { acceptance("Categories - preloadStore handling", function () {
const styles = [ const styles = [
"categories_only", "categories_only",

View File

@ -621,15 +621,19 @@ class CategoriesController < ApplicationController
end end
include_topics = include_topics =
view_context.mobile_view? || params[:include_topics] || params[:include_topics] ||
(parent_category && parent_category.subcategory_list_includes_topics?) || (parent_category && parent_category.subcategory_list_includes_topics?) ||
SiteSetting.desktop_category_page_style == "categories_with_featured_topics" || SiteSetting.desktop_category_page_style == "categories_with_featured_topics" ||
SiteSetting.desktop_category_page_style == "subcategories_with_featured_topics" || SiteSetting.desktop_category_page_style == "subcategories_with_featured_topics" ||
SiteSetting.desktop_category_page_style == "categories_boxes_with_topics" || SiteSetting.desktop_category_page_style == "categories_boxes_with_topics" ||
SiteSetting.desktop_category_page_style == "categories_with_top_topics" SiteSetting.desktop_category_page_style == "categories_with_top_topics" ||
SiteSetting.mobile_category_page_style == "categories_with_featured_topics" ||
SiteSetting.mobile_category_page_style == "categories_boxes_with_topics" ||
SiteSetting.mobile_category_page_style == "subcategories_with_featured_topics"
include_subcategories = include_subcategories =
SiteSetting.desktop_category_page_style == "subcategories_with_featured_topics" || SiteSetting.desktop_category_page_style == "subcategories_with_featured_topics" ||
SiteSetting.mobile_category_page_style == "subcategories_with_featured_topics" ||
params[:include_subcategories] == "true" params[:include_subcategories] == "true"
category_options = { category_options = {

View File

@ -0,0 +1,32 @@
# frozen_string_literal: true
require "enum_site_setting"
class MobileCategoryPageStyle < EnumSiteSetting
def self.valid_value?(val)
values.any? { |v| v[:value].to_s == val.to_s }
end
def self.values
@values ||= [
{ name: "category_page_style.categories_only", value: "categories_only" },
{
name: "category_page_style.categories_with_featured_topics",
value: "categories_with_featured_topics",
},
{ name: "category_page_style.categories_boxes", value: "categories_boxes" },
{
name: "category_page_style.categories_boxes_with_topics",
value: "categories_boxes_with_topics",
},
{
name: "category_page_style.subcategories_with_featured_topics",
value: "subcategories_with_featured_topics",
},
]
end
def self.translate_names?
true
end
end

View File

@ -2237,6 +2237,7 @@ en:
min_title_similar_length: "The minimum length of a title before it will be checked for similar topics." min_title_similar_length: "The minimum length of a title before it will be checked for similar topics."
desktop_category_page_style: "This setting determines the visual layout of the /categories page on desktop. It includes options such as displaying subcategories with featured topics, showing the latest topics, or presenting top topics. The chosen style will influence how users interact and navigate through categories on the site." desktop_category_page_style: "This setting determines the visual layout of the /categories page on desktop. It includes options such as displaying subcategories with featured topics, showing the latest topics, or presenting top topics. The chosen style will influence how users interact and navigate through categories on the site."
mobile_category_page_style: "This setting determines the visual layout of the /categories page on mobile."
category_colors: "A list of hexadecimal color values allowed for categories." category_colors: "A list of hexadecimal color values allowed for categories."
default_dark_mode_color_scheme_id: "The color palette used when in dark mode." default_dark_mode_color_scheme_id: "The color palette used when in dark mode."
dark_mode_none: "None" dark_mode_none: "None"
@ -3017,6 +3018,7 @@ en:
delete_user_max_post_age: "" delete_user_max_post_age: ""
delete_user_self_max_post_count: "" delete_user_self_max_post_count: ""
desktop_category_page_style: "" desktop_category_page_style: ""
mobile_category_page_style: ""
detailed_404: "" detailed_404: ""
detect_custom_avatars: "" detect_custom_avatars: ""
digest_logo: "" digest_logo: ""

View File

@ -283,6 +283,10 @@ basic:
client: true client: true
enum: "CategoryPageStyle" enum: "CategoryPageStyle"
default: "categories_and_latest_topics" default: "categories_and_latest_topics"
mobile_category_page_style:
client: true
enum: "MobileCategoryPageStyle"
default: "categories_with_featured_topics"
category_colors: category_colors:
client: true client: true
type: list type: list