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 26d27692e..c47a3abfb 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 d5efe0d79..c88312665 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 f68488c09..3f2a4cb14 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 4092ad732..71dfa42ba 100644 --- a/test/controllers/notes_controller_test.rb +++ b/test/controllers/notes_controller_test.rb @@ -184,4 +184,38 @@ class NotesControllerTest < ActionDispatch::IntegrationTest 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 -- 2.39.5