This commit is contained in:
anhefti 2021-04-07 12:43:07 +02:00
parent 357251d40b
commit 7cd2d3566d
4 changed files with 125 additions and 108 deletions

View file

@ -23,7 +23,6 @@ import org.slf4j.LoggerFactory;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigurationAttribute; import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigurationAttribute;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation; import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation;
import ch.ethz.seb.sebserver.gbl.util.Utils; import ch.ethz.seb.sebserver.gbl.util.Utils;
import ch.ethz.seb.sebserver.gui.service.examconfig.impl.CellFieldBuilderAdapter.ExpandBarCellFieldBuilderAdapter;
public class AttributeMapping { public class AttributeMapping {
@ -163,7 +162,7 @@ public class AttributeMapping {
return Collections.emptyList(); return Collections.emptyList();
} }
final String expandGroupKey = ExpandBarCellFieldBuilderAdapter.getExpandGroupKey(orientation.groupId); final String expandGroupKey = ViewGridBuilder.getExpandGroupKey(orientation.groupId);
if (expandGroupKey == null) { if (expandGroupKey == null) {
return Collections.emptyList(); return Collections.emptyList();
} }

View file

@ -12,24 +12,19 @@ import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.lang3.StringUtils;
import org.eclipse.swt.SWT; import org.eclipse.swt.SWT;
import org.eclipse.swt.layout.GridData; import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.widgets.Composite; import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.ExpandBar; import org.eclipse.swt.widgets.ExpandBar;
import org.eclipse.swt.widgets.ExpandItem;
import org.eclipse.swt.widgets.Group; import org.eclipse.swt.widgets.Group;
import org.eclipse.swt.widgets.Label; import org.eclipse.swt.widgets.Label;
import ch.ethz.seb.sebserver.gbl.Constants;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigurationAttribute; import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigurationAttribute;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation; import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.TitleOrientation; import ch.ethz.seb.sebserver.gbl.model.sebconfig.TitleOrientation;
import ch.ethz.seb.sebserver.gui.service.examconfig.ExamConfigurationService; import ch.ethz.seb.sebserver.gui.service.examconfig.ExamConfigurationService;
import ch.ethz.seb.sebserver.gui.service.examconfig.InputField;
import ch.ethz.seb.sebserver.gui.service.examconfig.InputFieldBuilder;
import ch.ethz.seb.sebserver.gui.service.i18n.LocTextKey; import ch.ethz.seb.sebserver.gui.service.i18n.LocTextKey;
import ch.ethz.seb.sebserver.gui.widget.WidgetFactory; import ch.ethz.seb.sebserver.gui.widget.WidgetFactory;
@ -51,31 +46,6 @@ interface CellFieldBuilderAdapter {
default void balanceGrid(final CellFieldBuilderAdapter[][] grid, final int x, final int y) { default void balanceGrid(final CellFieldBuilderAdapter[][] grid, final int x, final int y) {
} }
static CellFieldBuilderAdapter fieldBuilderAdapter(
final InputFieldBuilder inputFieldBuilder,
final ConfigurationAttribute attribute) {
return new CellFieldBuilderAdapter() {
@Override
public void createCell(final ViewGridBuilder builder) {
final InputField inputField = inputFieldBuilder.createInputField(
builder.parent,
attribute,
builder.viewContext);
if (inputField != null) {
builder.viewContext.registerInputField(inputField);
}
}
@Override
public String toString() {
return "[FIELD]";
}
};
}
static CellFieldBuilderAdapter labelBuilder( static CellFieldBuilderAdapter labelBuilder(
final ConfigurationAttribute attribute, final ConfigurationAttribute attribute,
final Orientation orientation) { final Orientation orientation) {
@ -234,8 +204,6 @@ interface CellFieldBuilderAdapter {
class ExpandBarCellFieldBuilderAdapter implements CellFieldBuilderAdapter { class ExpandBarCellFieldBuilderAdapter implements CellFieldBuilderAdapter {
public final static Pattern EXPAND_BAR_GROUP_PATTERN = Pattern.compile("\\[(.*?)\\]");
final Map<String, Collection<Orientation>> orientationsOfExpandBar; final Map<String, Collection<Orientation>> orientationsOfExpandBar;
int x = 100; int x = 100;
@ -243,58 +211,11 @@ interface CellFieldBuilderAdapter {
int width = 1; int width = 1;
int height = 1; int height = 1;
public static final String getExpandKey(final String groupId) {
final Matcher matcher = EXPAND_BAR_GROUP_PATTERN.matcher(groupId);
if (matcher.find()) {
String expandableGroup = matcher.group();
expandableGroup = expandableGroup.substring(1, expandableGroup.length() - 1);
return expandableGroup;
}
return null;
}
public static final String getExpandGroupKey(final String groupId) {
String expandKey = getExpandKey(groupId);
if (expandKey == null) {
if (StringUtils.isNotBlank(groupId) && groupId.contains(Constants.EMBEDDED_LIST_SEPARATOR)) {
expandKey = groupId;
} else {
return null;
}
}
final String[] split = StringUtils.split(expandKey, Constants.EMBEDDED_LIST_SEPARATOR);
if (split != null && split.length > 0) {
return split[0];
}
return null;
}
public static final String getExpandItemKey(final String groupId) {
String expandKey = getExpandKey(groupId);
if (expandKey == null) {
if (StringUtils.isNotBlank(groupId) && groupId.contains(Constants.EMBEDDED_LIST_SEPARATOR)) {
expandKey = groupId;
} else {
return null;
}
}
final String[] split = StringUtils.split(expandKey, Constants.EMBEDDED_LIST_SEPARATOR);
if (split != null && split.length > 1) {
return split[1];
}
return null;
}
ExpandBarCellFieldBuilderAdapter(final Collection<Orientation> orientationsOfExpandBar) { ExpandBarCellFieldBuilderAdapter(final Collection<Orientation> orientationsOfExpandBar) {
this.orientationsOfExpandBar = new HashMap<>(); this.orientationsOfExpandBar = new HashMap<>();
for (final Orientation o : orientationsOfExpandBar) { for (final Orientation o : orientationsOfExpandBar) {
final String expandKey = getExpandKey(o.groupId); final String expandKey = ViewGridBuilder.getExpandKey(o.groupId);
if (expandKey == null) { if (expandKey == null) {
continue; continue;
} }
@ -323,7 +244,7 @@ interface CellFieldBuilderAdapter {
.stream() .stream()
.findFirst() .findFirst()
.map(key -> { .map(key -> {
final String expandGroupKey = getExpandGroupKey(key); final String expandGroupKey = ViewGridBuilder.getExpandGroupKey(key);
return new LocTextKey( return new LocTextKey(
ExamConfigurationService.TOOL_TIP_SUFFIX + expandGroupKey, ExamConfigurationService.TOOL_TIP_SUFFIX + expandGroupKey,
expandGroupKey); expandGroupKey);
@ -332,23 +253,25 @@ interface CellFieldBuilderAdapter {
final ExpandBar expandBar = widgetFactory.expandBarLocalized( final ExpandBar expandBar = widgetFactory.expandBarLocalized(
builder.parent, builder.parent,
expandTooltipText); expandTooltipText);
expandBar.setLayoutData(new GridData(SWT.FILL, SWT.TOP, true, false, this.width, this.height)); expandBar.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, false, this.width, this.height + 2));
for (final Map.Entry<String, Collection<Orientation>> entry : this.orientationsOfExpandBar.entrySet()) { for (final Map.Entry<String, Collection<Orientation>> entry : this.orientationsOfExpandBar.entrySet()) {
final String expandItemKey = getExpandItemKey(entry.getKey()); final String expandItemKey = ViewGridBuilder.getExpandItemKey(entry.getKey());
final Collection<Orientation> value = entry.getValue(); final Collection<Orientation> value = entry.getValue();
final LocTextKey labelKey = new LocTextKey( final LocTextKey labelKey = new LocTextKey(
ExamConfigurationService.GROUP_LABEL_LOC_TEXT_PREFIX + expandItemKey, ExamConfigurationService.GROUP_LABEL_LOC_TEXT_PREFIX + expandItemKey,
expandItemKey); expandItemKey);
final Composite expandItem = widgetFactory.expandItemLocalized( final ExpandItem expandItem = widgetFactory.expandItemLocalized(
expandBar, expandBar,
this.width, this.width,
labelKey); labelKey);
expandItem.setHeight(this.height * 25);
final Composite body = (Composite) expandItem.getControl();
final ViewGridBuilder expandBuilder = new ViewGridBuilder( final ViewGridBuilder expandBuilder = new ViewGridBuilder(
expandItem, body,
builder.viewContext, builder.viewContext,
this, this,
builder.examConfigurationService); builder.examConfigurationService);
@ -361,4 +284,5 @@ interface CellFieldBuilderAdapter {
} }
} }
} }
} }

View file

@ -11,6 +11,8 @@ package ch.ethz.seb.sebserver.gui.service.examconfig.impl;
import java.util.Arrays; import java.util.Arrays;
import java.util.HashSet; import java.util.HashSet;
import java.util.Set; import java.util.Set;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.lang3.BooleanUtils; import org.apache.commons.lang3.BooleanUtils;
import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.StringUtils;
@ -21,10 +23,12 @@ import org.eclipse.swt.widgets.Label;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import ch.ethz.seb.sebserver.gbl.Constants;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.AttributeType; import ch.ethz.seb.sebserver.gbl.model.sebconfig.AttributeType;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigurationAttribute; import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigurationAttribute;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation; import ch.ethz.seb.sebserver.gbl.model.sebconfig.Orientation;
import ch.ethz.seb.sebserver.gui.service.examconfig.ExamConfigurationService; import ch.ethz.seb.sebserver.gui.service.examconfig.ExamConfigurationService;
import ch.ethz.seb.sebserver.gui.service.examconfig.InputField;
import ch.ethz.seb.sebserver.gui.service.examconfig.InputFieldBuilder; import ch.ethz.seb.sebserver.gui.service.examconfig.InputFieldBuilder;
import ch.ethz.seb.sebserver.gui.service.examconfig.impl.CellFieldBuilderAdapter.ExpandBarCellFieldBuilderAdapter; import ch.ethz.seb.sebserver.gui.service.examconfig.impl.CellFieldBuilderAdapter.ExpandBarCellFieldBuilderAdapter;
import ch.ethz.seb.sebserver.gui.service.examconfig.impl.CellFieldBuilderAdapter.GroupCellFieldBuilderAdapter; import ch.ethz.seb.sebserver.gui.service.examconfig.impl.CellFieldBuilderAdapter.GroupCellFieldBuilderAdapter;
@ -33,6 +37,8 @@ public class ViewGridBuilder {
private static final Logger log = LoggerFactory.getLogger(ViewGridBuilder.class); private static final Logger log = LoggerFactory.getLogger(ViewGridBuilder.class);
public static Pattern EXPAND_BAR_GROUP_PATTERN = Pattern.compile("\\[(.*?)\\]");
final ExamConfigurationService examConfigurationService; final ExamConfigurationService examConfigurationService;
final Composite parent; final Composite parent;
final ViewContext viewContext; final ViewContext viewContext;
@ -101,6 +107,95 @@ public class ViewGridBuilder {
this.registeredExpandables = null; this.registeredExpandables = null;
} }
public static String getGroupKey(final String groupId) {
if (groupId == null || !groupId.contains(Constants.SQUARE_BRACE_OPEN.toString())) {
return groupId;
}
if (groupId.startsWith(Constants.SQUARE_BRACE_OPEN.toString())) {
return null;
}
final String[] split = StringUtils.split(groupId, Constants.SQUARE_BRACE_OPEN);
if (split != null && split.length > 0) {
return split[0];
}
return null;
}
public static String getExpandKey(final String groupId) {
final Matcher matcher = EXPAND_BAR_GROUP_PATTERN.matcher(groupId);
if (matcher.find()) {
String expandableGroup = matcher.group();
expandableGroup = expandableGroup.substring(1, expandableGroup.length() - 1);
return expandableGroup;
}
return null;
}
public static String getExpandGroupKey(final String groupId) {
String expandKey = getExpandKey(groupId);
if (expandKey == null) {
if (StringUtils.isNotBlank(groupId) && groupId.contains(Constants.EMBEDDED_LIST_SEPARATOR)) {
expandKey = groupId;
} else {
return null;
}
}
final String[] split = StringUtils.split(expandKey, Constants.EMBEDDED_LIST_SEPARATOR);
if (split != null && split.length > 0) {
return split[0];
}
return null;
}
public static String getExpandItemKey(final String groupId) {
String expandKey = getExpandKey(groupId);
if (expandKey == null) {
if (StringUtils.isNotBlank(groupId) && groupId.contains(Constants.EMBEDDED_LIST_SEPARATOR)) {
expandKey = groupId;
} else {
return null;
}
}
final String[] split = StringUtils.split(expandKey, Constants.EMBEDDED_LIST_SEPARATOR);
if (split != null && split.length > 1) {
return split[1];
}
return null;
}
public static CellFieldBuilderAdapter fieldBuilderAdapter(
final InputFieldBuilder inputFieldBuilder,
final ConfigurationAttribute attribute) {
return new CellFieldBuilderAdapter() {
@Override
public void createCell(final ViewGridBuilder builder) {
final InputField inputField = inputFieldBuilder.createInputField(
builder.parent,
attribute,
builder.viewContext);
if (inputField != null) {
builder.viewContext.registerInputField(inputField);
}
}
@Override
public String toString() {
return "[FIELD]";
}
};
}
ViewGridBuilder add(final ConfigurationAttribute attribute) { ViewGridBuilder add(final ConfigurationAttribute attribute) {
if (log.isDebugEnabled()) { if (log.isDebugEnabled()) {
log.debug("Add SEB Configuration Attribute: " + attribute); log.debug("Add SEB Configuration Attribute: " + attribute);
@ -121,7 +216,7 @@ public class ViewGridBuilder {
// create group builder // create group builder
if (StringUtils.isNotBlank(orientation.groupId)) { if (StringUtils.isNotBlank(orientation.groupId)) {
final String expandGroupKey = ExpandBarCellFieldBuilderAdapter.getExpandGroupKey(orientation.groupId); final String expandGroupKey = getExpandGroupKey(orientation.groupId);
if (!this.isExpandBarBuilder && !this.isGroupBuilder && expandGroupKey != null) { if (!this.isExpandBarBuilder && !this.isGroupBuilder && expandGroupKey != null) {
if (this.registeredExpandables.contains(expandGroupKey)) { if (this.registeredExpandables.contains(expandGroupKey)) {
return this; return this;
@ -137,7 +232,9 @@ public class ViewGridBuilder {
} }
if (!this.isGroupBuilder) { if (!this.isGroupBuilder) {
if (this.registeredGroups.contains(orientation.groupId)) { final String groupKey = getGroupKey(orientation.groupId);
if (groupKey != null) {
if (this.registeredGroups.contains(groupKey)) {
return this; return this;
} }
@ -149,13 +246,10 @@ public class ViewGridBuilder {
fillDummy(xpos, ypos, groupBuilder.width, groupBuilder.height); fillDummy(xpos, ypos, groupBuilder.width, groupBuilder.height);
this.grid[ypos][xpos] = groupBuilder; this.grid[ypos][xpos] = groupBuilder;
this.registeredGroups.add(orientation.groupId); this.registeredGroups.add(groupKey);
return this; return this;
} }
} }
if (this.isExpandBarBuilder) {
System.out.print("**************** attr:" + attribute.name);
} }
// create single input field with label // create single input field with label
@ -170,7 +264,7 @@ public class ViewGridBuilder {
attribute, attribute,
orientation); orientation);
this.grid[ypos][xpos] = CellFieldBuilderAdapter.fieldBuilderAdapter( this.grid[ypos][xpos] = fieldBuilderAdapter(
inputFieldBuilder, inputFieldBuilder,
attribute); attribute);

View file

@ -533,7 +533,7 @@ public class WidgetFactory {
return expandBar; return expandBar;
} }
public Composite expandItemLocalized( public ExpandItem expandItemLocalized(
final ExpandBar parent, final ExpandBar parent,
final int columns, final int columns,
final LocTextKey locTextKey) { final LocTextKey locTextKey) {
@ -548,7 +548,7 @@ public class WidgetFactory {
expandItem.setControl(body); expandItem.setControl(body);
this.polyglotPageService.injectI18n(expandItem, locTextKey); this.polyglotPageService.injectI18n(expandItem, locTextKey);
return body; return expandItem;
} }
public Tree treeLocalized(final Composite parent, final int style) { public Tree treeLocalized(final Composite parent, final int style) {