/**
  * Creates data provider instance with search query applied
  *
  * @param array $params
  *
  * @return ActiveDataProvider
  */
 public function search($params, $way = null)
 {
     if ($way == null) {
         $query = GivenTask::find();
     } else {
         $query = $way;
     }
     $query->joinWith('user');
     $query->joinWith('groupHasDiscipline');
     $query->joinWith('task');
     $query->joinWith('student')->joinWith('student.group');
     $dataProvider = new ActiveDataProvider(['query' => $query, 'sort' => ['defaultOrder' => ['status' => SORT_ASC, 'given_date' => SORT_DESC]]]);
     $dataProvider->setSort(['attributes' => ['studentFullname' => ['asc' => ['user.last_name' => SORT_ASC, 'user.middle_name' => SORT_ASC, 'user.first_name' => SORT_ASC], 'desc' => ['user.last_name' => SORT_DESC, 'user.middle_name' => SORT_DESC, 'user.first_name' => SORT_DESC]], 'teacherFullname' => ['asc' => ['user.last_name' => SORT_ASC, 'user.middle_name' => SORT_ASC, 'user.first_name' => SORT_ASC], 'desc' => ['user.last_name' => SORT_DESC, 'user.middle_name' => SORT_DESC, 'user.first_name' => SORT_DESC]], 'group' => ['asc' => ['student.group.name' => SORT_ASC], 'desc' => ['student.group.name' => SORT_DESC]], 'id', 'status']]);
     $this->load($params);
     if (!$this->validate()) {
         // uncomment the following line if you do not want to return any records when validation fails
         // $query->where('0=1');
         return $dataProvider;
     }
     $query->andFilterWhere(['id' => $this->id, 'given_task.given_date' => $this->given_date, 'given_task.teacher_id' => $this->teacher_id, 'given_task.status' => $this->status, 'given_task.result' => $this->result, 'given_task.complete_date' => $this->complete_date]);
     $query->andFilterWhere(['like', 'comment', $this->comment])->andFilterWhere(['like', 'group_key', $this->group_key])->andFilterWhere(['like', 'task.name', $this->task_id]);
     //->andFilterWhere(['like','user.last_name',$this->student_id]);
     $query->joinWith(['task' => function ($q) {
         $q->where('task.name LIKE "%' . $this->taskName . '%" ');
     }]);
     $query->joinWith('student')->joinWith(['student.user as suser' => function ($q) {
         $q->where('suser.first_name LIKE "%' . $this->studentFullname . '%" ' . 'OR suser.last_name LIKE "%' . $this->studentFullname . '%"' . 'OR suser.middle_name LIKE "%' . $this->studentFullname . '%"');
     }]);
     $query->joinWith('groupHasDiscipline')->joinWith(['groupHasDiscipline.discipline' => function ($q) {
         $q->where('discipline.name LIKE "%' . $this->disciplineName . '%" ');
     }]);
     $query->joinWith('teacher')->joinWith(['teacher.user as tuser' => function ($q) {
         $q->where('tuser.first_name LIKE "%' . $this->teacherFullname . '%" ' . 'OR tuser.last_name LIKE "%' . $this->teacherFullname . '%"' . 'OR tuser.middle_name LIKE "%' . $this->teacherFullname . '%"');
     }]);
     $query->joinWith('student')->joinWith(['student.group as sgroup' => function ($q) {
         $q->where('sgroup.name LIKE "%' . $this->group . '%"');
     }]);
     return $dataProvider;
 }
Beispiel #2
0
 public function getNewTasksCheckCount()
 {
     return GivenTask::find()->where(['teacher_id' => Yii::$app->user->identity->teacher->id])->andWhere(['status' => '1'])->count();
 }
 /**
  * @taken tasks
  */
 public function actionTaken()
 {
     $searchModel = new GivenTaskSearch();
     $query = GivenTask::find()->where(['student_id' => Yii::$app->user->identity->student->id])->orderBy('status');
     $dataProvider = $searchModel->search(Yii::$app->request->queryParams, $query);
     return $this->render('taken_tasks_list', ['dataProvider' => $dataProvider, 'searchModel' => $searchModel]);
 }
Beispiel #4
0
 public function getTasksCount()
 {
     return GivenTask::find()->where(['student_id' => $this->id])->count();
 }
Beispiel #5
0
 public static function newTakenTasksCount()
 {
     return GivenTask::find()->where(['student_id' => Yii::$app->user->identity->student->id])->andWhere(['!=', 'status', '3'])->count();
 }
Beispiel #6
0
 /**
  * @taken tasks
  */
 public function actionTaken($id = NULL)
 {
     if (Yii::$app->request->isAjax) {
         $takenTask = GivenTask::find($id)->one();
         if (isset(Yii::$app->request->post()['close'])) {
             return $this->render('taken_task', ['takenTask' => $takenTask, 'openform' => false]);
         } elseif (isset(Yii::$app->request->post()['submit'])) {
             $cEx = new \common\models\CompleteExercise();
             $cEx->text = Yii::$app->request->post()['textarea'];
             $cEx->save();
             return $this->render('taken_task', ['takenTask' => $takenTask, 'complete' => true]);
         } else {
             return $this->render('taken_task', ['takenTask' => $takenTask, 'openform' => true]);
         }
     }
     if ($id == NULL || !GivenTask::findOne($id)) {
         $searchModel = new GivenTaskSearch();
         $query = GivenTask::find()->where(['student_id' => Yii::$app->user->identity->student->id]);
         $dataProvider = $searchModel->search(Yii::$app->request->queryParams, $query);
         return $this->render('taken_tasks_list', ['dataProvider' => $dataProvider, 'searchModel' => $searchModel]);
     } else {
         $takenTask = GivenTask::findOne($id);
         if ($takenTask->student_id != Yii::$app->user->identity->student->id) {
             throw new ForbiddenHttpException('У вас нет доступа к этому заданию.');
         }
         return $this->render('taken_task', ['takenTask' => $takenTask]);
     }
 }