0.0
Low commit activity in last 3 years
No release in over a year
Arrangeable provides an organized and seamless way to sort your ActiveRecord objects by different attributes.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

~> 2.0
~> 13.0
~> 3.0

Runtime

 Project Readme

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.