Actualización
This commit is contained in:
157
main/lp/scormOrganization.class.php
Normal file
157
main/lp/scormOrganization.class.php
Normal file
@@ -0,0 +1,157 @@
|
||||
<?php
|
||||
/* For licensing terms, see /license.txt */
|
||||
|
||||
/**
|
||||
* Container for the scormOrganization class.
|
||||
*
|
||||
* @author Yannick Warnier <ywarnier@beeznest.org>
|
||||
*/
|
||||
|
||||
/**
|
||||
* Class defining the <organization> tag in an imsmanifest.xml file.
|
||||
*/
|
||||
class scormOrganization
|
||||
{
|
||||
public $identifier = '';
|
||||
public $structure = '';
|
||||
public $title = '';
|
||||
public $items = [];
|
||||
public $metadata;
|
||||
|
||||
/**
|
||||
* Class constructor. Depending of the type of construction called ('db' or 'manifest'),
|
||||
* will create a scormOrganization
|
||||
* object from database records or from the DOM element given as parameter.
|
||||
*
|
||||
* @param string Type of construction needed ('db' or 'manifest', default = 'manifest')
|
||||
* @param mixed Depending on the type given, DB id for the lp_item or reference to the DOM element
|
||||
*/
|
||||
public function __construct($type, &$element, $scorm_charset = 'UTF-8')
|
||||
{
|
||||
if (isset($element)) {
|
||||
// Parsing using PHP5 DOMXML methods.
|
||||
switch ($type) {
|
||||
case 'db':
|
||||
// TODO: Implement this way of metadata object creation.
|
||||
break;
|
||||
case 'manifest': // Do the same as the default.
|
||||
default:
|
||||
// this is already check prior to the call to this function.
|
||||
$children = $element->childNodes;
|
||||
foreach ($children as $child) {
|
||||
switch ($child->nodeType) {
|
||||
case XML_ELEMENT_NODE:
|
||||
switch ($child->tagName) {
|
||||
case 'item':
|
||||
$oItem = new scormItem(
|
||||
'manifest',
|
||||
$child
|
||||
);
|
||||
if ('' != $oItem->identifier) {
|
||||
$this->items[$oItem->identifier] = $oItem;
|
||||
}
|
||||
break;
|
||||
case 'metadata':
|
||||
$this->metadata = new scormMetadata(
|
||||
'manifest',
|
||||
$child
|
||||
);
|
||||
break;
|
||||
case 'title':
|
||||
$tmp_children = $child->childNodes;
|
||||
if (1 == $tmp_children->length && '' != $child->firstChild->nodeValue) {
|
||||
$this->title = api_utf8_decode(
|
||||
api_html_entity_decode(
|
||||
$child->firstChild->nodeValue,
|
||||
ENT_QUOTES,
|
||||
'UTF-8'
|
||||
)
|
||||
);
|
||||
}
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case XML_TEXT_NODE:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if ($element->hasAttributes()) {
|
||||
$attributes = $element->attributes;
|
||||
//$keep_href = '';
|
||||
foreach ($attributes as $attrib) {
|
||||
switch ($attrib->name) {
|
||||
case 'identifier':
|
||||
$this->identifier = $attrib->value;
|
||||
break;
|
||||
case 'structure':
|
||||
$this->structure = $attrib->value;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
// End parsing using PHP5 DOMXML methods.
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Get a flat list of items in the organization.
|
||||
*
|
||||
* @return array Array containing an ordered list of all items with
|
||||
* their level and all information related to each item
|
||||
*/
|
||||
public function get_flat_items_list()
|
||||
{
|
||||
$list = [];
|
||||
$i = 1;
|
||||
foreach ($this->items as $id => $dummy) {
|
||||
$abs_order = 0;
|
||||
// Passes the array as a pointer so it is modified in $list directly.
|
||||
$this->items[$id]->get_flat_list($list, $abs_order, $i, 0);
|
||||
$i++;
|
||||
}
|
||||
|
||||
return $list;
|
||||
}
|
||||
|
||||
/**
|
||||
* Name getter.
|
||||
*
|
||||
* @return string Name or empty string
|
||||
*/
|
||||
public function get_name()
|
||||
{
|
||||
if (!empty($this->title)) {
|
||||
return Database::escape_string($this->title);
|
||||
} else {
|
||||
return '';
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Reference identifier getter.
|
||||
*
|
||||
* @return string Identifier or empty string
|
||||
*/
|
||||
public function get_ref()
|
||||
{
|
||||
if (!empty($this->identifier)) {
|
||||
return Database::escape_string($this->identifier);
|
||||
} else {
|
||||
return '';
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Sets the title element.
|
||||
*
|
||||
* @param string $title New title to set
|
||||
*/
|
||||
public function set_name($title)
|
||||
{
|
||||
if (!empty($title)) {
|
||||
$this->title = Database::escape_string($title);
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user