#encoding: utf-8
class SyllabusesController < ApplicationController
  include ApplicationHelper
  helper :attachments
  include AttachmentsHelper
  include CoursesHelper
  include SyllabusesHelper
  include UsersHelper
  before_filter :is_logged, :only => [:index, :show, :edit, :new, :update, :destroy, :delete_syllabus, :syllabus_resources, :syllabus_homeworks]
  before_filter :check_authentication
  before_filter :find_syllabus, :only => [:show, :edit, :update, :destroy, :syllabus_courselist, :edit_syllabus_eng_name, :edit_syllabus_title, :update_base_info, :delete_syllabus,
                                          :delete_des, :members, :update_des, :edit_ref, :update_ref, :add_sy_member_alert, :search_not_sy_member, :syllabus_resources, :syllabus_homeworks,
                                          :send_homeworks_to_course, :choose_user_course, :send_resources_to_course, :send_r_and_h_to_course]

  def index
    @status = params[:type].nil? ? 1 : params[:type].to_i # 1表示正在进行,2表示已结束
    @tab = params[:tab].nil? ? 1 : params[:tab].to_i
    @my_syllabuses = "我的课堂"
    user = User.current
    if @status == 1
      case @tab
        when 2
          @courses = user.courses.not_deleted_not_end.order("updated_at desc").select{ |course| user.has_teacher_role(course)}
        when 3
          @courses = user.courses.not_deleted_not_end.order("updated_at desc").select{ |course| !user.has_teacher_role(course)}
        when 1
          @courses = user.courses.not_deleted_not_end.order("updated_at desc")
      end
    else
      case @tab
        when 2
          @courses = user.courses.not_deleted_but_is_end.order("updated_at desc").select{ |course| user.has_teacher_role(course)}
        when 3
          @courses = user.courses.not_deleted_but_is_end.order("updated_at desc").select{ |course| !user.has_teacher_role(course)}
        when 1
          @courses = user.courses.not_deleted_but_is_end.order("updated_at desc")
      end
    end

    @limit = 15
    @is_remote = true
    @courses_count = @courses.count
    @courses_pages = Paginator.new @courses_count, @limit, params['page'] || 1
    @offset ||= @courses_pages.offset
    @courses = paginateHelper @courses, @limit

    respond_to do |format|
      format.html{ render :layout => 'base_edu'}
      format.js
    end
  end

  def show
    @is_syllabus_teacher = User.current.admin? || @syllabus.syllabus_members.map{|sm| sm.user_id}.include?(User.current.id) || !@syllabus.courses.not_deleted_not_end.select { |course| User.current.has_teacher_role(course)}.blank?
    @is_syllabus_member = !@syllabus.courses.not_deleted_not_end.select { |course| User.current.member_of_course?(course)}.blank?
    @is_syllabus_admin = User.current.admin? || @syllabus.syllabus_members.map{|sm| sm.user_id}.include?(User.current.id)
    @is_authen_teacher = User.current.authentication && User.current.user_extensions.try(:identity) != 1
    @reference_materials = @syllabus.reference_materials
    @members = @syllabus.syllabus_members.includes(:user => {:user_extensions => []}).order("rank asc")
    @courses = @syllabus.courses.where("is_delete = 0 and is_end = 0").select("courses.*,(SELECT MAX(updated_at) FROM `course_activities` WHERE course_activities.course_id = courses.id) AS ca_update").order("ca_update desc")
    @end_courses = @syllabus.courses.where("is_delete = 0 and is_end = 1").select("courses.*,(SELECT MAX(updated_at) FROM `course_activities` WHERE course_activities.course_id = courses.id) AS ca_update").order("ca_update desc")
    respond_to do |format|
      format.js
      format.html{render :layout => 'base_edu_syllabus'}
      format.api
    end
  end

  def new
    @syllabus = Syllabus.new
    render :layout => 'base_edu'
  end

  def create
    if User.current.user_extensions.identity
      @syllabus = Syllabus.new
      @syllabus.title = params[:title].to_s.strip
      @syllabus.eng_name = params[:eng_name]
      @syllabus.user_id = User.current.id
      @syllabus.major_level = params[:major_level].to_i
      @syllabus.discipline_category_id = params[:discipline_category_id].to_i
      @syllabus.first_level_discipline_id = params[:first_level_discipline_id].to_i
      @syllabus.major_id = params[:major_id].to_i
      @syllabus.syllabus_type = params[:syllabus_type].to_i
      @syllabus.description = Message.where("id = 19412").first.nil? ? '' : Message.where("id = 19412").first.content
      if @syllabus && @syllabus.save
        member =  SyllabusMember.create(:user_id => @syllabus.user_id, :rank => 1)
        @syllabus.syllabus_members << member
        respond_to do |format|
          #flash[:notice] = l(:notice_successful_create)
          format.html {redirect_to syllabus_path(@syllabus)}
          format.api { render :action => 'show', :status => :created, :location => url_for(:controller => 'syllabuses', :action => 'show', :id => @syllabus.id) }
        end
      else
        respond_to do |format|
          flash[:notice] = l(:notice_create_failed)
          format.html { redirect_to new_syllabus_path } #Added by young
          format.api { render_validation_errors(@syllabus) }
        end
      end
    end
  end

  def regex_syllabus_name
    data = {result:1}
    if params[:syllabus_id]
      if User.current.syllabuses.where("id != #{params[:syllabus_id]} and title = '#{params[:name]}'").count > 0
        data[:result] = 0
      end
    else
      if Syllabus.where(:user_id => User.current.id, :title => params[:name]).count > 0
        data[:result] = 0
      end
    end
    render :json => data
  end

  def edit
    respond_to do |format|
      format.html{render :layout => 'base_edu'}
    end
  end

  def update
    title = @syllabus.title
    @syllabus.title = params[:title].to_s.strip
    @syllabus.eng_name = params[:eng_name]
    @syllabus.major_level = params[:major_level].to_i
    @syllabus.discipline_category_id = params[:discipline_category_id].to_i
    @syllabus.first_level_discipline_id = params[:first_level_discipline_id].to_i
    @syllabus.major_id = params[:major_id].to_i
    @syllabus.syllabus_type = params[:syllabus_type].to_i
    if @syllabus.save
      if title != params[:title].to_s.strip
        @syllabus.courses.each do |course|
          course.name.gsub!(/^#{title}/, params[:title].to_s.strip)
          course.save
        end
      end
    end
    redirect_to syllabus_path(@syllabus)
  end

  def edit_ref
    @reference_materials = @syllabus.reference_materials
    respond_to do |format|
      format.js
    end
  end

  def update_ref
    @syllabus.reference_materials.destroy_all
    refer_inputs = params[:syllabus][:book] if params[:syllabus]
    if Array === refer_inputs
      refer_inputs.each_with_index do |val, i|
        @syllabus.reference_materials << ReferenceMaterial.new(
            book: val,
            editor: params[:syllabus][:editor][i],
            press: params[:syllabus][:press][i]
        )
      end
    end
    sy_update_record = SyllabusUpdateRecord.new(:property => 2, :user_id => User.current.id)
    @syllabus.syllabus_update_records << sy_update_record
    @reference_materials = @syllabus.reference_materials
    @is_syllabus_admin = User.current.admin? || @syllabus.syllabus_members.map{|sm| sm.user_id}.include?(User.current.id)
    respond_to do |format|
      format.js
    end
  end

  def update_des
    @syllabus.description = params[:syllabus][:description]
    @syllabus.des_status = 1
    #@syllabus.save_attachments(params[:attachments])
    if @syllabus.save
      sy_update_record = SyllabusUpdateRecord.new(:property => 1, :user_id => User.current.id)
      @syllabus.syllabus_update_records << sy_update_record
      if params[:asset_id]
        ids = params[:asset_id].split(',')
        update_kindeditor_assets_owner ids,@syllabus.id,OwnerTypeHelper::SYLLABUS
      end
    end
    redirect_to syllabus_path(@syllabus)
  end

  def add_sy_member_alert
    respond_to do |format|
      format.js
    end
  end

  def search_not_sy_member
    if params[:q] && params[:q].lstrip.rstrip != ""
      @users = Principal.active.sorted.not_member_of_syllabus(@syllabus).like(params[:q])
    else
      @users = []
    end
  end

  def syllabus_resources
    @is_syllabus_teacher = User.current.admin? || @syllabus.syllabus_members.map{|sm| sm.user_id}.include?(User.current.id) || !@syllabus.courses.not_deleted_not_end.select { |course| User.current.has_teacher_role(course)}.blank?
    @is_syllabus_member = !@syllabus.courses.not_deleted_not_end.select { |course| User.current.member_of_course?(course)}.blank?
    @is_syllabus_admin = User.current.admin? || @syllabus.syllabus_members.map{|sm| sm.user_id}.include?(User.current.id)
    @is_authen_teacher = User.current.authentication && User.current.user_extensions.try(:identity) != 1
    @order, @r_sort = params[:order] || "created_at", params[:sort] || "asc"
    @sort = @r_sort == "desc" ? "asc" : "desc"
    @resources = sy_resources @syllabus
    if @order == "created_at"
      @resources = @resources.order("#{@order} #{@sort}")
    else
      @resources = @resources.select("resource_banks.*, (quotes+downloads) as heat").order("#{@order} #{@sort}, created_at desc")
    end
    @resource_count = @resources.count
    @public_resource_count = @resources.where(:is_public => 1).count
    @private_resource_count = @resources.where(:is_public => 0).count

    if !(@is_syllabus_admin || @is_syllabus_member)
      @resources = @resources.where(:is_public => 1)
    end

    #分页
    @page_resource_count = @resources.count
    @limit = 10
    @is_remote = true
    @resource_pages = Paginator.new @page_resource_count, @limit, params['page'] || 1
    @offset ||= @resource_pages.offset
    @resources = paginateHelper @resources,@limit
    respond_to do |format|
      format.js
    end
  end

  def syllabus_homeworks
    @is_syllabus_teacher = User.current.admin? || @syllabus.syllabus_members.map{|sm| sm.user_id}.include?(User.current.id) || !@syllabus.courses.not_deleted_not_end.select { |course| User.current.has_teacher_role(course)}.blank?
    @is_syllabus_member = !@syllabus.courses.not_deleted_not_end.select { |course| User.current.member_of_course?(course)}.blank?
    @is_syllabus_admin = User.current.admin? || @syllabus.syllabus_members.map{|sm| sm.user_id}.include?(User.current.id)
    @is_authen_teacher = User.current.authentication && User.current.user_extensions.try(:identity) != 1
    @order, @r_sort = params[:order] || "created_at", params[:sort] || "asc"
    @sort = @r_sort == "desc" ? "asc" : "desc"
    @homeworks = @syllabus.homework_banks.order("#{@order} #{@sort}")
    @homework_count = @homeworks.count
    @public_homework_count = @homeworks.where(:is_public => 1).count
    @private_homework_count = @homeworks.where(:is_public => 0).count

    if !(@is_syllabus_admin || @is_syllabus_member)
      @homeworks = @homeworks.where(:is_public => 1)
    end

    @page_homework_count = @homeworks.count
    @limit = 10
    @is_remote = true
    @homework_pages = Paginator.new @page_homework_count, @limit, params['page'] || 1
    @offset ||= @homework_pages.offset
    @homeworks = paginateHelper @homeworks, @limit
    respond_to do |format|
      format.js
    end
  end

  def choose_user_course
    if !params[:search].nil?
      search = "%#{params[:search].to_s.strip.downcase}%"
      @courses = User.current.courses.where("is_delete = 0 and is_end = 0 and (#{Course.table_name}.id = #{params[:search].to_i } or #{Course.table_name}.name like :p)",:p=>search).select { |course| User.current.has_teacher_role(course)}
    else
      @courses = User.current.courses.where("is_delete = 0 and is_end = 0").select { |course| User.current.has_teacher_role(course)}
    end
    @resource_ids = params[:check_resource] if params[:check_resource]
    @homework_ids = params[:check_homework] if params[:check_homework]
    @search = params[:search]
    #这里仅仅是传递需要发送的资源id
    @type = params[:type]
    respond_to do |format|
      format.js
    end
  end

  def send_resources_to_course
    course = Course.find params[:course_id]
    if course
      params[:resource_id].each do |resource_id|
        resource = ResourceBank.find resource_id
        quote_resource_bank resource, course
      end
    end
  end

  def send_homeworks_to_course
    course = Course.find params[:course_id]
    if course
      params[:homework_id].each do |homework_id|
        homework = HomeworkBank.find homework_id
        quote_homework_bank homework, course
      end
    end
  end

  def send_r_and_h_to_course
    course = Course.find params[:course_id]
    if course
      resources = sy_resources @syllabus
      homeworks = @syllabus.homework_banks.order("#{@order} #{@sort}")

      ActiveRecord::Base.transaction do
        begin
          resources.each do |resource|
            quote_resource_bank resource, course
          end

          homeworks.each do |homework|
            quote_homework_bank homework, course
          end
        rescue Exception => e
          puts e
        end
      end
    end
  end

  def delete_syllabus
    respond_to do |format|
      format.js
    end
  end

  #删除课程大纲的描述
  def delete_des
    if @syllabus
      @syllabus.description = Message.where("id = 19412").first.nil? ? '' : Message.where("id = 19412").first.content
      @syllabus.des_status = 0
      @syllabus.attachments.destroy_all
      if @syllabus.save
        redirect_to syllabus_path(@syllabus)
      end
    end
  end

  def destroy
    if @syllabus && @syllabus.courses.not_deleted.empty?
      @syllabus.destroy
      redirect_to syllabuses_path()
    end
  end


  #班级列表 list_type: 1 班级列表  2 归档班级列表
  def syllabus_courselist
    @list_type = params[:list_type].to_i || 0
    @order, @c_sort,@type = params[:order] || 1, params[:sort] || 1, params[:type] || 1

    #确定 sort_type
    if @order.to_i == @type.to_i
      @c_sort = @c_sort.to_i == 1 ? 2 : 1   #1升序 2降序
    else
      @c_sort = 2
    end

    sort_name = "updated_on"
    sort_type = @c_sort == 1 ? "asc" : "desc"

    @courses = @syllabus.courses.where("is_delete = ?", @list_type).select("courses.*,(SELECT MAX(updated_at)  FROM `course_activities` WHERE course_activities.course_id = courses.id) AS #{sort_name}").order("#{sort_name} #{sort_type}")

    #根据 作业+资源数排序
    if @order.to_i == 2
      @type = 2
      @courses.each do |course|
        course[:infocount] = (User.current.admin? || User.current.allowed_to?(:as_teacher,course)) ? (course.homework_commons.count + visable_attachemnts_incourse(course).count) : (course.homework_commons.where("publish_time <= '#{Time.now}'").count + visable_attachemnts_incourse(course).count)
        if course[:infocount] < 0
          course[:infocount] = 0
        end
      end
      @c_sort == 1 ? (@courses = @courses.sort{|x,y| x[:infocount] <=> y[:infocount] }) : (@courses = @courses.sort{|x,y| y[:infocount] <=> x[:infocount]})
      @courses = sortby_time_countcommon_nosticky @courses,sort_name
    else
      @type = 1
    end

    #分页
    @limit = 10
    @is_remote = true
    @atta_count = @courses.count
    @atta_pages = Paginator.new @atta_count, @limit, params['page'] || 1
    @offset ||= @atta_pages.offset
    @courses = paginateHelper @courses,@limit

    respond_to do |format|
      format.js
      format.html{render :layout => 'base_syllabus'}
    end
  end

  #修改课程名称
  def edit_syllabus_title
    if @syllabus && params[:title] != ""
      @syllabus.update_column("title",params[:title])
    end
    respond_to do |format|
      format.js
    end
  end

  #修改英文名称
  def edit_syllabus_eng_name
    if @syllabus
      @syllabus.update_column("eng_name",params[:eng_name])
    end
    respond_to do |format|
      format.js
    end
  end

  #编辑属性
  def update_base_info
    if @syllabus
      @syllabus.update_attributes(:credit => params[:credit], :hours => params[:hours], :theory_hours => params[:theory_hours], :practice_hours => params[:practice_hours], :applicable_major => params[:applicable_major], :pre_course => params[:pre_course])
      @syllabus.update_attributes(:syllabus_type => params[:syllabus_type])
      respond_to do |format|
        format.js
      end
    end
  end

  def members
    @members = @syllabus.syllabus_members.includes(:user => {:user_extensions => [], :courses => []}).order("rank asc")
    @show = params[:show] ? params[:show].to_i : 0
    respond_to do |format|
      format.js
      format.html{render :layout => 'base_syllabus'}
    end
  end

  def get_discipline_categories
    data = {result:0,options:[]}
    if params[:major_level]
      if DisciplineCategory.where(:major_level => params[:major_level].to_i).count > 0
        data[:result] = 1
        DisciplineCategory.where(:major_level => params[:major_level].to_i).each do |dis|
          option = []
          option << dis.name.to_s
          option << dis.id
          data[:options] << option
        end
      end
    end

    render :json =>data
  end

  def get_first_level_disciplines
    data = {result:0,options:[]}
    if params[:discipline_category_id]
      if FirstLevelDiscipline.where(:discipline_category_id => params[:discipline_category_id].to_i).count > 0
        data[:result] = 1
        FirstLevelDiscipline.where(:discipline_category_id => params[:discipline_category_id].to_i).each do |dis|
          option = []
          option << dis.name.to_s
          option << dis.id
          data[:options] << option
        end
      end
    end

    render :json =>data
  end

  def get_major
    data = {result:0,options:[]}
    if params[:first_level_discipline_id]
      if Major.where(:first_level_discipline_id => params[:first_level_discipline_id].to_i).count > 0
        data[:result] = 1
        Major.where(:first_level_discipline_id => params[:first_level_discipline_id].to_i).each do |dis|
          option = []
          option << dis.name.to_s
          option << dis.id
          data[:options] << option
        end
      end
    end

    render :json =>data
  end

  private
  def find_syllabus
    @syllabus = Syllabus.find params[:id]
  end

  def is_logged
    redirect_to signin_path unless User.current.logged?
  end
end