Merge branch 'master' into openstreetbugs
[rails.git] / app / models / diary_entry.rb
1 class DiaryEntry < ActiveRecord::Base
2   belongs_to :user
3   belongs_to :language, :foreign_key => 'language_code'
4   
5   has_many :comments, :class_name => "DiaryComment",
6                       :include => :user,
7                       :order => "diary_comments.id"
8   has_many :visible_comments, :class_name => "DiaryComment",
9                               :include => :user,
10                               :conditions => {
11                                 :users => { :status => ["active", "confirmed" ] },
12                                 :visible => true
13                               },
14                               :order => "diary_comments.id"
15
16   scope :visible, where(:visible => true)
17
18   validates_presence_of :title, :body
19   validates_length_of :title, :within => 1..255
20   #validates_length_of :language, :within => 2..5, :allow_nil => false
21   validates_numericality_of :latitude, :allow_nil => true,
22                             :greater_than_or_equal_to => -90, :less_than_or_equal_to => 90
23   validates_numericality_of :longitude, :allow_nil => true,
24                             :greater_than_or_equal_to => -180, :less_than_or_equal_to => 180
25   validates_associated :language
26
27   attr_accessible :title, :body, :language_code, :latitude, :longitude
28
29   after_initialize :set_defaults
30
31   def body
32     RichText.new(read_attribute(:body_format), read_attribute(:body))
33   end
34
35 private
36
37   def set_defaults
38     self.body_format = "markdown" unless self.attribute_present?(:body_format)
39   end
40 end