SEBSLI-4 institution feature and full feature message mockup
This commit is contained in:
parent
52192619fd
commit
12f67149f0
11 changed files with 77 additions and 6 deletions
|
@ -181,6 +181,8 @@ public class ActivitiesPane implements TemplateComposer {
|
||||||
sebAdmin.dispose();
|
sebAdmin.dispose();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// ---- SEB ADMIN ----------------------------------------------------------------------
|
// ---- SEB ADMIN ----------------------------------------------------------------------
|
||||||
//--------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -445,6 +447,9 @@ public class ActivitiesPane implements TemplateComposer {
|
||||||
private TreeItem getDefaultSelectionFor(final Tree navigation, final CurrentUser currentUser2) {
|
private TreeItem getDefaultSelectionFor(final Tree navigation, final CurrentUser currentUser2) {
|
||||||
try {
|
try {
|
||||||
if (this.currentUser.get().hasAnyRole(UserRole.SEB_SERVER_ADMIN, UserRole.INSTITUTIONAL_ADMIN)) {
|
if (this.currentUser.get().hasAnyRole(UserRole.SEB_SERVER_ADMIN, UserRole.INSTITUTIONAL_ADMIN)) {
|
||||||
|
if (pageService.isSEBServerLightSetup()) {
|
||||||
|
return navigation.getItem(0).getItem(1);
|
||||||
|
}
|
||||||
return navigation.getItem(0);
|
return navigation.getItem(0);
|
||||||
} else if (this.currentUser.get().hasAnyRole(UserRole.EXAM_ADMIN)) {
|
} else if (this.currentUser.get().hasAnyRole(UserRole.EXAM_ADMIN)) {
|
||||||
return findItemByActionDefinition(
|
return findItemByActionDefinition(
|
||||||
|
|
|
@ -94,6 +94,12 @@ public class InstitutionList implements TemplateComposer {
|
||||||
pageContext.getParent(),
|
pageContext.getParent(),
|
||||||
TITLE_TEXT_KEY);
|
TITLE_TEXT_KEY);
|
||||||
|
|
||||||
|
if (pageService.isSEBServerLightSetup()) {
|
||||||
|
pageService.applyFullVersionNote(content, pageContext);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
final PageActionBuilder pageActionBuilder =
|
final PageActionBuilder pageActionBuilder =
|
||||||
this.pageService.pageActionBuilder(pageContext.clearEntityKeys());
|
this.pageService.pageActionBuilder(pageContext.clearEntityKeys());
|
||||||
|
|
||||||
|
|
|
@ -27,6 +27,7 @@ public interface PageContext {
|
||||||
|
|
||||||
Logger log = LoggerFactory.getLogger(PageContext.class);
|
Logger log = LoggerFactory.getLogger(PageContext.class);
|
||||||
|
|
||||||
|
|
||||||
/** Defines attribute keys that can be used to store attribute values within the page context state */
|
/** Defines attribute keys that can be used to store attribute values within the page context state */
|
||||||
interface AttributeKeys {
|
interface AttributeKeys {
|
||||||
|
|
||||||
|
|
|
@ -127,6 +127,13 @@ public interface PageService {
|
||||||
* @return the configured tooltip mode for input forms */
|
* @return the configured tooltip mode for input forms */
|
||||||
FormTooltipMode getFormTooltipMode();
|
FormTooltipMode getFormTooltipMode();
|
||||||
|
|
||||||
|
/** Indicates if SEB Server runs with SEB Server light setup
|
||||||
|
*
|
||||||
|
* @return true if this is a SEB Server light setup*/
|
||||||
|
boolean isSEBServerLightSetup();
|
||||||
|
|
||||||
|
void applyFullVersionNote(Composite content, PageContext pageContext);
|
||||||
|
|
||||||
/** Get a PageAction function to go back to the current state.
|
/** Get a PageAction function to go back to the current state.
|
||||||
*
|
*
|
||||||
* @return a PageAction function to go back to the current state. */
|
* @return a PageAction function to go back to the current state. */
|
||||||
|
|
|
@ -20,7 +20,9 @@ import java.util.function.Supplier;
|
||||||
|
|
||||||
import javax.servlet.http.HttpSession;
|
import javax.servlet.http.HttpSession;
|
||||||
|
|
||||||
|
import ch.ethz.seb.sebserver.gui.GuiServiceInfo;
|
||||||
import org.eclipse.rap.rwt.RWT;
|
import org.eclipse.rap.rwt.RWT;
|
||||||
|
import org.eclipse.swt.widgets.Composite;
|
||||||
import org.eclipse.swt.widgets.TreeItem;
|
import org.eclipse.swt.widgets.TreeItem;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
@ -88,6 +90,7 @@ public class PageServiceImpl implements PageService {
|
||||||
private final ResourceService resourceService;
|
private final ResourceService resourceService;
|
||||||
private final CurrentUser currentUser;
|
private final CurrentUser currentUser;
|
||||||
private final ServerPushService serverPushService;
|
private final ServerPushService serverPushService;
|
||||||
|
private final GuiServiceInfo guiServiceInfo;
|
||||||
|
|
||||||
public PageServiceImpl(
|
public PageServiceImpl(
|
||||||
final Cryptor cryptor,
|
final Cryptor cryptor,
|
||||||
|
@ -96,7 +99,8 @@ public class PageServiceImpl implements PageService {
|
||||||
final PolyglotPageService polyglotPageService,
|
final PolyglotPageService polyglotPageService,
|
||||||
final ResourceService resourceService,
|
final ResourceService resourceService,
|
||||||
final CurrentUser currentUser,
|
final CurrentUser currentUser,
|
||||||
final ServerPushService serverPushService) {
|
final ServerPushService serverPushService,
|
||||||
|
final GuiServiceInfo guiServiceInfo) {
|
||||||
|
|
||||||
this.cryptor = cryptor;
|
this.cryptor = cryptor;
|
||||||
this.jsonMapper = jsonMapper;
|
this.jsonMapper = jsonMapper;
|
||||||
|
@ -105,6 +109,7 @@ public class PageServiceImpl implements PageService {
|
||||||
this.resourceService = resourceService;
|
this.resourceService = resourceService;
|
||||||
this.currentUser = currentUser;
|
this.currentUser = currentUser;
|
||||||
this.serverPushService = serverPushService;
|
this.serverPushService = serverPushService;
|
||||||
|
this.guiServiceInfo = guiServiceInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -182,6 +187,19 @@ public class PageServiceImpl implements PageService {
|
||||||
return FormTooltipMode.INPUT;
|
return FormTooltipMode.INPUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isSEBServerLightSetup() {
|
||||||
|
return this.guiServiceInfo.isLightSetup();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final LocTextKey FULL_VERSION_NOTE = new LocTextKey("sebserver.features.lightsetup.fullversion.message");
|
||||||
|
@Override
|
||||||
|
public void applyFullVersionNote(final Composite content, final PageContext pageContext) {
|
||||||
|
final Composite warningPanel = this.widgetFactory.createWarningPanel(content);
|
||||||
|
warningPanel.setData(RWT.CUSTOM_VARIANT, WidgetFactory.CustomVariant.NOTE.key);
|
||||||
|
this.widgetFactory.labelLocalizedNote(warningPanel, FULL_VERSION_NOTE);
|
||||||
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
@Override
|
@Override
|
||||||
public <T extends PageEvent> void firePageEvent(final T event, final PageContext pageContext) {
|
public <T extends PageEvent> void firePageEvent(final T event, final PageContext pageContext) {
|
||||||
|
|
|
@ -220,6 +220,7 @@ public class WidgetFactory {
|
||||||
MESSAGE("message"),
|
MESSAGE("message"),
|
||||||
ERROR("error"),
|
ERROR("error"),
|
||||||
WARNING("warning"),
|
WARNING("warning"),
|
||||||
|
NOTE("note"),
|
||||||
DISABLED("disabled"),
|
DISABLED("disabled"),
|
||||||
CONFIG_INPUT_READONLY("inputreadonly"),
|
CONFIG_INPUT_READONLY("inputreadonly"),
|
||||||
|
|
||||||
|
@ -507,6 +508,14 @@ public class WidgetFactory {
|
||||||
labelLocalized.setLayoutData(gridData);
|
labelLocalized.setLayoutData(gridData);
|
||||||
return labelLocalized;
|
return labelLocalized;
|
||||||
}
|
}
|
||||||
|
public Label labelLocalizedNote(final Composite content, final LocTextKey locTextKey) {
|
||||||
|
final Label labelLocalized = labelLocalized(content, CustomVariant.NOTE, locTextKey);
|
||||||
|
labelLocalized.setData(RWT.MARKUP_ENABLED, true);
|
||||||
|
final GridData gridData = new GridData(SWT.FILL, SWT.FILL, true, false);
|
||||||
|
labelLocalized.setLayoutData(gridData);
|
||||||
|
return labelLocalized;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public Text textInput(final Composite content, final LocTextKey ariaLabel) {
|
public Text textInput(final Composite content, final LocTextKey ariaLabel) {
|
||||||
return textInput(content, false, false, ariaLabel.name, ariaLabel);
|
return textInput(content, false, false, ariaLabel.name, ariaLabel);
|
||||||
|
|
|
@ -114,11 +114,19 @@ public class WebserviceInit implements ApplicationListener<ApplicationReadyEvent
|
||||||
SEBServerInit.INIT_LOGGER.info("----> JDBC connection pool max size: {}",
|
SEBServerInit.INIT_LOGGER.info("----> JDBC connection pool max size: {}",
|
||||||
this.environment.getProperty("spring.datasource.hikari.maximumPoolSize"));
|
this.environment.getProperty("spring.datasource.hikari.maximumPoolSize"));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (this.webserviceInfo.isDistributed()) {
|
if (this.webserviceInfo.isDistributed()) {
|
||||||
|
if (this.webserviceInfo.isLightSetup()) {
|
||||||
|
throw new IllegalStateException("Illegal invalid setup configuration detected, SEB Serer light and distributed setup cannot be applied within the same setup.");
|
||||||
|
}
|
||||||
SEBServerInit.INIT_LOGGER.info("----> ");
|
SEBServerInit.INIT_LOGGER.info("----> ");
|
||||||
SEBServerInit.INIT_LOGGER.info("----> Distributed Setup: {}", this.webserviceInfo.getWebserviceUUID());
|
SEBServerInit.INIT_LOGGER.info("----> Distributed Setup: {}", this.webserviceInfo.getWebserviceUUID());
|
||||||
SEBServerInit.INIT_LOGGER.info("----> Connection update time: {}",
|
SEBServerInit.INIT_LOGGER.info("----> Connection update time: {}",
|
||||||
this.environment.getProperty("sebserver.webservice.distributed.connectionUpdate", "2000"));
|
this.environment.getProperty("sebserver.webservice.distributed.connectionUpdate", "2000"));
|
||||||
|
} else if (this.webserviceInfo.isLightSetup()) {
|
||||||
|
SEBServerInit.INIT_LOGGER.info("----> ");
|
||||||
|
SEBServerInit.INIT_LOGGER.info("----> SEB Server light setup enabled!");
|
||||||
}
|
}
|
||||||
|
|
||||||
SEBServerInit.INIT_LOGGER.info("----> ");
|
SEBServerInit.INIT_LOGGER.info("----> ");
|
||||||
|
|
|
@ -25,7 +25,8 @@ sebserver.webservice.clean-db-on-startup=false
|
||||||
|
|
||||||
# webservice setup configuration
|
# webservice setup configuration
|
||||||
sebserver.init.adminaccount.gen-on-init=false
|
sebserver.init.adminaccount.gen-on-init=false
|
||||||
sebserver.webservice.distributed=true
|
sebserver.webservice.light.setup=true
|
||||||
|
sebserver.webservice.distributed=false
|
||||||
#sebserver.webservice.master.delay.threshold=10000
|
#sebserver.webservice.master.delay.threshold=10000
|
||||||
sebserver.webservice.http.external.scheme=http
|
sebserver.webservice.http.external.scheme=http
|
||||||
sebserver.webservice.http.external.servername=localhost
|
sebserver.webservice.http.external.servername=localhost
|
||||||
|
@ -75,5 +76,5 @@ sebserver.feature.seb.screenProctoring.bundled.url=http://localhost:8090
|
||||||
sebserver.feature.seb.screenProctoring.bundled.clientId=sebserverClient
|
sebserver.feature.seb.screenProctoring.bundled.clientId=sebserverClient
|
||||||
sebserver.feature.seb.screenProctoring.bundled.sebserveraccount.username=SEBServerAPIAccount
|
sebserver.feature.seb.screenProctoring.bundled.sebserveraccount.username=SEBServerAPIAccount
|
||||||
|
|
||||||
sebserver.feature.admin.institution.enabled=false
|
sebserver.feature.admin.institution.enabled=true
|
||||||
|
|
||||||
|
|
|
@ -20,8 +20,6 @@ server.tomcat.socket.soKeepAlive=true
|
||||||
server.tomcat.socket.performanceConnectionTime=1
|
server.tomcat.socket.performanceConnectionTime=1
|
||||||
server.tomcat.socket.performanceLatency=2
|
server.tomcat.socket.performanceLatency=2
|
||||||
server.tomcat.socket.performanceBandwidth=0
|
server.tomcat.socket.performanceBandwidth=0
|
||||||
server.tomcat.keepAliveTimeout(3000);
|
|
||||||
server.tomcat.maxKeepAliveRequests(3000);
|
|
||||||
server.tomcat.uri-encoding=UTF-8
|
server.tomcat.uri-encoding=UTF-8
|
||||||
|
|
||||||
### encoding
|
### encoding
|
||||||
|
|
|
@ -2572,4 +2572,4 @@ sebserver.seblogs.delete.action.delete=Delete All Logs
|
||||||
sebserver.seblogs.delete.confirm.title=Deletion Successful
|
sebserver.seblogs.delete.confirm.title=Deletion Successful
|
||||||
sebserver.seblogs.delete.confirm.message={0} SEB client logs where successfully deleted.<br/><br/>And there where {1} errors.
|
sebserver.seblogs.delete.confirm.message={0} SEB client logs where successfully deleted.<br/><br/>And there where {1} errors.
|
||||||
|
|
||||||
sebserver.features.lightsetup.fullversion.message=MOCKUP_TEXT: This feature is not available within this SEB Server (light) setup. To use this feature you need a full version SEB Server setup. Please read more about SEB Server setups in the <a href="..." target="blank">SEB Server installation guide</a>
|
sebserver.features.lightsetup.fullversion.message=MOCKUP-TEXT:<br/><br/>[Specific feature description here!?]<br/><br/>Note that this feature is not available within the SEB Server Light setup.<br/>To use this feature you will need a full version SEB Server setup.<br/><br/>Please read more about SEB Server setups in the <a href="https://seb-server-setup.readthedocs.io/en/latest/overview.html" target="blank">SEB Server installation guide</a>
|
||||||
|
|
|
@ -80,6 +80,8 @@ Label.h2 {
|
||||||
color: #1f407a;
|
color: #1f407a;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Label.h3 {
|
Label.h3 {
|
||||||
font: bold 14px Arial, Helvetica, sans-serif;
|
font: bold 14px Arial, Helvetica, sans-serif;
|
||||||
height: 20px;
|
height: 20px;
|
||||||
|
@ -93,6 +95,13 @@ Label.subtitle {
|
||||||
color: #4a4a4a;
|
color: #4a4a4a;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Label.note {
|
||||||
|
font: 18px Arial, Helvetica, sans-serif;
|
||||||
|
height: 22px;
|
||||||
|
padding: 0 0 6px 0;
|
||||||
|
color: #4a4a4a;
|
||||||
|
}
|
||||||
|
|
||||||
Label.error {
|
Label.error {
|
||||||
font: 10px Arial, Helvetica, sans-serif;
|
font: 10px Arial, Helvetica, sans-serif;
|
||||||
color: #aa0000;
|
color: #aa0000;
|
||||||
|
@ -252,6 +261,15 @@ Composite.warning {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Composite.note {
|
||||||
|
background-gradient-color: rgba( 31, 64, 122, 0.2 );
|
||||||
|
background-image: gradient( linear, left top, left bottom, from(rgba( 31, 64, 122, 0.2 ) ), to( rgba( 31, 64, 122, 0.2 ) ) );
|
||||||
|
background-repeat: repeat;
|
||||||
|
background-position: left top;
|
||||||
|
font: bold 18px Arial, Helvetica, sans-serif;
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
|
||||||
*.header {
|
*.header {
|
||||||
font: bold 12px Arial, Helvetica, sans-serif;
|
font: bold 12px Arial, Helvetica, sans-serif;
|
||||||
color: #FFFFFF;
|
color: #FFFFFF;
|
||||||
|
|
Loading…
Reference in a new issue