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

org.openurp.edu.program.plan.model.AbstractCourseGroup.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.program.plan.model

import scala.collection.mutable.{ Buffer, ListBuffer }

import org.beangle.commons.lang.{ Numbers, Strings }
import org.beangle.data.model.LongId
import org.beangle.data.model.pojo.{ Named, Remark }
import org.openurp.edu.base.code.model.CourseType
import org.openurp.edu.base.model.Terms

/**
 * 课程设置中的课程组 

* * @author chaostone * @since 2009 */ abstract class AbstractCourseGroup extends LongId with CourseGroup with Cloneable with Ordered[CourseGroup] with Remark { /** * 计划 */ var plan: CoursePlan = _ /** * 上级组 */ var parent: Option[CourseGroup] = None /** * 下级组列表 */ var children: Buffer[AbstractCourseGroup] = new ListBuffer[AbstractCourseGroup] /** * 计划课程列表 */ var planCourses: Buffer[PlanCourse] = new ListBuffer[PlanCourse] /** * 课程类别 */ var courseType: CourseType = _ /** * 要求学分 */ var credits: Float = _ /** * 要求完成组数 */ var subCount: Short = _ /** * 要求门数 */ var courseCount: Short = _ /** * 学期学分分布 */ var termCredits: String = _ /** * index no */ var indexno: String = _ override def name: String = { courseType.name } def index(): Int = { var index = Strings.substringAfterLast(indexno, ".") if (Strings.isEmpty(index)) index = indexno var idx = Numbers.toInt(index) if (idx <= 0) idx = 1 idx } def compulsory: Boolean = { val requiredSubCount = if (subCount == -1) children.size else subCount (requiredSubCount == children.size && !planCourses.exists(p => !p.compulsory)) } def addGroup(group: AbstractCourseGroup) { group.parent = Some(this) children += group } def addCourse(planCourse: AbstractPlanCourse): Unit = { if (planCourses.exists(_.course == planCourse.course)) return planCourse.group = this planCourses += planCourse } def removeCourse(pc: PlanCourse) { planCourses -= pc } /** * 添加计划课程 */ def addCourses(planCourses: Iterable[AbstractPlanCourse]) { for (element <- planCourses) { addCourse(element) } } def follow(plan: CoursePlan) { this.plan = plan children.foreach { c => c.follow(plan) } } def planCourses(terms: Terms): Seq[PlanCourse] = { if (Strings.isEmpty(null)) return planCourses.toList planCourses.filter(pc => pc.terms.matches(terms)) } override def compare(o: CourseGroup): Int = { indexno.compareTo(o.indexno) } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy