luci-app-nlbwmon: Fixed incorrect period parameter/display
authorJo-Philipp Wich <jo@mein.io>
Fri, 1 Feb 2019 18:54:32 +0000 (13:54 -0500)
committerJo-Philipp Wich <jo@mein.io>
Fri, 15 Feb 2019 11:21:51 +0000 (12:21 +0100)
Switch from using the unreliable string data constructor syntax to
a more explicit year / month / day variant and pass through the
period value as-is in order to ensure that the proper start date
is requested from the backend.

This should fix issues with prevent the display of older data
periods in the nlbwmon gui.

Ref: https://github.com/jow-/nlbwmon/issues/25
Ref: https://github.com/openwrt/luci/pull/2496
Suggested-by: Aktanusa <chanam.geo@yahoo.com>
[squashed commits, add a more thorough commit message]
Signed-off-by: Jo-Philipp Wich <jo@mein.io>
(backported from commit bd56c1aac650c9d60d9f66bb0c923b0346f3fa41)

(cherry picked from commit 30d9bc02b2a8194e93abb0943082f6630fb1acf6)

applications/luci-app-nlbwmon/luasrc/view/nlbw/display.htm

index 932c8849a7afcc6cd78cc66dae95cbf6508fe2be..73e58b1112fdea9392f9e62155160c325e8fda4a 100644 (file)
@@ -429,13 +429,15 @@ function renderPeriods()
        var sel = document.getElementById('nlbw.period');
 
        for (var e, i = trafficPeriods.length - 1; e = trafficPeriods[i]; i--) {
-               var d1 = new Date(e);
-               var d2, pd;
+               var ymd1 = e.split(/-/);
+               var d1 = new Date(+ymd1[0], +ymd1[1] - 1, +ymd1[2]);
+               var ymd2, d2, pd;
 
                if (i) {
-                       d2 = new Date(trafficPeriods[i - 1]);
+                       ymd2 = trafficPeriods[i - 1].split(/-/);
+                       d2 = new Date(+ymd2[0], +ymd2[1] - 1, +ymd2[2]);
                        d2.setDate(d2.getDate() - 1);
-                       pd = '%04d-%02d-%02d'.format(d1.getFullYear(), d1.getMonth() + 1, d1.getDate());
+                       pd = e;
                }
                else {
                        d2 = new Date();