better indicator coloring on monitoring
This commit is contained in:
parent
38442dda25
commit
0d4e5c419a
4 changed files with 26 additions and 33 deletions
|
@ -153,9 +153,9 @@ public class ClientConnectionDetails {
|
||||||
form.setFieldValue(indData.indicator.name, Constants.EMPTY_NOTE);
|
form.setFieldValue(indData.indicator.name, Constants.EMPTY_NOTE);
|
||||||
form.setFieldColor(indData.indicator.name, indData.defaultColor);
|
form.setFieldColor(indData.indicator.name, indData.defaultColor);
|
||||||
} else {
|
} else {
|
||||||
final int colorIndex = IndicatorData.getColorIndex(indData, value);
|
final int weight = IndicatorData.getWeight(indData, value);
|
||||||
final Color color = (colorIndex >= 0)
|
final Color color = (weight >= 0 && weight < indData.thresholdColor.length)
|
||||||
? indData.thresholdColor[colorIndex].color
|
? indData.thresholdColor[weight].color
|
||||||
: indData.defaultColor;
|
: indData.defaultColor;
|
||||||
form.setFieldValue(indData.indicator.name, String.valueOf(value));
|
form.setFieldValue(indData.indicator.name, String.valueOf(value));
|
||||||
form.setFieldColor(indData.indicator.name, color);
|
form.setFieldColor(indData.indicator.name, color);
|
||||||
|
|
|
@ -260,7 +260,8 @@ public final class ClientConnectionTable {
|
||||||
final Long connectionId;
|
final Long connectionId;
|
||||||
private boolean changed = false;
|
private boolean changed = false;
|
||||||
private ClientConnectionData connectionData;
|
private ClientConnectionData connectionData;
|
||||||
private int[] thresholdColorIndices;
|
private int indicatorWeight;
|
||||||
|
//private int[] thresholdColorIndices;
|
||||||
private boolean duplicateChecked = false;
|
private boolean duplicateChecked = false;
|
||||||
|
|
||||||
UpdatableTableItem(final Long connectionId) {
|
UpdatableTableItem(final Long connectionId) {
|
||||||
|
@ -331,8 +332,9 @@ public final class ClientConnectionTable {
|
||||||
indicatorData.defaultColor);
|
indicatorData.defaultColor);
|
||||||
} else {
|
} else {
|
||||||
tableItem.setText(indicatorData.index, getDisplayValue(indicatorValue));
|
tableItem.setText(indicatorData.index, getDisplayValue(indicatorValue));
|
||||||
final Color color = (this.thresholdColorIndices[i] >= 0)
|
final Color color =
|
||||||
? indicatorData.thresholdColor[this.thresholdColorIndices[i]].color
|
(this.indicatorWeight >= 0 && this.indicatorWeight < indicatorData.thresholdColor.length)
|
||||||
|
? indicatorData.thresholdColor[this.indicatorWeight].color
|
||||||
: indicatorData.defaultColor;
|
: indicatorData.defaultColor;
|
||||||
tableItem.setBackground(indicatorData.index, color);
|
tableItem.setBackground(indicatorData.index, color);
|
||||||
}
|
}
|
||||||
|
@ -352,15 +354,7 @@ public final class ClientConnectionTable {
|
||||||
}
|
}
|
||||||
|
|
||||||
int thresholdsWeight() {
|
int thresholdsWeight() {
|
||||||
if (this.thresholdColorIndices == null) {
|
return this.indicatorWeight;
|
||||||
return 100;
|
|
||||||
}
|
|
||||||
|
|
||||||
int weight = 0;
|
|
||||||
for (int i = 0; i < this.thresholdColorIndices.length; i++) {
|
|
||||||
weight += this.thresholdColorIndices[i];
|
|
||||||
}
|
|
||||||
return 100 - weight;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String getStatusName() {
|
String getStatusName() {
|
||||||
|
@ -396,21 +390,17 @@ public final class ClientConnectionTable {
|
||||||
ClientConnectionTable.this.needsSort = true;
|
ClientConnectionTable.this.needsSort = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.thresholdColorIndices == null) {
|
|
||||||
this.thresholdColorIndices = new int[connectionData.indicatorValues.size()];
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i = 0; i < connectionData.indicatorValues.size(); i++) {
|
for (int i = 0; i < connectionData.indicatorValues.size(); i++) {
|
||||||
final IndicatorValue indicatorValue = connectionData.indicatorValues.get(i);
|
final IndicatorValue indicatorValue = connectionData.indicatorValues.get(i);
|
||||||
final IndicatorData indicatorData =
|
final IndicatorData indicatorData =
|
||||||
ClientConnectionTable.this.indicatorMapping.get(indicatorValue.getType());
|
ClientConnectionTable.this.indicatorMapping.get(indicatorValue.getType());
|
||||||
|
|
||||||
final double value = indicatorValue.getValue();
|
final double value = indicatorValue.getValue();
|
||||||
final int colorIndex = IndicatorData.getColorIndex(indicatorData, value);
|
final int indicatorWeight = IndicatorData.getWeight(indicatorData, value);
|
||||||
if (this.thresholdColorIndices[i] != colorIndex) {
|
if (this.indicatorWeight != indicatorWeight) {
|
||||||
ClientConnectionTable.this.needsSort = true;
|
ClientConnectionTable.this.needsSort = true;
|
||||||
}
|
}
|
||||||
this.thresholdColorIndices[i] = colorIndex;
|
this.indicatorWeight = indicatorWeight;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.connectionData = connectionData;
|
this.connectionData = connectionData;
|
||||||
|
|
|
@ -50,15 +50,18 @@ final class IndicatorData {
|
||||||
return indicatorMapping;
|
return indicatorMapping;
|
||||||
}
|
}
|
||||||
|
|
||||||
static final int getColorIndex(final IndicatorData indicatorData, final double value) {
|
static final int getWeight(final IndicatorData indicatorData, final double value) {
|
||||||
final int top = indicatorData.thresholdColor.length - 1;
|
for (int j = 0; j < indicatorData.thresholdColor.length; j++) {
|
||||||
for (int j = 0; j < top; j++) {
|
if (value < indicatorData.thresholdColor[j].value) {
|
||||||
if (value > indicatorData.thresholdColor[j].value && value < indicatorData.thresholdColor[j + 1].value) {
|
if (j == 0) {
|
||||||
return j;
|
return -1;
|
||||||
|
} else {
|
||||||
|
return j - 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return top;
|
return indicatorData.thresholdColor.length - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static final class ThresholdColor {
|
static final class ThresholdColor {
|
||||||
|
|
|
@ -78,8 +78,8 @@ public class HTTPClientBot {
|
||||||
|
|
||||||
public HTTPClientBot(final Map<String, String> args) {
|
public HTTPClientBot(final Map<String, String> args) {
|
||||||
|
|
||||||
//this.webserviceAddress = args.getOrDefault("webserviceAddress", "http://ralph.ethz.ch:8080");
|
this.webserviceAddress = args.getOrDefault("webserviceAddress", "http://ralph.ethz.ch:8080");
|
||||||
this.webserviceAddress = args.getOrDefault("webserviceAddress", "http://localhost:8080");
|
//this.webserviceAddress = args.getOrDefault("webserviceAddress", "http://localhost:8080");
|
||||||
//this.webserviceAddress = args.getOrDefault("webserviceAddress", "https://seb.test-swissmooc.ch");
|
//this.webserviceAddress = args.getOrDefault("webserviceAddress", "https://seb.test-swissmooc.ch");
|
||||||
|
|
||||||
this.accessTokenEndpoint = args.getOrDefault("accessTokenEndpoint", "/oauth/token");
|
this.accessTokenEndpoint = args.getOrDefault("accessTokenEndpoint", "/oauth/token");
|
||||||
|
@ -91,10 +91,10 @@ public class HTTPClientBot {
|
||||||
// args.getOrDefault("clientSecret", "CSXh6tQ^fdi00(XdL%6xic{q-5YlEE@Yc$Rg}H1f}JPt=P5PGH+KOhCW}oYSiC3L");
|
// args.getOrDefault("clientSecret", "CSXh6tQ^fdi00(XdL%6xic{q-5YlEE@Yc$Rg}H1f}JPt=P5PGH+KOhCW}oYSiC3L");
|
||||||
this.apiPath = args.getOrDefault("apiPath", "/exam-api");
|
this.apiPath = args.getOrDefault("apiPath", "/exam-api");
|
||||||
this.apiVersion = args.getOrDefault("apiVersion", "v1");
|
this.apiVersion = args.getOrDefault("apiVersion", "v1");
|
||||||
|
// this.examId = args.getOrDefault("examId", "2");
|
||||||
|
// this.institutionId = args.getOrDefault("institutionId", "1");
|
||||||
this.examId = args.getOrDefault("examId", "2");
|
this.examId = args.getOrDefault("examId", "2");
|
||||||
this.institutionId = args.getOrDefault("institutionId", "1");
|
this.institutionId = args.getOrDefault("institutionId", "1");
|
||||||
// this.examId = args.getOrDefault("examId", "1");
|
|
||||||
// this.institutionId = args.getOrDefault("institutionId", "2");
|
|
||||||
this.numberOfConnections = Integer.parseInt(args.getOrDefault("numberOfConnections", "4"));
|
this.numberOfConnections = Integer.parseInt(args.getOrDefault("numberOfConnections", "4"));
|
||||||
this.pingInterval = Long.parseLong(args.getOrDefault("pingInterval", "200"));
|
this.pingInterval = Long.parseLong(args.getOrDefault("pingInterval", "200"));
|
||||||
this.errorInterval = Long.parseLong(args.getOrDefault("errorInterval", String.valueOf(TEN_SECONDS)));
|
this.errorInterval = Long.parseLong(args.getOrDefault("errorInterval", String.valueOf(TEN_SECONDS)));
|
||||||
|
|
Loading…
Reference in a new issue