condition filters now have a 'target' filter when applicable

This commit is contained in:
BroodjeAap 2022-10-18 19:43:48 +00:00
parent 33f681a62a
commit e9fe96fff4
3 changed files with 109 additions and 43 deletions

View file

@ -538,7 +538,7 @@ func storeFilterResult(filter *Filter, db *gorm.DB, debug bool) {
func getFilterResultConditionDiff(filter *Filter, db *gorm.DB) { func getFilterResultConditionDiff(filter *Filter, db *gorm.DB) {
var previousOutput FilterOutput var previousOutput FilterOutput
db.Model(&FilterOutput{}).Order("time desc").Where("watch_id = ? AND name = ?", filter.WatchID, filter.Name).Limit(1).Find(&previousOutput) db.Model(&FilterOutput{}).Order("time desc").Where("watch_id = ? AND name = ?", filter.WatchID, filter.Var2).Limit(1).Find(&previousOutput)
for _, parent := range filter.Parents { for _, parent := range filter.Parents {
for _, result := range parent.Results { for _, result := range parent.Results {
@ -553,7 +553,7 @@ func getFilterResultConditionDiff(filter *Filter, db *gorm.DB) {
func getFilterResultConditionLowerLast(filter *Filter, db *gorm.DB) { func getFilterResultConditionLowerLast(filter *Filter, db *gorm.DB) {
var previousOutput FilterOutput var previousOutput FilterOutput
db.Model(&FilterOutput{}).Order("time desc").Where("watch_id = ? AND name = ?", filter.WatchID, filter.Name).Limit(1).Find(&previousOutput) db.Model(&FilterOutput{}).Order("time desc").Where("watch_id = ? AND name = ?", filter.WatchID, filter.Var2).Limit(1).Find(&previousOutput)
for _, parent := range filter.Parents { for _, parent := range filter.Parents {
for _, result := range parent.Results { for _, result := range parent.Results {
if previousOutput.WatchID == 0 { if previousOutput.WatchID == 0 {
@ -646,7 +646,7 @@ func getFilterResultConditionLowerThan(filter *Filter) {
func getFilterResultConditionHigherLast(filter *Filter, db *gorm.DB) { func getFilterResultConditionHigherLast(filter *Filter, db *gorm.DB) {
var previousOutput FilterOutput var previousOutput FilterOutput
db.Model(&FilterOutput{}).Order("time desc").Where("watch_id = ? AND name = ?", filter.WatchID, filter.Name).Limit(1).Find(&previousOutput) db.Model(&FilterOutput{}).Order("time desc").Where("watch_id = ? AND name = ?", filter.WatchID, filter.Var2).Limit(1).Find(&previousOutput)
for _, parent := range filter.Parents { for _, parent := range filter.Parents {
for _, result := range parent.Results { for _, result := range parent.Results {
if previousOutput.WatchID == 0 { if previousOutput.WatchID == 0 {
@ -676,7 +676,7 @@ func getFilterResultConditionHigherLast(filter *Filter, db *gorm.DB) {
func getFilterResultConditionHighest(filter *Filter, db *gorm.DB) { func getFilterResultConditionHighest(filter *Filter, db *gorm.DB) {
var previousOutputs []FilterOutput var previousOutputs []FilterOutput
db.Model(&FilterOutput{}).Where("watch_id = ? AND name = ?", filter.WatchID, filter.Name).Find(&previousOutputs) db.Model(&FilterOutput{}).Where("watch_id = ? AND name = ?", filter.WatchID, filter.Var2).Find(&previousOutputs)
highest := math.MaxFloat64 highest := math.MaxFloat64
if previousOutputs != nil { if previousOutputs != nil {
for _, previousOutput := range previousOutputs { for _, previousOutput := range previousOutputs {

View file

@ -1,3 +1,14 @@
var __values = (this && this.__values) || function(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m) return m.call(o);
if (o && typeof o.length === "number") return {
next: function () {
if (o && i >= o.length) o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
};
var __read = (this && this.__read) || function (o, n) { var __read = (this && this.__read) || function (o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator]; var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o; if (!m) return o;
@ -18,17 +29,6 @@ var __spread = (this && this.__spread) || function () {
for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i])); for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));
return ar; return ar;
}; };
var __values = (this && this.__values) || function(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m) return m.call(o);
if (o && typeof o.length === "number") return {
next: function () {
if (o && i >= o.length) o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
};
function onTypeChange(node) { function onTypeChange(node) {
if (node === void 0) { node = null; } if (node === void 0) { node = null; }
var select = document.getElementById("typeInput"); var select = document.getElementById("typeInput");
@ -560,13 +560,18 @@ function onMathChange(node) {
} }
} }
function onConditionChange(node) { function onConditionChange(node) {
var e_1, _a;
if (node === void 0) { node = null; } if (node === void 0) { node = null; }
var var1Input = document.getElementById("var1Input"); var var1Input = document.getElementById("var1Input");
var var1Label = document.getElementById("var1Label"); var var1Label = document.getElementById("var1Label");
var var1Div = document.getElementById("var1Div");
var var2Input = document.getElementById("var2Input"); var var2Input = document.getElementById("var2Input");
var var2Label = document.getElementById("var2Label"); var var2Label = document.getElementById("var2Label");
var var2Div = document.getElementById("var2Div");
var2Div.innerHTML = "";
var var3Input = document.getElementById("var3Input"); var var3Input = document.getElementById("var3Input");
var var3Label = document.getElementById("var3Label"); var var3Label = document.getElementById("var3Label");
var var3Div = document.getElementById("var3Div");
var var1Value = ""; var var1Value = "";
var var2Value = ""; var var2Value = "";
var var3Value = ""; var var3Value = "";
@ -585,24 +590,57 @@ function onConditionChange(node) {
var1Label.innerHTML = "Condition"; var1Label.innerHTML = "Condition";
switch (var1Value) { switch (var1Value) {
case "lowert": { case "lowert": {
var2Input.disabled = false; var var2Input_1 = document.createElement("input");
var2Input.type = "number"; var2Input_1.name = "var2";
var2Input.value = var2Value; var2Input_1.id = "var2Input";
var2Input_1.type = "number";
var2Input_1.value = var2Value;
var2Input_1.classList.add("form-control");
var2Label.innerHTML = "Threshold"; var2Label.innerHTML = "Threshold";
var2Div.appendChild(var2Input_1);
break; break;
} }
case "highert": { case "highert": {
var2Input.disabled = false; var var2Input_2 = document.createElement("input");
var2Input.type = "number"; var2Input_2.name = "var2";
var2Input.value = var2Value; var2Input_2.id = "var2Input";
var2Input_2.type = "number";
var2Input_2.value = var2Value;
var2Input_2.classList.add("form-control");
var2Label.innerHTML = "Threshold"; var2Label.innerHTML = "Threshold";
var2Div.appendChild(var2Input_2);
break; break;
} }
default: { default: {
var2Input.disabled = true; var filterSelect = document.createElement("select");
var2Input.type = "text"; filterSelect.name = "var2";
var2Input.value = var2Value; filterSelect.id = "var2Input";
var2Label.innerHTML = "-"; filterSelect.disabled = false;
filterSelect.classList.add("form-control");
try {
for (var _b = __values(_diagram.nodes.values()), _c = _b.next(); !_c.done; _c = _b.next()) {
var node_1 = _c.value;
if (node_1.type != "store") {
continue;
}
var nodeOption = document.createElement("option");
nodeOption.value = node_1.label;
nodeOption.innerHTML = node_1.label;
filterSelect.appendChild(nodeOption);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b["return"])) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
if (var2Value != "") {
filterSelect.value = var2Value;
}
var2Label.innerHTML = "Filter";
var2Div.appendChild(filterSelect);
break; break;
} }
} }
@ -623,7 +661,7 @@ function onSubmitNewFilter() {
}); });
} }
function editNode(node) { function editNode(node) {
var e_1, _a; var e_2, _a;
var addFilterButton = document.getElementById("filterButton"); var addFilterButton = document.getElementById("filterButton");
addFilterButton.click(); addFilterButton.click();
var name = node.label; var name = node.label;
@ -672,17 +710,17 @@ function editNode(node) {
filterModalFooter.appendChild(cardDiv); filterModalFooter.appendChild(cardDiv);
} }
} }
catch (e_1_1) { e_1 = { error: e_1_1 }; } catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally { finally {
try { try {
if (_c && !_c.done && (_a = _b["return"])) _a.call(_b); if (_c && !_c.done && (_a = _b["return"])) _a.call(_b);
} }
finally { if (e_1) throw e_1.error; } finally { if (e_2) throw e_2.error; }
} }
submitButton.onclick = function () { submitEditNode(node); }; submitButton.onclick = function () { submitEditNode(node); };
} }
function logNode(node) { function logNode(node) {
var e_2, _a; var e_3, _a;
var logButton = document.getElementById("logButton"); var logButton = document.getElementById("logButton");
logButton.click(); logButton.click();
var logTitle = document.getElementById("logModalLabel"); var logTitle = document.getElementById("logModalLabel");
@ -702,12 +740,12 @@ function logNode(node) {
logBody.appendChild(row); logBody.appendChild(row);
} }
} }
catch (e_2_1) { e_2 = { error: e_2_1 }; } catch (e_3_1) { e_3 = { error: e_3_1 }; }
finally { finally {
try { try {
if (_c && !_c.done && (_a = _b["return"])) _a.call(_b); if (_c && !_c.done && (_a = _b["return"])) _a.call(_b);
} }
finally { if (e_2) throw e_2.error; } finally { if (e_3) throw e_3.error; }
} }
} }
function deleteNode(node) { function deleteNode(node) {
@ -744,7 +782,7 @@ function submitEditNode(node) {
saveWatchButton.classList.add("btn-danger"); saveWatchButton.classList.add("btn-danger");
} }
function saveWatch() { function saveWatch() {
var e_3, _a, e_4, _b; var e_4, _a, e_5, _b;
var watchIdInput = document.getElementById("watch_id"); var watchIdInput = document.getElementById("watch_id");
var watchId = Number(watchIdInput.value); var watchId = Number(watchIdInput.value);
var filters = new Array(); var filters = new Array();
@ -768,12 +806,12 @@ function saveWatch() {
}); });
} }
} }
catch (e_3_1) { e_3 = { error: e_3_1 }; } catch (e_4_1) { e_4 = { error: e_4_1 }; }
finally { finally {
try { try {
if (_d && !_d.done && (_a = _c["return"])) _a.call(_c); if (_d && !_d.done && (_a = _c["return"])) _a.call(_c);
} }
finally { if (e_3) throw e_3.error; } finally { if (e_4) throw e_4.error; }
} }
var filtersInput = document.getElementById("filtersInput"); var filtersInput = document.getElementById("filtersInput");
filtersInput.value = JSON.stringify(filters); filtersInput.value = JSON.stringify(filters);
@ -790,12 +828,12 @@ function saveWatch() {
}); });
} }
} }
catch (e_4_1) { e_4 = { error: e_4_1 }; } catch (e_5_1) { e_5 = { error: e_5_1 }; }
finally { finally {
try { try {
if (_f && !_f.done && (_b = _e["return"])) _b.call(_e); if (_f && !_f.done && (_b = _e["return"])) _b.call(_e);
} }
finally { if (e_4) throw e_4.error; } finally { if (e_5) throw e_5.error; }
} }
var connectionsInput = document.getElementById("connectionsInput"); var connectionsInput = document.getElementById("connectionsInput");
connectionsInput.value = JSON.stringify(connections); connectionsInput.value = JSON.stringify(connections);

View file

@ -562,10 +562,14 @@ function onMathChange(node: DiagramNode | null = null){
function onConditionChange(node: DiagramNode | null = null){ function onConditionChange(node: DiagramNode | null = null){
let var1Input = document.getElementById("var1Input") as HTMLSelectElement; let var1Input = document.getElementById("var1Input") as HTMLSelectElement;
let var1Label = document.getElementById("var1Label") as HTMLLabelElement; let var1Label = document.getElementById("var1Label") as HTMLLabelElement;
let var1Div = document.getElementById("var1Div") as HTMLDivElement;
let var2Input = document.getElementById("var2Input") as HTMLInputElement; let var2Input = document.getElementById("var2Input") as HTMLInputElement;
let var2Label = document.getElementById("var2Label") as HTMLLabelElement; let var2Label = document.getElementById("var2Label") as HTMLLabelElement;
let var2Div = document.getElementById("var2Div") as HTMLDivElement;
var2Div.innerHTML = "";
let var3Input = document.getElementById("var3Input") as HTMLInputElement; let var3Input = document.getElementById("var3Input") as HTMLInputElement;
let var3Label = document.getElementById("var3Label") as HTMLLabelElement; let var3Label = document.getElementById("var3Label") as HTMLLabelElement;
let var3Div = document.getElementById("var3Div") as HTMLDivElement;
let var1Value = ""; let var1Value = "";
let var2Value = ""; let var2Value = "";
@ -586,25 +590,49 @@ function onConditionChange(node: DiagramNode | null = null){
switch(var1Value) { switch(var1Value) {
case "lowert": { case "lowert": {
var2Input.disabled = false; let var2Input = document.createElement("input");
var2Input.name = "var2";
var2Input.id = "var2Input";
var2Input.type = "number"; var2Input.type = "number";
var2Input.value = var2Value; var2Input.value = var2Value;
var2Input.classList.add("form-control")
var2Label.innerHTML = "Threshold"; var2Label.innerHTML = "Threshold";
var2Div.appendChild(var2Input)
break; break;
} }
case "highert": { case "highert": {
var2Input.disabled = false; let var2Input = document.createElement("input");
var2Input.name = "var2";
var2Input.id = "var2Input";
var2Input.type = "number"; var2Input.type = "number";
var2Input.value = var2Value; var2Input.value = var2Value;
var2Input.classList.add("form-control")
var2Label.innerHTML = "Threshold"; var2Label.innerHTML = "Threshold";
var2Div.appendChild(var2Input)
break; break;
} }
default: { default: {
var2Input.disabled = true; let filterSelect = document.createElement("select");
var2Input.type = "text"; filterSelect.name = "var2";
var2Input.value = var2Value; filterSelect.id = "var2Input";
var2Label.innerHTML = "-"; filterSelect.disabled = false;
break; filterSelect.classList.add("form-control");
for(let node of _diagram.nodes.values()) {
if (node.type != "store"){
continue;
}
let nodeOption = document.createElement("option");
nodeOption.value = node.label;
nodeOption.innerHTML = node.label;
filterSelect.appendChild(nodeOption);
}
if (var2Value != ""){
filterSelect.value = var2Value;
}
var2Label.innerHTML = "Filter";
var2Div.appendChild(filterSelect);
break
} }
} }
} }