41 $this->db = $DIC->database();
42 $this->survey = $a_survey;
45 $this->skill_profile_service = $DIC->skills()->profile();
46 $this->skill_personal_service = $DIC->skills()->personal();
47 $this->skill_usage_service = $DIC->skills()->usage();
50 public function read(): void
55 "SELECT * FROM svy_quest_skill " .
56 " WHERE survey_id = " .
$ilDB->quote($this->survey->getId(),
"integer")
59 while ($rec =
$ilDB->fetchAssoc($set)) {
61 $this->q_skill[(
int) $rec[
"q_id"]] = array(
62 "q_id" => (
int) $rec[
"q_id"],
63 "base_skill_id" => (
int) $rec[
"base_skill_id"],
64 "tref_id" => (
int) $rec[
"tref_id"]
78 return $this->q_skill[$a_question_id] ??
null;
90 foreach ($this->q_skill as $q_id => $s) {
91 if ($s[
"base_skill_id"] === $a_base_skill_id &&
92 $s[
"tref_id"] === $a_tref_id) {
108 int $a_base_skill_id,
115 array(
"q_id" => array(
"integer", $a_question_id)),
117 "survey_id" => array(
"integer", $this->survey->getId()),
118 "base_skill_id" => array(
"integer", $a_base_skill_id),
119 "tref_id" => array(
"integer", $a_tref_id)
122 $this->q_skill[$a_question_id] = array(
123 "q_id" => $a_question_id,
124 "base_skill_id" => $a_base_skill_id,
125 "tref_id" => $a_tref_id
129 $this->skill_usage_service->addUsage($this->survey->getId(), $a_base_skill_id, $a_tref_id);
139 "SELECT * FROM svy_quest_skill " .
140 " WHERE q_id = " .
$ilDB->quote($a_question_id,
"integer")
143 while ($rec =
$ilDB->fetchAssoc($set)) {
145 "skill_id" => $rec[
"base_skill_id"],
146 "tref_id" => $rec[
"tref_id"]
152 "DELETE FROM svy_quest_skill WHERE " .
153 " q_id = " .
$ilDB->quote($a_question_id,
"integer")
155 unset($this->q_skill[$a_question_id]);
169 $svy_log->debug(
"delete skill assignment, obj id " . $a_obj_id .
174 $svy_log->debug(
"call removeQuestionSkillAssignment.");
178 $svy_skill->removeQuestionSkillAssignment($a_question_id);
190 $used_skills = array();
191 foreach ($a_skills as $skill) {
193 $used_skills[] = $skill[
"skill_id"] .
":" . $skill[
"tref_id"];
199 foreach ($a_skills as $skill) {
200 if (!in_array($skill[
"skill_id"] .
":" . $skill[
"tref_id"], $used_skills,
true)) {
201 $this->skill_usage_service->removeUsage($this->survey->getId(), $skill[
"skill_id"], $skill[
"tref_id"]);
213 "SELECT * FROM svy_quest_skill " .
214 " WHERE base_skill_id = " .
$ilDB->quote($a_skill_id,
"integer") .
215 " AND tref_id = " .
$ilDB->quote($a_tref_id,
"integer") .
216 " AND survey_id = " .
$ilDB->quote($this->survey->getId(),
"integer")
218 if ($rec =
$ilDB->fetchAssoc($set)) {
231 foreach ($this->q_skill as $sk) {
244 bool $a_self_eval =
false,
251 foreach ($opts as $k => $title) {
252 $k = explode(
":", $k);
255 $ld = $bs->getLevelData();
258 "base_skill_id" => (
int) $k[0],
259 "tref_id" => (
int) $k[1],
260 "skill_title" => $title,
267 if ($finished_id > 0) {
268 $finished_ids = array($finished_id);
270 $finished_ids = $this->survey->getFinishedIdsForAppraiseeId($a_appraisee_id,
true);
273 $finished_id = $this->survey->getFinishedIdForAppraiseeIdAndRaterId($a_appraisee_id, $a_appraisee_id);
274 if ($finished_id > 0) {
275 $finished_ids = array($finished_id);
284 $results = $this->survey->getUserSpecificResults($finished_ids);
285 $this->log->debug(
"Finished IDS: " . print_r($finished_ids,
true));
286 foreach ($skills as $k => $s) {
288 $this->log->debug(
"Skill: " . $s[
"base_skill_id"] .
":" . $s[
"tref_id"] .
", Questions: " . implode(
",", $q_ids));
290 foreach ($q_ids as $q_id) {
295 foreach (
$results[$q_id] as $uid => $answer) {
300 $scale_values = array_keys($answer);
301 $this->log->debug(
"User answer (scale values): " . print_r($scale_values,
true));
302 $sum += array_sum($scale_values);
303 $cnt += count($scale_values);
306 $qmean = $sum / $cnt;
308 $this->log->debug(
"MEAN: " . $qmean);
311 $this->log->debug(
"MEAN SUM: " . $mean_sum);
313 $skills[$k][
"mean_sum"] = $mean_sum;
316 $thresholds = $skthr->getThresholds();
319 foreach ($skills[$k][
"level_data"] as $l) {
320 $t = $thresholds[$l[
"id"]][$s[
"tref_id"]] ?? 0;
321 if ($t > 0 && $mean_sum >= $t) {
322 $skills[$k][
"new_level"] = $l[
"title"];
323 $skills[$k][
"new_level_id"] = $l[
"id"];
324 $skills[$k][
"next_level_perc"] = 0;
325 } elseif ($t > 0 && $mean_sum < $t) {
327 if ($previous == ($skills[$k][
"new_level_id"] ??
null) && !isset($skills[$k][
"next_level_perc"])) {
328 $skills[$k][
"next_level_perc"] = 1 / ($t - $previous_t) * ($mean_sum - $previous_t);
332 $previous = $l[
"id"];
345 $question_ids = $ssk->getQuestionsForSkill($a_base_skill, $a_tref_id);
347 foreach ($question_ids as $q_id) {
349 if (!is_object(
$q)) {
352 $cats =
$q->getCategories();
354 for ($i = 0; $i < $cats->getCategoryCount(); $i++) {
355 $c = $cats->getCategory($i);
359 if (
$c->scale > $max_scale) {
360 $max_scale =
$c->scale;
364 $scale_sum += $max_scale;
378 foreach ($new_levels as $nl) {
379 if (($nl[
"new_level_id"] ?? 0) > 0) {
381 (
int) $nl[
"new_level_id"],
383 $this->survey->getRefId(),
384 (
int) $nl[
"tref_id"],
389 $nl[
"next_level_perc"]
392 if (($nl[
"tref_id"] ?? 0) > 0) {
393 $this->skill_personal_service->addPersonalSkill($user_id, (
int) $nl[
"tref_id"]);
395 $this->skill_personal_service->addPersonalSkill($user_id, (
int) $nl[
"base_skill_id"]);
401 $this->skill_profile_service->writeCompletionEntryForAllProfiles($user_id);
413 foreach ($new_levels as $nl) {
414 if (($nl[
"new_level_id"] ?? 0) > 0) {
416 (
int) $nl[
"new_level_id"],
418 $this->survey->getRefId(),
419 (
int) $nl[
"tref_id"],
424 $nl[
"next_level_perc"],
428 if (($nl[
"tref_id"] ?? 0) > 0) {
429 $this->skill_personal_service->addPersonalSkill($appr_id, (
int) $nl[
"tref_id"]);
431 $this->skill_personal_service->addPersonalSkill($appr_id, (
int) $nl[
"base_skill_id"]);
445 foreach ($new_levels as $nl) {
446 if (($nl[
"new_level_id"] ?? 0) > 0) {
448 (
int) $nl[
"new_level_id"],
450 $this->survey->getRefId(),
451 (
int) $nl[
"tref_id"],
456 $nl[
"next_level_perc"]
459 if (($nl[
"tref_id"] ?? 0) > 0) {
460 $this->skill_personal_service->addPersonalSkill($user_id, (
int) $nl[
"tref_id"]);
462 $this->skill_personal_service->addPersonalSkill($user_id, (
int) $nl[
"base_skill_id"]);
static getLogger(string $a_component_id)
Get component logger.
writeAndAddAppraiseeSkills(int $user_id)
Write appraisee skills and add them to user's competence records.
addQuestionSkillAssignment(int $a_question_id, int $a_base_skill_id, int $a_tref_id)
Add survey question to skill assignment.
static _lookupTitle(int $a_obj_id, int $a_tref_id=0)
__construct(ilObjSurvey $a_survey)
determineSkillLevelsForAppraisee(int $a_appraisee_id, bool $a_self_eval=false, int $finished_id=0)
Determine skill levels for appraisee.
writeAndAddIndFeedbackSkills(int $finished_id, int $appr_id, string $rater_id)
static handleQuestionDeletion(int $a_question_id, int $a_obj_id)
Remove question skill assignment.
writeAndAddSelfEvalSkills(int $user_id)
Write skills on self evaluation and add them to user's competence records.
getSkillForQuestion(int $a_question_id)
Get skill for question.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
ILIAS Skill Service SkillUsageService $skill_usage_service
static _exists(int $id, bool $reference=false, ?string $type=null)
checks if an object exists in object_data
determineMaxScale(int $a_base_skill, int $a_tref_id=0)
removeQuestionSkillAssignment(int $a_question_id)
static writeUserSkillLevelStatus(int $a_level_id, int $a_user_id, int $a_trigger_ref_id, int $a_tref_id=0, int $a_status=ilBasicSkill::ACHIEVED, bool $a_force=false, bool $a_self_eval=false, string $a_unique_identifier="", float $a_next_level_fulfilment=0.0, string $trigger_user_id="")
getQuestionsForSkill(int $a_base_skill_id, int $a_tref_id)
Get questions for skill.
removeUsagesOfSkills(array $a_skills)
Remove usages of skills This function checks, if the skills are really not in use anymore...
getAllAssignedSkillsAsOptions()
isSkillAssignedToQuestion(int $a_skill_id, int $a_tref_id)
ILIAS Skill Service SkillProfileService $skill_profile_service
ILIAS Skill Service SkillPersonalService $skill_personal_service
static _lookupType(int $id, bool $reference=false)
static _instanciateQuestion(int $question_id)
Get question object.
static _questionExists(int $question_id)