ILIAS  release_6 Revision v6.24-5-g0c8bfefb3b8
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 @access public. More...
 
 getItem ($a_node_id)
 
 getIconImagePathPrefix ()
 
 getNodesToSkip ()
 
 formatHeader ($tpl, $a_obj_id, $a_option)
 overwritten method from base class @access public More...
 
 createTarget ($a_type, $a_child, $a_highlighted_subtree=false, $a_append_anch=true)
 Creates Get Parameter @access 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 @access 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 @access public More...
 
 setOrderDirection ($a_direction)
 set the order direction @access public More...
 
 setTargetGet ($a_target_get)
 set the varname in Get-string @access public More...
 
 setParamsGet ($a_params_get)
 set additional params to be passed in Get-string @access 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 @access 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 @access 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 @access 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 @access private. More...
 
 setFrameTarget ($a_target)
 set target frame or not frame? More...
 
 createLines ($a_depth)
 Creates lines for explorer view @access private. More...
 
 is_in_array ($a_start, $a_depth)
 DESCRIPTION MISSING @access private. More...
 
 getIndex ($a_data)
 get index of format_options array from specific ref_id,parent_id @access private More...
 
 addFilter ($a_item)
 adds item to the filter @access public More...
 
 delFilter ($a_item)
 removes item from the filter @access 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,...) @access private More...
 
 forceExpandAll ($a_mode, $a_show_minus=true)
 force expandAll. More...
 
 setFiltered ($a_bool)
 active/deactivate the filter @access public More...
 
 checkFilter ($a_item)
 check if item is in filter @access private More...
 
 sortNodes ($a_nodes, $a_parent_obj_id)
 sort nodes and put adm object to the end of sorted array @access 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 @access public.

Parameters
stringscriptname
intuser_id

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

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 }
outputIcons($a_icons)
output icons
checkPermissions($a_check)
check permissions via rbac
setOrderColumn($a_column)
set the order column @access public
SCORM Object Tree.
__construct(Container $dic, ilPlugin $plugin)
@inheritDoc

References ILIAS\GlobalScreen\Provider\__construct(), ilExplorer\checkPermissions(), ilExplorer\outputIcons(), and ilExplorer\setOrderColumn().

+ 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 210 of file class.ilSCORMExplorer.php.

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

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

Referenced by createOutput(), and getOutput().

+ 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 138 of file class.ilSCORMExplorer.php.

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

References createOutputArray(), and ilExplorer\showChilds().

Referenced by createOutputArray(), and setOutput().

+ 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 @access private.

Parameters
string
integer
Returns
string

Reimplemented from ilExplorer.

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

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

References $_SERVER, and $a_type.

◆ formatHeader()

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

overwritten method from base class @access public

Parameters
integerobj_id
integerarray options

Reimplemented from ilExplorer.

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

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

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

◆ getIconImagePathPrefix()

ilSCORMExplorer::getIconImagePathPrefix ( )

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

70 {
71 return "scorm/";
72 }

Referenced by getOutputIcons().

+ 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 }

◆ 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.

@access public

Returns
string

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

196 {
197 $output = $this->createOutput($this->format_options, $jsApi);
198
199 return $output->get();
200 }

References ilExplorer\$output, and createOutput().

+ 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 326 of file class.ilSCORMExplorer.php.

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

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

Referenced by insertObject().

+ 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 267 of file class.ilSCORMExplorer.php.

268 {
269 if (!is_array($option) || !isset($option["id"])) {
270 $this->ilias->raiseError(get_class($this) . "::insertObject(): Missing parameter or wrong datatype! " .
271 "options:" . var_dump($option), $this->ilias->error_obj->WARNING);
272 }
273
274 //get scorm item
275 $sc_object = new ilSCORMItem($option["id"]);
276 $id_ref = $sc_object->getIdentifierRef();
277
278 //get scorm resource ref id
279 $sc_res_id = ilSCORMResource::_lookupIdByIdRef($id_ref, $sc_object->getSLMId());
280
281 //get scorm type
282 $scormtype = strtolower(ilSCORMResource::_lookupScormType($sc_res_id));
283
284 //is scorm clickabke
285 $clickable = $this->isClickable($option["c_type"], $option["id"], $sc_object);
286
287 if ($this->output_icons && $clickable) {
288 $this->getOutputIcons($tpl, $option, $option["id"], $scormtype);
289 }
290
291 if ($clickable) { // output link
292 $tpl->setCurrentBlock("link");
293 $frame_target = $this->buildFrameTarget($option["c_type"], $option["id"], $option["obj_id"]);
294 if ($frame_target != "") {
295 $tpl->setVariable("TITLE", ilUtil::shortenText($option["title"], $this->textwidth, true));
296 $tpl->setVariable("LINK_TARGET", "javascript:void(0);");
297 if ($jsApi == true) {
298 $tpl->setVariable("ONCLICK", " onclick=\"parent.API.IliasLaunch('" . $option["id"] . "');return false;\"");
299 } else {
300 $tpl->setVariable("ONCLICK", " onclick=\"parent.APIFRAME.setupApi();parent.APIFRAME.API."
301 . ($scormtype == 'asset' ? 'IliasLaunchAsset' : 'IliasLaunchSahs')
302 . "('" . $option["id"] . "');return false;\"");
303 }
304 }
305 $tpl->parseCurrentBlock();
306 } else { // output text only
307 $tpl->setCurrentBlock("text");
308 $tpl->setVariable("OBJ_TITLE", ilUtil::shortenText($option["title"], $this->textwidth, true));
309 $tpl->parseCurrentBlock();
310 }
311
312 $tpl->setCurrentBlock("li");
313 $tpl->parseCurrentBlock();
314
315 return $tpl;
316 }
buildFrameTarget($a_type, $a_child=0, $a_obj_id=0)
get frame target (may be overwritten by derived classes)
isClickable($a_type, $a_id=0, $a_obj=0)
can i click on the module name
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)
static shortenText( $a_str, $a_len, $a_dots=false, $a_next_blank=false, $a_keep_extension=false)
shorten a string to given length.

References ilExplorer\$tpl, ilSCORMResource\_lookupIdByIdRef(), ilSCORMResource\_lookupScormType(), ilExplorer\buildFrameTarget(), getOutputIcons(), isClickable(), and ilUtil\shortenText().

Referenced by createOutput().

+ 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 241 of file class.ilSCORMExplorer.php.

242 {
243 if ($a_type != "sit") {
244 return false;
245 } else {
246 if (is_object($a_obj)) {
247 $sc_object = $a_obj;
248 } else {
249 $sc_object = new ilSCORMItem($a_id);
250 }
251 if ($sc_object->getIdentifierRef() != "") {
252 return true;
253 }
254 }
255 return false;
256 }

References $a_type.

Referenced by insertObject().

+ Here is the caller graph for this function:

◆ isVisible()

ilSCORMExplorer::isVisible (   $a_id,
  $a_type 
)

Reimplemented from ilExplorer.

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

180 {
181 if ($a_type == "sre") {
182 return false;
183 } else {
184 return true;
185 }
186 }

References $a_type.

◆ 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

Reimplemented from ilExplorer.

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

127 {
128 $this->format_options = $this->createOutputArray($parent_id);
129 }

References createOutputArray().

+ 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: