115 lines
3.2 KiB
Ruby
115 lines
3.2 KiB
Ruby
# encoding: utf-8
|
||
## This helper be included in applicationHelper
|
||
module CoursesHelper
|
||
=begin
|
||
1. define TeacherRoles, StudentRoles
|
||
2. define count function
|
||
3. define search by roles
|
||
4. define search member function
|
||
=end
|
||
TeacherRoles = [3, 4, 7, 9]
|
||
StudentRoles = [5, 10]
|
||
AllPeople = StudentRoles+TeacherRoles
|
||
## return people count
|
||
|
||
# 返回x项目成员数量,即roles表中定义的所有成员
|
||
def projectCount project
|
||
searchCountByRoles project, AllPeople
|
||
end
|
||
|
||
# 返回教师数量,即roles表中定义的Manager
|
||
def teacherCount project
|
||
searchCountByRoles project, TeacherRoles
|
||
# or
|
||
# searchTeacherAndAssistant(project).count
|
||
end
|
||
|
||
# 返回学生数量,即roles表中定义的Reporter
|
||
def studentCount project
|
||
searchCountByRoles project,StudentRoles
|
||
# or
|
||
# searchStudent(project).count
|
||
end
|
||
|
||
# =====================================================================================
|
||
# return people list
|
||
def searchTeacherAndAssistant project
|
||
searchPeopleByRoles(project, TeacherRoles)
|
||
end
|
||
|
||
def searchStudent project
|
||
searchPeopleByRoles(project, StudentRoles)
|
||
end
|
||
# =====================================================================================
|
||
|
||
def searchCountByRoles project, roles_id
|
||
members = searchPeopleByRoles project, roles_id
|
||
members.count
|
||
end
|
||
|
||
def searchPeopleByRoles project, roles_id
|
||
members = []
|
||
begin
|
||
members = project.members.joins(:member_roles).where("member_roles.role_id IN (:role_id)", {:role_id => roles_id})
|
||
rescue Exception => e
|
||
logger.error "[CoursesHelper] ===> #{e}"
|
||
end
|
||
members
|
||
end
|
||
|
||
#useless
|
||
def searchMembersByRole project, role_id
|
||
members = []
|
||
begin
|
||
members = project.members.joins(:member_roles).where("member_roles.role_id = :role_id", {:role_id => role_id })
|
||
rescue Exception => e
|
||
logger.error "[CoursesHelper] ===> #{e}"
|
||
end
|
||
members
|
||
end
|
||
|
||
def findCourseTime project
|
||
str = ""
|
||
begin
|
||
@course = Course.find_by_extra(@project.identifier)
|
||
date_format = l(:zh_date)[:formats][:default]
|
||
if @course
|
||
str = DateTime.parse(@course.setup_time.to_s).strftime("#{date_format}").to_s unless @course.setup_time.blank?
|
||
str << '-' unless @course.setup_time.blank?
|
||
str << DateTime.parse(@course.endup_time.to_s).strftime("#{date_format}").to_s unless @course.endup_time.blank?
|
||
end
|
||
rescue Exception => e
|
||
logger.error "[CoursesHelper] ===> #{e}"
|
||
end
|
||
str
|
||
end
|
||
|
||
def get_course_term project
|
||
str = ( project.try(:course_extra).try(:time).to_s << '.' << project.try(:course_extra).try(:term).to_s )
|
||
str[0..-4]
|
||
end
|
||
|
||
def members_to_user_ids members
|
||
people = []
|
||
members.each { |member|
|
||
people << member.user_id
|
||
}
|
||
people
|
||
end
|
||
# 截至到2014-03-17 这个是最终的判断课程是否过期的方法
|
||
def course_endTime_timeout? project
|
||
end_time_str = Course.find_by_extra(project.try(:identifier)).try(:endup_time)
|
||
begin
|
||
cTime = Time.parse(end_time_str.to_s)
|
||
rescue TypeError,ArgumentError
|
||
cTime = Time.parse("3000-01-01")
|
||
end
|
||
now = Time.now
|
||
|
||
now > cTime
|
||
end
|
||
def find_by_extra_from_project extra
|
||
Course.find_by_extra(try(extra))
|
||
end
|
||
end
|