ILIAS  release_5-3 Revision v5.3.23-19-g915713cf615
ilSCORMExplorer Class Reference

Explorer View for SCORM Learning Modules. More...

+ Inheritance diagram for ilSCORMExplorer:
+ Collaboration diagram for ilSCORMExplorer:

Public Member Functions

 __construct ($a_target, &$a_slm_obj)
 Constructor public. More...
 
 getItem ($a_node_id)
 
 getIconImagePathPrefix ()
 
 getNodesToSkip ()
 
 formatHeader ($tpl, $a_obj_id, $a_option)
 overwritten method from base class public More...
 
 createTarget ($a_type, $a_child, $a_highlighted_subtree=false, $a_append_anch=true)
 Creates Get Parameter private. More...
 
 setOutput ($parent_id, $a_depth=1, $a_obj_id=0, $a_highlighted_subtree=false)
 possible output array is set More...
 
 isVisible ($a_id, $a_type)
 
 getOutput ($jsApi=false)
 Creates output template. More...
 
 createOutput ($option, $jsApi)
 recursive creation of output templates More...
 
 isClickable ($a_type, $a_id=0, $a_obj=0)
 can i click on the module name More...
 
 getOutputIcons (&$tpl, $a_option, $a_node_id, $scormtype="sco")
 tpl is filled with option state More...
 
- Public Member Functions inherited from ilExplorer
 __construct ($a_target)
 Constructor public. More...
 
 setId ($a_val)
 Set id. More...
 
 getId ()
 Get id. More...
 
 setAsynchExpanding ($a_val)
 Set asynch expanding. More...
 
 getAsynchExpanding ()
 Get asynch expanding. More...
 
 initItemCounter ($a_number)
 Init item counter. More...
 
 setTitle ($a_val)
 Set title. More...
 
 setTitleLength ($a_length)
 Set max title length. More...
 
 getTitleLength ()
 Get max title length. More...
 
 getTitle ()
 Get title. More...
 
 setRoot ($a_root_id)
 Set root node. More...
 
 getRoot ()
 get root id More...
 
 setOrderColumn ($a_column)
 set the order column public More...
 
 setOrderDirection ($a_direction)
 set the order direction public More...
 
 setTargetGet ($a_target_get)
 set the varname in Get-string public More...
 
 setParamsGet ($a_params_get)
 set additional params to be passed in Get-string public More...
 
 setExpandTarget ($a_exp_target)
 target script for expand icons More...
 
 setFrameUpdater ($a_up_frame, $a_up_script, $a_params="")
 Set Explorer Updater. More...
 
 highlightNode ($a_id)
 set highlighted node More...
 
 checkPermissions ($a_check)
 check permissions via rbac More...
 
 setSessionExpandVariable ($a_var_name="expand")
 set name of expand session variable More...
 
 outputIcons ($a_icons)
 output icons More...
 
 setClickable ($a_type, $a_clickable)
 (de-)activates links for a certain object type More...
 
 isVisible ($a_ref_id, $a_type)
 
 setTreeLead ($a_val)
 Set tree leading content. More...
 
 getTreeLead ()
 Get tree leading content. More...
 
 isClickable ($a_type, $a_ref_id=0)
 check if links for certain object type are activated More...
 
 setPostSort ($a_sort)
 process post sorting More...
 
 setFilterMode ($a_mode=IL_FM_NEGATIVE)
 set filter mode More...
 
 getFilterMode ()
 get filter mode More...
 
 setUseStandardFrame ($a_val)
 Set use standard frame. More...
 
 getUseStandardFrame ()
 Get use standard explorer frame. More...
 
 getChildsOfNode ($a_parent_id)
 Get childs of node. More...
 
 setOutput ($a_parent_id, $a_depth=1, $a_obj_id=0, $a_highlighted_subtree=false)
 Creates output for explorer view in admin menue recursive method public. More...
 
 modifyChilds ($a_parent_id, $a_objects)
 
 showChilds ($a_parent_id)
 determines wether the childs of an object should be shown or not note: this standard implementation always returns true but it could be overwritten by derived classes (e.g. More...
 
 forceExpanded ($a_obj_id)
 force expansion of node More...
 
 getMaximumTreeDepth ()
 Get maximum tree depth. More...
 
 getOutput ()
 Creates output recursive method public. More...
 
 handleListEndTags (&$a_tpl_tree, $a_cur_depth, $a_item_depth)
 handle list end tags ( and ) More...
 
 handleListStartTags (&$a_tpl_tree, $a_cur_depth, $a_item_depth)
 handle list start tags ( More...
 
 formatHeader ($tpl, $a_obj_id, $a_option)
 Creates output for header (is empty here but can be overwritten in derived classes) More...
 
 formatObject ($tpl, $a_node_id, $a_option, $a_obj_id=0)
 Creates output recursive method private. More...
 
 getImage ($a_name, $a_type="", $a_obj_id="")
 get image path (may be overwritten by derived classes) More...
 
 getImageAlt ($a_default_text, $a_type="", $a_obj_id="")
 get image alt text More...
 
 getNodeStyleClass ($a_id, $a_type)
 get style class for node More...
 
 buildLinkTarget ($a_node_id, $a_type)
 get link target (may be overwritten by derived classes) More...
 
 buildOnClick ($a_node_id, $a_type, $a_title)
 get onclick event handling (may be overwritten by derived classes) More...
 
 buildTitle ($a_title, $a_id, $a_type)
 standard implementation for title, may be overwritten by derived classes More...
 
 buildDescription ($a_desc, $a_id, $a_type)
 standard implementation for description, may be overwritten by derived classes More...
 
 buildSelect ($a_node_id, $a_type)
 standard implementation for adding an option select box between image and title More...
 
 buildFrameTarget ($a_type, $a_child=0, $a_obj_id=0)
 get frame target (may be overwritten by derived classes) More...
 
 createTarget ($a_type, $a_node_id, $a_highlighted_subtree=false, $a_append_anch=true)
 Creates Get Parameter private. More...
 
 setFrameTarget ($a_target)
 set target frame or not frame? More...
 
 createLines ($a_depth)
 Creates lines for explorer view private. More...
 
 is_in_array ($a_start, $a_depth)
 DESCRIPTION MISSING private. More...
 
 getIndex ($a_data)
 get index of format_options array from specific ref_id,parent_id private More...
 
 addFilter ($a_item)
 adds item to the filter public More...
 
 delFilter ($a_item)
 removes item from the filter public More...
 
 setExpand ($a_node_id)
 set the expand option this value is stored in a SESSION variable to save it different view (lo view, frm view,...) private More...
 
 forceExpandAll ($a_mode, $a_show_minus=true)
 force expandAll. More...
 
 setFiltered ($a_bool)
 active/deactivate the filter public More...
 
 checkFilter ($a_item)
 check if item is in filter private More...
 
 sortNodes ($a_nodes, $a_parent_obj_id)
 sort nodes and put adm object to the end of sorted array private More...
 

Data Fields

 $slm_obj
 
- Data Fields inherited from ilExplorer
 $id
 
 $output
 
 $format_options
 
 $tree
 
 $target
 
 $target_get
 
 $params_get
 
 $expanded
 
 $order_column
 
 $order_direction = "asc"
 
 $expand_target
 
 $rbac_check
 
 $output_icons
 
 $expand_variable
 
 $is_clickable
 
 $post_sort
 
 $filtered = false
 
 $filter_mode
 
 $expand_all = false
 
 $root_id = null
 
 $use_standard_frame = false
 

Protected Member Functions

 createOutputArray ($a_parent_id, $options=array())
 recursivi creating of outputs More...
 
 insertObject ($option, ilTemplate $tpl, $jsApi)
 insert the option data in $tpl More...
 

Additional Inherited Members

- Protected Attributes inherited from ilExplorer
 $obj_definition
 
 $error
 
 $rbacsystem
 
 $tpl
 
 $lng
 

Detailed Description

Constructor & Destructor Documentation

◆ __construct()

ilSCORMExplorer::__construct (   $a_target,
$a_slm_obj 
)

Constructor public.

Parameters
stringscriptname
intuser_id

Definition at line 53 of file class.ilSCORMExplorer.php.

References ilExplorer\checkPermissions(), ilExplorer\outputIcons(), ilTree\readRootId(), and ilExplorer\setOrderColumn().

54  {
55  parent::__construct($a_target);
56  $this->slm_obj = $a_slm_obj;
57  $this->tree = new ilSCORMTree($a_slm_obj->getId());
58  $this->root_id = $this->tree->readRootId();
59  $this->checkPermissions(false);
60  $this->outputIcons(true);
61  $this->setOrderColumn("");
62  }
checkPermissions($a_check)
check permissions via rbac
setOrderColumn($a_column)
set the order column public
SCORM Object Tree.
outputIcons($a_icons)
output icons
readRootId()
read root id from database
+ Here is the call graph for this function:

Member Function Documentation

◆ createOutput()

ilSCORMExplorer::createOutput (   $option,
  $jsApi 
)

recursive creation of output templates

Parameters
array$option
bool$jsApi
Returns
ilTemplate $tpl

Definition at line 208 of file class.ilSCORMExplorer.php.

References $ilBench, $key, ilExplorer\$tpl, and insertObject().

Referenced by getOutput().

209  {
210  global $ilBench;
211 
212  if ($option["visible"]) {
213  $tpl = new ilTemplate("tpl.sahs_tree_ul.html", true, true, "Modules/ScormAicc");
214  $tpl = $this->insertObject($option, $tpl, $jsApi);
215  } else {
216  $tpl = new ilTemplate("tpl.sahs_tree_free.html", true, true, "Modules/ScormAicc");
217  }
218 
219  if (count($option["childs"])) {
220  foreach ($option["childs"] as $key => $ch_option) {
221  $tpl->setCurrentBlock("childs");
222  $tpl->setVariable("CHILDS", $this->createOutput($ch_option, $jsApi)->get());
223  $tpl->parseCurrentBlock();
224  }
225  }
226 
227  return $tpl;
228  }
insertObject($option, ilTemplate $tpl, $jsApi)
insert the option data in $tpl
special template class to simplify handling of ITX/PEAR
createOutput($option, $jsApi)
recursive creation of output templates
global $ilBench
Definition: ilias.php:18
$key
Definition: croninfo.php:18
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ createOutputArray()

ilSCORMExplorer::createOutputArray (   $a_parent_id,
  $options = array() 
)
protected

recursivi creating of outputs

Parameters
int$a_parent_id
array$optionsexisting output options
Returns
array $options

Definition at line 136 of file class.ilSCORMExplorer.php.

References $key, $options, array, and ilExplorer\showChilds().

Referenced by setOutput().

137  {
138  $types_do_not_display = array("sos", "sma");
139  $types_do_not_load = array("srs");
140 
141  if (!isset($a_parent_id)) {
142  $this->ilias->raiseError(get_class($this) . "::setOutput(): No node_id given!", $this->ilias->error_obj->WARNING);
143  }
144 
145  if (!$this->showChilds($a_parent_id)) {
146  return array();
147  }
148 
149  foreach ($this->tree->getChilds($a_parent_id, $this->order_column) as $key => $child) {
150  if (in_array($child["c_type"], $types_do_not_load)) {
151  continue;
152  }
153 
154  $option = array();
155  $option["parent"] = $child["parent"];
156  $option["id"] = $child["child"];
157  $option["title"] = $child["title"];
158  $option["c_type"] = $child["c_type"];
159  $option["obj_id"] = $child["obj_id"];
160  $option["desc"] = "obj_" . $child["c_type"];
161  $option["container"] = false;
162  $option["visible"] = !in_array($child["c_type"], $types_do_not_display);
163 
164  if ($this->showChilds($option["id"])) {
165  $option = $this->createOutputArray($option["id"], $option, ++$depth);
166  }
167 
168  $options["childs"][] = $option;
169  }
170 
171  return $options;
172  }
createOutputArray($a_parent_id, $options=array())
recursivi creating of outputs
showChilds($a_parent_id)
determines wether the childs of an object should be shown or not note: this standard implementation a...
redirection script todo: (a better solution should control the processing via a xml file) ...
Create styles array
The data for the language used.
$key
Definition: croninfo.php:18
if(!isset($_REQUEST['ReturnTo'])) if(!isset($_REQUEST['AuthId'])) $options
Definition: as_login.php:20
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ createTarget()

ilSCORMExplorer::createTarget (   $a_type,
  $a_child,
  $a_highlighted_subtree = false,
  $a_append_anch = true 
)

Creates Get Parameter private.

Parameters
string
integer
Returns
string

Definition at line 108 of file class.ilSCORMExplorer.php.

References $_SERVER, and $a_type.

109  {
110  // SET expand parameter:
111  // positive if object is expanded
112  // negative if object is compressed
113  $a_child = ($a_type == '+')
114  ? $a_child
115  : -(int) $a_child;
116 
117  return $_SERVER["PATH_INFO"] . "?cmd=explorer&ref_id=" . $this->slm_obj->getRefId() . "&scexpand=" . $a_child;
118  }
if((!isset($_SERVER['DOCUMENT_ROOT'])) OR(empty($_SERVER['DOCUMENT_ROOT']))) $_SERVER['DOCUMENT_ROOT']
$a_type
Definition: workflow.php:92

◆ formatHeader()

ilSCORMExplorer::formatHeader (   $tpl,
  $a_obj_id,
  $a_option 
)

overwritten method from base class public

Parameters
integerobj_id
integerarray options

Definition at line 86 of file class.ilSCORMExplorer.php.

References ilExplorer\$lng, and ilExplorer\$tpl.

87  {
88  global $lng, $ilias;
89 
90  $tpl = new ilTemplate("tpl.tree.html", true, true, "Services/UIComponent/Explorer");
91 
92  $tpl->setCurrentBlock("row");
93  $tpl->setVariable("TITLE", $lng->txt("cont_manifest"));
94  $tpl->setVariable("LINK_TARGET", $this->target . "&" . $this->target_get . "=" . $a_obj_id);
95  $tpl->setVariable("TARGET", " target=\"" . $this->frame_target . "\"");
96  $tpl->parseCurrentBlock();
97 
98  $this->output[] = $tpl->get();
99  }
special template class to simplify handling of ITX/PEAR

◆ getIconImagePathPrefix()

ilSCORMExplorer::getIconImagePathPrefix ( )

Definition at line 69 of file class.ilSCORMExplorer.php.

Referenced by getOutputIcons().

70  {
71  return "scorm/";
72  }
+ Here is the caller graph for this function:

◆ getItem()

ilSCORMExplorer::getItem (   $a_node_id)

Definition at line 64 of file class.ilSCORMExplorer.php.

65  {
66  return new ilSCORMItem($a_node_id);
67  }
SCORM Item.

◆ getNodesToSkip()

ilSCORMExplorer::getNodesToSkip ( )

Definition at line 74 of file class.ilSCORMExplorer.php.

75  {
76  return 2;
77  }

◆ getOutput()

ilSCORMExplorer::getOutput (   $jsApi = false)

Creates output template.

public

Returns
string

Definition at line 193 of file class.ilSCORMExplorer.php.

References ilExplorer\$output, and createOutput().

194  {
195  $output = $this->createOutput($this->format_options, $jsApi);
196 
197  return $output->get();
198  }
createOutput($option, $jsApi)
recursive creation of output templates
+ Here is the call graph for this function:

◆ getOutputIcons()

ilSCORMExplorer::getOutputIcons ( $tpl,
  $a_option,
  $a_node_id,
  $scormtype = "sco" 
)

tpl is filled with option state

Parameters
ilTemplate$tpl
array$a_option
int$a_node_id
string$scormtype

Definition at line 323 of file class.ilSCORMExplorer.php.

References ilExplorer\$lng, ilExplorer\$tpl, ilSCORMItem\_lookupTrackingDataOfUser(), getIconImagePathPrefix(), and ilUtil\getImagePath().

Referenced by insertObject().

324  {
325  global $lng;
326 
327  $tpl->setCurrentBlock("icon");
328 
329  if ($scormtype == 'asset') {
330  $tpl->setVariable('ICON_IMAGE', ilUtil::getImagePath($this->getIconImagePathPrefix() . "asset.svg"));
331  $tpl->setVariable('TXT_ALT_IMG', '');
332  $tpl->parseCurrentBlock();
333  return;
334  }
335 
337  $a_node_id,
338  0,
339  $this->slm_obj->getId()
340  );
341 
342  // status
343  $status = ($trdata["cmi.core.lesson_status"] == "")
344  ? "not attempted"
345  : $trdata["cmi.core.lesson_status"];
346 
347  $statusChar=strtolower(substr($status, 0, 1));
348  if ($statusChar=="f") {
349  $status="failed";
350  } elseif ($statusChar=="b") {
351  $status="browsed";
352  } elseif ($statusChar=="c") {
353  $status="completed";
354  } elseif ($statusChar=="n") {
355  $status="not_attempted";
356  } elseif ($statusChar=="p") {
357  $status="passed";
358  } elseif ($statusChar=="r") {
359  $status="running";
360  }
361 
362  $alt = $lng->txt("cont_status") . ": " .
363  $lng->txt("cont_sc_stat_" . str_replace(" ", "_", $status));
364 
365  // score
366  if ($trdata["cmi.core.score.raw"] != "") {
367  $alt.= ", " . $lng->txt("cont_credits") .
368  ": " . $trdata["cmi.core.score.raw"];
369  }
370 
371  // total time
372  if ($trdata["cmi.core.total_time"] != "" &&
373  $trdata["cmi.core.total_time"] != "0000:00:00.00") {
374  $alt.= ", " . $lng->txt("cont_total_time") .
375  ": " . $trdata["cmi.core.total_time"];
376  }
377 
378  $tpl->setVariable("ICON_NAME", 'scoIcon' . $a_node_id);
379  $tpl->setVariable("ICON_IMAGE", ilUtil::getImagePath($this->getIconImagePathPrefix() . str_replace(" ", "_", $status) . ".svg"));
380  $tpl->setVariable("TXT_ALT_IMG", $alt);
381  $tpl->parseCurrentBlock();
382  }
static getImagePath($img, $module_path="", $mode="output", $offline=false)
get image path (for images located in a template directory)
static _lookupTrackingDataOfUser($a_item_id, $a_user_id=0, $a_obj_id=0)
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ insertObject()

ilSCORMExplorer::insertObject (   $option,
ilTemplate  $tpl,
  $jsApi 
)
protected

insert the option data in $tpl

Parameters
array$option
ilTemplate$tpl
bool$jsApi
Returns
ilTemplate $tpl

Definition at line 264 of file class.ilSCORMExplorer.php.

References ilExplorer\$tpl, ilSCORMResource\_lookupIdByIdRef(), ilSCORMResource\_lookupScormType(), ilExplorer\buildFrameTarget(), getOutputIcons(), isClickable(), ilTemplate\parseCurrentBlock(), ilTemplate\setCurrentBlock(), HTML_Template_IT\setVariable(), and ilUtil\shortenText().

Referenced by createOutput().

265  {
266  if (!is_array($option) || !isset($option["id"])) {
267  $this->ilias->raiseError(get_class($this) . "::insertObject(): Missing parameter or wrong datatype! " .
268  "node_id: " . $a_node_id . " options:" . var_dump($a_option), $this->ilias->error_obj->WARNING);
269  }
270 
271  //get scorm item
272  $sc_object = new ilSCORMItem($option["id"]);
273  $id_ref = $sc_object->getIdentifierRef();
274 
275  //get scorm resource ref id
276  $sc_res_id = ilSCORMResource::_lookupIdByIdRef($id_ref, $sc_object->getSLMId());
277 
278  //get scorm type
279  $scormtype = strtolower(ilSCORMResource::_lookupScormType($sc_res_id));
280 
281  //is scorm clickabke
282  $clickable = $this->isClickable($option["c_type"], $option["id"], $sc_object);
283 
284  if ($this->output_icons && $clickable) {
285  $this->getOutputIcons($tpl, $option, $option["id"], $scormtype);
286  }
287 
288  if ($clickable) { // output link
289  $tpl->setCurrentBlock("link");
290  $frame_target = $this->buildFrameTarget($option["c_type"], $option["id"], $option["obj_id"]);
291  if ($frame_target != "") {
292  $tpl->setVariable("TITLE", ilUtil::shortenText($option["title"], $this->textwidth, true));
293  $tpl->setVariable("LINK_TARGET", "javascript:void(0);");
294  if ($jsApi == true) {
295  $tpl->setVariable("ONCLICK", " onclick=\"parent.API.IliasLaunch('" . $option["id"] . "');return false;\"");
296  } else {
297  $tpl->setVariable("ONCLICK", " onclick=\"parent.APIFRAME.setupApi();parent.APIFRAME.API."
298  . ($scormtype == 'asset' ? 'IliasLaunchAsset' : 'IliasLaunchSahs')
299  . "('" . $option["id"] . "');return false;\"");
300  }
301  }
302  $tpl->parseCurrentBlock();
303  } else { // output text only
304  $tpl->setCurrentBlock("text");
305  $tpl->setVariable("OBJ_TITLE", ilUtil::shortenText($option["title"], $this->textwidth, true));
306  $tpl->parseCurrentBlock();
307  }
308 
309  $tpl->setCurrentBlock("li");
310  $tpl->parseCurrentBlock();
311 
312  return $tpl;
313  }
static shortenText( $a_str, $a_len, $a_dots=false, $a_next_blank=false, $a_keep_extension=false)
shorten a string to given length.
buildFrameTarget($a_type, $a_child=0, $a_obj_id=0)
get frame target (may be overwritten by derived classes)
getOutputIcons(&$tpl, $a_option, $a_node_id, $scormtype="sco")
tpl is filled with option state
static _lookupIdByIdRef($a_id_ref, $a_slm_id)
static _lookupScormType($a_obj_id)
setVariable($variable, $value='')
Sets a variable value.
Definition: IT.php:613
SCORM Item.
redirection script todo: (a better solution should control the processing via a xml file) ...
isClickable($a_type, $a_id=0, $a_obj=0)
can i click on the module name
setCurrentBlock($part="DEFAULT")
Überladene Funktion, die sich hier lokal noch den aktuellen Block merkt.
parseCurrentBlock($part="DEFAULT")
Überladene Funktion, die auf den aktuelle Block vorher noch ein replace ausführt public...
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ isClickable()

ilSCORMExplorer::isClickable (   $a_type,
  $a_id = 0,
  $a_obj = 0 
)

can i click on the module name

Parameters
string$a_type
int$a_id
int$a_obj
Returns
bool

Definition at line 238 of file class.ilSCORMExplorer.php.

References $a_type.

Referenced by insertObject().

239  {
240  if ($a_type != "sit") {
241  return false;
242  } else {
243  if (is_object($a_obj)) {
244  $sc_object = $a_obj;
245  } else {
246  $sc_object = new ilSCORMItem($a_id);
247  }
248  if ($sc_object->getIdentifierRef() != "") {
249  return true;
250  }
251  }
252  return false;
253  }
$a_type
Definition: workflow.php:92
SCORM Item.
+ Here is the caller graph for this function:

◆ isVisible()

ilSCORMExplorer::isVisible (   $a_id,
  $a_type 
)

Definition at line 177 of file class.ilSCORMExplorer.php.

References $a_type.

178  {
179  if ($a_type == "sre") {
180  return false;
181  } else {
182  return true;
183  }
184  }
$a_type
Definition: workflow.php:92

◆ setOutput()

ilSCORMExplorer::setOutput (   $parent_id,
  $a_depth = 1,
  $a_obj_id = 0,
  $a_highlighted_subtree = false 
)

possible output array is set

Parameters
int$parent_id

Definition at line 124 of file class.ilSCORMExplorer.php.

References createOutputArray().

125  {
126  $this->format_options = $this->createOutputArray($parent_id);
127  }
createOutputArray($a_parent_id, $options=array())
recursivi creating of outputs
+ Here is the call graph for this function:

Field Documentation

◆ $slm_obj

ilSCORMExplorer::$slm_obj

Definition at line 45 of file class.ilSCORMExplorer.php.


The documentation for this class was generated from the following file: