use of org.olat.core.gui.components.htmlheader.jscss.JSAndCSSFormItem in project openolat by klemens.
the class HotspotEditorController method initForm.
@Override
protected void initForm(FormItemContainer formLayout, Controller listener, UserRequest ureq) {
setFormContextHelp("Test editor QTI 2.1 in detail#details_testeditor_fragetypen_hotspot");
titleEl = uifactory.addTextElement("title", "form.imd.title", -1, itemBuilder.getTitle(), formLayout);
titleEl.setElementCssClass("o_sel_assessment_item_title");
titleEl.setMandatory(true);
titleEl.setEnabled(!readOnly);
String relativePath = rootDirectory.toPath().relativize(itemFile.toPath().getParent()).toString();
VFSContainer itemContainer = (VFSContainer) rootContainer.resolve(relativePath);
String question = itemBuilder.getQuestion();
textEl = uifactory.addRichTextElementForQTI21("desc", "form.imd.descr", question, 8, -1, itemContainer, formLayout, ureq.getUserSession(), getWindowControl());
textEl.addActionListener(FormEvent.ONCLICK);
textEl.setEnabled(!readOnly);
textEl.setVisible(!readOnly);
if (readOnly) {
FlowFormItem textReadOnlyEl = new FlowFormItem("descro", itemFile);
textReadOnlyEl.setLabel("form.imd.descr", null);
textReadOnlyEl.setBlocks(itemBuilder.getQuestionBlocks());
textReadOnlyEl.setMapperUri(mapperUri);
formLayout.add(textReadOnlyEl);
}
String[] cardinalityKeys = new String[] { Cardinality.SINGLE.name(), Cardinality.MULTIPLE.name() };
String[] cardinalityValues = new String[] { translate(Cardinality.SINGLE.name()), translate(Cardinality.MULTIPLE.name()) };
cardinalityEl = uifactory.addRadiosHorizontal("form.imd.cardinality", formLayout, cardinalityKeys, cardinalityValues);
cardinalityEl.setElementCssClass("o_sel_assessment_item_cardinality");
cardinalityEl.setEnabled(!restrictedEdit && !readOnly);
if (itemBuilder.isSingleChoice()) {
cardinalityEl.select(cardinalityKeys[0], true);
} else {
cardinalityEl.select(cardinalityKeys[1], true);
}
responsiveEl = uifactory.addCheckboxesHorizontal("form.imd.responsive", formLayout, onKeys, new String[] { "" });
responsiveEl.setHelpText(translate("form.imd.responsive.hint"));
responsiveEl.setEnabled(!restrictedEdit && !readOnly);
if (itemBuilder.isResponsive()) {
responsiveEl.select(onKeys[0], true);
}
initialBackgroundImage = getCurrentBackground();
backgroundEl = uifactory.addFileElement(getWindowControl(), "form.imd.background", "form.imd.background", formLayout);
backgroundEl.setEnabled(!restrictedEdit && !readOnly);
if (initialBackgroundImage != null) {
backgroundEl.setInitialFile(initialBackgroundImage);
}
backgroundEl.addActionListener(FormEvent.ONCHANGE);
backgroundEl.setDeleteEnabled(true);
backgroundEl.limitToMimeType(mimeTypes, "error.mimetype", new String[] { mimeTypes.toString() });
String[] resizeKeys = new String[] { "no" };
String[] resizeValues = new String[] { translate("form.imd.background.resize.no") };
resizeEl = uifactory.addRadiosHorizontal("form.imd.background.resize", formLayout, resizeKeys, resizeValues);
resizeEl.setVisible(false);
resizeEl.setEnabled(!readOnly);
if (initialBackgroundImage != null) {
Size size = imageService.getSize(new LocalFileImpl(initialBackgroundImage), null);
optimizeResizeEl(size, false);
}
// responses
String page = velocity_root + "/hotspots.html";
hotspotsCont = FormLayoutContainer.createCustomFormLayout("answers", getTranslator(), page);
hotspotsCont.getFormItemComponent().addListener(this);
hotspotsCont.setLabel("new.spots", null);
hotspotsCont.setRootForm(mainForm);
hotspotsCont.contextPut("mapperUri", backgroundMapperUri);
hotspotsCont.contextPut("restrictedEdit", restrictedEdit || readOnly);
JSAndCSSFormItem js = new JSAndCSSFormItem("js", new String[] { "js/jquery/openolat/jquery.drawing.js" });
formLayout.add(js);
formLayout.add(hotspotsCont);
newCircleButton = uifactory.addFormLink("new.circle", "new.circle", null, hotspotsCont, Link.BUTTON);
newCircleButton.setIconLeftCSS("o_icon o_icon-lg o_icon_circle");
newCircleButton.setVisible(!restrictedEdit && !readOnly);
newRectButton = uifactory.addFormLink("new.rectangle", "new.rectangle", null, hotspotsCont, Link.BUTTON);
newRectButton.setIconLeftCSS("o_icon o_icon-lg o_icon_rectangle");
newRectButton.setVisible(!restrictedEdit && !readOnly);
updateBackground();
String[] emptyKeys = new String[0];
correctHotspotsEl = uifactory.addCheckboxesHorizontal("form.imd.correct.spots", formLayout, emptyKeys, emptyKeys);
correctHotspotsEl.setElementCssClass("o_sel_assessment_item_correct_spots");
correctHotspotsEl.setEnabled(!restrictedEdit && !readOnly);
correctHotspotsEl.addActionListener(FormEvent.ONCHANGE);
rebuildWrappersAndCorrectSelection();
HotspotLayouts[] layouts = HotspotLayouts.values();
String[] layoutKeys = new String[layouts.length];
String[] layoutValues = new String[layouts.length];
for (int i = layouts.length; i-- > 0; ) {
layoutKeys[i] = layouts[i].cssClass();
layoutValues[i] = translate("hotspot.layout." + layouts[i].name());
}
layoutEl = uifactory.addDropdownSingleselect("hotspot.layout", "hotspot.layout", formLayout, layoutKeys, layoutValues, null);
layoutEl.addActionListener(FormEvent.ONCHANGE);
layoutEl.setEnabled(!readOnly);
boolean found = false;
for (int i = layoutKeys.length; i-- > 0; ) {
if (itemBuilder.hasHotspotInteractionClass(layoutKeys[i])) {
layoutEl.select(layoutKeys[i], true);
found = true;
}
}
if (!found) {
layoutEl.select(layoutKeys[0], true);
}
shadowEl = uifactory.addCheckboxesHorizontal("hotspot.layout.shadow", "hotspot.layout.shadow", formLayout, onKeys, new String[] { "" });
shadowEl.setEnabled(!readOnly);
if (!itemBuilder.hasHotspotInteractionClass(QTI21Constants.CSS_HOTSPOT_DISABLE_SHADOW)) {
shadowEl.select(onKeys[0], true);
}
updateLayoutCssClass();
// Submit Button
FormLayoutContainer buttonsContainer = FormLayoutContainer.createButtonLayout("buttons", getTranslator());
buttonsContainer.setElementCssClass("o_sel_hotspots_save");
buttonsContainer.setRootForm(mainForm);
buttonsContainer.setVisible(!readOnly);
formLayout.add(buttonsContainer);
uifactory.addFormSubmitButton("submit", buttonsContainer);
}
Aggregations