class CollectiveIdea::Acts::NestedSet::Tree
:nodoc:
:nodoc:
:nodoc:
def increment_indice!(node)
def increment_indice!(node) indices[scope_for_rebuild.call(node)] += 1 end
def initialize(model, validate_nodes)
def initialize(model, validate_nodes) @model = model @validate_nodes = validate_nodes @indices = {} end
def node_children(node)
def node_children(node) model.where(["#{quoted_parent_column_full_name} = ? #{scope_for_rebuild.call(node)}", node.primary_id]). order(order_for_rebuild) end
def rebuild!
def rebuild! # Don't rebuild a valid tree. return true if model.valid? root_nodes.each do |root_node| # setup index for this scope indices[scope_for_rebuild.call(root_node)] ||= 0 set_left_and_rights(root_node) reset_counter_cache(root_node) end end
def reset_counter_cache(node)
def reset_counter_cache(node) return unless counter_cache_column_name node.class.reset_counters(node.id, :children) node.children.each do |child| reset_counter_cache(child) end end
def root_nodes
def root_nodes model.where("#{quoted_parent_column_full_name} IS NULL").order(order_for_rebuild) end
def set_left!(node)
def set_left!(node) node[left_column_name] = increment_indice!(node) end
def set_left_and_rights(node)
def set_left_and_rights(node) set_left!(node) # find node_children(node).each { |n| set_left_and_rights(n) } set_right!(node) node.save!(:validate => validate_nodes) end
def set_right!(node)
def set_right!(node) node[right_column_name] = increment_indice!(node) end