ILIAS  trunk Revision v11.0_alpha-3011-gc6b235a2e85
assErrorTextExport Class Reference

This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Learning e.V. More...

+ Inheritance diagram for assErrorTextExport:
+ Collaboration diagram for assErrorTextExport:

Public Member Functions

 toXML ($a_include_header=true, $a_include_binary=true, $a_shuffle=false, $test_output=false, $force_image_references=false)
 Returns a QTI xml representation of the question and sets the internal domxml variable with the DOM XML representation of the QTI xml representation. More...
 
- Public Member Functions inherited from assQuestionExport
 __construct ($a_object)
 assQuestionExport constructor More...
 
 exportFeedbackOnly ($a_xml_writer)
 
 toXML ($a_include_header=true, $a_include_binary=true, $a_shuffle=false, $test_output=false, $force_image_references=false)
 Returns a QTI xml representation of the question Returns a QTI xml representation of the question and sets the internal domxml variable with the DOM XML representation of the QTI xml representation. More...
 
 addQTIMaterial (ilXmlWriter $a_xml_writer, string $a_material, bool $close_material_tag=true, bool $add_mobs=true)
 

Additional Inherited Members

- Data Fields inherited from assQuestionExport
 $object
 
- Protected Member Functions inherited from assQuestionExport
 addAnswerSpecificFeedback (ilXmlWriter $a_xml_writer, $answers)
 
 addGenericFeedback (ilXmlWriter $a_xml_writer)
 
 addQtiMetaDataField (ilXmlWriter $a_xml_writer, $fieldLabel, $fieldValue)
 adds a qti meta data field with given name and value to the passed xml writer (xml writer must be in context of opened "qtimetadata" tag) More...
 
 addAdditionalContentEditingModeInformation (ilXmlWriter $a_xml_writer)
 adds a qti meta data field for ilias specific information of "additional content editing mode" (xml writer must be in context of opened "qtimetadata" tag) More...
 
 addGeneralMetadata (ilXmlWriter $xmlwriter)
 
 addSuggestedSolution (ilXmlWriter $writer)
 

Detailed Description

This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Learning e.V.

ILIAS is licensed with the GPL-3.0, see https://www.gnu.org/licenses/gpl-3.0.en.html You should have received a copy of said license along with the source code, too.

If this is not the case or you just want to try ILIAS, you'll find us at: https://www.ilias.de https://github.com/ILIAS-eLearning Class for error text question exports

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 26 of file class.assErrorTextExport.php.

Member Function Documentation

◆ toXML()

assErrorTextExport::toXML (   $a_include_header = true,
  $a_include_binary = true,
  $a_shuffle = false,
  $test_output = false,
  $force_image_references = false 
)

Returns a QTI xml representation of the question and sets the internal domxml variable with the DOM XML representation of the QTI xml representation.

Reimplemented from assQuestionExport.

Definition at line 32 of file class.assErrorTextExport.php.

32 : string
33 {
34 global $DIC;
35 $ilias = $DIC['ilias'];
36
37 $a_xml_writer = new ilXmlWriter();
38 // set xml header
39 $a_xml_writer->xmlHeader();
40 $a_xml_writer->xmlStartTag("questestinterop");
41 $attrs = [
42 "ident" => "il_" . IL_INST_ID . "_qst_" . $this->object->getId(),
43 "title" => $this->object->getTitle(),
44 "maxattempts" => $this->object->getNrOfTries()
45 ];
46 $a_xml_writer->xmlStartTag("item", $attrs);
47 // add question description
48 $a_xml_writer->xmlElement("qticomment", null, $this->object->getComment());
49 $a_xml_writer->xmlStartTag("itemmetadata");
50 $a_xml_writer->xmlStartTag("qtimetadata");
51 $a_xml_writer->xmlStartTag("qtimetadatafield");
52 $a_xml_writer->xmlElement("fieldlabel", null, "ILIAS_VERSION");
53 $a_xml_writer->xmlElement("fieldentry", null, $ilias->getSetting("ilias_version"));
54 $a_xml_writer->xmlEndTag("qtimetadatafield");
55 $a_xml_writer->xmlStartTag("qtimetadatafield");
56 $a_xml_writer->xmlElement("fieldlabel", null, "QUESTIONTYPE");
57 $a_xml_writer->xmlElement("fieldentry", null, $this->object->getQuestionType());
58 $a_xml_writer->xmlEndTag("qtimetadatafield");
59 $a_xml_writer->xmlStartTag("qtimetadatafield");
60 $a_xml_writer->xmlElement("fieldlabel", null, "AUTHOR");
61 $a_xml_writer->xmlElement("fieldentry", null, $this->object->getAuthor());
62 $a_xml_writer->xmlEndTag("qtimetadatafield");
63
64 // additional content editing information
66 $this->addGeneralMetadata($a_xml_writer);
67
68 $a_xml_writer->xmlStartTag("qtimetadatafield");
69 $a_xml_writer->xmlElement("fieldlabel", null, "points_wrong");
70 $a_xml_writer->xmlElement("fieldentry", null, $this->object->getPointsWrong());
71 $a_xml_writer->xmlEndTag("qtimetadatafield");
72 $a_xml_writer->xmlStartTag("qtimetadatafield");
73 $a_xml_writer->xmlElement("fieldlabel", null, "errortext");
74 $a_xml_writer->xmlElement("fieldentry", null, $this->object->getErrorText());
75 $a_xml_writer->xmlEndTag("qtimetadatafield");
76 $a_xml_writer->xmlStartTag("qtimetadatafield");
77 $a_xml_writer->xmlElement("fieldlabel", null, "parsederrortext");
78 $a_xml_writer->xmlElement("fieldentry", null, serialize($this->object->getParsedErrorText()));
79 $a_xml_writer->xmlEndTag("qtimetadatafield");
80 $a_xml_writer->xmlStartTag("qtimetadatafield");
81 $a_xml_writer->xmlElement("fieldlabel", null, "textsize");
82 $a_xml_writer->xmlElement("fieldentry", null, $this->object->getTextSize());
83 $a_xml_writer->xmlEndTag("qtimetadatafield");
84 $a_xml_writer->xmlStartTag("qtimetadatafield");
85 $a_xml_writer->xmlElement("fieldlabel", null, "errordata");
86 $serialized = [];
87 foreach ($this->object->getErrorData() as $data) {
88 array_push(
89 $serialized,
90 [
91 $data->getTextCorrect(),
92 $data->getTextWrong(),
93 $data->getPoints(),
94 $data->getPosition()
95 ]
96 );
97 }
98 $a_xml_writer->xmlElement("fieldentry", null, serialize($serialized));
99 $a_xml_writer->xmlEndTag("qtimetadatafield");
100 $a_xml_writer->xmlEndTag("qtimetadata");
101 $a_xml_writer->xmlEndTag("itemmetadata");
102
103 // PART I: qti presentation
104 $attrs = [
105 "label" => $this->object->getTitle()
106 ];
107 $a_xml_writer->xmlStartTag("presentation", $attrs);
108 // add flow to presentation
109 $a_xml_writer->xmlStartTag("flow");
110 // add material with question text to presentation
111 $this->addQTIMaterial($a_xml_writer, $this->object->getQuestion());
112 // add answers to presentation
113 $a_xml_writer->xmlEndTag("flow");
114 $a_xml_writer = $this->addSuggestedSolution($a_xml_writer);
115 $a_xml_writer->xmlEndTag("presentation");
116
117 $this->addGenericFeedback($a_xml_writer);
118
119 $this->addAnswerSpecificFeedback($a_xml_writer, $this->object->getErrorData());
120
121 $a_xml_writer->xmlEndTag("item");
122 $a_xml_writer->xmlEndTag("questestinterop");
123
124 $xml = $a_xml_writer->xmlDumpMem(false);
125 if (!$a_include_header) {
126 $pos = strpos($xml, "?>");
127 $xml = substr($xml, $pos + 2);
128 }
129 return $xml;
130 }
addGeneralMetadata(ilXmlWriter $xmlwriter)
addQTIMaterial(ilXmlWriter $a_xml_writer, string $a_material, bool $close_material_tag=true, bool $add_mobs=true)
addSuggestedSolution(ilXmlWriter $writer)
addAnswerSpecificFeedback(ilXmlWriter $a_xml_writer, $answers)
addGenericFeedback(ilXmlWriter $a_xml_writer)
addAdditionalContentEditingModeInformation(ilXmlWriter $a_xml_writer)
adds a qti meta data field for ilias specific information of "additional content editing mode" (xml w...
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
const IL_INST_ID
Definition: constants.php:40
global $DIC
Definition: shib_login.php:26

References $data, $DIC, assQuestionExport\addAdditionalContentEditingModeInformation(), assQuestionExport\addAnswerSpecificFeedback(), assQuestionExport\addGeneralMetadata(), assQuestionExport\addGenericFeedback(), assQuestionExport\addQTIMaterial(), assQuestionExport\addSuggestedSolution(), IL_INST_ID, and ILIAS\Repository\object().

+ Here is the call graph for this function:

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