From 36bb267199d74e614e301b456574dd887f4d893b Mon Sep 17 00:00:00 2001 From: Boof <97455552+hexahigh@users.noreply.github.com> Date: Thu, 19 Jan 2023 12:10:36 +0100 Subject: [PATCH] Add files via upload --- js/offline.js | 275 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 275 insertions(+) create mode 100644 js/offline.js diff --git a/js/offline.js b/js/offline.js new file mode 100644 index 0000000..bd95c44 --- /dev/null +++ b/js/offline.js @@ -0,0 +1,275 @@ +/*! offline-js 0.7.13 */ +(function() { + var Offline, checkXHR, defaultOptions, extendNative, grab, handlers, init; + extendNative = function(to, from) { + var e, key, results, val; + results = []; + for (key in from.prototype) try { + val = from.prototype[key], null == to[key] && "function" != typeof val ? results.push(to[key] = val) :results.push(void 0); + } catch (_error) { + e = _error; + } + return results; + }, Offline = {}, null == Offline.options && (Offline.options = {}), defaultOptions = { + checks:{ + xhr:{ + url:function() { + return "/favicon.ico?_=" + Math.floor(1e9 * Math.random()); + }, + timeout:5e3 + }, + image:{ + url:function() { + return "/favicon.ico?_=" + Math.floor(1e9 * Math.random()); + } + }, + active:"xhr" + }, + checkOnLoad:!1, + interceptRequests:!0, + reconnect:!0 + }, grab = function(obj, key) { + var cur, i, j, len, part, parts; + for (cur = obj, parts = key.split("."), i = j = 0, len = parts.length; len > j && (part = parts[i], + cur = cur[part], "object" == typeof cur); i = ++j) ; + return i === parts.length - 1 ? cur :void 0; + }, Offline.getOption = function(key) { + var ref, val; + return val = null != (ref = grab(Offline.options, key)) ? ref :grab(defaultOptions, key), + "function" == typeof val ? val() :val; + }, "function" == typeof window.addEventListener && window.addEventListener("online", function() { + return setTimeout(Offline.confirmUp, 100); + }, !1), "function" == typeof window.addEventListener && window.addEventListener("offline", function() { + return Offline.confirmDown(); + }, !1), Offline.state = "up", Offline.markUp = function() { + return Offline.trigger("confirmed-up"), "up" !== Offline.state ? (Offline.state = "up", + Offline.trigger("up")) :void 0; + }, Offline.markDown = function() { + return Offline.trigger("confirmed-down"), "down" !== Offline.state ? (Offline.state = "down", + Offline.trigger("down")) :void 0; + }, handlers = {}, Offline.on = function(event, handler, ctx) { + var e, events, j, len, results; + if (events = event.split(" "), events.length > 1) { + for (results = [], j = 0, len = events.length; len > j; j++) e = events[j], results.push(Offline.on(e, handler, ctx)); + return results; + } + return null == handlers[event] && (handlers[event] = []), handlers[event].push([ ctx, handler ]); + }, Offline.off = function(event, handler) { + var _handler, ctx, i, ref, results; + if (null != handlers[event]) { + if (handler) { + for (i = 0, results = []; i < handlers[event].length; ) ref = handlers[event][i], + ctx = ref[0], _handler = ref[1], _handler === handler ? results.push(handlers[event].splice(i, 1)) :results.push(i++); + return results; + } + return handlers[event] = []; + } + }, Offline.trigger = function(event) { + var ctx, handler, j, len, ref, ref1, results; + if (null != handlers[event]) { + for (ref = handlers[event], results = [], j = 0, len = ref.length; len > j; j++) ref1 = ref[j], + ctx = ref1[0], handler = ref1[1], results.push(handler.call(ctx)); + return results; + } + }, checkXHR = function(xhr, onUp, onDown) { + var _onerror, _onload, _onreadystatechange, _ontimeout, checkStatus; + return checkStatus = function() { + return xhr.status && xhr.status < 12e3 ? onUp() :onDown(); + }, null === xhr.onprogress ? (_onerror = xhr.onerror, xhr.onerror = function() { + return onDown(), "function" == typeof _onerror ? _onerror.apply(null, arguments) :void 0; + }, _ontimeout = xhr.ontimeout, xhr.ontimeout = function() { + return onDown(), "function" == typeof _ontimeout ? _ontimeout.apply(null, arguments) :void 0; + }, _onload = xhr.onload, xhr.onload = function() { + return checkStatus(), "function" == typeof _onload ? _onload.apply(null, arguments) :void 0; + }) :(_onreadystatechange = xhr.onreadystatechange, xhr.onreadystatechange = function() { + return 4 === xhr.readyState ? checkStatus() :0 === xhr.readyState && onDown(), "function" == typeof _onreadystatechange ? _onreadystatechange.apply(null, arguments) :void 0; + }); + }, Offline.checks = {}, Offline.checks.xhr = function() { + var e, xhr; + xhr = new XMLHttpRequest(), xhr.offline = !1, xhr.open("HEAD", Offline.getOption("checks.xhr.url"), !0), + null != xhr.timeout && (xhr.timeout = Offline.getOption("checks.xhr.timeout")), + checkXHR(xhr, Offline.markUp, Offline.markDown); + try { + xhr.send(); + } catch (_error) { + e = _error, Offline.markDown(); + } + return xhr; + }, Offline.checks.image = function() { + var img; + return img = document.createElement("img"), img.onerror = Offline.markDown, img.onload = Offline.markUp, + void (img.src = Offline.getOption("checks.image.url")); + }, Offline.checks.down = Offline.markDown, Offline.checks.up = Offline.markUp, Offline.check = function() { + return Offline.trigger("checking"), Offline.checks[Offline.getOption("checks.active")](); + }, Offline.confirmUp = Offline.confirmDown = Offline.check, Offline.onXHR = function(cb) { + var _XDomainRequest, _XMLHttpRequest, monitorXHR; + return monitorXHR = function(req, flags) { + var _open; + return _open = req.open, req.open = function(type, url, async, user, password) { + return cb({ + type:type, + url:url, + async:async, + flags:flags, + user:user, + password:password, + xhr:req + }), _open.apply(req, arguments); + }; + }, _XMLHttpRequest = window.XMLHttpRequest, window.XMLHttpRequest = function(flags) { + var _overrideMimeType, _setRequestHeader, req; + return req = new _XMLHttpRequest(flags), monitorXHR(req, flags), _setRequestHeader = req.setRequestHeader, + req.headers = {}, req.setRequestHeader = function(name, value) { + return req.headers[name] = value, _setRequestHeader.call(req, name, value); + }, _overrideMimeType = req.overrideMimeType, req.overrideMimeType = function(type) { + return req.mimeType = type, _overrideMimeType.call(req, type); + }, req; + }, extendNative(window.XMLHttpRequest, _XMLHttpRequest), null != window.XDomainRequest ? (_XDomainRequest = window.XDomainRequest, + window.XDomainRequest = function() { + var req; + return req = new _XDomainRequest(), monitorXHR(req), req; + }, extendNative(window.XDomainRequest, _XDomainRequest)) :void 0; + }, init = function() { + return Offline.getOption("interceptRequests") && Offline.onXHR(function(arg) { + var xhr; + return xhr = arg.xhr, xhr.offline !== !1 ? checkXHR(xhr, Offline.markUp, Offline.confirmDown) :void 0; + }), Offline.getOption("checkOnLoad") ? Offline.check() :void 0; + }, setTimeout(init, 0), window.Offline = Offline; +}).call(this), function() { + var down, next, nope, rc, reset, retryIntv, tick, tryNow, up; + if (!window.Offline) throw new Error("Offline Reconnect brought in without offline.js"); + rc = Offline.reconnect = {}, retryIntv = null, reset = function() { + var ref; + return null != rc.state && "inactive" !== rc.state && Offline.trigger("reconnect:stopped"), + rc.state = "inactive", rc.remaining = rc.delay = null != (ref = Offline.getOption("reconnect.initialDelay")) ? ref :3; + }, next = function() { + var delay, ref; + return delay = null != (ref = Offline.getOption("reconnect.delay")) ? ref :Math.min(Math.ceil(1.5 * rc.delay), 3600), + rc.remaining = rc.delay = delay; + }, tick = function() { + return "connecting" !== rc.state ? (rc.remaining -= 1, Offline.trigger("reconnect:tick"), + 0 === rc.remaining ? tryNow() :void 0) :void 0; + }, tryNow = function() { + return "waiting" === rc.state ? (Offline.trigger("reconnect:connecting"), rc.state = "connecting", + Offline.check()) :void 0; + }, down = function() { + return Offline.getOption("reconnect") ? (reset(), rc.state = "waiting", Offline.trigger("reconnect:started"), + retryIntv = setInterval(tick, 1e3)) :void 0; + }, up = function() { + return null != retryIntv && clearInterval(retryIntv), reset(); + }, nope = function() { + return Offline.getOption("reconnect") && "connecting" === rc.state ? (Offline.trigger("reconnect:failure"), + rc.state = "waiting", next()) :void 0; + }, rc.tryNow = tryNow, reset(), Offline.on("down", down), Offline.on("confirmed-down", nope), + Offline.on("up", up); +}.call(this), function() { + var clear, flush, held, holdRequest, makeRequest, waitingOnConfirm; + if (!window.Offline) throw new Error("Requests module brought in without offline.js"); + held = [], waitingOnConfirm = !1, holdRequest = function(req) { + return Offline.trigger("requests:capture"), "down" !== Offline.state && (waitingOnConfirm = !0), + held.push(req); + }, makeRequest = function(arg) { + var body, name, password, ref, type, url, user, val, xhr; + xhr = arg.xhr, url = arg.url, type = arg.type, user = arg.user, password = arg.password, + body = arg.body, xhr.abort(), xhr.open(type, url, !0, user, password), ref = xhr.headers; + for (name in ref) val = ref[name], xhr.setRequestHeader(name, val); + return xhr.mimeType && xhr.overrideMimeType(xhr.mimeType), xhr.send(body); + }, clear = function() { + return held = []; + }, flush = function() { + var i, key, len, request, requests, url; + for (Offline.trigger("requests:flush"), requests = {}, i = 0, len = held.length; len > i; i++) request = held[i], + url = request.url.replace(/(\?|&)_=[0-9]+/, function(match, char) { + return "?" === char ? char :""; + }), requests[request.type.toUpperCase() + " - " + url] = request; + for (key in requests) request = requests[key], makeRequest(request); + return clear(); + }, setTimeout(function() { + return Offline.getOption("requests") !== !1 ? (Offline.on("confirmed-up", function() { + return waitingOnConfirm ? (waitingOnConfirm = !1, clear()) :void 0; + }), Offline.on("up", flush), Offline.on("down", function() { + return waitingOnConfirm = !1; + }), Offline.onXHR(function(request) { + var _onreadystatechange, _send, async, hold, xhr; + return xhr = request.xhr, async = request.async, xhr.offline !== !1 && (hold = function() { + return holdRequest(request); + }, _send = xhr.send, xhr.send = function(body) { + return request.body = body, _send.apply(xhr, arguments); + }, async) ? null === xhr.onprogress ? (xhr.addEventListener("error", hold, !1), + xhr.addEventListener("timeout", hold, !1)) :(_onreadystatechange = xhr.onreadystatechange, + xhr.onreadystatechange = function() { + return 0 === xhr.readyState ? hold() :4 === xhr.readyState && (0 === xhr.status || xhr.status >= 12e3) && hold(), + "function" == typeof _onreadystatechange ? _onreadystatechange.apply(null, arguments) :void 0; + }) :void 0; + }), Offline.requests = { + flush:flush, + clear:clear + }) :void 0; + }, 0); +}.call(this), function() { + var base, i, len, ref, state; + if (!Offline) throw new Error("Offline simulate brought in without offline.js"); + for (ref = [ "up", "down" ], i = 0, len = ref.length; len > i; i++) state = ref[i], + (document.querySelector("script[data-simulate='" + state + "']") || localStorage.OFFLINE_SIMULATE === state) && (null == Offline.options && (Offline.options = {}), + null == (base = Offline.options).checks && (base.checks = {}), Offline.options.checks.active = state); +}.call(this), function() { + var RETRY_TEMPLATE, TEMPLATE, _onreadystatechange, addClass, content, createFromHTML, el, flashClass, flashTimeouts, init, removeClass, render, roundTime; + if (!window.Offline) throw new Error("Offline UI brought in without offline.js"); + TEMPLATE = '