diff options
Diffstat (limited to 'app/models/page.rb')
| -rw-r--r-- | app/models/page.rb | 51 |
1 files changed, 50 insertions, 1 deletions
diff --git a/app/models/page.rb b/app/models/page.rb index 0fcb4a8..fee20a8 100644 --- a/app/models/page.rb +++ b/app/models/page.rb | |||
| @@ -1,7 +1,56 @@ | |||
| 1 | class Page < ActiveRecord::Base | 1 | class Page < ActiveRecord::Base |
| 2 | 2 | ||
| 3 | belongs_to :node | 3 | belongs_to :node |
| 4 | has_and_belongs_to_many :flags | ||
| 4 | 5 | ||
| 5 | acts_as_list :column => :revision, :scope => :node_id | 6 | acts_as_list :column => :revision, :scope => :node_id |
| 6 | 7 | ||
| 7 | end | 8 | # Alternativ Queries with one or two inner joins. Loading the Flags themselves |
| 9 | # would be another query. Could be faster on larger data sets. | ||
| 10 | # | ||
| 11 | # Single Join: | ||
| 12 | # | ||
| 13 | # Page.find( | ||
| 14 | # :all, | ||
| 15 | # :joins => 'JOIN flags_pages on pages.id = flags_pages.page_id', | ||
| 16 | # :include => :flags, | ||
| 17 | # :conditions => ['flags_pages.flag_id IN (?)', [1,2]] | ||
| 18 | # ) | ||
| 19 | # Two inner joins: | ||
| 20 | # | ||
| 21 | # Page.find( | ||
| 22 | # :all, | ||
| 23 | # :joins => :flags_pages, | ||
| 24 | # :conditions => ['flags_pages.flag_id IN (?)', [1,2]] | ||
| 25 | # ) | ||
| 26 | named_scope :with_flags, lambda {|flag_names| | ||
| 27 | if (flags = Flag.find_all_by_name(flag_names)).empty? | ||
| 28 | {} | ||
| 29 | else | ||
| 30 | {:include => :flags, :conditions => ['flags_pages.flag_id IN (?)', flags.map(&:id)] } | ||
| 31 | end | ||
| 32 | } | ||
| 33 | |||
| 34 | # <aggregate | ||
| 35 | # flags="updates pressemitteilungen" | ||
| 36 | # limit="20" | ||
| 37 | # order_by="published_at" | ||
| 38 | # order_direction="DESC" | ||
| 39 | # /> | ||
| 40 | def self.aggregate options | ||
| 41 | |||
| 42 | defaults = { | ||
| 43 | :flags => "", | ||
| 44 | :limit => 20, | ||
| 45 | :order_by => "id", | ||
| 46 | :order_direction => "ASC" | ||
| 47 | } | ||
| 48 | |||
| 49 | options = defaults.merge options | ||
| 50 | |||
| 51 | pages = Page.with_flags(options[:flags].split(/\s/)).all( | ||
| 52 | :limit => options[:limit], | ||
| 53 | :order => "#{options[:order_by]} #{options[:order_direction]}" | ||
| 54 | ) | ||
| 55 | end | ||
| 56 | end \ No newline at end of file | ||
