Sha256: ce49db025761169274c6c973859396d513764d81f1104334bae446ec8bf906e5
Contents?: true
Size: 1.92 KB
Versions: 1
Compression:
Stored size: 1.92 KB
Contents
[data:image/s3,"s3://crabby-images/87610/876104be46513e2934439ae8cb01983c1abbb650" alt="Build Status"](http://travis-ci.org/pyromaniac/mongoid_orderable) # What? Mongoid::Orderable is a ordered list implementation for your mongoid models. # Why? * It uses native mongo batch increment feature * It supports mutators api * It correctly assigns the position while moving document between scopes * It supports mongoid 2, 3 and 4 # How? ``` gem 'mongoid_orderable' ``` Gem has the same api as others. Just include Mongoid::Orderable into your model and call `orderable` method. ``` class Item include Mongoid::Document include Mongoid::Orderable # belongs_to :group # belongs_to :drawer, class_name: "Office::Drawer", # foreign_key: "legacy_drawer_key_id" # orderable # orderable scope: :group, column: :pos # orderable scope: :drawer, column: :pos # resolves scope foreign key from relation # orderable scope: 'drawer', column: :pos # but if you pass a string - it will use it as is, as the column name for scope # orderable scope: lambda { |document| where(group_id: document.group_id) } # orderable index: false # this one if you want specify indexes manually # orderable base: 0 # count position from zero as the top-most value (1 is the default value) end ``` # Usage ``` item.move_to 2 # just change position item.move_to! 2 # and save item.move_to = 2 # assignable method # symbol position item.move_to :top item.move_to :bottom item.move_to :higher item.move_to :lower # generated methods item.move_to_top item.move_to_bottom item.move_higher item.move_lower item.next_items # return a collection of items higher on the list item.previous_items # return a collection of items lower on the list item.next_item # returns the next item in the list item.previous_item # returns the previous item in the list ``` # Contributing Fork && Patch && Spec && Push && Pull request. # License Mongoid::Orderable is released under the MIT license.
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
mongoid_orderable-4.1.0 | README.md |