123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977 |
- <?php
- /* For licensing terms, see /license.txt */
- use Chamilo\CoreBundle\Entity\GradebookEvaluation;
- use ChamiloSession as Session;
- /**
- * Class Evaluation.
- *
- * @package chamilo.gradebook
- */
- class Evaluation implements GradebookItem
- {
- public $studentList;
- /** @var GradebookEvaluation */
- public $entity;
- private $id;
- private $name;
- private $description;
- private $user_id;
- private $course_code;
- /** @var Category */
- private $category;
- private $created_at;
- private $weight;
- private $eval_max;
- private $visible;
- private $sessionId;
- /**
- * Construct.
- */
- public function __construct()
- {
- }
- /**
- * @return Category
- */
- public function getCategory()
- {
- return $this->category;
- }
- /**
- * @param Category $category
- */
- public function setCategory($category)
- {
- $this->category = $category;
- }
- /**
- * @return int
- */
- public function get_category_id()
- {
- return $this->category->get_id();
- }
- /**
- * @param int $category_id
- */
- public function set_category_id($category_id)
- {
- $categories = Category::load($category_id);
- if (isset($categories[0])) {
- $this->setCategory($categories[0]);
- }
- }
- /**
- * @return int
- */
- public function get_id()
- {
- return (int) $this->id;
- }
- /**
- * @return string
- */
- public function get_name()
- {
- return $this->name;
- }
- /**
- * @return string
- */
- public function get_description()
- {
- return $this->description;
- }
- public function get_user_id()
- {
- return $this->user_id;
- }
- public function get_course_code()
- {
- return $this->course_code;
- }
- /**
- * @return int
- */
- public function getSessionId()
- {
- return $this->sessionId;
- }
- /**
- * @param int $sessionId
- */
- public function setSessionId($sessionId)
- {
- $this->sessionId = (int) $sessionId;
- }
- public function get_date()
- {
- return $this->created_at;
- }
- public function get_weight()
- {
- return $this->weight;
- }
- public function get_max()
- {
- return $this->eval_max;
- }
- public function get_type()
- {
- return $this->type;
- }
- public function is_visible()
- {
- return $this->visible;
- }
- public function get_locked()
- {
- return $this->locked;
- }
- public function is_locked()
- {
- return isset($this->locked) && $this->locked == 1 ? true : false;
- }
- public function set_id($id)
- {
- $this->id = (int) $id;
- }
- public function set_name($name)
- {
- $this->name = $name;
- }
- public function set_description($description)
- {
- $this->description = $description;
- }
- public function set_user_id($user_id)
- {
- $this->user_id = $user_id;
- }
- public function set_course_code($course_code)
- {
- $this->course_code = $course_code;
- }
- public function set_date($date)
- {
- $this->created_at = $date;
- }
- public function set_weight($weight)
- {
- $this->weight = $weight;
- }
- public function set_max($max)
- {
- $this->eval_max = $max;
- }
- public function set_visible($visible)
- {
- $this->visible = $visible;
- }
- public function set_type($type)
- {
- $this->type = $type;
- }
- public function set_locked($locked)
- {
- $this->locked = $locked;
- }
- /**
- * Retrieve evaluations and return them as an array of Evaluation objects.
- *
- * @param int $id evaluation id
- * @param int $user_id user id (evaluation owner)
- * @param string $course_code course code
- * @param int $category_id parent category
- * @param int $visible visible
- *
- * @return array
- */
- public static function load(
- $id = null,
- $user_id = null,
- $course_code = null,
- $category_id = null,
- $visible = null,
- $locked = null
- ) {
- $table = Database::get_main_table(TABLE_MAIN_GRADEBOOK_EVALUATION);
- $sql = 'SELECT * FROM '.$table;
- $paramcount = 0;
- if (isset($id)) {
- $sql .= ' WHERE id = '.intval($id);
- $paramcount++;
- }
- if (isset($user_id)) {
- if ($paramcount != 0) {
- $sql .= ' AND';
- } else {
- $sql .= ' WHERE';
- }
- $sql .= ' user_id = '.intval($user_id);
- $paramcount++;
- }
- if (isset($course_code) && $course_code != '-1') {
- $courseInfo = api_get_course_info($course_code);
- if ($courseInfo) {
- if ($paramcount != 0) {
- $sql .= ' AND';
- } else {
- $sql .= ' WHERE';
- }
- $sql .= " c_id = '".$courseInfo['real_id']."'";
- $paramcount++;
- }
- }
- if (isset($category_id)) {
- if ($paramcount != 0) {
- $sql .= ' AND';
- } else {
- $sql .= ' WHERE';
- }
- $sql .= ' category_id = '.intval($category_id);
- $paramcount++;
- }
- if (isset($visible)) {
- if ($paramcount != 0) {
- $sql .= ' AND';
- } else {
- $sql .= ' WHERE';
- }
- $sql .= ' visible = '.intval($visible);
- $paramcount++;
- }
- if (isset($locked)) {
- if ($paramcount != 0) {
- $sql .= ' AND';
- } else {
- $sql .= ' WHERE';
- }
- $sql .= ' locked = '.intval($locked);
- }
- $result = Database::query($sql);
- $allEval = self::create_evaluation_objects_from_sql_result($result);
- return $allEval;
- }
- /**
- * Insert this evaluation into the database.
- */
- public function add()
- {
- if (isset($this->name) &&
- isset($this->user_id) &&
- isset($this->weight) &&
- isset($this->eval_max) &&
- isset($this->visible)
- ) {
- if (empty($this->type)) {
- $this->type = 'evaluation';
- }
- $em = Database::getManager();
- $evaluation = new GradebookEvaluation();
- $evaluation
- ->setDescription($this->description)
- ->setCourse(api_get_course_entity())
- ->setName($this->get_name())
- ->setCategoryId($this->get_category_id())
- ->setUserId($this->get_user_id())
- ->setWeight(api_float_val($this->get_weight()))
- ->setMax($this->get_max())
- ->setVisible($this->is_visible())
- ->setType($this->type)
- ;
- $em->persist($evaluation);
- $em->flush();
- $this->set_id($evaluation->getId());
- }
- return false;
- }
- /**
- * @param int $id
- */
- public function addEvaluationLog($id)
- {
- if (!empty($id)) {
- $tbl_grade_evaluations = Database::get_main_table(TABLE_MAIN_GRADEBOOK_EVALUATION);
- $tbl_grade_linkeval_log = Database::get_main_table(TABLE_MAIN_GRADEBOOK_LINKEVAL_LOG);
- $eval = new Evaluation();
- $dateobject = $eval->load($id, null, null, null, null);
- $arreval = get_object_vars($dateobject[0]);
- if (!empty($arreval['id'])) {
- $sql = 'SELECT weight from '.$tbl_grade_evaluations.'
- WHERE id='.$arreval['id'];
- $rs = Database::query($sql);
- $row_old_weight = Database::fetch_array($rs, 'ASSOC');
- $current_date = api_get_utc_datetime();
- $params = [
- 'id_linkeval_log' => $arreval['id'],
- 'name' => $arreval['name'],
- 'description' => $arreval['description'],
- 'created_at' => $current_date,
- 'weight' => $row_old_weight['weight'],
- 'visible' => $arreval['visible'],
- 'type' => 'evaluation',
- 'user_id_log' => api_get_user_id(),
- ];
- Database::insert($tbl_grade_linkeval_log, $params);
- }
- }
- }
- /**
- * Update the properties of this evaluation in the database.
- */
- public function save()
- {
- $tbl_grade_evaluations = Database::get_main_table(TABLE_MAIN_GRADEBOOK_EVALUATION);
- $sql = 'UPDATE '.$tbl_grade_evaluations
- ." SET name = '".Database::escape_string($this->get_name())."'"
- .', description = ';
- if (isset($this->description)) {
- $sql .= "'".Database::escape_string($this->get_description())."'";
- } else {
- $sql .= 'null';
- }
- $sql .= ', user_id = '.intval($this->get_user_id())
- .', c_id = ';
- if (isset($this->courseId)) {
- $sql .= "'".Database::escape_string($this->getCourseId())."'";
- } else {
- $sql .= 'null';
- }
- $sql .= ', category_id = ';
- if (isset($this->category)) {
- $sql .= intval($this->get_category_id());
- } else {
- $sql .= 'null';
- }
- $sql .= ', weight = "'.Database::escape_string($this->get_weight()).'" '
- .', max = '.intval($this->get_max())
- .', visible = '.intval($this->is_visible())
- .' WHERE id = '.intval($this->id);
- //recorded history
- $eval_log = new Evaluation();
- $eval_log->addEvaluationLog($this->id);
- Database::query($sql);
- }
- /**
- * Delete this evaluation from the database.
- */
- public function delete()
- {
- $table = Database::get_main_table(TABLE_MAIN_GRADEBOOK_EVALUATION);
- $sql = 'DELETE FROM '.$table.'
- WHERE id = '.$this->get_id();
- Database::query($sql);
- }
- /**
- * Check if an evaluation name (with the same parent category) already exists.
- *
- * @param string $name to check (if not given, the name property of this object will be checked)
- * @param $parent parent category
- *
- * @return bool
- */
- public function does_name_exist($name, $parent)
- {
- if (!isset($name)) {
- $name = $this->name;
- $parent = $this->category;
- }
- $tbl_grade_evaluations = Database::get_main_table(TABLE_MAIN_GRADEBOOK_EVALUATION);
- $sql = "SELECT count(id) AS number
- FROM $tbl_grade_evaluations
- WHERE name = '".Database::escape_string($name)."'";
- if (api_is_allowed_to_edit()) {
- $parent = Category::load($parent);
- $courseId = $parent[0]->getCourseId();
- if (isset($courseId) && !empty($courseId)) {
- $table = Database :: get_main_table(TABLE_MAIN_COURSE_USER);
- $sql .= ' AND user_id IN (
- SELECT user_id FROM '.$table.'
- WHERE
- c_id = '.$courseId.' AND
- status = '.COURSEMANAGER.'
- )';
- } else {
- $sql .= ' AND user_id = '.api_get_user_id();
- }
- } else {
- $sql .= ' AND user_id = '.api_get_user_id();
- }
- if (!isset($parent)) {
- $sql .= ' AND category_id is null';
- } else {
- $sql .= ' AND category_id = '.intval($parent);
- }
- $result = Database::query($sql);
- $number = Database::fetch_row($result);
- return $number[0] != 0;
- }
- /**
- * Are there any results for this evaluation yet ?
- * The 'max' property should not be changed then.
- *
- * @return bool
- */
- public function has_results()
- {
- $table = Database::get_main_table(TABLE_MAIN_GRADEBOOK_RESULT);
- $sql = 'SELECT count(id) AS number
- FROM '.$table.'
- WHERE evaluation_id = '.intval($this->get_id());
- $result = Database::query($sql);
- $number = Database::fetch_row($result);
- return $number[0] != 0;
- }
- /**
- * Delete all results for this evaluation.
- */
- public function delete_results()
- {
- $table = Database::get_main_table(TABLE_MAIN_GRADEBOOK_RESULT);
- $sql = 'DELETE FROM '.$table.'
- WHERE evaluation_id = '.$this->get_id();
- Database::query($sql);
- }
- /**
- * Delete this evaluation and all underlying results.
- */
- public function delete_with_results()
- {
- $this->delete_results();
- $this->delete();
- }
- /**
- * Check if the given score is possible for this evaluation.
- */
- public function is_valid_score($score)
- {
- return is_numeric($score) && $score >= 0 && $score <= $this->eval_max;
- }
- /**
- * Calculate the score of this evaluation.
- *
- * @param int $stud_id (default: all students who have results for this eval - then the average is returned)
- * @param string $type (best, average, ranking)
- *
- * @return array (score, max) if student is given
- * array (sum of scores, number of scores) otherwise
- * or null if no scores available
- */
- public function calc_score($stud_id = null, $type = null)
- {
- $allowStats = api_get_configuration_value('allow_gradebook_stats');
- if ($allowStats) {
- $evaluation = $this->entity;
- if (!empty($evaluation)) {
- $weight = $evaluation->getMax();
- switch ($type) {
- case 'best':
- $bestResult = $evaluation->getBestScore();
- $result = [$bestResult, $weight];
- return $result;
- break;
- case 'average':
- $count = count($evaluation->getUserScoreList());
- if (empty($count)) {
- $result = [0, $weight];
- return $result;
- }
- $sumResult = array_sum($evaluation->getUserScoreList());
- $result = [$sumResult / $count, $weight];
- return $result;
- break;
- case 'ranking':
- $ranking = AbstractLink::getCurrentUserRanking($stud_id, $evaluation->getUserScoreList());
- return $ranking;
- break;
- default:
- $weight = $evaluation->getMax();
- if (!empty($stud_id)) {
- $scoreList = $evaluation->getUserScoreList();
- $result = [0, $weight];
- if (isset($scoreList[$stud_id])) {
- $result = [$scoreList[$stud_id], $weight];
- }
- return $result;
- } else {
- $studentCount = count($evaluation->getUserScoreList());
- $sumResult = array_sum($evaluation->getUserScoreList());
- $result = [$sumResult, $studentCount];
- }
- return $result;
- break;
- }
- }
- }
- $useSession = true;
- if (isset($stud_id) && empty($type)) {
- $key = 'result_score_student_list_'.api_get_course_int_id().'_'.api_get_session_id().'_'.$this->id.'_'.$stud_id;
- $data = Session::read('calc_score');
- $results = isset($data[$key]) ? $data[$key] : null;
- if ($useSession == false) {
- $results = null;
- }
- $results = null;
- if (empty($results)) {
- $results = Result::load(null, $stud_id, $this->id);
- Session::write('calc_score', [$key => $results]);
- }
- $score = 0;
- /** @var Result $res */
- foreach ($results as $res) {
- $score = $res->get_score();
- }
- return [$score, $this->get_max()];
- } else {
- $count = 0;
- $sum = 0;
- $bestResult = 0;
- $weight = 0;
- $sumResult = 0;
- $key = 'result_score_student_list_'.api_get_course_int_id().'_'.api_get_session_id().'_'.$this->id;
- $data = Session::read('calc_score');
- $allResults = isset($data[$key]) ? $data[$key] : null;
- if ($useSession == false) {
- $allResults = null;
- }
- if (empty($allResults)) {
- $allResults = Result::load(null, null, $this->id);
- Session::write($key, $allResults);
- }
- $students = [];
- /** @var Result $res */
- foreach ($allResults as $res) {
- $score = $res->get_score();
- if (!empty($score) || $score == '0') {
- $count++;
- $sum += $score / $this->get_max();
- $sumResult += $score;
- if ($score > $bestResult) {
- $bestResult = $score;
- }
- $weight = $this->get_max();
- }
- $students[$res->get_user_id()] = $score;
- }
- if (empty($count)) {
- return [null, null];
- }
- switch ($type) {
- case 'best':
- return [$bestResult, $weight];
- break;
- case 'average':
- return [$sumResult / $count, $weight];
- break;
- case 'ranking':
- $students = [];
- /** @var Result $res */
- foreach ($allResults as $res) {
- $score = $res->get_score();
- $students[$res->get_user_id()] = $score;
- }
- return AbstractLink::getCurrentUserRanking($stud_id, $students);
- break;
- default:
- return [$sum, $count];
- break;
- }
- }
- }
- /**
- * Generate an array of possible categories where this evaluation can be moved to.
- * Notice: its own parent will be included in the list: it's up to the frontend
- * to disable this element.
- *
- * @return array 2-dimensional array - every element contains 3 subelements (id, name, level)
- */
- public function get_target_categories()
- {
- // - course independent evaluation
- // -> movable to root or other course independent categories
- // - evaluation inside a course
- // -> movable to root, independent categories or categories inside the course
- $user = api_is_platform_admin() ? null : api_get_user_id();
- $targets = [];
- $level = 0;
- $root = [0, get_lang('Main folder'), $level];
- $targets[] = $root;
- if (isset($this->courseId) && !empty($this->courseId)) {
- $crscats = Category::load(null, null, $this->course_code, 0);
- foreach ($crscats as $cat) {
- $targets[] = [$cat->get_id(), $cat->get_name(), $level + 1];
- $targets = $this->addTargetSubcategories($targets, $level + 1, $cat->get_id());
- }
- }
- $indcats = Category::load(null, $user, 0, 0);
- foreach ($indcats as $cat) {
- $targets[] = [$cat->get_id(), $cat->get_name(), $level + 1];
- $targets = $this->addTargetSubcategories(
- $targets,
- $level + 1,
- $cat->get_id()
- );
- }
- return $targets;
- }
- /**
- * Move this evaluation to the given category.
- * If this evaluation moves from inside a course to outside,
- * its course code is also changed.
- */
- public function move_to_cat($cat)
- {
- $this->set_category_id($cat->get_id());
- if ($this->get_course_code() != $cat->get_course_code()) {
- $this->set_course_code($cat->get_course_code());
- }
- $this->save();
- }
- /**
- * Retrieve evaluations where a student has results for
- * and return them as an array of Evaluation objects.
- *
- * @param int $cat_id parent category (use 'null' to retrieve them in all categories)
- * @param int $stud_id student id
- *
- * @return array
- */
- public static function get_evaluations_with_result_for_student($cat_id = null, $stud_id)
- {
- $tbl_grade_evaluations = Database::get_main_table(TABLE_MAIN_GRADEBOOK_EVALUATION);
- $tbl_grade_results = Database::get_main_table(TABLE_MAIN_GRADEBOOK_RESULT);
- $sql = 'SELECT * FROM '.$tbl_grade_evaluations.'
- WHERE id IN (
- SELECT evaluation_id FROM '.$tbl_grade_results.'
- WHERE user_id = '.intval($stud_id).' AND score IS NOT NULL
- )';
- if (!api_is_allowed_to_edit()) {
- $sql .= ' AND visible = 1';
- }
- if (isset($cat_id)) {
- $sql .= ' AND category_id = '.intval($cat_id);
- } else {
- $sql .= ' AND category_id >= 0';
- }
- $result = Database::query($sql);
- $alleval = self::create_evaluation_objects_from_sql_result($result);
- return $alleval;
- }
- /**
- * Get a list of students that do not have a result record for this evaluation.
- *
- * @param string $first_letter_user
- *
- * @return array
- */
- public function get_not_subscribed_students($first_letter_user = '')
- {
- $tbl_user = Database::get_main_table(TABLE_MAIN_USER);
- $table = Database::get_main_table(TABLE_MAIN_GRADEBOOK_RESULT);
- $sql = "SELECT user_id,lastname,firstname,username
- FROM $tbl_user
- WHERE
- lastname LIKE '".Database::escape_string($first_letter_user)."%' AND
- status = ".STUDENT." AND user_id NOT IN (
- SELECT user_id FROM $table
- WHERE evaluation_id = ".$this->get_id()."
- )
- ORDER BY lastname";
- $result = Database::query($sql);
- $users = Database::store_result($result);
- return $users;
- }
- /**
- * Find evaluations by name.
- *
- * @param string $name_mask search string
- *
- * @return array evaluation objects matching the search criterium
- *
- * @todo can be written more efficiently using a new (but very complex) sql query
- */
- public function findEvaluations($name_mask, $selectcat)
- {
- $rootcat = Category::load($selectcat);
- $evals = $rootcat[0]->get_evaluations(
- (api_is_allowed_to_create_course() ? null : api_get_user_id()),
- true
- );
- $foundevals = [];
- foreach ($evals as $eval) {
- if (!(api_strpos(api_strtolower($eval->get_name()), api_strtolower($name_mask)) === false)) {
- $foundevals[] = $eval;
- }
- }
- return $foundevals;
- }
- public function get_item_type()
- {
- return 'E';
- }
- public function get_icon_name()
- {
- return $this->has_results() ? 'evalnotempty' : 'evalempty';
- }
- /**
- * Locks an evaluation, only one who can unlock it is the platform administrator.
- *
- * @param int locked 1 or unlocked 0
- */
- public function lock($locked)
- {
- $table_evaluation = Database::get_main_table(TABLE_MAIN_GRADEBOOK_EVALUATION);
- $sql = "UPDATE $table_evaluation
- SET locked = '".intval($locked)."'
- WHERE id='".$this->get_id()."'";
- Database::query($sql);
- }
- public function check_lock_permissions()
- {
- if (api_is_platform_admin()) {
- return true;
- } else {
- if ($this->is_locked()) {
- api_not_allowed();
- }
- }
- }
- public function delete_linked_data()
- {
- }
- /**
- * @return mixed
- */
- public function getStudentList()
- {
- return $this->studentList;
- }
- /**
- * @param $list
- */
- public function setStudentList($list)
- {
- $this->studentList = $list;
- }
- /**
- * @param int $evaluationId
- */
- public static function generateStats($evaluationId)
- {
- $allowStats = api_get_configuration_value('allow_gradebook_stats');
- if ($allowStats) {
- $evaluation = self::load($evaluationId);
- $results = Result::load(null, null, $evaluationId);
- $sumResult = 0;
- $bestResult = 0;
- $average = 0;
- $scoreList = [];
- if (!empty($results)) {
- /** @var Result $result */
- foreach ($results as $result) {
- $score = $result->get_score();
- $scoreList[$result->get_user_id()] = $score;
- $sumResult += $score;
- if ($score > $bestResult) {
- $bestResult = $score;
- }
- }
- $average = $sumResult / count($results);
- }
- /** @var Evaluation $evaluation */
- $evaluation = $evaluation[0];
- $evaluation = $evaluation->entity;
- $evaluation
- ->setBestScore($bestResult)
- ->setAverageScore($average)
- ->setUserScoreList($scoreList)
- ;
- $em = Database::getManager();
- $em->persist($evaluation);
- $em->flush();
- }
- }
- /**
- * @param int $courseId
- *
- * @return Evaluation
- */
- public function setCourseId($courseId)
- {
- $this->courseId = $courseId;
- return $this;
- }
- /**
- * @param array $result
- *
- * @return array
- */
- private static function create_evaluation_objects_from_sql_result($result)
- {
- $alleval = [];
- $allow = api_get_configuration_value('allow_gradebook_stats');
- if ($allow) {
- $em = Database::getManager();
- $repo = $em->getRepository('ChamiloCoreBundle:GradebookEvaluation');
- }
- if (Database::num_rows($result)) {
- while ($data = Database::fetch_array($result)) {
- $eval = new Evaluation();
- $eval->set_id($data['id']);
- $eval->set_name($data['name']);
- $eval->set_description($data['description']);
- $eval->set_user_id($data['user_id']);
- $eval->setCourseId($data['c_id']);
- $courseInfo = api_get_course_info_by_id($data['c_id']);
- $eval->set_course_code($courseInfo['code']);
- $eval->set_category_id($data['category_id']);
- $eval->set_date(api_get_local_time($data['created_at']));
- $eval->set_weight($data['weight']);
- $eval->set_max($data['max']);
- $eval->set_visible($data['visible']);
- $eval->set_type($data['type']);
- $eval->set_locked($data['locked']);
- $eval->setSessionId(api_get_session_id());
- if ($allow) {
- $eval->entity = $repo->find($data['id']);
- }
- $alleval[] = $eval;
- }
- }
- return $alleval;
- }
- /**
- * Internal function used by get_target_categories().
- *
- * @param array $targets
- * @param int $level
- * @param int $categoryId
- *
- * @return array
- */
- private function addTargetSubcategories($targets, $level, $categoryId)
- {
- $subcats = Category::load(null, null, null, $categoryId);
- foreach ($subcats as $cat) {
- $targets[] = [$cat->get_id(), $cat->get_name(), $level + 1];
- $targets = $this->addTargetSubcategories(
- $targets,
- $level + 1,
- $cat->get_id()
- );
- }
- return $targets;
- }
- }
|