Arrangeable
Arrangeable provides an organized and seamless way to sort your ActiveRecord objects by different attributes.
Installation
Add this line to your application's Gemfile:
gem 'arrangeable', '~> 0.1.5'
And then execute:
$ bundle
Or install it yourself as:
$ gem install arrangeable
Usage
Include Arrangeable inside ApplicationRecord or directly inside your ActiveRecord model and override the arrangeable_fields
method for each model to whitelist the fields you want to use for sorting:
class User < ApplicationRecord
include Arrangeable
concerning :Arranging do
class_methods do
def arrangeable_fields
%w[id first_name last_name]
end
end
end
end
Failing to override arrangeable_fields
will raise a NotImplementedError
.
Now sort your objects by calling arrange
on your model and passing a comma-separated order string. Prepend a negative sign -
before a key to order by that key descendingly:
@users = User.all
order_string = 'first_name,-id'
@users = @users.arrange(order_string)
The previous example will generate the following SQL order clause: ORDER BY first_name ASC, id DESC
.
Note that id
can always be used for sorting regardless of whether you whitelist it or not. Any non whitelisted sorting keys will be ignored.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/umar221b/arrangeable.
License
The gem is available as open source under the terms of the MIT License.