From 738e66afa6231390f52679fe8b343478643f5684 Mon Sep 17 00:00:00 2001
From: Emin Kocan
Date: Wed, 30 Oct 2024 22:00:59 +0100
Subject: [PATCH] Add status filter to user's note page
---
app/controllers/notes_controller.rb | 3 +-
app/views/notes/index.html.erb | 14 ++++++++++
config/locales/en.yml | 5 ++++
test/controllers/notes_controller_test.rb | 34 +++++++++++++++++++++++
4 files changed, 55 insertions(+), 1 deletion(-)
diff --git a/app/controllers/notes_controller.rb b/app/controllers/notes_controller.rb
index 26d27692e5..c47a3abfb9 100644
--- a/app/controllers/notes_controller.rb
+++ b/app/controllers/notes_controller.rb
@@ -18,12 +18,13 @@ class NotesController < ApplicationController
def index
param! :page, Integer, :min => 1
- @params = params.permit(:display_name)
+ @params = params.permit(:display_name, :status)
@title = t ".title", :user => @user.display_name
@page = (params[:page] || 1).to_i
@page_size = 10
@notes = @user.notes
@notes = @notes.visible unless current_user&.moderator?
+ @notes = @notes.where(:status => params[:status]) unless params[:status] == "all" || params[:status].blank?
@notes = @notes.order("updated_at DESC, id").distinct.offset((@page - 1) * @page_size).limit(@page_size).preload(:comments => :author)
render :layout => "site"
diff --git a/app/views/notes/index.html.erb b/app/views/notes/index.html.erb
index d5efe0d79c..c883126658 100644
--- a/app/views/notes/index.html.erb
+++ b/app/views/notes/index.html.erb
@@ -6,6 +6,20 @@
:commented => tag.span(t(".subheading_commented"), :class => "px-2 py-1 bg-body") %>
<% end %>
+<%= form_with :url => user_notes_path(@user), :method => :get, :data => { :turbo => true } do %>
+
+
+ <%= label_tag :status, t(".status") %>
+ <%= select_tag :status,
+ options_for_select([[t(".all"), "all"], [t(".open"), "open"], [t(".closed"), "closed"]], params[:status] || "all"),
+ :class => "form-select" %>
+
+
+ <%= submit_tag t(".apply"), :name => nil, :class => "btn btn-primary" %>
+
+
+<% end %>
+
<% if @notes.empty? %>
<%= t ".no_notes" %>
diff --git a/config/locales/en.yml b/config/locales/en.yml
index f68488c09c..3f2a4cb140 100644
--- a/config/locales/en.yml
+++ b/config/locales/en.yml
@@ -2966,6 +2966,11 @@ en:
description: "Description"
created_at: "Created at"
last_changed: "Last changed"
+ apply: "Apply"
+ all: "All"
+ open: "Open"
+ closed: "Closed"
+ status: "Status"
show:
title: "Note: %{id}"
description: "Description"
diff --git a/test/controllers/notes_controller_test.rb b/test/controllers/notes_controller_test.rb
index 4092ad7326..71dfa42bae 100644
--- a/test/controllers/notes_controller_test.rb
+++ b/test/controllers/notes_controller_test.rb
@@ -184,4 +184,38 @@ def test_new_note
assert_template "notes/new"
assert_select "#sidebar_content a[href='#{login_path(:referer => new_note_path)}']", :count => 0
end
+
+ def test_index_filter_by_status
+ user = create(:user)
+ other_user = create(:user)
+
+ open_note = create(:note, :status => "open")
+ create(:note_comment, :note => open_note, :author => user)
+
+ closed_note = create(:note, :status => "closed")
+ create(:note_comment, :note => closed_note, :author => user)
+
+ hidden_note = create(:note, :status => "hidden")
+ create(:note_comment, :note => hidden_note, :author => user)
+
+ commented_note = create(:note, :status => "open")
+ create(:note_comment, :note => commented_note, :author => other_user)
+ create(:note_comment, :note => commented_note, :author => user)
+
+ get user_notes_path(user, :status => "all")
+ assert_response :success
+ assert_select "table.note_list tbody tr", :count => 3
+
+ get user_notes_path(user, :status => "open")
+ assert_response :success
+ assert_select "table.note_list tbody tr", :count => 2
+
+ get user_notes_path(user, :status => "closed")
+ assert_response :success
+ assert_select "table.note_list tbody tr", :count => 1
+
+ get user_notes_path(user)
+ assert_response :success
+ assert_select "table.note_list tbody tr", :count => 3
+ end
end