42 "DELETE FROM skl_level WHERE " 43 .
" skill_id = " .
$ilDB->quote($skill_id,
"integer")
47 public function addLevel(
int $skill_id,
string $a_title,
string $a_description,
string $a_import_id =
""): void
52 $nid =
$ilDB->nextId(
"skl_level");
53 $ilDB->insert(
"skl_level", array(
54 "id" => array(
"integer", $nid),
55 "skill_id" => array(
"integer", $skill_id),
56 "nr" => array(
"integer", $nr + 1),
57 "title" => array(
"text", $a_title),
58 "description" => array(
"clob", $a_description),
59 "import_id" => array(
"text", $a_import_id),
60 "creation_date" => array(
"timestamp",
ilUtil::now())
69 "SELECT MAX(nr) mnr FROM skl_level WHERE " .
70 " skill_id = " .
$ilDB->quote($skill_id,
"integer")
72 $rec =
$ilDB->fetchAssoc($set);
73 return (
int) ($rec[
"mnr"] ?? 0);
85 $and =
" AND id = " .
$ilDB->quote($a_id,
"integer");
89 "SELECT * FROM skl_level WHERE " .
90 " skill_id = " .
$ilDB->quote($skill_id,
"integer") .
95 while ($rec =
$ilDB->fetchAssoc($set)) {
109 "SELECT $a_prop FROM skl_level WHERE " .
110 " id = " .
$ilDB->quote($a_id,
"integer")
112 $rec =
$ilDB->fetchAssoc($set);
114 return isset($rec[$a_prop]) ? (string) $rec[$a_prop] : null;
132 protected function writeLevelProperty(
int $a_id,
string $a_prop, ?
string $a_value,
string $a_type): void
136 $ilDB->update(
"skl_level", array(
137 $a_prop => array($a_type, $a_value),
139 "id" => array(
"integer", $a_id),
158 foreach ($order as
$id => $o) {
160 "UPDATE skl_level SET " .
161 " nr = " .
$ilDB->quote($cnt,
"integer") .
162 " WHERE id = " .
$ilDB->quote(
$id,
"integer")
173 "DELETE FROM skl_level WHERE " 174 .
" id = " .
$ilDB->quote($a_id,
"integer")
183 "SELECT id, nr FROM skl_level WHERE " .
184 " skill_id = " .
$ilDB->quote($skill_id,
"integer") .
188 while ($rec =
$ilDB->fetchAssoc($set)) {
190 "UPDATE skl_level SET " .
191 " nr = " .
$ilDB->quote($cnt,
"integer") .
192 " WHERE id = " .
$ilDB->quote($rec[
"id"],
"integer")
203 "SELECT * FROM skl_level WHERE " .
204 " id = " .
$ilDB->quote($a_level_id,
"integer")
207 if ($rec =
$ilDB->fetchAssoc($set)) {
208 if ($this->tree_repo->isInAnyTree((
int) $rec[
"skill_id"])) {
lookupLevelSkillId(int $a_id)
writeLevelDescription(int $a_id, string $a_description)
writeLevelProperty(int $a_id, string $a_prop, ?string $a_value, string $a_type)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static now()
Return current timestamp in Y-m-d H:i:s format.
writeLevelTitle(int $a_id, string $a_title)
ilSkillTreeRepository $tree_repo
__construct(ilSkillTreeRepository $tree_repo, ilDBInterface $db=null)
addLevel(int $skill_id, string $a_title, string $a_description, string $a_import_id="")
deleteLevelsOfSkill(int $skill_id)
updateLevelOrder(array $order)
lookupLevelTitle(int $a_id)
lookupLevelProperty(int $a_id, string $a_prop)
fixLevelNumbering(int $skill_id)
$id
plugin.php for ilComponentBuildPluginInfoObjectiveTest::testAddPlugins
getSkillForLevelId(int $a_level_id)
getMaxLevelNr(int $skill_id)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
lookupLevelDescription(int $a_id)
getLevelData(int $skill_id, int $a_id=0)
Returns multiple rows when $a_id is 0 else one or [].