diff --git a/public/service-worker.js b/public/service-worker.js index 0bc576c..a7a49a8 100644 --- a/public/service-worker.js +++ b/public/service-worker.js @@ -1,14 +1,14 @@ -const CACHE_NAME = 'static-cache-v13'; +const CACHE_NAME = 'static-cache-v14'; const FILES_TO_CACHE = [ '/offline.html', - '/static/v13/css/materialize.min.css', - '/static/v13/css/material-icons.css', - '/static/v13/css/local.css', - '/static/v13/js/jquery-3.4.1.min.js', - '/static/v13/js/materialize.min.js', - '/static/v13/js/travelynx-actions.min.js', - '/static/v13/js/autocomplete.min.js', - '/static/v13/js/geolocation.min.js', + '/static/v14/css/materialize.min.css', + '/static/v14/css/material-icons.css', + '/static/v14/css/local.css', + '/static/v14/js/jquery-3.4.1.min.js', + '/static/v14/js/materialize.min.js', + '/static/v14/js/travelynx-actions.min.js', + '/static/v14/js/autocomplete.min.js', + '/static/v14/js/geolocation.min.js', ]; self.addEventListener('install', (evt) => { diff --git a/public/static/css/material-icons.css b/public/static/css/material-icons.css index bf145f1..3287b4e 100644 --- a/public/static/css/material-icons.css +++ b/public/static/css/material-icons.css @@ -2,12 +2,12 @@ font-family: 'Material Icons'; font-style: normal; font-weight: 400; - src: url(/static/v13/fonts/MaterialIcons-Regular.eot); /* For IE6-8 */ + src: url(/static/v14/fonts/MaterialIcons-Regular.eot); /* For IE6-8 */ src: local('Material Icons'), local('MaterialIcons-Regular'), - url(/static/v13/fonts/MaterialIcons-Regular.woff2) format('woff2'), - url(/static/v13/fonts/MaterialIcons-Regular.woff) format('woff'), - url(/static/v13/fonts/MaterialIcons-Regular.ttf) format('truetype'); + url(/static/v14/fonts/MaterialIcons-Regular.woff2) format('woff2'), + url(/static/v14/fonts/MaterialIcons-Regular.woff) format('woff'), + url(/static/v14/fonts/MaterialIcons-Regular.ttf) format('truetype'); } .material-icons { diff --git a/public/static/js/travelynx-actions.js b/public/static/js/travelynx-actions.js index da8243e..e7ac84c 100644 --- a/public/static/js/travelynx-actions.js +++ b/public/static/js/travelynx-actions.js @@ -110,4 +110,7 @@ $(document).ready(function() { if ($('.publicstatuscol .autorefresh').length) { setTimeout(tvly_update_public, 20000); } + $(window).on('beforeunload', function () { + $('nav .preloader-wrapper').addClass('active'); + }); }); diff --git a/public/static/js/travelynx-actions.min.js b/public/static/js/travelynx-actions.min.js index 5b66281..e207b50 100644 --- a/public/static/js/travelynx-actions.min.js +++ b/public/static/js/travelynx-actions.min.js @@ -1 +1 @@ -function tvly_run(t,a,e){var n='error',c=$('
');t.hide(),t.after(c),$.post("/action",a,function(a){a.success?$(location).attr("href",a.redirect_to):(M.toast({html:n+" "+a.error}),c.remove(),e&&e(),t.append(" "+n),t.show())})}function tvly_update(){$.get("/ajax/status_card.html",function(t){$(".statuscol").html(t),tvly_reg_handlers(),setTimeout(tvly_update,2e4)}).fail(function(){$(".sync-failed-marker").css("display","block"),setTimeout(tvly_update,2e4)})}function tvly_update_public(){var t;$(".publicstatuscol").each(function(){t=$(this).data("user")}),$.get("/ajax/status/"+t+".html",function(t){$(".publicstatuscol").html(t),setTimeout(tvly_update_public,2e4)}).fail(function(){$(".sync-failed-marker").css("display","block"),setTimeout(tvly_update_public,2e4)})}function tvly_reg_handlers(){$(".action-checkin").click(function(){var t=$(this);tvly_run(t,{action:"checkin",station:t.data("station"),train:t.data("train")})}),$(".action-checkout").click(function(){var t=$(this),a={action:"checkout",station:t.data("station"),force:t.data("force")};tvly_run(t,a,function(){t.append(" – Ohne Echtzeitdaten auschecken?"),t.data("force",!0)})}),$(".action-undo").click(function(){var t=$(this);tvly_run(t,{action:"undo",undo_id:t.data("id")})}),$(".action-cancelled-from").click(function(){var t=$(this);tvly_run(t,{action:"cancelled_from",station:t.data("station"),train:t.data("train")})}),$(".action-cancelled-to").click(function(){var t=$(this);tvly_run(t,{action:"cancelled_to",station:t.data("station"),force:!0})}),$(".action-delete").click(function(){var t=$(this),a={action:"delete",id:t.data("id"),checkin:t.data("checkin"),checkout:t.data("checkout")};really_delete=confirm("Diese Zugfahrt wirklich löschen? Der Eintrag wird sofort aus der Datenbank entfernt und kann nicht wiederhergestellt werden."),really_delete&&tvly_run(t,a)})}$(document).ready(function(){tvly_reg_handlers(),$(".statuscol .autorefresh").length&&setTimeout(tvly_update,2e4),$(".publicstatuscol .autorefresh").length&&setTimeout(tvly_update_public,2e4)}); +function tvly_run(t,a,e){var n='error',c=$('
');t.hide(),t.after(c),$.post("/action",a,function(a){a.success?$(location).attr("href",a.redirect_to):(M.toast({html:n+" "+a.error}),c.remove(),e&&e(),t.append(" "+n),t.show())})}function tvly_update(){$.get("/ajax/status_card.html",function(t){$(".statuscol").html(t),tvly_reg_handlers(),setTimeout(tvly_update,2e4)}).fail(function(){$(".sync-failed-marker").css("display","block"),setTimeout(tvly_update,2e4)})}function tvly_update_public(){var t;$(".publicstatuscol").each(function(){t=$(this).data("user")}),$.get("/ajax/status/"+t+".html",function(t){$(".publicstatuscol").html(t),setTimeout(tvly_update_public,2e4)}).fail(function(){$(".sync-failed-marker").css("display","block"),setTimeout(tvly_update_public,2e4)})}function tvly_reg_handlers(){$(".action-checkin").click(function(){var t=$(this);tvly_run(t,{action:"checkin",station:t.data("station"),train:t.data("train")})}),$(".action-checkout").click(function(){var t=$(this),a={action:"checkout",station:t.data("station"),force:t.data("force")};tvly_run(t,a,function(){t.append(" – Ohne Echtzeitdaten auschecken?"),t.data("force",!0)})}),$(".action-undo").click(function(){var t=$(this);tvly_run(t,{action:"undo",undo_id:t.data("id")})}),$(".action-cancelled-from").click(function(){var t=$(this);tvly_run(t,{action:"cancelled_from",station:t.data("station"),train:t.data("train")})}),$(".action-cancelled-to").click(function(){var t=$(this);tvly_run(t,{action:"cancelled_to",station:t.data("station"),force:!0})}),$(".action-delete").click(function(){var t=$(this),a={action:"delete",id:t.data("id"),checkin:t.data("checkin"),checkout:t.data("checkout")};really_delete=confirm("Diese Zugfahrt wirklich löschen? Der Eintrag wird sofort aus der Datenbank entfernt und kann nicht wiederhergestellt werden."),really_delete&&tvly_run(t,a)})}$(document).ready(function(){tvly_reg_handlers(),$(".statuscol .autorefresh").length&&setTimeout(tvly_update,2e4),$(".publicstatuscol .autorefresh").length&&setTimeout(tvly_update_public,2e4),$(window).on("beforeunload",function(){$("nav .preloader-wrapper").addClass("active")})}); diff --git a/public/static/manifest.json b/public/static/manifest.json index 9f13d9f..221e283 100644 --- a/public/static/manifest.json +++ b/public/static/manifest.json @@ -3,27 +3,27 @@ "short_name": "Travelynx", "scope": "/", "icons": [{ - "src": "/static/v13/icons/icon-128x128.png", + "src": "/static/v14/icons/icon-128x128.png", "sizes": "128x128", "type": "image/png" }, { - "src": "/static/v13/icons/icon-144x144.png", + "src": "/static/v14/icons/icon-144x144.png", "sizes": "144x144", "type": "image/png" }, { - "src": "/static/v13/icons/icon-152x152.png", + "src": "/static/v14/icons/icon-152x152.png", "sizes": "152x152", "type": "image/png" }, { - "src": "/static/v13/icons/icon-192x192.png", + "src": "/static/v14/icons/icon-192x192.png", "sizes": "192x192", "type": "image/png" }, { - "src": "/static/v13/icons/icon-256x256.png", + "src": "/static/v14/icons/icon-256x256.png", "sizes": "256x256", "type": "image/png" }, { - "src": "/static/v13/icons/icon-512x512.png", + "src": "/static/v14/icons/icon-512x512.png", "sizes": "512x512", "type": "image/png" }], diff --git a/public/static/v12 b/public/static/v14 similarity index 100% rename from public/static/v12 rename to public/static/v14 diff --git a/templates/layouts/default.html.ep b/templates/layouts/default.html.ep index e52174d..934a84b 100644 --- a/templates/layouts/default.html.ep +++ b/templates/layouts/default.html.ep @@ -9,7 +9,7 @@ - % my $av = 'v13'; # asset version + % my $av = 'v14'; # asset version %= stylesheet "/static/${av}/css/materialize.min.css" @@ -31,11 +31,26 @@