Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Patched a problem with asset resources

  • Loading branch information...
commit d64bc8aea65ac07797de65f04457cb11f607291c 1 parent a366326
bobopinna authored
View
2  mod/scorm/lib.php
@@ -543,7 +543,7 @@ function scorm_parse($basedir,$file,$scorm_id) {
}
} else {
foreach ($resources as $label => $resource) {
- if ((isset($resource['type'])) && ($resource['type'] == 'sco')) {
+ if (!empty($resource['href'])) {
$sco->identifier = $label;
$sco->title = $label;
$sco->parent = '/';
View
BIN  mod/scorm/pix/asset.gif
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
View
15 mod/scorm/playscorm.php
@@ -73,7 +73,7 @@
//
$bodyscripts = "";
if ($scorm->popup != "") {
- $bodyscripts = "onLoad='SCOInitialize();' onUnload='API.SaveTotalTime(); closeMain();' onbeforeUnload='API.SaveTotalTime();'";
+ $bodyscripts = "onLoad='SCOInitialize();' onUnload='SCOFinish(); closeMain();' onbeforeUnload='SCOFinish();'";
}
print_header($pagetitle, "$course->fullname",
"$navigation <a target=\"{$CFG->framename}\" href=\"view.php?id=$cm->id\" title=\"$scorm->summary\">$scorm->name</a>",
@@ -173,8 +173,9 @@ function expandCollide(which,list) {
}
$score = "";
if ($sco_user=get_record("scorm_sco_users","scoid",$sco->id,"userid",$USER->id)) {
- if ( $sco_user->cmi_core_lesson_status == "")
+ if ( $sco_user->cmi_core_lesson_status == "") {
$sco_user->cmi_core_lesson_status = "not attempted";
+ }
echo " <img src=\"pix/".scorm_remove_spaces($sco_user->cmi_core_lesson_status).".gif\" alt=\"".get_string(scorm_remove_spaces($sco_user->cmi_core_lesson_status),"scorm")."\" title=\"".get_string(scorm_remove_spaces($sco_user->cmi_core_lesson_status),"scorm")."\" />\n";
if (($sco_user->cmi_core_lesson_status == "not attempted") || ($sco_user->cmi_core_lesson_status == "incomplete")) {
if ($currentSCO == "") {
@@ -188,8 +189,12 @@ function expandCollide(which,list) {
$score = "(".get_string("score","scorm").":&nbsp;".$sco_user->cmi_core_score_raw.")";
}
} else {
- echo " <img src=\"pix/notattempted.gif\" alt=\"".get_string("notattempted","scorm")."\" />";
- $incomplete = true;
+ if ($sco->type == 'sco') {
+ echo " <img src=\"pix/notattempted.gif\" alt=\"".get_string("notattempted","scorm")."\" />";
+ $incomplete = true;
+ } else {
+ echo " <img src=\"pix/asset.gif\" alt=\"".get_string("asset","scorm")."\" />";
+ }
}
echo " &nbsp;$startbold<a href=\"javascript:playSCO(".$sco->id.");\">$sco->title</a> $score$endbold\n </li>\n";
} else {
@@ -267,7 +272,7 @@ function expandCollide(which,list) {
echo "<html>\n";
echo "<head><title>$course->shortname: $scorm->name</title></head>\n";
echo "<script id=\"scormAPI\" language=\"JavaScript\" type=\"text/javascript\" src=\"scormAPI.php?id=$cm->id&mode=".$mode.$scoid."\"></script>\n";
- echo "<frameset rows=\"$CFG->scorm_framesize,*\" onLoad=\"SCOInitialize();\" onUnload=\"API.SaveTotalTime();\" onbeforeUnload=\"API.SaveTotalTime();\">\n";
+ echo "<frameset rows=\"$CFG->scorm_framesize,*\" onLoad=\"SCOInitialize();\" onUnload=\"SCOFinish();\" onbeforeUnload=\"SCOFinish();\">\n";
echo "\t <frame name=\"navigation\" src=\"playscorm.php?id=$cm->id&mode=".$mode.'&currentorg='.$currentorg."&frameset=top\">\n";
echo "\t <frame name=\"main\" src=\"\">\n";
echo "</frameset>\n";
View
33 mod/scorm/scormAPI.php
@@ -83,25 +83,25 @@
// Create user scoes records
//
foreach ($scoes as $sco) {
- if ($sco->launch != "") {
- if (!isset($first))
+ if (($sco->launch != "") && ($sco->type != "sca") && ($sco->type != "asset")){
+ if (!isset($first)) {
$first = $sco;
+ }
$sco_user->userid = $USER->id;
$sco_user->scoid = $sco->id;
$sco_user->scormid = $scorm->id;
$element = "cmi_core_lesson_status";
- if ($sco->type == "sco")
- $sco_user->$element = "not attempted";
- else if (($sco->type == "sca") || ($sco->type == "asset"))
- $sco_user->$element = "completed";
+ $sco_user->$element = "not attempted";
$ident = insert_record("scorm_sco_users",$sco_user);
}
}
- if (isset($first))
+ if (isset($first)) {
$sco = $first;
+ }
if (!empty($scoid)) {
- if ($sco = get_record("scorm_scoes","id",$scoid))
+ if ($sco = get_record("scorm_scoes","id",$scoid)) {
unset($first);
+ }
}
}
}
@@ -147,10 +147,13 @@
}
}
$navObj = "top.";
- if ($scorm->popup == "")
- $navObj = "top.navigation.";
-
- include("api1_2.php");
+ if ($scorm->popup == "") {
+ $navObj = "top.navigation.";
+ }
+
+ if ($sco->type == 'sco') {
+ include("api1_2.php");
+ }
?>
@@ -186,6 +189,12 @@ function SCOInitialize() {
?>
}
+function SCOFinish(){
+ if (typeof API != "undefined") {
+ SaveTotalTime();
+ }
+}
+
function changeSco(direction) {
if (direction == "previous")
<?php echo $navObj ?>document.navform.scoid.value="<?php echo $prevsco; ?>";
View
8 mod/scorm/view.php
@@ -163,8 +163,12 @@
$score = "(".get_string("score","scorm").":&nbsp;".$sco_user->cmi_core_score_raw.")";
}
} else {
- echo " <img src=\"pix/notattempted.gif\" alt=\"".get_string("notattempted","scorm")."\" />";
- $incomplete = true;
+ if ($sco->type == 'sco') {
+ echo " <img src=\"pix/notattempted.gif\" alt=\"".get_string("notattempted","scorm")."\" />";
+ $incomplete = true;
+ } else {
+ echo " <img src=\"pix/asset.gif\" alt=\"".get_string("asset","scorm")."\" />";
+ }
}
echo " &nbsp;<a href=\"javascript:playSCO(".$sco->id.")\">$sco->title</a> $score\n </li>\n";
} else {
Please sign in to comment.
Something went wrong with that request. Please try again.