mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 11:32:46 +08:00
FIX: Make subcategories page more like categories (#29240)
The subcategories page was not paginated and it was using the subcategory style from the category settings. The same page style should be used for categories and subcategories page.
This commit is contained in:
parent
23c486799f
commit
c1f078cacf
|
@ -36,6 +36,7 @@ const globalComponents = {
|
|||
};
|
||||
|
||||
export default class CategoriesDisplay extends Component {
|
||||
@service router;
|
||||
@service siteSettings;
|
||||
@service site;
|
||||
|
||||
|
@ -69,7 +70,10 @@ export default class CategoriesDisplay extends Component {
|
|||
}
|
||||
|
||||
get categoriesComponent() {
|
||||
if (this.args.parentCategory) {
|
||||
if (
|
||||
this.args.parentCategory &&
|
||||
this.router.currentRouteName === "discovery.category"
|
||||
) {
|
||||
return this.#componentForSubcategories;
|
||||
} else {
|
||||
return this.#globalComponent;
|
||||
|
|
|
@ -133,22 +133,15 @@ class CategoryList
|
|||
|
||||
def find_categories
|
||||
query = Category.includes(CategoryList.included_associations).secured(@guardian)
|
||||
|
||||
query =
|
||||
query.where(
|
||||
"categories.parent_category_id = ?",
|
||||
@options[:parent_category_id].to_i,
|
||||
) if @options[:parent_category_id].present?
|
||||
|
||||
query = self.class.order_categories(query)
|
||||
|
||||
if @options[:parent_category_id].present? || @guardian.can_lazy_load_categories?
|
||||
query = query.where(parent_category_id: @options[:parent_category_id])
|
||||
end
|
||||
|
||||
page = [1, @options[:page].to_i].max
|
||||
if @guardian.can_lazy_load_categories? && @options[:parent_category_id].blank?
|
||||
query =
|
||||
query
|
||||
.where(parent_category_id: nil)
|
||||
.limit(CATEGORIES_PER_PAGE)
|
||||
.offset((page - 1) * CATEGORIES_PER_PAGE)
|
||||
if @guardian.can_lazy_load_categories?
|
||||
query = query.limit(CATEGORIES_PER_PAGE).offset((page - 1) * CATEGORIES_PER_PAGE)
|
||||
elsif page > 1
|
||||
# Pagination is supported only when lazy load is enabled. If it is not,
|
||||
# everything is returned on page 1.
|
||||
|
|
Loading…
Reference in New Issue
Block a user