kanbanworkflowstimelinescrumrubyroadmapproject-planningproject-managementopenprojectangularissue-trackerifcgantt-chartganttbug-trackerboardsbcf
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
134 lines
4.7 KiB
134 lines
4.7 KiB
#-- encoding: UTF-8
|
|
#-- copyright
|
|
# OpenProject is a project management system.
|
|
# Copyright (C) 2012-2014 the OpenProject Foundation (OPF)
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License version 3.
|
|
#
|
|
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
|
|
# Copyright (C) 2006-2013 Jean-Philippe Lang
|
|
# Copyright (C) 2010-2013 the ChiliProject Team
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# as published by the Free Software Foundation; either version 2
|
|
# of the License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
#
|
|
# See doc/COPYRIGHT.rdoc for more details.
|
|
#++
|
|
|
|
class Redmine::MenuManager::Mapper
|
|
def initialize(menu, items)
|
|
items[menu] ||= Redmine::MenuManager::TreeNode.new(:root, {})
|
|
@menu = menu
|
|
@menu_items = items[menu]
|
|
end
|
|
|
|
@@last_items_count = Hash.new {|h,k| h[k] = 0}
|
|
|
|
# Adds an item at the end of the menu. Available options:
|
|
# * param: the parameter name that is used for the project id (default is :id)
|
|
# * if: a Proc that is called before rendering the item, the item is displayed only if it returns true
|
|
# * caption that can be:
|
|
# * a localized string Symbol
|
|
# * a String
|
|
# * a Proc that can take the project as argument
|
|
# * before, after: specify where the menu item should be inserted (eg. :after => :activity)
|
|
# * parent: menu item will be added as a child of another named menu (eg. :parent => :issues)
|
|
# * children: a Proc that is called before rendering the item. The Proc should return an array of MenuItems, which will be added as children to this item.
|
|
# eg. :children => Proc.new {|project| [Redmine::MenuManager::MenuItem.new(...)] }
|
|
# * last: menu item will stay at the end (eg. :last => true)
|
|
# * html_options: a hash of html options that are passed to link_to
|
|
def push(name, url, options={})
|
|
options = options.dup
|
|
|
|
if options[:parent]
|
|
subtree = self.find(options[:parent])
|
|
if subtree
|
|
target_root = subtree
|
|
else
|
|
target_root = @menu_items.root
|
|
end
|
|
|
|
else
|
|
target_root = @menu_items.root
|
|
end
|
|
|
|
# menu item position
|
|
if first = options.delete(:first)
|
|
target_root.prepend(Redmine::MenuManager::MenuItem.new(name, url, options))
|
|
elsif before = options.delete(:before)
|
|
|
|
if exists?(before)
|
|
target_root.add_at(Redmine::MenuManager::MenuItem.new(name, url, options), position_of(before))
|
|
else
|
|
target_root.add(Redmine::MenuManager::MenuItem.new(name, url, options))
|
|
end
|
|
|
|
elsif after = options.delete(:after)
|
|
|
|
if exists?(after)
|
|
target_root.add_at(Redmine::MenuManager::MenuItem.new(name, url, options), position_of(after) + 1)
|
|
else
|
|
target_root.add(Redmine::MenuManager::MenuItem.new(name, url, options))
|
|
end
|
|
|
|
elsif options[:last] # don't delete, needs to be stored
|
|
target_root.add_last(Redmine::MenuManager::MenuItem.new(name, url, options))
|
|
else
|
|
target_root.add(Redmine::MenuManager::MenuItem.new(name, url, options))
|
|
end
|
|
end
|
|
|
|
# Removes a menu item
|
|
def delete(name)
|
|
if found = self.find(name)
|
|
@menu_items.remove!(found)
|
|
end
|
|
end
|
|
|
|
# Checks if a menu item exists
|
|
def exists?(name)
|
|
@menu_items.any? {|node| node.name == name}
|
|
end
|
|
|
|
def find(name)
|
|
@menu_items.find {|node| node.name == name}
|
|
end
|
|
|
|
def position_of(name)
|
|
@menu_items.each do |node|
|
|
if node.name == name
|
|
return node.position
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
class Redmine::MenuManager::MapDeferrer
|
|
def initialize(menu_builder_queue)
|
|
@menu_builder_queue = menu_builder_queue
|
|
end
|
|
|
|
def defer(method, *args)
|
|
ActiveSupport::Deprecation.warn "Calling #{method.to_s} and accessing the the menu object from outside of the block attached to the map method is deprecated and will be removed in ChiliProject 3.0. Please access the menu object from within the attached block instead. Please also note the differences between the APIs.", caller.drop(1)
|
|
menu_builder = proc{ |menu_mapper| menu_mapper.send(method, *args) }
|
|
@menu_builder_queue.push(menu_builder)
|
|
end
|
|
|
|
[:push, :delete, :exists?, :find, :position_of].each do |method|
|
|
define_method method do |*args|
|
|
defer(method, *args)
|
|
end
|
|
end
|
|
end
|
|
|