From: Leo-Andres Hofmann <hofmann@leo-andres.de>
To: development@lists.ipfire.org
Subject: [PATCH 2/4] WUI: Refactor rrdimage JavaScript
Date: Sat, 01 Apr 2023 16:43:41 +0200 [thread overview]
Message-ID: <20230401144343.1483-2-hofmann@leo-andres.de> (raw)
In-Reply-To: <20230401144343.1483-1-hofmann@leo-andres.de>
[-- Attachment #1: Type: text/plain, Size: 10506 bytes --]
This migrates the rrdimage.js functions to the new WUI framework
and improves some functions.
Signed-off-by: Leo-Andres Hofmann <hofmann(a)leo-andres.de>
---
config/cfgroot/graphs.pl | 2 +-
html/html/include/rrdimage.js | 122 -------------------
html/html/include/wui_rrdimage.mjs | 103 +++++++++++++++-
html/html/themes/ipfire/include/functions.pl | 1 -
4 files changed, 102 insertions(+), 126 deletions(-)
delete mode 100644 html/html/include/rrdimage.js
diff --git a/config/cfgroot/graphs.pl b/config/cfgroot/graphs.pl
index 9803dd124..a637e1a6a 100644
--- a/config/cfgroot/graphs.pl
+++ b/config/cfgroot/graphs.pl
@@ -118,7 +118,7 @@ END
# Print range select buttons
foreach my $range (@time_ranges) {
print <<END;
- <li><button data-range="$range" onclick="rrdimage_selectRange(this)">$Lang::tr{$range}</button></li>
+ <li><button type="button" data-range="$range">$Lang::tr{$range}</button></li>
END
}
diff --git a/html/html/include/rrdimage.js b/html/html/include/rrdimage.js
deleted file mode 100644
index c6f5930c9..000000000
--- a/html/html/include/rrdimage.js
+++ /dev/null
@@ -1,122 +0,0 @@
-/*#############################################################################
-# #
-# IPFire.org - A linux based firewall #
-# Copyright (C) 2007-2021 IPFire Team <info(a)ipfire.org> #
-# #
-# This program is free software: you can redistribute it and/or modify #
-# it under the terms of the GNU General Public License as published by #
-# the Free Software Foundation, either version 3 of the License, or #
-# (at your option) any later version. #
-# #
-# This program is distributed in the hope that it will be useful, #
-# but WITHOUT ANY WARRANTY; without even the implied warranty of #
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
-# GNU General Public License for more details. #
-# #
-# You should have received a copy of the GNU General Public License #
-# along with this program. If not, see <http://www.gnu.org/licenses/>. #
-# #
-#############################################################################*/
-
-// "onclick" event handler for graph time range select button
-// buttonObj: reference to the button
-function rrdimage_selectRange(buttonObj) {
- if(! (buttonObj && ('range' in buttonObj.dataset))) {
- return; //required parameters are missing
- }
-
- // Get selected time range from button
- const range = buttonObj.dataset.range;
-
- // Get surrounding div box and select new range
- let graphBox = $(buttonObj).closest('div');
- _rrdimg_setRange(graphBox, range);
-}
-
-// Document loaded: Process all graphs, start reload timers
-$(function() {
- $('div.rrdimage').each(function() {
- let graphBox = $(this);
- _rrdimg_setRange(graphBox, graphBox.data('defaultRange'), true);
- });
-});
-
-//--- Internal functions ---
-
-// Set or update graph time range, start automatic reloading
-// graphBox: jQuery object, reference to graph div box
-// range: time range (day, hour, ...)
-// initMode: don't immediately reload graph, but force timers and attributes update
-function _rrdimg_setRange(graphBox, range, initMode = false) {
- if(! ((graphBox instanceof jQuery) && (graphBox.length === 1))) {
- return; //graphBox element missing
- }
-
- // Check range parameter, default to "day" on error
- if(! ["hour", "day", "week", "month", "year"].includes(range)) {
- range = "day";
- }
-
- // Check if the time range is changed
- if((graphBox.data('range') !== range) || initMode) {
- graphBox.data('range', range); //Store new range
-
- // Update button highlighting
- graphBox.find('button').removeClass('selected');
- graphBox.find(`button[data-range="${range}"]`).addClass('selected');
- }
-
- // Clear pending reload timer to prevent multiple image reloads
- let timerId = graphBox.data('reloadTimer');
- if(timerId !== undefined) {
- window.clearInterval(timerId);
- graphBox.removeData('reloadTimer');
- }
-
- // Determine auto reload interval (in seconds),
- // interval = 0 disables auto reloading by default
- let interval = 0;
- switch(range) {
- case 'hour':
- interval = 60;
- break;
-
- case 'day':
- case 'week':
- interval = 300;
- break;
- }
-
- // Start reload timer and store reference
- if(interval > 0) {
- timerId = window.setInterval(function(graphRef) {
- _rrdimg_reload(graphRef);
- }, interval * 1000, graphBox);
- graphBox.data('reloadTimer', timerId);
- }
-
- // Always reload image unless disabled by init mode
- if(! initMode) {
- _rrdimg_reload(graphBox);
- }
-}
-
-// Reload graph image, add timestamp to prevent caching
-// graphBox: jQuery object (graph element must be valid)
-function _rrdimg_reload(graphBox) {
- const origin = graphBox.data('origin');
- const graph = graphBox.data('graph');
- const timestamp = Date.now();
-
- // Get user selected range or fall back to default
- let range = graphBox.data('range');
- if(! range) {
- range = graphBox.data('defaultRange');
- }
-
- // Generate new image URL with timestamp
- const imageUrl = `/cgi-bin/getrrdimage.cgi?origin=${origin}&graph=${graph}&range=${range}×tamp=${timestamp}`;
-
- // Get graph image and set new URL
- graphBox.children('img').first().attr('src', imageUrl);
-}
diff --git a/html/html/include/wui_rrdimage.mjs b/html/html/include/wui_rrdimage.mjs
index 5254b1e98..64b34dfac 100644
--- a/html/html/include/wui_rrdimage.mjs
+++ b/html/html/include/wui_rrdimage.mjs
@@ -24,7 +24,106 @@ import {WUIcore_moduleBase as WUI_module} from "./wui_core.mjs";
//--- RRDtool graph images ---
export class WUImodule_rrdimage extends WUI_module {
- constructor(translations) {
- super(translations);
+
+ // DOMContentLoaded/jQuery.ready event handler
+ _handleDOMReady() {
+ super._handleDOMReady();
+
+ // Process all graphs, start reload timers
+ $("div.rrdimage").each((i, divElem) => {
+ const $graphBox = $(divElem);
+ this.#updateProperties($graphBox, $graphBox.data("defaultRange"), true);
+
+ // Attach event listeners to buttons
+ $graphBox.find("button[data-range]").each((j, buttonElem) => {
+ const $rangeBtn = $(buttonElem);
+ $rangeBtn.on(`click.${this.namespace}`, {"graphBox": $graphBox, "range": $rangeBtn.data("range")}, this.#handleRangeClick.bind(this));
+ });
+ });
+ }
+
+ // Graph range select button "click" event handler
+ #handleRangeClick(event) {
+ event.preventDefault();
+
+ this.#updateProperties(event.data["graphBox"], event.data["range"]);
+ }
+
+ // Update graph range
+ // $graphBox: jQuery object, reference to a single graph div box
+ // range: time range (day, hour, ...)
+ setRange($graphBox, range) {
+ if(($graphBox instanceof jQuery) && ($graphBox.length === 1)) {
+ this.#updateProperties($graphBox, range);
+ }
+ }
+
+ // Update graph range properties, configure automatic reloading
+ // $graphBox: jQuery object, reference to graph div box
+ // range: time range (day, hour, ...)
+ // initialize: don't immediately reload graph, but force timers and attributes update
+ #updateProperties($graphBox, range, initialize = false) {
+ // Check range parameter, default to "day" on error
+ if(! ["hour", "day", "week", "month", "year"].includes(range)) {
+ range = "day";
+ }
+
+ // Check if the time range is changed
+ if(($graphBox.data("range") !== range) || initialize) {
+ $graphBox.data("range", range); //Store new range
+
+ // Update button highlighting
+ $graphBox.find("button[data-range]").removeClass("selected");
+ $graphBox.find(`button[data-range="${range}"]`).addClass("selected");
+ }
+
+ // Clear pending reload timer to prevent multiple image reloads
+ let timerId = $graphBox.data("reloadTimer");
+ if(typeof timerId !== "undefined") {
+ window.clearInterval(timerId);
+ $graphBox.removeData("reloadTimer");
+ }
+
+ // Determine auto reload interval (in seconds),
+ // interval = 0 disables auto reloading by default
+ let interval = 0;
+ switch(range) {
+ case "hour":
+ interval = 60;
+ break;
+
+ case "day":
+ case "week":
+ interval = 300;
+ break;
+ }
+
+ // Start reload timer and store reference
+ if(interval > 0) {
+ timerId = window.setInterval(this.#reloadImage.bind(this), interval * 1000, $graphBox);
+ $graphBox.data("reloadTimer", timerId);
+ }
+
+ // Always reload image unless disabled by init mode
+ if(! initialize) {
+ this.#reloadImage($graphBox);
+ }
+ }
+
+ // Reload graph image, add timestamp to prevent caching
+ // $graphBox: jQuery object (graph element must be valid/previously processed by updateRange)
+ #reloadImage($graphBox) {
+ const origin = $graphBox.data("origin");
+ const graph = $graphBox.data("graph");
+
+ // Get user selected range or fall back to default
+ const range = $graphBox.data("range") ?? $graphBox.data("defaultRange");
+
+ // Generate new image URL with timestamp
+ const timestamp = Date.now();
+ const imageUrl = `/cgi-bin/getrrdimage.cgi?origin=${origin}&graph=${graph}&range=${range}×tamp=${timestamp}`;
+
+ // Get graph image and set new URL
+ $graphBox.children("img").first().attr("src", imageUrl);
}
}
diff --git a/html/html/themes/ipfire/include/functions.pl b/html/html/themes/ipfire/include/functions.pl
index 445597e51..bc66d7fdb 100644
--- a/html/html/themes/ipfire/include/functions.pl
+++ b/html/html/themes/ipfire/include/functions.pl
@@ -115,7 +115,6 @@ print <<END;
<link rel="shortcut icon" href="/favicon.ico" />
<script src="/include/jquery.js"></script>
<script src="/include/wui.js" type="module"></script>
- <script src="/include/rrdimage.js"></script>
$extrahead
<script type="text/javascript">
--
2.37.1.windows.1
next prev parent reply other threads:[~2023-04-01 14:43 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-04-01 14:43 [PATCH 1/4] WUI: Start implementing a simple JavaScript framework Leo-Andres Hofmann
2023-04-01 14:43 ` Leo-Andres Hofmann [this message]
2023-04-01 14:43 ` [PATCH 3/4] WUI: Implement form confirmation dialog Leo-Andres Hofmann
2023-04-01 14:43 ` [PATCH 4/4] ovpnmain.cgi: Add confirm dialog to delete form Leo-Andres Hofmann
2023-04-11 12:58 ` [PATCH 1/4] WUI: Start implementing a simple JavaScript framework Michael Tremer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20230401144343.1483-2-hofmann@leo-andres.de \
--to=hofmann@leo-andres.de \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox