mirror of
https://github.com/we-promise/sure.git
synced 2026-04-23 22:14:08 +00:00
Include subcategories in transaction search filters (#401)
* Initial plan * Fix subcategory filtering in transaction search Co-authored-by: jjmata <187772+jjmata@users.noreply.github.com> * Address code review: scope category lookup to family for security Co-authored-by: jjmata <187772+jjmata@users.noreply.github.com> * Make sure parent categories are not NULL. --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: jjmata <187772+jjmata@users.noreply.github.com> Co-authored-by: Juan José Mata <juanjo.mata@gmail.com>
This commit is contained in:
@@ -408,9 +408,13 @@ class ReportsController < ApplicationController
|
||||
end
|
||||
|
||||
def apply_transaction_filters(transactions)
|
||||
# Filter by category
|
||||
# Filter by category (including subcategories)
|
||||
if params[:filter_category_id].present?
|
||||
transactions = transactions.where(category_id: params[:filter_category_id])
|
||||
category_id = params[:filter_category_id]
|
||||
# Scope to family's categories to prevent cross-family data access
|
||||
subcategory_ids = Current.family.categories.where(parent_id: category_id).pluck(:id)
|
||||
all_category_ids = [ category_id ] + subcategory_ids
|
||||
transactions = transactions.where(category_id: all_category_ids)
|
||||
end
|
||||
|
||||
# Filter by account
|
||||
|
||||
Reference in New Issue
Block a user