public function doSave($con = null)
 {
     if (is_null($con)) {
         $con = $this->getConnection();
     }
     $course_subject = $this->getObject();
     $values = $this->getValues();
     $c = new Criteria();
     if ($this->getCourseType() == CourseType::BIMESTER) {
         $c->add(CareerSchoolYearPeriodPeer::CAREER_SCHOOL_YEAR_PERIOD_ID, $values['quaterly_id']);
     } else {
         $c->add(CareerSchoolYearPeriodPeer::ID, $values['quaterly_id']);
     }
     $periods = CareerSchoolYearPeriodPeer::doSelect($c);
     try {
         $con->beginTransaction();
         $cscs = CourseSubjectConfigurationPeer::retrieveBySubject($course_subject);
         foreach ($cscs as $csc) {
             $csc->delete($con);
         }
         foreach ($periods as $period) {
             $csc = new CourseSubjectConfiguration();
             $csc->setCourseSubject($course_subject);
             $csc->setCareerSchoolYearPeriod($period);
             $csc->save($con);
         }
         $con->commit();
     } catch (Exception $e) {
         $con->rollBack();
         throw $e;
     }
 }
Exemple #2
0
 public function deleteCourseSubjectConfiguration()
 {
     foreach (CourseSubjectConfigurationPeer::retrieveBySubject($this) as $csc) {
         $csc->delete();
     }
 }
Exemple #3
0
 public function getCourseSubjectStudentsForBimesterQuaterly($quaterly, $student_career_school_year = null)
 {
     $results = array();
     foreach ($this->getCourseSubjectStudentsForCourseType(CourseType::BIMESTER, $student_career_school_year) as $css) {
         $subject_configurations = CourseSubjectConfigurationPeer::retrieveBySubject($css->getCourseSubject());
         foreach ($subject_configurations as $sc) {
             if ($sc->getCareerSchoolYearPeriod()->getCareerSchoolYearPeriodId() == $quaterly->getId()) {
                 $results[$css->getId()] = $css;
             }
         }
     }
     return $results;
 }