fix docu and code cleanup

This commit is contained in:
anhefti 2020-03-05 15:25:05 +01:00
parent b811bb5f29
commit df884bd8d2
4 changed files with 316 additions and 298 deletions

View file

@ -11,3 +11,7 @@ TODO
Exam Configuration
-------------------
TODO
Configuration Templates
------------------------

View file

@ -82,13 +82,35 @@ After successful login, one will see the main graphical user interface of the SE
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/overview.png
The main content usually is a list or a form.
In the header above on the right hand, we see the username of the currently logged in user and an action button the sign out and go back to the login page.
Overview
^^^^^^^^
The main content usually consist of a list or a form.
Lists
^^^^^^
A list shows all the objects of a particular activity in a table page. If the list contains as for one page, a page navigation is shown at the bottom of the list with the information of the current page and the number of pages along with a page navigation that can be used to navigate forward and backward thought the list pages.
Almost all lists have the ability to filter the content by certain column filter that are right above the corresponding columns. To filter a list one can use the column filter input to narrow down a specific collection of content. Accordingly to the value type of the column, there are different types of filter:
- Selection, to select one instance of a defined collection of values (drop-down).
- Text input, to write some text that a value must contain.
- Date selection, To select a from-date from a date-picker. A date selection can also have an additional time selection within separate input field
- Date range selection, To select a from- and a to-date within different inputs and a date-picker. A date range selection can also have an additional time range selection within separate input fields
.. image:: images/overview/list.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/list.png
A list can also be sorted by a column by clicking in the column header and the order of sorting can be changed by clicking again on the same column header. Depending on the column type, not all columns has the sort functionality.
Most columns have a short tool-tip description that pops up while the mouse pointer stays over the column header for a moment.
Forms
^^^^^^
.. image:: images/overview/form_readonly.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/form_readonly.png
.. image:: images/overview/form_edit.png
:align: center
:target: https://raw.githubusercontent.com/SafeExamBrowser/seb-server/master/docs/images/overview/form_edit.png

View file

@ -311,19 +311,18 @@ public class SebClientConfigForm implements TemplateComposer {
);
formHandle.getForm().getFieldInput(SebClientConfig.ATTR_FALLBACK)
.addListener(SWT.Selection, event -> {
formHandle.process(
FALLBACK_ATTRIBUTES::contains,
ffa -> {
boolean selected = ((Button) event.widget).getSelection();
ffa.setVisible(selected);
if (!selected && ffa.hasError()) {
ffa.resetError();
ffa.setStringValue(StringUtils.EMPTY);
}
.addListener(SWT.Selection, event -> formHandle.process(
FALLBACK_ATTRIBUTES::contains,
ffa -> {
boolean selected = ((Button) event.widget).getSelection();
ffa.setVisible(selected);
if (!selected && ffa.hasError()) {
ffa.resetError();
ffa.setStringValue(StringUtils.EMPTY);
}
);
});
}
));
final UrlLauncher urlLauncher = RWT.getClient().getService(UrlLauncher.class);
this.pageService.pageActionBuilder(formContext.clearEntityKeys())

View file

@ -80,27 +80,24 @@ public class ActionPane implements TemplateComposer {
label.setData(
PageEventListener.LISTENER_ATTRIBUTE_KEY,
new ActionPublishEventListener() {
@Override
public void notify(final ActionPublishEvent event) {
final Composite parent = pageContext.getParent();
final Tree treeForGroup = getTreeForGroup(parent, event.action.definition);
final TreeItem actionItem = ActionPane.this.widgetFactory.treeItemLocalized(
treeForGroup,
event.action.definition.title);
(ActionPublishEventListener) event -> {
final Composite parent = pageContext.getParent();
final Tree treeForGroup = getTreeForGroup(parent, event.action.definition);
final TreeItem actionItem = ActionPane.this.widgetFactory.treeItemLocalized(
treeForGroup,
event.action.definition.title);
final Image image = event.active
? event.action.definition.icon.getImage(parent.getDisplay())
: event.action.definition.icon.getGreyedImage(parent.getDisplay());
final Image image = event.active
? event.action.definition.icon.getImage(parent.getDisplay())
: event.action.definition.icon.getGreyedImage(parent.getDisplay());
if (!event.active) {
actionItem.setForeground(new Color(parent.getDisplay(), new RGBA(150, 150, 150, 50)));
}
actionItem.setImage(image);
actionItem.setData(ACTION_EVENT_CALL_KEY, event.action);
parent.layout();
if (!event.active) {
actionItem.setForeground(new Color(parent.getDisplay(), new RGBA(150, 150, 150, 50)));
}
actionItem.setImage(image);
actionItem.setData(ACTION_EVENT_CALL_KEY, event.action);
parent.layout();
});
final Composite composite = new Composite(pageContext.getParent(), SWT.NONE);
@ -113,37 +110,34 @@ public class ActionPane implements TemplateComposer {
composite.setData(
PageEventListener.LISTENER_ATTRIBUTE_KEY,
new ActionActivationEventListener() {
@Override
public void notify(final ActionActivationEvent event) {
final Composite parent = pageContext.getParent();
for (final ActionDefinition ad : event.actions) {
final TreeItem actionItem = findAction(parent, ad);
if (actionItem == null) {
continue;
}
final Image image = event.activation
? ad.icon.getImage(parent.getDisplay())
: ad.icon.getGreyedImage(parent.getDisplay());
actionItem.setImage(image);
if (event.activation) {
actionItem.setForeground(null);
} else {
actionItem.setForeground(new Color(parent.getDisplay(), new RGBA(150, 150, 150, 50)));
ActionPane.this.pageService.getPolyglotPageService().injectI18n(actionItem, ad.title);
}
(ActionActivationEventListener) event -> {
final Composite parent = pageContext.getParent();
for (final ActionDefinition ad : event.actions) {
final TreeItem actionItem = findAction(parent, ad);
if (actionItem == null) {
continue;
}
if (event.decoration != null) {
final TreeItem actionItemToDecorate = findAction(parent, event.decoration._1);
if (actionItemToDecorate != null && event.decoration._2 != null) {
actionItemToDecorate.setImage(0,
event.decoration._2.icon.getImage(parent.getDisplay()));
ActionPane.this.pageService.getPolyglotPageService().injectI18n(
actionItemToDecorate,
event.decoration._2.title);
}
final Image image = event.activation
? ad.icon.getImage(parent.getDisplay())
: ad.icon.getGreyedImage(parent.getDisplay());
actionItem.setImage(image);
if (event.activation) {
actionItem.setForeground(null);
} else {
actionItem.setForeground(new Color(parent.getDisplay(), new RGBA(150, 150, 150, 50)));
ActionPane.this.pageService.getPolyglotPageService().injectI18n(actionItem, ad.title);
}
}
if (event.decoration != null) {
final TreeItem actionItemToDecorate = findAction(parent, event.decoration._1);
if (actionItemToDecorate != null && event.decoration._2 != null) {
actionItemToDecorate.setImage(0,
event.decoration._2.icon.getImage(parent.getDisplay()));
ActionPane.this.pageService.getPolyglotPageService().injectI18n(
actionItemToDecorate,
event.decoration._2.title);
}
}
});
@ -264,7 +258,6 @@ public class ActionPane implements TemplateComposer {
private void clearDisposedTrees() {
new ArrayList<>(this.actionTrees.entrySet())
.stream()
.forEach(entry -> {
final Control c = entry.getValue();
// of tree is already disposed.. remove it