415 lines
15 KiB
Ruby
415 lines
15 KiB
Ruby
# Redmine - project management software
|
|
# Copyright (C) 2006-2013 Jean-Philippe Lang
|
|
#
|
|
# 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.
|
|
|
|
class BoardsController < ApplicationController
|
|
layout 'base_projects'#by young
|
|
default_search_scope :messages
|
|
before_filter :find_project_by_project_id, :find_board_if_available, :except => [:join_to_org_subfields]
|
|
before_filter :authorize, :except => [:new, :show, :create, :index, :join_to_org_subfields, :update_position, :update_name]
|
|
accept_rss_auth :index, :show
|
|
|
|
|
|
helper :sort
|
|
include SortHelper
|
|
helper :watchers
|
|
helper :project_score
|
|
helper :attachments
|
|
include PraiseTreadHelper
|
|
def index
|
|
#modify by nwb
|
|
@flag = params[:flag] || false
|
|
if @project
|
|
if !@project.is_public? && !User.current.member_of?(@project) && !User.current.admin? && !User.current.allowed_to?(:view_messages, @project)
|
|
render_403
|
|
else
|
|
@boards = @project.boards.includes(:last_message => :author).all
|
|
@boards = [] << @boards[0] if @boards.any?
|
|
if @boards.size == 1
|
|
@board = @boards.first
|
|
show and return
|
|
end
|
|
render :layout => false if request.xhr?
|
|
end
|
|
elsif @course
|
|
if (User.current.admin? || @course.is_public == 1 || (@course.is_public == 0 && User.current.member_of_course?(@course)))
|
|
@boards = @course.boards.includes(:last_message => :author).all
|
|
if @course.boards.empty?
|
|
@board = @course.boards.build
|
|
@board.name = " #{l(:label_borad_course) }"
|
|
@board.description = @course.name.to_s
|
|
@board.project_id = -1
|
|
if @board.save
|
|
@boards = @course.boards.includes(:last_message => :author).all
|
|
end
|
|
end
|
|
if params[:board_id]
|
|
@board = Board.find params[:board_id].to_i
|
|
else
|
|
unless @course.boards.where("parent_id is NULL").empty?
|
|
@board = @course.boards.where("parent_id is NULL").first
|
|
end
|
|
end
|
|
show and return
|
|
else
|
|
render_403
|
|
end
|
|
elsif @contest
|
|
if (User.current.admin? || @contest.is_public || (!@contest.is_public && User.current.member_of_contest?(@contest)))
|
|
@boards = @contest.boards.includes(:last_message => :author).all
|
|
if @contest.boards.empty?
|
|
@board = @contest.boards.build
|
|
@board.name = " #{l(:label_board_contest) }"
|
|
@board.description = @contest.name.to_s
|
|
@board.project_id = -1
|
|
@board.course_id = -1
|
|
if @board.save
|
|
@boards = @contest.boards.includes(:last_message => :author).all
|
|
end
|
|
end
|
|
if params[:board_id]
|
|
@board = Board.find params[:board_id].to_i
|
|
else
|
|
unless @contest.boards.where("parent_id is NULL").empty?
|
|
@board = @contest.boards.where("parent_id is NULL").first
|
|
end
|
|
end
|
|
show and return
|
|
else
|
|
render_403
|
|
end
|
|
end
|
|
end
|
|
|
|
def show
|
|
# 顶部导航
|
|
@project_menu_type = 3
|
|
|
|
@order, @b_sort,@type = params[:order] || 1, params[:sort] || 1, params[:type] || 1
|
|
#确定 sort_type 1升序 2 降序
|
|
if @order.to_i == @type.to_i
|
|
@b_sort = @b_sort.to_i == 1 ? 2 : 1
|
|
else
|
|
@b_sort = 2
|
|
end
|
|
sort_name = "updated_on"
|
|
sort_type = @b_sort == 1 ? "asc" : "desc"
|
|
|
|
# 讨论区消息状态更新(已读和未读)
|
|
if @project
|
|
ForgeMessage.where("user_id =? and project_id =? and viewed =?", User.current.id, @project.id, 0).update_all(:viewed => true)
|
|
elsif @course
|
|
CourseMessage.where("user_id =? and course_id =? and viewed =?", User.current.id, @course.id, 0).update_all(:viewed => true)
|
|
elsif @contest
|
|
ContestMessage.where("user_id =? and contest_id =? and viewed =?", User.current.id, @contest.id, 0).update_all(:viewed => true)
|
|
end
|
|
|
|
# sort_init 'updated_on', 'desc'
|
|
# sort_update 'created_on' => "#{Message.table_name}.created_on",
|
|
# 'replies' => "#{Message.table_name}.replies_count",
|
|
# 'updated_on' => "COALESCE(last_replies_messages.created_on, #{Message.table_name}.created_on)"
|
|
|
|
@is_new = params[:is_new]
|
|
@topic_count = @board ? @board.topics.count : 0
|
|
if @project
|
|
if @board
|
|
@topic_count = @board.topics.count();
|
|
@topic_pages = 0#(params[:page] ? params[:page].to_i + 1 : 0) *10
|
|
@topics = @board.topics.reorder("#{Message.table_name}.sticky DESC, COALESCE(last_replies_messages.created_on, #{Message.table_name}.created_on) #{sort_type}").
|
|
offset(@topic_pages).includes(:last_reply).
|
|
preload(:author, {:last_reply => :author}).all();
|
|
else
|
|
@topics = [];
|
|
end
|
|
elsif @course
|
|
if (@board)
|
|
@topic_count = @board.topics.count();
|
|
@topic_pages = 0 #(params[:page] ? params[:page].to_i + 1 : 0) *10
|
|
@topics = @board.topics.reorder("#{Message.table_name}.sticky DESC, COALESCE(last_replies_messages.created_on, #{Message.table_name}.created_on) #{sort_type}").offset(@topic_pages).includes(:last_reply).preload(:author, {:last_reply => :author}).all();
|
|
else
|
|
@topics = [];
|
|
end
|
|
elsif @contest
|
|
if (@board)
|
|
@topic_count = @board.topics.count();
|
|
@topic_pages = 0 #(params[:page] ? params[:page].to_i + 1 : 0) *10
|
|
@topics = @board.topics.reorder("#{Message.table_name}.sticky DESC, COALESCE(last_replies_messages.created_on, #{Message.table_name}.created_on) #{sort_type}").offset(@topic_pages).includes(:last_reply).preload(:author, {:last_reply => :author}).all();
|
|
else
|
|
@board = @contest.boards.build
|
|
@board.name = " #{l(:label_board_contest) }"#self.name
|
|
@board.description = @contest.name.to_s
|
|
@board.project_id = -1
|
|
@board.course_id = -1
|
|
if @board.save
|
|
@topic_count = @board.topics.count();
|
|
@topic_pages = 0 #(params[:page] ? params[:page].to_i + 1 : 0) *10
|
|
@topics = @board.topics.reorder("#{Message.table_name}.sticky DESC, COALESCE(last_replies_messages.created_on, #{Message.table_name}.created_on) #{sort_type}").offset(@topic_pages).includes(:last_reply).preload(:author, {:last_reply => :author}).all();
|
|
else
|
|
@topics = []
|
|
end
|
|
end
|
|
end
|
|
|
|
#根据 赞+回复数排序
|
|
if @order.to_i == 2
|
|
@type = 2
|
|
@topics.each do |topic|
|
|
all_comments = []
|
|
#count=get_all_children(all_comments, topic).count
|
|
count=Message.where("root_id = #{topic.id}").count
|
|
topic[:infocount] = get_praise_num(topic) + count
|
|
if topic[:infocount] < 0
|
|
topic[:infocount] = 0
|
|
end
|
|
end
|
|
@b_sort == 1 ? @topics = @topics.sort{|x,y| x[:infocount] <=> y[:infocount] } : @topics = @topics.sort{|x,y| y[:infocount] <=> x[:infocount] }
|
|
@topics = sort_by_sticky @topics
|
|
@topics = sortby_time_countcommon_hassticky @topics,sort_name
|
|
else
|
|
@type = 1
|
|
end
|
|
|
|
#分页
|
|
@limit = 15
|
|
@is_remote = true
|
|
@atta_count = @topics.count
|
|
@atta_pages = Paginator.new @atta_count, @limit, params['page'] || 1
|
|
@offset ||= @atta_pages.offset
|
|
@topics = paginateHelper @topics,@limit
|
|
|
|
@page = params[:page] ? params[:page].to_i + 1 : 0
|
|
@message = Message.new(:board => @board)
|
|
#modify by nwb
|
|
if (params[:page] || params[:order])
|
|
respond_to do |format|
|
|
format.js{render "show.js.erb"}
|
|
end
|
|
else
|
|
respond_to do |format|
|
|
format.js {render "show.js.erb"}
|
|
format.html {
|
|
if @project
|
|
render :action => 'show', :layout => 'base_projects'
|
|
elsif @course
|
|
@left_nav_type = 2
|
|
@params=params
|
|
render :action => 'show', :layout => 'base_courses'
|
|
elsif @contest
|
|
@left_nav_type = 4
|
|
@params=params
|
|
render :action => 'show', :layout => 'base_contests'
|
|
end
|
|
}
|
|
format.atom {
|
|
@messages = @board.messages.
|
|
reorder('created_on DESC').
|
|
includes(:author, :board).
|
|
limit(Setting.feeds_limit.to_i).
|
|
all
|
|
if @project
|
|
render_feed(@messages, :title => "#{@project}: #{@board}")
|
|
elsif @course
|
|
render_feed(@messages, :title => "#{@course}: #{@board}")
|
|
end
|
|
}
|
|
end
|
|
end
|
|
end
|
|
|
|
def board_history
|
|
@order, @b_sort,@type = params[:order] || 1, params[:sort] || 1, params[:type] || 1
|
|
#确定 sort_type 1升序 2 降序
|
|
if @order.to_i == @type.to_i
|
|
@b_sort = @b_sort.to_i == 1 ? 2 : 1
|
|
else
|
|
@b_sort = 2
|
|
end
|
|
sort_name = "updated_on"
|
|
sort_type = @b_sort == 1 ? "asc" : "desc"
|
|
|
|
@course = Course.find(params[:course])
|
|
syllabus = @course.syllabus
|
|
boards = Board.where(:course_id => syllabus.courses.map(&:id))
|
|
@topics = Message.where(:board_id => boards.map(&:id), :parent_id => nil).reorder("#{Message.table_name}.sticky DESC, COALESCE(last_replies_messages.created_on, #{Message.table_name}.created_on) #{sort_type}").offset(@topic_pages).includes(:last_reply).preload(:author, {:last_reply => :author}).all();
|
|
|
|
#根据 赞+回复数排序
|
|
if @order.to_i == 2
|
|
@type = 2
|
|
@topics.each do |topic|
|
|
all_comments = []
|
|
#count=get_all_children(all_comments, topic).count
|
|
count=Message.where("root_id = #{topic.id}").count
|
|
topic[:infocount] = get_praise_num(topic) + count
|
|
if topic[:infocount] < 0
|
|
topic[:infocount] = 0
|
|
end
|
|
end
|
|
@b_sort == 1 ? @topics = @topics.sort{|x,y| x[:infocount] <=> y[:infocount] } : @topics = @topics.sort{|x,y| y[:infocount] <=> x[:infocount] }
|
|
@topics = sort_by_sticky @topics
|
|
@topics = sortby_time_countcommon_hassticky @topics,sort_name
|
|
else
|
|
@type = 1
|
|
end
|
|
|
|
#分页
|
|
@limit = 15
|
|
@is_remote = true
|
|
@atta_count = @topics.count
|
|
@atta_pages = Paginator.new @atta_count, @limit, params['page'] || 1
|
|
@offset ||= @atta_pages.offset
|
|
@topics = paginateHelper @topics,@limit
|
|
@page = params[:page] ? params[:page].to_i + 1 : 0
|
|
respond_to do |format|
|
|
format.js
|
|
end
|
|
end
|
|
|
|
def new
|
|
@board = @project.boards.build
|
|
@board.safe_attributes = params[:board]
|
|
if @project.project_type == 1
|
|
@left_nav_type = 2
|
|
render :layout => 'base_courses'
|
|
end
|
|
end
|
|
|
|
def create
|
|
if @project
|
|
@board = @project.boards.build
|
|
@board.safe_attributes = params[:board]
|
|
|
|
if @board.save
|
|
flash[:notice] = l(:notice_successful_create)
|
|
#Modified by young
|
|
#redirect_to_settings_in_projects
|
|
redirect_to project_board_url(@project, @board)
|
|
#Ended by young
|
|
else
|
|
render :action => 'new'
|
|
end
|
|
elsif @course
|
|
parent = Board.find params[:board_id].to_i
|
|
board = @course.boards.build
|
|
board.name = params[:name]
|
|
board.description = board.name
|
|
board.project_id = -1
|
|
board.position = parent.children.count + 1
|
|
parent.children << board
|
|
respond_to do |format|
|
|
format.js
|
|
end
|
|
elsif @contest
|
|
parent = Board.find params[:board_id].to_i
|
|
board = @contest.boards.build
|
|
board.name = params[:name]
|
|
board.description = board.name
|
|
board.project_id = -1
|
|
board.course_id = -1
|
|
board.position = parent.children.count + 1
|
|
parent.children << board
|
|
respond_to do |format|
|
|
format.js
|
|
end
|
|
end
|
|
end
|
|
|
|
def edit
|
|
if @project.project_type == 1
|
|
@left_nav_type = 2
|
|
render :layout => 'base_courses'
|
|
end
|
|
end
|
|
|
|
def update
|
|
@board.safe_attributes = params[:board]
|
|
if @board.save
|
|
redirect_to_settings_in_projects
|
|
else
|
|
render :action => 'edit'
|
|
end
|
|
end
|
|
|
|
def destroy
|
|
after_boards = @board.parent.children.where("position > #{@board.position}")
|
|
after_boards.update_all("position = position - 1")
|
|
@board.destroy
|
|
if @course || @contest
|
|
respond_to do |format|
|
|
format.js
|
|
end
|
|
elsif @project
|
|
redirect_to_settings_in_projects
|
|
end
|
|
end
|
|
|
|
def update_position
|
|
if @course || @contest
|
|
boards = @board.parent.children
|
|
if params[:opr] == 'up' && @board.position > 1
|
|
before_board = boards.where("position = #{@board.position - 1}").first
|
|
if before_board && @board.update_attribute('position', @board.position - 1)
|
|
before_board.update_attribute('position', before_board.position + 1)
|
|
end
|
|
elsif params[:opr] == 'down' && @board.position < boards.count
|
|
after_board = boards.where("position = #{@board.position + 1}").first
|
|
if after_board && @board.update_attribute('position', @board.position + 1)
|
|
after_board.update_attribute('position', after_board.position - 1)
|
|
end
|
|
end
|
|
respond_to do |format|
|
|
format.js
|
|
end
|
|
end
|
|
end
|
|
|
|
def update_name
|
|
if @course || @contest
|
|
@board.update_attribute("name", params[:name])
|
|
@board.update_attribute("description", params[:name])
|
|
respond_to do |format|
|
|
format.js
|
|
end
|
|
end
|
|
end
|
|
|
|
def join_to_org_subfields
|
|
if params[:id]
|
|
@board = Board.find(params[:id])
|
|
@org_subfield_ids = params[:org_subfield_ids]
|
|
@org_subfield_ids.each do |id|
|
|
OrgSubfieldBoard.create(:org_subfield_id => id.to_i, :board_id => params[:id].to_i)
|
|
end
|
|
end
|
|
end
|
|
|
|
private
|
|
def redirect_to_settings_in_projects
|
|
redirect_to settings_project_url(@project, :tab => 'boards')
|
|
end
|
|
|
|
def find_board_if_available
|
|
if @project
|
|
@board = @project.boards.find(params[:id]) if params[:id]
|
|
elsif @course
|
|
@board = @course.boards.find(params[:id]) if params[:id]
|
|
elsif @contest
|
|
@board = @contest.boards.find(params[:id]) if params[:id]
|
|
end
|
|
rescue ActiveRecord::RecordNotFound
|
|
render_404
|
|
end
|
|
end
|