Mercurial > hg > soundsoftware-site
comparison app/models/board.rb @ 1338:25603efa57b5
Merge from live branch
author | Chris Cannam |
---|---|
date | Thu, 20 Jun 2013 13:14:14 +0100 |
parents | 433d4f72a19b |
children | 622f24f53b42 |
comparison
equal
deleted
inserted
replaced
1209:1b1138f6f55e | 1338:25603efa57b5 |
---|---|
1 # Redmine - project management software | 1 # Redmine - project management software |
2 # Copyright (C) 2006-2011 Jean-Philippe Lang | 2 # Copyright (C) 2006-2012 Jean-Philippe Lang |
3 # | 3 # |
4 # This program is free software; you can redistribute it and/or | 4 # This program is free software; you can redistribute it and/or |
5 # modify it under the terms of the GNU General Public License | 5 # modify it under the terms of the GNU General Public License |
6 # as published by the Free Software Foundation; either version 2 | 6 # as published by the Free Software Foundation; either version 2 |
7 # of the License, or (at your option) any later version. | 7 # of the License, or (at your option) any later version. |
19 include Redmine::SafeAttributes | 19 include Redmine::SafeAttributes |
20 belongs_to :project | 20 belongs_to :project |
21 has_many :topics, :class_name => 'Message', :conditions => "#{Message.table_name}.parent_id IS NULL", :order => "#{Message.table_name}.created_on DESC" | 21 has_many :topics, :class_name => 'Message', :conditions => "#{Message.table_name}.parent_id IS NULL", :order => "#{Message.table_name}.created_on DESC" |
22 has_many :messages, :dependent => :destroy, :order => "#{Message.table_name}.created_on DESC" | 22 has_many :messages, :dependent => :destroy, :order => "#{Message.table_name}.created_on DESC" |
23 belongs_to :last_message, :class_name => 'Message', :foreign_key => :last_message_id | 23 belongs_to :last_message, :class_name => 'Message', :foreign_key => :last_message_id |
24 acts_as_list :scope => :project_id | 24 acts_as_tree :dependent => :nullify |
25 acts_as_list :scope => '(project_id = #{project_id} AND parent_id #{parent_id ? "= #{parent_id}" : "IS NULL"})' | |
25 acts_as_watchable | 26 acts_as_watchable |
26 | 27 |
27 validates_presence_of :name, :description | 28 validates_presence_of :name, :description |
28 validates_length_of :name, :maximum => 30 | 29 validates_length_of :name, :maximum => 30 |
29 validates_length_of :description, :maximum => 255 | 30 validates_length_of :description, :maximum => 255 |
31 validate :validate_board | |
30 | 32 |
31 named_scope :visible, lambda {|*args| { :include => :project, | 33 scope :visible, lambda {|*args| { :include => :project, |
32 :conditions => Project.allowed_to_condition(args.shift || User.current, :view_messages, *args) } } | 34 :conditions => Project.allowed_to_condition(args.shift || User.current, :view_messages, *args) } } |
33 | 35 |
34 safe_attributes 'name', 'description', 'move_to' | 36 safe_attributes 'name', 'description', 'parent_id', 'move_to' |
35 | 37 |
36 def visible?(user=User.current) | 38 def visible?(user=User.current) |
37 !user.nil? && user.allowed_to?(:view_messages, project) | 39 !user.nil? && user.allowed_to?(:view_messages, project) |
38 end | 40 end |
39 | 41 |
42 def reload(*args) | |
43 @valid_parents = nil | |
44 super | |
45 end | |
46 | |
40 def to_s | 47 def to_s |
41 name | 48 name |
49 end | |
50 | |
51 def valid_parents | |
52 @valid_parents ||= project.boards - self_and_descendants | |
42 end | 53 end |
43 | 54 |
44 def reset_counters! | 55 def reset_counters! |
45 self.class.reset_counters!(id) | 56 self.class.reset_counters!(id) |
46 end | 57 end |
51 update_all("topics_count = (SELECT COUNT(*) FROM #{Message.table_name} WHERE board_id=#{board_id} AND parent_id IS NULL)," + | 62 update_all("topics_count = (SELECT COUNT(*) FROM #{Message.table_name} WHERE board_id=#{board_id} AND parent_id IS NULL)," + |
52 " messages_count = (SELECT COUNT(*) FROM #{Message.table_name} WHERE board_id=#{board_id})," + | 63 " messages_count = (SELECT COUNT(*) FROM #{Message.table_name} WHERE board_id=#{board_id})," + |
53 " last_message_id = (SELECT MAX(id) FROM #{Message.table_name} WHERE board_id=#{board_id})", | 64 " last_message_id = (SELECT MAX(id) FROM #{Message.table_name} WHERE board_id=#{board_id})", |
54 ["id = ?", board_id]) | 65 ["id = ?", board_id]) |
55 end | 66 end |
67 | |
68 def self.board_tree(boards, parent_id=nil, level=0) | |
69 tree = [] | |
70 boards.select {|board| board.parent_id == parent_id}.sort_by(&:position).each do |board| | |
71 tree << [board, level] | |
72 tree += board_tree(boards, board.id, level+1) | |
73 end | |
74 if block_given? | |
75 tree.each do |board, level| | |
76 yield board, level | |
77 end | |
78 end | |
79 tree | |
80 end | |
81 | |
82 protected | |
83 | |
84 def validate_board | |
85 if parent_id && parent_id_changed? | |
86 errors.add(:parent_id, :invalid) unless valid_parents.include?(parent) | |
87 end | |
88 end | |
56 end | 89 end |