275 lines
12 KiB
Ruby
275 lines
12 KiB
Ruby
# encoding: utf-8
|
||
#
|
||
# 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.
|
||
|
||
module AttachmentsHelper
|
||
# Displays view/delete links to the attachments of the given object
|
||
# Options:
|
||
# :author -- author names are not displayed if set to false
|
||
# :thumbails -- display thumbnails if enabled in settings
|
||
|
||
include Redmine::Pagination
|
||
|
||
def link_to_attachments(container, options = {})
|
||
options.assert_valid_keys(:author, :thumbnails)
|
||
|
||
if container.attachments.any?
|
||
options = {:deletable => container.attachments_deletable?, :author => true}.merge(options)
|
||
render :partial => 'attachments/links',
|
||
:locals => {:attachments => container.attachments, :options => options, :thumbnails => (options[:thumbnails] && Setting.thumbnails_enabled?)}
|
||
end
|
||
end
|
||
|
||
def link_to_attachment_project(container, options = {})
|
||
options.assert_valid_keys(:deletable, :author, :thumbnails)
|
||
|
||
if container.attachments.any?
|
||
options = {:deletable => container.attachments_deletable?, :author => true}.merge(options)
|
||
render :partial => 'attachments/project_file_links',
|
||
:locals => {:attachments => container.attachments, :options => options, :thumbnails => (options[:thumbnails] && Setting.thumbnails_enabled?)}
|
||
end
|
||
end
|
||
|
||
def link_to_attachments_course(container, options = {})
|
||
options.assert_valid_keys(:author, :thumbnails)
|
||
|
||
if container.attachments.any?
|
||
options = {:deletable => container.attachments_deletable?, :author => true}.merge(options)
|
||
render :partial => 'attachments/course_file_links',
|
||
:locals => {:attachments => container.attachments, :options => options, :thumbnails => (options[:thumbnails] && Setting.thumbnails_enabled?)}
|
||
end
|
||
end
|
||
|
||
def attach_delete(project)
|
||
if User.current.logged? && (User.current.admin? || (!Member.where('user_id = ? and project_id = ?', User.current.id, project.bid.courses.first.id).first.nil? && (Member.where('user_id = ? and project_id = ?', User.current.id, project.bid.courses.first.id).first.roles&Role.where('id = ? or id = ?', 3, 7)).size >0) || project.user_id == User.current.id)
|
||
true
|
||
else
|
||
false
|
||
end
|
||
|
||
end
|
||
|
||
def render_api_attachment(attachment, api)
|
||
api.attachment do
|
||
api.id attachment.id
|
||
api.filename attachment.filename
|
||
api.filesize attachment.filesize
|
||
api.content_type attachment.content_type
|
||
api.description attachment.description
|
||
api.content_url url_for(:controller => 'attachments', :action => 'download', :id => attachment, :filename => attachment.filename, :only_path => false)
|
||
api.author(:id => attachment.author.id, :name => attachment.author.name) if attachment.author
|
||
api.created_on attachment.created_on
|
||
end
|
||
end
|
||
|
||
def link_to_memo_attachments(container, options = {})
|
||
options.assert_valid_keys(:author, :thumbnails)
|
||
|
||
if container.attachments.any?
|
||
options = {:deletable => deletable?(container), :author => true}.merge(options)
|
||
render :partial => 'attachments/links',
|
||
:locals => {:attachments => container.attachments, :options => options, :thumbnails => (options[:thumbnails] && Setting.thumbnails_enabled?)}
|
||
end
|
||
end
|
||
|
||
#判断课程course中是否包含课件attachment,course中引用了attachment也算作包含
|
||
def course_contains_attachment? course,attachment
|
||
course.attachments.each do |att|
|
||
if att.id == attachment.id || (!att.copy_from.nil? && !attachment.copy_from.nil? && att.copy_from == attachment.copy_from) || att.copy_from == attachment.id || att.id == attachment.copy_from
|
||
return true
|
||
end
|
||
end
|
||
false
|
||
end
|
||
|
||
#判断项目project中是否包含课件attachment,project中引用了attachment也算作包含
|
||
def project_contains_attachment? project,attachment
|
||
project.attachments.each do |att|
|
||
if att.id == attachment.id || (!att.copy_from.nil? && !attachment.copy_from.nil? && att.copy_from == attachment.copy_from) || att.copy_from == attachment.id || att.id == attachment.copy_from
|
||
return true
|
||
end
|
||
end
|
||
false
|
||
end
|
||
|
||
def get_qute_number attachment
|
||
if attachment.copy_from
|
||
result = Attachment.find_by_sql("select count(*) as number from attachments where copy_from = #{attachment.copy_from}")
|
||
else
|
||
result = Attachment.find_by_sql("select count(*) as number from attachments where copy_from = #{attachment.id}")
|
||
end
|
||
if result.nil? || result.count <= 0
|
||
return 0
|
||
else
|
||
return result[0].number
|
||
end
|
||
end
|
||
|
||
private
|
||
|
||
def deletable? container, user=User.current
|
||
User.current.logged? && (container.author == user || user.admin?)
|
||
end
|
||
|
||
# this method is used to get all projects that tagged one tag
|
||
# added by william
|
||
def get_attachments_by_tag(tag_name)
|
||
Attachment.tagged_with(tag_name).order('created_on desc')
|
||
end
|
||
|
||
# this method is used to get all attachments that from one project and tagged one tag
|
||
# added by Long Jun
|
||
def get_attachments_by_project_tag(tag_name, obj)
|
||
@project_id =nil
|
||
if obj.container_type == 'Version'
|
||
@project_id = Version.find(obj.container_id).project_id
|
||
|
||
elsif obj.container_type == 'Project'
|
||
@project_id = obj.container_id
|
||
|
||
end
|
||
attachments = Attachment.tagged_with(tag_name).order('created_on desc').where("(container_id = :project_id and container_type = 'Project') or
|
||
(container_id in (select id from versions where project_id =:project_id) and container_type = 'Version')", {:project_id => @project_id})
|
||
return attachments
|
||
end
|
||
|
||
|
||
def render_attachments_for_new_project(project, limit=nil)
|
||
# 查询条件
|
||
params[:q] ||= ""
|
||
filename_condition = params[:q].strip
|
||
|
||
attachAll = Attachment.scoped
|
||
# 当前项目所有资源
|
||
# attachments = Attachment.find_all_by_container_type_and_container_id(project.class, project.id)
|
||
# attachments = Attachment.where("container_type = '#{project.class}' and container_id = #{project.id}")
|
||
|
||
# 除去当前项目的所有资源
|
||
nobelong_attach = Attachment.where("!(container_type = '#{project.class}' and container_id = #{project.id})") unless project.blank?
|
||
|
||
# 搜索域确定
|
||
domain = project.nil? ? attachAll : nobelong_attach
|
||
|
||
# 搜索到的资源
|
||
searched_attach = domain.where("is_public=1 and filename LIKE :like ", like:"%#{filename_condition}%").limit(limit).order('created_on desc')
|
||
#searched_attach = private_filter searched_attach
|
||
searched_attach = paginateHelper(searched_attach, 10)
|
||
|
||
s = content_tag('div', attachments_check_box_tags('attachment[attach][]', searched_attach), :id => 'attachments')
|
||
links = pagination_links_full(@obj_pages, @obj_count, :per_page_links => false) {|text, parameters, options|
|
||
link_to text, attachments_autocomplete_path( parameters.merge(:project_id=>project.id,:q => params[:q], :format => 'js')), :remote => true }
|
||
|
||
return s + content_tag('div', content_tag('ul', links), :class => 'pagination')
|
||
|
||
# ================================================================================================
|
||
|
||
# attach_count = searched_attach.count
|
||
# attach_pages = Redmine::Pagination::Paginator.new attach_count, 10, params['page'] #by young
|
||
# attachs = searched_attach.offset(attach_pages.offset).limit(attach_pages.per_page).all
|
||
|
||
# s = content_tag('div', attachments_check_box_tags('attachment[attach][]', attachs), :id => 'attachments')
|
||
# links = pagination_links_full(attach_pages, attach_count, :per_page_links => false) {|text, parameters, options|
|
||
# link_to text, attachments_autocomplete_path( parameters.merge(:q => params[:q], :format => 'js')), :remote => true }
|
||
|
||
# return s + content_tag('div', content_tag('ul', links), :class => 'pagination')
|
||
# return searched_attach.to_json
|
||
end
|
||
|
||
# add by nwb
|
||
def render_attachments_for_new_course(course, limit=nil)
|
||
# 查询条件
|
||
params[:q] ||= ""
|
||
filename_condition = params[:q].strip
|
||
|
||
#attachAll = Attachment.where("author_id = #{User.current.id}")
|
||
#
|
||
## 除去当前课程的所有资源
|
||
#nobelong_attach =
|
||
|
||
# 搜索域确定
|
||
course.nil? ?
|
||
domain=Attachment.where("author_id = #{User.current.id}")
|
||
:
|
||
domain=Attachment.where("author_id = #{User.current.id} and container_type = 'Course' and container_id <> #{course.id}") unless course.blank?
|
||
|
||
# 搜索到的资源
|
||
searched_attach = domain.where("filename LIKE :like ", like:"%#{filename_condition}%").limit(limit).order('created_on desc')
|
||
#searched_attach = private_filter searched_attach
|
||
searched_attach = paginateHelper(searched_attach, 10)
|
||
|
||
#testattach = Attachment.public_attachments
|
||
|
||
s = content_tag('div', attachments_check_box_tags('attachment[attach][]', searched_attach), :id => 'attachments')
|
||
links = pagination_links_full(@obj_pages, @obj_count, :per_page_links => false) {|text, parameters, options|
|
||
link_to text, attachments_autocomplete_path( parameters.merge(:course_id=>course.id,:q => params[:q], :format => 'js')), :remote => true }
|
||
|
||
return s + content_tag('div', content_tag('ul', links), :class => 'pagination')
|
||
|
||
end
|
||
|
||
def attachments_check_box_tags(name, attachs)
|
||
s = ''
|
||
attachs.each do |attach|
|
||
s << "<label>#{ check_box_tag name, attach.id, false, :id => nil } #{h attach.filename}</label><br/>"
|
||
end
|
||
s.html_safe
|
||
end
|
||
|
||
|
||
|
||
# Modified by Longjun
|
||
# 有参数的方法要加()
|
||
def private_filter(resultSet)
|
||
result = resultSet.to_a.dup
|
||
|
||
# modify by nwb
|
||
#添加对课程资源文件的判断
|
||
resultSet.map { |res|
|
||
if(res.container.nil? ||
|
||
(res.container.class.to_s=="Project" && res.container.is_public == false) ||
|
||
(res.container.has_attribute?(:project) && res.container.project && res.container.project.is_public == false) ||
|
||
(res.container.class.to_s=="HomeworkAttach" && res.container.bid.reward_type == 3) ||
|
||
(res.container.class.to_s=="Course" && res.container.is_public == false) ||
|
||
(res.container.has_attribute?(:course) && res.container.course && res.container.course.is_public == false)
|
||
)
|
||
result.delete(res)
|
||
end
|
||
}
|
||
result
|
||
end
|
||
|
||
# Modified by Longjun
|
||
# include 应放在class/model 的开始处
|
||
# include Redmine::Pagination
|
||
# end
|
||
|
||
def paginateHelper (obj, pre_size=10)
|
||
@obj_count = obj.count
|
||
@obj_pages = Paginator.new @obj_count, pre_size, params['page']
|
||
if obj.kind_of? ActiveRecord::Base or obj.kind_of? ActiveRecord::Relation
|
||
obj.limit(@obj_pages.per_page).offset(@obj_pages.offset)
|
||
elsif obj.kind_of? Array
|
||
obj[@obj_pages.offset, @obj_pages.per_page]
|
||
else
|
||
logger.error "[ApplicationController] Error : application_controller#paginateHelper ===> unknow category: #{obj.class}"
|
||
raise RuntimeError, 'unknow type, Please input you type into this helper.'
|
||
end
|
||
end
|
||
|
||
end
|