Question

is there any way to use one model scopes as part of another model scope?

Example

class DocumentVersion < ActiveRecord::Base
  belongs_to :document
  scope :are_latest, lambda{ where(latest: true)}
end

class Document < ActiveRecord::Base
  has_many :document_versions
  scope :are_latest, lambda { ...something... } # I want something that will get documents that have documnet_versions that are_latest

  # I know I can do this 
  scope :are_latest,   lambda{ joins(:document_versions).where('document_versions.latest = true') }  # this works well

  # but I would like to keep that condition its own model
  scope :are_latest, lambda { joins(:document_versions).are_latest } # this wont obviously work, but something like that 

end
Was it helpful?

Solution

Yes you can use merge to combine scopes together.

class Document < ActiveRecord::Base
  has_many :document_versions

  scope :are_latest, lambda { joins(:document_versions).merge(DocumentVersion.are_latest) }
end
Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top