profile_list_block.rb
1.51 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
class ProfileListBlock < Block
  settings_items :limit, :default => 6
  def self.description
    _('A block that displays random profiles')
  end
  # Override this method to make the block list specific types of profiles
  # instead of anyone.
  #
  # In this class this method just returns <tt>Profile</tt> (the class). In
  # subclasses you could return <tt>Person</tt>, for instance, if you only want
  # to list people, or <tt>Organization</tt>, if you want organizations only.
  #
  # You don't need to return only classes. You can for instance return an
  # association array from a has_many ActiveRecord association, for example.
  # Actually the only requirement for the object returned by this method is to
  # have a <tt>find</tt> method that accepts the same interface as the
  # ActiveRecord::Base's find method .
  def profile_finder
    @profile_finder ||= ProfileListBlock::Finder.new(self)
  end
  # Default finder. Finds the most recently added profiles.
  class Finder
    def initialize(block)
      @block = block
    end
    attr_reader :block
    def find
      Profile.find(:all, :limit => block.limit, :order => 'created_at desc')
    end
  end
  def profiles
    profile_finder.find
  end
  # the title of the block. Probably will be overriden in subclasses.
  def title
    _('People and Groups')
  end
  def content
    profiles = self.profiles
    title = self.title
    lambda do
      block_title(title) +
      profiles.map {|item| content_tag('div', profile_image_link(item)) }.join("\n")
    end
  end
end