# 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 # 返回课程设置界面 def course_settings_tabs tabs = [{:name => 'info', :action => :edit_course, :partial => 'courses/edit', :label => :label_information_plural}, {:name => 'members', :action => :manage_members, :partial => 'courses/settings/members', :label => :label_member_plural} ] tabs.select { |tab| User.current.allowed_to?(tab[:action], @course) } end # garble count 混淆数量 # alias projectCountOrigin projectCount # def projectCount project # count = projectCountOrigin project # garble count # end def homework_type_option type = [] option1 = [] option2 = [] option1 << l(:label_task_submit_form_accessory) option1 << 1 option2 << l(:label_task_submit_form_project) option2 << 2 type << option1 type << option2 end alias teacherCountOrigin teacherCount def teacherCount project count = teacherCountOrigin project garble count end alias studentCountOrigin studentCount def studentCount project count = studentCountOrigin project garble count end def eventToLanguageCourse event_type, course case event_type when "issue-note" l :label_issue when "issue" l :label_issue when "attachment" l :label_attachment when "news" l :label_notification else "" end end def garble count count = count.round( 1-count.to_s.size ).to_i return count.to_s if count.to_s.size.eql?(1) count.to_s << '+' 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 def sort_courses(state) content = ''.html_safe case state when 0 content << content_tag('li', link_to(l(:label_sort_by_active), courses_path(:courses_sort_type => '1'))) content << content_tag('li', link_to(l(:label_sort_by_influence), courses_path(:courses_sort_type => '2'))) content << content_tag('li', link_to(l(:label_sort_by_time), courses_path(:courses_sort_type => '0'), :class=>"selected"), :class=>"selected") when 1 content << content_tag('li', link_to(l(:label_sort_by_active), courses_path(:courses_sort_type => '1'), :class=>"selected"), :class=>"selected") content << content_tag('li', link_to(l(:label_sort_by_influence), courses_path(:courses_sort_type => '2'))) content << content_tag('li', link_to(l(:label_sort_by_time), courses_path(:courses_sort_type => '0'))) when 2 content << content_tag('li', link_to(l(:label_sort_by_active), courses_path(:courses_sort_type => '1'))) content << content_tag('li', link_to(l(:label_sort_by_influence), courses_path(:courses_sort_type => '2'), :class=>"selected"), :class=>"selected") content << content_tag('li', link_to(l(:label_sort_by_time), courses_path(:courses_sort_type => '0'))) end content = content_tag('ul', content) content_tag('div', content, :class => "tabs") end def render_course_hierarchy(courses) render_course_nested_lists(courses) do |course| s = link_to_course(course, {}, :class => "#{course.css_classes} #{User.current.member_of?(course) ? 'my-course' : nil}").html_safe s end 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 sort_course(state, school_id) content = ''.html_safe case state when 0 content << content_tag('li', link_to(l(:label_sort_by_time), courses_path(:course_sort_type => '0'), :school_id => school_id, :class=>"selected"), :class=>"selected") content << content_tag('li', link_to(l(:label_sort_by_active), courses_path(:course_sort_type => '1', :school_id => school_id))) content << content_tag('li', link_to(l(:label_sort_by_activity), courses_path(:course_sort_type => '3', :school_id => school_id))) when 1 content << content_tag('li', link_to(l(:label_sort_by_time), courses_path(:course_sort_type => '0', :school_id => school_id))) content << content_tag('li', link_to(l(:label_sort_by_active), courses_path(:course_sort_type => '1', :school_id => school_id), :class=>"selected"), :class=>"selected") content << content_tag('li', link_to(l(:label_sort_by_activity), courses_path(:course_sort_type => '3', :school_id => school_id))) when 2 content << content_tag('li', link_to(l(:label_sort_by_time), courses_path(:course_sort_type => '0', :school_id => school_id))) content << content_tag('li', link_to(l(:label_sort_by_active), courses_path(:course_sort_type => '1', :school_id => school_id))) content << content_tag('li', link_to(l(:label_sort_by_activity), courses_path(:course_sort_type => '3', :school_id => school_id))) #gcm when 3 content << content_tag('li', link_to(l(:label_sort_by_time), courses_path(:course_sort_type => '0', :school_id => school_id))) content << content_tag('li', link_to(l(:label_sort_by_active), courses_path(:course_sort_type => '1', :school_id => school_id))) content << content_tag('li', link_to(l(:label_sort_by_activity), courses_path(:course_sort_type => '3', :school_id => school_id), :class=>"selected"), :class=>"selected") end #gcmend content = content_tag('ul', content) content_tag('div', content, :class => "tabs") 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 # added by nwb def get_course_term course str = ( course.try(:time).to_s << '.' << course.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(:extra)).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 #判断制定用户是不是当前课程的老师 def is_course_teacher user,course people = [] course.members.each do |member| role_id = member.roles.first.id if TeacherRoles.include? role_id people << member.user end end people.include?(user) end #当前用户是不是指定课程的学生 def is_cur_course_student? course people = [] course.members.each do |member| if StudentRoles.include? member.roles.first.id people << member.user end end people.include?(User.current) end #获取当前用户在指定作业下提交的作业的集合 def cur_user_homework_for_bid bid cur_user_homework = HomeworkAttach.where("user_id = ? and bid_id = ?",User.current,params[:id]) cur_user_homework end end