aboutsummaryrefslogtreecommitdiffstats
path: root/interface/js
diff options
context:
space:
mode:
authormoisseev <moiseev@mezonplus.ru>2023-12-16 20:31:52 +0300
committermoisseev <moiseev@mezonplus.ru>2023-12-16 20:31:52 +0300
commit4faef335693f3b728172a2f01f92ef07c517e690 (patch)
tree184a16fb706d435e7b52d5ff2b25a249a5ed1dfc /interface/js
parent83c63b984d7df32cbf3ae5c86798b4b464a90192 (diff)
downloadrspamd-4faef335693f3b728172a2f01f92ef07c517e690.tar.gz
rspamd-4faef335693f3b728172a2f01f92ef07c517e690.zip
[WebUI] Send only altered symbols in save requests
Diffstat (limited to 'interface/js')
-rw-r--r--interface/js/app/symbols.js59
1 files changed, 31 insertions, 28 deletions
diff --git a/interface/js/app/symbols.js b/interface/js/app/symbols.js
index 6cbe984c3..82f67f3e3 100644
--- a/interface/js/app/symbols.js
+++ b/interface/js/app/symbols.js
@@ -28,23 +28,22 @@ define(["jquery", "app/rspamd", "footable"],
($, rspamd) => {
"use strict";
const ui = {};
+ let altered = {};
- function saveSymbols(action, id, server) {
+ function clear_altered() {
+ $("#save-alert").addClass("d-none");
+ altered = {};
+ }
+
+ function saveSymbols(server) {
$("#save-alert button").attr("disabled", true);
- const inputs = $("#" + id + ' :input[data-role="numerictextbox"]');
- const url = action;
const values = [];
- $(inputs).each(function () {
- values.push({
- name: $(this).attr("id").substring(5),
- value: parseFloat($(this).val())
- });
- });
+ Object.entries(altered).forEach(([key, value]) => values.push({name: key, value: value}));
- rspamd.query(url, {
+ rspamd.query("./savesymbols", {
success: function () {
- $("#save-alert").addClass("d-none");
+ clear_altered();
rspamd.alertMessage("alert-modal alert-success", "Symbols successfully saved");
},
complete: () => $("#save-alert button").removeAttr("disabled", true),
@@ -79,7 +78,7 @@ define(["jquery", "app/rspamd", "footable"],
label_class = "scorebar-spam";
}
item.weight = '<input class="form-control input-sm mb-disabled scorebar ' + label_class +
- '" data-role="numerictextbox" autocomplete="off" type="number" step="0.01" tabindex="1" ' +
+ '" autocomplete="off" type="number" step="0.01" tabindex="1" ' +
'value="' + formatter.format(item.weight) + '" id="_sym_' + item.symbol + '"></input>';
if (!item.time) {
item.time = 0;
@@ -124,7 +123,7 @@ define(["jquery", "app/rspamd", "footable"],
}
// @get symbols into modal form
ui.getSymbols = function (checked_server) {
- $("#save-alert").addClass("d-none");
+ clear_altered();
rspamd.query("symbols", {
success: function (json) {
const [{data}] = json;
@@ -224,26 +223,12 @@ define(["jquery", "app/rspamd", "footable"],
},
server: (checked_server === "All SERVERS") ? "local" : checked_server
});
- $("#symbolsTable")
- .on("input", ".scorebar", ({target}) => {
- const t = $(target);
- t.removeClass("scorebar-ham scorebar-spam");
- if (target.value < 0) {
- t.addClass("scorebar-ham");
- } else if (target.value > 0) {
- t.addClass("scorebar-spam");
- }
- $("#save-alert").removeClass("d-none");
- });
- $("#save-alert button")
- .off("click")
- .on("click", ({target}) => saveSymbols("./savesymbols", "symbolsTable", $(target).data("save")));
};
$("#updateSymbols").on("click", (e) => {
e.preventDefault();
- $("#save-alert").addClass("d-none");
+ clear_altered();
const checked_server = rspamd.getSelector("selSrv");
rspamd.query("symbols", {
success: function (data) {
@@ -254,5 +239,23 @@ define(["jquery", "app/rspamd", "footable"],
});
});
+ $("#symbolsTable")
+ .on("input", ".scorebar", ({target}) => {
+ const t = $(target);
+ t.removeClass("scorebar-ham scorebar-spam");
+ if (target.value < 0) {
+ t.addClass("scorebar-ham");
+ } else if (target.value > 0) {
+ t.addClass("scorebar-spam");
+ }
+ })
+ .on("change", ".scorebar", ({target}) => {
+ altered[$(target).attr("id").substring(5)] = parseFloat(target.value);
+ $("#save-alert").removeClass("d-none");
+ });
+
+ $("#save-alert button")
+ .on("click", ({target}) => saveSymbols($(target).data("save")));
+
return ui;
});