Sha256: 78dc9985543141424fe04b142c39a60c393fcf4798545eee992fbfd0f847576f
Contents?: true
Size: 1.64 KB
Versions: 13
Compression:
Stored size: 1.64 KB
Contents
=begin rdoc A note is a 'dated' element. It is typically used for blog entries or/and calendar events. === dates On top of the Node's dates (+created_at+, +updated_at+, +publish_from+), a note uses the following: log_at:: used to sort/display blog entries event_at:: used in calendars These two dates enable you to announce an event in the blog list a couple of days before it actually occurs (event_at). All dates are stored internally as 'utc' and are converted to/from the visitor's current timezone. === links Default links for Notes are: calendars:: make this note appear in the given calendar (there is one calendar per project). By default the note is not included in its project's calendar. projects:: make this note appear in the blog of the given project. A note always appear in its project. === subclasses === subclasses to implement before 1.0 Task:: manage things to be done (parent = Note = Todo). The parent provides the 'due date'. Letter:: like the name says... Request:: subclass of Todo. Manage user/client requests. Bug:: (the class we most need!). subclass of Request. Milestone:: special event used when choosing a Request/Bug's parent. =end class Note < Node class << self def select_classes list = subclasses.inject([]) do |list, k| next if k.to_s == 'Post' list << k.to_s list end.sort list.unshift 'Post' end end def export_keys h = super h[:dates].merge!('log_at' => log_at, 'event_at' => event_at) h end private def set_defaults super self[:log_at] ||= self[:event_at] || Time.now self[:event_at] ||= self[:log_at] end end
Version data entries
13 entries across 13 versions & 1 rubygems