Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sweep: Pagination Missing on "Shop Summary" Merchant Table (βœ“ Sandbox Passed) #100

Closed
6 changes: 6 additions & 0 deletions app/controllers/shops_controller.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
class ShopsController < ApplicationController
def index
# Assuming Kaminari for pagination. Replace with will_paginate equivalent if necessary.
@shops = Shop.all.page(params[:page]).per(100)
end
end
30 changes: 30 additions & 0 deletions app/helpers/pagination_helper.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
module PaginationHelper
def custom_paginate_renderer(collection, options = {})
content_tag(:nav, class: "pagination-controls") do
previous_page_link(collection, options) + page_numbers(collection, options) + next_page_link(collection, options)
end
end

private

def link_to_previous_page(collection, options)
unless collection.first_page?
link_to 'Previous', url_for(page: collection.prev_page), class: options[:previous_class] || "prev-page"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[standard] <Style/StringLiterals> reported by reviewdog 🐢
Prefer double-quoted strings unless you need single quotes to avoid extra backslashes for escaping.

Suggested change
link_to 'Previous', url_for(page: collection.prev_page), class: options[:previous_class] || "prev-page"
link_to "Previous", url_for(page: collection.prev_page), class: options[:previous_class] || "prev-page"

Copy link
Author

@sweep-ai sweep-ai bot Feb 3, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

πŸš€ Wrote Changes

Done.

This is an automated message generated by Sweep AI.

end
end

def link_to_next_page(collection, options)
unless collection.last_page?
link_to 'Next', url_for(page: collection.next_page), class: options[:next_class] || "next-page"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[standard] <Style/StringLiterals> reported by reviewdog 🐢
Prefer double-quoted strings unless you need single quotes to avoid extra backslashes for escaping.

Suggested change
link_to 'Next', url_for(page: collection.next_page), class: options[:next_class] || "next-page"
link_to "Next", url_for(page: collection.next_page), class: options[:next_class] || "next-page"

end
end

def page_numbers(collection, options)
start_page = [collection.current_page - options[:page_range], 1].max
end_page = [collection.current_page + options[:page_range], collection.total_pages].min

(start_page..end_page).map do |page|
link_to page, url_for(page: page), class: ((page == collection.current_page ? options[:active_class] : options[:page_class]))
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[standard] <Style/TernaryParentheses> reported by reviewdog 🐢
Use parentheses for ternary expressions with complex conditions.

Suggested change
link_to page, url_for(page: page), class: ((page == collection.current_page ? options[:active_class] : options[:page_class]))
link_to page, url_for(page: page), class: (((page == collection.current_page ? options[:active_class] : options[:page_class]))

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[standard] <Style/TernaryParentheses> reported by reviewdog 🐢
Use parentheses for ternary expressions with complex conditions.

Suggested change
link_to page, url_for(page: page), class: ((page == collection.current_page ? options[:active_class] : options[:page_class]))
link_to page, url_for(page: page), class: ((((page == collection.current_page ? options[:active_class] : options[:page_class])))

Copy link
Author

@sweep-ai sweep-ai bot Feb 3, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

πŸš€ Wrote Changes

Done.

This is an automated message generated by Sweep AI.

end.join.html_safe
end
end
3 changes: 3 additions & 0 deletions app/views/shops/index.html.erb
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<%# Assuming the table of merchants is already implemented above this line %>

<%= paginate @shops %>
2 changes: 1 addition & 1 deletion config/routes.rb
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
resources :summarys, only: [] do
collection do
get :monthly, to: "summarys/monthly#index"
get :shop, to: "summarys/shop#index"
get "shops/index/(:page)", to: 'shops#index', as: "shops_index"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

[standard] <Style/StringLiterals> reported by reviewdog 🐢
Prefer double-quoted strings unless you need single quotes to avoid extra backslashes for escaping.

Suggested change
get "shops/index/(:page)", to: 'shops#index', as: "shops_index"
get "shops/index/(:page)", to: "shops#index", as: "shops_index"

end
end

Expand Down
Loading