Ejemplo n.º 1
0
 public function executeSaveScoreEks()
 {
     $counsel_id = $this->getRequestParameter('counseling_id');
     $counseling = CounselingPeer::retrieveByPK($counsel_id);
     $this->forward404Unless($counseling);
     $this->counseling = $counseling;
     $accal_id = $this->getRequestParameter('accal_id');
     $academic_calendar = AcademicCalendarPeer::retrieveByPK($accal_id);
     $this->forward404Unless($academic_calendar);
     $this->academic_calendar = $academic_calendar;
     $schedule = SchedulePeer::retrieveByPk($this->getRequestParameter('schedule_id'));
     $this->forward404Unless($schedule);
     $this->schedule = $schedule;
     $schedule_detail = ScheduleDetailPeer::retrieveByPk($this->getRequestParameter('detail_id'));
     $this->forward404Unless($schedule_detail);
     $this->schedule_detail = $schedule_detail;
     $cj = new Criteria();
     $cj->add(GradeConversionPeer::DEPARTMENT_ID, $academic_calendar->getDepartmentId());
     $cj->add(GradeConversionPeer::GRADE_CONVERSION_TEMPLATE_ID, 19);
     $cj->add(GradeConversionPeer::TYPE_CONVERSION, ScoreRule::FIVE);
     $cj->addDescendingOrderByColumn(GradeConversionPeer::MAX_VALUE);
     $grade_convs = GradeConversionPeer::doSelect($cj);
     $scores = $this->getRequestParameter('score');
     foreach ($scores as $k => $score) {
         if ($score != null) {
             if ($score != '-') {
                 $ids = split('_', $k);
                 ## $ids[0] = Cur13 Ekskul Id
                 ## $ids[1] = Grade Spec Id
                 $c = new Criteria();
                 $c->add(Cur13GradeEkskulPeer::CUR13_EKSKUL_ID, $ids[0]);
                 $c->add(Cur13GradeEkskulPeer::GRADE_SPEC_ID, $ids[1]);
                 $cur13_grade_ekskul = Cur13GradeEkskulPeer::doSelectOne($c);
                 if ($cur13_grade_ekskul == null) {
                     $cur13_grade_ekskul = new Cur13GradeEkskul();
                 }
                 $cur13_grade_ekskul->setCur13EkskulId($ids[0]);
                 $cur13_grade_ekskul->setGradeSpecId($ids[1]);
                 $cur13_grade_ekskul->setGrade($score);
                 $cur13_grade_ekskul->save();
                 $cc = new Criteria();
                 $cc->add(Cur13GradeEkskulPeer::CUR13_EKSKUL_ID, $ids[0]);
                 $cur13_grades = Cur13GradeEkskulPeer::doSelect($cc);
                 if ($cur13_grades) {
                     $total = 0;
                     $count = 0;
                     foreach ($cur13_grades as $cur13_grade) {
                         $count += 1;
                         $total += $cur13_grade->getGrade();
                     }
                     $avg = round($total / $count);
                     $scale = number_format($avg / 100 * 4, 2);
                     $remark = '';
                     foreach ($grade_convs as $gc) {
                         if ($avg >= $gc->getMinValue() && $avg < $gc->getMaxValue() + 1) {
                             $remark = $gc->getName();
                         }
                     }
                     $cur13_ekskul = Cur13EkskulPeer::retrieveByPK($ids[0]);
                     $cur13_ekskul->setGradeScale($scale);
                     $cur13_ekskul->setGrade($avg);
                     $cur13_ekskul->setRemark($remark);
                     $cur13_ekskul->save();
                 }
             } else {
                 $ids = split('_', $k);
                 ## $ids[0] = Cur13 Ekskul Id
                 ## $ids[1] = Grade Spec Id
                 $c = new Criteria();
                 $c->add(Cur13GradeEkskulPeer::CUR13_EKSKUL_ID, $ids[0]);
                 $c->add(Cur13GradeEkskulPeer::GRADE_SPEC_ID, $ids[1]);
                 $cur13_grade_ekskul = Cur13GradeEkskulPeer::doSelectOne($c);
                 if ($cur13_grade_ekskul != null) {
                     $cur13_grade_ekskul->delete();
                 }
             }
         }
     }
     return $this->redirect('counseling_sd/listEksStu?id=' . $schedule->getId() . '&detail_id=' . $schedule_detail->getId() . '&accal_id=' . $academic_calendar->getId() . '&counseling_id=' . $counseling->getId());
 }
Ejemplo n.º 2
0
 public function addCur13GradeEkskul(Cur13GradeEkskul $l)
 {
     $this->collCur13GradeEkskuls[] = $l;
     $l->setCur13Ekskul($this);
 }