All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.openurp.edu.graduation.plan.domain.StdGrade.scala Maven / Gradle / Ivy

There is a newer version: 0.18.1
Show newest version
/*
 * OpenURP, Agile University Resource Planning Solution.
 *
 * Copyright © 2014, The OpenURP Software.
 *
 * 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 3 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, see .
 */
package org.openurp.edu.graduation.plan.domain

import org.beangle.commons.bean.orderings.MultiPropertyOrdering
import org.beangle.commons.collection.Collections
import org.openurp.edu.base.model.Course
import org.openurp.edu.grade.course.model.CourseGrade

class StdGrade(val grades: collection.Seq[CourseGrade]) {

  private val gradeMap = grades.sorted(new MultiPropertyOrdering("course,score desc")).groupBy(g => g.course)

  private val usedCourses = Collections.newSet[Course]

  private val noGradeCourses = Collections.newSet[Course]

  /**
   * 查询课程对应的成绩,不会被标记为usedCourses
   *
   */
  def getGrades(course: Course): collection.Seq[CourseGrade] = {
    if (noGradeCourses.contains(course)) return List.empty
    gradeMap.get(course).getOrElse(List.empty)
  }

  /**
   * 使用课程课程拿成绩之后,会被标记为usedCourses
   */
  def useGrades(course: Course): collection.Seq[CourseGrade] = {
    if (noGradeCourses.contains(course)) {
      List.empty
    } else {
      usedCourses += course
      gradeMap.get(course) match {
        case None => List.empty
        case Some(l) => l.toList
      }
    }
  }

  /**
   * 拿到还未使用过的课程
   *
   */
  def restCourses: Set[Course] = {
    gradeMap.keySet -- usedCourses
  }

  /**
   * 获得一个课程的成绩,并且会标记该课程已被使用过
   *
   */
  def addNoGradeCourse(course: Course): Unit = {
    noGradeCourses += course
  }

  /**
   * 返回每个课程是否通过
   */
  def getCoursePassedMap: Map[Long, Boolean] = {
    gradeMap.map {
      case (k, l) => k.id -> l.exists(_.passed)
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy