ILIAS  Release_4_0_x_branch Revision 61816
 All Data Structures Namespaces Files Functions Variables Groups Pages
assClozeTestImport Class Reference

Class for cloze question imports. More...

+ Inheritance diagram for assClozeTestImport:
+ Collaboration diagram for assClozeTestImport:

Public Member Functions

 fromXML (&$item, $questionpool_id, &$tst_id, &$tst_object, &$question_counter, &$import_mapping)
 Creates a question from a QTI file.
- Public Member Functions inherited from assQuestionImport
 assQuestionImport (&$a_object)
 assQuestionImport constructor
 getFeedbackGeneric ($item)

Additional Inherited Members

- Data Fields inherited from assQuestionImport
 $object

Detailed Description

Class for cloze question imports.

assClozeTestImport is a class for cloze question imports

Author
Helmut Schottmüller helmu.nosp@m.t.sc.nosp@m.hottm.nosp@m.uell.nosp@m.er@ma.nosp@m.c.co.nosp@m.m
Version
$Id$

Definition at line 35 of file class.assClozeTestImport.php.

Member Function Documentation

assClozeTestImport::fromXML ( $item,
  $questionpool_id,
$tst_id,
$tst_object,
$question_counter,
$import_mapping 
)

Creates a question from a QTI file.

Receives parameters from a QTI parser and creates a valid ILIAS question object

Parameters
object$itemThe QTI item object
integer$questionpool_idThe id of the parent questionpool
integer$tst_idThe id of the parent test if the question is part of a test
object$tst_objectA reference to the parent test object
integer$question_counterA reference to a question counter to count the questions of an imported question pool
array$import_mappingAn array containing references to included ILIAS objects public

Reimplemented from assQuestionImport.

Definition at line 50 of file class.assClozeTestImport.php.

References $_SESSION, ilObjQuestionPool\_getImportDirectory(), ilObjTest\_getImportDirectory(), ilRTE\_replaceMediaObjectImageSrc(), ilObjMediaObject\_saveTempFileAsMediaObject(), CLOZE_NUMERIC, CLOZE_SELECT, CLOZE_TEXT, FIBTYPE_DECIMAL, FIBTYPE_INTEGER, and FIBTYPE_STRING.

{
global $ilUser;
// empty session variable for imported xhtml mobs
unset($_SESSION["import_mob_xhtml"]);
$presentation = $item->getPresentation();
$duration = $item->getDuration();
$questiontext = array();
$shuffle = 0;
$now = getdate();
$created = sprintf("%04d%02d%02d%02d%02d%02d", $now['year'], $now['mon'], $now['mday'], $now['hours'], $now['minutes'], $now['seconds']);
$gaps = array();
foreach ($presentation->order as $entry)
{
switch ($entry["type"])
{
case "material":
$material = $presentation->material[$entry["index"]];
array_push($questiontext, $this->object->QTIMaterialToString($material));
break;
case "response":
$response = $presentation->response[$entry["index"]];
$rendertype = $response->getRenderType();
array_push($questiontext, "<<" . $response->getIdent() . ">>");
switch (strtolower(get_class($response->getRenderType())))
{
case "ilqtirenderfib":
switch ($response->getRenderType()->getFibtype())
{
array_push($gaps,
array(
"ident" => $response->getIdent(),
"type" => CLOZE_NUMERIC,
"answers" => array(),
"minnumber" => $response->getRenderType()->getMinnumber(),
"maxnumber" => $response->getRenderType()->getMaxnumber()
)
);
break;
default:
array_push($gaps, array("ident" => $response->getIdent(), "type" => CLOZE_TEXT, "answers" => array()));
break;
}
break;
case "ilqtirenderchoice":
$answers = array();
$shuffle = $rendertype->getShuffle();
$answerorder = 0;
foreach ($rendertype->response_labels as $response_label)
{
$ident = $response_label->getIdent();
$answertext = "";
foreach ($response_label->material as $mat)
{
$answertext .= $this->object->QTIMaterialToString($mat);
}
$answers[$ident] = array(
"answertext" => $answertext,
"points" => 0,
"answerorder" => $answerorder++,
"action" => "",
"shuffle" => $rendertype->getShuffle()
);
}
array_push($gaps, array("ident" => $response->getIdent(), "type" => CLOZE_SELECT, "shuffle" => $rendertype->getShuffle(), "answers" => $answers));
break;
}
break;
}
}
$responses = array();
$feedbacks = array();
$feedbacksgeneric = array();
foreach ($item->resprocessing as $resprocessing)
{
foreach ($resprocessing->respcondition as $respcondition)
{
$ident = "";
$correctness = 1;
$conditionvar = $respcondition->getConditionvar();
foreach ($conditionvar->order as $order)
{
switch ($order["field"])
{
case "varequal":
$equals = $conditionvar->varequal[$order["index"]]->getContent();
$gapident = $conditionvar->varequal[$order["index"]]->getRespident();
break;
}
}
foreach ($respcondition->setvar as $setvar)
{
if (strcmp($gapident, "") != 0)
{
foreach ($gaps as $gi => $g)
{
if (strcmp($g["ident"], $gapident) == 0)
{
if ($g["type"] == CLOZE_SELECT)
{
foreach ($gaps[$gi]["answers"] as $ai => $answer)
{
if (strcmp($answer["answertext"], $equals) == 0)
{
$gaps[$gi]["answers"][$ai]["action"] = $setvar->getAction();
$gaps[$gi]["answers"][$ai]["points"] = $setvar->getContent();
}
}
}
else if ($g["type"] == CLOZE_TEXT)
{
array_push($gaps[$gi]["answers"], array(
"answertext" => $equals,
"points" => $setvar->getContent(),
"answerorder" => count($gaps[$gi]["answers"]),
"action" => $setvar->getAction()
));
}
else if ($g["type"] == CLOZE_NUMERIC)
{
array_push($gaps[$gi]["answers"], array(
"answertext" => $equals,
"points" => $setvar->getContent(),
"answerorder" => count($gaps[$gi]["answers"]),
"action" => $setvar->getAction()
));
}
}
}
}
}
if (count($respcondition->displayfeedback))
{
foreach ($respcondition->displayfeedback as $feedbackpointer)
{
if (strlen($feedbackpointer->getLinkrefid()))
{
foreach ($item->itemfeedback as $ifb)
{
if (strcmp($ifb->getIdent(), "response_allcorrect") == 0)
{
// found a feedback for the identifier
if (count($ifb->material))
{
foreach ($ifb->material as $material)
{
$feedbacksgeneric[1] = $material;
}
}
if ((count($ifb->flow_mat) > 0))
{
foreach ($ifb->flow_mat as $fmat)
{
if (count($fmat->material))
{
foreach ($fmat->material as $material)
{
$feedbacksgeneric[1] = $material;
}
}
}
}
}
else if (strcmp($ifb->getIdent(), "response_onenotcorrect") == 0)
{
// found a feedback for the identifier
if (count($ifb->material))
{
foreach ($ifb->material as $material)
{
$feedbacksgeneric[0] = $material;
}
}
if ((count($ifb->flow_mat) > 0))
{
foreach ($ifb->flow_mat as $fmat)
{
if (count($fmat->material))
{
foreach ($fmat->material as $material)
{
$feedbacksgeneric[0] = $material;
}
}
}
}
}
}
}
}
}
}
}
$this->object->setTitle($item->getTitle());
$this->object->setComment($item->getComment());
$this->object->setAuthor($item->getAuthor());
$this->object->setOwner($ilUser->getId());
$this->object->setObjId($questionpool_id);
$this->object->setEstimatedWorkingTime($duration["h"], $duration["m"], $duration["s"]);
$textgap_rating = $item->getMetadataEntry("textgaprating");
$this->object->setFixedTextLength($item->getMetadataEntry("fixedTextLength"));
$this->object->setIdenticalScoring($item->getMetadataEntry("identicalScoring"));
if (strlen($textgap_rating) == 0) $textgap_rating = "ci";
$this->object->setTextgapRating($textgap_rating);
$gaptext = array();
foreach ($gaps as $gapidx => $gap)
{
$gapcontent = array();
include_once "./Modules/TestQuestionPool/classes/class.assClozeGap.php";
$clozegap = new assClozeGap($gap["type"]);
foreach ($gap["answers"] as $index => $answer)
{
include_once "./Modules/TestQuestionPool/classes/class.assAnswerCloze.php";
$gapanswer = new assAnswerCloze($answer["answertext"], $answer["points"], $answer["answerorder"]);
switch ($clozegap->getType())
{
$clozegap->setShuffle($answer["shuffle"]);
break;
$gapanswer->setLowerBound($gap["minnumber"]);
$gapanswer->setUpperBound($gap["maxnumber"]);
break;
}
$clozegap->addItem($gapanswer);
array_push($gapcontent, $answer["answertext"]);
}
$this->object->addGapAtIndex($clozegap, $gapidx);
$gaptext[$gap["ident"]] = "[gap]" . join(",", $gapcontent). "[/gap]";
}
$clozetext = join("", $questiontext);
foreach ($gaptext as $idx => $val)
{
$clozetext = str_replace("<<" . $idx . ">>", $val, $clozetext);
}
$this->object->setQuestion($clozetext);
$this->object->saveToDb();
// handle the import of media objects in XHTML code
foreach ($feedbacks as $ident => $material)
{
$m = $this->object->QTIMaterialToString($material);
$feedbacks[$ident] = $m;
}
foreach ($feedbacksgeneric as $correctness => $material)
{
$m = $this->object->QTIMaterialToString($material);
$feedbacksgeneric[$correctness] = $m;
}
$questiontext = $this->object->getQuestion();
if (is_array($_SESSION["import_mob_xhtml"]))
{
include_once "./Services/MediaObjects/classes/class.ilObjMediaObject.php";
include_once "./Services/RTE/classes/class.ilRTE.php";
foreach ($_SESSION["import_mob_xhtml"] as $mob)
{
if ($tst_id > 0)
{
include_once "./Modules/Test/classes/class.ilObjTest.php";
$importfile = ilObjTest::_getImportDirectory() . "/" . $_SESSION["tst_import_subdir"] . "/" . $mob["uri"];
}
else
{
include_once "./Modules/TestQuestionPool/classes/class.ilObjQuestionPool.php";
$importfile = ilObjQuestionPool::_getImportDirectory() . "/" . $_SESSION["qpl_import_subdir"] . "/" . $mob["uri"];
}
$media_object =& ilObjMediaObject::_saveTempFileAsMediaObject(basename($importfile), $importfile, FALSE);
$questiontext = str_replace("src=\"" . $mob["mob"] . "\"", "src=\"" . "il_" . IL_INST_ID . "_mob_" . $media_object->getId() . "\"", $questiontext);
foreach ($feedbacks as $ident => $material)
{
$feedbacks[$ident] = str_replace("src=\"" . $mob["mob"] . "\"", "src=\"" . "il_" . IL_INST_ID . "_mob_" . $media_object->getId() . "\"", $material);
}
foreach ($feedbacksgeneric as $correctness => $material)
{
$feedbacksgeneric[$correctness] = str_replace("src=\"" . $mob["mob"] . "\"", "src=\"" . "il_" . IL_INST_ID . "_mob_" . $media_object->getId() . "\"", $material);
}
}
}
$this->object->setQuestion(ilRTE::_replaceMediaObjectImageSrc($questiontext, 1));
foreach ($feedbacks as $ident => $material)
{
//$this->object->saveFeedbackSingleAnswer($ident, ilRTE::_replaceMediaObjectImageSrc($material, 1));
}
foreach ($feedbacksgeneric as $correctness => $material)
{
$this->object->saveFeedbackGeneric($correctness, ilRTE::_replaceMediaObjectImageSrc($material, 1));
}
$this->object->saveToDb();
if (count($item->suggested_solutions))
{
foreach ($item->suggested_solutions as $suggested_solution)
{
$this->object->setSuggestedSolution($suggested_solution["solution"]->getContent(), $suggested_solution["gap_index"], true);
}
$this->object->saveToDb();
}
if ($tst_id > 0)
{
$q_1_id = $this->object->getId();
$question_id = $this->object->duplicate(true);
$tst_object->questions[$question_counter++] = $question_id;
$import_mapping[$item->getIdent()] = array("pool" => $q_1_id, "test" => $question_id);
}
else
{
$import_mapping[$item->getIdent()] = array("pool" => $this->object->getId(), "test" => 0);
}
}

+ Here is the call graph for this function:


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