Search code examples
ruby-on-railsruby-on-rails-pluginshas-and-belongs-to-manyacts-as-list

acts_as_list with has_and_belongs_to_many relationship


I've found an old plugin called acts_as_habtm_list - but it's for Rails 1.0.0.

Is this functionality built in acts_as_list now? I can't seem to find any information on it.

Basically, I have an artists_events table - no model. The relationship is handled through those two models specifying :has_and_belongs_to_many

How can I specify order in this situation?


Solution

  • I'm assuming that you have two models - Artist and Event.

    You want to have an habtm relationship between them and you want to be able to define an order of events for each artist.

    Here's my solution. I'm writing this code from my head, but similar solution works in my case. I'm pretty sure there is a room for improvement.

    I'm using rails acts_as_list plugin.

    That's how I would define models:

    class Artist < ActiveRecord::Base
      has_many :artist_events
      has_many :events, :through => :artist_events, :order => 'artist_events.position'
    end
    
    class Event < ActiveRecord::Base
      has_many :artist_events
      has_many :artists, :through => :artist_events, :order => 'artist_events.position'
    end
    
    class ArtistEvent < ActiveRecord::Base
      default_scope :order => 'position'
      belongs_to :artist
      belongs_to :event
      acts_as_list :scope => :artist
    end
    

    As you see you need an additional model ArtistEvent, joining the other two. The artist_events table should have two foreign ids and additional column - position.

    Now you can use acts_as_list methods (on ArtistEvent model, unfortunately) but something like

    Artist.find(:id).events

    should give you a list of events belonging to specific artist in correct order.